diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 81e3deb36..6ab0888f4 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1,2 +1,3 @@ * @krille-chan -assets/l10n/*.arb @weblate \ No newline at end of file +pubspec.* @dependabot +lib/l10n/*.arb @weblate \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml index 485bfd8c5..d241cf918 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.yml +++ b/.github/ISSUE_TEMPLATE/bug_report.yml @@ -34,6 +34,28 @@ body: placeholder: "e.g. 1.12.0" validations: required: true + - type: dropdown + id: platform + attributes: + label: "Platform" + description: "Select the platform where the bug occurs." + options: + - Android (PlayStore) + - Android (F-Droid) + - Android (Other) + - iOS (iPhone) + - iOS (iPad) + - Web (Chrome(ium)) + - Web (Firefox) + - Web (Safari) + - Linux (Snap) + - Linux (Flatpak) + - Linux (Other) + - macOS (iOS/iPadOS version) + - macOS (Self-compiled) + - Windows (Self-compiled) + validations: + required: true - type: input id: platform-info attributes: diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml index 780f692f7..ddcf8edba 100644 --- a/.github/ISSUE_TEMPLATE/config.yml +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -1,5 +1,5 @@ -blank_issues_enabled: true +blank_issues_enabled: false contact_links: - name: 👬 FluffyChat Community - url: https://matrix.to/#/#fluffychat:matrix.org + url: https://matrix.to/#/#fluffy-space:matrix.org about: Please ask and answer questions here. diff --git a/.github/workflows/issue_pr_management.yaml b/.github/ISSUE_TEMPLATE/issue_pr_management.yml similarity index 84% rename from .github/workflows/issue_pr_management.yaml rename to .github/ISSUE_TEMPLATE/issue_pr_management.yml index bec4abca5..3a7509236 100644 --- a/.github/workflows/issue_pr_management.yaml +++ b/.github/ISSUE_TEMPLATE/issue_pr_management.yml @@ -12,14 +12,14 @@ jobs: steps: - uses: actions/stale@v9 with: - days-before-issue-stale: 120 + days-before-issue-stale: 365 days-before-issue-close: 14 stale-issue-label: "stale" - stale-issue-message: "This issue is stale because it has been open for 120 days with no activity." + stale-issue-message: "This issue is stale because it has been open for 365 days with no activity." close-issue-message: "This issue was closed because it has been inactive for 14 days since being marked as stale." - stale-pr-message: "This pull request is stale because it has been open for 120 days with no activity." + stale-pr-message: "This pull request is stale because it has been open for 365 days with no activity." close-pr-message: "This pull request was closed because it has been inactive for 14 days since being marked as stale." - days-before-pr-stale: 120 + days-before-pr-stale: 365 days-before-pr-close: 14 exempt-milestones: true exempt-assignees: krille-chan diff --git a/.github/PULL_REQUEST_TEMPLATE/pull_request_template.md b/.github/PULL_REQUEST_TEMPLATE/pull_request_template.md deleted file mode 100644 index c92536427..000000000 --- a/.github/PULL_REQUEST_TEMPLATE/pull_request_template.md +++ /dev/null @@ -1,21 +0,0 @@ -*Thank you so much for your contribution to FluffyChat ❤️❤️❤️* - -Please make sure that your Pull Request meet the following **acceptance criteria**: - -- [ ] Code formatting and import sorting has been done with `dart format lib/ test/` and `dart run import_sorter:main --no-comments` -- [ ] The commit message uses the format of [Conventional Commits](https://www.conventionalcommits.org) -- [ ] The commit message describes what has been changed, why it has been changed and how it has been changed -- [ ] Every new feature or change of the design/GUI is linked to an approved design proposal in an issue -- [ ] Every new feature in the app or the build system has a strategy how this will be tested and maintained from now on for every release, e.g. a volunteer who takes over maintainership - - -### Pull Request has been tested on: - -- [ ] Android -- [ ] iOS -- [ ] Browser (Chromium based) -- [ ] Browser (Firefox based) -- [ ] Browser (WebKit based) -- [ ] Desktop Linux -- [ ] Desktop Windows -- [ ] Desktop macOS \ No newline at end of file diff --git a/.github/actions/free_up_space/action.yaml b/.github/actions/free_up_space/action.yaml new file mode 100644 index 000000000..abe2c4b55 --- /dev/null +++ b/.github/actions/free_up_space/action.yaml @@ -0,0 +1,50 @@ +name: "Free up space" + +inputs: + target: + required: true + +runs: + using: "composite" + steps: + - name: Free up space + shell: bash + run: | + sudo rm -rf /usr/share/dotnet + sudo rm -rf /usr/local/share/boost + sudo rm -rf /usr/local/share/chromium + sudo rm -rf /usr/local/share/powershell + sudo rm -rf /usr/local/share/vcpkg + sudo rm -rf /usr/local/share/miniconda + sudo rm -rf /opt/ghc + sudo rm -rf /opt/hostedtoolcache/CodeQL + sudo rm -rf /opt/hostedtoolcache/go + sudo rm -rf /opt/hostedtoolcache/Python + sudo rm -rf /opt/hostedtoolcache/node + sudo rm -rf /opt/hostedtoolcache/R + sudo rm -rf /opt/hostedtoolcache/Java + sudo rm -rf /opt/hostedtoolcache/LLVM + sudo rm -rf /opt/hostedtoolcache/Swift + sudo rm -rf /opt/hostedtoolcache/Php + sudo rm -rf /opt/hostedtoolcache/Perl + sudo rm -rf /opt/hostedtoolcache/Scala + sudo rm -rf /opt/hostedtoolcache/Julia + sudo rm -rf /opt/hostedtoolcache/Mono + sudo rm -rf /opt/hostedtoolcache/PowerShell + sudo rm -rf /opt/hostedtoolcache/Crystal + sudo rm -rf /opt/hostedtoolcache/Elixir + sudo rm -rf /opt/hostedtoolcache/Erlang + sudo rm -rf /opt/hostedtoolcache/FSharp + sudo rm -rf /opt/hostedtoolcache/Haskell + sudo rm -rf /opt/hostedtoolcache/OCaml + sudo rm -rf /opt/hostedtoolcache/Sbt + sudo rm -rf /opt/hostedtoolcache/Solidity + sudo rm -rf /opt/hostedtoolcache/VisualStudio + sudo rm -rf /opt/hostedtoolcache/WinAppDriver + sudo rm -rf /opt/hostedtoolcache/Xamarin + sudo rm -rf /opt/hostedtoolcache/Yarn + sudo rm -rf /opt/hostedtoolcache/Zephyr + sudo rm -rf /opt/hostedtoolcache/zig + sudo rm -rf /opt/hostedtoolcache/zulu + sudo rm -rf /opt/hostedtoolcache/azcopy + echo "export CARGO_BUILD_JOBS=1" >> $GITHUB_ENV diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 2b993ea05..37557f77e 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -9,6 +9,9 @@ updates: commit-message: prefix: "build: " include: "scope" + assignees: + - "krille-chan" + open-pull-requests-limit: 5 - package-ecosystem: "github-actions" directory: "/" schedule: diff --git a/.github/pull_request_template.md b/.github/pull_request_template.md new file mode 100644 index 000000000..7f4e66ec9 --- /dev/null +++ b/.github/pull_request_template.md @@ -0,0 +1,14 @@ +*Thank you so much for your contribution to FluffyChat ❤️❤️❤️* + +- [ ] I have read and understood the [contributing guidelines](https://github.com/krille-chan/fluffychat/blob/main/CONTRIBUTING.md). + +### Pull Request has been tested on: + +- [ ] Android +- [ ] iOS +- [ ] Browser (Chromium based) +- [ ] Browser (Firefox based) +- [ ] Browser (WebKit based) +- [ ] Desktop Linux +- [ ] Desktop Windows +- [ ] Desktop macOS \ No newline at end of file diff --git a/.github/workflows/integrate.yaml b/.github/workflows/integrate.yaml index d487d6b4b..d06333bc5 100644 --- a/.github/workflows/integrate.yaml +++ b/.github/workflows/integrate.yaml @@ -8,13 +8,18 @@ jobs: code_tests: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 + - uses: webiny/action-conventional-commits@v1.3.1 + - run: ./scripts/generate-locale-config.sh + - run: git diff --exit-code - run: cat .github/workflows/versions.env >> $GITHUB_ENV - uses: subosito/flutter-action@v2 with: flutter-version: ${{ env.FLUTTER_VERSION }} cache: true - run: flutter pub get + - name: Check if pubspec.lock is up to date + run: git diff --exit-code pubspec.lock - run: flutter gen-l10n - name: Check formatting run: dart format lib/ test/ --set-exit-if-changed @@ -23,17 +28,30 @@ jobs: - name: Check license compliance run: dart run license_checker check-licenses -c licenses.yaml --problematic - run: flutter analyze - - name: Apply google services patch - run: git apply ./scripts/enable-android-google-services.patch + - run: dart run dart_code_linter:metrics analyze lib --reporter=github + - run: dart run dart_code_linter:metrics check-unused-code lib + - run: dart run dart_code_linter:metrics check-unused-files lib + - run: dart run dart_code_linter:metrics check-unused-l10n lib + - name: Check for commented-out Dart code with semicolons + run: | + if grep -R --include="*.dart" -nE '^[[:space:]]*//[^/<].*;[[:space:]]*$' lib/; then + echo "" + echo "❌ Found commented-out Dart code ending with semicolon." + exit 1 + fi + - name: Add Firebase Messaging + run: ./scripts/add-firebase-messaging.sh - run: flutter analyze - run: flutter test build_debug_apk: + needs: [ code_tests ] runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 + - uses: ./.github/actions/free_up_space - run: cat .github/workflows/versions.env >> $GITHUB_ENV - - uses: actions/setup-java@v4 + - uses: actions/setup-java@v5 with: java-version: ${{ env.JAVA_VERSION }} distribution: "zulu" @@ -41,50 +59,195 @@ jobs: with: flutter-version: ${{ env.FLUTTER_VERSION }} cache: true - - run: flutter pub get - - run: flutter build apk --debug + - uses: moonrepo/setup-rust@v1 + with: + cache: true + - name: Cache Gradle + uses: actions/cache@v5 + with: + path: | + ~/.gradle/caches + ~/.gradle/wrapper + key: gradle-${{ runner.os }}-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }} + restore-keys: gradle-${{ runner.os }}- + - run: ./scripts/add-firebase-messaging.sh + - run: flutter build apk --debug --target-platform android-x64 + - name: Upload Debug APK + uses: actions/upload-artifact@v7 + with: + name: debug-apk-x64 + path: build/app/outputs/flutter-apk/app-debug.apk build_debug_web: + needs: [ code_tests ] runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - uses: subosito/flutter-action@v2 with: flutter-version: ${{ env.FLUTTER_VERSION }} cache: true + - uses: moonrepo/setup-rust@v1 + - run: rustup component add rust-src --toolchain nightly-x86_64-unknown-linux-gnu - run: flutter pub get - name: Prepare web run: ./scripts/prepare-web.sh - - run: flutter build web + - run: flutter build web --dart-define=WITH_SEMANTICS=true + - name: Upload Web Build + uses: actions/upload-artifact@v7 + with: + name: Web Build + path: build/web build_debug_linux: - runs-on: ubuntu-latest + needs: [ code_tests ] + strategy: + matrix: + arch: [ x64, arm64 ] + runs-on: ${{ matrix.arch == 'arm64' && 'ubuntu-24.04-arm' || 'ubuntu-latest'}} steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - - uses: subosito/flutter-action@v2 - with: - flutter-version: ${{ env.FLUTTER_VERSION }} - cache: true - name: Install dependencies - run: sudo apt-get update && sudo apt-get install curl clang cmake ninja-build pkg-config libgtk-3-dev libblkid-dev liblzma-dev libjsoncpp-dev cmake-data libsecret-1-dev libsecret-1-0 librhash0 libssl-dev -y - - run: flutter pub get - - run: flutter build linux --target-platform linux-x64 + run: sudo apt-get update && sudo apt-get install git wget curl clang cmake ninja-build pkg-config libgtk-3-dev libblkid-dev liblzma-dev libjsoncpp-dev cmake-data libsecret-1-dev libsecret-1-0 librhash0 libwebkit2gtk-4.1-dev -y + - name: Install Flutter + run: | + git clone --branch ${{ env.FLUTTER_VERSION }} https://github.com/flutter/flutter.git + ./flutter/bin/flutter doctor + - uses: moonrepo/setup-rust@v1 + - run: ./flutter/bin/flutter pub get + - run: ./flutter/bin/flutter build linux --target-platform linux-${{ matrix.arch }} build_debug_ios: - runs-on: macos-latest + needs: [ code_tests ] + runs-on: macos-15 steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - uses: subosito/flutter-action@v2 with: flutter-version: ${{ env.FLUTTER_VERSION }} cache: true - - name: Setup Xcode version - uses: maxim-lobanov/setup-xcode@v1.6.0 - with: - xcode-version: latest + - name: Use Xcode 16.4 + run: sudo xcode-select --switch /Applications/Xcode_16.4.app - run: brew install sqlcipher + - uses: moonrepo/setup-rust@v1 + - name: Add Firebase Messaging + run: | + flutter pub add fcm_shared_isolate:0.1.0 + sed -i '' 's,//,,g' lib/utils/background_push.dart - run: flutter pub get - run: flutter build ios --no-codesign + + integration_test: + runs-on: ubuntu-latest + timeout-minutes: 60 + needs: [ build_debug_apk ] + strategy: + matrix: + api-level: [34] + env: + ANDROID_USER_HOME: /home/runner/.android + ANDROID_EMULATOR_HOME: /home/runner/.android + ANDROID_AVD_HOME: /home/runner/.android/avd + AVD_CONFIG_PATH: "~/.android/avd/test.avd/config.ini" + steps: + - uses: actions/checkout@v6 + - uses: actions/download-artifact@v8 + with: + name: debug-apk-x64 + path: . + - uses: ./.github/actions/free_up_space + # https://github.blog/changelog/2023-02-23-hardware-accelerated-android-virtualization-on-actions-windows-and-linux-larger-hosted-runners/ + - name: Enable KVM group perms + run: | + echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules + sudo udevadm control --reload-rules + sudo udevadm trigger --name-match=kvm + - name: AVD cache + uses: actions/cache@v5 + id: avd-cache + with: + path: ~/.android/* + key: avd-${{ matrix.api-level }}-integration_docker + - name: create AVD and generate snapshot for caching + if: steps.avd-cache.outputs.cache-hit != 'true' + uses: reactivecircus/android-emulator-runner@d94c3fbe4fe6a29e4a5ba47c12fb47677c73656b + with: + api-level: ${{ matrix.api-level }} + target: google_apis + arch: x86_64 + cores: 16 + ndk: 28.2.13676358 + force-avd-creation: false + disk-size: 4096M + ram-size: 4096M + sdcard-path-or-size: 4096M + emulator-options: -no-window -wipe-data -accel on -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none + script: | + cat ${{ env.AVD_CONFIG_PATH }} + + sed -i.bak 's/hw.lcd.density = .*/hw.lcd.density=420/' ${{ env.AVD_CONFIG_PATH }} + sed -i.bak 's/hw.lcd.height = .*/hw.lcd.height=1920/' ${{ env.AVD_CONFIG_PATH }} + sed -i.bak 's/hw.lcd.width = .*/hw.lcd.width=1080/' ${{ env.AVD_CONFIG_PATH }} + + if ! grep -q "hw.lcd.density" ${{ env.AVD_CONFIG_PATH }} && echo "hw.lcd.density = 420" >> ${{ env.AVD_CONFIG_PATH }}; then :; fi + if ! grep -q "hw.lcd.height" ${{ env.AVD_CONFIG_PATH }} && echo "hw.lcd.height = 1920" >> ${{ env.AVD_CONFIG_PATH }}; then :; fi + if ! grep -q "hw.lcd.width" ${{ env.AVD_CONFIG_PATH }} && echo "hw.lcd.width = 1080" >> ${{ env.AVD_CONFIG_PATH }}; then :; fi + + echo "Emulator settings (${{ env.AVD_CONFIG_PATH }})" + cat ${{ env.AVD_CONFIG_PATH }} + echo "Generated AVD snapshot for caching." + - uses: subosito/flutter-action@v2 + with: + flutter-version: ${{ env.FLUTTER_VERSION }} + cache: true + - uses: remarkablemark/setup-maestro-cli@v1 + - name: Load integration test env + run: cat integration_test/data/integration_users.env >> $GITHUB_ENV + - name: Prepare Homeserver + run: | + docker run -d --name synapse --tmpfs /data \ + --volume="$(pwd)/integration_test/synapse/data/homeserver.yaml":/data/homeserver.yaml:rw \ + --volume="$(pwd)/integration_test/synapse/data/localhost.log.config":/data/localhost.log.config:rw \ + -p 80:80 matrixdotorg/synapse:latest + while ! curl -XGET "http://$HOMESERVER/_matrix/client/v3/login" >/dev/null 2>/dev/null; do + echo "Waiting for homeserver to be available... (GET http://$HOMESERVER/_matrix/client/v3/login)" + sleep 2 + done + + echo "Homeserver is online!" + + # create users + curl -fS --retry 3 -XPOST -d "{\"username\":\"$USER1_NAME\", \"password\":\"$USER1_PW\", \"inhibit_login\":true, \"auth\": {\"type\":\"m.login.dummy\"}}" "http://$HOMESERVER/_matrix/client/r0/register" + curl -fS --retry 3 -XPOST -d "{\"username\":\"$USER2_NAME\", \"password\":\"$USER2_PW\", \"inhibit_login\":true, \"auth\": {\"type\":\"m.login.dummy\"}}" "http://$HOMESERVER/_matrix/client/r0/register" + + - name: Integration tests + id: integration_tests + uses: reactivecircus/android-emulator-runner@v2 + with: + api-level: ${{ matrix.api-level }} + target: google_apis + arch: x86_64 + cores: 16 + ndk: 28.2.13676358 + force-avd-creation: false + disk-size: 4096M + ram-size: 4096M + sdcard-path-or-size: 4096M + emulator-options: -no-snapshot-save -no-window -wipe-data -accel on -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none + script: | + flutter run --use-application-binary=$PWD/app-debug.apk > flutter_logs.txt 2>&1 & + FLUTTER_PID=$! + sleep 10 + maestro test integration_test/login.yaml --env HOMESERVER=10.0.2.2 --env USER1_NAME=${USER1_NAME} --env USER1_PW=${USER1_PW} + kill $FLUTTER_PID 2>/dev/null || true + cp flutter_logs.txt ~/.maestro/tests/ + - name: Upload Flutter and Maestro logs + if: failure() + uses: actions/upload-artifact@v7 + with: + name: maestro-logs + path: ~/.maestro/tests + if-no-files-found: ignore \ No newline at end of file diff --git a/.github/workflows/main_deploy.yaml b/.github/workflows/main_deploy.yaml index 1a817f006..4636ce7f7 100644 --- a/.github/workflows/main_deploy.yaml +++ b/.github/workflows/main_deploy.yaml @@ -14,18 +14,17 @@ jobs: deploy_web: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - uses: subosito/flutter-action@v2 with: flutter-version: ${{ env.FLUTTER_VERSION }} - - name: Remove Emoji Font - run: | - rm -rf fonts/NotoEmoji - yq -i 'del( .flutter.fonts[] | select(.family == "NotoEmoji") )' pubspec.yaml - - run: flutter pub get + - uses: moonrepo/setup-rust@v1 + - run: rustup component add rust-src --toolchain nightly-x86_64-unknown-linux-gnu - name: Prepare web run: ./scripts/prepare-web.sh + - run: rm ./assets/vodozemac/.gitignore + - run: flutter pub get - name: Build Release Web run: flutter build web --dart-define=FLUTTER_WEB_CANVASKIT_URL=canvaskit/ --release --source-maps --base-href "/nightly/" - run: mv build/web/ public @@ -40,9 +39,9 @@ jobs: deploy_playstore_internal: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - - uses: actions/setup-java@v4 + - uses: actions/setup-java@v5 with: java-version: ${{ env.JAVA_VERSION }} distribution: 'zulu' @@ -54,14 +53,14 @@ jobs: uses: ruby/setup-ruby@v1 with: ruby-version: '3.3' + - uses: ./.github/actions/free_up_space + - uses: moonrepo/setup-rust@v1 - name: Install Fastlane run: gem install fastlane -NV - - name: Apply Google Services Patch - run: git apply ./scripts/enable-android-google-services.patch - - name: Remove Emoji Font + - name: Add Firebase Messaging run: | - rm -rf fonts/NotoEmoji - yq -i 'del( .flutter.fonts[] | select(.family == "NotoEmoji") )' pubspec.yaml + echo '${{secrets.GOOGLE_SERVICES_JSON}}' | base64 -d > android/app/google-services.json + ./scripts/add-firebase-messaging.sh - run: flutter pub get - name: Prepare Android Release Build env: @@ -70,7 +69,10 @@ jobs: PLAYSTORE_DEPLOY_KEY: ${{ secrets.PLAYSTORE_DEPLOY_KEY }} run: ./scripts/prepare-android-release.sh - name: Build Android Release - run: flutter build appbundle --target-platform android-arm,android-arm64,android-x64 + run: flutter build appbundle --target-platform android-arm,android-arm64 + - name: Set changelog + working-directory: android/fastlane/metadata/android/en-US/changelogs + run: git log --no-merges -1 --pretty=%B > default.txt - name: Deploy Android Release run: | mkdir -p build/android diff --git a/.github/workflows/matrix_notify.yaml b/.github/workflows/matrix_notify.yaml new file mode 100644 index 000000000..fe4672808 --- /dev/null +++ b/.github/workflows/matrix_notify.yaml @@ -0,0 +1,59 @@ +name: Matrix Notification + +on: + issues: + types: [opened] + pull_request_target: + types: [opened] + +jobs: + notify: + runs-on: ubuntu-latest + steps: + - name: Send notification to Matrix room + env: + HOMESERVER: ${{ secrets.MATRIX_HOMESERVER }} + ACCESS_TOKEN: ${{ secrets.MATRIX_ACCESS_TOKEN }} + ROOM_ID: ${{ secrets.MATRIX_ROOM_ID }} + EVENT_NAME: ${{ github.event_name }} + ISSUE_TITLE: ${{ github.event.issue.title }} + ISSUE_URL: ${{ github.event.issue.html_url }} + ISSUE_LABELS: ${{ join(github.event.issue.labels.*.name, ', ') }} + ISSUE_AUTHOR: ${{ github.event.issue.user.login }} + PR_TITLE: ${{ github.event.pull_request.title }} + PR_URL: ${{ github.event.pull_request.html_url }} + PR_LABELS: ${{ join(github.event.pull_request.labels.*.name, ', ') }} + PR_AUTHOR: ${{ github.event.pull_request.user.login }} + run: | + if [ "${EVENT_NAME}" = "issues" ]; then + EMOJI="📝" + PREFIX="New Issue" + TITLE="${ISSUE_TITLE}" + URL="${ISSUE_URL}" + LABELS="${ISSUE_LABELS}" + AUTHOR="${ISSUE_AUTHOR}" + else + EMOJI="🔀" + PREFIX="New Pull Request" + TITLE="${PR_TITLE}" + URL="${PR_URL}" + LABELS="${PR_LABELS}" + AUTHOR="${PR_AUTHOR}" + fi + + AUTHOR_URL="https://github.com/${AUTHOR}" + PLAIN="${EMOJI} ${PREFIX} by ${AUTHOR}: ${TITLE} - ${URL}" + HTML="

${EMOJI} ${PREFIX}

" + HTML="${HTML}${TITLE}
" + HTML="${HTML}👤 ${AUTHOR}" + if [ -n "${LABELS}" ]; then + HTML="${HTML}
🏷️ ${LABELS}" + fi + TXN_ID=$(date +%s%N) + + curl -s -o /dev/null -w "%{http_code}" -X PUT \ + "${HOMESERVER}/_matrix/client/v3/rooms/${ROOM_ID}/send/m.room.message/${TXN_ID}" \ + -H "Authorization: Bearer ${ACCESS_TOKEN}" \ + -H "Content-Type: application/json" \ + -d "$(jq -n --arg body "$PLAIN" --arg html "$HTML" \ + '{"msgtype":"m.notice","body":$body,"format":"org.matrix.custom.html","formatted_body":$html}')" \ No newline at end of file diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 1a0e42e8a..09275b7ec 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -17,27 +17,24 @@ jobs: build_web: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - uses: subosito/flutter-action@v2 with: flutter-version: ${{ env.FLUTTER_VERSION }} cache: true - - name: Install dependencies - run: sudo apt-get update && sudo apt-get install nodejs -y - - name: Remove Emoji Font - run: | - rm -rf fonts/NotoEmoji - yq -i 'del( .flutter.fonts[] | select(.family == "NotoEmoji") )' pubspec.yaml + - uses: moonrepo/setup-rust@v1 + - run: rustup component add rust-src --toolchain nightly-x86_64-unknown-linux-gnu - run: flutter pub get - name: Prepare web run: ./scripts/prepare-web.sh + - run: rm ./assets/vodozemac/.gitignore - name: Build Release Web - run: flutter build web --dart-define=FLUTTER_WEB_CANVASKIT_URL=canvaskit/ --release --source-maps --base-href "/web/" + run: flutter build web --dart-define=FLUTTER_WEB_CANVASKIT_URL=canvaskit/ --release --source-maps - name: Create archive run: tar -czf fluffychat-web.tar.gz build/web/ - name: Upload Web Build - uses: actions/upload-artifact@v4 + uses: actions/upload-artifact@v7 with: name: Web Build path: fluffychat-web.tar.gz @@ -52,11 +49,11 @@ jobs: asset_content_type: application/gzip - name: Build Website run: | - cd docs && npx tailwindcss -o ./tailwind.css --minify && cd .. - mv docs public - mv repo public || true - mv build/web/ public/web - cp public/web -r public/nightly + mkdir public + mkdir public/nightly + cp -r build/web/* public/ + cp -r build/web/* public/nightly/ + echo "app.fluffy.chat" >> public/CNAME - name: Deploy to GitHub Pages if: startsWith(github.ref, 'refs/tags/v') uses: peaceiris/actions-gh-pages@v4 @@ -64,14 +61,14 @@ jobs: personal_token: ${{ secrets.PAGES_DEPLOY_TOKEN }} publish_dir: ./public publish_branch: gh-pages - cname: fluffychat.im + cname: app.fluffy.chat build_apk: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - - uses: actions/setup-java@v4 + - uses: actions/setup-java@v5 with: java-version: ${{ env.JAVA_VERSION }} distribution: 'zulu' @@ -79,12 +76,12 @@ jobs: with: flutter-version: ${{ env.FLUTTER_VERSION }} cache: true - - name: Apply Google Services Patch - run: git apply ./scripts/enable-android-google-services.patch - - name: Remove Emoji Font + - name: Add Firebase Messaging run: | - rm -rf fonts/NotoEmoji - yq -i 'del( .flutter.fonts[] | select(.family == "NotoEmoji") )' pubspec.yaml + echo '${{secrets.GOOGLE_SERVICES_JSON}}' | base64 -d > android/app/google-services.json + ./scripts/add-firebase-messaging.sh + - uses: ./.github/actions/free_up_space + - uses: moonrepo/setup-rust@v1 - run: flutter pub get - name: Prepare Android Release Build env: @@ -92,7 +89,7 @@ jobs: FDROID_KEY_PASS: ${{ secrets.FDROID_KEY_PASS }} PLAYSTORE_DEPLOY_KEY: ${{ secrets.PLAYSTORE_DEPLOY_KEY }} run: ./scripts/prepare-android-release.sh - - run: flutter build apk --release + - run: flutter build apk --release --target-platform android-arm,android-arm64 - name: Upload to release uses: actions/upload-release-asset@v1 env: @@ -104,36 +101,40 @@ jobs: asset_content_type: application/vnd.android.package-archive build_linux: - runs-on: ubuntu-latest + strategy: + matrix: + arch: [ x64, arm64 ] + runs-on: ${{ matrix.arch == 'arm64' && 'ubuntu-24.04-arm' || 'ubuntu-latest'}} steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - - uses: subosito/flutter-action@v2 - with: - flutter-version: 3.19.6 # Workaround for not working on 3.22 - cache: true - name: Install dependencies - run: sudo apt-get update && sudo apt-get install curl clang cmake ninja-build pkg-config libgtk-3-dev libblkid-dev liblzma-dev libjsoncpp-dev cmake-data libsecret-1-dev libsecret-1-0 librhash0 libssl-dev -y - - run: flutter pub get - - run: flutter build linux --release --target-platform linux-x64 + run: sudo apt-get update && sudo apt-get install curl clang cmake ninja-build pkg-config libgtk-3-dev libblkid-dev liblzma-dev libjsoncpp-dev cmake-data libsecret-1-dev libsecret-1-0 librhash0 libwebkit2gtk-4.1-dev -y + - name: Install Flutter + run: | + git clone --branch ${{ env.FLUTTER_VERSION }} https://github.com/flutter/flutter.git + ./flutter/bin/flutter doctor + - uses: moonrepo/setup-rust@v1 + - run: ./flutter/bin/flutter pub get + - run: ./flutter/bin/flutter build linux --target-platform linux-${{ matrix.arch }} - name: Create archive - run: tar -czf fluffychat-linux-x64.tar.gz -C build/linux/x64/release/bundle/ . + run: tar -czf fluffychat-linux-${{ matrix.arch }}.tar.gz -C build/linux/${{ matrix.arch }}/release/bundle/ . - name: Upload to release uses: actions/upload-release-asset@v1 env: GITHUB_TOKEN: ${{ secrets.PAGES_DEPLOY_TOKEN }} with: upload_url: ${{ github.event.release.upload_url }} - asset_path: fluffychat-linux-x64.tar.gz - asset_name: fluffychat-linux-x64.tar.gz + asset_path: fluffychat-linux-${{ matrix.arch }}.tar.gz + asset_name: fluffychat-linux-${{ matrix.arch }}.tar.gz asset_content_type: application/gzip deploy_playstore: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v6 - run: cat .github/workflows/versions.env >> $GITHUB_ENV - - uses: actions/setup-java@v4 + - uses: actions/setup-java@v5 with: java-version: ${{ env.JAVA_VERSION }} distribution: 'zulu' @@ -145,14 +146,15 @@ jobs: uses: ruby/setup-ruby@v1 with: ruby-version: '3.3' + - uses: ./.github/actions/free_up_space + - uses: moonrepo/setup-rust@v1 - name: Install Fastlane + working-directory: android run: gem install fastlane -NV - - name: Apply Google Services Patch - run: git apply ./scripts/enable-android-google-services.patch - - name: Remove Emoji Font + - name: Add Firebase Messaging run: | - rm -rf fonts/NotoEmoji - yq -i 'del( .flutter.fonts[] | select(.family == "NotoEmoji") )' pubspec.yaml + echo '${{secrets.GOOGLE_SERVICES_JSON}}' | base64 -d > android/app/google-services.json + ./scripts/add-firebase-messaging.sh - run: flutter pub get - name: Prepare Android Release Build env: @@ -161,7 +163,7 @@ jobs: PLAYSTORE_DEPLOY_KEY: ${{ secrets.PLAYSTORE_DEPLOY_KEY }} run: ./scripts/prepare-android-release.sh - name: Build Android Release - run: flutter build appbundle --target-platform android-arm,android-arm64,android-x64 + run: flutter build appbundle --target-platform android-arm,android-arm64 - name: Get Tag Name id: tag_name run: echo "::set-output name=tag::$(echo ${GITHUB_REF#refs/tags/})" @@ -180,28 +182,6 @@ jobs: fi cd .. - promote_snapcraft: - runs-on: ubuntu-latest - env: - SNAPCRAFT_STORE_CREDENTIALS: ${{ secrets.SNAPCRAFT_TOKEN }} - steps: - - name: Check out Git repository - uses: actions/checkout@v4 - - name: Install Snapcraft - uses: samuelmeuli/action-snapcraft@v2 - - name: Get Tag Name - id: tag_name - run: echo "::set-output name=tag::$(echo ${GITHUB_REF#refs/tags/})" - - name: Promote Snap - env: # Workaround for https://github.com/snapcore/snapcraft/issues/4439 - SNAPCRAFT_HAS_TTY: "true" - run: | - if [[ $GITHUB_REF_NAME == rc* ]]; then - yes | snapcraft promote fluffychat --from-channel edge --to-channel candidate - else - yes | snapcraft promote fluffychat --from-channel edge --to-channel stable - fi - deploy_docker: runs-on: ubuntu-latest permissions: @@ -209,7 +189,7 @@ jobs: packages: write steps: - name: Check out Git repository - uses: actions/checkout@v4 + uses: actions/checkout@v6 - name: Log in to the Container registry uses: docker/login-action@v3 with: @@ -222,7 +202,7 @@ jobs: with: images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} - name: Build and push Docker image - uses: docker/build-push-action@v5 + uses: docker/build-push-action@v6 with: context: . push: true diff --git a/.github/workflows/stale.yaml b/.github/workflows/stale.yaml new file mode 100644 index 000000000..4d7ecce82 --- /dev/null +++ b/.github/workflows/stale.yaml @@ -0,0 +1,21 @@ +name: 'Close stale issues and PRs' +on: + schedule: + - cron: '30 1 * * *' + +jobs: + stale: + runs-on: ubuntu-latest + steps: + - uses: actions/stale@v10 + with: + stale-issue-message: 'This issue is stale because it has been open 365 days with no activity. Remove stale label or comment or this will be closed in 30 days.' + stale-pr-message: 'This PR is stale because it has been open 365 days with no activity. Remove stale label or comment or this will be closed in 30 days.' + close-issue-message: 'This issue was closed because it has been stalled for 30 days with no activity.' + close-pr-message: 'This PR was closed because it has been stalled for 30 days with no activity.' + days-before-issue-stale: 365 + days-before-pr-stale: 365 + days-before-issue-close: 30 + days-before-pr-close: 30 + exempt-all-assignees: true + operations-per-run: 1000 \ No newline at end of file diff --git a/.github/workflows/versions.env b/.github/workflows/versions.env index 4d10c42f4..e5d1f0b2b 100644 --- a/.github/workflows/versions.env +++ b/.github/workflows/versions.env @@ -1,2 +1,2 @@ -FLUTTER_VERSION=3.22.2 +FLUTTER_VERSION=3.41.2 JAVA_VERSION=17 diff --git a/.gitignore b/.gitignore index 0ce56e79e..ba0d23ffa 100644 --- a/.gitignore +++ b/.gitignore @@ -13,7 +13,8 @@ prime # libolm package -/assets/js/package +web/Imaging.js +web/Imaging.wasm # IntelliJ related *.iml @@ -49,10 +50,11 @@ docs/tailwind.css android/key.jks android/keys.json android/Gemfile.lock -lib/l10n_old +lib/l10n/*.dart ios/Flutter/.last_build_id ios/Podfile.lock ios/Runner.ipa +ios/Runner/GoogleServices-Info.plist /windows/out /winuwp/out @@ -60,3 +62,13 @@ ios/Runner.ipa /macos/out .vs olm +docs/node_modules +rust + +libcrypto.3.dylib +android/app/src/main/jniLibs/** +android/app/google-services.json +web/pkg/package.json +web/pkg/vodozemac_bindings_dart_bg.wasm +web/pkg/vodozemac_bindings_dart.js +web/native_executor.js* diff --git a/.metadata b/.metadata index 236851946..ab6d41f12 100644 --- a/.metadata +++ b/.metadata @@ -4,7 +4,7 @@ # This file should be version controlled and should not be manually edited. version: - revision: "abb292a07e20d696c4568099f918f6c5f330e6b0" + revision: "fcf2c11572af6f390246c056bc905eca609533a0" channel: "stable" project_type: app @@ -13,11 +13,11 @@ project_type: app migration: platforms: - platform: root - create_revision: abb292a07e20d696c4568099f918f6c5f330e6b0 - base_revision: abb292a07e20d696c4568099f918f6c5f330e6b0 - - platform: linux - create_revision: abb292a07e20d696c4568099f918f6c5f330e6b0 - base_revision: abb292a07e20d696c4568099f918f6c5f330e6b0 + create_revision: fcf2c11572af6f390246c056bc905eca609533a0 + base_revision: fcf2c11572af6f390246c056bc905eca609533a0 + - platform: android + create_revision: fcf2c11572af6f390246c056bc905eca609533a0 + base_revision: fcf2c11572af6f390246c056bc905eca609533a0 # User provided section diff --git a/CHANGELOG.md b/CHANGELOG.md index 83968b329..989fe36f1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,899 @@ +## v2.4.0 +FluffyChat 2.4.0 adds a new improved GUI for managing stickers with tutorials how to +easily add your own sticker packs. +It also improves the search and image gallery in chats, especially encrypted chats. +Besides that this update comes with a lot of fixes and improvements under the hood. + +- feat: Create new sticker packs (krille-chan) +- feat: Edit displayname and attribution for sticker packs (krille-chan) +- feat: Improved search (Christian Kußowski) +- feat: Set usage of custom emojis and stickers (krille-chan) +- feat: Upload multiple stickers at once (krille-chan) +- build: (deps): bump actions/checkout from 5 to 6 (dependabot[bot]) +- build: (deps): bump animations from 2.1.0 to 2.1.1 (dependabot[bot]) +- build: (deps): bump device_info_plus from 12.2.0 to 12.3.0 (dependabot[bot]) +- build: (deps): bump emoji_picker_flutter from 4.3.0 to 4.4.0 (dependabot[bot]) +- build: (deps): bump file_picker from 10.3.6 to 10.3.7 (dependabot[bot]) +- build: (deps): bump file_picker from 10.3.7 to 10.3.8 (dependabot[bot]) +- build: (deps): bump file_selector from 1.0.4 to 1.1.0 (dependabot[bot]) +- build: (deps): bump flutter_foreground_task from 9.1.0 to 9.2.0 (dependabot[bot]) +- build: (deps): bump flutter_webrtc from 1.2.0 to 1.2.1 (dependabot[bot]) +- build: (deps): bump go_router from 17.0.0 to 17.0.1 (dependabot[bot]) +- build: (deps): bump image from 4.5.4 to 4.6.0 (dependabot[bot]) +- build: (deps): bump image from 4.6.0 to 4.7.1 (dependabot[bot]) +- build: (deps): bump image from 4.7.1 to 4.7.2 (dependabot[bot]) +- build: (deps): bump matrix from 4.0.0 to 4.0.1 (dependabot[bot]) +- build: (deps): bump shared_preferences from 2.5.3 to 2.5.4 (dependabot[bot]) +- build: (deps): bump translations_cleaner from 0.0.5 to 0.1.0 (dependabot[bot]) +- build: (deps): bump universal_html from 2.2.4 to 2.3.0 (dependabot[bot]) +- build: Reenable shrink resources and minify in gradle (Christian Kußowski) +- build: Upgrade to flutter 3.38.4 (Christian Kußowski) +- build: Use matrix sdk vom pub.dev again (Christian Kußowski) +- chore(translations): Translated using Weblate (Basque) (xabirequejo) +- chore(translations): Translated using Weblate (Belarusian) (Alex Katon) +- chore(translations): Translated using Weblate (Bengali) (Kom nake) +- chore(translations): Translated using Weblate (Chinese (Simplified Han script)) (Creeper) +- chore(translations): Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- chore(translations): Translated using Weblate (Croatian) (Milo Ivir) +- chore(translations): Translated using Weblate (Czech) (arxari) +- chore(translations): Translated using Weblate (Dutch) (Jelv) +- chore(translations): Translated using Weblate (Estonian) (Priit Jõerüüt) +- chore(translations): Translated using Weblate (Finnish) (Ricky Tigg) +- chore(translations): Translated using Weblate (French) (hugues de keyzer) +- chore(translations): Translated using Weblate (Galician) (josé m.) +- chore(translations): Translated using Weblate (Georgian) (Nicholas Winterhalter) +- chore(translations): Translated using Weblate (Georgian) (Temuri Doghonadze) +- chore(translations): Translated using Weblate (German) (Bella) +- chore(translations): Translated using Weblate (German) (nautilusx) +- chore(translations): Translated using Weblate (Greek) (Rain4Cats) +- chore(translations): Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- chore(translations): Translated using Weblate (Italian) (Alessio Olivieri) +- chore(translations): Translated using Weblate (Italian) (Claudio Maradonna) +- chore(translations): Translated using Weblate (Latvian) (Edgars Andersons) +- chore(translations): Translated using Weblate (Norwegian Bokmål) (Frank Paul Silye) +- chore(translations): Translated using Weblate (Portuguese (Brazil)) (LucasMZ) +- chore(translations): Translated using Weblate (Russian) (BeMeritus) +- chore(translations): Translated using Weblate (Russian) (Christian) +- chore(translations): Translated using Weblate (Russian) (Дмитрий Михирев) +- chore(translations): Translated using Weblate (Serbian) (Luka) +- chore(translations): Translated using Weblate (Spanish) (Kimby) +- chore(translations): Translated using Weblate (Ukrainian) (Andriy Kushnir) +- chore(translations): Translated using Weblate (Ukrainian) (Ihor Hordiichuk) +- chore(translations): Translated using Weblate (Uzbek) (BeMeritus) +- chore(translations): Translated using Weblate (Uzbek) (Maftuna Vohidjonovna) +- chore: Allow all chars for emoji search (Christian Kußowski) +- chore: Allow export of readonly sticker packs (Christian Kußowski) +- chore: delete unrelated line (ShootingStarDragons) +- chore: Display attribution for sticker packs (krille-chan) +- chore: Escape title in check duplicates job (Christian Kußowski) +- chore: ignore for now deprecated regex (Christian Kußowski) +- chore: Improve room custom emote UX (krille-chan) +- chore: Improve sticker editor UX (krille-chan) +- chore: Improve text selection color for messages (Christian Kußowski) +- chore: Improve via calculation (Christian Kußowski) +- chore: Increase padding for code blocks (Christian Kußowski) +- chore: Link how do I get stickers FAQ entry (Christian Kußowski) +- chore: Localize emoji picker (Christian Kußowski) +- chore: Make attribution url field clickable (Christian Kußowski) +- chore: Make cross signing self sign mandatory for bootstrap (Christian Kußowski) +- chore: make locale for emoji suggestions configureable (krille-chan) +- chore: Make sticker previews in editor clickable (krille-chan) +- chore: Make stickers smaller than normal image messages (Christian Kußowski) +- chore: Override sqlcipher license (Christian Kußowski) +- chore: Remove horizontal scrolling for code blocks (Christian Kußowski) +- chore: remove the userId param (ShootingStarDragons) +- chore: Replace copy action with pin event action in UI (Christian Kußowski) +- chore: Request keys for last room messages after bootstrap (krille-chan) +- chore: Simplify adaptive bottom sheet code (Christian Kußowski) +- chore: Update privacy policy links (Christian Kußowski) +- chore: Update start poll design (Christian Kußowski) +- chore: Update user device keys before creating bootstrap (Christian Kußowski) +- chore: Use license_checker from pub again (Christian Kußowski) +- chore: Wait for secrets after bootstrap verification (Christian Kußowski) +- Fix regression after new linter rules (Andriy Kushnir) +- fix: Better wait for secrets after verification bootstrap (Christian Kußowski) +- fix: Broken ruzzian plurals (Christian Kußowski) +- fix: Do not auto load history in rooms with collapsed state only (Christian Kußowski) +- fix: Do not display empty file description body (Christian Kußowski) +- fix: Do not render html in unformatted messages (Christian Kußowski) +- fix: Do not request hero users for rooms with name (Christian Kußowski) +- fix: enable users without passwords to delete their accounts by using uia request in account deletion (ggurdin) +- fix: Hide no fcm warning after dismissed (Christian Kußowski) +- fix: jump cannot work properly when there are multi users (ShootingStarDragons) +- fix: Make keyboard moving bottom sheet up (Christian Kußowski) +- fix: No description for video and audio messages displayed (Christian Kußowski) +- fix: Render not permitted html tags as text instead of hiding (Christian Kußowski) +- fix: Scrolling in fragmented timeline (Christian Kußowski) +- fix: spoiler formatting in reply (denalena) +- fix: State problem when not changing emote name (krille-chan) +- fix: Unlock app with leading 0 in pin is not possible (Christian Kußowski) +- fix: when user has multi counts,notification not works well (ShootingStarDragons) +- refactor: Adjust state event design (Christian Kußowski) +- refactor: Always open Chat Backup as page right after login (Christian Kußowski) +- refactor: Display all sticker packs in same editor with filterchips (krille-chan) +- refactor: File selector just use default FileType and remove not working zip selector (Christian Kußowski) +- refactor: Improved design and UX for sticker editor (krille-chan) +- refactor: Remove native imaging and enable web worker (Christian Kußowski) +- refactor: Remove unused feature tor browser detector (Christian Kußowski) +- refactor: Remove unused html onfocus streams (Christian Kußowski) +- refactor: Remove unused msix (Christian Kußowski) +- refactor: Remove workaround for download files (Christian Kußowski) +- refactor: Update flutter lints (Christian Kußowski) +- refactor: Update to Dart 3.10 with . shorthands (Christian Kußowski) +- refactor: Use localized emojis for suggestion input (krille-chan) +- refactor: Use own highlight rendering with working scrollbar and text selection (Christian Kußowski) +- chore: Update links to matrix spaces to avoid confusion (Andriy Kushnir) + +## v2.3.0 + +FluffyChat v2.3.0 fixes a possible database corruption bug on Android, also fixes a +major performance leak and introduces polls and threads. + +- feat: Implement polls (Christian Kußowski) +- feat: Implement threads (krille-chan) +- fix: Database corruption because notification tab isolate starts too late (Christian Kußowski) +- fix: Import sticker packs (Christian Kußowski) +- refactor: Improved UIA support for OIDC and SSO (Christian Kußowski) +- refactor: Invite users when upgrading private room (Christian Kußowski) +- build: (deps): bump cross_file from 0.3.4+2 to 0.3.5 (dependabot[bot]) +- build: (deps): bump file_picker from 10.3.3 to 10.3.6 (dependabot[bot]) +- build: (deps): bump go_router from 16.3.0 to 17.0.0 (dependabot[bot]) +- build: (deps): bump http from 1.5.0 to 1.6.0 (dependabot[bot]) +- build: (deps): bump image_picker from 1.2.0 to 1.2.1 (dependabot[bot]) +- build: (deps): bump qr_code_scanner_plus from 2.0.13 to 2.0.14 (dependabot[bot]) +- build: (deps): bump video_player from 2.10.0 to 2.10.1 (dependabot[bot]) +- build: Switch back to stable web auth package (krille-chan) +- build: Use matrix sdk 4.0.0 (Christian Kußowski) +- build: Use secure storage from pub.dev again (krille-chan) +- chore: Remove Notification actions when using UnifiedPush (Christian Kußowski) +- chore(translations): Added translation using Weblate (Uzbek) (bahrom04) +- chore(translations): Translated using Weblate (Basque) (xabirequejo) +- chore(translations): Translated using Weblate (Belarusian) (Alex Katon) +- chore(translations): Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- chore(translations): Translated using Weblate (Dutch) (Jelv) +- chore(translations): Translated using Weblate (Estonian) (Priit Jõerüüt) +- chore(translations): Translated using Weblate (Finnish) (Priit Jõerüüt) +- chore(translations): Translated using Weblate (Finnish) (Ricky Tigg) +- chore(translations): Translated using Weblate (French) (luneth) +- chore(translations): Translated using Weblate (Galician) (josé m.) +- chore(translations): Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- chore(translations): Translated using Weblate (Latvian) (Edgars Andersons) +- chore(translations): Translated using Weblate (Norwegian Bokmål) (Frank Paul Silye) +- chore(translations): Translated using Weblate (Uzbek) (bahrom04) +- chore(translations): Translated using Weblate (Uzbek) (BeMeritus) + +## v2.2.0 + +FluffyChat 2.2.0 introduces a new UX for spaces and adds support for restricted +join rules. + +The app also now has a new design for recording voice messages including a new +pause button. + +You also now see the progress when downloading files. + +On web the performance for image compressing has been drastically improved. Also +the config.json file loading has finally been fixed. Please be aware that the format +has changed as the available configs are now generated automatically. + +Did you know that you can set a lot of additional configs in the new config viewer +inside the app? This now supports much more options but please use with care! + +On Android FluffyChat now supports notification actions (reply and mark as read) and +also now supports Android Auto integration. Please do not cause an accident when using +the app while driving! + +On iOS the notifications are now localized. Stay tuned for more improvements on iOS +notifications in the next releases! + +Besides that this release brings a ton of bug fixes and performance improvements and +of course updated translations. Big thanks to all the volunteers who have helped on weblate! + +- feat: Add donation buttons except for PlayStore&AppStore version (Christian Kußowski) +- feat: Add iOS Notification Service Extension for localizable push notifications (Christian Kußowski) +- feat: Add notification actions (krille-chan) +- feat: Add support for restricted join rule (Christian Kußowski) +- feat: Display progress for downloading content (Christian Kußowski) +- feat: Display progress on redact events and clear archive dialogs (Christian Kußowski) +- feat: Enable native imaging for web (Christian Kußowski) +- feat: Forward notifications to Android Auto (Christian Kußowski) +- feat: Nicer record voice message UI with pause function (Christian Kußowski) +- feat: Notification actions on android (krille-chan) +- design: Improved spaces UX (Christian Kußowski) +- fix: Correctly pass through obscure text (Christian Kußowski) +- fix: Create a subdirectory in the tmp directory (Inex Code) +- fix: Cupertino text dialogs (Christian Kußowski) +- fix: Null pointer crash in chat list item (Christian Kußowski) +- chore(translations): Translated using Weblate (Arabic) (jamazi) +- chore(translations): Translated using Weblate (Basque) (xabirequejo) +- chore(translations): Translated using Weblate (Belarusian) (Alex Katon) +- chore(translations): Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- chore(translations): Translated using Weblate (Croatian) (Milo Ivir) +- chore(translations): Translated using Weblate (Czech) (Flibble) +- chore(translations): Translated using Weblate (Dutch) (Jelv) +- chore(translations): Translated using Weblate (Esperanto) (Anonymous) +- chore(translations): Translated using Weblate (Estonian) (Priit Jõerüüt) +- chore(translations): Translated using Weblate (Finnish) (Aminda Suomalainen) +- chore(translations): Translated using Weblate (Galician) (josé m) +- chore(translations): Translated using Weblate (German) (Alex Katon) +- chore(translations): Translated using Weblate (German) (cheese1) +- chore(translations): Translated using Weblate (German) (Christian) +- chore(translations): Translated using Weblate (German) (Jana) +- chore(translations): Translated using Weblate (Greek) (Λευτέρης Τ) +- chore(translations): Translated using Weblate (Hebrew) (Anonymous) +- chore(translations): Translated using Weblate (Hungarian) (Balázs Meskó) +- chore(translations): Translated using Weblate (Indonesian) (Linerly) +- chore(translations): Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- chore(translations): Translated using Weblate (Japanese) (Allan Nordhøy) +- chore(translations): Translated using Weblate (Korean) (loyedison92) +- chore(translations): Translated using Weblate (Latvian) (Edgars Andersons) +- chore(translations): Translated using Weblate (Latvian) (ℂ𝕠𝕠𝕠𝕝 (𝕘𝕚𝕥𝕙𝕦𝕓.𝕔𝕠𝕞/ℂ𝕠𝕠𝕠𝕝)) +- chore(translations): Translated using Weblate (Lithuanian) (Anonymous) +- chore(translations): Translated using Weblate (Norwegian Bokmål) (Frank Paul Silye) +- chore(translations): Translated using Weblate (Norwegian Bokmål) (sunniva) +- chore(translations): Translated using Weblate (Polish) (Paweł Gronowski) +- chore(translations): Translated using Weblate (Portuguese (Brazil)) (LucasMZ) +- chore(translations): Translated using Weblate (Portuguese (Portugal)) (Anonymous) +- chore(translations): Translated using Weblate (Romanian) (Anonymous) +- chore(translations): Translated using Weblate (Russian) (Christian) +- chore(translations): Translated using Weblate (Russian) (Дмитрий Михирев) +- chore(translations): Translated using Weblate (Russian) (Жора Змейкин) +- chore(translations): Translated using Weblate (Serbian) (Anonymous) +- chore(translations): Translated using Weblate (Slovak) (Anonymous) +- chore(translations): Translated using Weblate (Spanish) (Kimby) +- chore(translations): Translated using Weblate (Spanish) (LucasMZ) +- chore(translations): Translated using Weblate (Turkish) (Christian) +- chore(translations): Translated using Weblate (Turkish) (Ufuk Karal) +- chore(translations): Translated using Weblate (Vietnamese) (desperadohp) +- chore: add a link to the platforms' different behaviors for the 24h format (kaanelloed) +- chore: Add ActionsPadding in column mode (Christian Kußowski) +- chore: Add close icon to snackbar in column mode (Christian Kußowski) +- chore: Adjust chat details button design (Christian Kußowski) +- chore: Adjust encryption page design (Christian Kußowski) +- chore: Adjust input bar button design (Christian Kußowski) +- chore: Adjust material dialog button design (krille-chan) +- chore: Adjust padding for status msg list (Christian Kußowski) +- chore: Adjust status header design (krille-chan) +- chore: Better display rooms without known messages (Christian Kußowski) +- chore: Better routing to space id (Christian Kußowski) +- chore: Correctly remove knockRestricted from possible join rules (Christian Kußowski) +- chore: Fix load config.json (Christian Kußowski) +- chore: Go back to pub.dev matrix dep (Christian Kußowski) +- chore: Hide restricted and knock restricted for unsupported room versions (Christian Kußowski) +- chore: Hide topic if empty and cannot be changed (Christian Kußowski) +- chore: Improve chat details icon color design (Christian Kußowski) +- chore: Improve ignore list UX (Christian Kußowski) +- chore: Leave invites and DM rooms when blocking a user (Christian Kußowski) +- chore: Make privacy url not configurable (Christian Kußowski) +- chore: Make progress indicators rounder (Christian Kußowski) +- chore: Mention rebases (Christian Kußowski) +- chore: Move emote settings button to chat popup menu (Christian Kußowski) +- chore: Move encryption button to input row (Christian Kußowski) +- chore: Revert "refactor: Make ChatListItem cache lasteventbody for better performance" (Christian Kußowski) +- chore: Translate iOS notifications into german (Christian Kußowski) +- chore: Try out refactored user device keys update method (Christian Kußowski) +- chore: Update matrix dart sdk (Christian Kußowski) +- chore: use time format based on system settings (kaanelloed) +- ci: Build only for arm64 (Christian Kußowski) +- refactor: Make ChatListItem cache lasteventbody for better performance (Christian Kußowski) +- refactor: Remove unused directories (Christian Kußowski) +- refactor: Rename models for matrix spec 1.16 (Christian Kußowski) +- refactor: Replace flutter typeahead with autocomplete to fix (Christian Kußowski) +- refactor: Use AppSettings enum based configuration everywhere and fix load from json on web (Christian Kußowski) +- build: Flutter upgrade 3.35.5 (Christian Kußowski) +- build: Matrix version 3.0.0 (Christian Kußowski) +- build: Remove dependency for telephony (Christian Kußowski) +- build: Remove openssl dependency (Christian Kußowski) +- build: Use correct fcm_shared_isolate version (Christian Kußowski) +- build: Use correct version of vodozemac for web build (Christian Kußowski) + +## v2.1.1 +Bugfix release to trigger flatpak arm64 release again. + +- build: (deps): bump actions/checkout from 4 to 5 (dependabot[bot]) +- build: (deps): bump app_links from 6.4.0 to 6.4.1 (dependabot[bot]) +- build: (deps): bump file_picker from 10.2.3 to 10.3.1 (dependabot[bot]) +- build: (deps): bump msix from 3.16.10 to 3.16.12 (dependabot[bot]) +- build: (deps): bump package_info_plus from 8.3.0 to 8.3.1 (dependabot[bot]) +- build: (deps): bump share_plus from 11.0.0 to 11.1.0 (dependabot[bot]) +- build: Also build linux on github runners (Christian Kußowski) +- build: Update macos podfile (Christian Kußowski) +- chore: Follow up subtitle font style (Christian Kußowski) +- chore: Slightly adjust font sizes and design (Christian Kußowski) +- chore(translations): Translated using Weblate (Chinese (Traditional Han script)) (miullu) +- chore(translations): Translated using Weblate (Norwegian Bokmål) (Frank Paul Silye) +- chore(translations): Translated using Weblate (Polish) (Piotr Orzechowski) +- feat: support xdp selector for linux (ShootingStarDragons) +- fix: Follow up fix rectangle avatars (Christian Kußowski) +- refactor: Remove broken push error reporter (Christian Kußowski) + +## v2.1.0 +FluffyChat 2.1.0 brings support for room version 12 and a lot of bugfixes, updated translations and performance improvements. Also chat state events are now collapsed by default. + +- feat: Collapse all state events by default (Christian Kußowski) +- feat(linux/notify): support avatar icon (ShootingStarDragons) +- build: (deps): bump archive from 3.6.1 to 4.0.7 (dependabot[bot]) +- build: (deps): bump chewie from 1.11.3 to 1.12.1 (dependabot[bot]) +- build: (deps): bump desktop_drop from 0.4.4 to 0.6.1 (dependabot[bot]) +- build: (deps): bump device_info_plus from 10.1.2 to 11.5.0 (dependabot[bot]) +- build: (deps): bump dynamic_color from 1.7.0 to 1.8.1 (dependabot[bot]) +- build: (deps): bump file_picker from 10.2.0 to 10.2.1 (dependabot[bot]) +- build: (deps): bump file_picker from 8.3.7 to 10.2.0 (dependabot[bot]) +- build: (deps): bump flutter_foreground_task from 6.5.0 to 9.1.0 (dependabot[bot]) +- build: (deps): bump flutter_local_notifications from 19.3.0 to 19.4.0 (dependabot[bot]) +- build: (deps): bump flutter_map from 6.2.1 to 8.1.1 (dependabot[bot]) +- build: (deps): bump flutter_map from 8.1.1 to 8.2.1 (dependabot[bot]) +- build: (deps): bump flutter_native_splash from 2.4.4 to 2.4.6 (dependabot[bot]) +- build: (deps): bump flutter_webrtc from 0.12.12+hotfix.1 to 1.0.0 (dependabot[bot]) +- build: (deps): bump geolocator from 13.0.4 to 14.0.2 (dependabot[bot]) +- build: (deps): bump go_router from 15.1.2 to 16.0.0 (dependabot[bot]) +- build: (deps): bump go_router from 16.0.0 to 16.1.0 (dependabot[bot]) +- build: (deps): bump just_audio from 0.9.46 to 0.10.4 (dependabot[bot]) +- build: (deps): bump matrix from 1.0.1 to 1.1.0 (dependabot[bot]) +- build: (deps): bump mime from 1.0.6 to 2.0.0 (dependabot[bot]) +- build: (deps): bump msix from 3.16.9 to 3.16.10 (dependabot[bot]) +- build: (deps): bump permission_handler from 11.4.0 to 12.0.1 (dependabot[bot]) +- build: (deps): bump pretty_qr_code from 3.4.0 to 3.5.0 (dependabot[bot]) +- build: (deps): bump share_plus from 10.1.4 to 11.0.0 (dependabot[bot]) +- build: (deps): bump sqflite_common_ffi from 2.3.5 to 2.3.6 (dependabot[bot]) +- build: (deps): bump sqlcipher_flutter_libs from 0.6.6 to 0.6.7 (dependabot[bot]) +- build: (deps): bump unifiedpush from 5.0.2 to 6.0.2 (dependabot[bot]) +- build: (deps): bump url_launcher from 6.3.1 to 6.3.2 (dependabot[bot]) +- build: Update Flutter 3.32.8 (Christian Kußowski) +- build: Upgrade emoji picker flutter (Christian Kußowski) +- build: Use gradle in kotlin (Christian Kußowski) +- build: Use macos-latest for debug ios job (Christian Kußowski) +- chore: Add CI workflow for thank you message after issue got completed (Christian Kußowski) +- chore: Add dependabot to code owners for pubspec (Christian Kußowski) +- chore: Add ISC as compatible license to aGPLv3 (Christian Kußowski) +- chore: Better error handling for push notifications (Christian Kußowski) +- chore: Bump Flutter version in pubspec.lock (Rafał Hirsch) +- chore: do format (ShootingStarDragons) +- chore: Fix snapcraft build (krille-chan) +- chore: Nicer own reaction color design (Christian Kußowski) +- chore: Remove double quotes from screenshot filenames (Christian Kußowski) +- chore: Remove lifecyclestate logs (Christian Kußowski) +- chore: Remove unused workflow (krille-chan) +- chore: Set height for screenshots in readme (krille-chan) +- chore: Set text message max length to 16384 but make it configurable (Christian Kußowski) +- chore: Update height for screenshots in readme (krille-chan) +- chore: Update screenshots in readme (krille-chan) +- fix: Add flexible to file messages to prevent long name overflow (Kelrap) +- fix: Avoid using MediaQuery.of() (imnotlxy) +- fix: Config viewer not updating state (Christian Kußowski) +- fix: Delete database correctly after corruption (krille-chan) +- fix: Design glitches in sticker dialog (Christian Kußowski) +- fix: limit characters and lines so redact message can't be too long (avashilling) +- fix: LoadingSnackBar consistently remains visible until the upload is complete (JaWeee) +- fix: notification clicked still cannot jump (ShootingStarDragons) +- fix: open chat from notification (ShootingStarDragons) +- fix: Open database crashes on start (krille-chan) +- fix: Open external account management when trying to delete devices (Christian Kußowski) +- fix: Use retry http client (Christian Kußowski) +- fix: Workaround for reversed width and height of compressed videos sent from Android (Christian Kußowski) +- refactor: Add support for Room version 12 via matrix dart sdk update +- refactor: Better UX for accepting declining invite (krille-chan) +- refactor: ignore bubble gradient when using system high contrast mode (Christian Kußowski) +- refactor: Make notification avatars rounded (krille-chan) +- refactor: Remove unused dependencies (krille-chan) +- chore(translations): Translated using Weblate (Basque) (xabirequejo) +- chore(translations): Translated using Weblate (Belarusian) (Alex Katon) +- chore(translations): Translated using Weblate (German) (Christian) +- chore(translations): Translated using Weblate (Norwegian Bokmål) (Frank Paul Silye) +- chore(translations): Translated using Weblate (Portuguese (Brazil)) (LucasMZ) +- chore(translations): Translated using Weblate (Spanish) (Fuan200) +- chore(translations): Translated using Weblate (Tamil) (தமிழ்நேரம்) +- chore(translations): Translated using Weblate (Ukrainian) (Ihor Hordiichuk) +- Translated using Weblate (Arabic) (LucasMZ) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- Translated using Weblate (Chinese (Traditional Han script)) (miullu) +- Translated using Weblate (Czech) (LucasMZ) +- Translated using Weblate (Dutch) (Jelv) +- Translated using Weblate (English) (LucasMZ) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (German) (nautilusx) +- Translated using Weblate (Hebrew) (LucasMZ) +- Translated using Weblate (Hungarian) (LucasMZ) +- Translated using Weblate (Indonesian) (Linerly) +- Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- Translated using Weblate (Irish) (LucasMZ) +- Translated using Weblate (Italian) (Angelo Schirinzi) +- Translated using Weblate (Italian) (LucasMZ) +- Translated using Weblate (Latvian) (Edgars Andersons) +- Translated using Weblate (Latvian) (LucasMZ) +- Translated using Weblate (Norwegian Bokmål) (Christian) +- Translated using Weblate (Norwegian Bokmål) (Frank Paul Silye) +- Translated using Weblate (Persian) (Alireza Rashidi) +- Translated using Weblate (Polish) (Piotr Orzechowski) +- Translated using Weblate (Portuguese (Brazil)) (LucasMZ) +- Translated using Weblate (Portuguese) (Ana Elisa Ramos) +- Translated using Weblate (Portuguese) (LucasMZ) +- Translated using Weblate (Russian) (LucasMZ) +- Translated using Weblate (Tamil) (தமிழ்நேரம்) +- Translated using Weblate (Tamil) (LucasMZ) +- Translated using Weblate (Telugu) (LucasMZ) +- Translated using Weblate (Ukrainian) (Ihor Hordiichuk) +- Translated using Weblate (Ukrainian) (LucasMZ) +- Translated using Weblate (Vietnamese) (LucasMZ) + +## v2.0.0 + +This version migrates to Vodozemac and Matrix Dart SDK 1.0.0. This is a breaking +change. The user should not notice the migration at all but downgrading from +v2.0.0 to a previous version is not possible without losing the session. + +- fix: Do not set read markers for sending events (Christian Kußowski) +- fix: fix compile error related to MxcImage (gilice) +- fix: Forward last version of events when forwarding (Christian Kußowski) +- fix: Ban button displayed for already banned users (Christian Kußowski) +- fix: Route back to room list after leaving a chat (Christian Kußowski) +- build: Switch to matrix sdk 1.0.0 (Christian Kußowski) +- build: Upgrade flutter to 3.32.2 (krille-chan) +- build: Update to flutter 3.32.4 (Christian Kußowski) +- chore: Add missing mounted check (Christian Kußowski) +- chore: highlight select mode actions (Christian Kußowski) +- refactor: sdk 1.0 (Christian Kußowski) +- refactor: New message context menu (Christian Kußowski) +- refactor: Nicer popupmenus (Christian Kußowski) +- Translated using Weblate (Spanish) (Kimby) + +## v1.27.0 +- feat: Add confirmation dialog before accepting invite (krille-chan) +- feat: Add feature flag for refresh tokens (Christian Kußowski) +- feat: add setting for whether to show space navigation rail on mobile (ggurdin) +- feat: Background audio player (Christian Kußowski) +- feat: Check markdown checkboxes in messages (krille-chan) +- feat: Create lists with checkboxes via + menu (krille-chan) +- feat: Limit height of text messages and expand if selected (krille-chan) +- feat: Move videoplayer into multi image viewer (Christian Kußowski) +- feat: Show all supported image-/video-files when sending images or videos (MoonlightWave-12) +- feat: Show WebM-videos when choosing video-files for sending (MoonlightWave-12) +- fix: Add missing mounted check to mxcImage (Christian Kußowski) +- fix: App crash on page navigation with open popup menu (Christian Kußowski) +- fix: App crashes on window resize in chat (krille-chan) +- fix: Change `PNGs` to `PNG` for consistency in file-selector (MoonlightWave-12) +- fix: Crash when going to settings in desktop mode (krille-chan) +- Fix: Fix jagged avatar edges Use anti-alias Clipping allowing for round Avatar circles (martin) +- fix: Join new room after room upgrade (krille-chan) +- fix: Keep state of text input dialogs (Christian Kußowski) +- fix: Localizations (krille-chan) +- fix: No crash on logging out in client chooser button (Christian Kußowski) +- fix: Show WebP-images with a file-extension written in lower-case (MoonlightWave-12) +- build: Update matrix dart sdk 0.40.2 (Christian Kußowski) +- build: Update record package (Christian Kußowski) +- build: Update shared preferences android (krille-chan) +- build: Upgrade to flutter 3.32.1 (Christian Kußowski) +- build: Use workaround for flutter secure storage on linux (krille-chan) +- chore: Crop shortcut file on android and cache it (krille-chan) +- chore: Display loading dialog when preparing voice message (Christian Kußowski) +- chore: Format lib/utils/file_selector.dart (MoonlightWave-12) +- chore: Let users decide for the title in error reporter (Christian Kußowski) +- chore: make space nav bar narrower on mobile and ensure space nav bar matches user's theme (ggurdin) +- chore: Nicer checkboxes (Christian Kußowski) +- chore: Preload server file config before upload files (Christian Kußowski) +- chore: Remove custom errorwidgetbuilder (Christian Kußowski) +- chore: Remove unused translations (Christian Kußowski) +- chore: Simplify voiceMessage getter (Christian Kußowski) +- chore: Update voice message localization (Christian Kußowski) +- refactor: Always use HtmlMessage (krille-chan) +- refactor: Reduce notification avatar size to 128 (krille-chan) +- Added translation using Weblate (Cantonese (Traditional Han script)) (Mike Evans) +- Added translation using Weblate (Danish) (Øjvind Fritjof Arnfred) +- Added translation using Weblate (Yue (yue_HK)) (Mike Evans) +- Translated using Weblate (Arabic) (abdelbasset jabrane) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Cantonese (Traditional Han script)) (Mike Evans) +- Translated using Weblate (Catalan) (Marc Pina Artigas) +- Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- Translated using Weblate (Chinese (Simplified Han script)) (Mike Evans) +- Translated using Weblate (Chinese (Traditional Han script)) (Mike Evans) +- Translated using Weblate (Chinese (Traditional Han script)) (miullu) +- Translated using Weblate (Danish) (Øjvind Fritjof Arnfred) +- Translated using Weblate (Dutch) (Jelv) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Finnish) (sevonj) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (German) (Christian) +- Translated using Weblate (German) (Jana) +- Translated using Weblate (German) (JSchmerling) +- Translated using Weblate (Hebrew) (DavidEl-Natan) +- Translated using Weblate (Hungarian) (H Tamás) +- Translated using Weblate (Indonesian) (Linerly) +- Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- Translated using Weblate (Italian) (Angelo Schirinzi) +- Translated using Weblate (Latvian) (ℂ𝕠𝕠𝕠𝕝 (𝕘𝕚𝕥𝕙𝕦𝕓.𝕔𝕠𝕞/ℂ𝕠𝕠𝕠𝕝)) +- Translated using Weblate (Latvian) (Edgars Andersons) +- Translated using Weblate (Polish) (Piotr Orzechowski) +- Translated using Weblate (Portuguese (Brazil)) (Pedro Alves) +- Translated using Weblate (Russian) (Yurt Page) +- Translated using Weblate (Ukrainian) (Bezruchenko Simon) +- Translated using Weblate (Ukrainian) (Ihor Hordiichuk) + +## v1.26.1 + +Updates the Matrix Dart SDK to fix multiple issues where messages can be missing in the timeline. + +- feat: Reenable archive feature after various fixes landed in sdk (krille-chan) +- build: Update matrix dart sdk to 0.40.0 (Christian Kußowski) +- chore: Adjust new chat page design (krille-chan) +- chore: Display count of invited in members page (krille-chan) +- chore: Do not load timeline while sync processing (Krille) +- chore: Do not store event from push in database (Krille) +- chore: Only show joined members in members list by default (Krille) +- chore: Remove matrix notification workflow (Krille) +- fix(docs): escape tag (Sophie L) +- fix: Crash when opening settings in column mode from popup menu (krille-chan) +- refactor: Display thread messages like replies as a thread fallback (Krille) + +## v1.26.0 + +- feat: Add advanced configuration page (Krille) +- feat: clearly mark when a video is to be downloaded (Rafał Hirsch) +- feat: Filter for room members page and easier approve knocking users (Krille) +- feat: Navigate in image viewer with keyboard keys (krille-chan) +- feat: New video file picker button (Krille) +- feat: Send optional message with images or files (Krille) +- feat: support inline video playback on macOS (Rafał Hirsch) +- build: Flutter 3.29.3 (Krille) +- build: Update gorouter package (Krille) +- build: Update kotlin gradle plugin (Krille) +- build: Update matrix dart sdk (Krille) +- build: Update openssl to 0.5.0 (Krille) +- build: use singleInstance as launchmode (krille-chan) +- chore: Add matrix notifications for issues (Krille) +- chore: Better error handling for image rendering (krille-chan) +- chore: Better no compression supported UX (Krille) +- chore: Correct availability of desktop builds (Lenni) +- chore: disable echoCancel for audio messages (Krille) +- chore: divider when scrolled up (krille-chan) +- chore: Improve avatar designg (Krille) +- chore: Make push gateway configurable (Krille) +- chore: Nicer colors for reactions (krille-chan) +- chore: Nicer scaffold dialog for column mode (Krille) +- chore: Simpler changing config variables (Krille) +- chore: Update locale config for localizations (Krille) +- chore: Update pubspec.lock (Krille) +- chore: upgrade chewie and video_player packages (Rafał Hirsch) +- chore: Use Cupertino Activity Indicator in ChatEventList (krille-chan) +- chore: Use other join endpoint for room upgrades (Krille) +- fix(macos): update dependencies to make the build work (Rafał Hirsch) +- fix: Add missing \ html tag to render (Krille) +- fix: Consistent element padding between server picker and login view (xegim) +- fix: Index of numbered lists are off (Krille) +- fix: never use a transition on the shell route (Rafał Hirsch) +- fix: Null error in ClientChooserButton (krille-chan) +- fix: prevent users from creating spaces with empty names (ggurdin) +- fix: properly dispose VideoPlayerController (Rafał Hirsch) +- fix: Remove too sensitive dismiss gesture on chat list items (Krille) +- fix: Text scale factor in Linkify widgets (Krille) +- fix: update condition in account deletion function to allow deletion to go through (ggurdin) +- refactor: Easier shift enter logic for text input (Krille) +- refactor: Formatting (Krille) +- refactor: Implement avatar image viewer and adjust design (Krille) +- refactor: Improved UX for room upgrades (Krille) +- refactor: Migrate more config options to config viewer (Krille) +- refactor: Move public room bottom sheet into dialog (Krille) +- refactor: Remove custom font and emoji font workaround (krille-chan) +- refactor: Replace user bottom sheet with menu and small dialog (Krille) +- Added translation using Weblate (Telugu) (katakam chakri) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Chinese (Simplified Han script)) (Poesty Li) +- Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- Translated using Weblate (Chinese (Traditional Han script)) (Mare JP) +- Translated using Weblate (Chinese (Traditional Han script)) (miullu) +- Translated using Weblate (Dutch) (Jelv) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Filipino) (searinminecraft) +- Translated using Weblate (French) (Antonin Del Fabbro) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (German) (nautilusx) +- Translated using Weblate (German) (Very Able) +- Translated using Weblate (Indonesian) (Linerly) +- Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- Translated using Weblate (Italian) (Angelo Schirinzi) +- Translated using Weblate (Korean) (kdh8219) +- Translated using Weblate (Latvian) (Edgars Andersons) +- Translated using Weblate (Latvian) (ℂ𝕠𝕠𝕠𝕝 (𝕘𝕚𝕥𝕙𝕦𝕓.𝕔𝕠𝕞/ℂ𝕠𝕠𝕠𝕝)) +- Translated using Weblate (Polish) (Piotr Orzechowski) +- Translated using Weblate (Russian) (Yurt Page) +- Translated using Weblate (Spanish) (José Muñoz) +- Translated using Weblate (Spanish) (Kimby) +- Translated using Weblate (Telugu) (katakam chakri) +- Translated using Weblate (Ukrainian) (Ihor Hordiichuk) + +## v1.25.0 + +- feat: Display all push rules and allow to enable disable them (Krille) +- feat: Inspect and delete push rules (Krille) +- feat: Pick share keys with (Krille) +- feat: Select share keys with property in security settings (Krille) +- feat: Use dynamic gradient for chat bubbles (Krille) +- fix: Image search rendering problem (krille-chan) +- build: Add locale config for android (krille-chan) +- build: Add missing permissions (Krille) +- build: Automerge weblate PRs (Krille) +- build: Fix ios debug build (krille-chan) +- build: Follow up auto merge weblate (Krille) +- build: remove weblate auto merge (Krille) +- build: Switch to flutter_shortcuts_new (Krille) +- build: Update dependencies for flutter (Krille) +- build: Update dependencies to remove more flutter android v1 references (Krille) +- build: Update fcm_shared_isolate (Krille) +- build: Update flutter web uild (Krille) +- build: Update flutter_olm to 2.0.0 (Krille) +- build: Update gradle version (Krille) +- build: Update native_imaging (Krille) +- build: Update PAT (Krille) +- build: Update to flutter 3.27.4 (Krille) +- build: Update weblate auto merge (Krille) +- build: Upgrade gradle (Krille) +- chore: Add explanation for PlayStore Safety Standards (Krille) +- chore: Add medium font (Krille) +- chore: Add start to ordered list (Krille) +- chore: Add tooltip to links in html (Krille) +- chore: Adjust button icon colors (Krille) +- chore: Adjust design of adaptive dialogs (krille-chan) +- chore: Adjust navrail design (Krille) +- chore: Adjust share scaffold dialog design (Krille) +- chore: Better connection status indicator (Krille) +- chore: Design adjustments (krille-chan) +- chore: Make login with matrix id more prominent again (krille-chan) +- chore: Message bubble color follow up (krille-chan) +- chore: Remove gradle workaround (Krille) +- chore: Slightly adjust welcome screen (Krille) +- chore: Use UbuntuMono (Krille) +- docs: Fix snap store icon (krille-chan) +- refactor: Display navigationrail in settings page (krille-chan) +- refactor: Follow up fix types in localization files (Krille) +- refactor: Improve sso login UX on web (krille-chan) +- refactor: Migrate to maintained badge package (Krille) +- refactor: Migrate uni_links to app_links (Krille) +- refactor: New html rendering (Krille) +- refactor: Remove broken callkeep implementation (Krille) +- refactor: Remove unused class (krille-chan) +- refactor: Switch to maintained qr code package (Krille) +- refactor: Switch to ubuntu font (krille-chan) +- refactor: Update arb file types (Krille) +- Translated using Weblate (Arabic) (Rex_sa) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Catalan) (fadelkon) +- Translated using Weblate (Chinese (Simplified Han script)) (玖然) +- Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- Translated using Weblate (Chinese (Traditional Han script)) (玖然) +- Translated using Weblate (Croatian) (Milo Ivir) +- Translated using Weblate (Dutch) (Jelv) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (German) (Christian) +- Translated using Weblate (German) (Ettore Atalan) +- Translated using Weblate (German) (Jana) +- Translated using Weblate (Indonesian) (Linerly) +- Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- Translated using Weblate (Italian) (Angelo Schirinzi) +- Translated using Weblate (Korean) (kdh8219) +- Translated using Weblate (Latvian) (Edgars Andersons) +- Translated using Weblate (Slovak) (Anonymous) +- Translated using Weblate (Spanish) (Alfredo Sola) +- Translated using Weblate (Ukrainian) (Bezruchenko Simon) +- Translated using Weblate (Ukrainian) (Ihor Hordiichuk) + +## v1.24.0 + +- build: Add missing libssl library (krille-chan) +- build: Update dart_webrtc package (Krille) +- build: Update matrix sdk and dependencies (Krille) +- build: Update to flutter 3.27 (Krille) +- chore: Better bottom sheets on desktop (krille-chan) +- chore: Check file size before loading (krille-chan) +- chore: Display normal Slider when no waveform provided in audioplayer (krille-chan) +- chore: Do not display sender prefix for DM rooms in notification ticker (krille-chan) +- chore: Enable share multiple files to app (krille-chan) +- chore: Improve alias UX in chat settings (Krille) +- chore: Improve join abandoned invite exception (Krille) +- chore: Improve UserBottomSheet UX (Krille) +- chore: Make message bubble color dark also in dark mode (krille-chan) +- chore: Remove conversationTitle if room is dm room in android notifications (krille-chan) +- feat: QR Code viewer for mxid sharing (Krille) +- fix: Do not set public visibility for private groups (Krille) +- fix: Use MB and KB instead of MiB and KiB for file sizes (Krille) +- refactor: Adjust chat list item UX (Krille) +- refactor: Better custom image resizer (Krille) +- refactor: Clean up android manifest (Krille) +- refactor: Implement own adaptive dialogs and remove package (krille-chan) +- refactor: Improve UX of user role in UserBottomSheet (Krille) +- refactor: Improved share / forward dialog (krille-chan) +- Translated using Weblate (Arabic) (Rex_sa) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Catalan) (fadelkon) +- Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- Translated using Weblate (Czech) (Erin) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (German) (Christian) +- Translated using Weblate (Indonesian) (Linerly) +- Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- Translated using Weblate (Italian) (Angelo Schirinzi) +- Translated using Weblate (Latvian) (Edgars Andersons) +- Translated using Weblate (Polish) (Piotr Orzechowski) +- Translated using Weblate (Russian) (-) +- Translated using Weblate (Tamil) (Christian) +- Translated using Weblate (Tamil) (தமிழ்நேரம்) +- Translated using Weblate (Turkish) (goknarbahceli) +- Translated using Weblate (Ukrainian) (Bezruchenko Simon) +- Translated using Weblate (Vietnamese) (Tewuzij) + +## v1.23.0 + +- design: Highlight emoji only messages (Krille) +- design: New login design (Krille) +- docs: fix snapstore badge on website (Krille) +- feat: Add about server page (Krille) +- feat: Add default chat wallpaper (Krille) +- feat: Add markdown context actions for text input (krille-chan) +- feat: Better wallpapers with blur and opacity sliders and improved styles page (krille-chan) +- feat: Display warning banner on unverified devices (krille-chan) +- feat: New audio message design with displayed body (krille-chan) +- feat: Nicer room creation UI (krille-chan) +- feat: Open account manage url when using MAS (krille-chan) +- feat: Sending multiple files at once (krille-chan) +- feat: Swipe to archive rooms (Krille) +- fix: Bypass image compression in flutter_file_picker (q234rty) +- fix: dont use thumbnails for emoticons (Marek Vospěl) +- fix: Public rooms always publicly visible even when turned off on creation (krille-chan) +- fix: Wait for room invite before open in pushhelper (krille-chan) +- refactor: Better future loading dialog without flickering (krille-chan) +- refactor: Display two lines on new messages (krille-chan) +- refactor: Improve delete device UX flow (krille-chan) +- refactor: Load bytes from sending files later to not let app crash (krille-chan) +- refactor: Migrate to newer keyboard shortcuts package (Krille) +- refactor: Move to upstream geolocator (Krille) +- refactor: Performance boost for avatar widget (Krille) +- refactor: Remove duplicated navigator workaround (krille-chan) +- refactor: Remove keyboard shortcuts (Krille) +- refactor: Remove unnecessary builder widget (krille-chan) +- refactor: Reuse flutter local notifications object (krille-chan) +- refactor: Use adaptive dialog action (Krille) +- refactor: Use file selector on linux (krille-chan) +- refactor: Use non nullable localizations builder and lazy load on web (krille-chan) +- Revert "chore: Follow up new chat design" (Krille) +- Revert "feat: Add default chat wallpaper" (Krille) +- Revert "refactor: Performance boost for avatar widget" (krille-chan) +- Translated using Weblate (Arabic) (Rex_sa) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Catalan) (fadelkon) +- Translated using Weblate (Chinese (Simplified Han script)) (大王叫我来巡山) +- Translated using Weblate (Czech) (Michal Bedáň) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Finnish) (Priit Jõerüüt) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (German) (Christian) +- Translated using Weblate (German) (Ettore Atalan) +- Translated using Weblate (German) (Peter Wallerius) +- Translated using Weblate (Hungarian) (Zentropivity) +- Translated using Weblate (Indonesian) (Linerly) +- Translated using Weblate (Irish) (Aindriú Mac Giolla Eoin) +- Translated using Weblate (Irish) (Christian) +- Translated using Weblate (Italian) (Angelo Schirinzi) +- Translated using Weblate (Korean) (Bruno Roh) +- Translated using Weblate (Korean) (kdh8219) +- Translated using Weblate (Latvian) (Edgars Andersons) +- Translated using Weblate (Latvian) (GGLVXD) +- Translated using Weblate (Russian) (Pavel Kozhukhov) +- Translated using Weblate (Russian) (v1s7) +- Translated using Weblate (Spanish) (Kimby) +- Translated using Weblate (Turkish) (Oğuz Ersen) +- Translated using Weblate (Ukrainian) (Bezruchenko Simon) +- Translated using Weblate (Ukrainian) (Ihor Hordiichuk) + +## v1.22.0 + +FluffyChat v1.22.0 brings a new design for spaces, replaces the bottom navigation bar with filter +chips and makes it finally possible to play ogg audio messages on iOS. A lot of other fixes and +improvements have also been added to this release. + +FluffyChat also now uses the new authenticated media endpoints if the server supports Matrix v1.11 +or +mentions the msc with the key `org.matrix.msc3916.stable` in the `unstable_features`. + +- design: Add snackbar with link to changelog on new version (Krille) +- docs: Update privacy policy (krille-chan) +- feat: Support for matrix auth media endpoints +- feat: Convert opus to aac on iOS before playing (Krille) +- feat: New spaces and chat list design (krille-chan) +- feat: Record voice message with opus/ogg if supported (Krille) +- feat: Send voice messages from web (Krille) +- feat: Add about server page (Krille) +- feat: Add default chat wallpaper (Krille) +- feat: Add markdown context actions for text input (krille-chan) +- feat: Better wallpapers with blur and opacity sliders and improved styles page (krille-chan) +- feat: Display warning banner on unverified devices (krille-chan) +- feat: New audio message design with displayed body (krille-chan) +- feat: Nicer room creation UI (krille-chan) +- feat: Open account manage url when using MAS (krille-chan) +- feat: Sending multiple files at once (krille-chan) +- feat: Swipe to archive rooms (Krille) +- fix: Display only available join rules (Krille) +- fix: Path correct userId to ignore list (krille-chan) +- fix: Scroll to event missing the position (Krille) +- Fix web base url and privacy url configuration processing (dlyrsk) +- refactor: Clean up some widths (krille-chan) +- refactor: Design polishment and better user viewer (Krille) +- refactor: Migrate android gradle plugin (Krille) +- refactor: Only initialize FlutterLocalNotificationsPlugin once (krille-chan) +- refactor: Recording dialog (Krille) +- Refactor: Reduce .of(context) calls theme (Thomas Klein Langenhorst) +- refactor: Use cached network image for mxc image uris (Krille) +- Translated using Weblate (Arabic) (kdh8219) +- Translated using Weblate (Arabic) (Rex_sa) +- Translated using Weblate (Basque) (kdh8219) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Chinese (Simplified)) (kdh8219) +- Translated using Weblate (Chinese (Simplified)) (大王叫我来巡山) +- Translated using Weblate (Chinese (Traditional)) (kdh8219) +- Translated using Weblate (Chinese (Traditional)) (Lukas) +- Translated using Weblate (Chinese (Traditional)) (Ricky From Hong Kong) +- Translated using Weblate (Chinese (Traditional)) (不知火 Shiranui) +- Translated using Weblate (Croatian) (Milo Ivir) +- Translated using Weblate (Czech) (Anonymous) +- Translated using Weblate (Czech) (Michal Bedáň) +- Translated using Weblate (Dutch) (Guacamolie) +- Translated using Weblate (Dutch) (Jelv) +- Translated using Weblate (Dutch) (Thomas Klein Langenhorst) +- Translated using Weblate (Esperanto) (Anonymous) +- Translated using Weblate (Estonian) (kdh8219) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Finnish) (Anonymous) +- Translated using Weblate (French) (Sovkipyk) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (German) (Christian) +- Translated using Weblate (German) (Pixelcode) +- Translated using Weblate (German) (tct123) +- Translated using Weblate (Hebrew) (Anonymous) +- Translated using Weblate (Indonesian) (Linerly) +- Translated using Weblate (Irish) (Anonymous) +- Translated using Weblate (Japanese) (Anonymous) +- Translated using Weblate (Korean) (kdh8219) +- Translated using Weblate (Lithuanian) (Anonymous) +- Translated using Weblate (Norwegian Bokmål) (Anonymous) +- Translated using Weblate (Persian) (Anonymous) +- Translated using Weblate (Portuguese (Portugal)) (Anonymous) +- Translated using Weblate (Romanian) (Anonymous) +- Translated using Weblate (Russian) (-) +- Translated using Weblate (Serbian) (Anonymous) +- Translated using Weblate (Slovenian) (Anonymous) +- Translated using Weblate (Spanish) (Anonymous) +- Translated using Weblate (Turkish) (kdh8219) +- Translated using Weblate (Turkish) (Oğuz Ersen) +- Translated using Weblate (Ukrainian) (Bezruchenko Simon) +- Translated using Weblate (Ukrainian) (Ihor Hordiichuk) + +## v1.21.2 + +Updates the Matrix Dart SDK to fix some minor bugs. + +- Added translation using Weblate (Lojban) (Zig-Rust-Odin) +- build: Update matrix dart sdk (Krille) +- chore: Update last event after decryption (Krille) +- fix: Correctly localize time of date (Krille) +- refactor: Omit local types (Krille) +- Translated using Weblate (Arabic) (Rex_sa) +- Translated using Weblate (Basque) (xabirequejo) +- Translated using Weblate (Chinese (Simplified)) (大王叫我来巡山) +- Translated using Weblate (Croatian) (Milo Ivir) +- Translated using Weblate (Estonian) (Priit Jõerüüt) +- Translated using Weblate (Galician) (josé m) +- Translated using Weblate (Hungarian) (H Tamás) +- Translated using Weblate (Korean) (kdh8219) +- Translated using Weblate (Latvian) (Edgars Andersons) +- Translated using Weblate (Polish) (Eryk Michalak) +- Translated using Weblate (Portuguese (Brazil)) (lucasmz-dev) +- Translated using Weblate (Russian) (Nicholas Winterhalter) +- Translated using Weblate (Turkish) (Oğuz Ersen) + ## v1.21.1 + - build: Update Matrix Dart SDK (Krille) - build: Update to Flutter 3.22.2 (krille-chan) - feat: add option to configure reply swipe direction (MrSpoony) @@ -12,7 +907,10 @@ - Translated using Weblate (Vietnamese) (Karo) ## v1.21.0 -FluffyChat v1.21.0 introduces the new search feature which also includes a gallery and files list for each chat. Several performance improvements have been added under the hood, leading to a much nicer user experience. + +FluffyChat v1.21.0 introduces the new search feature which also includes a gallery and files list +for each chat. Several performance improvements have been added under the hood, leading to a much +nicer user experience. - feat: Enable download images on iOS, not only share images (krille-chan) - feat: Search feature (krille-chan) @@ -41,7 +939,8 @@ FluffyChat v1.21.0 introduces the new search feature which also includes a galle - refactor: Delete database file on failed app start (krille-chan) - refactor: Display better command hints (Krille) - refactor: Improve performance of chat list (krille-chan) -- refactor: Precache theme and directchatmatrixid to improve performance in chat list item (krille-chan) +- refactor: Precache theme and directchatmatrixid to improve performance in chat list item ( + krille-chan) - refactor: Update to Matrix Dart SDK 0.29.9 (Krille) - Translated using Weblate (Croatian) (Milo Ivir) - Translated using Weblate (Czech) (Jozef Mlich) @@ -53,6 +952,7 @@ FluffyChat v1.21.0 introduces the new search feature which also includes a galle - Translated using Weblate (Turkish) (Oğuz Ersen) ## v1.20.0 + Design improvements and new advanced UI to manage rooms. - build: Fix google services patch (Krille) @@ -87,6 +987,7 @@ Design improvements and new advanced UI to manage rooms. - Translated using Weblate (Portuguese (Brazil)) (Rudah Ximenes Alvarenga) ## v1.19.2 + Bugfix release to mostly fix the new database encryption on Linux and update the translations. - build: (deps): bump peaceiris/actions-gh-pages from 3 to 4 (dependabot[bot]) @@ -94,7 +995,8 @@ Bugfix release to mostly fix the new database encryption on Linux and update the - build: Update emoji picker package (krille-chan) - build: Update flutter_map package (krille-chan) - docs: Fix typo in android app description (Krille) -- fix: Allow unencrypted database if gnome keyring not present or platform does not support it (krille-chan) +- fix: Allow unencrypted database if gnome keyring not present or platform does not support it ( + krille-chan) - fix: Background color of images with transparency (Krille) - fix: Localizations from weblate confused by unknownEvent locale (Krille) - fix: More logs when database fails to init and trycatch sendInitNotification (Krille) @@ -124,6 +1026,7 @@ Bugfix release to mostly fix the new database encryption on Linux and update the - Translated using Weblate (Ukrainian) (Ihor Hordiichuk) ## v1.19.1 + Minor bugfix release for login with SSO on web. - feat: Show/hide third column in chat view (krille-chan) @@ -135,7 +1038,9 @@ Minor bugfix release for login with SSO on web. - refactor: new flutter only typing animation (krille-chan) ## v1.19.0 -FluffyChat v1.19.0 features an improved design for message bubbles and a lot of fixes under the hood. + +FluffyChat v1.19.0 features an improved design for message bubbles and a lot of fixes under the +hood. - build: Update matrix dart sdk (Krille) - build: Update to flutter 3.19.5 (krille-chan) @@ -157,7 +1062,8 @@ FluffyChat v1.19.0 features an improved design for message bubbles and a lot of - feat: Add insert content via gboard (krille-chan) - feat: Reply with one button in desktop (krille-chan) - fix: Do not sync in background mode (krille-chan) -- fix: FluffyChat should assume m.change_password capabilitiy is supported if not present per spec (krille-chan) +- fix: FluffyChat should assume m.change_password capabilitiy is supported if not present per spec ( + krille-chan) - fix: never use root navigator for bottom sheets (The one with the braid) - fix: Remove pantalaimon message with normal error message (krille-chan) - fix: Search in spaces view (krille-chan) @@ -172,6 +1078,7 @@ FluffyChat v1.19.0 features an improved design for message bubbles and a lot of - Translated using Weblate (Interlingua) (Software In Interlingua) ## v1.18.0 + - feat: Add speed button for audioplayer (krille-chan) - feat: enhanced send video functionality by adding toggle send original (Mubeen Rizvi) - feat: add dialog to hide presence list with long-press (Marcus Hoffmann) @@ -210,6 +1117,7 @@ FluffyChat v1.19.0 features an improved design for message bubbles and a lot of - Translated using Weblate (Ukrainian) (Сергій) ## v1.17.3 + - feat: New account data based wallpaper feature (Krille) - build: Update dependencies (Krille) - build: Update flutter to 3.16.9 (Krille) @@ -227,6 +1135,7 @@ FluffyChat v1.19.0 features an improved design for message bubbles and a lot of - fix: Share invite links of public rooms (Krille) ## v1.17.2 + Another minor bugfix release which also implements private read receipts. - feat: Implement private read receipts (krille-chan) @@ -256,6 +1165,7 @@ Another minor bugfix release which also implements private read receipts. - Translated using Weblate (Ukrainian) (Сергій) ## v1.17.1 + Minor bugfix release. - build: Update matrix sdk 0.25.5 (Krille) @@ -263,13 +1173,17 @@ Minor bugfix release. - chore: Remove vibration on iOS for long press (Krille) - design: Better paddings in tablet mode (krille-chan) - docs: Fix typo in readme (Krille) -- Fix dependency. missing yq when invoking setup-web. also ensure updated config.json copied in (Isaac Johnson) +- Fix dependency. missing yq when invoking setup-web. also ensure updated config.json copied in ( + Isaac Johnson) - fix: text nodes with multiple links crash the timeline (Krille) - fix: URL too long when reporting bug (Krille) - fix: Wait for user device keys before start verification (Krille) ## v1.17.0 -FluffyChat v1.17.0 refreshes the overall user experience, changes some design and fixes a lot of bugs. It also replaces the stories feature with matrix presences, introduces a new kind of database to store the messages locally and improves the performance and app stability. + +FluffyChat v1.17.0 refreshes the overall user experience, changes some design and fixes a lot of +bugs. It also replaces the stories feature with matrix presences, introduces a new kind of database +to store the messages locally and improves the performance and app stability. - change: Remove wallpaper feature (krille-chan) - design: Adjust login page design (krille-chan) @@ -323,9 +1237,11 @@ FluffyChat v1.17.0 refreshes the overall user experience, changes some design an - Translated using Weblate (Ukrainian) (Ihor Hordiichuk) ## v1.16.1 + Test candidate for the new database. ## v1.16.0 + - build: Set olm to 1.3.2 to fix android build (krille-chan) - build: Update dependencies (krille-chan) - build: Update flutter_olm (Krille) @@ -486,6 +1402,7 @@ Test candidate for the new database. - Translated using Weblate (Vietnamese) (Sorunome) ## v1.15.1 + - feat: Make all text in chat selectable on desktop (krille-chan) - chore: Add border to images in timeline (krille-chan) - chore: added android audio sharing intent (Aryan Arora) @@ -511,6 +1428,7 @@ Test candidate for the new database. - Translated using Weblate (Ukrainian) (Ihor Hordiichuk) ## v1.15.0 + - feat: Add experimental todo list for rooms (krille-chan) - feat: better scroll to last read message handling (krille-chan) - build: Add appid suffix to android debug builds (krille-chan) @@ -524,13 +1442,15 @@ Test candidate for the new database. - design: Make incoming messages color more light (krille-chan) - design: Make key verification an adaptive dialog (krille-chan) - design: Make own chat bubble primary color for better contrast (krille-chan) -- fix: Create chat dialog crashes sometimes and power level textfield does not validate input (krille-chan) +- fix: Create chat dialog crashes sometimes and power level textfield does not validate input ( + krille-chan) - fix: Remove uncompatible dependencies connectivity_plus and wakelock (Krille) - fix: Use correct localization for redactedBy (krille-chan) - fix: noFCM warning dialog (krille-chan) - fix: render tg-forward as blockquote style (krille-chan) - fix: Archive does not update its state -- refactor: Change audio codec to opus where supported to have better compatibility with Element (Krille) +- refactor: Change audio codec to opus where supported to have better compatibility with Element ( + Krille) - refactor: Make file dialog adaptive and adjust design (krille-chan) - refactor: Preload notification sound on web (Krille) - refactor: Remove unused config (krille-chan) @@ -550,10 +1470,12 @@ Test candidate for the new database. - Translated using Weblate (Thai) (Amy/Atius) ## v1.14.5 + - Hotfix iOS crashes on start - Hotfix cannot reset applock ## v1.14.4 + Minor bugfix release. Please note that because of a Flutter update FluffyChat is no longer compatible with iOS 11. @@ -569,17 +1491,24 @@ compatible with iOS 11. - refactor: Only preload client for GUI start (krille-chan) ## v1.14.3 + - hotfix app lock still displayed even when account is logged out - Update to Flutter 3.13.6 ## v1.14.2 + - hotfix for broken applock screen ## v1.14.1 + - fix: Routing bug when adding second account via password login ## v1.14.0 -Release with a lot of bugfixes and refactorings under the hood. FluffyChat now uses go_router instead of vrouter, works with the newest Flutter SDK and supports "reason" field for redactions. For Android there is a new "background-fetch mode" for Push Notifications which should make notifications in background faster and more reliable and reduce battery-usage. + +Release with a lot of bugfixes and refactorings under the hood. FluffyChat now uses go_router +instead of vrouter, works with the newest Flutter SDK and supports "reason" field for redactions. +For Android there is a new "background-fetch mode" for Push Notifications which should make +notifications in background faster and more reliable and reduce battery-usage. - feat: Background fetch mode on Android (krille-chan) - feat: Improved mouse support for selecting events (krille-chan) @@ -645,6 +1574,7 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - Translated using Weblate (Ukrainian) (Skrripy) ## v1.13.0 + - feat: option to not send typing notifications (Bnyro) - feat: small performance tweaks for Message (gilice) - feat: New onboarding screen with SSO as first class feature @@ -652,7 +1582,8 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - fix: Set iOS badge (Krille) - refactor: Switch the dev hosting platform from GitLab to GitHub - design: New more compact chat bubble design and other design tweaks -- design: Login now shows SSO more prominent and deprecates in-app registration in favor of SSO registration +- design: Login now shows SSO more prominent and deprecates in-app registration in favor of SSO + registration - Translated using Weblate (Arabic) (Rex_sa) - Translated using Weblate (Chinese (Simplified)) (Poesty Li) - Translated using Weblate (Estonian) (Priit Jõerüüt) @@ -661,6 +1592,7 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - Translated using Weblate (Ukrainian) (Ihor Hordiichuk) ## v1.12.0 + - Added translation using Weblate (Toki Pona) (Mæve Rey) - Translated using Weblate (Arabic) (Rex_sa) - Translated using Weblate (Chinese (Simplified)) (Eric) @@ -698,12 +1630,14 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - feat: Add toggle to mute notifications from chat groups (fbievan) - feat: Allow ruby tags in html (Krille) - feat: Display progress value for initial sync (Krille) -- feat: Implement new error reporting tool when critical features break like playing audio or video messages or opening a chat (Krille) +- feat: Implement new error reporting tool when critical features break like playing audio or video + messages or opening a chat (Krille) - feat: clean up macOS build metadata (TheOneWithTheBraid) - feat: set display information correctly (TheOneWithTheBraid) - feat: update macOS build files (TheOneWithTheBraid) - feat: update macOS build information for macOS Ventura (TheOneWithTheBraid) -- fix "Unhandled Exception: VRouter.of(context) was called with a context which does not contain a VRouter." (Lauren N. Liberda) +- fix "Unhandled Exception: VRouter.of(context) was called with a context which does not contain a + VRouter." (Lauren N. Liberda) - fix: Broken arb file (Krille) - fix: Do not unnecessary request all members in public rooms (Krille) - fix: Remove wrong rendered linebreak in html (Krille) @@ -725,6 +1659,7 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - refactor: Use DateTime for weekday localization (Malin Errenst) ## v1.11.2 + - Translated using Weblate (Croatian) (Milo Ivir) - Translated using Weblate (Dutch) (Jelv) - Translated using Weblate (Estonian) (Priit Jõerüüt) @@ -736,9 +1671,11 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - fix: Chats do not load (Krille) ## v1.11.1 - 2023-04-20 + - fix: Download files on web and iOS with correct mimetype ## v1.11.0 - 2023-04-14 + - feat: Add visual read marker (Krille) - feat: Jump to last read event (Krille) - feat: Use fragmented timeline to jump to event (Krille) @@ -769,6 +1706,7 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - Translated using Weblate (Ukrainian) (Ihor Hordiichuk) ## v1.10.0 - 2023-02-25 + - Added translation using Weblate (Thai) (Wphaoka) - Added translation using Weblate (Tibetan) (Nathan Freitas) - Default hardcoded message when l10n is not available (fabienli) @@ -806,7 +1744,8 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - fix: Display error when user tries to send too large file (Christian Pauly) - refactor: Do only instantiate AudioPlayer() object when in use (Christian Pauly) - refactor: Remove syncstatus verbose logs (Christian Pauly) -- refactor: Store cached files in tmp directory so OS will clear file cache from time to time (Krille) +- refactor: Store cached files in tmp directory so OS will clear file cache from time to time ( + Krille) - style: Adjust key verification dialog (Christian Pauly) - style: Bootstrap design adjustments (Christian Pauly) - style: Encryption page adjustments (Christian Pauly) @@ -823,6 +1762,7 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - utils/url_launcher: force opening http(s) links in external browser (Marcus Hoffmann) ## v1.9.0 - 2023-01-29 + - Translated using Weblate (Czech) (Michal Bedáň) - Translated using Weblate (Czech) (grreby) - Translated using Weblate (Dutch) (Jelv) @@ -861,6 +1801,7 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - style: Redesign public room bottomsheets (Krille) ## v1.8.0 2022-12-30 + - Added translation using Weblate (Yue (yue_HK)) (Raatty) - Translated using Weblate (Chinese (Simplified)) (Mike Evans) - Translated using Weblate (Estonian) (Priit Jõerüüt) @@ -887,13 +1828,19 @@ Release with a lot of bugfixes and refactorings under the hood. FluffyChat now u - fix: minor issues in room list (TheOneWithTheBraid) ## v1.7.2 2022-12-19 + Update dependencies and translations. ## v1.7.1 2022-11-23 -Minor bugfix release to retrigger build for FlatPak and Android. Fixes some style bugs and updates some translations + +Minor bugfix release to retrigger build for FlatPak and Android. Fixes some style bugs and updates +some translations ## v1.7.0 2022-11-17 -FluffyChat 1.7.0 features a new way to work with spaces via a bottom navigation bar. A lot of work has also been done under the hood to make the app faster and more stable. The main color has slightly changed and the design got some finetuning. + +FluffyChat 1.7.0 features a new way to work with spaces via a bottom navigation bar. A lot of work +has also been done under the hood to make the app faster and more stable. The main color has +slightly changed and the design got some finetuning. - chore: Add keys to roomlist and stories header (Christian Pauly) - chore: Add unread badge to navigation rail and adjust design (Christian Pauly) @@ -950,6 +1897,7 @@ FluffyChat 1.7.0 features a new way to work with spaces via a bottom navigation - Translated using Weblate (Ukrainian) (Raatty) ## v1.6.4 - 2022-09-08 + - Translated using Weblate (Chinese (Simplified)) (Eric) - Translated using Weblate (Estonian) (Priit Jõerüüt) - Translated using Weblate (Galician) (Xosé M) @@ -965,6 +1913,7 @@ FluffyChat 1.7.0 features a new way to work with spaces via a bottom navigation - fix: add missing command localizations (Christian Pauly) ## v1.6.3 - 2022-08-25 + - Translated using Weblate (Chinese (Simplified)) (Eric) - Translated using Weblate (Estonian) (Priit Jõerüüt) - Translated using Weblate (Finnish) (Aminda Suomalainen) @@ -977,6 +1926,7 @@ FluffyChat 1.7.0 features a new way to work with spaces via a bottom navigation - refactor: App widget (Christian Pauly) ## v1.6.0 - 2022-07-31 + FluffyChat 1.6.0 features a lot of bug fixes and improvements. The code base has been simplified and the drawer on the chat list page got a come-back. Some new features like the space hierarchy and session dump have been implemented. @@ -1047,6 +1997,7 @@ the space hierarchy and session dump have been implemented. - chore: remove snapping sheet (TheOneWithTheBraid) ## v1.5.0 - 2022-06-03 + - Translated using Weblate (Ukrainian) (Ihor Hordiichuk) - feat: Better sign up UX and allow signup without password (Christian Pauly) - feat: Initial material you support (Christian Pauly) @@ -1082,6 +2033,7 @@ the space hierarchy and session dump have been implemented. - Translated using Weblate (Turkish) (Oğuz Ersen) ## v1.4.0 - 2022-04-23 + - design: Display icon for failed sent messages (Krille Fear) - design: Display own stories at first place and combine with new stories button (Krille Fear) - feat: Add "Show related DMs in spaces" settings (20kdc) @@ -1136,6 +2088,7 @@ the space hierarchy and session dump have been implemented. - refactor: New push (Krille Fear) ## v1.3.1 - 2022-03-20 + - Allow app to be moved to external storage (Marcel) - Translated using Weblate (Arabic) (Mads Louis) - Translated using Weblate (Basque) (Sorunome) @@ -1174,14 +2127,19 @@ the space hierarchy and session dump have been implemented. - refactor: Switch to just audio for playing sounds (Krille Fear) ## v1.3.0 - 2022-02-12 -FluffyChat 1.3.0 makes it possible to report offensive users to server admins (not only messages). It fixes + +FluffyChat 1.3.0 makes it possible to report offensive users to server admins (not only messages). +It fixes the video player, improves Linux desktop notifications, and the stories design. -The button to create a new story is now in the app bar of the main page so that users who don't want to use +The button to create a new story is now in the app bar of the main page so that users who don't want +to use this feature no longer have a whole list item pinned at the top of the chat list. -FluffyChat 1.3.0 is the first release with full null safe dart code. While this is a huge change under the -hood, it should improve the stability and performance of the app. It also builds now with Flutter 2.10. +FluffyChat 1.3.0 is the first release with full null safe dart code. While this is a huge change +under the +hood, it should improve the stability and performance of the app. It also builds now with Flutter +2.10. Thanks to all contributors and translators!! <3 @@ -1221,6 +2179,7 @@ Thanks to all contributors and translators!! <3 - refactor: Migrate to null safety (Krille Fear) ## v1.2.0 - 2022-01-27 + FluffyChat 1.2.0 brings a new stories feature, a lot of bug fixes and improved voice messages. @@ -1254,7 +2213,8 @@ voice messages. - followup: Improve stories (Krille Fear) - Improve website SEO tagging (Marcel) - Increase font size granularity (S1m) -- refactor: /command hints add tooltips, test for missing hints, script to generate glue code, hints for dm, create, clearcache, discardsession (Steef Hegeman) +- refactor: /command hints add tooltips, test for missing hints, script to generate glue code, hints + for dm, create, clearcache, discardsession (Steef Hegeman) - refactor: Make more files null safe (Krille Fear) - refactor: Make style settings null safe (Krille Fear) - systemNavigationBarColor ← appBar.backgroundColor (Steef Hegeman) @@ -1284,6 +2244,7 @@ voice messages. - Translated using Weblate (Ukrainian) (Ihor Hordiichuk) ## v1.1.0 - 2021-12-08 + - CI: Add candidate release pipeline (Krille Fear) - Translated using Weblate (Dutch) (Jelv) - Translated using Weblate (Estonian) (Priit Jõerüüt) @@ -1304,6 +2265,7 @@ voice messages. - refactor: Make user device list item null safe (Krille Fear) ## v1.0.0 - 2021-11-29 + - design: Chat backup dialog as a banner - design: Encrypted by design, all users valid is normal not green - design: Move video call button to menu @@ -1361,7 +2323,9 @@ voice messages. - fix: Wrong version in snap packages ## v0.42.2 - 2021-11-04 -Minor bugfix release which fixes signing up on matrix.org and make FluffyChats voice messages playable in Element. + +Minor bugfix release which fixes signing up on matrix.org and make FluffyChats voice messages +playable in Element. - feat: Nicer registration form - feat: Nicer audio message design and send duration @@ -1371,6 +2335,7 @@ Minor bugfix release which fixes signing up on matrix.org and make FluffyChats v - fix: Crash on logout ## v0.42.1 - 2021-10-26 + Minor bugfix release. - feat: Ignore users directly from bottom sheet @@ -1381,6 +2346,7 @@ Minor bugfix release. - design: Make homepicker page nicer ## v0.42.0 - 2021-10-14 + This release fixes several bugs and makes E2EE enabled by default. - feat: Enable E2EE by default for new rooms @@ -1391,17 +2357,20 @@ This release fixes several bugs and makes E2EE enabled by default. - feat: More finetuning for font sizes - chore: Updated translations (Thanks to all translators!) - fix: App crash on logout -- fix: Temporary disable sign-up for matrix.org (Currently gives "500: Internal Server Error" while FluffyChat **should** send the same requests like Element) +- fix: Temporary disable sign-up for matrix.org (Currently gives "500: Internal Server Error" while + FluffyChat **should** send the same requests like Element) - fix: Implement Roboto font to fix font issues on Linux Desktop and mobile - fix: QR Code scanning ## v0.41.3 - 2021-10-08 + Minor bugfix release. - fix: Last space is not visible - chore: Google services disabled by default for F-Droid ## v0.41.1 - 2021-09-15 + Minor bugfix release. - fix: Start up time waits for first sync @@ -1411,7 +2380,10 @@ Minor bugfix release. And some other minor bugs. ## v0.41.0 - 2021-09-14 -This release features a lot of bug fixes and the new multi account feature which also include account bundles. + +This release features a lot of bug fixes and the new multi account feature which also include +account bundles. + - feat: Multiple accounts - feat: New splash screen - fix: Password reset @@ -1423,21 +2395,28 @@ This release features a lot of bug fixes and the new multi account feature which - chore: Updated translations ## v0.40.1 - 2021-09-14 + Minor bug fixes. ## v0.40.0 - 2021-09-13 -This release contains a security fix. Red more about it here: https://matrix.org/blog/2021/09/13/vulnerability-disclosure-key-sharing + +This release contains a security fix. Red more about it +here: https://matrix.org/blog/2021/09/13/vulnerability-disclosure-key-sharing - New in-app registration - Design improvements - Minor fixes ## v0.39.0 - 2021-08-30 + - Hotfix a bug which produces problems in downloading files and playing audios - Hotfix a bug which breaks device management ## v0.39.0 - 2021-08-28 -This release fixes a bug which makes it impossible to send images in unencrypted rooms. It also implements a complete new designed new chat page which now uses a QR code based workflow to start a new chat. + +This release fixes a bug which makes it impossible to send images in unencrypted rooms. It also +implements a complete new designed new chat page which now uses a QR code based workflow to start a +new chat. - feat: Dismiss keyboard on scroll in iOS - feat: Implement QR code scanner @@ -1450,11 +2429,13 @@ This release fixes a bug which makes it impossible to send images in unencrypted - fix: Open matrix.to urls - fix: Padding and colors - fix: Sharing invite link -- fix: Unread bubbles on iOS +- fix: Unread bubbles on iOS - fix: Sending images in unencrypted rooms ## v0.38.0 - 2021-08-22 -This release adds more functionality for spaces, enhances the html viewer, adds a brand new video player and brings some improvements for voice messages. Thanks to everyone involved! + +This release adds more functionality for spaces, enhances the html viewer, adds a brand new video +player and brings some improvements for voice messages. Thanks to everyone involved! ### All changes: @@ -1479,7 +2460,8 @@ This release adds more functionality for spaces, enhances the html viewer, adds - fix: Display loading dialog on start DM - fix: Dont add/remove DMs to space - fix: Empty timelines crashing the room view -- fix: excessive CPU usage on Windows, as described in https://github.com/flutter/flutter/issues/78517#issuecomment-846436695 +- fix: excessive CPU usage on Windows, as described + in https://github.com/flutter/flutter/issues/78517#issuecomment-846436695 - fix: Joining room aliases not published into the room directory - fix: Keep display alive while recording - fix: Load space members to display DM rooms @@ -1497,22 +2479,27 @@ This release adds more functionality for spaces, enhances the html viewer, adds - fix: Wrap login form into `AutofillGroup` ## v0.37.0 - 2021-08-06 + - Implement location sharing - Updated translations - Improved spaces support - Minor bug fixes ## v0.36.2 - 2021-08-03 + Hotfix a routing problem on web and desktop ## v0.36.1 - 2021-08-03 + - Hotfix uploading to many OTKs - Implement initial spaces UI ## v0.36.0 - 2021-07-31 + Minor design improvements and bug fixes. ### All changes: + * design: Make unread listtiles more visible * design: Move pinned icon in title * feat: Rate limit streams so that large accounts have a smoother UI @@ -1525,10 +2512,13 @@ Minor design improvements and bug fixes. * fix: Tests ## v0.35.0 - 2021-07-24 + This release introduces stickers and a lot of minor bug fixes and improvements. ### All changes: + ### Feature + * Add sticker picker [205d7e8] * Also suggest username completions based on their slugs [3d980df] * Nicer mentions [99bc819] @@ -1537,6 +2527,7 @@ This release introduces stickers and a lot of minor bug fixes and improvements. * Android SSO in webview [befd8e1] ### Fixes + * Reset bootstrap on bad ssss [b78b654] * Hide stickers button when there is not sticker pack [b71dd4b] * Download files on iOS [a8201c4] @@ -1552,15 +2543,19 @@ This release introduces stickers and a lot of minor bug fixes and improvements. * Close safariviewcontroller on SSO [ba685b7] ### Refactor + * Rename store and allow storing custom values [b1c35e5] ## v0.34.1 - 2021-07-14 + Bugfix image picker on Android 11 ## v0.34.0 - 2021-07-13 + Mostly bugfixes and one new feature: Lottie file rendering. ### All changes: + * feat: Add rendering of lottie files * fix: Check for jitsi server in well-known lookup also on login screen * fix: show thumbnails in timeline on desktop @@ -1572,21 +2567,27 @@ Mostly bugfixes and one new feature: Lottie file rendering. * fix: Don't allow backup of the android app ## v0.33.3 - 2021-07-11 + Another bugfixing release to solve some problems and republish the app on iOS. ### Changes + * Redesign SSO buttons * Update dependencies * Remove moor database (no migration from here possible) * fix: Keyboard hides imagePicker buttons on iOS ## v0.33.2 - 2021-06-29 + * Fix Linux Flatpak persistent storing of data ## v0.33.0 - 2021-06-26 -Just a more minor bugfixing release with some design changes in the settings, updated missing translations and for rebuilding the arm64 Linux Flatpak. + +Just a more minor bugfixing release with some design changes in the settings, updated missing +translations and for rebuilding the arm64 Linux Flatpak. ### Features + * redesigned settings * Updated translations - thanks to all translators * display progress bar in first sync @@ -1594,23 +2595,31 @@ Just a more minor bugfixing release with some design changes in the settings, up * update some dependencies ### Fixes + * Favicon on web * Database not storing files correctly * Linux builds for arm64 * a lot of minor bugs ## v0.32.2 - 2021-06-20 + * fix: Broken hive keys ## v0.32.1 - 2021-06-17 -* fix: Hive breaks if room IDs contain emojis (yes there are users with hacked synapses out there who needs this) + +* fix: Hive breaks if room IDs contain emojis (yes there are users with hacked synapses out there + who needs this) * feat: Also migrate inbound group sessions - ## v0.32.0 - 2021-06-16 -FluffyChat 0.32.0 targets improved stability and a new onboarding flow where single sign on is now the more prominent way to get new users into the app. This release also introduces a complete rewritten database under the hood based on the key value store Hive instead of sqlite. This should improve the overall stability and the performance of the web version. + +FluffyChat 0.32.0 targets improved stability and a new onboarding flow where single sign on is now +the more prominent way to get new users into the app. This release also introduces a complete +rewritten database under the hood based on the key value store Hive instead of sqlite. This should +improve the overall stability and the performance of the web version. ### Feat + * Long-press reactions to see who sent this * New login UI * Shift+Enter makes a new line on web and desktop @@ -1620,6 +2629,7 @@ FluffyChat 0.32.0 targets improved stability and a new onboarding flow where sin * Minor design tweaks ### Fixes + * Single sign on on iOS and web * Database corruptions * Minor fixes @@ -1627,26 +2637,31 @@ FluffyChat 0.32.0 targets improved stability and a new onboarding flow where sin ## v0.31.3 - 2021-05-28 ### Fixes + * Build Linux * Multiline keyboard on web and desktop ## v0.31.2 - 2021-05-28 ### Fixes + * Setting up push was broken ## v0.31.0 - 2021-05-26 ### Chore + * Format iOS stuff [584c873] * LibOlm has been updated to 3.2.3 ### Feature + * Cute animation for hiding the + button in inputbar [37c40a2] * Improved chat bubble design and splash animations [0b3734f] * Zoom page transition on Android and Fuchsia [e6c20dd] ### Fixes + * "Pick an image" button in emote settings doesn't do anything [e6be684] * Formatting and style [2540a6c] * Emoji picker [e1bd4e1] @@ -1660,9 +2675,11 @@ FluffyChat 0.32.0 targets improved stability and a new onboarding flow where sin * Send read markers [08dd2d7] ### Docs + * Update code style [3e7269d] ### Refactor + * Structure files in more directories [ebc598a] * Rename UI to Views [e44de26] * rename UI to View and MVC login page [cc113bb] @@ -1675,40 +2692,58 @@ FluffyChat 0.32.0 targets improved stability and a new onboarding flow where sin ## v0.30.2 - 2021-05-13 ### Feature + * Implement registration with email [19616f3] ### Fixes + * Android input after sending message [4488520] ### Changes + * Switch to tchncs.de as default homeserver ### Refactor + * UIA registering [48bf116] ## v0.30.1 - 2021-05-07 ### Chore + * Update translations ### Fixes + * Record audio on iOS [cd1e9ae] ## v0.30.0 - 2021-05-01 -In this release we have mostly focused on bugfixing and stability. We have switched to the new Flutter 2 framework and have done a lot of refactoring under the hood. The annoying freezing bug should now be fixed. Voice messages now have a new backend which should improve the sound quality and stability. There is now a more professional UI for editing aliases of a room. Users can now see a list of all aliases, add new aliases, delete them and mark one alias as the canonical (or main) alias. Some minor design changes and design fixes should improve the overall UX of the app exspecially on tablets. +In this release we have mostly focused on bugfixing and stability. We have switched to the new +Flutter 2 framework and have done a lot of refactoring under the hood. The annoying freezing bug +should now be fixed. Voice messages now have a new backend which should improve the sound quality +and stability. There is now a more professional UI for editing aliases of a room. Users can now see +a list of all aliases, add new aliases, delete them and mark one alias as the canonical (or main) +alias. Some minor design changes and design fixes should improve the overall UX of the app +exspecially on tablets. -Version 0.30.0 will be the first version with arm64 support. You can download binaries from the CI and we will try to publish it on Flathub. Together with the new Linux Desktop Notifications feature, this might be interesting for the Librem 5 or the PinePhone. Sadly I don't own one of these very interesting devices. If you have one, I would very like to see some screenshots of it! :-) +Version 0.30.0 will be the first version with arm64 support. You can download binaries from the CI +and we will try to publish it on Flathub. Together with the new Linux Desktop Notifications feature, +this might be interesting for the Librem 5 or the PinePhone. Sadly I don't own one of these very +interesting devices. If you have one, I would very like to see some screenshots of it! :-) ### Chore + * Update UP and automatically re-register UP on startup [aa3348e] ### Feature + * Desktop notifications on Linux Desktop [25e76f0] * Much better alias managing [642db67] * Archive with clean up [f366ab6] ### Fixes + * Lock screen [f8ba7bd] * Freeze bug [15c3178] * UserBottomSheet [dbb0464] @@ -1723,6 +2758,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Chat UI doesnt load [4f20ea4] ### Refactor + * Remove unused variable [b9f5c94] * Remove flutter_sound [334d4c0] * Switch to record package [2cf4f47] @@ -1753,9 +2789,11 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.29.1 - 2021-04-13 ### Chore + * Bump version [215f3c8] ### Fixes + * Save file [3f854d6] * Routing broken in chat details [f1166b2] * Tests [e75a5a0] @@ -1763,6 +2801,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * nogooglewarning [7619941] ### Refactor + * MVC archive [c2cbad7] * MVC sign up password view [fa0162a] * MVC sign up view [db19b37] @@ -1771,6 +2810,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.29.0 - 2021-04-09 ### Chore + * Clean up repo [ef7ccef] * Bump version [81a4c26] * Nicer FAB icon [3eeb9a9] @@ -1779,9 +2819,11 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Remove unused dependencies [c505c50] ### Feature + * Experimental support for room upgrades [a3af5a9] ### Fixes + * Room upgrade again [1d40705] * Better padding [c79562f] * Room upgrade [dac26dd] @@ -1805,9 +2847,11 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Select room version [2f5a73f] ### Docs + * Add code style [035ad96] ### Refactor + * Move app_config to /configs [8b9f4a4] * homeserver picker view [8e828d8] * widgets dir [c9ab69a] @@ -1815,12 +2859,15 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.28.1 - 2021-03-28 ### Chore + * Update version [518634a] ### Feature + * Implement new search view design [e42dd4b] ### Fixes + * Share on iOS [ea31991] * Permission to send video call [4de6d16] * Unread badge color [49d5f86] @@ -1831,11 +2878,13 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Set status missing [17a3311] ### Refactor + * push stuff [b6eaf5b] ## v0.28.0 - 2021-03-16 ### Chore + * Bump version [f8ee682] * Change push gateway url [078aefa] * Update file picker cross dependency [91c6912] @@ -1845,12 +2894,14 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Update famedlySdk [ec64cf6] ### Feature + * Cache and resend status message [c8a7031] * New experimental design [94aa9a3] * Better verification design [9bcd6b2] * Verify and block devices in devices list [8ebacfe] ### Fixes + * substring in reply key respects unicode runes [5695342] * Resend status message [05cd699] * Remove test push [a838d90] @@ -1892,10 +2943,12 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Use single-isolate push [949771d] ### Docs + * Update readme and contributing [449e46d] * Update Turkish translation for website [4a664eb] ### Refactor + * Update SDK and enable login with email and phone [864b665] * Migrate to flutter 2 [bb97b1b] * Switch to TextButton [55803d1] @@ -1903,6 +2956,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.27.0 - 2021-02-17 ### Chore + * Switch to experimental new hedwig [30a1fb0] * update sdk & remove selfSign [26f7cb3] * Update sdk [cde8a30] @@ -1910,6 +2964,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Change push gateway port [8f36140] ### Feature + * localize bootstrap [395e62e] * Add more bootstrap features [e4db84a] * Add some tooltipps [b9eb8d1] @@ -1924,6 +2979,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Implement autofillhints [41a2457] ### Fixes + * Website [080a909] * docs _site dir [875d652] * Bootstrap dialog [c72da0a] @@ -1960,29 +3016,35 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * iOS push [c01bdf7] ### Docs + * Fix qr-codes [c7f0a74] * grammar fixes [c4d569b] ### Refactor + * Theme colors [fe13778] * border radius [ddd10d1] ## v0.26.1 - 2021-01-26 ### Chore + * Update SDK [e9df6bf] * Bump version [d79b356] * Update dependencies [6159f99] ### Feature + * Add unified push as push provider [124a5ee] ### Fixes + * Link color [16d6623] ## v0.26.0 - 2021-01-25 ### Chore + * Redesign textfields [aef8090] * Simplify bootstrap [2df4a78] * Update audio player icons [3f14d5e] @@ -1998,6 +3060,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Use correct paths on new server [2f00007] ### Feature + * emoji working on desktop [c3feb65] * Implement sso [d1d470d] * Implement app lock [77ee2ef] @@ -2005,6 +3068,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Display version number in app [e1e60c4] ### Fixes + * Dark mode fixes [36746c8] * Dark theme [0bd0e58] * clean up iOS dir [6ae59a8] @@ -2038,6 +3102,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Readme [dda0925] ### Docs + * Make howtofork.md less misunderstandable [96de54a] * Add howtofork.md [f091469] * Mention emoji font [bb53714] @@ -2045,23 +3110,28 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Update fdroid button [ea7e20b] ### Refactor + * Theme and iOS stuff [189f65a] * Upgrade to latest flutter_sound_lite [2f7dece] ## v0.25.1 - 2021-01-17 ### Chore + * Bump version [c881424] ### Fixes + * Change size [83e2385] ### Refactor + * remove deprecated approute [be08de5] ## v0.25.0 - 2021-01-16 ### Chore + * Minor design improvements [d4dbe83] * Minor design tweaks [06581e2] * Bump version [7f51f7f] @@ -2069,6 +3139,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Better authwebview [d76df0a] ### Fixes + * Share files [d018a4b] * Typing update [9b5a3ca] * Status [d27dbe0] @@ -2091,9 +3162,11 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Minor apl bugs [05b9551] ### Docs + * Update fdroid logo [31d16a0] ### Refactor + * Use APL [cbcfa15] * Use Provider [880f9cc] * Use adaptive_theme [5d52c26] @@ -2101,29 +3174,35 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.24.3 - 2021-01-15 ### Chore + * Bump version [46c8386] * Update SDK [ba0726c] * Update fdroid domain [f130681] * Update dependencies [611e5e3] ### Feature + * Add Turkish translations for website [817c7dd] * Handle matrix: URIs as per MSC2312 [1da643f] ### Fixes + * Format [84b2ac9] * Push gateway url [ed2fbf7] ## v0.24.2 - 2021-01-08 ### Chore + * Update linux version [ef9369c] * Update SDK [4a006c9] ### Feature + * Regulate when thumbnails are animated as per MSC2705 [f5e11c2] ### Fixes + * Don't allow an empty ssss passphrase in key verification [3a0ce79] * reactions [92684da] * Reply fallback sometimes being stripped incorrectly [e9ec699] @@ -2131,11 +3210,13 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Properly handle url encoding in matrix.to URLs [baccd0a] ### Refactor + * Switch to loading dialog [e84bc25] ## v0.24.1 - 2020-12-24 ### Chore + * Update linux build [a91407f] * Add website to main repo [4df33a1] * Update dependencies [0d9f418] @@ -2145,11 +3226,13 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Update SDK [e802593] ### Feature + * Better invite search bar [3c4a29b] * Open alias in discover page [f0d1f5a] * Implement logger [714c7b4] ### Fixes + * auto-dep update [d9e8c5f] * Read receipts and filtered events [0ae36f0] * Don't re-render the lock icon nearly as often [00a56a7] @@ -2168,6 +3251,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.24.0 - 2020-12-18 ### Chore + * Update dependencies [550cb4a] * Update SDK [775a33b] * Update dependencies [644433c] @@ -2176,6 +3260,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Update dependencies [5af4eab] ### Feature + * Add languages to iOS [68a5efb] * Bring back config.json [b6a0d37] * Implement emojipicker for reactions [20b3157] @@ -2191,6 +3276,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Implement rich notification settings [87a73dd] ### Fixes + * Update typing [3d70b1e] * Build in dev [f892a9f] * Fix that damn regex [8961bff] @@ -2207,16 +3293,19 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * CI [da5bc56] ### Refactor + * Update sdk [32acc21] ## v0.23.1 - 2020-11-25 ### Fixes + * Release CI [14d8c80] ## v0.23.0 - 2020-11-25 ### Chore + * Update adaptive dialogs [0061660] * Prettier redacted events [d1e291e] * Minor design changes in user viewer [b4fb283] @@ -2225,6 +3314,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Only load google services if needed [bae779a] ### Feature + * Next version [1af048e] * Annoy user with dialog to add a recovery method [d9ec9f6] * Implement password recovery [4b2fef5] @@ -2233,6 +3323,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Improved encryption UI [2516848] ### Fixes + * Broken dialog [97bb692] * set email dialog [72e325a] * Minor fixes [11e2dd5] @@ -2248,17 +3339,20 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Suggest correct rooms [59ec9de] ### Refactor + * Make verification in dialogs [1f9e953] * matrix to link prefix [1aa9c08] ## v0.22.1 - 2020-11-21 ### Fixes + * Input bar not working, making app unusable [10773b4] ## v0.22.0 - 2020-11-21 ### Chore + * fix CI [00ed0d6] * fix CI [bb4bb9f] * Fix CI variables [d3822b0] @@ -2272,6 +3366,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Remove unused dependency [d12de2d] ### Feature + * Add svg support and better image handling [f70bbc3] * add config.json [4b7fb6b] * persistent upload of release artifacts [1b2481b] @@ -2279,28 +3374,33 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Better encryption / verification [1ff986e] ### Fixes + * iOS [26731ab] * resolve some sentry issues [61f35e8] * resolve some sentry issues [2c3693e] * iOS build [9fee409] * Automatic update deps job [255c05d] -* Don't re-render message widgets on insertion of new messages, making e.g. audio playing not stop [25b2997] +* Don't re-render message widgets on insertion of new messages, making e.g. audio playing not + stop [25b2997] * Add missing safearea [caab868] * no pushers enpdoint [b3942ad] * Sentry and small null fix [5dc22be] ### Refactor + * CI [34d7fdd] * SDK update [7e23280] ## v0.21.1 - 2020-10-28 ### Chore + * update version code [d1dfa9c] ## v0.21.0 - 2020-10-28 ### Chore + * Change compileSdkVersion again [f93f9c2] * Update packages [b471bd0] * Update SDK [86a385d] @@ -2311,6 +3411,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * release [844b4a8] ### Fixes + * CompileSDKVersion [bcf75fc] * Target sdk [c3e23b6] * File picker issue [aa191c1] @@ -2326,6 +3427,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.20.0 - 2020-10-23 ### Chore + * update dependencies [427cdc0] * upate matrix link text [0892ca9] * Change default linux window size [719323a] @@ -2337,6 +3439,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Make app ready for flutter 1 22 [e5b23fa] ### Feature + * Implement mouse select chat list items [6d41136] * Implement linux desktop notifications [75cd6f1] * Implement change device name [bfd3888] @@ -2349,6 +3452,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Enable macOS build [a845209] ### Fixes + * return text field to the previous state after editing message [08e61c0] * Web server picker [4cb19be] * Some single-emoji names crashing [b29ebce] @@ -2391,6 +3495,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi ## v0.19.0 - 2020-09-21 ### Chore + * Version update & olm-CI [0f805a2] * Update SDK & Changelog [1825543] * Add new language [c6d67ad] @@ -2404,6 +3509,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * update sdk [954eedb] ### Feature + * Implement send reactions [6bf25b7] * Improve design [c8a63c6] * Display emotes/emojis bigger [9cccd07] @@ -2419,6 +3525,7 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * New notification sound [8a5be21] ### Fixes + * Last bits for the release [1db9bdd] * Small stuff [9d3f272] * Search bar [eca25de] @@ -2434,5 +3541,5 @@ Version 0.30.0 will be the first version with arm64 support. You can download bi * Send read receipt only on focus [98316f1] * Desktop notifications [b05bfa6] - -This CHANGELOG.md was generated with [**Changelog for Dart**](https://pub.dartlang.org/packages/changelog) +This CHANGELOG.md was generated with [**Changelog for Dart +**](https://pub.dartlang.org/packages/changelog) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 000000000..6c192cc44 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,172 @@ +# Contributing to FluffyChat +Contributions are always welcome. Yet we might lack manpower to review all of them in time. + +To improve the process please make sure that you read the following guidelines carefully: + +## Contributing Guidelines + +1. Always create a Pull Request for any changes. +2. Whenever possible please make sure that your Pull Request only contains **one** commit. Cases where multiple commits make sense are very rare. +3. Do not add merge commits. Use rebases. +4. Every Pull Request should change only one thing. For bigger changes it is often better to split them up in multiple Pull Requests. +5. [Sign your commits](https://docs.github.com/en/authentication/managing-commit-signature-verification/signing-commits). +6. Format the commit message as [Conventional Commits](https://www.conventionalcommits.org). +7. Format (`flutter format lib`) and sort impots (`dart run import_sorter:main --no-comments`) in all code files. +8. For bigger or complex changes (more than a couple of code lines) write an issue or refer to an existing issue and ask for approval from the maintainers (@krille-chan) **before** starting to implement it. This way you reduce the risk that your Pull Request get's declined. +9. Prefer simple and easy to maintain solutions over complexity and fancy ones. + +# Code Style + +FluffyChat tries to be as minimal as possible even in the code style. We try to keep the code clean, simple and easy to read. The source code of the app is under `/lib` with the main entry point `/lib/main.dart`. + + + + + + +**Table of Contents** + +- [Directory Structure:](#directory-structure) +- [Separation of Controllers and Views](#separation-of-controllers-and-views) +- [Formatting](#formatting) +- [Code Analyzis](#code-analyzis) + + + + + + +### Directory Structure: + + +- /lib + - /config + - app_config.dart + - ...Constants, styles and other configurations + - /utils + - handy_function.dart + - ...Helper functions and extensions + - /pages + - /chat + - chat.dart + - chat_view.dart + - /chat_list + - chat_list.dart + - chat_list_view.dart + - ...The pages of the app separated in Controllers and Views + - /widgets + - /layouts + - ...Custom widgets created for this project + - main.dart + + +Most of the business model is in the Famedly Matrix Dart SDK. We try to not keep a model inside of the source code but extend it under `/utils`. + +### Separation of Controllers and Views + +We split views and controller logic with stateful widgets as controller where the build method just builds a stateless widget which receives the state as the only parameter. A common controller would look like this: + +```dart +// /lib/controller/enter_name_controller.dart +import 'package:flutter/material.dart'; + +class EnterName extends StatefulWidget { + @override + EnterNameController createState() => EnterNameController(); +} + +class EnterNameController extends State { + final TextEditingController textEditingController = TextEditingController(); + String name = 'Unknown'; + + /// Changes the name with the content in the textfield. If the textfield is + /// empty, this breaks up and displays a SnackBar. + void setNameAction() { + if (textEditingController.text.isEmpty) { + ScaffoldMessenger.of(context).showSnackBar( + SnackBar( + content: Text('You have not entered your name'), + ), + ); + return; + } + setState(() => name = textEditingController.text); + } + + @override + Widget build(BuildContext context) => EnterNameView(this); +} +``` + +So we have a controller for a `EnterName` view which as a `TextEditingController`, a state `name` and an action `void setNameAction()`. Actions must always be methods of a type, that we dont need to pass parameters in the corresponding view class and must have dartdoc comments. + +The view class could look like this: + +```dart +// /lib/views/enter_name_view.dart +import 'package:flutter/material.dart'; + +class EnterNameView extends StatelessWidget { + final EnterNameController controller; + + const EnterNameView(this.controller, {Key key}) : super(key: key); + @override + Widget build(BuildContext context) { + return Scaffold( + appBar: AppBar( + title: Text('Your name: ${controller.name}'), + ), + body: Center( + child: TextField( + controller: controller.textEditingController, + ), + ), + floatingActionButton: FloatingActionButton( + onPressed: controller.setNameAction, + child: Icon(Icons.save), + ), + ); + } +} +``` + +Views should just contain code which describes the view. All other parameters or logic should be in the controller. The job of the view class is just to take the current state and build the widget tree and pipe the callbacks back. If there is any calulation necessary which is not solveable as a simple if-else or switch statement, it should be done in an external helper function unter `/lib/utils/`. + +All file names must be lower_snake_case. All views must have a `View` suffix and all controller must have a `Controller` suffix. Widgets may have a controller too but they should pass the callbacks back to the view where possible. Calling one line methods directly in the view is only recommended if there is no need to pass a parameter. + +To perform an action on state initialization we use the initState method: +```dart +@override + void initState() { + // TODO: implement initState + super.initState(); + } +``` + +And the dispose method to perform an action on disposing: +```dart +@override + void dispose() { + // TODO: implement dispose + super.dispose(); + } +``` + +To run code after the widget was created first we use the WidgetBindings in the initState: +```dart +@override + void initState() { + WidgetsBinding.instance.addPostFrameCallback((_) { + // Do something when build is finished + }); + super.initState(); + } +``` + +### Formatting + +We do not allow code with wrong formatting. Please run `flutter format lib` if your IDE doesn't do this automatically. + +### Code Analyzis + +We do not allow codes with dart errors or warnings. We use the [flutter_lints](https://pub.dev/packages/flutter_lints) package for static code analysis with additional rules under `analysis_options.yaml`. diff --git a/Dockerfile b/Dockerfile index 831ba871d..39505aadf 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,5 +1,5 @@ FROM ghcr.io/cirruslabs/flutter as builder -RUN sudo apt update && sudo apt install curl wget jq -y +RUN sudo apt update && sudo apt install curl wget jq build-essential -y WORKDIR /tmp RUN wget https://github.com/mikefarah/yq/releases/download/v4.40.5/yq_linux_amd64.tar.gz @@ -8,6 +8,9 @@ RUN mv yq_linux_amd64 /usr/bin/yq COPY . /app WORKDIR /app +RUN curl https://sh.rustup.rs -sSf | bash -s -- -y +ENV PATH="/root/.cargo/bin:${PATH}" +RUN rustup component add rust-src --toolchain nightly-x86_64-unknown-linux-gnu RUN ./scripts/prepare-web.sh COPY config.* /app/ RUN flutter pub get diff --git a/PRIVACY.md b/PRIVACY.md index dd978f243..53c7cdd82 100644 --- a/PRIVACY.md +++ b/PRIVACY.md @@ -1,35 +1,34 @@ # Privacy -FluffyChat is available on Android, iOS and as a web version. Desktop versions for Windows, Linux and macOS may follow. +FluffyChat is available on Android, iOS, Linux and as a web version. Desktop versions for Windows and macOS may follow. * [Matrix](#matrix) -* Sentry * [Database](#database) * [Encryption](#encryption) * [App Permissions](#app-permissions) * [Push Notifications](#push-notifications) -* [Stories](#stories) +* [PlayStore Safety Standards](#playstore-safety) -## Matrix +## # Matrix FluffyChat uses the Matrix protocol. This means that FluffyChat is just a client that can be connected to any compatible matrix server. The respective data protection agreement of the server selected by the user then applies. For convenience, one or more servers are set as default that the FluffyChat developers consider trustworthy. The developers of FluffyChat do not guarantee their trustworthiness. Before the first communication, users are informed which server they are connecting to. -FluffyChat only communicates with the selected server, with sentry.io if enabled and with [OpenStreetMap](https://openstreetmap.org) to display maps. +FluffyChat only communicates with the selected server and with [OpenStreetMap](https://openstreetmap.org) to display maps. More information is available at: [https://matrix.org](https://matrix.org) -## Database -FluffyChat caches some data received from the server in a local database on the device of the user. +## # Database +FluffyChat caches some data received from the server in a local sqflite database on the device of the user. On web indexedDB is used. FluffyChat always tries to encrypt the database by using SQLCipher and stores the encryption key in the [Secure Storage](https://pub.dev/packages/flutter_secure_storage) of the device. -More information is available at: [https://pub.dev/packages/hive](https://pub.dev/packages/hive) +More information is available at: [https://pub.dev/packages/sqflite](https://pub.dev/packages/sqflite) and [https://pub.dev/packages/sqlcipher_flutter_libs](https://pub.dev/packages/sqlcipher_flutter_libs) -## Encryption +## # Encryption All communication of substantive content between Fluffychat and any server is done in secure way, using transport encryption to protect it. -FluffyChat is able to use End-To-End-Encryption as a tech preview. +FluffyChat also uses End-To-End-Encryption by using [Vodozemac](https://github.com/matrix-org/vodozemac) and enables it by default for private chats. -## App Permissions +## # App Permissions The permissions are the same on Android and iOS but may differ in the name. This are the Android Permissions: @@ -52,7 +51,7 @@ The user is able to send files from the device's file system. #### Location FluffyChat makes it possible to share the current location via the chat. When the user shares their location, FluffyChat uses the device location service and sends the geo-data via Matrix. -## Push Notifications +## # Push Notifications FluffyChat uses the Firebase Cloud Messaging service for push notifications on Android and iOS. This takes place in the following steps: 1. The matrix server sends the push notification to the FluffyChat Push Gateway 2. The FluffyChat Push Gateway forwards the message in a different format to Firebase Cloud Messaging @@ -60,7 +59,7 @@ FluffyChat uses the Firebase Cloud Messaging service for push notifications on A 4. The device receives the push notification from Firebase Cloud Messaging and displays it as a notification The source code of the push gateway can be viewed here: -[https://gitlab.com/famedly/services/famedly-push-gateway](https://gitlab.com/famedly/services/famedly-push-gateway) +[https://github.com/krille-chan/fluffygate](https://github.com/krille-chan/fluffygate) `event_id_only` is used as the format for the push notification. A typical push notification therefore only contains: - Event ID @@ -95,22 +94,20 @@ A typical push notification could look like this: FluffyChat sets the `event_id_only` flag at the Matrix Server. This server is then responsible to send the correct data. -## Stories -FluffyChat supports stories which is a feature similar to WhatsApp status or Instagram stories. However it is just a different GUI for the same room-related communication. More information about the feature can be found here: +# # Explanation of FluffyChat's Compliance with Google Play Store's Safety Standards -https://github.com/krillefear/matrix-doc/blob/main/proposals/3588-stories-as-rooms.md +FluffyChat is committed to promoting a safe and respectful environment for all users. As a Matrix client, FluffyChat connects users to various Matrix servers. Please note that FluffyChat does not host or manage any servers directly, and as such, we do not have the capability to enforce content moderation or deletion within the app itself. -Stories are basically: +To enhance user safety and help protect against the sexual abuse and exploitation of children, FluffyChat enables users to report inappropriate content directly to server administrators. -- End to end encrypted rooms -- Read-only rooms with only one admin who can post stuff (while there is no technical limitation to have multiple admins) +#### Reporting Content or Users: -By default: +1. Mark a message in the chat: Tap and hold the message you wish to report. +2. Report the message: Select the "Report" option. +3. Provide a reason and score: Enter the reason for reporting and assign a score from 1-100 to indicate how offensive the content is. +4. Notification to admin: The server administrator will be notified of the reported content. -- The user has to invite all contacts manually to a story room -- The user can only invite contacts (matrix users the user shares a DM room with) to the story room -- The story room is created when the first story is posted -- User can mute and leave story rooms +In addition to reporting messages, users can also report other users following a similar process. -The user is informed in the app that in theory all contacts can see each other in the story room. The user must give consent here. However the user is at any time able to create a group chat and invite all of their contacts to this chat in any matrix client which has the same result. +We encourage server administrators to adhere to strict safety standards and provide mechanisms for addressing and moderating inappropriate content. For more information on the Matrix protocol and its safety standards, please refer to the following link: https://matrix.org/docs/older/moderation/ diff --git a/README.md b/README.md index 8dec17573..b118f085e 100644 --- a/README.md +++ b/README.md @@ -1,12 +1,12 @@ ![Screenshot](https://github.com/krille-chan/fluffychat/blob/main/assets/banner_transparent.png?raw=true) -[FluffyChat](https://fluffychat.im) is an open source, nonprofit and cute [[matrix](https://matrix.org)] client written in [Flutter](https://flutter.dev). The goal of the app is to create an easy to use instant messenger which is open source and accessible for everyone. +[FluffyChat](https://fluffy.chat) is an open source, nonprofit and cute [[matrix](https://matrix.org)] client written in [Flutter](https://flutter.dev). The goal of the app is to create an easy to use instant messenger which is open source and accessible for everyone. ### Links: - 🌐 [[Weblate] Translate FluffyChat into your language](https://hosted.weblate.org/projects/fluffychat/) -- 🌍 [[m] Join the community](https://matrix.to/#/#fluffychat:matrix.org) -- 📰 [[Mastodon] Get updates on social media](https://mastodon.art/@krille) +- 🌍 [[m] Join the community](https://matrix.to/#/#fluffy-space:matrix.org) +- 📰 [[Mastodon] Get updates on social media](https://troet.cafe/@krille) - 🖥️ [[Famedly] Server hosting and professional support](https://famedly.com/kontakt) - 💝 [[Liberapay] Support FluffyChat development](https://de.liberapay.com/KrilleChritzelius) @@ -14,7 +14,8 @@ ### Screenshots: -![Screenshot](https://github.com/krille-chan/fluffychat/blob/main/docs/screenshots/product.jpeg?raw=true) + + # Features @@ -43,13 +44,67 @@ Please visit the website for installation instructions: -- https://fluffychat.im +- https://fluffy.chat # How to build -Please visit the [Wiki](https://github.com/krille-chan/fluffychat/wiki) for build instructions: +1. To build FluffyChat you need [Flutter](https://flutter.dev) and [Rust](https://www.rust-lang.org/tools/install) -- https://github.com/krille-chan/fluffychat/wiki/How-To-Build +2. Clone the repo: +``` +git clone https://github.com/krille-chan/fluffychat.git +cd fluffychat +``` +3. Choose your target platform below and enable support for it. +3.1 If you want, enable Googles Firebase Cloud Messaging: + +`./scripts/add-firebase-messaging.sh` + +4. Debug with: `flutter run` + +### Android + +* Build with: `flutter build apk` + +### iOS / iPadOS + +* Have a Mac with Xcode installed, and set up for Xcode-managed app signing +* If you want automatic app installation to connected devices, make sure you have Apple Configurator installed, with the Automation Tools (`cfgutil`) enabled +* Set a few environment variables + * FLUFFYCHAT_NEW_TEAM: the Apple Developer team that your certificates should live under + * FLUFFYCHAT_NEW_GROUP: the group you want App IDs and such to live under (ie: com.example.fluffychat) + * FLUFFYCHAT_INSTALL_IPA: set to `1` if you want the IPA to be deployed to connected devices after building, otherwise unset +* Run `./scripts/build-ios.sh` + +### Web + +* Build with: +```bash +./scripts/prepare-web.sh # To install Vodozemac +flutter build web --release +``` + +* Optionally configure by serving a `config.json` at the same path as fluffychat. + An example can be found at `config.sample.json`. All values there are optional. + **Please only the values, you really need**. If you e.g. only want + to change the default homeserver, then only modify the `defaultHomeserver` key. + +### Desktop (Linux, Windows, macOS) + +* Enable Desktop support in Flutter: https://flutter.dev/desktop + +#### Install custom dependencies (Linux) + +```bash +sudo apt install libjsoncpp1 libsecret-1-dev libsecret-1-0 librhash0 libwebkit2gtk-4.0-dev lld +``` + +* Build with one of these: +```bash +flutter build linux --release +flutter build windows --release +flutter build macos --release +``` # Special thanks @@ -62,8 +117,6 @@ Please visit the [Wiki](https://github.com/krille-chan/fluffychat/wiki) for buil * Also thanks to all translators and testers! With your help, fluffychat is now available in more than 12 languages. -* Noto Emoji Font for the awesome emojis. - * WoodenBeaver sound theme for the notification sound. * The Matrix Foundation for making and maintaining the [emoji translations](https://github.com/matrix-org/matrix-spec/blob/main/data-definitions/sas-emoji.json) used for emoji verification, licensed Apache 2.0 diff --git a/SECURITY.md b/SECURITY.md new file mode 100644 index 000000000..ff51b140f --- /dev/null +++ b/SECURITY.md @@ -0,0 +1,15 @@ +# Security Policy + +If you believe you have discovered a security vulnerability in this project, **do not open a public issue**. + +To report a security issue responsibly, please go to the Security tab or visit: + +https://github.com/krille-chan/fluffychat/security/advisories/new + +The following information can help us address the issue: + +- Clear steps to reproduce the vulnerability +- The software version you are using +- The affected platforms + +We appreciate your report and will respond as quickly as possible. Please note that this project is maintained by volunteers and is provided without guarantees. diff --git a/analysis_options.yaml b/analysis_options.yaml index 34a01078b..0b19afcfc 100644 --- a/analysis_options.yaml +++ b/analysis_options.yaml @@ -2,52 +2,75 @@ include: package:flutter_lints/flutter.yaml linter: rules: - - camel_case_types - avoid_print - constant_identifier_names - prefer_final_locals - prefer_final_in_for_each - sort_pub_dependencies - require_trailing_commas + - omit_local_variable_types + - cancel_subscriptions + - always_declare_return_types + - avoid_void_async + - no_adjacent_strings_in_list + - test_types_in_equals + - throw_in_finally + - unnecessary_statements + - avoid_bool_literals_in_conditional_expressions + - prefer_single_quotes + - prefer_const_declarations + - unnecessary_lambdas + - combinators_ordering + - noop_primitive_operations + - unnecessary_null_checks + - unnecessary_null_in_if_null_operators + - unnecessary_to_list_in_spreads + - use_is_even_rather_than_modulo + - use_super_parameters + # Flutter specific: + - use_colored_box analyzer: + plugins: + - dart_code_linter errors: todo: ignore use_build_context_synchronously: ignore exclude: - - lib/generated_plugin_registrant.dart - lib/l10n/*.dart -dart_code_metrics: - metrics: - cyclomatic-complexity: 20 - number-of-arguments: 4 - maximum-nesting-level: 5 - source-lines-of-code: 50 - maintainability-index: 40 +dart_code_linter: rules: - - no-boolean-literal-compare - - no-empty-block - - prefer-conditional-expressions + # Dart specific: + - avoid-dynamic + - avoid-redundant-async + - avoid-unnecessary-type-assertions + - avoid-unnecessary-type-casts + - avoid-unrelated-type-assertions - no-equal-then-else - - no-magic-number: - severity: style - - avoid-late-keyword: - severity: style - - avoid-non-null-assertion: - severity: style - - avoid-unused-parameters - - binary-expression-operand-order - - avoid-unnecessary-setstate + - prefer-first + - prefer-last + - prefer-immediate-return + - prefer-enums-by-name + - avoid-unnecessary-conditionals + # TODO: + # - member-ordering + # - avoid-global-state + # - prefer-match-file-name + # - avoid-banned-imports: + # entries: + # - paths: ['some/folder/.*\.dart', 'another/folder/.*\.dart'] + # deny: ['package:flutter/material.dart'] + # message: 'Do not import Flutter Material Design library, we should not depend on it!' + # - no-magic-number: + # allowed: [-1, 0, 1,2,4,6,8,12,16,32,40,56,64] + # allow-only-once: true + # Flutter specific: + - prefer-media-query-direct-access - avoid-wrapping-in-padding - - prefer-const-border-radius - - prefer-single-widget-per-file: - ignore-private-widgets: true - - prefer-extracting-callbacks - metrics-exclude: - - test/** - rules-exclude: - - test/** - anti-patterns: - - long-method - - long-parameter-list + - prefer-correct-edge-insets-constructor + - avoid-returning-widgets + # TODO: + # - prefer-single-widget-per-file: + # ignore-private-widgets: true + # - prefer-extracting-callbacks diff --git a/android/app/build.gradle b/android/app/build.gradle deleted file mode 100644 index aa8b76494..000000000 --- a/android/app/build.gradle +++ /dev/null @@ -1,93 +0,0 @@ -def localProperties = new Properties() -def localPropertiesFile = rootProject.file('local.properties') -if (localPropertiesFile.exists()) { - localPropertiesFile.withReader('UTF-8') { reader -> - localProperties.load(reader) - } -} - -def flutterRoot = localProperties.getProperty('flutter.sdk') -if (flutterRoot == null) { - throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.") -} - -def flutterVersionCode = localProperties.getProperty('flutter.versionCode') -if (flutterVersionCode == null) { - flutterVersionCode = '1' -} - -def flutterVersionName = localProperties.getProperty('flutter.versionName') -if (flutterVersionName == null) { - flutterVersionName = '1.0' -} - -apply plugin: 'com.android.application' -apply plugin: 'kotlin-android' -apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle" - -def keystoreProperties = new Properties() -def keystorePropertiesFile = rootProject.file('key.properties') -if (keystorePropertiesFile.exists()) { - keystoreProperties.load(new FileInputStream(keystorePropertiesFile)) -} - -android { - compileSdkVersion 34 - - sourceSets { - main.java.srcDirs += 'src/main/kotlin' - } - - lintOptions { - disable 'InvalidPackage' - } - - defaultConfig { - applicationId "chat.fluffy.fluffychat" - minSdkVersion 21 - targetSdkVersion 33 - versionCode flutterVersionCode.toInteger() - versionName flutterVersionName - testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" - multiDexEnabled true - } - - signingConfigs { - release { - if (keystorePropertiesFile.exists()) { - keyAlias keystoreProperties['keyAlias'] - keyPassword keystoreProperties['keyPassword'] - storeFile file(keystoreProperties['storeFile']) - storePassword keystoreProperties['storePassword'] - } - } - } - buildTypes { - debug { - signingConfig signingConfigs.debug - versionNameSuffix "-debug" - } - release { - signingConfig signingConfigs.release - } - } - // https://stackoverflow.com/a/77494454/8222484 - packagingOptions { - pickFirst 'lib/x86/libc++_shared.so' - pickFirst 'lib/x86_64/libc++_shared.so' - pickFirst 'lib/armeabi-v7a/libc++_shared.so' - pickFirst 'lib/arm64-v8a/libc++_shared.so' - } -} - -flutter { - source '../..' -} - -dependencies { - implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" - //implementation 'com.google.firebase:firebase-messaging:19.0.1' // Workaround for https://github.com/microg/android_packages_apps_GmsCore/issues/313#issuecomment-617651698 - implementation 'androidx.multidex:multidex:2.0.1' -} - -//apply plugin: 'com.google.gms.google-services' diff --git a/android/app/build.gradle.kts b/android/app/build.gradle.kts new file mode 100644 index 000000000..0aa18d9b3 --- /dev/null +++ b/android/app/build.gradle.kts @@ -0,0 +1,95 @@ +import java.util.Properties +import java.io.FileInputStream + +plugins { + id("com.android.application") + id("kotlin-android") + // The Flutter Gradle Plugin must be applied after the Android and Kotlin Gradle plugins. + id("dev.flutter.flutter-gradle-plugin") +} + +if (file("google-services.json").exists()) { + apply(plugin = "com.google.gms.google-services") +} + +dependencies { + coreLibraryDesugaring("com.android.tools:desugar_jdk_libs:2.1.4") // For flutter_local_notifications // Workaround for: https://github.com/MaikuB/flutter_local_notifications/issues/2286 + implementation("androidx.core:core-ktx:1.17.0") // For Android Auto +} + + +// Workaround for https://pub.dev/packages/unifiedpush#the-build-fails-because-of-duplicate-classes +configurations.all { + // Use the latest version published: https://central.sonatype.com/artifact/com.google.crypto.tink/tink-android + val tink = "com.google.crypto.tink:tink-android:1.17.0" + // You can also use the library declaration catalog + // val tink = libs.google.tink + resolutionStrategy { + force(tink) + dependencySubstitution { + substitute(module("com.google.crypto.tink:tink")).using(module(tink)) + } + } +} + + +android { + namespace = "chat.fluffy.fluffychat" + compileSdk = flutter.compileSdkVersion + ndkVersion = flutter.ndkVersion + + compileOptions { + sourceCompatibility = JavaVersion.VERSION_11 + targetCompatibility = JavaVersion.VERSION_11 + isCoreLibraryDesugaringEnabled = true + } + + kotlinOptions { + jvmTarget = JavaVersion.VERSION_11.toString() + } + + signingConfigs { + create("release") { + keyAlias = "dummyAlias" + keyPassword = "dummyPassword" + storeFile = file("dummy.keystore") + storePassword = "dummyStorePassword" + } + } + + val keystoreProperties = Properties() + val keystorePropertiesFile = rootProject.file("key.properties") + if (keystorePropertiesFile.exists()) { + keystoreProperties.load(FileInputStream(keystorePropertiesFile)) + signingConfigs.getByName("release").apply { + keyAlias = keystoreProperties["keyAlias"] as String + keyPassword = keystoreProperties["keyPassword"] as String + storeFile = keystoreProperties["storeFile"]?.let { file(it) } + storePassword = keystoreProperties["storePassword"] as String + } + } + + defaultConfig { + applicationId = "chat.fluffy.fluffychat" + minSdk = flutter.minSdkVersion + targetSdk = flutter.targetSdkVersion + versionCode = flutter.versionCode + versionName = flutter.versionName + ndk { // Workaround for https://github.com/flutter/flutter/issues/162153#issuecomment-2612443642 + abiFilters += listOf("armeabi-v7a", "arm64-v8a", "x86_64", "x86") + } + } + + buildTypes { + release { + signingConfig = signingConfigs.getByName("release") + isMinifyEnabled = true + isShrinkResources = true + proguardFiles(getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro") + } + } +} + +flutter { + source = "../.." +} diff --git a/android/app/google-services.json b/android/app/google-services.json deleted file mode 100644 index e33988c40..000000000 --- a/android/app/google-services.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "project_info": { - "project_number": "865731724731", - "project_id": "fluffychat-ef3e8", - "storage_bucket": "fluffychat-ef3e8.appspot.com" - }, - "client": [ - { - "client_info": { - "mobilesdk_app_id": "1:865731724731:android:ec427b3b1dcd4a1e64309e", - "android_client_info": { - "package_name": "chat.fluffy.fluffychat" - } - }, - "oauth_client": [ - { - "client_id": "865731724731-od6969v178ul9970elgacpt936v5t7qg.apps.googleusercontent.com", - "client_type": 3 - } - ], - "api_key": [ - { - "current_key": "AIzaSyBLdZpGSPjcinikB4lAU6awW_h88NG17Sg" - } - ], - "services": { - "appinvite_service": { - "other_platform_oauth_client": [ - { - "client_id": "865731724731-od6969v178ul9970elgacpt936v5t7qg.apps.googleusercontent.com", - "client_type": 3 - }, - { - "client_id": "865731724731-ofdr7e6m04murgb1bvchlj9oaos0q5i3.apps.googleusercontent.com", - "client_type": 2, - "ios_info": { - "bundle_id": "im.fluffychat.app" - } - } - ] - } - } - } - ], - "configuration_version": "1" -} \ No newline at end of file diff --git a/android/app/src/main/AndroidManifest.xml b/android/app/src/main/AndroidManifest.xml index c0595780a..1b3f5182c 100644 --- a/android/app/src/main/AndroidManifest.xml +++ b/android/app/src/main/AndroidManifest.xml @@ -1,6 +1,6 @@ + android:installLocation="auto"> + + @@ -36,6 +30,7 @@ android:requestLegacyExternalStorage="true" android:allowBackup="false" android:fullBackupContent="false" + android:localeConfig="@xml/locale_config" > + + + + @@ -63,42 +62,40 @@ android:scheme="https" android:host="matrix.to"/> + + + + + + + + - + - + - - - - - - - - - - - + @@ -124,29 +121,13 @@ android:foregroundServiceType="camera|microphone|mediaProjection"> - - - - - + + - - - - - - - - - - - + + diff --git a/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt b/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt index d9930f557..0db8bdcae 100644 --- a/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt +++ b/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt @@ -2,17 +2,9 @@ import com.famedly.fcm_shared_isolate.FcmSharedIsolateService -import chat.fluffy.fluffychat.MainActivity - -import io.flutter.embedding.android.FlutterActivity import io.flutter.embedding.engine.FlutterEngine -import io.flutter.view.FlutterMain import io.flutter.embedding.engine.dart.DartExecutor.DartEntrypoint - import android.content.Context -import android.os.Bundle -import android.util.Log -import android.view.WindowManager class FcmPushService : FcmSharedIsolateService() { override fun getEngine(): FlutterEngine { diff --git a/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt b/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt index 1afc46062..747183cd3 100644 --- a/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt +++ b/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt @@ -4,13 +4,11 @@ import io.flutter.embedding.android.FlutterActivity import io.flutter.embedding.engine.FlutterEngine import android.content.Context -import androidx.multidex.MultiDex class MainActivity : FlutterActivity() { override fun attachBaseContext(base: Context) { super.attachBaseContext(base) - MultiDex.install(this) } diff --git a/android/app/src/main/kotlin/chat/fluffy/fluffychat/UnifiedPushService.kt b/android/app/src/main/kotlin/chat/fluffy/fluffychat/UnifiedPushService.kt deleted file mode 100644 index c5d4ba9d7..000000000 --- a/android/app/src/main/kotlin/chat/fluffy/fluffychat/UnifiedPushService.kt +++ /dev/null @@ -1,23 +0,0 @@ -package chat.fluffy.fluffychat - -import io.flutter.embedding.engine.FlutterEngine -import io.flutter.embedding.engine.dart.DartExecutor -import org.unifiedpush.flutter.connector.UnifiedPushReceiver - -import android.content.Context - -class UnifiedPushReceiver : UnifiedPushReceiver() { - override fun getEngine(context: Context): FlutterEngine { - var engine = MainActivity.engine - if (engine == null) { - engine = MainActivity.provideEngine(context) - engine.localizationPlugin.sendLocalesToFlutter( - context.resources.configuration - ) - engine.dartExecutor.executeDartEntrypoint( - DartExecutor.DartEntrypoint.createDefault() - ) - } - return engine - } -} \ No newline at end of file diff --git a/android/app/src/main/res/xml/automotive_app_desc.xml b/android/app/src/main/res/xml/automotive_app_desc.xml new file mode 100644 index 000000000..dd5581b2a --- /dev/null +++ b/android/app/src/main/res/xml/automotive_app_desc.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/android/app/src/main/res/xml/locale_config.xml b/android/app/src/main/res/xml/locale_config.xml new file mode 100644 index 000000000..03c69a698 --- /dev/null +++ b/android/app/src/main/res/xml/locale_config.xml @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/android/build.gradle b/android/build.gradle deleted file mode 100644 index a8c597ff1..000000000 --- a/android/build.gradle +++ /dev/null @@ -1,32 +0,0 @@ -buildscript { - ext.kotlin_version = '1.8.0' - repositories { - google() - mavenCentral() - } - - dependencies { - classpath 'com.android.tools.build:gradle:7.1.2' - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - //classpath 'com.google.gms:google-services:4.3.8' - } -} - -allprojects { - repositories { - google() - mavenCentral() - } -} - -rootProject.buildDir = '../build' -subprojects { - project.buildDir = "${rootProject.buildDir}/${project.name}" -} -subprojects { - project.evaluationDependsOn(':app') -} - -tasks.register("clean", Delete) { - delete rootProject.buildDir -} diff --git a/android/build.gradle.kts b/android/build.gradle.kts new file mode 100644 index 000000000..89176ef44 --- /dev/null +++ b/android/build.gradle.kts @@ -0,0 +1,21 @@ +allprojects { + repositories { + google() + mavenCentral() + } +} + +val newBuildDir: Directory = rootProject.layout.buildDirectory.dir("../../build").get() +rootProject.layout.buildDirectory.value(newBuildDir) + +subprojects { + val newSubprojectBuildDir: Directory = newBuildDir.dir(project.name) + project.layout.buildDirectory.value(newSubprojectBuildDir) +} +subprojects { + project.evaluationDependsOn(":app") +} + +tasks.register("clean") { + delete(rootProject.layout.buildDirectory) +} diff --git a/android/fastlane/metadata/android/en-US/changelogs/2324 (1.6.0).txt b/android/fastlane/metadata/android/en-US/changelogs/2324 (1.6.0).txt deleted file mode 100644 index b2318505f..000000000 --- a/android/fastlane/metadata/android/en-US/changelogs/2324 (1.6.0).txt +++ /dev/null @@ -1,68 +0,0 @@ -FluffyChat 1.6.0 features a lot of bug fixes and improvements. The code base has been -simplified and the drawer on the chat list page got a come-back. Some new features like -the space hierarchy and session dump have been implemented. - -- feat: Added monochrome entry for themed icon support in Android 13 (James Reilly) -- feat: Display timeline of messages in android notification (Christian Pauly) -- feat: Emoji related fixes (TheOneWithTheBraid) -- feat: Implement deleting pushers in app (Christian Pauly) -- feat: New material 3 design (Christian Pauly) -- feat: Redesign bootsstrap and offer secure storage support (Christian Pauly) -- feat: Send multiple images at once (Christian Pauly) -- feat: implement session dump (TheOneWithTheBraid) -- feat: implement space hierarchy (TheOneWithTheBraid) -- feat: introduce extended integration tests (TheOneWithTheBraid) -- feat: libhandy integration (TheOneWithTheBraid) -- fix: Clearing push triggered when only one room got seen (Christian Pauly) -- fix: Dont display loading dialog when adding reaction (Christian Pauly) -- fix: Follow up for spaces hierarchy (TheOneWithTheBraid) -- fix: Missing null checks in chat details view (Christian Pauly) -- fix: Non FCM Android builds crash on start (Christian Pauly) -- fix: Permission chooser dialog on iOS (Christian Pauly) -- fix: Set avatar on only single action available (Christian Pauly) -- fix: Sharing on iOS and iPad (Christian Pauly) -- fix: Unread bubble is invisible in dark mode (Christian Pauly) -- fix: appimage builds (TheOneWithTheBraid) -- fix: only use custom http client on android (Jayesh Nirve) -- fix: pass isrg cert to http client (Jayesh Nirve) -- refactor: Chat view (Christian Pauly) -- refactor: Encryption button (Christian Pauly) -- refactor: Remove duplicated imports (Christian Pauly) -- refactor: Remove legacy store (Christian Pauly) -- refactor: Remove presence status feature (Christian Pauly) -- refactor: Simplify MxcImage and replace CachedNetworkImage (Christian Pauly) -- refactor: Switch to Hive Collections DB (Christian Pauly) -- refactor: move start chat FAB to implementation file (TheOneWithTheBraid) -- Translated using Weblate (Catalan) (Alfonso Montero López) -- Translated using Weblate (Catalan) (Auri B.P) -- Translated using Weblate (Chinese (Simplified)) (Eric) -- Translated using Weblate (Croatian) (Milo Ivir) -- Translated using Weblate (Dutch) (Jelv) -- Translated using Weblate (English) (Raatty) -- Translated using Weblate (Estonian) (Priit Jõerüüt) -- Translated using Weblate (Finnish) (Aminda Suomalainen) -- Translated using Weblate (Galician) (Xosé M) -- Translated using Weblate (Indonesian) (Linerly) -- Translated using Weblate (Persian) (Amir Hossein Maher) -- Translated using Weblate (Polish) (Przemysław Romanik) -- Translated using Weblate (Russian) (Nikita Epifanov) -- Translated using Weblate (Turkish) (Oğuz Ersen) -- Translated using Weblate (Ukrainian) (Ihor Hordiichuk) -- chore: Add border to avatars (Christian Pauly) -- chore: Add fancy hero animations (Christian Pauly) -- chore: Adjust appbar design (Christian Pauly) -- chore: Adjust design (Christian Pauly) -- chore: Adjust search bar design (Christian Pauly) -- chore: Always display header elevation in chat (Christian Pauly) -- chore: Design follow up fixes (Christian Pauly) -- chore: Design follow up fixes (Christian Pauly) -- chore: Disable integration tests without runners (Krille Fear) -- chore: Enhance invitiation UX (Christian Pauly) -- chore: Make push helper more fail safe (Christian Pauly) -- chore: Make push helper more stable (Christian Pauly) -- chore: Minor design improvements (Christian Pauly) -- chore: Pinned events design (Christian Pauly) -- chore: Remove permission handler dependency and increase compileSdkVersion (Christian Pauly) -- chore: Switch to flutter 3.0.5 (Krille Fear) -- chore: Update SDK (Christian Pauly) -- chore: remove snapping sheet (TheOneWithTheBraid) \ No newline at end of file diff --git a/android/fastlane/metadata/android/en-US/changelogs/default.txt b/android/fastlane/metadata/android/en-US/changelogs/default.txt new file mode 100644 index 000000000..5eed864e7 --- /dev/null +++ b/android/fastlane/metadata/android/en-US/changelogs/default.txt @@ -0,0 +1,4 @@ +FluffyChat 2.4.0 adds a new improved GUI for managing stickers with tutorials how to +easily add your own sticker packs. +It also improves the search and image gallery in chats, especially encrypted chats. +Besides that this update comes with a lot of fixes and improvements under the hood. \ No newline at end of file diff --git a/android/gradle.properties b/android/gradle.properties index 94adc3a3f..975e44b52 100644 --- a/android/gradle.properties +++ b/android/gradle.properties @@ -1,3 +1,4 @@ -org.gradle.jvmargs=-Xmx1536M +org.gradle.jvmargs=-Xmx4608m android.useAndroidX=true android.enableJetifier=true +kotlin.jvm.target.validation.mode=IGNORE \ No newline at end of file diff --git a/android/gradle/wrapper/gradle-wrapper.properties b/android/gradle/wrapper/gradle-wrapper.properties index cc5527d78..9c957989d 100644 --- a/android/gradle/wrapper/gradle-wrapper.properties +++ b/android/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Fri Jun 23 08:50:38 CEST 2017 +#Mon Mar 17 08:36:03 CET 2025 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists +distributionUrl=https\://services.gradle.org/distributions/gradle-8.11.1-all.zip zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-all.zip diff --git a/android/settings.gradle b/android/settings.gradle deleted file mode 100644 index 44e62bcf0..000000000 --- a/android/settings.gradle +++ /dev/null @@ -1,11 +0,0 @@ -include ':app' - -def localPropertiesFile = new File(rootProject.projectDir, "local.properties") -def properties = new Properties() - -assert localPropertiesFile.exists() -localPropertiesFile.withReader("UTF-8") { reader -> properties.load(reader) } - -def flutterSdkPath = properties.getProperty("flutter.sdk") -assert flutterSdkPath != null, "flutter.sdk not set in local.properties" -apply from: "$flutterSdkPath/packages/flutter_tools/gradle/app_plugin_loader.gradle" diff --git a/android/settings.gradle.kts b/android/settings.gradle.kts new file mode 100644 index 000000000..a5d070147 --- /dev/null +++ b/android/settings.gradle.kts @@ -0,0 +1,28 @@ +pluginManagement { + val flutterSdkPath = run { + val properties = java.util.Properties() + file("local.properties").inputStream().use { properties.load(it) } + val flutterSdkPath = properties.getProperty("flutter.sdk") + require(flutterSdkPath != null) { "flutter.sdk not set in local.properties" } + flutterSdkPath + } + + includeBuild("$flutterSdkPath/packages/flutter_tools/gradle") + + repositories { + google() + mavenCentral() + gradlePluginPortal() + } +} + +plugins { + id("dev.flutter.flutter-plugin-loader") version "1.0.0" + id("com.android.application") version "8.9.1" apply false + id("org.jetbrains.kotlin.android") version "2.1.0" apply false + if (file("app/google-services.json").exists()) { + id("com.google.gms.google-services") version "4.3.8" apply false + } +} + +include(":app") diff --git a/appimage/.gitignore b/appimage/.gitignore deleted file mode 100644 index eeda4edb4..000000000 --- a/appimage/.gitignore +++ /dev/null @@ -1,3 +0,0 @@ -FluffyChat.AppDir -*.AppImage -*.AppImage.zsync diff --git a/appimage/AppRun b/appimage/AppRun deleted file mode 100755 index 95b7c0568..000000000 --- a/appimage/AppRun +++ /dev/null @@ -1,4 +0,0 @@ -#!/bin/sh - -cd "$(dirname "$0")" -exec ./fluffychat \ No newline at end of file diff --git a/appimage/FluffyChat.desktop b/appimage/FluffyChat.desktop deleted file mode 100644 index ceee4c91d..000000000 --- a/appimage/FluffyChat.desktop +++ /dev/null @@ -1,9 +0,0 @@ -[Desktop Entry] -Type=Application -Version=1.0 -Name=FluffyChat -Comment=Matrix Client. Chat with your friends -Exec=AppRun -Icon=fluffychat -Terminal=false -Categories=Network;Chat;InstantMessaging;X-Matrix; \ No newline at end of file diff --git a/appimage/README.md b/appimage/README.md deleted file mode 100644 index 60f82dea0..000000000 --- a/appimage/README.md +++ /dev/null @@ -1,24 +0,0 @@ -# FluffyChat AppImage - -FluffyChat is provided as AppImage too. To Download, visit fluffychat.im. - -## Building - -- Ensure you install `appimagetool` - -```shell -flutter build linux - -# copy binaries to appimage dir -cp -r build/linux/{x64,arm64}/release/bundle appimage/FluffyChat.AppDir -cd appimage - -# prepare AppImage files -cp FluffyChat.desktop FluffyChat.AppDir/ -mkdir -p FluffyChat.AppDir/usr/share/icons -cp ../assets/logo.svg FluffyChat.AppDir/fluffychat.svg -cp AppRun FluffyChat.AppDir - -# build the AppImage -appimagetool FluffyChat.AppDir -``` diff --git a/assets/js/package/.gitkeep b/assets/js/package/.gitkeep deleted file mode 100644 index e69de29bb..000000000 diff --git a/assets/l10n/intl_ar.arb b/assets/l10n/intl_ar.arb deleted file mode 100644 index 53b18d7b1..000000000 --- a/assets/l10n/intl_ar.arb +++ /dev/null @@ -1,2712 +0,0 @@ -{ - "@@locale": "ar", - "@@last_modified": "2021-08-14 12:41:10.156221", - "about": "حول", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "أقبل", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} قبل الدعوة", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "الحساب", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 تم تنشيط {username} التشفير من طرف إلى طرف", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "المدير", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "اللقب", - "@alias": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} أجاب على المكالمة", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "يمكن لأي أحد الدخول", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "الأرشيف", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "هل يُسمح للزوار الدخول", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "أمتأكد؟", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "لتتمكن من التأكد من الشخص الآخر، يرجى إدخال عبارة المرور أو مفتاح الاسترداد.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "أتقبل طلب تحقق {username}؟", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banFromChat": "حظر من المحادثة", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "محظور", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} حظر {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "أُحظر الجهاز", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "cancel": "ألغِ", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "غيَّر {username} صورة المحادثة", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "غيَّر {username} وصف المحادثة الى: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "غيَّر {username} اسم المحادثة الى: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "غيَّر {username} أذون المحادثة", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} غير إسمه العلني إلى: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "غيّر {username} قواعد وصول الزوار", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "غيّر {username} قواعد وصول الزوار الى: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "غيَّر {username} مرئية التأريخ", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "غيَّر {username} مرئية التأريخ الى: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "غيَّر {username} قواعد الانضمام", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "غيَّر {username} قواعد الانضمام الى: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "غيّر {username} صورته الشخصية", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "غيّر {username} ألقاب الغرف", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "غيّر {username} رابط الدعوة", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeTheHomeserver": "غيّر الخادم", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "غيّر أسلوبك", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "غيِّر اسم المجموعة", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "فسُد التشفير", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "محادثة", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "تفاصيل المحادثة", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "اختر كلمة سر قوية", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "اغلق", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "يرجى مقارنة الرموز التعبيرية", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "الرجاء مقارنة الأرقام", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "أكّد", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "اتصل", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "دعيَ المراسل للمجموعة", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "نُسخ للحافظة", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "انسخ", - "@copy": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "تعذر فك تشفير الرسالة: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} منتسبا", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "أنشئ", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 أنشأ {username} المحادثة", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "نشطٌ حاليا", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "داكن", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}/{month}/{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "لا مجال للعودة، أتأكد تعطيل حسابك؟", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "delete": "احذف", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "احذف الحساب", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "حذف الرسالة", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "جهاز", - "@device": { - "type": "text", - "placeholders": {} - }, - "devices": "الأجهزة", - "@devices": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "غُيِّر الاسم العلني", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "نزِّل الملف", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "حرر الاسم العلني", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "الانفعالة موجودة مسبقا!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "رمز الانفعالة غير صالح!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "اعدادات الانفعالات", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "رمز الانفعالة", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "اختر صورة ورمزا للانفعالة!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "محادثة فارغة", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "لن يمكنك تعطيل التشفير أبدا، أمتأكد؟", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encryption": "التشفير", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "التشفير معطل", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "أنهى {senderName} المكالمة", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterYourHomeserver": "أدخل الخادم", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "fileName": "اسم الملف", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "فلافي-شات", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "أعد التوجيه", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "من بعد الانضمام", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "من بعد الدعوة", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "المجموعة", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "المجموعة عامة", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "في مجموعة مع {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "يمنع الزوار", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "يمكن للزوار الانضمام", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "سحب {username} دعوة {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "المساعدة", - "@help": { - "type": "text", - "placeholders": {} - }, - "id": "المعرّف", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "المُعرّف", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "المستخدمون المتجاهلون", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "عبارة مرور أو مفتاح استرداد خطأ", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "دعوة مراسل", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "أدعو مراسلا الى {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "دُعيَ", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} دعا {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "المستخدمون المدعوون فقط", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteText": "دعاك {username} إلى FluffyChat.\n1. قم بزيارة موقع fluffychat.im وقم بتثبيت التطبيق\n2. قم بإنشاءحساب أو تسجيل الدخول\n3. افتح رابط الدعوة:\n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "يكتب…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 انضم {username} إلى المحادثة", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "انضم للمحادثة", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} ركل {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} ركل وحظر {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "طرد من المحادثة", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "آخر نشاط: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "غادر", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "غادر المحادثة", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "الرخصة", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "فاتح", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "حمِّل {count} منتسبًا إضافيًا", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "يحمّل… يرجى الانتظار.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "حمِّل المزيد…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "لِج", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "لِج ل {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "اخرج", - "@logout": { - "type": "text", - "placeholders": {} - }, - "moderator": "مشرف", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "أكتم الماحدثة", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "اعلم أننا نستخدم بانتاليمون للتشفير طرفا لطرف.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 رسالة جديدة في FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "طلب تحقق جديد!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "no": "لا", - "@no": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "لم يُعثر على انفعالة. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "يبدو أن خدمة Firebase Cloud Messaging غير متاحة على جهازك. لمواصلة تلقي الإشعارات، نوصي بتثبيت ntfy. باستخدام ntfy أو أي مزود خدمة Unified Push آخر، يمكنك تلقي إشعارات الدفع بطريقة آمنة للبيانات. يمكنك تنزيل ntfy من PlayStore أو من F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "بدون", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPermission": "بدون اذن", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "لم يُعثر على غرف…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "ok": "موافق", - "@ok": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "تم تفعيل النسخ الاحتياطي للمفاتيح عبر الإنترنت", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "عذراً، هناك خطأ ما…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "افتح التطبيق لقراءة الرسائل", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "افتح الكميرا", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "عبارة المرور أو مفتاح الاستعادة", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "كلمة السر", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "غُيّرت كلمة السر", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "pickImage": "اختر صورة", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "ثبِّت", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "شغّل {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseEnterYourPassword": "أدخل كلمة السر", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "أدخل اسم المستخدم", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "privacy": "الخصوصية", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "الغرف العامة", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "recording": "يسجل", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "حذف {username} حدثًا", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "رفض", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "رفض {username} الدعوة", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "أعد الانضمام", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "أزِل", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "أزِل كل الأجهزة الأخرى", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "أزاله {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "أزل جهازا", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "فك حجبه من المحادثة", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "صيّر الرسائل ذات المحتوى الكبير", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "ردّ", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "أطلب إذنا", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "رُقيّت الغرفة", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "رآه {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "أرسل", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "أرسل رسالة", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "أرسل ملفًا صوتيًا", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "أرسل ملف", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "أرسل صورة", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "أرسل الملف الأصلي", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "أرسل فيديو", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 أرسل {username} ملفا", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 أرسل {username} ملفا صوتيا", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} أرسل صورة", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 أرسل {username} ملصقا", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 أرسل {username} مقطع فيديو", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "أرسل {senderName} معلومات مكالمة", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setInvitationLink": "عيّن رابط الدعوة", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setStatus": "عيّن الحالة", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "الإعدادات", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "شارك", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "شارك {username} موقعه", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "skip": "تخط", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "الشفرة المصدرية", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "بدأ {senderName} مكالمة", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "statusExampleMessage": "ماهو وضعك؟", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "أرسل", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "النظام", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "لا يتطبقان", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "متطبقان", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "فلافي-شات", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "حاول إعادة الارسال", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "ألغى {username} حظر {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "ألغ حظر الجهاز", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "جهز مجهول", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "خوارزمية تشفير مجهولة", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "حدث مجهول '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "ألغِ كتم المحادثة", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "ألغِ التثبيت", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 محادثة غير مقروءة} other{{unreadCount} محادثات غير مقروءة}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} و {count} أخرون يكتبون…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} و {username2} يكتبان…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} يكتب…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} غادر المحادثة", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "اسم المستخدم", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "أرسل {username} حدث {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "تحقق", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "ابدأ التحقق", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "تُحقق منك بنجاح!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "يتحقق من الحساب الآخر", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "مكالمة فيديو", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "مرئية تأريخ المحادثة", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "مرئي لكل المنتسبين", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "مرئي للجميع", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "رسالة صوتية", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "ينتظر قبول الشريك للطلب…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "ينتظر قبول الشريك لإيموجي…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "ينتظر قبول الشريك للأرقام…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "الخلفية:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "تحذير!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "من يسمح له الانضمام للمجموعة", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "اكتب رسالة…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "نعم", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "انت", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "لم تعد منتسبا لهذه المحادثة", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "حُظرت من هذه المحادثة", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "people": "أشخاص", - "@people": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "امسح رمز الاستجابة السريعة", - "@scanQrCode": {}, - "noMatrixServer": "{server1} ليس خادم ماتريكس، بدلًا منه أتريد استخدام {server2}؟", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "noConnectionToTheServer": "انقطع الاتصال بالخادم", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "next": "التالي", - "@next": { - "type": "text", - "placeholders": {} - }, - "newChat": "محادثة جديدة", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "messages": "الرسائل", - "@messages": { - "type": "text", - "placeholders": {} - }, - "mention": "اذكر", - "@mention": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "تغييرات تخص الأعضاء", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "غير مسيء", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "نقرت على الرابط", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "ignore": "تجاهل", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "ما مدى سوء هذا المحتوى؟", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "اخف الأحداث المجهولة", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "groups": "المجموعات", - "@groups": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "انتقل للغرفة الجديدة", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "fontSize": "حجم الخط", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "مسيئة للغاية", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "كل شيء جاهز!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "homeserver": "الخادم", - "@homeserver": {}, - "enterAnEmailAddress": "أدخل عنوان بريد إلكتروني", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "encrypted": "مشفر", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "فعّل التشفير", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "حزمة الوجوه التعبيرية للغرفة", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "عدّل الصورة الرمزية للغرفة", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "عدّل الخوادم المحجوبة", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "edit": "عدّل", - "@edit": { - "type": "text", - "placeholders": {} - }, - "directChats": "محادثات مباشرة", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "deviceId": "معرّف الجهاز", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "مساحة جديدة", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "انسخ الى الحافظة", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "أّرسل الابلاغ الى مدير الخادم", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "يحوي اسم المستخدم", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "يحوي الاسم العلني", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "commandMissing": "{command} ليس بأمر.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "commandInvalid": "أمر غير صالح", - "@commandInvalid": { - "type": "text" - }, - "commandHint_unban": "فك الحظر عن المستخدم المذكور في هذه الغرفة", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandHint_send": "أرسل نصًا", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_react": "أرسل ردًا كتفاعل", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_plain": "أرسل نصًا غير منسق", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_op": "عين مستوى نفوذ المستخدم في هذه الغرفة (الافتراضي: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_myroomnick": "عين اسمًا لك مخصص لهذه الغرفة", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_me": "صف نفسك", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_leave": "تغادر هذه الغرفة", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_kick": "يزيل المستخدم المذكور من الغرفة", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_join": "تنضم الى الغرفة المذكورة", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_invite": "يدعو المستخدم المذكور الى الغرفة", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_html": "أرسل نصًا بتنسيق HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_ban": "يحظر المستخدم المذكور من هذه الغرفة", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "clearArchive": "امسح الأرشيف", - "@clearArchive": {}, - "chats": "المحادثات", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "أُضيفت المحادثة الى هذا المساحة", - "@chatHasBeenAddedToThisSpace": {}, - "chatBackup": "النسخ الاحتياطي للمحادثات", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "غيّر الصورة الرمزية", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "changePassword": "غيّر كلمة السر", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "غيّر اسم الجهاز", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "تعذر فتح المسار {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "blocked": "محجوب", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "أرسل عند الدخول", - "@sendOnEnter": {}, - "autoplayImages": "شغِّل الملصقات والوجوه المتحركة تلقائيا", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "areYouSureYouWantToLogout": "أمتأكد من الخروج؟", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "appLock": "قفل التطبيق", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "allChats": "كل المحادثات", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "all": "الكل", - "@all": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "أضف إلى المساحة", - "@addToSpace": {}, - "addEmail": "أضف بريدًا إلكترونيًا", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "لم تضف أي طريقة لاستعادة كلمة السر.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "notifications": "الإشعارات", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "reason": "السبب", - "@reason": { - "type": "text", - "placeholders": {} - }, - "search": "ابحث", - "@search": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "خدمات الموقع معطلة. مكنها لتتمكن من مشاركة موقعك.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "خطأ أثناء الحصول على الموقع: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "editRoomAliases": "عدّل الاسم المميز للغرفة", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "configureChat": "ضبط المحادثة", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "يتم تأمين رسائلك القديمة باستخدام مفتاح الاسترداد. يرجى التأكد من أنك لا تضيعه.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "شارك الموقع", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "اختر رمز المرور", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "اختر رجاء", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "استعادة كلمة السر", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "نسيتَ كلمة السر", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "participant": "منتسب", - "@participant": { - "type": "text", - "placeholders": {} - }, - "or": "أو", - "@or": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "يتطلب هذا الخادم التحقق من بريدك الإلكتروني.", - "@serverRequiresEmail": {}, - "link": "رابط", - "@link": {}, - "openInMaps": "افتح في الخريطة", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "enableMultiAccounts": "(ميزة تجربية) فعّل تعدد الحسابات", - "@enableMultiAccounts": {}, - "bundleName": "اسم الحزمة", - "@bundleName": {}, - "removeFromBundle": "أزله من الحزمة", - "@removeFromBundle": {}, - "addToBundle": "أضفه الى حزمة", - "@addToBundle": {}, - "editBundlesForAccount": "عدّل حزم هذا الحساب", - "@editBundlesForAccount": {}, - "addAccount": "أضف حسابًا", - "@addAccount": {}, - "online": "متصل", - "@online": { - "type": "text", - "placeholders": {} - }, - "offline": "غير متصل", - "@offline": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} يكتبون…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "notificationsEnabledForThisAccount": "الإشعارات مفعلة لهذا الحساب", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "عام في المساحة", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "بدّل حالة التفضيل", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "علّمه كمقروء/غير مقروء", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "unavailable": "غير متوفر", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "لماذا تريد الإبلاغ عنه؟", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "يمكنك استعادة كلمة السر بهذه العناوين.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "تسجيل دخول أحادي", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "بدّل حالة الكتم", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "showPassword": "أظهر كلمة السر", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "verified": "موثّق", - "@verified": { - "type": "text", - "placeholders": {} - }, - "spaceName": "اسم المساحة", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "يُزامن… يرجى الانتظار.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "طابات كثيرة. حاول مجددًا لاحقًا!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "أرسلنا لك رسالة بالبريد الإلكتروني", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "مفتاحك العمومي", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "status": "الحالة", - "@status": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "أنقله من جهاز آخر", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "مسح نسخة المحادثة الاحتياطية لإنشاء مفتاح استرداد جديد؟", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "saveFile": "احفظ الملف", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "security": "الأمان", - "@security": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "أزل الصورة الرمزية", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "botMessages": "رسائل البوت", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "أرسل نصًا", - "@sendAsText": { - "type": "text" - }, - "sendMessages": "إرسال رسائل", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "دعوات لي", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "استبدل الغرفة باصدار أحدث", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "register": "سجّل", - "@register": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "يحصل على الموقع…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "أرسل ملصقًا", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "مستوى الأذونات الإفتراضي", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "تعيين مستوى الأذونات", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "عيّن وجوهًا تعبيرية مخصصة", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "أُ خرج أحد العملاء الذي تسختدمها", - "@oneClientLoggedOut": {}, - "pleaseEnter4Digits": "أدخل 4 أرقام أو أتركه فارغ لتعطيل القفل.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "احذف رسالة", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "أبلغ عن الرسالة", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "إصدار الغرفة", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "كرّر كلمة السر", - "@repeatPassword": {}, - "removeFromSpace": "أزل من المساحة", - "@removeFromSpace": {}, - "unverified": "غير مؤكد", - "@unverified": {}, - "whoCanPerformWhichAction": "من يستطيع القيام بأي عمل", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "messageInfo": "معلومات الرسالة", - "@messageInfo": {}, - "messageType": "نوع الرسالة", - "@messageType": {}, - "sender": "المرسل", - "@sender": {}, - "openGallery": "افتخ المعرض", - "@openGallery": {}, - "time": "الوقت", - "@time": {}, - "badServerLoginTypesException": "يدعم الخادم المستخدم أنواع تسجيل الدخول التالية:\n{serverVersions}\nلكن هذا التطبيق يدعم فقط:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "commandHint_clearcache": "مسح الذاكرة المؤقتة", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "enableEmotesGlobally": "تفعيل حزمة التعبيرات بشكل عام", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "إخفاء الأحداث المنقحة", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "commandHint_discardsession": "إنهاء الجلسة", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "locationPermissionDeniedNotice": "تم رفض إذن الموقع. الرجاء منح الإذن للقدرة على مشاركة موقعك.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "يدعم الخادم الرئيسي المستخدم إصدارات المواصفات:\n{serverVersions}\nلكن هذا التطبيق يدعم فقط:\n{supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "offensive": "عدواني", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "تم إعداد النسخ الاحتياطي لمحادثاتك.", - "@yourChatBackupHasBeenSetUp": {}, - "noEncryptionForPublicRooms": "يمكنك فقط تفعيل التشفير عندما تصبح الغرفة غير متاحة للعامة.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "emojis": "إيموجي", - "@emojis": {}, - "voiceCall": "مكالمة صوتية", - "@voiceCall": {}, - "unsupportedAndroidVersion": "نسخة أندرويد غير مدعومة", - "@unsupportedAndroidVersion": {}, - "unsupportedAndroidVersionLong": "تتطلب هذه الميزة إصدار Android أحدث. يرجى التحقق من وجود تحديثات أو دعم Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "experimentalVideoCalls": "مكالمات الفيديو التجريبية", - "@experimentalVideoCalls": {}, - "commandHint_create": "أنشأ محادثة جماعية فارغة\nاستخدم --لا-تشفير لتعطيل التشفير", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_dm": "إبدأ محادثة مباشرة\nاستخدم --لا-تشفير لتعطيل التشفير", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "oopsPushError": "عذراً! للأسف، حدث خطأ أثناء إعداد الإشعارات.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "يرجى اتباع التعليمات الموجودة على الموقع والنقر على التالي.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "commandHint_myroomavatar": "حدد صورتك لهذه الغرفة (عن طريق mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "videoCallsBetaWarning": "يرجى ملاحظة أن مكالمات الفيديو حالياً في مرحلة تجريبية. قد لا تعمل كما هو متوقع أو تعمل على الإطلاق على جميع المنصات.", - "@videoCallsBetaWarning": {}, - "placeCall": "إجراء مكالمة", - "@placeCall": {}, - "videoWithSize": "فيديو ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "emailOrUsername": "البريد الإلكتروني أو اسم المستخدم", - "@emailOrUsername": {}, - "dismiss": "رفض", - "@dismiss": {}, - "setAsCanonicalAlias": "تعيين كاسم مستعار رئيسي", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "يرجى النقر على الرابط الموجود في البريد الإلكتروني ثم المتابعة.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "الرجاء إدخال رقم التعريف الشخصي الخاص بك", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pushRules": "قواعد الإشعارات", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reactedWith": "{sender} تفاعل ب {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "markAsRead": "حدد كمقروء", - "@markAsRead": {}, - "openVideoCamera": "افتح الكاميرا لمقطع فيديو", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "start": "إبدأ", - "@start": {}, - "publish": "انشر", - "@publish": {}, - "addToSpaceDescription": "إختر مساحة لإضافة هذه المحادثة إليها.", - "@addToSpaceDescription": {}, - "reportUser": "التبيلغ عن المستخدم", - "@reportUser": {}, - "openChat": "فتح المحادثة", - "@openChat": {}, - "pinMessage": "تثبيت في الغرفة", - "@pinMessage": {}, - "confirmEventUnpin": "هل أنت متأكد من إلغاء تثبيت الحدث بشكل دائم؟", - "@confirmEventUnpin": {}, - "fileHasBeenSavedAt": "تم حفظ الملف في {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "user": "مستخدم", - "@user": {}, - "custom": "مُخصّص", - "@custom": {}, - "googlyEyesContent": "{senderName} يرسل لك عيون googly", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "widgetVideo": "فيديو", - "@widgetVideo": {}, - "recoveryKeyLost": "هل فقدت مفتاح الاسترداد؟", - "@recoveryKeyLost": {}, - "pleaseEnterRecoveryKeyDescription": "لإلغاء قفل رسائلك القديمة ، يرجى إدخال مفتاح الاسترداد الذي تم إنشاؤه في جلسة سابقة. مفتاح الاسترداد ليس كلمة المرور الخاصة بك.", - "@pleaseEnterRecoveryKeyDescription": {}, - "confirmMatrixId": "يرجى تأكيد معرف Matrix الخاص بك من أجل حذف حسابك.", - "@confirmMatrixId": {}, - "supposedMxid": "يجب أن يكون هذا {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "hydrateTor": "مستخدمو تور: استيراد تصدير الجلسة", - "@hydrateTor": {}, - "commandHint_googly": "أرسل بعض عيون googly", - "@commandHint_googly": {}, - "commandHint_cuddle": "أرسل عناق", - "@commandHint_cuddle": {}, - "commandHint_hug": "إرسال حضن", - "@commandHint_hug": {}, - "cuddleContent": "{senderName} يحتضنك", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "unlockOldMessages": "إلغاء قفل الرسائل القديمة", - "@unlockOldMessages": {}, - "commandHint_markasdm": "وضع علامة على أنها غرفة رسائل مباشرة لمعرف المصفوفة", - "@commandHint_markasdm": {}, - "allRooms": "جميع الدردشات الجماعية", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "dehydrate": "تصدير الجلسة ومسح الجهاز", - "@dehydrate": {}, - "dehydrateWarning": "لا يمكن التراجع عن هذا الإجراء. تأكد من تخزين ملف النسخ الاحتياطي بأمان.", - "@dehydrateWarning": {}, - "dehydrateTorLong": "بالنسبة لمستخدمي تور ، يوصى بتصدير الجلسة قبل إغلاق النافذة.", - "@dehydrateTorLong": {}, - "dehydrateTor": "مستخدمو تور: تصدير الجلسة", - "@dehydrateTor": {}, - "hydrate": "استعادة من ملف النسخ الاحتياطي", - "@hydrate": {}, - "pleaseEnterRecoveryKey": "الرجاء إدخال مفتاح الاسترداد:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKey": "مفتاح الاسترداد", - "@recoveryKey": {}, - "startFirstChat": "ابدأ محادثتك الأولى", - "@startFirstChat": {}, - "widgetCustom": "مُخصّص", - "@widgetCustom": {}, - "widgetNameError": "يرجى تقديم اسم العرض.", - "@widgetNameError": {}, - "errorAddingWidget": "خطأ في إضافة الأداة.", - "@errorAddingWidget": {}, - "youRejectedTheInvitation": "لقد رفضت الدعوة", - "@youRejectedTheInvitation": {}, - "youJoinedTheChat": "لقد انضممت إلى المحادثة", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 لقد قبلت الدعوة", - "@youAcceptedTheInvitation": {}, - "youBannedUser": "لقد حظرت {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "لقد سحبت الدعوة لـ {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 لقد تمت دعوتك من قبل {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "storeInAndroidKeystore": "تخزين في سجل مفاتيح اندرويد", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "تخزين في سلسلة مفاتيح ابل", - "@storeInAppleKeyChain": {}, - "storeSecurlyOnThisDevice": "احفظه بأمان على هذا الجهاز", - "@storeSecurlyOnThisDevice": {}, - "countFiles": "ملفات {count}", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "foregroundServiceRunning": "يظهر هذا الإشعار عند تشغيل الخدمة الأمامية.", - "@foregroundServiceRunning": {}, - "screenSharingTitle": "مشاركة الشاشة", - "@screenSharingTitle": {}, - "appearOnTop": "يظهر في الأعلى", - "@appearOnTop": {}, - "otherCallingPermissions": "الميكروفون والكاميرا وأذونات FluffyChat الأخرى", - "@otherCallingPermissions": {}, - "enterSpace": "أدخل المساحة", - "@enterSpace": {}, - "enterRoom": "أدخل الغرفة", - "@enterRoom": {}, - "deviceKeys": "مفاتيح الجهاز:", - "@deviceKeys": {}, - "whyIsThisMessageEncrypted": "لماذا هذه الرسالة غير قابلة للقراءة؟", - "@whyIsThisMessageEncrypted": {}, - "nextAccount": "الحساب التالي", - "@nextAccount": {}, - "previousAccount": "الحساب السابق", - "@previousAccount": {}, - "encryptThisChat": "تشفير هذه المحادثة", - "@encryptThisChat": {}, - "screenSharingDetail": "أنت تشارك شاشتك في FuffyChat", - "@screenSharingDetail": {}, - "hideUnimportantStateEvents": "إخفاء أحداث الحالة غير المهمة", - "@hideUnimportantStateEvents": {}, - "newGroup": "مجموعة جديدة", - "@newGroup": {}, - "youKicked": "👞 لقد ركلت {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "newSpace": "مساحة جديدة", - "@newSpace": {}, - "commandHint_markasgroup": "وضع علامة كمجموعة", - "@commandHint_markasgroup": {}, - "separateChatTypes": "الدردشات المباشرة والمجموعات المنفصلة", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "hugContent": "{senderName} يعانقك", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hydrateTorLong": "هل قمت بتصدير جلستك الأخيرة على تور؟ قم باستيرادها بسرعة واستمر في المحادثة.", - "@hydrateTorLong": {}, - "widgetUrlError": "هذا ليس عنوان URL صالحًا.", - "@widgetUrlError": {}, - "indexedDbErrorTitle": "مشاكل الوضع الخاص", - "@indexedDbErrorTitle": {}, - "indexedDbErrorLong": "للأسف ، لم يتم تمكين تخزين الرسائل في الوضع الخاص افتراضيا.\nيرجى زيارة\n - حول:التكوين\n - تعيين dom.indexedDB.privateBrowsing.enabled إلى true\nخلاف ذلك ، لا يمكن تشغيل FluffyChat.", - "@indexedDbErrorLong": {}, - "switchToAccount": "التبديل إلى الحساب {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "addWidget": "إضافة اداة", - "@addWidget": {}, - "widgetEtherpad": "ملاحظة نصية", - "@widgetEtherpad": {}, - "youKickedAndBanned": "🙅 لقد ركلت وحظرت {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "قمت بإلغاء الحظر {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "saveKeyManuallyDescription": "احفظ هذا المفتاح يدويا عن طريق تشغيل مربع حوار مشاركة النظام أو الحافظة.", - "@saveKeyManuallyDescription": {}, - "widgetJitsi": "اجتماعات جيتسي", - "@widgetJitsi": {}, - "youInvitedUser": "📩 قمت بدعوة {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "storeInSecureStorageDescription": "قم بتخزين مفتاح الاسترداد في التخزين الآمن لهذا الجهاز.", - "@storeInSecureStorageDescription": {}, - "widgetName": "الاسم", - "@widgetName": {}, - "users": "المستخدمون", - "@users": {}, - "callingPermissions": "أذونات الاتصال", - "@callingPermissions": {}, - "callingAccount": "الاتصال بالحساب", - "@callingAccount": {}, - "callingAccountDetails": "يسمح لـ FluffyChat باستخدام تطبيق android Dialer الأصلي.", - "@callingAccountDetails": {}, - "appearOnTopDetails": "يسمح للتطبيق بالظهور في الأعلى (ليست هناك حاجة إذا قمت بالفعل بإعداد Fluffychat كحساب اتصال)", - "@appearOnTopDetails": {}, - "numChats": "{number} الدردشات", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "jump": "قفز", - "@jump": {}, - "report": "التقرير", - "@report": {}, - "noKeyForThisMessage": "يمكن أن يحدث هذا إذا تم إرسال الرسالة قبل تسجيل الدخول إلى حسابك على هذا الجهاز.\n\nمن الممكن أيضا أن يكون المرسل قد حظر جهازك أو حدث خطأ ما في الاتصال بالإنترنت.\n\nهل يمكنك قراءة الرسالة في جلسة أخرى؟ ثم يمكنك نقل الرسالة منه! انتقل إلى الإعدادات > الأجهزة وتأكد من أن أجهزتك قد تحققت من بعضها البعض. عندما تفتح الغرفة في المرة التالية وتكون كلتا الجلستين في المقدمة ، سيتم إرسال المفاتيح تلقائيا.\n\nألا تريد أن تفقد المفاتيح عند تسجيل الخروج أو تبديل الأجهزة؟ تأكد من تمكين النسخ الاحتياطي للدردشة في الإعدادات.", - "@noKeyForThisMessage": {}, - "allSpaces": "كل المساحات", - "@allSpaces": {}, - "doNotShowAgain": "لا تظهر مرة أخرى", - "@doNotShowAgain": {}, - "wasDirectChatDisplayName": "محادثة فارغة (كانت {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "disableEncryptionWarning": "لأسباب أمنية ، لا يمكنك تعطيل التشفير في المحادثة ، حيث تم تمكينه من قبل.", - "@disableEncryptionWarning": {}, - "reportErrorDescription": "😭 أوه لا. هناك خطأ ما. إذا كنت تريد، يمكنك الإبلاغ عن هذا الخطأ إلى المطورين.", - "@reportErrorDescription": {}, - "newSpaceDescription": "يسمح لك تطبيق المساحات بتوحيد دردشاتك وبناء مجتمعات خاصة أو عامة.", - "@newSpaceDescription": {}, - "sorryThatsNotPossible": "معذرة... هذا غير ممكن", - "@sorryThatsNotPossible": {}, - "openLinkInBrowser": "فتح الرابط في المتصفح", - "@openLinkInBrowser": {}, - "reopenChat": "إعادة فتح المحادثة", - "@reopenChat": {}, - "noBackupWarning": "تحذير! بدون تمكين النسخ الاحتياطي للدردشة ، ستفقد الوصول إلى رسائلك المشفرة. يوصى بشدة بتمكين النسخ الاحتياطي للدردشة أولاً قبل تسجيل الخروج.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "لم يتم العثور على أجهزة أخرى", - "@noOtherDevicesFound": {}, - "fileIsTooBigForServer": "أبلغ الخادم أن الملف كبير جدًا بحيث لا يمكن إرساله.", - "@fileIsTooBigForServer": {}, - "jumpToLastReadMessage": "الانتقال إلى آخر رسالة مقروءة", - "@jumpToLastReadMessage": {}, - "readUpToHere": "اقرأ حتى هنا", - "@readUpToHere": {}, - "signInWithPassword": "سجل الدخول بكلمة السر", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "رجاء حاول مجددا أو اختر خادما مختلفا.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "تسجيل الدخول باستخدام {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "importNow": "استيراد الآن", - "@importNow": {}, - "importEmojis": "استيراد الرموز التعبيرية", - "@importEmojis": {}, - "exportEmotePack": "تصدير حزمة الرموز التعبيرية بتنسيق zip", - "@exportEmotePack": {}, - "notAnImage": "ليس ملف صورة.", - "@notAnImage": {}, - "importFromZipFile": "الاستيراد من ملف .zip", - "@importFromZipFile": {}, - "replace": "استبدال", - "@replace": {}, - "sendTypingNotifications": "إرسال إشعارات الكتابة", - "@sendTypingNotifications": {}, - "createGroup": "إنشاء مجموعة", - "@createGroup": {}, - "messagesStyle": "الرسائل:", - "@messagesStyle": {}, - "shareInviteLink": "شارك رابط الدعوة", - "@shareInviteLink": {}, - "profileNotFound": "لا يمكن العثور على المستخدم على الخادم. ربما هناك مشكلة في الاتصال أو المستخدم غير موجود.", - "@profileNotFound": {}, - "setTheme": "تعيين السمة:", - "@setTheme": {}, - "setColorTheme": "تعيين لون السمة:", - "@setColorTheme": {}, - "inviteContactToGroupQuestion": "هل تريد دعوة {contact} إلى المحادثة \"{groupName}\"؟?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "أعد المحاولة", - "@tryAgain": {}, - "redactMessageDescription": "سيتم تنقيح الرسالة لجميع المشاركين في هذه المحادثة. هذا لا يمكن التراجع عنها.", - "@redactMessageDescription": {}, - "optionalRedactReason": "(اختياري) سبب تنقيح هذه الرسالة ...", - "@optionalRedactReason": {}, - "redactedBy": "منقح بواسطة {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactedByBecause": "تم حجبه بواسطة {username} بسبب: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "invite": "دعوة", - "@invite": {}, - "addChatDescription": "أضف وصفًا للدردشة...", - "@addChatDescription": {}, - "chatPermissions": "صلاحيات المحادثة", - "@chatPermissions": {}, - "chatDescription": "وصف المحادثة", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "تغير وصف المجموعة", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "لم يتم إنشاء وصف للمحادثة حتى الآن.", - "@noChatDescriptionYet": {}, - "invalidServerName": "اسم الخادم غير متاح", - "@invalidServerName": {}, - "setChatDescription": "تعيين وصفًا للدردشة", - "@setChatDescription": {}, - "directChat": "محادثة مباشرة", - "@directChat": {}, - "inviteGroupChat": "📨 دعوة للمحادثة الجماعية", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 دعوة دردشة خاصة", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "التعبيرات المستخدمة مؤخرًا ستظهر هنا ...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "invalidInput": "مدخل غير صالح!", - "@invalidInput": {}, - "wrongPinEntered": "تم إدخال رمز خاطئ! حاول مرة أخرى خلال {seconds} ثانية...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "hasKnocked": "🚪 لقد طرق {user}", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "pleaseEnterANumber": "الرجاء إدخال رقم أكبر من 0", - "@pleaseEnterANumber": {}, - "banUserDescription": "سيتم حظر المستخدم من المحادثة ولن يتمكن من الدخول إلى المحادثة مرة أخرى حتى يتم رفع الحظر عنه.", - "@banUserDescription": {}, - "removeDevicesDescription": "سيتم تسجيل خروجك من هذا الجهاز ولن تتمكن بعد ذلك من تلقي الرسائل.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "سيتمكن المستخدم من الدخول إلى المحادثة مرة أخرى إذا حاول.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "دفع الإخطارات غير متوفرة", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "بمجرد تعيين هذا المستخدم كمسؤول، قد لا تتمكن من التراجع عن هذا لأنه سيكون لديه نفس الأذونات التي تتمتع بها.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "سيتم نقل المحادثة إلى الأرشيف. سيتمكن المستخدمون الآخرون من رؤية أنك غادرت المحادثة.", - "@archiveRoomDescription": {}, - "learnMore": "تعلم المزيد", - "@learnMore": {}, - "roomUpgradeDescription": "سيتم بعد ذلك إعادة إنشاء المحادثة باستخدام إصدار الغرفة الجديد. سيتم إخطار جميع المشاركين بأنهم بحاجة إلى التبديل إلى المحادثة الجديدة. يمكنك معرفة المزيد حول إصدارات الغرف على https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "kickUserDescription": "يتم طرد المستخدم من المحادثة ولكن لا يتم حظره. في المحادثات العامة، يمكن للمستخدم الانضمام مرة أخرى في أي وقت.", - "@kickUserDescription": {}, - "createGroupAndInviteUsers": "إنشاء مجموعة ودعوة المستخدمين", - "@createGroupAndInviteUsers": {}, - "groupCanBeFoundViaSearch": "يمكن العثور على المجموعة عبر البحث", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "لسوء الحظ، لا يمكن العثور على مستخدم لديه \"{query}\". يرجى التحقق مما إذا كنت قد ارتكبت خطأ كتابي.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "yourGlobalUserIdIs": "معرف المستخدم العمومي الخاص بك هو: ", - "@yourGlobalUserIdIs": {}, - "groupName": "أسم المجموعة", - "@groupName": {}, - "searchChatsRooms": "ابحث عن #الدردشات، @المستخدمين...", - "@searchChatsRooms": {}, - "startConversation": "بدء محادثة", - "@startConversation": {}, - "commandHint_sendraw": "إرسال جيسون الخام", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "عذرًا... لا يبدو أن هذا هو مفتاح الاسترداد الصحيح.", - "@wrongRecoveryKey": {}, - "blockListDescription": "يمكنك حظر المستخدمين الذين يزعجونك. لن تتمكن من تلقي أي رسائل أو دعوات للغرفة من المستخدمين الموجودين في قائمة الحظر الشخصية الخاصة بك.", - "@blockListDescription": {}, - "blockedUsers": "المستخدمون المحظورون", - "@blockedUsers": {}, - "block": "حظر", - "@block": {}, - "blockUsername": "تجاهل اسم المستخدم", - "@blockUsername": {}, - "databaseMigrationTitle": "تم تحسين قاعدة البيانات", - "@databaseMigrationTitle": {}, - "databaseMigrationBody": "انتظر من فضلك. قد يستغرق ذلك بعض الوقت.", - "@databaseMigrationBody": {}, - "thisDevice": "هذا الجهاز:", - "@thisDevice": {}, - "publicSpaces": "مساحة عامة", - "@publicSpaces": {}, - "passwordIsWrong": "كلمة السر للدخول خاطئة", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "من فضلك أدخل كلمة السر الحالية", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "رابط عام", - "@publicLink": {}, - "nothingFound": "لم نجد شيئاً.", - "@nothingFound": {}, - "decline": "رفض", - "@decline": {}, - "newPassword": "كلمة المرور الجديدة", - "@newPassword": {}, - "passwordsDoNotMatch": "كلمات المرور لا تتطابق", - "@passwordsDoNotMatch": {}, - "subspace": "مساحة فرعية", - "@subspace": {}, - "select": "اختر", - "@select": {}, - "pleaseChooseAStrongPassword": "الرجاء اختيار كلمة مرور قوية", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "إضافة دردشة أو مساحة فرعية", - "@addChatOrSubSpace": {}, - "leaveEmptyToClearStatus": "اتركه فارغًا لمسح حالتك.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "انضم إلى المساحة", - "@joinSpace": {}, - "searchForUsers": "ابحث عن @users...", - "@searchForUsers": {}, - "databaseBuildErrorBody": "غير قادر على بناء قاعدة بيانات SQlite. يحاول التطبيق استخدام قاعدة بيانات قديمة في الوقت الحالي. الرجاء الإبلاغ عن هذا الخطأ للمطورين على {url}. رسالة الخطأ هي: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "حدث خطأ بداخل التطبيق", - "@initAppError": {}, - "sessionLostBody": "جلستك مفقودة يرجى إبلاغ المطورين بهذا الخطأ في {url}. رسالة الخطأ هي: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "يحاول التطبيق الآن استعادة جلستك من النسخة الاحتياطية. الرجاء الإبلاغ عن هذا الخطأ للمطورين على {url}. رسالة الخطأ هي:{error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "completedKeyVerification": "أكمل {sender} عملية التحقق من المفتاح", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "طلب {sender} التحقق من المفتاح", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "شفّاف", - "@transparent": {}, - "youInvitedToBy": "📩 تمت دعوتك عبر الرابط إلى:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "formattedMessagesDescription": "عرض محتوى الرسالة الغنية مثل النص الغامق باستخدام الماركداون.", - "@formattedMessagesDescription": {}, - "verifyOtherUserDescription": "إذا قمت بالتحقق من مستخدم آخر، فيمكنك التأكد من أنك تعرف من تكتب إليه حقًا. 💪\n\nعند بدء عملية التحقق، سترى أنت والمستخدم الآخر نافذة منبثقة في التطبيق. هناك سترى بعد ذلك سلسلة من الرموز التعبيرية أو الأرقام التي يتعين عليك مقارنتها مع بعضها البعض.\n\nأفضل طريقة للقيام بذلك هي الالتقاء أو بدء مكالمة فيديو. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "عند التحقق من جهاز آخر، يمكن لهذه الأجهزة تبادل المفاتيح، مما يزيد من أمانك بشكل عام. 💪 عند بدء عملية التحقق، ستظهر نافذة منبثقة في التطبيق على كلا الجهازين. هناك سترى بعد ذلك سلسلة من الرموز التعبيرية أو الأرقام التي يتعين عليك مقارنتها مع بعضها البعض. من الأفضل أن يكون كلا الجهازين في متناول يديك قبل بدء عملية التحقق. 🤳", - "@verifyOtherDeviceDescription": {}, - "formattedMessages": "رسائل منسقة", - "@formattedMessages": {}, - "sendReadReceipts": "إرسال بالقراءة", - "@sendReadReceipts": {}, - "verifyOtherDevice": "🔐 التحقق من الجهاز الآخر", - "@verifyOtherDevice": {}, - "forwardMessageTo": "هل تريد إعادة توجيه الرسالة إلى {roomName}؟", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendTypingNotificationsDescription": "يستطيع المشاركون الآخرون في المحادثة رؤيتك عند كتابة رسالة جديدة.", - "@sendTypingNotificationsDescription": {}, - "sendReadReceiptsDescription": "يمكن للمشاركين الآخرين في المحادثة معرفة متى قرأت الرسالة.", - "@sendReadReceiptsDescription": {}, - "verifyOtherUser": "🔐 التحقق من المستخدم الآخر", - "@verifyOtherUser": {}, - "acceptedKeyVerification": "وافق {sender} على التحقق من المفتاح", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "قام {sender} بإلغاء التحقق من المفتاح", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} جاهز للتحقق من المفتاح", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "بدأ {sender} عملية التحقق من المفتاح", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "hidePresences": "إخفاء قائمة الحالة؟", - "@hidePresences": {}, - "incomingMessages": "الرسائل الواردة", - "@incomingMessages": {}, - "presenceStyle": "الحضور:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "إظهار رسائل الحالة من المستخدمين الآخرين", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "stickers": "الملصقات", - "@stickers": {}, - "discover": "استكشف", - "@discover": {}, - "commandHint_ignore": "تجاهل معرف المصفوفة المعطى", - "@commandHint_ignore": {}, - "commandHint_unignore": "إلغاء تجاهل معرف المصفوفة المحدد", - "@commandHint_unignore": {}, - "unreadChatsInApp": "{appname}: {unread} الدردشات غير المقروءة", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "noDatabaseEncryption": "تشفير قاعدة البيانات غير مدعوم على هذا النظام الأساسي", - "@noDatabaseEncryption": {}, - "appLockDescription": "قفل التطبيق عند عدم استخدامه بالرمز السري", - "@appLockDescription": {}, - "accessAndVisibility": "الوصول والرؤية", - "@accessAndVisibility": {}, - "calls": "المكالمات", - "@calls": {}, - "customEmojisAndStickers": "الرموز التعبيرية والملصقات المخصصة", - "@customEmojisAndStickers": {}, - "hideRedactedMessagesBody": "إذا قام شخص ما بتنقيح رسالة، فلن تكون هذه الرسالة مرئية في المحادثة بعد الآن.", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "إخفاء تنسيقات الرسائل غير الصالحة أو غير المعروفة", - "@hideInvalidOrUnknownMessageFormats": {}, - "overview": "نظرة عامة", - "@overview": {}, - "notifyMeFor": "أعلمني بـ", - "@notifyMeFor": {}, - "passwordRecoverySettings": "إعدادات استعادة كلمة المرور", - "@passwordRecoverySettings": {}, - "globalChatId": "معرف المحادثة العامة", - "@globalChatId": {}, - "accessAndVisibilityDescription": "من المسموح له بالانضمام إلى هذه المحادثة وكيف يمكن اكتشاف المحادثة.", - "@accessAndVisibilityDescription": {}, - "customEmojisAndStickersBody": "قم بإضافة أو مشاركة الرموز التعبيرية أو الملصقات المخصصة التي يمكن استخدامها في أي دردشة.", - "@customEmojisAndStickersBody": {}, - "hideRedactedMessages": "إخفاء الرسائل المكررة", - "@hideRedactedMessages": {}, - "hideMemberChangesInPublicChats": "إخفاء تغييرات الأعضاء في الدردشات العامة", - "@hideMemberChangesInPublicChats": {}, - "hideMemberChangesInPublicChatsBody": "لا تظهر في المخطط الزمني للدردشة إذا انضم شخص ما إلى محادثة عامة أو غادرها لتحسين إمكانية القراءة.", - "@hideMemberChangesInPublicChatsBody": {}, - "usersMustKnock": "المستخدم يجب أن يطرق الباب", - "@usersMustKnock": {}, - "chatCanBeDiscoveredViaSearchOnServer": "يمكن اكتشاف الشات عن طريق البحث في {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "noOneCanJoin": "لا أحد يستطيع الانضمام", - "@noOneCanJoin": {}, - "knocking": "طرق", - "@knocking": {}, - "userWouldLikeToChangeTheChat": "{user} يرغب في الانضمام إلى المحادثة.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "لم يتم بعد إنشاء أي رابط عام", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "دق", - "@knock": {}, - "thereAreCountUsersBlocked": "يوجد حاليًا {count} من المستخدمين المحظورين.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "publicChatAddresses": "عناوين المحادثة العامة", - "@publicChatAddresses": {}, - "createNewAddress": "إنشاء عنوان جديد", - "@createNewAddress": {}, - "userRole": "دور المستخدم", - "@userRole": {}, - "minimumPowerLevel": "{level} هو الحد الأدنى من مستوى الطاقة.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "searchIn": "بحث في {chat}...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "files": "الملفات", - "@files": {}, - "restricted": "مقيد", - "@restricted": {}, - "knockRestricted": "قيود النقر", - "@knockRestricted": {}, - "searchMore": "ابحث أكثر...", - "@searchMore": {}, - "gallery": "المعرض", - "@gallery": {}, - "swipeRightToLeftToReply": "اسحب من اليمين إلى اليسار للرد", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_bn.arb b/assets/l10n/intl_bn.arb deleted file mode 100644 index c758ff5fe..000000000 --- a/assets/l10n/intl_bn.arb +++ /dev/null @@ -1,1885 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:10.154280", - "about": "সম্পর্কে", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "স্বীকার করি", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "{username} আমন্ত্রণ গ্রহণ করেছে", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "অ্যাকাউন্ট", - "@account": { - "type": "text", - "placeholders": {} - }, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@connect": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@chats": { - "type": "text", - "placeholders": {} - }, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@admin": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@addAccount": {}, - "@close": { - "type": "text", - "placeholders": {} - }, - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "@chatHasBeenAddedToThisSpace": {}, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@device": { - "type": "text", - "placeholders": {} - }, - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@encryption": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@invited": { - "type": "text", - "placeholders": {} - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@password": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@remove": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "@id": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "@blocked": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@sendOnEnter": {}, - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@fileName": { - "type": "text", - "placeholders": {} - }, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@create": { - "type": "text", - "placeholders": {} - }, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@alias": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@all": { - "type": "text", - "placeholders": {} - }, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@edit": { - "type": "text", - "placeholders": {} - }, - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@copy": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@none": { - "type": "text", - "placeholders": {} - }, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@yourChatBackupHasBeenSetUp": {}, - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@help": { - "type": "text", - "placeholders": {} - }, - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "@people": { - "type": "text", - "placeholders": {} - }, - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@repeatPassword": {}, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "@callingPermissions": {}, - "@delete": { - "type": "text", - "placeholders": {} - }, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@start": {}, - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@identity": { - "type": "text", - "placeholders": {} - }, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@moderator": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@send": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "@banned": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@notifications": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@chat": { - "type": "text", - "placeholders": {} - }, - "@group": { - "type": "text", - "placeholders": {} - }, - "@leave": { - "type": "text", - "placeholders": {} - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@allChats": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@license": { - "type": "text", - "placeholders": {} - }, - "@addToSpace": {}, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@forward": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@cancel": { - "type": "text", - "placeholders": {} - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@clearArchive": {}, - "@appLock": { - "type": "text", - "placeholders": {} - }, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "@importEmojis": {}, - "@confirm": { - "type": "text", - "placeholders": {} - }, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@you": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@search": { - "type": "text", - "placeholders": {} - }, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@logout": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterANumber": {}, - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "@messages": { - "type": "text", - "placeholders": {} - }, - "@login": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@archive": { - "type": "text", - "placeholders": {} - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "@devices": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@pin": { - "type": "text", - "placeholders": {} - }, - "@importNow": {}, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "@invite": {}, - "@enableMultiAccounts": {}, - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@screenSharingDetail": {}, - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {}, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - } -} \ No newline at end of file diff --git a/assets/l10n/intl_bo.arb b/assets/l10n/intl_bo.arb deleted file mode 100644 index b7b04532c..000000000 --- a/assets/l10n/intl_bo.arb +++ /dev/null @@ -1,1880 +0,0 @@ -{ - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@connect": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@chats": { - "type": "text", - "placeholders": {} - }, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@admin": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@addAccount": {}, - "@close": { - "type": "text", - "placeholders": {} - }, - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "@chatHasBeenAddedToThisSpace": {}, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@device": { - "type": "text", - "placeholders": {} - }, - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@encryption": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersionLong": {}, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@invited": { - "type": "text", - "placeholders": {} - }, - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@password": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@remove": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "@id": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "@blocked": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@sendOnEnter": {}, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@fileName": { - "type": "text", - "placeholders": {} - }, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@create": { - "type": "text", - "placeholders": {} - }, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@alias": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@all": { - "type": "text", - "placeholders": {} - }, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@edit": { - "type": "text", - "placeholders": {} - }, - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@copy": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@none": { - "type": "text", - "placeholders": {} - }, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@storeSecurlyOnThisDevice": {}, - "@yourChatBackupHasBeenSetUp": {}, - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@help": { - "type": "text", - "placeholders": {} - }, - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "@people": { - "type": "text", - "placeholders": {} - }, - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@repeatPassword": {}, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "@callingPermissions": {}, - "@delete": { - "type": "text", - "placeholders": {} - }, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@start": {}, - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@identity": { - "type": "text", - "placeholders": {} - }, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@moderator": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@send": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "@banned": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@account": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {}, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@notifications": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@chat": { - "type": "text", - "placeholders": {} - }, - "@group": { - "type": "text", - "placeholders": {} - }, - "@leave": { - "type": "text", - "placeholders": {} - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@allChats": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@license": { - "type": "text", - "placeholders": {} - }, - "@addToSpace": {}, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@forward": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@about": { - "type": "text", - "placeholders": {} - }, - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@cancel": { - "type": "text", - "placeholders": {} - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@clearArchive": {}, - "@appLock": { - "type": "text", - "placeholders": {} - }, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "@importEmojis": {}, - "@confirm": { - "type": "text", - "placeholders": {} - }, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@you": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@search": { - "type": "text", - "placeholders": {} - }, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@logout": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterANumber": {}, - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "@messages": { - "type": "text", - "placeholders": {} - }, - "@login": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@archive": { - "type": "text", - "placeholders": {} - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "@devices": { - "type": "text", - "placeholders": {} - }, - "@accept": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@pin": { - "type": "text", - "placeholders": {} - }, - "@importNow": {}, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@screenSharingDetail": {}, - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "@invite": {}, - "@enableMultiAccounts": {}, - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - } -} \ No newline at end of file diff --git a/assets/l10n/intl_ca.arb b/assets/l10n/intl_ca.arb deleted file mode 100644 index 0608d4456..000000000 --- a/assets/l10n/intl_ca.arb +++ /dev/null @@ -1,2611 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:10.145728", - "about": "Quant a", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Accepta", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} ha acceptat la invitació", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Compte", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} ha activat el xifratge d’extrem a extrem", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "Administració", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "àlies", - "@alias": { - "type": "text", - "placeholders": {} - }, - "allChats": "Tots els xats", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} ha respost a la trucada", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Qualsevol pot unir-se", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Blocatge de l’aplicació", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arxiu", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Es pot entrar a la sala com a convidadi", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "N’esteu seguri?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Per a poder donar accés a l’altra persona, introduïu la frase de seguretat o clau de recuperació.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Voleu acceptar aquesta sol·licitud de verificació de: {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banFromChat": "Veta del xat", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Vetadi", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} ha vetat a {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Bloca el dispositiu", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Missatges del bot", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Cancel·la", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "No es pot obrir l’URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Canvia el nom del dispositiu", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} ha canviat la imatge del xat", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} ha canviat la descripció del xat a: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} ha canviat el nom del xat a: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} ha canviat els permisos del xat", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRules": "{username} ha canviat les normes d’accés dels convidats", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} ha canviat les normes d’accés dels convidats a: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} ha canviat la visibilitat de l’historial", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} ha canviat la visibilitat de l’historial a: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} ha canviat les normes d’unió", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} ha canviat les normes d’unió a: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} ha canviat la seva imatge de perfil", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} ha canviat l’àlies de la sala", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} ha canviat l’enllaç per a convidar", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Canvia la contrasenya", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Canvia el servidor", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Canvia l’estil", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Canvia el nom del grup", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "El xifratge s’ha corromput", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Xat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Detalls del xat", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Xats", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Trieu una contrasenya forta", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Tanca", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_html": "Envia text en format HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_leave": "Abandona aquesta sala", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_op": "Estableix el nivell d'autoritat d'uni usuàriï (per defecte: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Envia text sense format", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_send": "Envia text", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "compareEmojiMatch": "Compareu aquests emojis", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Compareu aquests números", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Confirma", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Connecta", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "El contacte ha estat convidat al grup", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Conté l'àlies", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Inclou nom d'usuàriï", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "S’ha copiat al porta-retalls", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Copia", - "@copy": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "No s'ha pogut desxifrar el missatge: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} participants", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Crea", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} ha creat el xat", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Actiu actualment", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Fosc", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Es desactivarà el vostre compte d’usuàriï. És irreversible! Voleu fer-ho igualment?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "delete": "Suprimeix", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Suprimeix el compte", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Suprimeix el missatge", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Dispositiu", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Id. de dispositiu", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Dispositius", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Xats directes", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Ha canviat l'àlies", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Baixa el fitxer", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Edita", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Edita l'àlies", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "L'emoticona ja existeix!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Codi d'emoticona invàlid!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Paquet d'emoticones de la sala", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Paràmetres de les emoticones", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Codi d'emoticona", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Has de seleccionar un codi d'emoticona i una imatge!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Xat buit", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Activa el paquet d'emoticones global", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "No podreu desactivar el xifratge mai més. N’esteu segur?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Xifrat", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Xifratge", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "El xifratge no s’ha activat", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} ha finalitzat la trucada", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Introduïu una adreça electrònica", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Introdueix el teu servidor", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nom del fitxer", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Reenvia", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Des de la unió", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Des de la invitació", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "Grup", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "El grup és públic", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grup amb {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Els convidats no poden unir-se", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Els convidats es poden unir", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} ha retirat la invitació de {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Ajuda", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Amaga els esdeveniments estripats", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Amaga els esdeveniments desconeguts", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "id": "Id.", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identitat", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Usuaris ignorats", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "He fet clic a l'enllaç", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Frase de seguretat o clau de recuperació incorrecta", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Convida contacte", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Convida contacte a {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Convidat", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} ha convidat a {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Només usuàriïs convidadis", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Invitació per a mi", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} t'ha convidat a FluffyChat.\n1. Visita fluffychat.im i instaŀla l'app\n2. Registra't o inicia sessió\n3. Obre l'enllaç d'invitació:\n{link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "escrivint…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} s'ha unit al xat", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Uneix-te a la sala", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} ha expulsat a {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} ha expulsat i vetat a {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Expulsa del xat", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Actiu per última vegada: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Abandona", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Ha marxat del xat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Llicència", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Clar", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Carrega {count} participants més", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "S’està carregant… Espereu.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Carrega’n més…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "S’han desactivat els serveis d’ubicació. Activeu-los per a compartir la vostra ubicació.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "S’ha rebutjat el permís d’ubicació. Atorgueu-lo per a poder compartir la vostra ubicació.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Inicia la sessió", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Inicia sessió a {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Finalitza la sessió", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Canvis de participants", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Menciona", - "@mention": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderador", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Silencia el xat", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Tingueu en compte que, ara per ara, us cal el Pantalaimon per a poder utilitzar el xifratge d’extrem a extrem.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Missatge nou al FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nova sol·licitud de verificació!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "no": "No", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Sense connexió al servidor", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "No s’ha trobat cap emoticona. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Sembla que no teniu els Serveis de Google al telèfon. Això és una bona decisió respecte a la vostra privadesa! Per a rebre notificacions automàtiques del FluffyChat, us recomanem instaŀlar ntfy. Amb ntfy o qualsevol altre proveïdor de Unified Push, pots rebre notificacions de forma segura i lliure. Pots instaŀlar ntfy des de la PlayStore o des de F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Cap", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Encara no heu afegit cap mètode per a poder recuperar la contrasenya.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Sense permís", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "No s’ha trobat cap sala…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notificacions", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Notificacions activades per a aquest compte", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} usuàriïs escrivint…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "offline": "Fora de línia", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "D'acord", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "En línia", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "La còpia de seguretat de claus en línia està activada", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Alguna cosa ha anat malament…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Obre l'aplicació per llegir els missatges", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Obre la càmera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "or": "O", - "@or": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "contrasenya o clau de recuperació", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Contrasenya", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Contrasenya oblidada", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "La contrasenya ha canviat", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Recuperació de contrassenya", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Selecciona una imatge", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Fixa", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Reproduir {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChooseAPasscode": "Tria un codi d'accés", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Fes clic a l'enllaç del correu i, després, segueix.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Introdueix 4 dígits o deixa-ho buit per desactivar el bloqueig.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Introdueix la teva contrasenya", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Introdueix el teu nom d'usuàriï", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privadesa", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Sales públiques", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Regles push", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "recording": "Enregistrant", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} ha estripat un esdeveniment", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Rebutja", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} ha rebutjat la invitació", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Torna-t'hi a unir", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Elimina", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Elimina tots els altres dispositius", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Eliminat per {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Elimina dispositiu", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Aixeca el veto", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Mostra el contingut enriquit dels missatges", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "Respon", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Sol·licita permís", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "La sala s'ha actualitzat", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "security": "Seguretat", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Vist per {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Envia", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Envia un missatge", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Envia com a text", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Envia un àudio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Envia un fitxer", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Envia una imatge", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Envia l’original", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Envia adhesiu", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Envia un vídeo", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} ha enviat un fitxer", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} ha enviat un àudio", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} ha enviat una imatge", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} ha enviat un adhesiu", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} ha enviat un vídeo", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} ha enviat informació de trucada", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setInvitationLink": "Defineix l’enllaç per a convidar", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Defineix el nivell de permisos", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Defineix l’estat", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Paràmetres", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Comparteix", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} n’ha compartit la ubicació", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "singlesignon": "Autenticació única", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Omet", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Codi font", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} ha iniciat una trucada", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "statusExampleMessage": "Com us sentiu avui?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Envia", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistema", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "No coincideixen", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Coincideixen", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Marca com a llegit/sense llegir", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Massa sol·licituds. Torna-ho a provar més tard!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Intenta tornar a enviar", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "No disponible", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} ha aixecat el veto a {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Desbloqueja dispositiu", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Dispositiu desconegut", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "L’algorisme de xifratge és desconegut", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Esdeveniment desconegut '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Deixa de silenciar el xat", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Deixa de fixar", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 xat no llegit} other{{unreadCount} xats no llegits}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} i {count} més estan escrivint…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} i {username2} estan escrivint…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} està escrivint…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} ha marxat del xat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Nom d’usuàriï", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} ha enviat un esdeveniment {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "Verifica", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Inicia la verificació", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "T'has verificat correctament!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verificant un altre compte", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videotrucada", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Visibilitat de l’historial del xat", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Visible per a tots els participants", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Visible per a tothom", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Missatge de veu", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "S’està esperant que l’altre accepti l’emoji…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "S’està esperant que l’altre accepti els nombres…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Fons:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Atenció!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Us hem enviat un missatge de correu electrònic", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Qui pot unir-se a aquest grup", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Amb aquestes adreces, si ho necessiteu, podeu recuperar la vostra contrasenya.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Escriviu un missatge…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Sí", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Vós", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Ja no participeu en aquest xat", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "T'han vetat en aquest xat", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "La vostra clau pública", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "all": "Tot", - "@all": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Afegeix a un espai", - "@addToSpace": {}, - "areYouSureYouWantToLogout": "Segur que voleu finalitzar la sessió?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "addEmail": "Afegeix una adreça electrònica", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "commandInvalid": "L’ordre no és vàlida", - "@commandInvalid": { - "type": "text" - }, - "fontSize": "Mida de la lletra", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Ves a la sala nova", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "next": "Següent", - "@next": { - "type": "text", - "placeholders": {} - }, - "link": "Enllaç", - "@link": {}, - "people": "Gent", - "@people": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Estripa el missatge", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "Envia en prémer Retorn", - "@sendOnEnter": {}, - "clearArchive": "Neteja l’arxiu", - "@clearArchive": {}, - "chatBackupDescription": "Els teus xats antics estan protegits amb una clau de recuperació. Assegureu-vos de no perdre-la.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "El xat s’ha afegit a aquest espai", - "@chatHasBeenAddedToThisSpace": {}, - "autoplayImages": "Reprodueix automàticament enganxines i emoticones animades", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "chatBackup": "Còpia de seguretat del xat", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "blocked": "Blocat", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Tot és a punt!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Nom de l’espai", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "search": "Cerca", - "@search": { - "type": "text", - "placeholders": {} - }, - "verified": "Verificat", - "@verified": { - "type": "text", - "placeholders": {} - }, - "newChat": "Xat nou", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Canvia l’avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignora", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "commandHint_react": "Envia una resposta com a reacció", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "defaultPermissionLevel": "Nivell de permisos per defecte", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extremadament ofensiu", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "S’ha configurat la còpia de seguretat del xat.", - "@yourChatBackupHasBeenSetUp": {}, - "contentHasBeenReported": "El contingut s’ha denunciat als administradors del servidor", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Activa el xifratge", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "addAccount": "Afegeix un compte", - "@addAccount": {}, - "noEncryptionForPublicRooms": "Només podreu activar el xifratge quan la sala ja no sigui accessible públicament.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Versió de la sala", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Envia missatges", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Desa el fitxer", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Seguiu les instruccions al lloc web i toqueu «Següent».", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Denuncia el missatge", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Defineix com a àlies principal", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "status": "Estat", - "@status": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Commuta l’estat «preferit»", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Commuta l’estat «silenci»", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Transfereix des d’un altre dispositiu", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Defineix emoticones personalitzades", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Qui pot efectuar quina acció", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Per què voleu denunciar això?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Voleu suprimir la còpia de seguretat dels xats per a crear una clau de recuperació nova?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "S’està esperant que l’altre accepti la sol·licitud…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "unverified": "No verificat", - "@unverified": {}, - "commandHint_me": "Descriviu-vos", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandMissing": "{command} no és una ordre.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "configureChat": "Configura el xat", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Copia al porta-retalls", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Espai nou", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "S’ha produït un error en obtenir la ubicació: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "groups": "Grups", - "@groups": { - "type": "text", - "placeholders": {} - }, - "messages": "Missatges", - "@messages": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Mostra la contrasenya", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "L’espai és públic", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "Escaneja un codi QR", - "@scanQrCode": {}, - "obtainingLocation": "S’està obtenint la ubicació…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Comparteix la ubicació", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "S’està sincronitzant… Espereu.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "reason": "Raó", - "@reason": { - "type": "text", - "placeholders": {} - }, - "changedTheDisplaynameTo": "{username} ha canviat el seu àlies a: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "howOffensiveIsThisContent": "Com d’ofensiu és aquest contingut?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "commandHint_clearcache": "Neteja la memòria cau", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_join": "Uneix-te a la sala", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Expulsa uni usuàriï d'aquesta sala", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_myroomavatar": "Establiu la imatge per a aquesta sala (per mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_dm": "Inicia un xat directe\nUsa --no-encryption per desactivar l'encriptatge", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_invite": "Convida uni usuàriï a aquesta sala", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_ban": "Veta uni usuàriï d'aquesta sala", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_create": "Crea un xat de grup buit\nUsa --no-encryption per desactivar l'encriptatge", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_discardsession": "Descarta la sessió", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "repeatPassword": "Repetiu la contrasenya", - "@repeatPassword": {}, - "commandHint_myroomnick": "Estableix el teu àlies per a aquesta sala", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "editBlockedServers": "Edita els servidors bloquejats", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "El servidor admet els inicis de sessió:\n{serverVersions}\nPerò l'aplicació només admet:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "hugContent": "{senderName} t'abraça", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "jumpToLastReadMessage": "Salta a l'últim missatge llegit", - "@jumpToLastReadMessage": {}, - "allRooms": "Tots els xats de grup", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "commandHint_cuddle": "Envia una carícia", - "@commandHint_cuddle": {}, - "widgetVideo": "Vídeo", - "@widgetVideo": {}, - "dismiss": "Ignora-ho", - "@dismiss": {}, - "reportErrorDescription": "😭 Oh no. Hi ha hagut algun error. Si vols, pots informar d'aquest bug a l'equip de desenvolupament.", - "@reportErrorDescription": {}, - "removeYourAvatar": "Esborra el teu avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "unsupportedAndroidVersion": "Aquesta versió d'Android és incompatible", - "@unsupportedAndroidVersion": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "messageType": "Tipus de missatge", - "@messageType": {}, - "indexedDbErrorLong": "L'emmagatzematge de missatges no està disponible per defecte en el mode privat.\nVisita\n - about:config\n - posa a true l'opció dom.indexedDB.privateBrowsing.enabled\nSi no ho fas, no podràs fer servir FluffyChat en mode privat.", - "@indexedDbErrorLong": {}, - "oneClientLoggedOut": "Una de les teves aplicacions ha tancat la sessió", - "@oneClientLoggedOut": {}, - "startFirstChat": "Comença el teu primer xat", - "@startFirstChat": {}, - "callingAccount": "Compte de la trucada", - "@callingAccount": {}, - "setColorTheme": "Tria el color del tema:", - "@setColorTheme": {}, - "nextAccount": "Compte següent", - "@nextAccount": {}, - "allSpaces": "Tots els espais", - "@allSpaces": {}, - "supposedMxid": "Això hauria de ser {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "user": "Usuàrïi", - "@user": {}, - "youAcceptedTheInvitation": "👍 Has acceptat la invitació", - "@youAcceptedTheInvitation": {}, - "noMatrixServer": "{server1} no és un servidor de matrix, vols fer servir {server2} ?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "youInvitedBy": "📩 {user} t'ha convidat", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "banUserDescription": "Es vetarà li usuàriï vetadi a la sala i no podrà tornar-hi a entrar fins que se li aixequi el veto.", - "@banUserDescription": {}, - "widgetEtherpad": "Nota de text", - "@widgetEtherpad": {}, - "removeDevicesDescription": "Tancaràs la sessió d'aquest dispositiu i no hi podràs rebre més missatges.", - "@removeDevicesDescription": {}, - "separateChatTypes": "Separa xats directes i grups", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "tryAgain": "Torna-ho a provar", - "@tryAgain": {}, - "youKickedAndBanned": "🙅 Has expulsat i vetat a {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "unbanUserDescription": "L'usuàrïi ja pot tornar a entrar a la sala.", - "@unbanUserDescription": {}, - "youRejectedTheInvitation": "Has rebutjat la invitació", - "@youRejectedTheInvitation": {}, - "otherCallingPermissions": "Micròfon, càmera i altres permisos del FluffyChat", - "@otherCallingPermissions": {}, - "messagesStyle": "Missatges:", - "@messagesStyle": {}, - "widgetUrlError": "La URL no és vàlida.", - "@widgetUrlError": {}, - "emailOrUsername": "Email o nom d'usuàrïi", - "@emailOrUsername": {}, - "newSpaceDescription": "Els espais et permeten consolidar ls por", - "@newSpaceDescription": {}, - "chatDescription": "Descripció del xat", - "@chatDescription": {}, - "callingAccountDetails": "Permet al FluffyChat de fer servir l'app de trucades nativa de l'Android.", - "@callingAccountDetails": {}, - "editRoomAliases": "Canvia els àlies de la sala", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "enterSpace": "Obre l'espai", - "@enterSpace": {}, - "encryptThisChat": "Xifra aquest xat", - "@encryptThisChat": {}, - "previousAccount": "Compte anterior", - "@previousAccount": {}, - "reopenChat": "Reobre el xat", - "@reopenChat": {}, - "pleaseEnterRecoveryKey": "Introdueix la teva clau de recuperació:", - "@pleaseEnterRecoveryKey": {}, - "widgetNameError": "Posa el nom públic.", - "@widgetNameError": {}, - "inoffensive": "Inofensiu", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "addToBundle": "Afegeix al pquet", - "@addToBundle": {}, - "addWidget": "Afegeix un giny", - "@addWidget": {}, - "countFiles": "{count} arxius", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "noKeyForThisMessage": "Això pot passar si el missatge es va enviar abans que haguessis iniciat sessió al teu compte des d'aquest dispositiu.\n\nTambé pot ser que l'emissor hagi bloquejat el teu dispositiu o que la connexió a internet anés malament.\n\nQue pots llegir el missatge des d'una altra sessió? Si és així, llavors pots transferir-lo! Ves a Paràmetres → Dispositius i assegura't que els teus dispositius s'ha verificat mútuament. Quan obris la sala la propera vegada i totes dues sessions estiguin executant-se, en primer pla, llavors les claus es trasnsmetran automàticament.\n\nVols evitar perdre les claus en tancar la sessió o en canviar de dispositiu? Llavors assegura't que has activat la còpia de seguretat del xat als paràmetres.", - "@noKeyForThisMessage": {}, - "commandHint_markasgroup": "Marca com un grup", - "@commandHint_markasgroup": {}, - "hydrateTor": "Usuàrïis de Tor: Importa una sessió anterior", - "@hydrateTor": {}, - "pushNotificationsNotAvailable": "Les notificacions push no estan disponibles", - "@pushNotificationsNotAvailable": {}, - "storeInAppleKeyChain": "Desa en la Apple KeyChain", - "@storeInAppleKeyChain": {}, - "replaceRoomWithNewerVersion": "Substitueix la sala amb la versió més recent", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "hydrate": "Restaura un arxiu de recuperació", - "@hydrate": {}, - "invalidServerName": "El nom del servidor és invàlid", - "@invalidServerName": {}, - "chatPermissions": "Permisos del xat", - "@chatPermissions": {}, - "sender": "Remitent", - "@sender": {}, - "storeInAndroidKeystore": "Desa en la Android KeyStore", - "@storeInAndroidKeystore": {}, - "signInWithPassword": "Inicia sessió amb contrasenya", - "@signInWithPassword": {}, - "offensive": "Ofensiu", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "makeAdminDescription": "Un cop hagis fet admin aquesta persona ja no podràs desfer-ho, ja que llavors tindrà els mateixos permisos que tu.", - "@makeAdminDescription": {}, - "saveKeyManuallyDescription": "Per desar aquesta clau manualment, pica l'eina de compartir o copia-la al porta-retalls.", - "@saveKeyManuallyDescription": {}, - "editBundlesForAccount": "Edita paquets per aquest compte", - "@editBundlesForAccount": {}, - "whyIsThisMessageEncrypted": "Per què no es pot llegir aquest missatge?", - "@whyIsThisMessageEncrypted": {}, - "setChatDescription": "Posa una descripció de xat", - "@setChatDescription": {}, - "importFromZipFile": "Importa des d'un arxiu zip", - "@importFromZipFile": {}, - "dehydrateWarning": "Aquesta acció és irreversible. Assegura't que deses l'arxiu de recuperació en un lloc segur.", - "@dehydrateWarning": {}, - "noOtherDevicesFound": "No s'han trobat més dispositius", - "@noOtherDevicesFound": {}, - "redactedBy": "Estripat per {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "videoCallsBetaWarning": "Tingues en compte que les trucades de vídeo estan encara en beta. Pot ser que no funcioni bé o que falli en alguna plataforma.", - "@videoCallsBetaWarning": {}, - "participant": "Participant", - "@participant": { - "type": "text", - "placeholders": {} - }, - "signInWith": "Inicia sessió amb {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "fileIsTooBigForServer": "El servidor ha rebutjat l'arxiu perquè és massa gran.", - "@fileIsTooBigForServer": {}, - "homeserver": "Servidor", - "@homeserver": {}, - "callingPermissions": "Permisos de trucada", - "@callingPermissions": {}, - "readUpToHere": "Llegit fins aquí", - "@readUpToHere": {}, - "start": "Comença", - "@start": {}, - "register": "Registra't", - "@register": { - "type": "text", - "placeholders": {} - }, - "unlockOldMessages": "Desbloqueja els missatges antics", - "@unlockOldMessages": {}, - "numChats": "{number} xats", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "optionalRedactReason": "(Opcional) El motiu per estripar el missatge...", - "@optionalRedactReason": {}, - "dehydrate": "Exporta la sessió i neteja el dispositiu", - "@dehydrate": {}, - "archiveRoomDescription": "Aquest xat serà arxivat. Els altres contactes del grup ho veuran com si haguessis abandonat la sala.", - "@archiveRoomDescription": {}, - "exportEmotePack": "Exporta com un pack Emote en .zip", - "@exportEmotePack": {}, - "switchToAccount": "Canvia al compte {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "experimentalVideoCalls": "Trucades de vídeo experimentals", - "@experimentalVideoCalls": {}, - "pleaseEnterRecoveryKeyDescription": "Per desbloquejar els missatges antics, introdueix la clau de recuperació que vas generar en una sessió anterior. La clau de recuperació NO és la teva contrasenya.", - "@pleaseEnterRecoveryKeyDescription": {}, - "openInMaps": "Obre als mapes", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroupQuestion": "Vols convidar {contact} al xat \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Estripat per {username} per: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Has rebutjat la invitació de {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "appearOnTopDetails": "Permet a l'app que aparegui sobre d'altres apps. No cal si ja has afegit FluffyChat com a compte de trucades", - "@appearOnTopDetails": {}, - "enterRoom": "Entra a la sala", - "@enterRoom": {}, - "reportUser": "Denuncia l'usuàrïi", - "@reportUser": {}, - "confirmEventUnpin": "Vols desfixar l'esdeveniment permanentment?", - "@confirmEventUnpin": {}, - "badServerVersionsException": "Aquest servidor suporta aquestes versions de Matrix:\n{serverVersions}\nPerò aquesta aplicación només és compatible amb {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "youInvitedUser": "📩 Has convidat a {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "fileHasBeenSavedAt": "S'ha desat l'arxiu a {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "redactMessageDescription": "S'estriparà el missatge per a totser d'aquesta sala. Aquesta acció és irreversible.", - "@redactMessageDescription": {}, - "recoveryKey": "Clau de recuperació", - "@recoveryKey": {}, - "invalidInput": "L'entrada no és vàlida!", - "@invalidInput": {}, - "dehydrateTorLong": "Per a lis usuàrïis de Tor, es recomana exportar la sessió abans de tancar la finestra.", - "@dehydrateTorLong": {}, - "doNotShowAgain": "No ho tornis a mostrar", - "@doNotShowAgain": {}, - "report": "informa", - "@report": {}, - "serverRequiresEmail": "Aquest servidor necessita validar la teva adreça per registrar-t'hi.", - "@serverRequiresEmail": {}, - "hideUnimportantStateEvents": "Amaga canvis d'estat poc importants", - "@hideUnimportantStateEvents": {}, - "screenSharingTitle": "compartició de pantalla", - "@screenSharingTitle": {}, - "widgetCustom": "Personalització", - "@widgetCustom": {}, - "addToSpaceDescription": "Tria un espai per afegir-hi el xat.", - "@addToSpaceDescription": {}, - "googlyEyesContent": "{senderName} t'ha enviat un parell d'ulls", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "youBannedUser": "Has vetat a {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "addChatDescription": "Afegeix una descripció al xat...", - "@addChatDescription": {}, - "editRoomAvatar": "Canvia la imatge de la sala", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "hasKnocked": "{user} pica a la porta", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "publish": "Publica", - "@publish": {}, - "openLinkInBrowser": "Obre l'enllaç en un navegador", - "@openLinkInBrowser": {}, - "messageInfo": "Informació del missatge", - "@messageInfo": {}, - "disableEncryptionWarning": "Per motius de seguretat, un cop activat, no es pot desactivar el xifratge.", - "@disableEncryptionWarning": {}, - "directChat": "Xat directe", - "@directChat": {}, - "wrongPinEntered": "Pin incorrecte! Torna-ho a provar en {seconds} segons...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "Envia notificacions d'escriptura", - "@sendTypingNotifications": {}, - "inviteGroupChat": "📨 Convida al grup", - "@inviteGroupChat": {}, - "appearOnTop": "Mostra per sobre", - "@appearOnTop": {}, - "invitePrivateChat": "📨 Convida a un xat privat", - "@invitePrivateChat": {}, - "foregroundServiceRunning": "Aquesta notificació apareix quan el servei de primer pla està corrent.", - "@foregroundServiceRunning": {}, - "voiceCall": "Videotrucada", - "@voiceCall": {}, - "commandHint_unban": "Aixeca el veto a aquesti usuàriï per aquesta sala", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "importEmojis": "Importa emojis", - "@importEmojis": {}, - "wasDirectChatDisplayName": "La sala buida ( va ser {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noChatDescriptionYet": "No s'ha afegit una descripció de xat.", - "@noChatDescriptionYet": {}, - "removeFromBundle": "Esborra del paquet", - "@removeFromBundle": {}, - "confirmMatrixId": "Confirma la teva ID de Matrix per poder esborrar el compte.", - "@confirmMatrixId": {}, - "learnMore": "Llegeix-ne més", - "@learnMore": {}, - "notAnImage": "No és un arxiu d'image.", - "@notAnImage": {}, - "users": "Usuàrïis", - "@users": {}, - "openGallery": "Obre la galeria", - "@openGallery": {}, - "chatDescriptionHasBeenChanged": "Ha canviat la descripció del xat", - "@chatDescriptionHasBeenChanged": {}, - "newGroup": "Grup nou", - "@newGroup": {}, - "bundleName": "Nom del paquet", - "@bundleName": {}, - "dehydrateTor": "Usuàrïis de Tor: Exporta la sessió", - "@dehydrateTor": {}, - "removeFromSpace": "Esborra de l'espai", - "@removeFromSpace": {}, - "roomUpgradeDescription": "El xat serà recreat amb una versió de sala nova. Totis lis participants seran notificadis que han de canviar a la nova sala. Pots llegir més sobre les versions de sala a https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Introdueix un número major que 0", - "@pleaseEnterANumber": {}, - "youKicked": "👞 Has expulsat a {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "profileNotFound": "No s'ha trobat el compte en aquest servidor. Pot ser un error de connexió, o que realment no existeixi.", - "@profileNotFound": {}, - "jump": "Salta", - "@jump": {}, - "reactedWith": "{sender} ha reaccionat amb {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "sorryThatsNotPossible": "Aquesta acció no és possible", - "@sorryThatsNotPossible": {}, - "videoWithSize": "Vídeo {size}", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "shareInviteLink": "Comparteix un enllaç d'invitació", - "@shareInviteLink": {}, - "commandHint_markasdm": "Marca com a conversa directa la sala amb aquesta ID de Matrix", - "@commandHint_markasdm": {}, - "recoveryKeyLost": "Que has perdut la clau de recuperació?", - "@recoveryKeyLost": {}, - "cuddleContent": "{senderName} et fa una carícia", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "deviceKeys": "Claus del dispositiu:", - "@deviceKeys": {}, - "emoteKeyboardNoRecents": "Els últims emotes usats apareixeran aquí...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Tria el tema:", - "@setTheme": {}, - "youJoinedTheChat": "T'has afegit al xat", - "@youJoinedTheChat": {}, - "openVideoCamera": "Obre la càmera per a fer un vídeo", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "markAsRead": "Marca com a llegit", - "@markAsRead": {}, - "widgetName": "Nom", - "@widgetName": {}, - "errorAddingWidget": "S'ha produït un error en afegir el giny.", - "@errorAddingWidget": {}, - "commandHint_hug": "Envia una abraçada", - "@commandHint_hug": {}, - "replace": "Reemplaça", - "@replace": {}, - "oopsPushError": "Ep! Sembla que s'ha produït un error en configurar les notificacions.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "youUnbannedUser": "Has aixecat el veto a {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "newSpace": "Espai nou", - "@newSpace": {}, - "emojis": "Emojis", - "@emojis": {}, - "pleaseEnterYourPin": "Introdueix el teu pin", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Escull", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "Envia uns ulls curiosos", - "@commandHint_googly": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Torna-ho a provar més tard o tria un servidor diferent.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Crea un grup", - "@createGroup": {}, - "hydrateTorLong": "Que vas exportar la teva última sessió a Tor? La pots importar ara i continuar xatejant.", - "@hydrateTorLong": {}, - "time": "Temps", - "@time": {}, - "custom": "Personalitzat", - "@custom": {}, - "noBackupWarning": "Compte! Si no actives la còpia de seguretat dels xats, perdràs accés als teus missatges xifrats. És molt recomanable activar-ho abans de tancar la sessió.", - "@noBackupWarning": {}, - "storeInSecureStorageDescription": "Desa la clau de recuperació en l'emmagatzematge segur d'aquest dispositiu.", - "@storeInSecureStorageDescription": {}, - "openChat": "Obre el xat", - "@openChat": {}, - "kickUserDescription": "Li usuàrïi ha estat expulsadi però no vetadi. Als xats públics, pot tornar-hi a entrar en qualsevol moment.", - "@kickUserDescription": {}, - "importNow": "Importa-ho ara", - "@importNow": {}, - "pinMessage": "Fixa a la sala", - "@pinMessage": {}, - "invite": "Convida", - "@invite": {}, - "enableMultiAccounts": "(Beta) Activa multi-compte en aquest dispositiu", - "@enableMultiAccounts": {}, - "indexedDbErrorTitle": "Problemes amb el mode privat", - "@indexedDbErrorTitle": {}, - "unsupportedAndroidVersionLong": "Aquesta funcionalitat només funciona amb versions d'Android més noves.", - "@unsupportedAndroidVersionLong": {}, - "storeSecurlyOnThisDevice": "Desa de forma segura en aquest dispositiu", - "@storeSecurlyOnThisDevice": {}, - "screenSharingDetail": "Estàs compartint la teva pantalla a FluffyChat", - "@screenSharingDetail": {}, - "placeCall": "Truca", - "@placeCall": {}, - "block": "bloca", - "@block": {}, - "blockUsername": "Ignora aquesti usuàrïi", - "@blockUsername": {}, - "blockedUsers": "Usuàrïis blocadis", - "@blockedUsers": {}, - "blockListDescription": "Pots bloquejar usuàrïis que et molestin. No rebràs missatges seus ni invitacions de part seva a cap sala.", - "@blockListDescription": {}, - "pleaseChooseAStrongPassword": "Tria una contrasenya forta", - "@pleaseChooseAStrongPassword": {}, - "youInvitedToBy": "📩 T'han enviat un enllaç d'invitació per:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "groupName": "Nom del grup", - "@groupName": {}, - "createGroupAndInviteUsers": "Crea un grup i convida-hi usuàrïis", - "@createGroupAndInviteUsers": {}, - "wrongRecoveryKey": "Malauradament, aquesta clau de recuperació no és la correcta.", - "@wrongRecoveryKey": {}, - "publicLink": "Enllaç públic", - "@publicLink": {}, - "transparent": "Transparent", - "@transparent": {}, - "sendReadReceiptsDescription": "Lis altris participants d'un xat poden veure quan has llegit un missatge.", - "@sendReadReceiptsDescription": {}, - "yourGlobalUserIdIs": "La teva ID global és: ", - "@yourGlobalUserIdIs": {}, - "startConversation": "Comença una conversa", - "@startConversation": {}, - "commandHint_sendraw": "Envia un json pelat", - "@commandHint_sendraw": {}, - "databaseMigrationTitle": "La base de dades ha estat optimitzada", - "@databaseMigrationTitle": {}, - "pleaseEnterYourCurrentPassword": "Fica la teva contrasenya actual", - "@pleaseEnterYourCurrentPassword": {}, - "newPassword": "Contrasenya nova", - "@newPassword": {}, - "restoreSessionBody": "L'aplicació provarà de restaurar la teva sessió des de la còpia de seguretat. Si us plau, comunica aquest error a l'equi pde desenvolupament a {url}. El missatge d'error és {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "formattedMessages": "Missatges amb format", - "@formattedMessages": {}, - "formattedMessagesDescription": "Mostra contingut amb format enriquit com text en cursiva, fent servir markdown.", - "@formattedMessagesDescription": {}, - "verifyOtherUser": "🔐 Verifica uni altri usuàrïi", - "@verifyOtherUser": {}, - "verifyOtherDevice": "🔐 Verifica un altre dispositiu", - "@verifyOtherDevice": {}, - "databaseBuildErrorBody": "No s'ha pogut construir la base de dades SQLite. L'aplicació provarà de fer servir un format de base de dades antiquat. Si us plau, comunica aquesta situació a la comunitat de desenvolupament a {url}. El missatge d'error és: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "S'ha produït un error mentre s'inicialitzava l'aplicació", - "@initAppError": {}, - "hidePresences": "Amagar la llista de Status?", - "@hidePresences": {}, - "noUsersFoundWithQuery": "No s'ha trobat cap usuàrïi amb \"{query}\". Revisa si ho has escrit malament.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "leaveEmptyToClearStatus": "Per esborrar el teu estat, deixa-ho en blanc.", - "@leaveEmptyToClearStatus": {}, - "select": "Tria", - "@select": {}, - "searchForUsers": "Cerca @usuariïs...", - "@searchForUsers": {}, - "subspace": "Subespai", - "@subspace": {}, - "addChatOrSubSpace": "Afegeix una sala o un subespai", - "@addChatOrSubSpace": {}, - "decline": "Denega", - "@decline": {}, - "sendReadReceipts": "Envia informes de tecleig", - "@sendReadReceipts": {}, - "sendTypingNotificationsDescription": "Lis altris participants d'un xat poden veure quan estàs teclejant un missatge nou.", - "@sendTypingNotificationsDescription": {}, - "incomingMessages": "Missatge d'entrada", - "@incomingMessages": {}, - "presenceStyle": "Presència:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "acceptedKeyVerification": "{sender} ha acceptat la verificació de claus", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender} ha canceŀlat la verificació de claus", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} ha comletat la verificació de claus", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} està a punt per verificar les claus", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "nothingFound": "No s'ha trobat res...", - "@nothingFound": {}, - "searchChatsRooms": "Cerca #sales, @usuariïs...", - "@searchChatsRooms": {}, - "groupCanBeFoundViaSearch": "El grup es pot trobar per la cerca general", - "@groupCanBeFoundViaSearch": {}, - "databaseMigrationBody": "Espereu un moment, si us plau.", - "@databaseMigrationBody": {}, - "passwordsDoNotMatch": "Les contrasenyes no coincideixen", - "@passwordsDoNotMatch": {}, - "passwordIsWrong": "La contrasenya introduïda és incorrecta", - "@passwordIsWrong": {}, - "joinSpace": "Fica't a l'espai", - "@joinSpace": {}, - "publicSpaces": "Espais públics", - "@publicSpaces": {}, - "thisDevice": "Aquest dispositiu:", - "@thisDevice": {}, - "sessionLostBody": "S'ha perdut la teva sessió. Si us plau, comunica aquest error a l'equip de desenvolupament a {url}. El missatge d'error és: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "forwardMessageTo": "Vols reenviar el missatge a {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "verifyOtherUserDescription": "Si verifiques aquesti usuàrïi, podràs estar seguri de a qui estàs escrivint. . 💪\n\nQuan inicies una verificació, l'altra persona i tu veureu un missatge emergent a l'app. Us sortiran un seguit d'emojis o números a cada pantalla, que haureu de comparar.\n\nLa millor manera de fer-ho és quedar en persona o fer una vídeo-trucada. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "Quan verifiques un altre dispositiu, aquests poden intercanviar claus, així que es millora la seguretat total. 💪 Quan comences una verificació, apareixerà un missatge emergent a tots dos dispositius. A cadascun hi apareixerà un seguit d'emojis o de números que hauràs de comparar. El millor és tenir tots dos dispositius a mà abans d'iniciar la verificació. 🤳", - "@verifyOtherDeviceDescription": {}, - "requestedKeyVerification": "{sender} ha soŀlicitat verificar claus", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} ha iniciat la verificació de claus", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "presencesToggle": "Mostra els missatges d'estat d'altres usuàrïis", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "stickers": "Enganxines", - "@stickers": {}, - "discover": "Descobreix", - "@discover": {}, - "commandHint_ignore": "Ignora el compte de matrix especificat", - "@commandHint_ignore": {}, - "commandHint_unignore": "Deixa d'ignorar el compt de matrix especificat", - "@commandHint_unignore": {} -} diff --git a/assets/l10n/intl_cs.arb b/assets/l10n/intl_cs.arb deleted file mode 100644 index c6a4820c4..000000000 --- a/assets/l10n/intl_cs.arb +++ /dev/null @@ -1,2408 +0,0 @@ -{ - "@@locale": "cs", - "@@last_modified": "2021-08-14 12:41:10.131133", - "about": "O aplikaci", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Přijmout", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} přijal/a pozvání", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Účet", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} aktivoval/a koncové šifrování", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Přidat e-mail", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Správce", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Vše", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Všechny chaty", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} odpověděl na hovor", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Kdokoliv se může připojit", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Zámek aplikace", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Archivovat", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Mohou se připojit hosté", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Jste si jistý?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Opravdu se chcete odhlásit?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Pro ověření této osoby zadejte prosím přístupovou frázi k „bezpečnému úložišti“ anebo „klíč pro obnovu“.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Přijmout žádost o ověření od {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Automaticky přehrajte animované nálepky a emoce", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "Homeserver podporuje přihlášení typu:\n{serverVersions}\nAle tato aplikace podporuje pouze:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "Homeserver podporuje specifikaci verzí:\n{serverVersions}\nAle tato aplikace podporuje pouze verze {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Zakázat chat", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Zakázán", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} zakázal {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blokovat zařízení", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Zakázán", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Zprávy od bota", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Zrušit", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Nelze otevřít URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Změnit název zařízení", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} změnil avatar chatu", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} změnil popis chatu na: „{description}“", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} změnil jméno chatu na: „{chatname}“", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} změnili nastavení oprávnění v chatu", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} změnili svoji přezdívku na: {displayname}", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} změnili přístupová práva pro hosty", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} změnili přístupová práva pro hosty na: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} změnili nastavení viditelnosti historie diskuze", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} změnili nastavení viditelnosti historie diskuze na: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} změnili nastavení pravidel připojení", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} změnili nastavení pravidel připojení na: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} změnili svůj avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} změnili nastavení aliasů místnosti", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} změnili odkaz k pozvání do místnosti", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Změnit heslo", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Změnit domovský server", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Změňte svůj styl", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Změnit název skupiny", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Změňte svůj avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Šifrování bylo poškozeno", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Záloha chatu", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Záloha chatu je zabezpečena bezpečnostním klíčem. Ujistěte se, prosím, že klíč neztratíte.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Bližší údaje o chatu", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Chaty", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Vyberte silné heslo", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Vymazat archiv", - "@clearArchive": {}, - "close": "Zavřít", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Zakázat danému uživateli přístup do této místnosti", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Odeslat text ve formátu HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Pozvěte daného uživatele do této místnosti", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Připojte se k dané místnosti", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Odeberte daného uživatele z této místnosti", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Opusťte tuto místnost", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Představ se", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Nastavte si obrázek pro tuto místnost (autor mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Nastavte si váš zobrazovaný název pro tuto místnost", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Nastavit úroveň práv daného uživatele (výchozí: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Odeslat neformátovaný text", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Odeslat odpověď jako reakci", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Poslat zprávu", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Zrušte zákaz přístupu daného uživatele do této místnosti", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Příkaz je neplatný", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} není příkaz.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Porovnejte a přesvědčete se, že následující emotikony se shodují na obou zařízeních:", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Porovnejte a přesvědčete se, že následující čísla se shodují na obou zařízeních:", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Nastavení chatu", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Potvrdit", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Připojit", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakt byl pozván do skupiny", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Obsahuje zobrazovaný název", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Obsahuje uživatelské jméno", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Obsah byl nahlášen správcům serveru", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Zkopírováno do schránky", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopírovat", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Zkopírovat do schránky", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Nebylo možné dešifrovat zprávu: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} účastníků", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Vytvořit", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} založil/a chat", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Nový prostor", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Aktuálně aktivní", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Tmavé", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}.{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}. {month}. {year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Tímto krokem se deaktivuje váš uživatelský účet. Akci nelze vrátit zpět! Jste si jistí?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Výchozí úroveň oprávnění", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Smazat", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Smazat účet", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Smazat zprávu", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Zařízení", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID zařízení", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Zařízení", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Přímé chatování", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Přezdívka byla změněna", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Stáhnout soubor", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Upravit", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Upravit zakázané servery", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Změnit přezdívku", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Upravit aliasy místností", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Upravit avatara místnosti", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emotikona již existuje!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Neplatný kód emotikony!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Balíček emotikonů pro místnost", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Nastavení emotikonů", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Klávesová zkratka emotikonu", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Musíte si vybrat klávesovou zkratku emotikonu a obrázek!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Prázdný chat", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Povolit balíček emotikon všude", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Povolit šifrování", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Šifrování již nebude možné vypnout. Jste si tím jisti?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Šifrováno", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Šifrování", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Šifrování není aktivní", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} ukončil hovor", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Zadejte e-mailovou adresu", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Zadejte svůj domovský server", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Chyba při získávání polohy: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Vše připraveno!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extrémně urážlivé", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Název souboru", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Velikost písma", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Přeposlat", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Od vstupu", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Od pozvání", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Přejít do nové místnost", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Skupina", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Skupina je veřejná", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Skupiny", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Skupina s {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Hosté jsou zakázáni", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Hosté se mohou připojit", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} stáhl pozvánku pro {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Pomoc", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Skrýt redigované události", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Skrýt neznámé události", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Jak urážlivý je tento obsah?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identita", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorovat", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Ignorovaní uživatelé", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Klikl jsem na odkaz", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Nesprávné přístupové heslo anebo klíč pro obnovu", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Neškodný", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Pozvat kontakt", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Pozvat kontakt do {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Pozvaný", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} pozval/a {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Pouze pozvaní uživatelé", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Pozvěte mě", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} vás pozvali na FluffyChat.\n1. Navštivte fluffychat.im a nainstalujte si aplikaci.\n2. Zaregistrujte se anebo se přihlašte.\n3. Otevřete pozvánku: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "píše…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} se připojil/a k chatu", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Připojte se k místnosti", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} vyhodil/a {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "{username} vyhodili a zakázali {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Vyhodit z chatu", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Naposledy aktivní: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Opustit", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Opustil chat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licence", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Světlé", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Načíst dalších {count} účastníků", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Načítání… Prosíme vyčkejte.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Načíst další…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Služby určování polohy jsou deaktivovány. Povolte jim, aby mohli sdílet vaši polohu.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Oprávnění k poloze odepřeno. Udělte jim prosím možnost sdílet vaši polohu.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Přihlásit se", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Přihlášení k {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Odhlásit", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Změny členů", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Zmínit se", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Zprávy", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderátor", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Ztlumit chat", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Prosím vezměte na vědomí, že pro použití koncového šifrování je prozatím potřeba použít Pantalaimon.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Nový chat", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "Nová zpráva ve FluffyChatu", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nová žádost o ověření!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Další", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Ne", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Žádné připojení k serveru", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Nebyly nalezeny žádné emotikony. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Můžete aktivovat šifrování jakmile místnost přestane být veřejně dostupná.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Zdá se, že v telefonu nemáte žádné služby Google. To je dobré rozhodnutí pro vaše soukromí! Chcete-li dostávat push oznámení ve FluffyChat, doporučujeme použít: https://microg.org/ nebo https://unifiedpush.org/.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} není matrixový server, použít místo toho server {server2}?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "none": "Žádný", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Dosud jste nepřidali způsob, jak obnovit své heslo.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Chybí oprávnění", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Nebyly nalezeny žádné místnosti…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Oznámení", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Oznámení povolena pro tento účet", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} uživatelé píší…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Získávání polohy…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Urážlivé", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Odpojeni", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Připojeni", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Online záloha kíčů je zapnuta", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Jejda! Při nastavování oznámení push došlo bohužel k chybě.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Jejda, něco se pokazilo…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Otevřete aplikaci pro přečtení zpráv", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Otevřít fotoaparát", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Otevřít v mapách", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Nebo", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Účastník", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "heslo nebo klíč pro obnovení", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Heslo", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Zapomenuté heslo", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Heslo bylo změněno", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Obnova hesla", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Lidé", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Zvolit obrázek", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Připnout zprávu", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Přehrát {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Prosím vyberte si", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Vyberte přístupový kód", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Klikněte na odkaz v e-mailu a pokračujte.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Chcete-li deaktivovat zámek aplikace, zadejte 4 číslice nebo nechte prázdné.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Zadejte prosím své heslo", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Zadejte svůj PIN", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Zadejte prosím své uživatelské jméno", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Postupujte podle pokynů na webu a klepněte na další.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Soukromí", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Veřejné místnosti", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Pravidla push", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Důvod", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Nahrávání", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} opravili událost", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Redigovat zprávu", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Registrovat", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Zamítnout", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} odmítli pozvání", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Znovu se připojte", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Odstranit", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Odstranit všechna další zařízení", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Odstraněno {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Odstraňit zařízení", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Zrušit zákaz chatu", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Odstraňte svého avatara", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Zobrazit bohatě vykreslený obsah zpráv", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Nahradit místnost novou verzí", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Odpovědět", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Nahlásit zprávu", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Vyžádat oprávnění", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Místnost byla upgradována", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Verze místnosti", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Uložit soubor", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Hledat", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Bezpečnostní", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Viděno uživatelem {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Odeslat", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Odeslat zprávu", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Odeslat jako text", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Odeslat audio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Odeslat soubor", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Odeslat obrázek", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Odeslat zprávy", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Odeslat originál", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Odeslat nálepku", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Odeslat video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "{username} poslali soubor", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "{username} poslali zvukovou nahrávku", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "{username} poslali obrázek", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "{username} poslali samolepku", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "{username} poslali video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} odeslal informace o hovoru", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Nastavit jako hlavní alias", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Nastavit vlastní emotikony", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Nastavit zvací odkaz", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Nastavit úroveň oprávnění", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Nastavit stav", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Nastavení", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Sdílet", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} sdílel jejich polohu", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Sdílet polohu", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Zobrazit heslo", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Jedinečné přihlášení", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Přeskočit", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Zdrojové kódy", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Prostor je veřejný", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Název prostoru", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} zahájil hovor", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Stav", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Jak se dneska máš?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Odeslat", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Synchronizace ... Čekejte prosím.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Téma systému", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Neshodují se", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Shodují se", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Přepnout Oblíbené", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Přepnout ztlumené", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Označit jako přečtené/nepřečtené", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Příliš mnoho požadavků. Prosím zkuste to znovu později!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Přenos z jiného zařízení", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Zkuste odeslat znovu", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Nedostupní", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} zrušili zákaz pro {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Odblokovat zařízení", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Neznámé zařízení", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Neznámý šifrovací algoritmus", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Neznámá událost „{type}“", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Zrušit ztlumení chatu", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Odepnout zprávu", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 nepřečtený chat} other{{unreadCount} nepřečtené chaty}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} a {count} dalších píší…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} a {username2} píší…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} píše…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "{username} opustili chat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Uživatelské jméno", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} poslali událost {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Ověřeno", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Ověřit", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Zahájit ověření", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Ověření proběhlo úspěšně!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Ověřuji druhý účet", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Video hovor", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Viditelnost historie chatu", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Viditelné pro všechny účastnící se", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Viditelné pro všechny", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Hlasová zpráva", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Čeká se na potvrzení žádosti partnerem…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Čeká se na potvrzení emoji partnerem…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Čekání na partnera až přijme čísla…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Pozadí:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Varování!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Zaslali jsme vám e-mail", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Kdo může provést jakou akci", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Kdo se může připojit do této skupiny", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Proč to chcete nahlásit?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Chcete vymazat zálohu chatu a vytvořit nový bezpečnostní klíč?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "S těmito adresami můžete obnovit své heslo.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Napište zprávu…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Ano", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Vy", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Tohoto chatu se nadále neúčastníte", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Byl vám zablokován přístup k tomuto chatu", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Váš veřejný klíč", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Do tohoto prostoru byl přidán chat", - "@chatHasBeenAddedToThisSpace": {}, - "addToSpace": "Přidat do prostoru", - "@addToSpace": {}, - "scanQrCode": "Naskenujte QR kód", - "@scanQrCode": {}, - "sendOnEnter": "Odeslat při vstupu", - "@sendOnEnter": {}, - "homeserver": "Domácí server", - "@homeserver": {}, - "serverRequiresEmail": "Tento server potřebuje k registraci ověřit vaši e -mailovou adresu.", - "@serverRequiresEmail": {}, - "addToBundle": "Přidat do balíčku", - "@addToBundle": {}, - "addAccount": "Přidat účet", - "@addAccount": {}, - "bundleName": "Název balíčku", - "@bundleName": {}, - "link": "Odkaz", - "@link": {}, - "yourChatBackupHasBeenSetUp": "Vaše záloha chatu byla nastavena.", - "@yourChatBackupHasBeenSetUp": {}, - "editBundlesForAccount": "Upravit balíčky pro tento účet", - "@editBundlesForAccount": {}, - "enableMultiAccounts": "(BETA) Na tomto zařízení povolte více účtů", - "@enableMultiAccounts": {}, - "oneClientLoggedOut": "Jeden z vašich klientů byl odhlášen", - "@oneClientLoggedOut": {}, - "removeFromBundle": "Odstranit z tohoto balíčku", - "@removeFromBundle": {}, - "unverified": "Neověřeno", - "@unverified": {}, - "messageInfo": "Informace o zprávě", - "@messageInfo": {}, - "time": "Čas", - "@time": {}, - "messageType": "Typ zprávy", - "@messageType": {}, - "sender": "Odesílatel", - "@sender": {}, - "repeatPassword": "Zopakujte heslo", - "@repeatPassword": {}, - "openGallery": "Otevřít galerii", - "@openGallery": {}, - "addToSpaceDescription": "Vyberte umístění, do kterého chcete tento chat přidat.", - "@addToSpaceDescription": {}, - "start": "Start", - "@start": {}, - "removeFromSpace": "Odstranit z tohoto místa", - "@removeFromSpace": {}, - "commandHint_clearcache": "Vymazat mezipamět", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_discardsession": "Zahodit relaci", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Zahajte přímý chat\nK deaktivaci šifrování použijte --no-encryption", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_create": "Vytvořte prázdný skupinový chat\n K deaktivaci šifrování použijte --no-encryption", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "openVideoCamera": "Otevřete fotoaparát pro video", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "publish": "Uveřejnit", - "@publish": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "markAsRead": "Označit jako přečtené", - "@markAsRead": {}, - "reportUser": "Nahlásit uživatele", - "@reportUser": {}, - "openChat": "Otevřete chat", - "@openChat": {}, - "dismiss": "Zavrhnout", - "@dismiss": {}, - "reactedWith": "{sender} reagoval s {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "emojis": "Emojis", - "@emojis": {}, - "voiceCall": "Hlasový hovor", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Nepodporovaná verze Androidu", - "@unsupportedAndroidVersion": {}, - "videoCallsBetaWarning": "Upozorňujeme, že videohovory jsou aktuálně ve verzi beta. Nemusí fungovat podle očekávání nebo fungovat vůbec na všech platformách.", - "@videoCallsBetaWarning": {}, - "placeCall": "Zavolejte", - "@placeCall": {}, - "emailOrUsername": "E-mail nebo uživatelské jméno", - "@emailOrUsername": {}, - "experimentalVideoCalls": "Experimentální videohovory", - "@experimentalVideoCalls": {}, - "unsupportedAndroidVersionLong": "Tato funkce vyžaduje novější verzi Android. Zkontrolujte prosím aktualizace nebo podporu Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "pinMessage": "Připnout zprávu do místnosti", - "@pinMessage": {}, - "confirmEventUnpin": "Opravdu chcete událost trvale odepnout?", - "@confirmEventUnpin": {}, - "separateChatTypes": "Odděĺlit přímé chaty, skupiny a prostory", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youKicked": "Vykopli jste uživatele {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "switchToAccount": "Přepnout na účet {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "previousAccount": "Předchozí účet", - "@previousAccount": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "youAcceptedTheInvitation": "Přijal jsi pozvání", - "@youAcceptedTheInvitation": {}, - "youJoinedTheChat": "Připojili jste se k chatu", - "@youJoinedTheChat": {}, - "youInvitedBy": "Byli jste pozváni uživatelem {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "nextAccount": "Další účet", - "@nextAccount": {}, - "addWidget": "Přidat widget", - "@addWidget": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetEtherpad": "Textová poznámka", - "@widgetEtherpad": {}, - "widgetName": "Jméno", - "@widgetName": {}, - "youBannedUser": "Zakázali jste uživatele {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "Pozvali jste uživatele {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "Vykopli jste a zakázali jste uživatele {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Zrušili jste zákaz uživateli {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "widgetCustom": "Vlastní", - "@widgetCustom": {}, - "youRejectedTheInvitation": "Odmítli jste pozvání", - "@youRejectedTheInvitation": {}, - "youHaveWithdrawnTheInvitationFor": "Stáhli jste pozvánku pro uživatele {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "widgetUrlError": "Toto není platná adresa URL.", - "@widgetUrlError": {}, - "widgetNameError": "Zadejte jméno pro zobrazení.", - "@widgetNameError": {}, - "errorAddingWidget": "Chyba při přidávání widgetu.", - "@errorAddingWidget": {}, - "disableEncryptionWarning": "Z bezpečnostních důvodů nemůžete vypnout šifrování v chatu, kde již bylo dříve zapnuto.", - "@disableEncryptionWarning": {}, - "confirmMatrixId": "Prosím, potvrďte vaše Matrix ID, abyste mohli smazat váš účet.", - "@confirmMatrixId": {}, - "commandHint_googly": "Poslat kroutící se očička", - "@commandHint_googly": {}, - "commandHint_cuddle": "Poslat mazlení", - "@commandHint_cuddle": {}, - "commandHint_hug": "Poslat obejmutí", - "@commandHint_hug": {}, - "hugContent": "{senderName} vás objímá", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "googlyEyesContent": "{senderName} vám posílá kroutící se očička", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} se s vámi mazlí", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "notAnImage": "Není obrázek.", - "@notAnImage": {}, - "importNow": "Importovat nyní", - "@importNow": {}, - "redactedByBecause": "Smazáno uživatelem {username} s důvodem: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "storeInAndroidKeystore": "Uložit v Android KeyStore", - "@storeInAndroidKeystore": {}, - "dehydrateTorLong": "Uživatelům TOR se doporučuje exportovat sezení před zavřením okna.", - "@dehydrateTorLong": {}, - "numChats": "{number} konverzací", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "dehydrate": "Exportovat sezení a promazat zařízení", - "@dehydrate": {}, - "newGroup": "Nová skupina", - "@newGroup": {}, - "hydrateTor": "TOR uživatelé: Import exportovaného sezení", - "@hydrateTor": {}, - "doNotShowAgain": "Nezobrazovat znovu", - "@doNotShowAgain": {}, - "commandHint_markasdm": "Označit jako místnost přímé konverzace s daným Matrix ID", - "@commandHint_markasdm": {}, - "recoveryKey": "Klíč k obnovení", - "@recoveryKey": {}, - "hydrateTorLong": "Exportovali jste vaše poslední sezení na TOR? Rychle jej importujte a pokračujte v konverzaci.", - "@hydrateTorLong": {}, - "hydrate": "Obnovit ze záložního souboru", - "@hydrate": {}, - "pleaseEnterRecoveryKey": "Prosím vložte váš klíč pro obnovení:", - "@pleaseEnterRecoveryKey": {}, - "createGroup": "Vytvořit skupinu", - "@createGroup": {}, - "shareInviteLink": "Sdílet pozvánku", - "@shareInviteLink": {}, - "pleaseEnterRecoveryKeyDescription": "K odemknutí vašich starých zpráv prosím vložte váš klíč k obnovení vygenerovaný v předchozím sezení. Váš klíč k obnovení NENÍ vaše heslo.", - "@pleaseEnterRecoveryKeyDescription": {}, - "setColorTheme": "Nastavit barvy:", - "@setColorTheme": {}, - "importEmojis": "Importovat Emoji", - "@importEmojis": {}, - "importFromZipFile": "Importovat ze .zip souboru", - "@importFromZipFile": {}, - "exportEmotePack": "Exportovat Emoji jako .zip", - "@exportEmotePack": {}, - "replace": "Nahradit", - "@replace": {}, - "users": "Uživatelé", - "@users": {}, - "storeInAppleKeyChain": "Uložit v Apple KeyChain", - "@storeInAppleKeyChain": {}, - "jumpToLastReadMessage": "Skočit na naposledy přečtenou zprávu", - "@jumpToLastReadMessage": {}, - "signInWithPassword": "Přihlásit se pomocí hesla", - "@signInWithPassword": {}, - "redactedBy": "Smazáno uživatelem {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "inviteContactToGroupQuestion": "Chcete pozvat {contact} do konverzace \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "dehydrateTor": "TOR uživatelé: Export sezení", - "@dehydrateTor": {}, - "tryAgain": "Zkuste to znovu", - "@tryAgain": {}, - "redactMessageDescription": "Tato zpráva bude smazána pro všechny účastníky konverzace. Tuto akci nelze vzít zpět.", - "@redactMessageDescription": {}, - "optionalRedactReason": "(Nepovinné) Důvod smazání této zprávy…", - "@optionalRedactReason": {}, - "messagesStyle": "Zprávy:", - "@messagesStyle": {}, - "allSpaces": "Všechny prostory", - "@allSpaces": {}, - "noOtherDevicesFound": "Žádná ostatní zařízení nebyla nalezena", - "@noOtherDevicesFound": {}, - "addChatDescription": "Přidejte popis konverzace", - "@addChatDescription": {}, - "chatDescription": "Popis konverzace", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Popis konverzace byl změněn", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "Zatím nebyl vytvořen žádný popis konverzace.", - "@noChatDescriptionYet": {}, - "invalidServerName": "Neplatné jméno serveru", - "@invalidServerName": {}, - "chatPermissions": "Oprávnění konverzace", - "@chatPermissions": {}, - "directChat": "Přímá konverzace", - "@directChat": {}, - "setChatDescription": "Nastavit popis konverzace", - "@setChatDescription": {}, - "startFirstChat": "Začněte svou první konverzaci", - "@startFirstChat": {}, - "callingPermissions": "Oprávnění volání", - "@callingPermissions": {}, - "whyIsThisMessageEncrypted": "Proč nelze přečíst tuto zprávu?", - "@whyIsThisMessageEncrypted": {}, - "wasDirectChatDisplayName": "Prázdná konverzace (dříve {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "newSpaceDescription": "Prostory umožňují organizovat vaše konverzace a vytvářet soukromé nebo veřejné komunity", - "@newSpaceDescription": {}, - "profileNotFound": "Uživatel nebyl na serveru nalezen. Možná je problém s připojením nebo uživatel neexistuje.", - "@profileNotFound": {}, - "setTheme": "Nastavit vzhled:", - "@setTheme": {}, - "sendTypingNotifications": "Posílat oznámení o psaní", - "@sendTypingNotifications": {}, - "commandHint_markasgroup": "Označit jako skupinu", - "@commandHint_markasgroup": {}, - "allRooms": "Všechny skupinové konverzace", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "recoveryKeyLost": "Ztracený klíč k obnovení?", - "@recoveryKeyLost": {}, - "unlockOldMessages": "Odemknout staré zprávy", - "@unlockOldMessages": {}, - "foregroundServiceRunning": "Toto oznámení se zobrazuje když běží služba na pozadí.", - "@foregroundServiceRunning": {}, - "screenSharingDetail": "Sdílíte svou obrazovku přes FluffyChat", - "@screenSharingDetail": {}, - "callingAccountDetails": "Opravňuje FluffyChat používat Android systémovou aplikaci pro vytáčení.", - "@callingAccountDetails": {}, - "appearOnTop": "Zobrazovat nahoře", - "@appearOnTop": {}, - "otherCallingPermissions": "Mikrofon, kamera a ostatní oprávnění FluffyChat", - "@otherCallingPermissions": {}, - "encryptThisChat": "Zašifrovat tuto konverzaci", - "@encryptThisChat": {}, - "sorryThatsNotPossible": "Omlouváme se… to není možné", - "@sorryThatsNotPossible": {}, - "deviceKeys": "Klíče zařízení:", - "@deviceKeys": {}, - "reopenChat": "Znovu otevřít konverzaci", - "@reopenChat": {}, - "fileIsTooBigForServer": "Server oznamuje že soubor je příliš velký na odeslání.", - "@fileIsTooBigForServer": {}, - "jump": "Skočit", - "@jump": {}, - "openLinkInBrowser": "Otevřít odkaz v prohlížeči", - "@openLinkInBrowser": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Prosím zkuste to znovu nebo si vyberte jiný server.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "Přihlásit se pomocí {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "supposedMxid": "Tady by mělo být {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "newSpace": "Nový prostor", - "@newSpace": {}, - "screenSharingTitle": "sdílení obrazovky", - "@screenSharingTitle": {}, - "user": "Uživatel", - "@user": {}, - "fileHasBeenSavedAt": "Soubor uložen do {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "custom": "Vlastní", - "@custom": {}, - "dehydrateWarning": "Tuto akci nelze vzít zpět. Ujistěte se že záložní soubor máte bezpečně uložen.", - "@dehydrateWarning": {}, - "storeInSecureStorageDescription": "Klíč k obnovení uložte v zabezpečeném úložišti tohoto zařízení.", - "@storeInSecureStorageDescription": {}, - "saveKeyManuallyDescription": "Uložte tento klíč manuálně pomocí systémového dialogu sdílení nebo zkopírováním do schránky.", - "@saveKeyManuallyDescription": {}, - "storeSecurlyOnThisDevice": "Uložit bezpečně na tomto zařízení", - "@storeSecurlyOnThisDevice": {}, - "countFiles": "{count} souborů", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@reportErrorDescription": {}, - "@banUserDescription": {}, - "@removeDevicesDescription": {}, - "@unbanUserDescription": {}, - "@pushNotificationsNotAvailable": {}, - "@makeAdminDescription": {}, - "@archiveRoomDescription": {}, - "@invalidInput": {}, - "@report": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@inviteGroupChat": {}, - "@invitePrivateChat": {}, - "@learnMore": {}, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "emoteKeyboardNoRecents": "Naposledy použité emoce se zobrazí zde...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@kickUserDescription": {}, - "@invite": {}, - "@indexedDbErrorLong": {}, - "@callingAccount": {}, - "@enterSpace": {}, - "@noKeyForThisMessage": {}, - "@readUpToHere": {}, - "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@hideUnimportantStateEvents": {}, - "@noBackupWarning": {}, - "@indexedDbErrorTitle": {}, - "appLockDescription": "Zamknout aplikaci pomocí PIN kódu když není používána", - "@appLockDescription": {}, - "globalChatId": "Globální ID chatu", - "@globalChatId": {}, - "accessAndVisibility": "Přístup a viditelnost", - "@accessAndVisibility": {}, - "calls": "Volání", - "@calls": {}, - "customEmojisAndStickers": "Vlastní emoji a nálepky", - "@customEmojisAndStickers": {}, - "accessAndVisibilityDescription": "Kdo se může připojit a najít tuto konverzaci.", - "@accessAndVisibilityDescription": {}, - "customEmojisAndStickersBody": "Přidat nebo sdílet vlastní emoji nebo nálepky, které mohou být použité v konverzaci.", - "@customEmojisAndStickersBody": {} -} diff --git a/assets/l10n/intl_de.arb b/assets/l10n/intl_de.arb deleted file mode 100644 index adf2d99d0..000000000 --- a/assets/l10n/intl_de.arb +++ /dev/null @@ -1,2710 +0,0 @@ -{ - "@@locale": "de", - "@@last_modified": "2021-08-14 12:41:10.119255", - "about": "Über", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Annehmen", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} hat die Einladung angenommen", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Konto", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} hat Ende-zu-Ende Verschlüsselung aktiviert", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "E-Mail hinzufügen", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "Alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Alle", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Alle Chats", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} hat den Anruf angenommen", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Jeder darf beitreten", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Anwendungssperre", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Archiv", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Dürfen Gäste beitreten", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Bist du sicher?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Willst du dich wirklich abmelden?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Bitte gib, um die andere Person signieren zu können, dein Sicherheitsschlüssel oder Wiederherstellungsschlüssel ein.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Diese Bestätigungsanfrage von {username} annehmen?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerLoginTypesException": "Der Homeserver unterstützt diese Anmelde-Typen:\n{serverVersions}\nAber diese App unterstützt nur:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "Der Homeserver unterstützt die Spec-Versionen:\n{serverVersions}\nAber diese App unterstützt nur:\n{supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Aus dem Chat verbannen", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Verbannt", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} hat {targetName} verbannt", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blockiere Gerät", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Blockiert", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bot-Nachrichten", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Abbrechen", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Die URI {uri} kann nicht geöffnet werden", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Gerätenamen ändern", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} hat den Chat-Avatar geändert", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} hat die Chat-Beschreibung geändert zu: „{description}“", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} hat den Chat-Namen geändert zu: „{chatname}“", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} hat die Chat-Berechtigungen geändert", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} hat den Nicknamen geändert zu: „{displayname}“", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} hat die Zugangsregeln für Gäste geändert", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} hat die Zugangsregeln für Gäste geändert zu: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} hat die Sichtbarkeit des Chat-Verlaufs geändert", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} hat die Sichtbarkeit des Chat-Verlaufs geändert zu: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} hat die Zugangsregeln geändert", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} hat die Zugangsregeln geändert zu: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} hat das Profilbild geändert", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} hat die Raum-Aliasse geändert", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} hat den Einladungslink geändert", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Passwort ändern", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Anderen Homeserver verwenden", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Ändere Deinen Style", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Gruppenname ändern", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Deinen Avatar ändern", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Die Verschlüsselung wurde korrumpiert", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Chat-Backup", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Deine alten Nachrichten sind mit einem Wiederherstellungsschlüssel gesichert. Bitte stellen sicher, dass du ihn nicht verlierst.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Chatdetails", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Chats", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Wähle ein sicheres Passwort", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Archiv leeren", - "@clearArchive": {}, - "close": "Schließen", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Banne ausgewählten Benutzer aus diesen Raum", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Sende HTML-formatierten Text", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Lade den Benutzer in diesen Raum ein", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Betrete den ausgewählten Raum", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Entferne den übergebenen Benutzer aus diesem Raum", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Diesen Raum verlassen", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Beschreibe dich selbst", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Setze dein Profilbild nur für diesen Raum (MXC-Uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Setze deinen Anzeigenamen nur für diesen Raum", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Setze den übergeben Powerlevel des Benutzers (Standard: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Sende unformatierten Text", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Sende die Antwort als Reaction", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Text senden", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Hebe die Verbannung dieses Benutzers in diesem Raum auf", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Befehl ungültig", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} ist kein Befehl.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Bitte vergleiche die Emojis", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Bitte vergleiche die Zahlen", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Chat konfigurieren", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Bestätigen", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Verbinden", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakt wurde in die Gruppe eingeladen", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Enthält Anzeigenamen", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Enthält Benutzernamen", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Der Inhalt wurde den Serveradministratoren gemeldet", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Wurde in die Zwischenablage kopiert", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopieren", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "In Zwischenablage kopieren", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Nachricht konnte nicht entschlüsselt werden: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} Mitglieder", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Erstellen", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} hat den Chat erstellt", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Neuer Space", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Jetzt gerade online", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Dunkel", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}.{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}.{month}.{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Dies deaktiviert dein Konto. Es kann nicht rückgängig gemacht werden! Bist du sicher?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Standardberechtigungsstufe", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Löschen", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Konto löschen", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Nachricht löschen", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Gerät", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Geräte-ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Geräte", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Direkte Chats", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Anzeigename wurde geändert", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Datei herunterladen", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Bearbeiten", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Blockierte Server einstellen", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Anzeigename ändern", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Raum-Aliase bearbeiten", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Raumavatar bearbeiten", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emoticon existiert bereits!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Ungültiges Emoticon-Kürzel!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Emoticon-Bündel für Raum", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emoticon-Einstellungen", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Emoticon-Kürzel", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Wähle ein Emoticon-Kürzel und ein Bild!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Leerer Chat", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Aktiviere Emoticon-Bündel global", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Verschlüsselung anschalten", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Du wirst die Verschlüsselung nicht mehr ausstellen können. Bist Du sicher?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Verschlüsselt", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Verschlüsselung", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Verschlüsselung ist nicht aktiviert", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} hat den Anruf beendet", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Gib eine E-Mail-Adresse ein", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Gib Deinen Homeserver ein", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Fehler beim Suchen des Standortes: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Alles fertig!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extrem beleidigend", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Dateiname", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Schriftgröße", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Weiterleiten", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Ab dem Beitritt", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Ab der Einladung", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Zum neuen Raum wechseln", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Gruppe", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Öffentliche Gruppe", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Gruppen", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Gruppe mit {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Gäste sind verboten", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Gäste dürfen beitreten", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} hat die Einladung für {targetName} zurückgezogen", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Hilfe", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Gelöschte Nachrichten ausblenden", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Unbekannte Ereignisse ausblenden", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Wie beleidigend ist dieser Inhalt?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identität", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorieren", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Ignorierte Personen", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Ich habe den Link angeklickt", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Falsches Passwort oder Wiederherstellungsschlüssel", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Harmlos", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Kontakt einladen", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Kontakt in die Gruppe {groupName} einladen", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Eingeladen", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} hat {targetName} eingeladen", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Nur eingeladene Mitglieder", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Einladung für mich", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} hat Dich zu FluffyChat eingeladen. \n1. Gehe auf fluffychat.im und installiere die App \n2. Melde Dich in der App an \n3. Öffne den Einladungslink: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "schreibt …", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} ist dem Chat beigetreten", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Raum beitreten", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} hat {targetName} hinausgeworfen", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} hat {targetName} hinausgeworfen und verbannt", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Aus dem Chat hinauswerfen", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Zuletzt aktiv: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Verlassen", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Hat den Chat verlassen", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Lizenz", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Hell", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "{count} weitere Mitglieder laden", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Lade … Bitte warten.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Mehr laden …", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Standort ist deaktiviert. Bitte aktivieren, um den Standort teilen zu können.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Standort-Berechtigung wurde abgelehnt. Bitte akzeptieren, um den Standort teilen zu können.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Anmelden", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Bei {homeserver} anmelden", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Abmelden", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Änderungen der Mitglieder", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Erwähnen", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Nachrichten", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Stummschalten", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Bitte beachte, dass du Pantalaimon brauchst, um Ende-zu-Ende-Verschlüsselung benutzen zu können.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Neuer Chat", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Neue Nachricht in FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Neue Verifikationsanfrage!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Weiter", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Nein", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Keine Verbindung zum Server", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Keine Emoticons gefunden. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Du kannst die Verschlüsselung erst aktivieren, sobald dieser Raum nicht mehr öffentlich zugänglich ist.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Firebase Cloud Messaging scheint auf deinem Gerät nicht verfügbar zu sein. Um trotzdem Push-Benachrichtigungen zu erhalten, empfehlen wir die Installation von ntfy. Mit ntfy oder einem anderen Unified Push Anbieter kannst du Push-Benachrichtigungen datensicher empfangen. Du kannst ntfy im PlayStore oder bei F-Droid herunterladen.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Keiner", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Du hast bisher keine Möglichkeit hinzugefügt, um dein Passwort zurückzusetzen.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Keine Berechtigung", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Keine Räume gefunden …", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Benachrichtigungen", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Benachrichtigungen für dieses Konto aktiviert", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} Mitglieder schreiben …", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Standort wird ermittelt …", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Beleidigend", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Offline", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Online", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Online-Schlüsselsicherung ist aktiviert", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Hoppla! Leider ist beim Einrichten der Push-Benachrichtigungen ein Fehler aufgetreten.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Hoppla, da ist etwas schiefgelaufen…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "App öffnen, um Nachrichten zu lesen", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Kamera öffnen", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "In Maps öffnen", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Oder", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Mitglieder", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "Passwort oder Wiederherstellungsschlüssel", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Passwort", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Passwort vergessen", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Passwort wurde geändert", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Passwort wiederherstellen", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Personen", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Bild wählen", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Anpinnen", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "{fileName} abspielen", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Bitte wählen", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Bitte einen Code festlegen", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Bitte auf den Link in der E-Mail klicken und dann fortfahren.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Bitte 4 Ziffern eingeben oder leer lassen, um die Anwendungssperre zu deaktivieren.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Bitte dein Passwort eingeben", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Bitte gib deine Pin ein", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Bitte deinen Benutzernamen eingeben", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Bitte folge den Anweisungen auf der Website und tippe auf Weiter.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privatsphäre", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Öffentliche Räume", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Push-Regeln", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Grund", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Aufnahme", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} hat ein Ereignis gelöscht", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Nachricht löschen", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Registrieren", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Ablehnen", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} hat die Einladung abgelehnt", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Wieder beitreten", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Entfernen", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Alle anderen Geräte entfernen", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Entfernt von {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Gerät entfernen", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Verbannung aufheben", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Deinen Avatar löschen", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Zeige Nachrichtenformatierungen an", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Raum mit neuer Version ersetzen", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Antworten", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Nachricht melden", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Berechtigung anfragen", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Der Raum wurde ge-upgraded", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Raumversion", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Datei speichern", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Suchen", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Sicherheit", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Gelesen von {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Senden", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Nachricht schreiben", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Sende als Text", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Sende Audiodatei", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Datei senden", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Bild senden", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Nachrichten senden", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Sende Original", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Sticker senden", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Sende Video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} hat eine Datei gesendet", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} hat eine Audio-Datei gesendet", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} hat ein Bild gesendet", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} hat einen Sticker gesendet", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} hat ein Video gesendet", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} hat Anrufinformationen geschickt", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Als Haupt-Alias festlegen", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Eigene Emoticons einstellen", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Einladungslink festlegen", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Berechtigungsstufe einstellen", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Status ändern", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Einstellungen", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Teilen", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} hat den Standort geteilt", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Standort teilen", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Passwort anzeigen", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Einmalige Anmeldung", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Überspringe", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Quellcode", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Space ist öffentlich", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Space-Name", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} hat einen Anruf getätigt", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Wie geht es dir heute?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Absenden", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Synchronisiere... Bitte warten.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "System", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Stimmen nicht überein", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Stimmen überein", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Favorite umschalten", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Stummgeschaltete umschalten", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Markieren als gelesen/ungelesen", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Zu viele Anfragen. Bitte versuche es später noch einmal!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Von anderem Gerät übertragen", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Nochmal versuchen zu senden", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Nicht verfügbar", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} hat die Verbannung von {targetName} aufgehoben", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Geräteblockierung aufheben", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Unbekanntes Gerät", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Unbekannter Verschlüsselungsalgorithmus", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Unbekanntes Ereignis '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Stumm aus", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Abpinnen", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 ungelesene Unterhaltung} other{{unreadCount} ungelesene Unterhaltungen}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} und {count} andere schreiben …", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} und {username2} schreiben …", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} schreibt …", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} hat den Chat verlassen", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Benutzername", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} hat ein {type}-Ereignis gesendet", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Verifiziert", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verifizieren", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Starte Verifikation", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Erfolgreich verifiziert!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Anderes Konto wird verifiziert", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videoanruf", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Sichtbarkeit des Chat-Verlaufs", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Sichtbar für alle Mitglieder", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Für jeden sichtbar", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Sprachnachricht", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Warte darauf, dass der Partner die Anfrage annimmt …", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Warte darauf, dass der Partner die Emoji annimmt …", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Warten, dass der Partner die Zahlen annimmt …", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Hintergrund:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Achtung!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Wir haben dir eine E-Mail gesendet", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Wer kann welche Aktion ausführen", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Wer darf der Gruppe beitreten", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Warum willst du dies melden?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Den Chat-Backup löschen, um einen neuen Wiederherstellungsschlüssel zu erstellen?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Mit diesen Adressen kannst du dein Passwort wiederherstellen, wenn du es vergessen hast.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Schreibe eine Nachricht …", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Ja", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Du", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Du bist kein Mitglied mehr in diesem Chat", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Du wurdest aus dem Chat verbannt", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Dein öffentlicher Schlüssel", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} ist kein Matrix-Server, stattdessen {server2} benutzen?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "scanQrCode": "QR-Code scannen", - "@scanQrCode": {}, - "chatHasBeenAddedToThisSpace": "Chat wurde zum Space hinzugefügt", - "@chatHasBeenAddedToThisSpace": {}, - "autoplayImages": "Animierte Sticker und Emotes automatisch abspielen", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "addToSpace": "Zum Space hinzufügen", - "@addToSpace": {}, - "serverRequiresEmail": "Dieser Server muss deine E-Mail-Adresse für die Registrierung überprüfen.", - "@serverRequiresEmail": {}, - "enableMultiAccounts": "(BETA) Aktiviere Multi-Accounts für dieses Gerät", - "@enableMultiAccounts": {}, - "bundleName": "Name des Bundles", - "@bundleName": {}, - "removeFromBundle": "Von diesem Bundle entfernen", - "@removeFromBundle": {}, - "addToBundle": "Zu einem Bundle hinzufügen", - "@addToBundle": {}, - "editBundlesForAccount": "Bundles für dieses Konto bearbeiten", - "@editBundlesForAccount": {}, - "addAccount": "Konto hinzufügen", - "@addAccount": {}, - "oneClientLoggedOut": "Einer deiner Clients wurde abgemeldet", - "@oneClientLoggedOut": {}, - "homeserver": "Homeserver", - "@homeserver": {}, - "sendOnEnter": "Senden mit Enter", - "@sendOnEnter": {}, - "link": "Link", - "@link": {}, - "yourChatBackupHasBeenSetUp": "Dein Chat-Backup wurde eingerichtet.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "Unverifiziert", - "@unverified": {}, - "messageInfo": "Nachrichten-Info", - "@messageInfo": {}, - "time": "Zeit", - "@time": {}, - "messageType": "Nachrichtentyp", - "@messageType": {}, - "sender": "Absender:in", - "@sender": {}, - "openGallery": "Galerie öffnen", - "@openGallery": {}, - "removeFromSpace": "Aus dem Space entfernen", - "@removeFromSpace": {}, - "addToSpaceDescription": "Wähle einen Space aus, um diesen Chat hinzuzufügen.", - "@addToSpaceDescription": {}, - "start": "Start", - "@start": {}, - "repeatPassword": "Passwort wiederholen", - "@repeatPassword": {}, - "commandHint_dm": "Starte einen direkten Chat\nBenutze --no-encryption um die Verschlüsselung auszuschalten", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_discardsession": "Sitzung verwerfen", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_clearcache": "Zwischenspeicher löschen", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Erstelle ein leeren Gruppenchat\nBenutze --no-encryption um die Verschlüsselung auszuschalten", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "openVideoCamera": "Video aufnehmen", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "publish": "Veröffentlichen", - "@publish": {}, - "pinMessage": "An Raum anheften", - "@pinMessage": {}, - "emojis": "Emojis", - "@emojis": {}, - "placeCall": "Anruf tätigen", - "@placeCall": {}, - "voiceCall": "Sprachanruf", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Nicht unterstützte Android-Version", - "@unsupportedAndroidVersion": {}, - "videoCallsBetaWarning": "Bitte beachte, dass sich Videoanrufe derzeit in der Beta-Phase befinden. Sie funktionieren möglicherweise nicht wie erwartet oder überhaupt nicht auf allen Plattformen.", - "@videoCallsBetaWarning": {}, - "emailOrUsername": "E-Mail oder Benutzername", - "@emailOrUsername": {}, - "unsupportedAndroidVersionLong": "Diese Funktion erfordert eine neuere Android-Version. Bitte suche nach Updates oder Lineage OS-Unterstützung.", - "@unsupportedAndroidVersionLong": {}, - "experimentalVideoCalls": "Experimentelle Videoanrufe", - "@experimentalVideoCalls": {}, - "reactedWith": "{sender} reagierte mit {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "markAsRead": "Als gelesen markiert", - "@markAsRead": {}, - "reportUser": "Benutzer melden", - "@reportUser": {}, - "openChat": "Chat öffnen", - "@openChat": {}, - "confirmEventUnpin": "Möchtest du das Ereignis wirklich dauerhaft lösen?", - "@confirmEventUnpin": {}, - "dismiss": "Verwerfen", - "@dismiss": {}, - "switchToAccount": "Zu Konto {number} wechseln", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Nächstes Konto", - "@nextAccount": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Angepasst", - "@widgetCustom": {}, - "widgetEtherpad": "Textnotiz", - "@widgetEtherpad": {}, - "addWidget": "Widget hinzufügen", - "@addWidget": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetName": "Name", - "@widgetName": {}, - "widgetUrlError": "Das ist keine gültige URL.", - "@widgetUrlError": {}, - "errorAddingWidget": "Fehler beim Hinzufügen des Widgets.", - "@errorAddingWidget": {}, - "previousAccount": "Vorheriges Konto", - "@previousAccount": {}, - "separateChatTypes": "Separate Direktchats und Gruppen", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "widgetNameError": "Bitte gib einen Anzeigenamen an.", - "@widgetNameError": {}, - "youKicked": "👞 Du hast {user} rausgeworfen", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Du hast {user} rausgeworfen und verbannt", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Du hast die Verbannung von {user} rückgängig gemacht", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "youRejectedTheInvitation": "Du hast die Einladung abgelehnt", - "@youRejectedTheInvitation": {}, - "youJoinedTheChat": "Du bist dem Chat beigetreten", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Du hast die Einladung angenommen", - "@youAcceptedTheInvitation": {}, - "youBannedUser": "Du hast den {user} verbannt", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Du hast die Einladung für {user} zurückgezogen", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 Du wurdest von {user} eingeladen", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Du hast {user} eingeladen", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "recoveryKey": "Wiederherstellungs-Schlüssel", - "@recoveryKey": {}, - "recoveryKeyLost": "Wiederherstellungsschlüssel verloren?", - "@recoveryKeyLost": {}, - "user": "Benutzer", - "@user": {}, - "custom": "Benutzerdefiniert", - "@custom": {}, - "storeInAndroidKeystore": "Im Android KeyStore speichern", - "@storeInAndroidKeystore": {}, - "storeSecurlyOnThisDevice": "Auf diesem Gerät sicher speichern", - "@storeSecurlyOnThisDevice": {}, - "dehydrate": "Sitzung exportieren und Gerät löschen", - "@dehydrate": {}, - "dehydrateWarning": "Diese Aktion kann nicht rückgängig gemacht werden. Stelle sicher, dass du die Sicherungsdatei sicher aufbewahrst.", - "@dehydrateWarning": {}, - "dehydrateTor": "TOR-Benutzer: Sitzung exportieren", - "@dehydrateTor": {}, - "dehydrateTorLong": "Für TOR-Benutzer wird empfohlen, die Sitzung zu exportieren, bevor das Fenster geschlossen wird.", - "@dehydrateTorLong": {}, - "hydrateTor": "TOR-Benutzer: Session-Export importieren", - "@hydrateTor": {}, - "hydrate": "Aus Sicherungsdatei wiederherstellen", - "@hydrate": {}, - "indexedDbErrorTitle": "Probleme im Privatmodus", - "@indexedDbErrorTitle": {}, - "unlockOldMessages": "Entsperre alte Nachrichten", - "@unlockOldMessages": {}, - "pleaseEnterRecoveryKeyDescription": "Um deine alten Nachrichten zu entsperren, gib bitte den Wiederherstellungsschlüssel ein, der in einer früheren Sitzung generiert wurde. Dein Wiederherstellungsschlüssel ist NICHT dein Passwort.", - "@pleaseEnterRecoveryKeyDescription": {}, - "saveKeyManuallyDescription": "Speicher diesen Schlüssel manuell, indem du den Systemfreigabedialog oder die Zwischenablage auslöst.", - "@saveKeyManuallyDescription": {}, - "hydrateTorLong": "Hast du deine Sitzung das letzte Mal auf TOR exportiert? Importiere sie schnell und chatte weiter.", - "@hydrateTorLong": {}, - "pleaseEnterRecoveryKey": "Bitte gebe deinen Wiederherstellungsschlüssel ein:", - "@pleaseEnterRecoveryKey": {}, - "countFiles": "{count} Dateien", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "users": "Benutzer", - "@users": {}, - "storeInSecureStorageDescription": "Speicher den Wiederherstellungsschlüssel im sicheren Speicher dieses Geräts.", - "@storeInSecureStorageDescription": {}, - "storeInAppleKeyChain": "Im Apple KeyChain speichern", - "@storeInAppleKeyChain": {}, - "indexedDbErrorLong": "Die Nachrichtenspeicherung ist im privaten Modus standardmäßig leider nicht aktiviert.\nBitte besuche\n- about:config\n- Setze dom.indexedDB.privateBrowsing.enabled auf true\nAndernfalls ist es nicht möglich, FluffyChat auszuführen.", - "@indexedDbErrorLong": {}, - "confirmMatrixId": "Bitte bestätigen deine Matrix-ID, um dein Konto zu löschen.", - "@confirmMatrixId": {}, - "supposedMxid": "das sollte sein {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasdm": "Als Direktnachrichtenraum für die angegebene Matrix-ID markieren", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "Als Gruppe markieren", - "@commandHint_markasgroup": {}, - "hideUnimportantStateEvents": "Blende unwichtige Zustandsereignisse aus", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Nicht mehr anzeigen", - "@doNotShowAgain": {}, - "appearOnTopDetails": "Ermöglicht, dass die App oben angezeigt wird (nicht erforderlich, wenn Sie Fluffychat bereits als Anrufkonto eingerichtet haben)", - "@appearOnTopDetails": {}, - "noKeyForThisMessage": "Dies kann passieren, wenn die Nachricht gesendet wurde, bevor du dich auf diesem Gerät bei deinem Konto angemeldet hast.\n\nEs ist auch möglich, dass der Absender dein Gerät blockiert hat oder etwas mit der Internetverbindung schief gelaufen ist.\n\nKannst du die Nachricht in einer anderen Sitzung lesen? Dann kannst du die Nachricht davon übertragen! Gehe zu den Einstellungen > Geräte und vergewissere dich, dass sich deine Geräte gegenseitig verifiziert haben. Wenn du den Raum das nächste Mal öffnest und beide Sitzungen im Vordergrund sind, werden die Schlüssel automatisch übertragen.\n\nDu möchtest die Schlüssel beim Abmelden oder Gerätewechsel nicht verlieren? Stelle sicher, dass du das Chat-Backup in den Einstellungen aktiviert hast.", - "@noKeyForThisMessage": {}, - "foregroundServiceRunning": "Diese Benachrichtigung wird angezeigt, wenn der Vordergrunddienst ausgeführt wird.", - "@foregroundServiceRunning": {}, - "screenSharingTitle": "Bildschirm teilen", - "@screenSharingTitle": {}, - "callingPermissions": "Anrufberechtigungen", - "@callingPermissions": {}, - "callingAccount": "Anrufkonto", - "@callingAccount": {}, - "callingAccountDetails": "Ermöglicht FluffyChat, die native Android-Dialer-App zu verwenden.", - "@callingAccountDetails": {}, - "appearOnTop": "Oben erscheinen", - "@appearOnTop": {}, - "otherCallingPermissions": "Mikrofon, Kamera und andere FluffyChat-Berechtigungen", - "@otherCallingPermissions": {}, - "whyIsThisMessageEncrypted": "Warum ist diese Nachricht nicht lesbar?", - "@whyIsThisMessageEncrypted": {}, - "newGroup": "Neue Gruppe", - "@newGroup": {}, - "newSpace": "Neuer Space", - "@newSpace": {}, - "enterSpace": "Raum betreten", - "@enterSpace": {}, - "enterRoom": "Raum betreten", - "@enterRoom": {}, - "allSpaces": "Alle Spaces", - "@allSpaces": {}, - "screenSharingDetail": "Du teilst deinen Bildschirm in FuffyChat", - "@screenSharingDetail": {}, - "numChats": "{number} Chats", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "newSpaceDescription": "Mit Spaces kannst du deine Chats zusammenfassen und private oder öffentliche Communities aufbauen.", - "@newSpaceDescription": {}, - "wasDirectChatDisplayName": "Leerer Chat (war {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "encryptThisChat": "Diesen Chat verschlüsseln", - "@encryptThisChat": {}, - "googlyEyesContent": "{senderName} hat dir Googly Eyes gesendet", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "startFirstChat": "Starte deinen ersten Chat", - "@startFirstChat": {}, - "deviceKeys": "Geräteschlüssel:", - "@deviceKeys": {}, - "commandHint_cuddle": "Umarmung senden", - "@commandHint_cuddle": {}, - "commandHint_hug": "Umarmung senden", - "@commandHint_hug": {}, - "cuddleContent": "{senderName} knuddelt dich", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "sorryThatsNotPossible": "Sorry ... das ist nicht möglich", - "@sorryThatsNotPossible": {}, - "hugContent": "{senderName} umarmt dich", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_googly": "Googly Eyes senden", - "@commandHint_googly": {}, - "disableEncryptionWarning": "Aus Sicherheitsgründen können Sie die Verschlüsselung in einem Chat nicht deaktivieren, wo sie zuvor aktiviert wurde.", - "@disableEncryptionWarning": {}, - "reopenChat": "Chat wieder eröffnen", - "@reopenChat": {}, - "fileIsTooBigForServer": "Der Server meldet, dass die Datei zu groß ist für eine Übermittlung ist.", - "@fileIsTooBigForServer": {}, - "noBackupWarning": "Achtung! Ohne Aktivierung des Chat-Backups verlierst du den Zugriff auf deine verschlüsselten Nachrichten. Vor dem Ausloggen wird dringend empfohlen den Chat-Backup zu aktivieren.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "Keine anderen Geräte anwesend", - "@noOtherDevicesFound": {}, - "allRooms": "Alle Gruppenchats", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "fileHasBeenSavedAt": "Datei wurde gespeichert unter {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Zur letzten ungelesenen Nachricht", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Bis hier gelesen", - "@readUpToHere": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Bitte versuche es später noch einmal oder wähle einen anderen Server.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "jump": "Springen", - "@jump": {}, - "openLinkInBrowser": "Link im Browser öffnen", - "@openLinkInBrowser": {}, - "reportErrorDescription": "😭 Oh nein. Etwas ist schief gelaufen. Wenn du möchtest, kannst du den Bug bei den Entwicklern melden.", - "@reportErrorDescription": {}, - "report": "Melden", - "@report": {}, - "signInWithPassword": "Anmelden mit Passwort", - "@signInWithPassword": {}, - "signInWith": "Anmelden mit {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "importNow": "Jetzt importieren", - "@importNow": {}, - "importEmojis": "Emojis importieren", - "@importEmojis": {}, - "importFromZipFile": "Aus ZIP-Datei importieren", - "@importFromZipFile": {}, - "exportEmotePack": "Emote-Paket als ZIP-Datei exportieren", - "@exportEmotePack": {}, - "notAnImage": "Keine Bilddatei.", - "@notAnImage": {}, - "replace": "Ersetzen", - "@replace": {}, - "sendTypingNotifications": "Tippbenachrichtigungen senden", - "@sendTypingNotifications": {}, - "profileNotFound": "Der Benutzer konnte auf dem Server nicht gefunden werden. Vielleicht gibt es ein Verbindungsproblem oder der Benutzer existiert nicht.", - "@profileNotFound": {}, - "createGroup": "Gruppe erstellen", - "@createGroup": {}, - "shareInviteLink": "Einladungslink teilen", - "@shareInviteLink": {}, - "inviteContactToGroupQuestion": "Willst du {contact} zum Chat {groupName} einladen?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "Neuer Versuch", - "@tryAgain": {}, - "redactMessageDescription": "Die Nachricht wird für alle Teilnehmer dieses Gesprächs gelöscht. Dies kann nicht rückgängig gemacht werden.", - "@redactMessageDescription": {}, - "redactedBy": "Gelöscht von {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactedByBecause": "Gelöscht von {username} weil: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "setTheme": "Design festlegen:", - "@setTheme": {}, - "setColorTheme": "Farbdesign einstellen:", - "@setColorTheme": {}, - "invite": "Einladen", - "@invite": {}, - "optionalRedactReason": "(Optional) Grund für die Löschung dieser Nachricht...", - "@optionalRedactReason": {}, - "messagesStyle": "Nachrichten:", - "@messagesStyle": {}, - "chatPermissions": "Chatberechtigungen", - "@chatPermissions": {}, - "chatDescription": "Chatbeschreibung", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Chatbeschreibung geändert", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "Noch keine Chatbeschreibung vorhanden.", - "@noChatDescriptionYet": {}, - "invalidServerName": "Ungültiger Servername", - "@invalidServerName": {}, - "directChat": "Privater Chat", - "@directChat": {}, - "addChatDescription": "Chatbeschreibung hinzufügen ...", - "@addChatDescription": {}, - "setChatDescription": "Chatbeschreibung festlegen", - "@setChatDescription": {}, - "inviteGroupChat": "📨 Einladungen zum Gruppenchat", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Einladungen zum privaten Chat", - "@invitePrivateChat": {}, - "invalidInput": "Ungültige Eingabe!", - "@invalidInput": {}, - "hasKnocked": "🚪 {user} hat angeklopft", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "wrongPinEntered": "Falsche PIN eingegeben! Bitte in {seconds} Sekunden erneut versuchen ...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "pleaseEnterANumber": "Bitte eine Zahl größer 0 eingeben", - "@pleaseEnterANumber": {}, - "emoteKeyboardNoRecents": "Kürzlich verwendete Emotes werden hier angezeigt ...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "banUserDescription": "Der Benutzer wird aus dem Chat gebannt und kann den Chat erst wieder betreten, wenn die Verbannung aufgehoben wird.", - "@banUserDescription": {}, - "removeDevicesDescription": "Du wirst von diesem Gerät abgemeldet und kannst dann dort keine Nachrichten mehr empfangen.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "Der Benutzer kann den Chat dann wieder betreten, wenn er es versucht.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Push-Benachrichtigungen nicht verfügbar", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Sobald du diesen Benutzer zum Administrator gemacht hast, kannst du das möglicherweise nicht mehr rückgängig machen, da er dann über dieselben Berechtigungen wie du verfügt.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Der Chat wird in das Archiv verschoben. Andere Benutzer können sehen, dass du den Chat verlassen hast.", - "@archiveRoomDescription": {}, - "learnMore": "Erfahre mehr", - "@learnMore": {}, - "roomUpgradeDescription": "Der Chat wird dann mit der neuen Raumversion neu erstellt. Alle Teilnehmer werden benachrichtigt, dass sie zum neuen Chat wechseln müssen. Mehr über Raumversionen erfährst du unter https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "kickUserDescription": "Der Benutzer wird aus dem Chat geworfen, aber nicht gebannt. In öffentlichen Chats kann der Benutzer jederzeit wieder beitreten.", - "@kickUserDescription": {}, - "blockListDescription": "Du kannst Benutzer blockieren, die dich stören. Von Benutzern auf deiner persönlichen Blocklierliste kannst du keine Nachrichten oder Raumeinladungen mehr erhalten.", - "@blockListDescription": {}, - "createGroupAndInviteUsers": "Gruppe erstellen und Nutzer einladen", - "@createGroupAndInviteUsers": {}, - "startConversation": "Unterhaltung starten", - "@startConversation": {}, - "blockedUsers": "Blockierte Benutzer", - "@blockedUsers": {}, - "groupCanBeFoundViaSearch": "Gruppe kann über die Suche gefunden werden", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "Leider konnte mit \"{query}\" kein Benutzer gefunden werden. Bitte schau nach, ob dir ein Tippfehler unterlaufen ist.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "block": "Blockieren", - "@block": {}, - "yourGlobalUserIdIs": "Deine globale Benutzer-ID ist: ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "Rohes JSON senden", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Entschuldigung ... das scheint nicht der richtige Wiederherstellungsschlüssel zu sein.", - "@wrongRecoveryKey": {}, - "blockUsername": "Blockiere Benutzername", - "@blockUsername": {}, - "groupName": "Gruppenname", - "@groupName": {}, - "searchChatsRooms": "Suche nach #Chats, @Nutzer ...", - "@searchChatsRooms": {}, - "databaseMigrationTitle": "Datenbank wird optimiert", - "@databaseMigrationTitle": {}, - "databaseMigrationBody": "Bitte warten. Dies kann einen Moment dauern.", - "@databaseMigrationBody": {}, - "thisDevice": "Dieses Gerät:", - "@thisDevice": {}, - "publicSpaces": "Öffentliche Spaces", - "@publicSpaces": {}, - "passwordIsWrong": "Dein eingegebenes Passwort ist falsch", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Bitte dein aktuelles Passwort eingeben", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "Öffentlicher Link", - "@publicLink": {}, - "nothingFound": "Nichts gefunden ...", - "@nothingFound": {}, - "decline": "Ablehnen", - "@decline": {}, - "newPassword": "Neues Passwort", - "@newPassword": {}, - "passwordsDoNotMatch": "Passwörter stimmen nicht überein", - "@passwordsDoNotMatch": {}, - "subspace": "Sub-Space", - "@subspace": {}, - "select": "Auswählen", - "@select": {}, - "pleaseChooseAStrongPassword": "Bitte wähle ein starkes Passwort", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "Chat oder Sub-Space hinzufügen", - "@addChatOrSubSpace": {}, - "leaveEmptyToClearStatus": "Leer lassen, um den Status zu löschen.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Space beitreten", - "@joinSpace": {}, - "searchForUsers": "Suche nach @benutzer ...", - "@searchForUsers": {}, - "initAppError": "Beim Starten der App ist ein Fehler aufgetreten", - "@initAppError": {}, - "databaseBuildErrorBody": "Die SQlite-Datenbank kann nicht erstellt werden. Die App versucht vorerst, die Legacy-Datenbank zu verwenden. Bitte melde diesen Fehler an die Entwickler unter {url}. Die Fehlermeldung lautet: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sessionLostBody": "Die App versucht nun, deine Sitzung aus der Sicherung wiederherzustellen. Bitte melde diesen Fehler an die Entwickler unter {url}. Die Fehlermeldung lautet: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "Die App versucht nun, deine Sitzung aus der Sicherung wiederherzustellen. Bitte melde diesen Fehler an die Entwickler unter {url}. Die Fehlermeldung lautet: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "youInvitedToBy": "📩 Du wurdest per Link eingeladen zu:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "sendReadReceipts": "Lesebestätigungen senden", - "@sendReadReceipts": {}, - "formattedMessages": "Formatierte Nachrichten", - "@formattedMessages": {}, - "forwardMessageTo": "Nachricht weiterleiten an {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendTypingNotificationsDescription": "Andere Teilnehmer in einem Chat können sehen, wenn du eine neue Nachricht tippst.", - "@sendTypingNotificationsDescription": {}, - "formattedMessagesDescription": "Formatierte Nachrichteninhalte wie fettgedruckten Text mit Markdown anzeigen.", - "@formattedMessagesDescription": {}, - "verifyOtherUser": "🔐 Anderen Benutzer verifizieren", - "@verifyOtherUser": {}, - "sendReadReceiptsDescription": "Andere Teilnehmer in einem Chat können sehen, ob du eine Nachricht gelesen hast.", - "@sendReadReceiptsDescription": {}, - "transparent": "Transparent", - "@transparent": {}, - "verifyOtherDevice": "🔐 Anderes Gerät verifizieren", - "@verifyOtherDevice": {}, - "verifyOtherUserDescription": "Wenn du einen anderen Benutzer verifizierst, kannst du sicher sein, dass du weißt, an wen du wirklich schreibst. 💪\n\nWenn du eine Verifizierung startest, wird dir und dem anderen Nutzer ein Popup in der App angezeigt. Dort siehst du dann eine Reihe von Emojis oder Zahlen, die ihr miteinander vergleichen müsst.\n\nDas geht am besten, wenn man sich trifft oder einen Videoanruf startet. 👭", - "@verifyOtherUserDescription": {}, - "acceptedKeyVerification": "{sender} hat die Schlüsselverifikation akzeptiert", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender} hat die Schlüsselverifikation abgebrochen", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} hat die Schlüsselverifikation abgeschlossen", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} ist bereit für die Schlüsselverifikation", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} hat eine Schlüsselverifikation angefragt", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} hat die Schlüsselverifikation gestartet", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "verifyOtherDeviceDescription": "Wenn Sie ein anderes Gerät verifizieren, können diese Geräteschlüssel austauschen, was Ihre Sicherheit insgesamt erhöht. 💪 Wenn Sie eine Verifizierung starten, erscheint ein Pop-up in der App auf beiden Geräten. Dort sehen Sie dann eine Reihe von Emojis oder Zahlen, die Sie miteinander vergleichen müssen. Am besten hältst du beide Geräte bereit, bevor du die Verifizierung startest. 🤳", - "@verifyOtherDeviceDescription": {}, - "presenceStyle": "Statusmeldungen:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Status-Nachrichten anderer Benutzer anzeigen", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "incomingMessages": "Eingehende Nachrichten", - "@incomingMessages": {}, - "commandHint_unignore": "Angegebene Matrix-ID nicht mehr ignorieren", - "@commandHint_unignore": {}, - "commandHint_ignore": "Angegebene Matrix-ID ignorieren", - "@commandHint_ignore": {}, - "noDatabaseEncryption": "Datenbankverschlüsselung wird auf dieser Plattform nicht unterstützt", - "@noDatabaseEncryption": {}, - "hidePresences": "Status-Liste verbergen?", - "@hidePresences": {}, - "stickers": "Sticker", - "@stickers": {}, - "discover": "Entdecken", - "@discover": {}, - "unreadChatsInApp": "{appname}: {unread} ungelesene Chats", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "customEmojisAndStickersBody": "Eigene Emojis oder Sticker zur Nutzung im Chat hinzufügen oder teilen.", - "@customEmojisAndStickersBody": {}, - "globalChatId": "Globale Chat-ID", - "@globalChatId": {}, - "accessAndVisibility": "Zugang und Sichtbarkeit", - "@accessAndVisibility": {}, - "hideMemberChangesInPublicChats": "Mitglieder-Änderungen in öffentlichen Chats ausblenden", - "@hideMemberChangesInPublicChats": {}, - "accessAndVisibilityDescription": "Wer darf dem Chat beitreten und wie kann der Chat gefunden werden.", - "@accessAndVisibilityDescription": {}, - "hideMemberChangesInPublicChatsBody": "Zeige keine Beitritt- oder Verlassen-Ereignisse von Mitgliedern in der Timeline an, um die Lesbarkeit in öffentlichen Chats zu verbessern.", - "@hideMemberChangesInPublicChatsBody": {}, - "userWouldLikeToChangeTheChat": "{user} würde dem Chat gerne beitreten.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "Es wurde noch kein öffentlicher Link erstellt", - "@noPublicLinkHasBeenCreatedYet": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Chat kann über die Suche auf {server} gefunden werden", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "appLockDescription": "App mit einer PIN sperren, wenn sie nicht verwendet wird", - "@appLockDescription": {}, - "calls": "Anrufe", - "@calls": {}, - "customEmojisAndStickers": "Eigene Emojis und Sticker", - "@customEmojisAndStickers": {}, - "hideRedactedMessages": "Geschwärzte Nachrichten verstecken", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "Wenn jemand eine Nachricht schwärzt/löscht, dann wird diese Nachricht im Chat nicht mehr sichtbar sein.", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "Ungültige und unbekannte Nachrichten-Formate ausblenden", - "@hideInvalidOrUnknownMessageFormats": {}, - "overview": "Übersicht", - "@overview": {}, - "notifyMeFor": "Benachrichtige mich für", - "@notifyMeFor": {}, - "passwordRecoverySettings": "Passwort-Wiederherstellungs-Einstellungen", - "@passwordRecoverySettings": {}, - "knock": "Anklopfen", - "@knock": {}, - "knocking": "Klopft", - "@knocking": {}, - "thereAreCountUsersBlocked": "Im Augenblick werden {count} Benutzer blockiert.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "usersMustKnock": "Benutzer müssen anklopfen", - "@usersMustKnock": {}, - "noOneCanJoin": "Niemand kann beitreten", - "@noOneCanJoin": {}, - "createNewAddress": "Neue Adresse erstellen", - "@createNewAddress": {}, - "userRole": "Benutzerrolle", - "@userRole": {}, - "minimumPowerLevel": "{level} is das minimale Power-Level.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "publicChatAddresses": "Öffentliche Chat-Adressen", - "@publicChatAddresses": {}, - "gallery": "Galerie", - "@gallery": {}, - "files": "Dateien", - "@files": {}, - "restricted": "Beschränkt", - "@restricted": {}, - "knockRestricted": "Anklopfen beschränkt", - "@knockRestricted": {}, - "searchIn": "In Chat \"{chat}\" suchen ...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Weiter suchen ...", - "@searchMore": {} -} diff --git a/assets/l10n/intl_en.arb b/assets/l10n/intl_en.arb deleted file mode 100644 index b687dc863..000000000 --- a/assets/l10n/intl_en.arb +++ /dev/null @@ -1,2692 +0,0 @@ -{ - "@@locale": "en", - "@@last_modified": "2021-08-14 12:38:37.885451", - "repeatPassword": "Repeat password", - "@repeatPassword": {}, - "notAnImage": "Not an image file.", - "@notAnImage": {}, - "remove": "Remove", - "@remove": { - "type": "text", - "placeholders": {} - }, - "importNow": "Import now", - "@importNow": {}, - "importEmojis": "Import Emojis", - "@importEmojis": {}, - "importFromZipFile": "Import from .zip file", - "@importFromZipFile": {}, - "exportEmotePack": "Export Emote pack as .zip", - "@exportEmotePack": {}, - "replace": "Replace", - "@replace": {}, - "about": "About", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Accept", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} accepted the invitation", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Account", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} activated end to end encryption", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Add email", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "confirmMatrixId": "Please confirm your Matrix ID in order to delete your account.", - "@confirmMatrixId": {}, - "supposedMxid": "This should be {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "addChatDescription": "Add a chat description...", - "@addChatDescription": {}, - "addToSpace": "Add to space", - "@addToSpace": {}, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "All", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "All chats", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "Send some googly eyes", - "@commandHint_googly": {}, - "commandHint_cuddle": "Send a cuddle", - "@commandHint_cuddle": {}, - "commandHint_hug": "Send a hug", - "@commandHint_hug": {}, - "googlyEyesContent": "{senderName} sends you googly eyes", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} cuddles you", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} hugs you", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "answeredTheCall": "{senderName} answered the call", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Anyone can join", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "App lock", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "appLockDescription": "Lock the app when not using with a pin code", - "@appLockDescription": {}, - "archive": "Archive", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Are guest users allowed to join", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Are you sure?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Are you sure you want to log out?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "To be able to sign the other person, please enter your secure store passphrase or recovery key.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Accept this verification request from {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Automatically play animated stickers and emotes", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "The homeserver supports the login types:\n{serverVersions}\nBut this app supports only:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "sendTypingNotifications": "Send typing notifications", - "@sendTypingNotifications": {}, - "swipeRightToLeftToReply": "Swipe right to left to reply", - "@swipeRightToLeftToReply": {}, - "sendOnEnter": "Send on enter", - "@sendOnEnter": {}, - "badServerVersionsException": "The homeserver supports the Spec versions:\n{serverVersions}\nBut this app supports only {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Ban from chat", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Banned", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} banned {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Block Device", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Blocked", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bot messages", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Cancel", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Can't open the URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Change device name", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} changed the chat avatar", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} changed the chat description to: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} changed the chat name to: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} changed the chat permissions", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} changed their displayname to: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} changed the guest access rules", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} changed the guest access rules to: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} changed the history visibility", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} changed the history visibility to: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} changed the join rules", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} changed the join rules to: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} changed their avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} changed the room aliases", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} changed the invitation link", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Change password", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Change the homeserver", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Change your style", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Change the name of the group", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Change your avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "The encryption has been corrupted", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "Your chat backup has been set up.", - "@yourChatBackupHasBeenSetUp": {}, - "chatBackup": "Chat backup", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Your old messages are secured with a recovery key. Please make sure you don't lose it.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Chat details", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Chat has been added to this space", - "@chatHasBeenAddedToThisSpace": {}, - "chats": "Chats", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Choose a strong password", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Clear archive", - "@clearArchive": {}, - "close": "Close", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_markasdm": "Mark as direct message room for the giving Matrix ID", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "Mark as group", - "@commandHint_markasgroup": {}, - "commandHint_ban": "Ban the given user from this room", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_clearcache": "Clear cache", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Create an empty group chat\nUse --no-encryption to disable encryption", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_discardsession": "Discard session", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Start a direct chat\nUse --no-encryption to disable encryption", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_html": "Send HTML-formatted text", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Invite the given user to this room", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Join the given room", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Remove the given user from this room", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Leave this room", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Describe yourself", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Set your picture for this room (by mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Set your display name for this room", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Set the given user's power level (default: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Send unformatted text", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Send reply as a reaction", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Send text", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Unban the given user from this room", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Command invalid", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} is not a command.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Please compare the emojis", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Please compare the numbers", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Configure chat", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Confirm", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Connect", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Contact has been invited to the group", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Contains display name", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Contains username", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "The content has been reported to the server admins", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Copied to clipboard", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Copy", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Copy to clipboard", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Could not decrypt message: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} participants", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Create", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} created the chat", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createGroup": "Create group", - "@createGroup": {}, - "createNewSpace": "New space", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Currently active", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Dark", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{year}-{month}-{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "This will deactivate your user account. This can not be undone! Are you sure?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Default permission level", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Delete", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Delete account", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Delete message", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Device", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Device ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Devices", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Direct Chats", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "allRooms": "All Group Chats", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Displayname has been changed", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Download file", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Edit", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Edit blocked servers", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "chatPermissions": "Chat permissions", - "@chatPermissions": {}, - "editDisplayname": "Edit displayname", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Edit room aliases", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Edit room avatar", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emote already exists!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Invalid emote shortcode!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteKeyboardNoRecents": "Recently-used emotes will appear here...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Emote packs for room", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emote Settings", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "globalChatId": "Global chat ID", - "@globalChatId": {}, - "accessAndVisibility": "Access and visibility", - "@accessAndVisibility": {}, - "accessAndVisibilityDescription": "Who is allowed to join this chat and how the chat can be discovered.", - "@accessAndVisibilityDescription": {}, - "calls": "Calls", - "@calls": {}, - "customEmojisAndStickers": "Custom emojis and stickers", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Add or share custom emojis or stickers which can be used in any chat.", - "@customEmojisAndStickersBody": {}, - "emoteShortcode": "Emote shortcode", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "You need to pick an emote shortcode and an image!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Empty chat", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Enable emote pack globally", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Enable encryption", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "You won't be able to disable the encryption anymore. Are you sure?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Encrypted", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Encryption", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Encryption is not enabled", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} ended the call", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Enter an email address", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Homeserver", - "@homeserver": {}, - "enterYourHomeserver": "Enter your homeserver", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Error obtaining location: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Everything ready!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extremely offensive", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "File name", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Font size", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Forward", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "From joining", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "From the invitation", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Go to the new room", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Group", - "@group": { - "type": "text", - "placeholders": {} - }, - "chatDescription": "Chat description", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Chat description changed", - "@chatDescriptionHasBeenChanged": {}, - "groupIsPublic": "Group is public", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Groups", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Group with {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Guests are forbidden", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Guests can join", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} has withdrawn the invitation for {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Help", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Hide redacted events", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideRedactedMessages": "Hide redacted messages", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "If someone redacts a message, this message won't be visible in the chat anymore.", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "Hide invalid or unknown message formats", - "@hideInvalidOrUnknownMessageFormats": {}, - "howOffensiveIsThisContent": "How offensive is this content?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identity", - "@identity": { - "type": "text", - "placeholders": {} - }, - "block": "Block", - "@block": {}, - "blockedUsers": "Blocked users", - "@blockedUsers": {}, - "blockListDescription": "You can block users who are disturbing you. You won't be able to receive any messages or room invites from the users on your personal block list.", - "@blockListDescription": {}, - "blockUsername": "Ignore username", - "@blockUsername": {}, - "iHaveClickedOnLink": "I have clicked on the link", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Incorrect passphrase or recovery key", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Inoffensive", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Invite contact", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroupQuestion": "Do you want to invite {contact} to the chat \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "inviteContactToGroup": "Invite contact to {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "noChatDescriptionYet": "No chat description created yet.", - "@noChatDescriptionYet": {}, - "tryAgain": "Try again", - "@tryAgain": {}, - "invalidServerName": "Invalid server name", - "@invalidServerName": {}, - "invited": "Invited", - "@invited": { - "type": "text", - "placeholders": {} - }, - "redactMessageDescription": "The message will be redacted for all participants in this conversation. This cannot be undone.", - "@redactMessageDescription": {}, - "optionalRedactReason": "(Optional) Reason for redacting this message...", - "@optionalRedactReason": {}, - "invitedUser": "📩 {username} invited {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Invited users only", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Invite for me", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} invited you to FluffyChat.\n1. Visit fluffychat.im and install the app \n2. Sign up or sign in \n3. Open the invite link: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "is typing…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} joined the chat", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Join room", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} kicked {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} kicked and banned {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Kick from chat", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Last active: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Leave", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Left the chat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "License", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Light", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Load {count} more participants", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "dehydrate": "Export session and wipe device", - "@dehydrate": {}, - "dehydrateWarning": "This action cannot be undone. Ensure you safely store the backup file.", - "@dehydrateWarning": {}, - "dehydrateTor": "TOR Users: Export session", - "@dehydrateTor": {}, - "dehydrateTorLong": "For TOR users, it is recommended to export the session before closing the window.", - "@dehydrateTorLong": {}, - "hydrateTor": "TOR Users: Import session export", - "@hydrateTor": {}, - "hydrateTorLong": "Did you export your session last time on TOR? Quickly import it and continue chatting.", - "@hydrateTorLong": {}, - "hydrate": "Restore from backup file", - "@hydrate": {}, - "loadingPleaseWait": "Loading… Please wait.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Load more…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Location services are disabled. Please enable them to be able to share your location.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Location permission denied. Please grant them to be able to share your location.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Login", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Log in to {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Logout", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Member changes", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Mention", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Messages", - "@messages": { - "type": "text", - "placeholders": {} - }, - "messagesStyle": "Messages:", - "@messagesStyle": {}, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Mute chat", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Please be aware that you need Pantalaimon to use end-to-end encryption for now.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "New chat", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 New message in FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "New verification request!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Next", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "No", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "No connection to the server", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "No emotes found. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "You can only activate encryption as soon as the room is no longer publicly accessible.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Firebase Cloud Messaging doesn't appear to be available on your device. To still receive push notifications, we recommend installing ntfy. With ntfy or another Unified Push provider you can receive push notifications in a data secure way. You can download ntfy from the PlayStore or from F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} is no matrix server, use {server2} instead?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "shareInviteLink": "Share invite link", - "@shareInviteLink": {}, - "scanQrCode": "Scan QR code", - "@scanQrCode": {}, - "none": "None", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "You have not added a way to recover your password yet.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "No permission", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "No rooms found…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notifications", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Notifications enabled for this account", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} users are typing…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Obtaining location…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Offensive", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Offline", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Online", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Online Key Backup is enabled", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Oops! Unfortunately, an error occurred when setting up the push notifications.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Oops, something went wrong…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Open app to read messages", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Open camera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openVideoCamera": "Open camera for a video", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "One of your clients has been logged out", - "@oneClientLoggedOut": {}, - "addAccount": "Add account", - "@addAccount": {}, - "editBundlesForAccount": "Edit bundles for this account", - "@editBundlesForAccount": {}, - "addToBundle": "Add to bundle", - "@addToBundle": {}, - "removeFromBundle": "Remove from this bundle", - "@removeFromBundle": {}, - "bundleName": "Bundle name", - "@bundleName": {}, - "enableMultiAccounts": "(BETA) Enable multi accounts on this device", - "@enableMultiAccounts": {}, - "openInMaps": "Open in maps", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "link": "Link", - "@link": {}, - "serverRequiresEmail": "This server needs to validate your email address for registration.", - "@serverRequiresEmail": {}, - "or": "Or", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Participant", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "passphrase or recovery key", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Password", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Password forgotten", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Password has been changed", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "hideMemberChangesInPublicChats": "Hide member changes in public chats", - "@hideMemberChangesInPublicChats": {}, - "hideMemberChangesInPublicChatsBody": "Do not show in the chat timeline if someone joins or leaves a public chat to improve readability.", - "@hideMemberChangesInPublicChatsBody": {}, - "overview": "Overview", - "@overview": {}, - "notifyMeFor": "Notify me for", - "@notifyMeFor": {}, - "passwordRecoverySettings": "Password recovery settings", - "@passwordRecoverySettings": {}, - "passwordRecovery": "Password recovery", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "People", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Pick an image", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Pin", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Play {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Please choose", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Please choose a pass code", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Please click on the link in the email and then proceed.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Please enter 4 digits or leave empty to disable app lock.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterRecoveryKey": "Please enter your recovery key:", - "@pleaseEnterRecoveryKey": {}, - "pleaseEnterYourPassword": "Please enter your password", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Please enter your pin", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Please enter your username", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Please follow the instructions on the website and tap on next.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privacy", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Public Rooms", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Push rules", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Reason", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Recording", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedBy": "Redacted by {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "directChat": "Direct chat", - "@directChat": {}, - "redactedByBecause": "Redacted by {username} because: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "redactedAnEvent": "{username} redacted an event", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Redact message", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Register", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Reject", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} rejected the invitation", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Rejoin", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Remove all other devices", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Removed by {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Remove device", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Unban from chat", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Remove your avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Replace room with newer version", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Reply", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Report message", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Request permission", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Room has been upgraded", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Room version", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Save file", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Search", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Security", - "@security": { - "type": "text", - "placeholders": {} - }, - "recoveryKey": "Recovery key", - "@recoveryKey": {}, - "recoveryKeyLost": "Recovery key lost?", - "@recoveryKeyLost": {}, - "seenByUser": "Seen by {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Send", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Send a message", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Send as text", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Send audio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Send file", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Send image", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Send messages", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Send original", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Send sticker", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Send video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} sent a file", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} sent an audio", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} sent a picture", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} sent a sticker", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} sent a video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} sent call information", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "separateChatTypes": "Separate Direct Chats and Groups", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Set as main alias", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Set custom emotes", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setChatDescription": "Set chat description", - "@setChatDescription": {}, - "setInvitationLink": "Set invitation link", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Set permissions level", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Set status", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Settings", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Share", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} shared their location", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Share location", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Show password", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "presenceStyle": "Presence:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Show status messages from other users", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Single Sign on", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Skip", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Source code", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Space is public", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Space name", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} started a call", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "startFirstChat": "Start your first chat", - "@startFirstChat": {}, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "How are you today?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Submit", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Synchronizing… Please wait.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "System", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "They Don't Match", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "They Match", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Toggle Favorite", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Toggle Muted", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Mark Read/Unread", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Too many requests. Please try again later!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Transfer from another device", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Try to send again", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Unavailable", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} unbanned {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Unblock Device", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Unknown device", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Unknown encryption algorithm", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Unknown event '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Unmute chat", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Unpin", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 unread chat} other{{unreadCount} unread chats}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} and {count} others are typing…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} and {username2} are typing…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} is typing…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} left the chat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Username", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} sent a {type} event", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "unverified": "Unverified", - "@unverified": {}, - "verified": "Verified", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verify", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Start Verification", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "You successfully verified!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verifying other account", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Video call", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Visibility of the chat history", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Visible for all participants", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Visible for everyone", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Voice message", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Waiting for partner to accept the request…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Waiting for partner to accept the emoji…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Waiting for partner to accept the numbers…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Wallpaper:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Warning!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "We sent you an email", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Who can perform which action", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Who is allowed to join this group", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Why do you want to report this?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Wipe your chat backup to create a new recovery key?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "With these addresses you can recover your password.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Write a message…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Yes", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "You", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "You are no longer participating in this chat", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "You have been banned from this chat", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Your public key", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "messageInfo": "Message info", - "@messageInfo": {}, - "time": "Time", - "@time": {}, - "messageType": "Message Type", - "@messageType": {}, - "sender": "Sender", - "@sender": {}, - "openGallery": "Open gallery", - "@openGallery": {}, - "removeFromSpace": "Remove from space", - "@removeFromSpace": {}, - "addToSpaceDescription": "Select a space to add this chat to it.", - "@addToSpaceDescription": {}, - "start": "Start", - "@start": {}, - "pleaseEnterRecoveryKeyDescription": "To unlock your old messages, please enter your recovery key that has been generated in a previous session. Your recovery key is NOT your password.", - "@pleaseEnterRecoveryKeyDescription": {}, - "publish": "Publish", - "@publish": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "openChat": "Open Chat", - "@openChat": {}, - "markAsRead": "Mark as read", - "@markAsRead": {}, - "reportUser": "Report user", - "@reportUser": {}, - "dismiss": "Dismiss", - "@dismiss": {}, - "reactedWith": "{sender} reacted with {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "pinMessage": "Pin to room", - "@pinMessage": {}, - "confirmEventUnpin": "Are you sure to permanently unpin the event?", - "@confirmEventUnpin": {}, - "emojis": "Emojis", - "@emojis": {}, - "placeCall": "Place call", - "@placeCall": {}, - "voiceCall": "Voice call", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Unsupported Android version", - "@unsupportedAndroidVersion": {}, - "unsupportedAndroidVersionLong": "This feature requires a newer Android version. Please check for updates or Lineage OS support.", - "@unsupportedAndroidVersionLong": {}, - "videoCallsBetaWarning": "Please note that video calls are currently in beta. They might not work as expected or work at all on all platforms.", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "Experimental video calls", - "@experimentalVideoCalls": {}, - "emailOrUsername": "Email or username", - "@emailOrUsername": {}, - "indexedDbErrorTitle": "Private mode issues", - "@indexedDbErrorTitle": {}, - "indexedDbErrorLong": "The message storage is unfortunately not enabled in private mode by default.\nPlease visit\n - about:config\n - set dom.indexedDB.privateBrowsing.enabled to true\nOtherwise, it is not possible to run FluffyChat.", - "@indexedDbErrorLong": {}, - "switchToAccount": "Switch to account {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Next account", - "@nextAccount": {}, - "previousAccount": "Previous account", - "@previousAccount": {}, - "addWidget": "Add widget", - "@addWidget": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetEtherpad": "Text note", - "@widgetEtherpad": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Custom", - "@widgetCustom": {}, - "widgetName": "Name", - "@widgetName": {}, - "widgetUrlError": "This is not a valid URL.", - "@widgetUrlError": {}, - "widgetNameError": "Please provide a display name.", - "@widgetNameError": {}, - "errorAddingWidget": "Error adding the widget.", - "@errorAddingWidget": {}, - "youRejectedTheInvitation": "You rejected the invitation", - "@youRejectedTheInvitation": {}, - "youJoinedTheChat": "You joined the chat", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 You accepted the invitation", - "@youAcceptedTheInvitation": {}, - "youBannedUser": "You banned {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "You have withdrawn the invitation for {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedToBy": "📩 You have been invited via link to:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "youInvitedBy": "📩 You have been invited by {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 You invited {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 You kicked {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 You kicked and banned {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "You unbanned {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "hasKnocked": "🚪 {user} has knocked", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "usersMustKnock": "Users must knock", - "@usersMustKnock": {}, - "noOneCanJoin": "No one can join", - "@noOneCanJoin": {}, - "userWouldLikeToChangeTheChat": "{user} would like to join the chat.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "No public link has been created yet", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "Knock", - "@knock": {}, - "users": "Users", - "@users": {}, - "unlockOldMessages": "Unlock old messages", - "@unlockOldMessages": {}, - "storeInSecureStorageDescription": "Store the recovery key in the secure storage of this device.", - "@storeInSecureStorageDescription": {}, - "saveKeyManuallyDescription": "Save this key manually by triggering the system share dialog or clipboard.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Store in Android KeyStore", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "Store in Apple KeyChain", - "@storeInAppleKeyChain": {}, - "storeSecurlyOnThisDevice": "Store securely on this device", - "@storeSecurlyOnThisDevice": {}, - "countFiles": "{count} files", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "user": "User", - "@user": {}, - "custom": "Custom", - "@custom": {}, - "foregroundServiceRunning": "This notification appears when the foreground service is running.", - "@foregroundServiceRunning": {}, - "screenSharingTitle": "screen sharing", - "@screenSharingTitle": {}, - "screenSharingDetail": "You are sharing your screen in FuffyChat", - "@screenSharingDetail": {}, - "callingPermissions": "Calling permissions", - "@callingPermissions": {}, - "callingAccount": "Calling account", - "@callingAccount": {}, - "callingAccountDetails": "Allows FluffyChat to use the native android dialer app.", - "@callingAccountDetails": {}, - "appearOnTop": "Appear on top", - "@appearOnTop": {}, - "appearOnTopDetails": "Allows the app to appear on top (not needed if you already have Fluffychat setup as a calling account)", - "@appearOnTopDetails": {}, - "otherCallingPermissions": "Microphone, camera and other FluffyChat permissions", - "@otherCallingPermissions": {}, - "whyIsThisMessageEncrypted": "Why is this message unreadable?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "This can happen if the message was sent before you have signed in to your account at this device.\n\nIt is also possible that the sender has blocked your device or something went wrong with the internet connection.\n\nAre you able to read the message on another session? Then you can transfer the message from it! Go to Settings > Devices and make sure that your devices have verified each other. When you open the room the next time and both sessions are in the foreground, the keys will be transmitted automatically.\n\nDo you not want to lose the keys when logging out or switching devices? Make sure that you have enabled the chat backup in the settings.", - "@noKeyForThisMessage": {}, - "newGroup": "New group", - "@newGroup": {}, - "newSpace": "New space", - "@newSpace": {}, - "enterSpace": "Enter space", - "@enterSpace": {}, - "enterRoom": "Enter room", - "@enterRoom": {}, - "allSpaces": "All spaces", - "@allSpaces": {}, - "numChats": "{number} chats", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Hide unimportant state events", - "@hideUnimportantStateEvents": {}, - "hidePresences": "Hide Status List?", - "@hidePresences": {}, - "doNotShowAgain": "Do not show again", - "@doNotShowAgain": {}, - "wasDirectChatDisplayName": "Empty chat (was {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "newSpaceDescription": "Spaces allows you to consolidate your chats and build private or public communities.", - "@newSpaceDescription": {}, - "encryptThisChat": "Encrypt this chat", - "@encryptThisChat": {}, - "disableEncryptionWarning": "For security reasons you can not disable encryption in a chat, where it has been enabled before.", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "Sorry... that is not possible", - "@sorryThatsNotPossible": {}, - "deviceKeys": "Device keys:", - "@deviceKeys": {}, - "reopenChat": "Reopen chat", - "@reopenChat": {}, - "noBackupWarning": "Warning! Without enabling chat backup, you will lose access to your encrypted messages. It is highly recommended to enable the chat backup first before logging out.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "No other devices found", - "@noOtherDevicesFound": {}, - "fileIsTooBigForServer": "The server reports that the file is too large to be sent.", - "@fileIsTooBigForServer": {}, - "fileHasBeenSavedAt": "File has been saved at {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Jump to last read message", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Read up to here", - "@readUpToHere": {}, - "jump": "Jump", - "@jump": {}, - "openLinkInBrowser": "Open link in browser", - "@openLinkInBrowser": {}, - "reportErrorDescription": "😭 Oh no. Something went wrong. If you want, you can report this bug to the developers.", - "@reportErrorDescription": {}, - "report": "report", - "@report": {}, - "signInWithPassword": "Sign in with password", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Please try again later or choose a different server.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "Sign in with {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "profileNotFound": "The user could not be found on the server. Maybe there is a connection problem or the user doesn't exist.", - "@profileNotFound": {}, - "setTheme": "Set theme:", - "@setTheme": {}, - "setColorTheme": "Set color theme:", - "@setColorTheme": {}, - "invite": "Invite", - "@invite": {}, - "inviteGroupChat": "📨 Invite group chat", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Invite private chat", - "@invitePrivateChat": {}, - "invalidInput": "Invalid input!", - "@invalidInput": {}, - "wrongPinEntered": "Wrong pin entered! Try again in {seconds} seconds...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "pleaseEnterANumber": "Please enter a number greater than 0", - "@pleaseEnterANumber": {}, - "archiveRoomDescription": "The chat will be moved to the archive. Other users will be able to see that you have left the chat.", - "@archiveRoomDescription": {}, - "roomUpgradeDescription": "The chat will then be recreated with the new room version. All participants will be notified that they need to switch to the new chat. You can find out more about room versions at https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "removeDevicesDescription": "You will be logged out of this device and will no longer be able to receive messages.", - "@removeDevicesDescription": {}, - "banUserDescription": "The user will be banned from the chat and will not be able to enter the chat again until they are unbanned.", - "@banUserDescription": {}, - "unbanUserDescription": "The user will be able to enter the chat again if they try.", - "@unbanUserDescription": {}, - "kickUserDescription": "The user is kicked out of the chat but not banned. In public chats, the user can rejoin at any time.", - "@kickUserDescription": {}, - "makeAdminDescription": "Once you make this user admin, you may not be able to undo this as they will then have the same permissions as you.", - "@makeAdminDescription": {}, - "pushNotificationsNotAvailable": "Push notifications not available", - "@pushNotificationsNotAvailable": {}, - "learnMore": "Learn more", - "@learnMore": {}, - "yourGlobalUserIdIs": "Your global user-ID is: ", - "@yourGlobalUserIdIs": {}, - "noUsersFoundWithQuery": "Unfortunately no user could be found with \"{query}\". Please check whether you made a typo.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "knocking": "Knocking", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Chat can be discovered via the search on {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "searchChatsRooms": "Search for #chats, @users...", - "@searchChatsRooms": {}, - "nothingFound": "Nothing found...", - "@nothingFound": {}, - "groupName": "Group name", - "@groupName": {}, - "createGroupAndInviteUsers": "Create a group and invite users", - "@createGroupAndInviteUsers": {}, - "groupCanBeFoundViaSearch": "Group can be found via search", - "@groupCanBeFoundViaSearch": {}, - "wrongRecoveryKey": "Sorry... this does not seem to be the correct recovery key.", - "@wrongRecoveryKey": {}, - "startConversation": "Start conversation", - "@startConversation": {}, - "commandHint_sendraw": "Send raw json", - "@commandHint_sendraw": {}, - "databaseMigrationTitle": "Database is optimized", - "@databaseMigrationTitle": {}, - "databaseMigrationBody": "Please wait. This may take a moment.", - "@databaseMigrationBody": {}, - "leaveEmptyToClearStatus": "Leave empty to clear your status.", - "@leaveEmptyToClearStatus": {}, - "select": "Select", - "@select": {}, - "searchForUsers": "Search for @users...", - "@searchForUsers": {}, - "pleaseEnterYourCurrentPassword": "Please enter your current password", - "@pleaseEnterYourCurrentPassword": {}, - "newPassword": "New password", - "@newPassword": {}, - "pleaseChooseAStrongPassword": "Please choose a strong password", - "@pleaseChooseAStrongPassword": {}, - "passwordsDoNotMatch": "Passwords do not match", - "@passwordsDoNotMatch": {}, - "passwordIsWrong": "Your entered password is wrong", - "@passwordIsWrong": {}, - "publicLink": "Public link", - "@publicLink": {}, - "publicChatAddresses": "Public chat addresses", - "@publicChatAddresses": {}, - "createNewAddress": "Create new address", - "@createNewAddress": {}, - "joinSpace": "Join space", - "@joinSpace": {}, - "publicSpaces": "Public spaces", - "@publicSpaces": {}, - "addChatOrSubSpace": "Add chat or sub space", - "@addChatOrSubSpace": {}, - "subspace": "Subspace", - "@subspace": {}, - "decline": "Decline", - "@decline": {}, - "thisDevice": "This device:", - "@thisDevice": {}, - "initAppError": "An error occured while init the app", - "@initAppError": {}, - "userRole": "User role", - "@userRole": {}, - "minimumPowerLevel": "{level} is the minimum power level.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "searchIn": "Search in chat \"{chat}\"...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Search more...", - "@searchMore": {}, - "gallery": "Gallery", - "@gallery": {}, - "files": "Files", - "@files": {}, - "databaseBuildErrorBody": "Unable to build the SQlite database. The app tries to use the legacy database for now. Please report this error to the developers at {url}. The error message is: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sessionLostBody": "Your session is lost. Please report this error to the developers at {url}. The error message is: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "The app now tries to restore your session from the backup. Please report this error to the developers at {url}. The error message is: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "forwardMessageTo": "Forward message to {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendReadReceipts": "Send read receipts", - "@sendReadReceipts": {}, - "sendTypingNotificationsDescription": "Other participants in a chat can see when you are typing a new message.", - "@sendTypingNotificationsDescription": {}, - "sendReadReceiptsDescription": "Other participants in a chat can see when you have read a message.", - "@sendReadReceiptsDescription": {}, - "formattedMessages": "Formatted messages", - "@formattedMessages": {}, - "formattedMessagesDescription": "Display rich message content like bold text using markdown.", - "@formattedMessagesDescription": {}, - "verifyOtherUser": "🔐 Verify other user", - "@verifyOtherUser": {}, - "verifyOtherUserDescription": "If you verify another user, you can be sure that you know who you are really writing to. 💪\n\nWhen you start a verification, you and the other user will see a popup in the app. There you will then see a series of emojis or numbers that you have to compare with each other.\n\nThe best way to do this is to meet up or start a video call. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDevice": "🔐 Verify other device", - "@verifyOtherDevice": {}, - "verifyOtherDeviceDescription": "When you verify another device, those devices can exchange keys, increasing your overall security. 💪 When you start a verification, a popup will appear in the app on both devices. There you will then see a series of emojis or numbers that you have to compare with each other. It's best to have both devices handy before you start the verification. 🤳", - "@verifyOtherDeviceDescription": {}, - "acceptedKeyVerification": "{sender} accepted key verification", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender} canceled key verification", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} completed key verification", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} is ready for key verification", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} requested key verification", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} started key verification", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "Transparent", - "@transparent": {}, - "incomingMessages": "Incoming messages", - "@incomingMessages": {}, - "stickers": "Stickers", - "@stickers": {}, - "discover": "Discover", - "@discover": {}, - "commandHint_ignore": "Ignore the given matrix ID", - "@commandHint_ignore": {}, - "commandHint_unignore": "Unignore the given matrix ID", - "@commandHint_unignore": {}, - "unreadChatsInApp": "{appname}: {unread} unread chats", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "noDatabaseEncryption": "Database encryption is not supported on this platform", - "@noDatabaseEncryption": {}, - "thereAreCountUsersBlocked": "Right now there are {count} users blocked.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "restricted": "Restricted", - "@restricted": {}, - "knockRestricted": "Knock restricted", - "@knockRestricted": {} -} diff --git a/assets/l10n/intl_es.arb b/assets/l10n/intl_es.arb deleted file mode 100644 index 88e9649c9..000000000 --- a/assets/l10n/intl_es.arb +++ /dev/null @@ -1,2380 +0,0 @@ -{ - "@@locale": "es", - "@@last_modified": "2021-08-14 12:41:10.097243", - "about": "Acerca de", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Aceptar", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "{username} aceptó la invitación", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Cuenta", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "{username} activó el cifrado de extremo a extremo", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Añadir dirección de correo", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Administrador", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} respondió a la llamada", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Cualquiera puede unirse", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "Archivo", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "¿Pueden unirse los usuarios visitantes?", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "¿Estás seguro?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "¿Confirma que quiere cerrar sesión?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Para poder confirmar a la otra persona, ingrese su contraseña de almacenamiento segura o la clave de recuperación.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "¿Aceptar esta solicitud de verificación de {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerLoginTypesException": "El servidor soporta los siguientes mecanismos para autenticación:\n{serverVersions}\npero esta aplicación sólo soporta:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "El servidor soporta las siguientes versiones de la especificación:\n{serverVersions}\npero esta aplicación sólo soporta las versiones {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Vetar del chat", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Vetado", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} vetó a {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Bloquear dispositivo", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Bloqueado", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "cancel": "Cancelar", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Cambiar el nombre del dispositivo", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} cambió el icono del chat", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} cambió la descripción del chat a: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} cambió el nombre del chat a: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} cambió los permisos del chat", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} cambió su nombre visible a: {displayname}", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} cambió las reglas de acceso de visitantes", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} cambió las reglas de acceso de visitantes a: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} cambió la visibilidad del historial", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} cambió la visibilidad del historial a: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} cambió las reglas de ingreso", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} cambió las reglas de ingreso a {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} cambió su imagen de perfil", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} cambió el alias de la sala", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} cambió el enlace de invitación", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Cambiar la contraseña", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Cambiar el servidor", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Cambia tu estilo", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Cambiar el nombre del grupo", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "El cifrado se ha corrompido", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Copia de respaldo del chat", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "La copia de respaldo del chat está protegida por una clave de seguridad. Procure no perderla.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Detalles del chat", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Conversaciones", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Elija una contraseña segura", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Borrar archivo", - "@clearArchive": {}, - "close": "Cerrar", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Por favor compare los emojis", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Por favor compare los números", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Confirmar", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Conectar", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "El contacto ha sido invitado al grupo", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Copiado al portapapeles", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Copiar", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Copiar al portapapeles", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "No se pudo descifrar el mensaje: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} participantes", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Crear", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬{username} creó el chat", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Actualmente activo", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Oscuro", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Se desactivará su cuenta de usuario. ¡La operación no se puede cancelar! ¿Está seguro?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "delete": "Eliminar", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Cancelar cuenta", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Eliminar mensaje", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Dispositivo", - "@device": { - "type": "text", - "placeholders": {} - }, - "devices": "Dispositivos", - "@devices": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "El nombre visible ha cambiado", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Descargar archivo", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Editar nombre visible", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Editar alias de la sala", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "¡El emote ya existe!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "¡El atajo del emote es inválido!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Paquetes de emoticonos para la habitación", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Configuración de emotes", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Atajo de emote", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "¡Debes elegir un atajo de emote y una imagen!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Chat vacío", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Habilitar paquete de emoticonos a nivel general", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Ya no podrá deshabilitar el cifrado. ¿Estás seguro?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encryption": "Cifrado", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "El cifrado no está habilitado", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} terminó la llamada", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Introducir una dirección de correo electrónico", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Ingrese su servidor", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "¡Todo listo!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nombre del archivo", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Reenviar", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Desde que se unió", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Desde la invitación", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "Grupo", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "El grupo es público", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grupo con {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Los visitantes están prohibidos", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Los visitantes pueden unirse", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} ha retirado la invitación para {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Ayuda", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Ocultar sucesos censurados", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Ocultar sucesos desconocidos", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "id": "Identificación", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identidad", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Usuarios ignorados", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Frase de contraseña o clave de recuperación incorrecta", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Invitar contacto", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Invitar contacto a {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Invitado", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩{username} invitó a {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Sólo usuarios invitados", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} te invitó a FluffyChat.\n1. Instale FluffyChat: https://fluffychat.im\n2. Regístrate o inicia sesión \n3. Abra el enlace de invitación: {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "está escribiendo…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋{username} se unió al chat", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Unirse a la sala", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞{username} echó a {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅{username} echó y vetó a {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Echar del chat", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Última vez activo: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Abandonar", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Abandonó el chat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licencia", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Claro", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Mostrar {count} participantes más", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Cargando… Por favor espere.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Mostrar más…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Acceso", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Iniciar sesión en {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Cerrar sesión", - "@logout": { - "type": "text", - "placeholders": {} - }, - "mention": "Mencionar", - "@mention": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderador", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Silenciar chat", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Tenga en cuenta que necesita Pantalaimon para utilizar el cifrado de extremo a extremo por ahora.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "Nuevo mensaje en FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "¡Nueva solicitud de verificación!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Siguiente", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "No", - "@no": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Ningún emote encontrado. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Sólo se puede activar el cifrado en cuanto la sala deja de ser de acceso público.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Parece que no tienes servicios de Google en tu teléfono. ¡Esa es una buena decisión para tu privacidad! Para recibir notificaciones instantáneas en FluffyChat, recomendamos usar microG: https://microg.org/", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Ninguno", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Sin autorización", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Ninguna sala encontrada…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "offline": "Desconectado", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Conectado", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "La copia de seguridad de la clave en línea está habilitada", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Ups, algo salió mal…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Abrir la aplicación para leer los mensajes", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Abrir cámara", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "contraseña o clave de recuperación", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Contraseña", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "La contraseña ha sido cambiada", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "people": "Personas", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Elegir imagen", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Pin", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Reproducir {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseClickOnLink": "Haga clic en el enlace del correo electrónico y luego continúe.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Por favor ingrese su contraseña", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Por favor ingrese su nombre de usuario", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Por favor, siga las instrucciones del sitio web y presione \"siguiente\".", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privacidad", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Salas públicas", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "recording": "Grabando", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} censuró un suceso", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Rechazar", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} rechazó la invitación", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Volver a unirse", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Eliminar", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Eliminar todos los otros dispositivos", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Eliminado por {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Eliminar dispositivo", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Eliminar la expulsión", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Mostrar el contenido con mensajes enriquecidos", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "Responder", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Solicitar permiso", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "La sala ha subido de categoría", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Versión de sala", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Visto por {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Enviar", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Enviar un mensaje", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Enviar audio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Enviar un archivo", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Enviar una imagen", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Enviar el original", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Enviar video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "{username} envió un archivo", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "{username} envió un audio", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "{username} envió una imagen", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "{username} envió un sticker", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "{username} envió un video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} envió información de la llamada", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Fijar alias principal", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Establecer enlace de invitación", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Establecer estado", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Ajustes", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Compartir", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} compartió la ubicación", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "showPassword": "Mostrar contraseña", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "skip": "Omitir", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Código fuente", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} comenzó una llamada", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "statusExampleMessage": "¿Cómo estás hoy?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Enviar", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistema", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "No coinciden", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Coinciden", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Transferir desde otro dispositivo", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Intentar enviar nuevamente", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Indisponible", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} admitió a {targetName} nuevamente", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Desbloquear dispositivo", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Dispositivo desconocido", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Algoritmo de cifrado desconocido", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Evento desconocido '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Dejar de silenciar el chat", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Despinchar", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 chat no leído} other{{unreadCount} chats no leídos}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} y {count} más están escribiendo…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} y {username2} están escribiendo…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} está escribiendo…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "{username} abandonó el chat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Nombre de usuario", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} envió un evento {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Verificado", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verificar", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Comenzar verificación", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "¡Has verificado exitosamente!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verificando la otra cuenta", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Video llamada", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Visibilidad del historial del chat", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Visible para todos los participantes", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Visible para todo el mundo", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Mensaje de voz", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Esperando a que el socio acepte la solicitud…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Esperando a que el socio acepte los emojis…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Esperando a que el socio acepte los números…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Fondo de pantalla:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "¡Advertencia!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Te enviamos un correo electrónico", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Quién tiene permitido unirse al grupo", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Escribe un mensaje…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Sí", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Tú", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Ya no estás participando en este chat", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Has sido vetado de este chat", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "Reproducir emoticonos y stickers animados automáticamente", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "allChats": "Todos los chats", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Agregar al espacio", - "@addToSpace": {}, - "cantOpenUri": "No puedo abrir el URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "all": "Todo", - "@all": { - "type": "text", - "placeholders": {} - }, - "appLock": "Bloqueo de aplicación", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Mensajes de bot", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "Se ha cerrado en la sesión de uno de sus clientes", - "@oneClientLoggedOut": {}, - "addAccount": "Añadir cuenta", - "@addAccount": {}, - "editBundlesForAccount": "Editar paquetes para esta cuenta", - "@editBundlesForAccount": {}, - "addToBundle": "Agregar al paquete", - "@addToBundle": {}, - "bundleName": "Nombre del paquete", - "@bundleName": {}, - "saveFile": "Guardar el archivo", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Enviar stickers", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Establecer nivel de permisos", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Compartir ubicación", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Inicio de sesión único", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "status": "Estado", - "@status": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Sincronizando... por favor espere.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "He hecho clic en el enlace", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "directChats": "Chat directo", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Error al obtener la ubicación: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "howOffensiveIsThisContent": "¿Cuán ofensivo es este contenido?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Invitar por mí", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Aún no ha agregado una forma de recuperar su contraseña.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} usuarios están escribiendo…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "or": "O", - "@or": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "El espacio es público", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "El chat se ha agregado a este espacio", - "@chatHasBeenAddedToThisSpace": {}, - "commandInvalid": "Comando inválido", - "@commandInvalid": { - "type": "text" - }, - "passwordRecovery": "Recuperación de contraseña", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "security": "Seguridad", - "@security": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extremadamente ofensivo", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Editar servidores bloqueado", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Configurar chat", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Sin conexión al servidor", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Tu clave pública", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Contraseña olvidada", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Inofensivo", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "reason": "Razón", - "@reason": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Cambios de miembros", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Nuevo espacio", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "edit": "Editar", - "@edit": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Establecer emoticonos personalizados", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorar", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notificaciones", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Notificaciones habilitadas para esta cuenta", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "offensive": "Ofensiva", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "Este servidor necesita validar su dirección de correo electrónico para registrarse.", - "@serverRequiresEmail": {}, - "pleaseChoose": "Por favor elija", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Reemplazar habitación con una versión más nueva", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "El contenido ha sido reportado a los administradores del servidor", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "groups": "Grupos", - "@groups": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Mensaje de informe", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "search": "Buscar", - "@search": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Permiso de ubicación denegado. Concédeles que puedan compartir tu ubicación.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Nivel de permiso predeterminado", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Obteniendo ubicación…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "participant": "Participante", - "@participant": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Regla de Push", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "register": "Registrarse", - "@register": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Enviar como texto", - "@sendAsText": { - "type": "text" - }, - "toggleMuted": "Alternar silenciado", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Demasiadas solicitudes. ¡Por favor inténtelo más tarde!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Con esta dirección puede recuperar su contraseña.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "commandHint_send": "Enviar texto", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "deviceId": "ID del dispositivo", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Contiene nombre de usuario", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "¡UPS¡ Desafortunadamente, se produjo un error al configurar las notificaciones push.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Quitar tu avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Habilitar la encriptación", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "messages": "Mensajes", - "@messages": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Tamaño de fuente", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Prohibir al usuario dado en esta sala", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_unban": "Des banear al usuario dado en esta sala", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandMissing": "{command} no es un comando.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "scanQrCode": "Escanear código QR", - "@scanQrCode": {}, - "homeserver": "Homeserver", - "@homeserver": {}, - "newChat": "Nuevo chat", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "commandHint_join": "Únete a la sala indicada", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "sendOnEnter": "Enviar con enter", - "@sendOnEnter": {}, - "changeYourAvatar": "Cambiar tu avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "commandHint_me": "Descríbete", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_html": "Enviar texto con formato HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Invitar al usuario indicado a esta sala", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_kick": "Eliminar el usuario indicado de esta sala", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Deja esta sala", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_myroomavatar": "Selecciona tu foto para esta sala (by mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Establece tu nombre para mostrar para esta sala", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Establece el nivel de potencia del usuario dado (default: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Enviar texto sin formato", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Enviar respuesta como reacción", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "containsDisplayName": "Contiene nombre para mostrar", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Editar avatar de sala", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Los servicios de ubicación están deshabilitado. Habilite para poder compartir su ubicación.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Encriptado", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Ir a la nueva sala", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} no es un servidor matrix, usar {server2} en su lugar?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "openInMaps": "Abrir en maps", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "removeFromBundle": "Quitar de este paquete", - "@removeFromBundle": {}, - "link": "Link", - "@link": {}, - "enableMultiAccounts": "(BETA) habilite varias cuenta en este dispositivo", - "@enableMultiAccounts": {}, - "pleaseEnter4Digits": "Ingrese 4 dígitos o déjelo en blanco para deshabilitar el bloqueo de la aplicación.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Elija un código de acceso", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Por favor ingrese su PIN", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Censurar mensaje", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Enviar mensajes", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Nombre del espacio", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Alternar favorito", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Marcar como: leído / no leído", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Quién puede realizar qué acción", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "¿Por qué quieres denunciar esto?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "¿Limpiar la copia de seguridad de su chat para crear una nueva clave de seguridad?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "Se ha configurado la copia de respaldo del chat.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "No verificado", - "@unverified": {}, - "commandHint_clearcache": "Limpiar cache", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "messageInfo": "Información del mensaje", - "@messageInfo": {}, - "time": "Tiempo", - "@time": {}, - "openVideoCamera": "Abrir la cámara para un video", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Repita la contraseña", - "@repeatPassword": {}, - "removeFromSpace": "Eliminar del espacio", - "@removeFromSpace": {}, - "addToSpaceDescription": "Elige un espacio para añadir este chat a el.", - "@addToSpaceDescription": {}, - "openGallery": "Abrir galería", - "@openGallery": {}, - "start": "Iniciar", - "@start": {}, - "commandHint_discardsession": "Descartar sesión", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "messageType": "Tipo de Mensaje", - "@messageType": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "publish": "Publicar", - "@publish": {}, - "newSpace": "Nuevo espacio", - "@newSpace": {}, - "allSpaces": "Todos los espacios", - "@allSpaces": {}, - "widgetUrlError": "Esta no es una URL válida.", - "@widgetUrlError": {}, - "commandHint_markasgroup": "Marcar como grupo", - "@commandHint_markasgroup": {}, - "nextAccount": "Siguiente cuenta", - "@nextAccount": {}, - "youRejectedTheInvitation": "Rechazaste la invitación", - "@youRejectedTheInvitation": {}, - "newGroup": "Nuevo grupo", - "@newGroup": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "previousAccount": "Cuenta anterior", - "@previousAccount": {}, - "users": "Usuarios", - "@users": {}, - "youInvitedBy": "📩 Has sido invitado por {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youAcceptedTheInvitation": "👍 Aceptaste la invitación", - "@youAcceptedTheInvitation": {}, - "widgetEtherpad": "Nota de texto", - "@widgetEtherpad": {}, - "commandHint_cuddle": "Mandar una carantoña", - "@commandHint_cuddle": {}, - "supposedMxid": "Esto debería ser {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "importFromZipFile": "Importar de un archivo .zip", - "@importFromZipFile": {}, - "exportEmotePack": "Exportar paquete de emotes como .zip", - "@exportEmotePack": {}, - "addChatDescription": "Añadir una descripción del chat", - "@addChatDescription": {}, - "sendTypingNotifications": "Enviar notificaciones \"está escribiendo\"", - "@sendTypingNotifications": {}, - "importEmojis": "Importar emojis", - "@importEmojis": {}, - "confirmMatrixId": "Por favor confirma tu Matrix ID para borrar tu cuenta.", - "@confirmMatrixId": {}, - "notAnImage": "El archivo no es una imagen.", - "@notAnImage": {}, - "commandHint_hug": "Mandar un abrazo", - "@commandHint_hug": {}, - "importNow": "Importar ahora", - "@importNow": {}, - "hugContent": "{senderName} te abraza", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "otherCallingPermissions": "Micrófono, cámara y otros permisos de FluffyChat", - "@otherCallingPermissions": {}, - "emailOrUsername": "Correo electrónico o nombre de usuario", - "@emailOrUsername": {}, - "countFiles": "{count} archivos", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "reportUser": "Reportar usuario", - "@reportUser": {}, - "voiceCall": "Llamada de voz", - "@voiceCall": {}, - "reactedWith": "{sender} reaccionó con {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "markAsRead": "Marcar como leído", - "@markAsRead": {}, - "widgetName": "Nombre", - "@widgetName": {}, - "replace": "Reemplazar", - "@replace": {}, - "unsupportedAndroidVersionLong": "Esta característica requiere una versión más reciente de Android. Por favor, compruebe las actualizaciones o la compatibilidad de LineageOS.", - "@unsupportedAndroidVersionLong": {}, - "storeSecurlyOnThisDevice": "Almacenar de forma segura en este dispositivo", - "@storeSecurlyOnThisDevice": {}, - "@encryptThisChat": {}, - "openChat": "Abrir chat", - "@openChat": {}, - "screenSharingDetail": "Usted está compartiendo su pantalla en FluffyChat", - "@screenSharingDetail": {}, - "@jumpToLastReadMessage": {}, - "allRooms": "Todos los chats grupales", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "widgetVideo": "Vídeo", - "@widgetVideo": {}, - "dismiss": "Descartar", - "@dismiss": {}, - "@reportErrorDescription": {}, - "unsupportedAndroidVersion": "Versión de Android no compatible", - "@unsupportedAndroidVersion": {}, - "indexedDbErrorLong": "El almacenamiento de mensajes, por desgracia, no está habilitado en el modo privado por defecto.\nPor favor, visite\n - about:config\n - Establezca dom.indexedDB.privateBrowsing.enabled a true\nDe otra forma, no es posible usar FluffyChat.", - "@indexedDbErrorLong": {}, - "startFirstChat": "Comience su primer chat", - "@startFirstChat": {}, - "@callingAccount": {}, - "@setColorTheme": {}, - "commandHint_create": "Crear un chat grupal vacío\nUse --no-encryption para deshabilitar el cifrado", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "user": "Usuario", - "@user": {}, - "@banUserDescription": {}, - "@removeDevicesDescription": {}, - "separateChatTypes": "Separar chats directos de grupos", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "tryAgain": "Inténtelo de nuevo", - "@tryAgain": {}, - "youKickedAndBanned": "🙅 Usted expulsó y prohibió el acceso a {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "messagesStyle": "Mensajes:", - "@messagesStyle": {}, - "@newSpaceDescription": {}, - "chatDescription": "Descripción del chat", - "@chatDescription": {}, - "callingAccountDetails": "Permite a FluffyChat utilizar la aplicación de llamadas nativa de Android.", - "@callingAccountDetails": {}, - "enterSpace": "Unirse al espacio", - "@enterSpace": {}, - "@reopenChat": {}, - "pleaseEnterRecoveryKey": "Por favor, introduzca su clave de recuperación:", - "@pleaseEnterRecoveryKey": {}, - "widgetNameError": "Por favor, introduzca un nombre a mostrar.", - "@widgetNameError": {}, - "addWidget": "Añadir widget", - "@addWidget": {}, - "@noKeyForThisMessage": {}, - "hydrateTor": "TOR: Importar sesión exportada", - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "storeInAppleKeyChain": "Almacenar en la KeyChain de Apple", - "@storeInAppleKeyChain": {}, - "hydrate": "Restaurar desde fichero de copia de seguridad", - "@hydrate": {}, - "invalidServerName": "Nombre del servidor no válido", - "@invalidServerName": {}, - "chatPermissions": "Permisos del chat", - "@chatPermissions": {}, - "sender": "Remitente", - "@sender": {}, - "storeInAndroidKeystore": "Almacenar en la KeyStore de Android", - "@storeInAndroidKeystore": {}, - "@signInWithPassword": {}, - "@makeAdminDescription": {}, - "saveKeyManuallyDescription": "Compartir esta clave manualmente usando el diálogo de compartir del sistema o el portapapeles.", - "@saveKeyManuallyDescription": {}, - "whyIsThisMessageEncrypted": "¿Por qué no se puede leer este mensaje?", - "@whyIsThisMessageEncrypted": {}, - "setChatDescription": "Establecer descripción del chat", - "@setChatDescription": {}, - "dehydrateWarning": "Esta acción no se puede deshacer. Asegúrese de que ha almacenado de forma segura el fichero de copia de seguridad.", - "@dehydrateWarning": {}, - "@noOtherDevicesFound": {}, - "redactedBy": "Censurado por {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "videoCallsBetaWarning": "Tenga en cuenta que las videollamadas están actualmente en fase beta. Es posible que no funcionen como se espera o que no funcionen de ninguna manera en algunas plataformas.", - "@videoCallsBetaWarning": {}, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@fileIsTooBigForServer": {}, - "callingPermissions": "Permisos de llamadas", - "@callingPermissions": {}, - "@readUpToHere": {}, - "unlockOldMessages": "Desbloquear mensajes viejos", - "@unlockOldMessages": {}, - "numChats": "{number} chats", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "optionalRedactReason": "(Opcional) Motivo para censurar este mensaje...", - "@optionalRedactReason": {}, - "dehydrate": "Exportar sesión y limpiar dispositivo", - "@dehydrate": {}, - "@archiveRoomDescription": {}, - "switchToAccount": "Cambiar a la cuenta {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "experimentalVideoCalls": "Videollamadas experimentales", - "@experimentalVideoCalls": {}, - "pleaseEnterRecoveryKeyDescription": "Para desbloquear sus viejos mensajes, introduzca su clave de recuperación que se generó en una sesión anterior. Su clave de recuperación NO es su contraseña.", - "@pleaseEnterRecoveryKeyDescription": {}, - "inviteContactToGroupQuestion": "¿Quieres invitar a {contact} al chat {groupName}?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Censurado por {username} porque: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Usted retiró la invitación a {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@appearOnTopDetails": {}, - "enterRoom": "Unirse a la sala", - "@enterRoom": {}, - "confirmEventUnpin": "¿Seguro que quiere desfijar permanentemente el evento?", - "@confirmEventUnpin": {}, - "youInvitedUser": "📩 Usted invitó a {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "redactMessageDescription": "El mensaje será censurado para todas las personas participantes en la conversación. Esto no se puede deshacer.", - "@redactMessageDescription": {}, - "recoveryKey": "Clave de recuperación", - "@recoveryKey": {}, - "@invalidInput": {}, - "dehydrateTorLong": "Si está usando TOR, es recomendable exportar la sesión antes de cerrar la ventana.", - "@dehydrateTorLong": {}, - "doNotShowAgain": "No mostrar de nuevo", - "@doNotShowAgain": {}, - "@report": {}, - "hideUnimportantStateEvents": "Ocultar eventos de estado no importantes", - "@hideUnimportantStateEvents": {}, - "screenSharingTitle": "Compartir la pantalla", - "@screenSharingTitle": {}, - "widgetCustom": "Personalizado", - "@widgetCustom": {}, - "youBannedUser": "Usted prohibió el acceso a {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@openLinkInBrowser": {}, - "@disableEncryptionWarning": {}, - "directChat": "Chat directo", - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@inviteGroupChat": {}, - "appearOnTop": "Aparecer en la cima", - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "foregroundServiceRunning": "Esta notificación aparece cuando el servicio en segundo plano se está ejecutando.", - "@foregroundServiceRunning": {}, - "wasDirectChatDisplayName": "Chat vacío (era {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noChatDescriptionYet": "No se ha creado una descripción del chat aún.", - "@noChatDescriptionYet": {}, - "@learnMore": {}, - "chatDescriptionHasBeenChanged": "Se ha cambiado la descripción del chat", - "@chatDescriptionHasBeenChanged": {}, - "dehydrateTor": "TOR: Exportar sesión", - "@dehydrateTor": {}, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "youKicked": "👞 Usted expulsó a {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@sorryThatsNotPossible": {}, - "shareInviteLink": "Compartir enlace de invitación", - "@shareInviteLink": {}, - "commandHint_markasdm": "Marcar como sala de mensajes directos para el ID de Matrix", - "@commandHint_markasdm": {}, - "recoveryKeyLost": "¿Perdió su clave de recuperación?", - "@recoveryKeyLost": {}, - "@deviceKeys": {}, - "emoteKeyboardNoRecents": "Los emotes usados recientemente aparecerán aquí...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "youJoinedTheChat": "Usted se ha unido al chat", - "@youJoinedTheChat": {}, - "errorAddingWidget": "Fallo al añadir el widget.", - "@errorAddingWidget": {}, - "commandHint_dm": "Iniciar un chat directo\nUse --no-encryption para deshabilitar el cifrado", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "youUnbannedUser": "Usted volvió a permitir el acceso a {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "emojis": "Emojis", - "@emojis": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Crear grupo", - "@createGroup": {}, - "hydrateTorLong": "¿Exportó su sesión la última vez que estuvo en TOR? Impórtela rápidamente y continúe chateando.", - "@hydrateTorLong": {}, - "custom": "Personalizado", - "@custom": {}, - "@noBackupWarning": {}, - "storeInSecureStorageDescription": "Almacenar la clave de recuperación en el almacenamiento seguro de este dispositivo.", - "@storeInSecureStorageDescription": {}, - "@kickUserDescription": {}, - "pinMessage": "Anclar a la sala", - "@pinMessage": {}, - "@invite": {}, - "indexedDbErrorTitle": "Problemas con el modo privado", - "@indexedDbErrorTitle": {}, - "googlyEyesContent": "{senderName} te manda ojos saltones", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} se acurruca contigo", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_googly": "Enviar unos ojos saltones", - "@commandHint_googly": {}, - "@placeCall": {} -} diff --git a/assets/l10n/intl_et.arb b/assets/l10n/intl_et.arb deleted file mode 100644 index 867822dc3..000000000 --- a/assets/l10n/intl_et.arb +++ /dev/null @@ -1,2712 +0,0 @@ -{ - "@@locale": "et", - "@@last_modified": "2021-08-14 12:41:10.079944", - "about": "Rakenduse teave", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Nõustu", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} võttis kutse vastu", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Kasutajakonto", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐{username} võttis kasutusele läbiva krüptimise", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Lisa e-posti aadress", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Peakasutaja", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Kõik", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Kõik vestlused", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} vastas kõnele", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Kõik võivad liituda", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Rakenduse lukustus", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arhiiv", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Kas külalised võivad liituda", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Kas sa oled kindel?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Kas sa oled kindel, et soovid välja logida?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Selleks, et teist osapoolt identifitseerivat allkirja anda, palun sisesta oma turvahoidla paroolifraas või taastevõti.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Kas võtad vastu selle verifitseerimispalve kasutajalt {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Esita liikuvad kleepse ja emotikone automaatselt", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "See koduserver toetab Matrixi võrku sisselogimiseks:\n{serverVersions}\nAga see rakendus toetab vaid järgmisi võimalusi:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "See koduserver toetab Matrixi spetsifikatsioonist järgmisi versioone:\n{serverVersions}\nAga see rakendus toetab vaid järgmisi versioone: {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Keela ligipääs vestlusele", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Ligipääs vestlusele on keelatud", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} keelas ligipääsu kasutajale {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blokeeri seade", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Blokeeritud", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Robotite sõnumid", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Katkesta", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "{uri} aadressi avamine ei õnnestu", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Muuda seadme nime", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} muutis vestluse tunnuspilti", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} muutis vestluse uueks kirjelduseks „{description}“", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} muutis oma uueks kuvatavaks nimeks „{chatname}“", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} muutis vestlusega seotud õigusi", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} muutis uueks kuvatavaks nimeks: {displayname}", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} muutis külaliste ligipääsureegleid", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} muutis külaliste ligipääsureegleid järgnevalt: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} muutis sõnumite ajaloo nähtavust", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} muutis sõnumite ajaloo nähtavust järgnevalt: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} muutis liitumise reegleid", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} muutis liitumise reegleid järgnevalt: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} muutis oma tunnuspilti", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} muutis jututoa aliast", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} muutis kutse linki", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Muuda salasõna", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Muuda koduserverit", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Muuda oma stiili", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Muuda vestlusrühma nime", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Muuda oma tunnuspilti", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Kasutatud krüptimine on vigane", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Vestlus", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Varunda vestlus", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Sinu vestluste varukoopia on krüptitud taastamiseks mõeldud turvavõtmega. Palun vaata, et sa seda ei kaota.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Vestluse teave", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Vestlused", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Vali korralik salasõna", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Kustuta arhiiv", - "@clearArchive": {}, - "close": "Sulge", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Sea sellele kasutajale antud jututoas suhtluskeeld", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Saada HTML-vormingus tekst", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Kutsu see kasutaja antud jututuppa", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Liitu selle jututoaga", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Eemalda antud kasutaja sellest jututoast", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Lahku sellest jututoast", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Kirjelda ennast", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Määra selles jututoas oma tunnuspilt (mxc-uri vahendusel)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Määra selles jututoas oma kuvatav nimi", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Seadista selle kasutaja õigusi (vaikimisi: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Saada vormindamata tekst", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Saada vastus reaktsioonina", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Saada sõnum", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Eemalda sellelt kasutajalt antud jututoas suhtluskeeld", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Vigane käsk", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} ei ole käsk.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Palun võrdle emotikone", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Palun võrdle numbreid", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Seadista vestlust", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Kinnita", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Ühenda", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Sinu kontakt on kutsutud liituma vestlusrühma", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Sisaldab kuvatavat nime", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Sisaldab kasutajanime", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Saatsime selle sisu kohta teate koduserveri haldajate", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Kopeerisin lõikelauale", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopeeri", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopeeri lõikelauale", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Sõnumi dekrüptimine ei õnnestunud: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} osalejat", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Loo", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} algatas vestluse", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Uus kogukond", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Hetkel aktiivne", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Tume", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}.{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{year}.{month}.{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Järgnevaga eemaldatakse sinu konto kasutusest. Seda tegevust ei saa tagasi pöörata! Kas sa ikka oled kindel?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Vaikimisi õigused", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Kustuta", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Kustuta kasutajakonto", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Kustuta sõnum", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Seade", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Seadme tunnus", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Seadmed", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Otsevestlused", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Kuvatav nimi on muudetud", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Laadi fail alla", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Muuda", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Muuda blokeeritud serverite loendit", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Muuda kuvatavat nime", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Muuda jututoa aliast", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Muuda jututoa tunnuspilti", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Selline emotsioonitegevus on juba olemas!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Vigane emotsioonitegevuse lühikood!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Emotsioonitegevuste pakid jututoa jaoks", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emotsioonitegevuste seadistused", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Emotsioonitegevuse lühikood", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Sa pead valima emotsioonitegevuse lühikoodi ja pildi!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Vestlust pole olnud", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Võta emotsioonitegevuste pakid läbivalt kasutusele", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Kasuta krüptimist", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Sa ei saa hiljem enam krüptimist välja lülitada. Kas oled kindel?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Krüptitud", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Krüptimine", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Krüptimine ei ole kasutusel", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} lõpetas kõne", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Sisesta e-posti aadress", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Sisesta oma koduserveri aadress", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Viga asukoha tuvastamisel: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Kõik on valmis!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Äärmiselt solvav", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Faili nimi", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Fondi suurus", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Edasta", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Alates liitumise hetkest", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Kutse saamisest", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Hakka kasutama uut jututuba", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Vestlusrühm", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Vestlusrühm on avalik", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Vestlusrühmad", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Vestlusrühm {displayname} kasutajanimega", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Külalised ei ole lubatud", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Külalised võivad liituda", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} on võtnud tagasi {targetName} kutse", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Abiteave", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Peida muudetud sündmused", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Peida tundmatud sündmused", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Kui solvav see sisu on?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identiteet", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Eira", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Eiratud kasutajad", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Ma olen klõpsinud saadetud linki", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Vigane paroolifraas või taastevõti", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Kahjutu", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Kutsu sõpru ja tuttavaid", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Kutsu sõpru ja tuttavaid {groupName} liikmeks", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Kutsutud", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} saatis kutse kasutajale {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Ainult kutsutud kasutajatele", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Kutse minu jaoks", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} kutsus sind kasutama Matrix'i-põhist suhtlusrakendust FluffyChat. \n1. Ava fluffychat.im ja paigalda FluffyChat'i rakendus \n2. Liitu kasutajaks või logi sisse olemasoleva Matrix'i kasutajakontoga\n3. Ava kutse link: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "kirjutab…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} liitus vestlusega", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Liitu jututoaga", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} müksas kasutaja {targetName} välja", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅{username} müksas kasutaja {targetName} välja ning seadis talle suhtluskeelu", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Müksa vestlusest välja", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Viimati nähtud: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Lahku", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Lahkus vestlusest", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Litsents", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Hele", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Lisa veel {count} osalejat", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Laadin andmeid… Palun oota.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Laadi veel…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Asukohateenused on seadmes väljalülitatud. Asukoha jagamiseks palun lülita nad sisse.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Puudub luba asukohateenuste kasutamiseks. Asukoha jagamiseks palun anna rakendusele vastavad õigused.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Logi sisse", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Logi sisse {homeserver} serverisse", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Logi välja", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Muudatused liikmeskonnas", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Märgi ära", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Sõnumid", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderaator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Summuta vestlus", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Palun arvesta, et sa saad hetkel kasutada läbivat krüptimist vaid siis, kui koduserver kasutab Pantalaimon'it.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Uus vestlus", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Uus sõnum FluffyChat'i vahendusel", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Uus verifitseerimispäring!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Edasi", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Ei", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Puudub ühendus koduserveriga", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Ühtegi emotsioonitegevust ei leidunud. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Sa võid krüptimise kasutusele võtta niipea, kui jututuba pole enam avalik.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Tundub, et sinu nutiseadmes pole Firebase Cloud Messaging teenuseid. Sinu privaatsuse mõttes on see kindlasti hea otsus! Kui sa soovid FluffyChat'is näha tõuketeavitusi, siis soovitame, et selle jaoks kasutad ntfy liidestust. Kasutades ntfy'd või mõnda muud Unified Push standardil põhinevat liidestust saad tõuketeavitusi turvalisel moel. Ntfy rakendus on saadaval nii PlayStore kui F-Droid'i rakendusepoodides.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} pole Matrix'i server, kas kasutame selle asemel {server2} serverit?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "none": "Mitte midagi", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Sa pole veel lisanud võimalust salasõna taastamiseks.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Õigused puuduvad", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Jututubasid ei leidunud…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Teavitused", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Teavitused on sellel kontol kasutusel", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} kasutajat kirjutavad…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Tuvastan asukohta…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Solvav", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Väljas", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "sobib", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Saadaval", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Krüptovõtmete veebipõhine varundus on kasutusel", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Hopsti! Kahjuks tekkis tõuketeavituste seadistamisel viga.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Hopsti! Midagi läks nüüd viltu…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Sõnumite lugemiseks ava rakendus", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Ava kaamera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Ava kaardirakendusega", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "või", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Osaleja", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "paroolifraas või taastevõti", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Salasõna", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Salasõna on ununenud", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Salasõna on muudetud", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Salasõna taastamine", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Inimesed", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Vali pilt", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Klammerda", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Esita {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Palun vali", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Palun vali rakenduse PIN-kood", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Jätkamiseks palun klõpsi sulle saadetud e-kirjas leiduvat linki.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Rakenduse luku jaoks sisesta 4 numbrit või kui sa sellist võimalust ei soovi kasutada, siis jäta nad tühjaks.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Palun sisesta oma salasõna", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Palun sisesta oma PIN-kood", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Palun sisesta oma kasutajanimi", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Palun järgi veebilehel olevaid juhiseid ja klõpsi nuppu Edasi.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privaatsus", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Avalikud jututoad", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Tõukereeglid", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Põhjus", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Salvestan", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} muutis sündmust", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Muuda sõnumit", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Registreeru", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Lükka tagasi", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} lükkas kutse tagasi", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Liitu uuesti", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Eemalda", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Eemalda kõik muud seadmed", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "{username} eemaldas sündmuse", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Eemalda seade", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Eemalda suhtluskeeld", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Kustuta oma tunnuspilt", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Visualiseeri vormindatud sõnumite sisu", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Asenda jututoa senine versioon uuega", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Vasta", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Teata sõnumist", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Palu õigusi", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Jututoa vesrioon on uuendatud", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Jututoa versioon", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Salvesta fail", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Otsi", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Turvalisus", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Sõnumit nägi {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Saada", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Saada sõnum", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Saada tekstisõnumina", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Saada helifail", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Saada fail", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Saada pilt", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Saada sõnumeid", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Saada fail muutmata kujul", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Saada kleeps", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Saada videofail", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} saatis faili", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} saatis helifaili", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} saatis pildi", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} saatis kleepsu", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} saatis video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} saatis teavet kõne kohta", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Määra põhinimeks", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Kohanda emotsioonitegevusi", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Tee kutselink", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Seadista õigusi", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Määra olek", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Seadistused", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Jaga", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} jagas oma asukohta", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Jaga asukohta", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Näita salasõna", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Ühekordne sisselogimine", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Jäta vahele", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Lähtekood", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Kogukond on avalik", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Kogukonna nimi", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} alustas kõnet", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Olek", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Kuidas sul täna läheb?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Saada", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Sünkroniseerin andmeid… Palun oota.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Süsteem", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Nad ei klapi omavahel", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Nad klapivad omavahel", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Muuda olekut lemmikuna", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Lülita summutamine sisse või välja", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Märgi loetuks / lugemata", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Liiga palju päringuid. Palun proovi hiljem uuesti!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Tõsta teisest seadmest", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Proovi uuesti saata", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Eemal", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} eemaldas ligipääsukeelu kasutajalt {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Eemalda seadmelt blokeering", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Tundmatu seade", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Tundmatu krüptoalgoritm", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Tundmatu sündmuse tüüp „{type}“", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Lõpeta vestluse vaigistamine", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Eemalda klammerdus", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 lugemata vestlus} other{{unreadCount} lugemata vestlust}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} ja {count} muud kirjutavad…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} ja {username2} kirjutavad…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} kirjutab…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪{username} lahkus vestlusest", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Kasutajanimi", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} saatis {type} sündmuse", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Verifitseeritud", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verifitseeri", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Alusta verifitseerimist", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Sinu verifitseerimine õnnestus!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verifitseerin teist kasutajakontot", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videokõne", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Vestluse ajaloo nähtavus", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Nähtav kõikidele osalejatele", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Nähtav kõikidele", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Häälsõnum", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Ootan, et teine osapool nõustuks päringuga…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Ootan teise osapoole kinnitust, et tegemist on samade emojidega…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Ootan teise osapoole kinnitust, et tegemist on samade numbritega…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Taustapilt:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Hoiatus!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Me saatsime sulle e-kirja", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Erinevatele kasutajatele lubatud toimingud", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Kes võivad selle vestlusrühmaga liituda", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Miks sa soovid sellest teatada?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Kas kustutame sinu vestluste varukoopia ja loome uue taastamiseks mõeldud krüptovõtme?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Nende e-posti aadresside abil saad taastada oma salasõna.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Kirjuta üks sõnum…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Jah", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Sina", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Sa enam ei osale selles vestluses", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Sinule on selles vestluses seatud suhtluskeeld", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Sinu avalik võti", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Lisasime vestluse kogukonda", - "@chatHasBeenAddedToThisSpace": {}, - "addToSpace": "Lisa kogukonda", - "@addToSpace": {}, - "scanQrCode": "Skaneeri QR-koodi", - "@scanQrCode": {}, - "sendOnEnter": "Saada sõnum sisestusklahvi vajutusel", - "@sendOnEnter": {}, - "homeserver": "Koduserver", - "@homeserver": {}, - "serverRequiresEmail": "See koduserver eeldab registreerimisel kasutatava e-postiaadressi kinnitamist.", - "@serverRequiresEmail": {}, - "enableMultiAccounts": "(KATSELINE) Pruugi selles seadmes mitut Matrix'i kasutajakontot", - "@enableMultiAccounts": {}, - "bundleName": "Köite nimi", - "@bundleName": {}, - "removeFromBundle": "Eemalda sellest köitest", - "@removeFromBundle": {}, - "addToBundle": "Lisa köitesse", - "@addToBundle": {}, - "editBundlesForAccount": "Muuda selle kasutajakonto köiteid", - "@editBundlesForAccount": {}, - "addAccount": "Lisa kasutajakonto", - "@addAccount": {}, - "oneClientLoggedOut": "Üks sinu klientrakendustest on Matrix'i võrgust välja loginud", - "@oneClientLoggedOut": {}, - "link": "Link", - "@link": {}, - "yourChatBackupHasBeenSetUp": "Sinu vestluste varundus on seadistatud.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "Verifitseerimata", - "@unverified": {}, - "repeatPassword": "Korda salasõna", - "@repeatPassword": {}, - "messageInfo": "Sõnumi teave", - "@messageInfo": {}, - "time": "Kellaaeg", - "@time": {}, - "messageType": "Sõnumi tüüp", - "@messageType": {}, - "sender": "Saatja", - "@sender": {}, - "openGallery": "Ava galerii", - "@openGallery": {}, - "addToSpaceDescription": "Vali kogukond, kuhu soovid seda vestlust lisada.", - "@addToSpaceDescription": {}, - "removeFromSpace": "Eemalda kogukonnast", - "@removeFromSpace": {}, - "start": "Alusta", - "@start": {}, - "commandHint_discardsession": "Loobu sessioonist", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_clearcache": "Tühjenda vahemälu", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_dm": "Alusta otsevestlust\nKrüptimise keelamiseks kasuta --no-encryption võtit", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_create": "Loo tühi vestlusrühm\nKrüptimise keelamiseks kasuta --no-encryption võtit", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "openVideoCamera": "Video salvestamiseks ava kaamera", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "markAsRead": "Märgi loetuks", - "@markAsRead": {}, - "reportUser": "Teata kasutajast", - "@reportUser": {}, - "openChat": "Ava vestlus", - "@openChat": {}, - "dismiss": "Loobu", - "@dismiss": {}, - "reactedWith": "{sender} reageeris nii {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "emojis": "Emotikonid", - "@emojis": {}, - "placeCall": "Helista", - "@placeCall": {}, - "unsupportedAndroidVersion": "See Androidi versioon ei ole toetatud", - "@unsupportedAndroidVersion": {}, - "voiceCall": "Häälkõne", - "@voiceCall": {}, - "confirmEventUnpin": "Kas sa oled kindel, et tahad klammerdatud sündmuse eemaldada?", - "@confirmEventUnpin": {}, - "pinMessage": "Klammerda sõnum jututuppa", - "@pinMessage": {}, - "videoCallsBetaWarning": "Palun arvesta, et videokõned on veel beetajärgus. Nad ei pruugi veel toimida kõikidel platvormidel korrektselt.", - "@videoCallsBetaWarning": {}, - "emailOrUsername": "E-posti aadress või kasutajanimi", - "@emailOrUsername": {}, - "experimentalVideoCalls": "Katselised videokõned", - "@experimentalVideoCalls": {}, - "unsupportedAndroidVersionLong": "See funktsionaalsus eeldab uuemat Androidi versiooni. Palun kontrolli, kas sinu nutiseadmele leidub süsteemiuuendusi või saaks seal Lineage OS'i kasutada.", - "@unsupportedAndroidVersionLong": {}, - "nextAccount": "Järgmine kasutajakonto", - "@nextAccount": {}, - "separateChatTypes": "Eraldi vestlused ja jututoad", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "errorAddingWidget": "Vidina lisamisel tekkis viga.", - "@errorAddingWidget": {}, - "widgetNameError": "Palun sisesta kuvatav nimi.", - "@widgetNameError": {}, - "addWidget": "Lisa vidin", - "@addWidget": {}, - "previousAccount": "Eelmine kasutajakonto", - "@previousAccount": {}, - "widgetUrlError": "See pole korrektne URL.", - "@widgetUrlError": {}, - "widgetName": "Nimi", - "@widgetName": {}, - "widgetCustom": "Kohandatud", - "@widgetCustom": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetEtherpad": "Märkmed ja tekstid", - "@widgetEtherpad": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "switchToAccount": "Pruugi kasutajakontot # {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "youAcceptedTheInvitation": "👍 Sa võtsid kutse vastu", - "@youAcceptedTheInvitation": {}, - "youUnbannedUser": "Sa eemaldasid suhtluskeelu kasutajalt {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Sa oled tühistanud kutse kasutajale {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youBannedUser": "Sa seadsid suhtluskeelu kasutajale {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youJoinedTheChat": "Sa liitusid vestlusega", - "@youJoinedTheChat": {}, - "youKickedAndBanned": "🙅Sa müksasid kasutaja {user} välja ning seadsid talle suhtluskeelu", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "youRejectedTheInvitation": "Sa lükkasid kutse tagasi", - "@youRejectedTheInvitation": {}, - "youKicked": "👞 Sa müksasid kasutaja {user} välja", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Sa saatsid kutse kasutajale {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 {user} saatis sulle kutse", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "publish": "Avalda", - "@publish": {}, - "pleaseEnterRecoveryKey": "Palun sisesta oma taastevõti:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKey": "Taastevõti", - "@recoveryKey": {}, - "users": "Kasutajad", - "@users": {}, - "storeInSecureStorageDescription": "Salvesta taastevõti selle seadme turvahoidlas.", - "@storeInSecureStorageDescription": {}, - "saveKeyManuallyDescription": "Salvesta see krüptovõti kasutades selle süsteemi jagamisvalikuid või lõikelauda.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Vali salvestuskohaks Android KeyStore", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "Vali salvestuskohaks Apple KeyChain", - "@storeInAppleKeyChain": {}, - "recoveryKeyLost": "Kas taasetvõti on kadunud?", - "@recoveryKeyLost": {}, - "pleaseEnterRecoveryKeyDescription": "Vanade sõnumite lugemiseks palun siseta oma varasemas sessioonis loodud taastevõti. Taastamiseks mõeldud krüptovõti EI OLE sinu salasõna.", - "@pleaseEnterRecoveryKeyDescription": {}, - "storeSecurlyOnThisDevice": "Salvesta turvaliselt selles seadmes", - "@storeSecurlyOnThisDevice": {}, - "unlockOldMessages": "Muuda vanad sõnumid loetavaks", - "@unlockOldMessages": {}, - "countFiles": "{count} faili", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "dehydrate": "Ekspordi sessiooni teave ja kustuta nutiseadmest rakenduse andmed", - "@dehydrate": {}, - "dehydrateTor": "TOR'i kasutajad: Ekspordi sessioon", - "@dehydrateTor": {}, - "hydrateTor": "TOR'i kasutajatele: impordi viimati eksporditud sessiooni andmed", - "@hydrateTor": {}, - "hydrateTorLong": "Kui viimati TOR'i võrku kasutasid, siis kas sa eksportisid oma sessiooni andmed? Kui jah, siis impordi nad mugavasti ja jätka suhtlemist.", - "@hydrateTorLong": {}, - "indexedDbErrorTitle": "Brauseri privaatse akna kasutamisega seotud asjaolud", - "@indexedDbErrorTitle": {}, - "dehydrateWarning": "Seda tegevust ei saa tagasi pöörata. Palun kontrolli, et sa oled varukoopia turvaliselt salvestanud.", - "@dehydrateWarning": {}, - "dehydrateTorLong": "Kui oled TOR'i võrgu kasutaja, siis enne akna sulgemist palun ekspordi viimase sessiooni andmed.", - "@dehydrateTorLong": {}, - "indexedDbErrorLong": "Privaatse akna puhul andmete salvestamine vaikimisi pole kasutusel.\nPalun toimi alljärgnevalt:\n- ava about:config\n- määra dom.indexedDB.privateBrowsing.enabled väärtuseks true\nVastasel juhul sa ei saa FluffyChat'i kasutada.", - "@indexedDbErrorLong": {}, - "hydrate": "Taasta varundatud failist", - "@hydrate": {}, - "user": "Kasutaja", - "@user": {}, - "custom": "Kohandatud", - "@custom": {}, - "confirmMatrixId": "Konto kustutamiseks palun kinnitage oma Matrix'i ID.", - "@confirmMatrixId": {}, - "supposedMxid": "See peaks olema {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasgroup": "Märgi vestlusrühmaks", - "@commandHint_markasgroup": {}, - "commandHint_markasdm": "Märgi otsevestusluseks antud Matrixi ID jaoks", - "@commandHint_markasdm": {}, - "whyIsThisMessageEncrypted": "Miks see sõnum pole loetav?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "See võib juhtuda, kui sõnum oli saadetud enne, kui siin seadmes oma kontoga sisse logisid.\n\nSamuti võib juhtuda siis, kui saatja on lugemises selles seadmes blokeerinud või on tekkinud tõrkeid veebiühenduses.\n\nAga mõnes teises seadmes saad seda sõnumit lugeda? Siis sa võid sõnumi sealt üle tõsta. Ava Seadistused -> Seadmed ning kontrolli, et kõik sinu seadmed on omavahel verifitseeritud. Kui avad selle vestluse või jututoa ning mõlemad sessioonid on avatud, siis vajalikud krüptovõtmed saadetakse automaatset.\n\nKas sa soovid vältida krüptovõtmete kadumist väljalogimisel ja seadmete vahetusel? Siis palun kontrolli, et seadistuses on krüptovõtmete varundus sisse lülitatud.", - "@noKeyForThisMessage": {}, - "callingPermissions": "Helistamise õigused", - "@callingPermissions": {}, - "callingAccountDetails": "Võimaldab FluffyChat'il kasutada Androidi helistamisrakendust.", - "@callingAccountDetails": {}, - "appearOnTop": "Luba pealmise rakendusena", - "@appearOnTop": {}, - "otherCallingPermissions": "Mikrofoni, kaamera ja muud FluffyChat'i õigused", - "@otherCallingPermissions": {}, - "newGroup": "Uus jututuba", - "@newGroup": {}, - "newSpace": "Uus kogukond", - "@newSpace": {}, - "enterSpace": "Sisene kogukonda", - "@enterSpace": {}, - "enterRoom": "Ava jututuba", - "@enterRoom": {}, - "appearOnTopDetails": "Sellega lubad rakendust avada kõige pealmisena (pole vajalik, kui Fluffychat on juba seadistatud toimima helistamiskontoga)", - "@appearOnTopDetails": {}, - "callingAccount": "Helistamiskonto", - "@callingAccount": {}, - "screenSharingTitle": "ekraani jagamine", - "@screenSharingTitle": {}, - "foregroundServiceRunning": "See teavitus toimib siis, kui esiplaaniteenus töötab.", - "@foregroundServiceRunning": {}, - "allSpaces": "Kõik kogukonnad", - "@allSpaces": {}, - "screenSharingDetail": "Sa jagad oma ekraani FuffyChat'i vahendusel", - "@screenSharingDetail": {}, - "numChats": "{number} vestlust", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Peida väheolulised olekuteated", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Ära näita uuesti", - "@doNotShowAgain": {}, - "commandHint_cuddle": "Saada üks kaisutus", - "@commandHint_cuddle": {}, - "commandHint_hug": "Saada üks kallistus", - "@commandHint_hug": {}, - "googlyEyesContent": "{senderName} saatis sulle otsivad silmad", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} kaisutab sind", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} kallistab sind", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_googly": "Saada ühed otsivad silmad", - "@commandHint_googly": {}, - "wasDirectChatDisplayName": "Sõnumiteta vestlus (vana nimega {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "startFirstChat": "Alusta oma esimest vestlust", - "@startFirstChat": {}, - "encryptThisChat": "Krüpti see vestlus", - "@encryptThisChat": {}, - "disableEncryptionWarning": "Kui vestluses on krüptimine kasutusele võetud, siis turvalisuse huvides ei saa seda hiljem välja lülitada.", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "Vabandust... see ei ole võimalik", - "@sorryThatsNotPossible": {}, - "deviceKeys": "Seadme võtmed:", - "@deviceKeys": {}, - "newSpaceDescription": "Kogukonnad võimaldavad sul koondada erinevaid vestlusi ning korraldada avalikku või privaatset ühistegevust.", - "@newSpaceDescription": {}, - "reopenChat": "Alusta vestlust uuesti", - "@reopenChat": {}, - "noOtherDevicesFound": "Muid seadmeid ei leidu", - "@noOtherDevicesFound": {}, - "noBackupWarning": "Hoiatus! Kui sa ei lülita sisse vestluse varundust, siis sul puudub hiljem ligipääs krüptitud sõnumitele. Me tungivalt soovitame, et palun lülita vestluse varundamine sisse enne väljalogimist.", - "@noBackupWarning": {}, - "fileIsTooBigForServer": "Serveri seadistuste alusel on see fail saatmiseks liiga suur.", - "@fileIsTooBigForServer": {}, - "fileHasBeenSavedAt": "Fail on salvestatud kausta: {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Liigu viimase loetud sõnumini", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Siiamaani on loetud", - "@readUpToHere": {}, - "jump": "Hüppa", - "@jump": {}, - "openLinkInBrowser": "Ava link veebibrauseris", - "@openLinkInBrowser": {}, - "report": "teata", - "@report": {}, - "allRooms": "Kõik vestlusrühmad", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "😭 Oh appike! Midagi läks valesti. Kui soovid, võid sellest veast arendajatele teatada.", - "@reportErrorDescription": {}, - "signInWithPassword": "Logi sisse salasõnaga", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Palun proovi hiljem uuesti või muuda serveri nime.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "Logi sisse kasutades teenusepakkujat {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "importFromZipFile": "Impordi zip-failist", - "@importFromZipFile": {}, - "exportEmotePack": "Ekspordi emotikonide pakk zip-failina", - "@exportEmotePack": {}, - "replace": "Asenda", - "@replace": {}, - "notAnImage": "See pole pildifail.", - "@notAnImage": {}, - "importNow": "Impordi kohe", - "@importNow": {}, - "importEmojis": "Impordi emojid", - "@importEmojis": {}, - "sendTypingNotifications": "Saada kirjutamise teavitusi", - "@sendTypingNotifications": {}, - "createGroup": "Loo vestlusrühm", - "@createGroup": {}, - "setTheme": "Vali teema:", - "@setTheme": {}, - "inviteContactToGroupQuestion": "Kas sa soovid kutsuda kasutajat {contact} „{groupName}“ jututuppa?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "Proovi uuesti", - "@tryAgain": {}, - "chatPermissions": "Vestluse õigused", - "@chatPermissions": {}, - "chatDescription": "Vestluse kirjeldus", - "@chatDescription": {}, - "noChatDescriptionYet": "Vestluse kirjeldus on puudu.", - "@noChatDescriptionYet": {}, - "optionalRedactReason": "(Kui soovid lisada) Sõnumi muutmise põhjus...", - "@optionalRedactReason": {}, - "messagesStyle": "Sõnumid:", - "@messagesStyle": {}, - "shareInviteLink": "Jaga kutse linki", - "@shareInviteLink": {}, - "directChat": "Otsevestlus", - "@directChat": {}, - "setChatDescription": "Lisa vestluse kirjeldus", - "@setChatDescription": {}, - "profileNotFound": "Sellist kasutajat serveris ei leidu. Tegemist võib olla kas võrguühenduse probleemiga või sellist kasutajat tõesti pole olemas.", - "@profileNotFound": {}, - "setColorTheme": "Vali värviteema:", - "@setColorTheme": {}, - "invite": "Kutsu", - "@invite": {}, - "invalidServerName": "Vigane serveri nimi", - "@invalidServerName": {}, - "addChatDescription": "Lisa vestluse kirjeldus...", - "@addChatDescription": {}, - "chatDescriptionHasBeenChanged": "Vestluse kirjeldus on muutunud", - "@chatDescriptionHasBeenChanged": {}, - "redactMessageDescription": "Sõnumi muudatus kehtib kõikidele vestluses osalejatele. Seda muudatust ei saa tagasi pöörata.", - "@redactMessageDescription": {}, - "redactedBy": "Muutja: {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactedByBecause": "Muutja {username} märkis põhjuseks: „{reason}“", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "inviteGroupChat": "📨 Kutsu vestlusrühma", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Kutsu omavahelisele vestlusele", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "Hiljuti kasutatud emotikonid kuvame siin...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "invalidInput": "Vigane sisend!", - "@invalidInput": {}, - "wrongPinEntered": "Sisestasid vale PIN-koodi! Proovi uuesti {seconds} sekundi pärast...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "banUserDescription": "Sellele kasutajale on nüüd selles jututoas seatud suhtluskeeld ning ta ei saa vestluses osaleda seni, kuni suhtluskeeld pole eemaldatud.", - "@banUserDescription": {}, - "removeDevicesDescription": "Sind logitakse sellest seadmest välja ja sa enam ei saa sõnumeid.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "Uuesti proovimisel saab see kasutaja nüüd vestlusega liituda.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Tõuketeavitused pole saadaval", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Kui annad sellele kasutajale peakasutaja õigused, siis kuna tal on sinuga samad õigused, sa ei saa seda toimingut enam tagasi pöörata.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Selle vestluse tõstame nüüd arhiivi. Muud osalejad näevad, et sa oled vestlusest lahkunud.", - "@archiveRoomDescription": {}, - "hasKnocked": "🚪{user} on jututoa uksele koputanud", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "learnMore": "Loe lisaks", - "@learnMore": {}, - "roomUpgradeDescription": "See vestlus luuakse nüüd uuesti jututoa uue versioonina. Kõik senised osalejad saavad teate, et nad peavad liituma uue vestlusega. Jututubade versioonide kohta leiad teavet https://spec.matrix.org/latest/rooms/ lehelt", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Palun sisesta 0'st suurem number", - "@pleaseEnterANumber": {}, - "kickUserDescription": "See kasutaja on nüüd jutuoast välja müksatud, kuid talle pole seatud suhtluskeeldu. Avaliku jututoa puhul saab ta alati uuesti liituda.", - "@kickUserDescription": {}, - "blockListDescription": "Sul on võimalik blokeerida neid kasutajaid, kes sind segavad. Oma isiklikku blokerimisloendisse lisatud kasutajad ei saa sulle saata sõnumeid ega kutseid.", - "@blockListDescription": {}, - "createGroupAndInviteUsers": "Lisavestlusrühm ja kutsu sinna kasutajaid", - "@createGroupAndInviteUsers": {}, - "startConversation": "Alusta vestlust", - "@startConversation": {}, - "blockedUsers": "Blokeeritud kasutajad", - "@blockedUsers": {}, - "groupCanBeFoundViaSearch": "Vestlusrühm on leitav otsinguga", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "Päringuga „{query}“ ei leidunud kahkus ühtegi kasutajat. Palun kontrolli, et päringus poleks vigu.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "block": "Blokeeri", - "@block": {}, - "yourGlobalUserIdIs": "Sinu üldine kasutajatunnus on: ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "Saada json oma algupärasel kujul", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Vabandust..., see ei tundu olema korrektne taastevõti.", - "@wrongRecoveryKey": {}, - "blockUsername": "Eira kasutajanime", - "@blockUsername": {}, - "groupName": "Vestlusrühma nimi", - "@groupName": {}, - "databaseMigrationTitle": "Andmebaas on optimeeritud", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "Otsi #vestlusi, @kasutajaid...", - "@searchChatsRooms": {}, - "databaseMigrationBody": "Palun oota üks hetk. Natuke võib kuluda aega.", - "@databaseMigrationBody": {}, - "thisDevice": "See seade:", - "@thisDevice": {}, - "publicSpaces": "Avalikud kogukonnad", - "@publicSpaces": {}, - "passwordIsWrong": "Sinu sisestatud salasõna on vale", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Palun sisesta oma praegune salasõna", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "Avalik link", - "@publicLink": {}, - "nothingFound": "Ei leidnud mitte midagi...", - "@nothingFound": {}, - "decline": "Keeldu", - "@decline": {}, - "newPassword": "Uus salasõna", - "@newPassword": {}, - "passwordsDoNotMatch": "Salasõnad ei klapi omavahel", - "@passwordsDoNotMatch": {}, - "subspace": "Jututuba või alamkogukond", - "@subspace": {}, - "select": "Vali", - "@select": {}, - "pleaseChooseAStrongPassword": "Palun sisesta korralik salasõna", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "Lisa vestlus või jututuba", - "@addChatOrSubSpace": {}, - "leaveEmptyToClearStatus": "Senise oleku eemaldamiseks jäta väärtus tühjaks.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Liitu kogukonnaga", - "@joinSpace": {}, - "searchForUsers": "Otsi kasutajat @kasutajanimi ...", - "@searchForUsers": {}, - "databaseBuildErrorBody": "SQlite andmebaasi loomine ei õnnestu. Seetõttu üritab rakendus kasutada senist andmehoidlat. Palun teata sellest veast arendajatele siin: {url} märkides veateate: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "Rakenduse käivitamisel tekkis viga", - "@initAppError": {}, - "sessionLostBody": "Sinu sessioon on kadunud. Palun teata sellest veast arendajatele siin: {url} märkides veateate: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "Nüüd üritab rakendus taastada sinu sessiooni varukoopiast. Palun teata sellest veast arendajatele siin: {url} märkides veateate: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "transparent": "Läbipaistev", - "@transparent": {}, - "youInvitedToBy": "📩 Sa oled lingiga saanud kutse jututuppa:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "sendReadReceipts": "Saada lugemisteatisi", - "@sendReadReceipts": {}, - "verifyOtherUserDescription": "Kui sa oled vestluse teise osapoole verifitseerinud, siis saad kindel olla, et tead, kellega suhtled. 💪\n\nKui alustad verifitseerimist, siis sinul ja teisel osapoolel tekib rakenduses hüpikaken. Seal kuvatakse emotikonide või numbrite jada, mida peate omavahel võrdlema.\n\nKõige lihtsam on seda teha kas omavahelise kohtumise ajal või videokõne kestel. 👭", - "@verifyOtherUserDescription": {}, - "forwardMessageTo": "Kas edastame sõnumi jututuppa {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendTypingNotificationsDescription": "Muud vestluses osalejad saavad näha, kui sa oled uut sõnumit kirjutamas.", - "@sendTypingNotificationsDescription": {}, - "sendReadReceiptsDescription": "Muud vestluses osalejad näevad, kas oled sõnumit lugenud.", - "@sendReadReceiptsDescription": {}, - "formattedMessages": "Vormindatud sõnumid", - "@formattedMessages": {}, - "verifyOtherUser": "🔐 Verifitseeri teine kasutaja", - "@verifyOtherUser": {}, - "verifyOtherDevice": "🔐 Verifitseeri oma muu seade", - "@verifyOtherDevice": {}, - "canceledKeyVerification": "{sender} katkestas krüptovõtmete verifitseerimise", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} sai valmis krüptovõtmete verifitseerimise", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "formattedMessagesDescription": "Kasutades markdown-süntaksit kuva vormindust, nagu rasvases kirjas tekst.", - "@formattedMessagesDescription": {}, - "verifyOtherDeviceDescription": "Kui sa oled oma muu seadme verifitseerinud, siis need seadmed võivad vahetada krüptovõtmeid ning see parandab üldist turvalisust. 💪 Kui alustad verifitseerimist, siis sinu mõlemas seadmes tekib rakenduses hüpikaken. Seal kuvatakse emotikonide või numbrite jada, mida pead omavahel võrdlema. On oluline, et mõlemad seadmed on verifitseerimise alustamisel sinu kõrval. 🤳", - "@verifyOtherDeviceDescription": {}, - "acceptedKeyVerification": "{sender} nõustus krüptovõtmete verifitseerimisega", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} on valmis krüptovõtmete verifitseerimiseks", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} palus krüptovõtmete verifitseerimist", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} alustas krüptovõtmete verifitseerimist", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "presenceStyle": "Olekuteated:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Näita teiste kasutajate olekuteateid", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "incomingMessages": "Saabuvad sõnumid", - "@incomingMessages": {}, - "hidePresences": "Peida olekute loend?", - "@hidePresences": {}, - "stickers": "Kleepsud", - "@stickers": {}, - "discover": "Otsi ja leia", - "@discover": {}, - "commandHint_ignore": "Eira seda Matrixi kasutajatunnust", - "@commandHint_ignore": {}, - "commandHint_unignore": "Lõpeta selle Matrixi kasutajatunnuse eiramine", - "@commandHint_unignore": {}, - "unreadChatsInApp": "{appname}: {unread} lugemata vestlust", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "globalChatId": "Üldine vestluse tunnus", - "@globalChatId": {}, - "accessAndVisibilityDescription": "Kes võib selle vestlusega liituda ja kuidas on võimalik seda vestlust leida.", - "@accessAndVisibilityDescription": {}, - "hideRedactedMessagesBody": "Kui keegi muudab sõnumit, siis teda enam ei kuvataks vestluses.", - "@hideRedactedMessagesBody": {}, - "userWouldLikeToChangeTheChat": "{user} soovib liituda vestlusega.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "hideMemberChangesInPublicChats": "Peida avalike vestluste liikmelisuse muutused", - "@hideMemberChangesInPublicChats": {}, - "notifyMeFor": "Teavita mind kui", - "@notifyMeFor": {}, - "usersMustKnock": "Kasutajad peavad uksele koputama", - "@usersMustKnock": {}, - "noOneCanJoin": "Mitte keegi ei saa liituda", - "@noOneCanJoin": {}, - "knocking": "Koputus uksele", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Vestluse või jututoa saad leida otsingust serveris {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "publicChatAddresses": "Vestluse avalik aadress", - "@publicChatAddresses": {}, - "minimumPowerLevel": "{level} on väikseim võimalik õiguste tase.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "noDatabaseEncryption": "Andmebaasi krüptimine pole sellel platvormil toetatud", - "@noDatabaseEncryption": {}, - "noPublicLinkHasBeenCreatedYet": "Avalikult kasutatavat linki pole veel olemas", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "Koputa uksele", - "@knock": {}, - "appLockDescription": "Kui sa rakendust parasjagu ei kasuta, siis lukusta ta PIN-koodiga", - "@appLockDescription": {}, - "accessAndVisibility": "Ligipääsetavus ja nähtavus", - "@accessAndVisibility": {}, - "calls": "Kõned", - "@calls": {}, - "customEmojisAndStickers": "Kohandatud emotikonid ja kleepsud", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Lisa või jaga kohandatud emotikone või kleepsupakke, mida võiks kasutada igas vestluses.", - "@customEmojisAndStickersBody": {}, - "hideRedactedMessages": "Peida muudetud sõnumid", - "@hideRedactedMessages": {}, - "hideInvalidOrUnknownMessageFormats": "Peida vigase või tundmatu vorminguga sõnumid", - "@hideInvalidOrUnknownMessageFormats": {}, - "hideMemberChangesInPublicChatsBody": "Parema loetavuse nimel ära näita vestluse ajajoonel avaliku jututoaga liitumisi ja sealt lahkumisi.", - "@hideMemberChangesInPublicChatsBody": {}, - "overview": "Ülevaade", - "@overview": {}, - "passwordRecoverySettings": "Salasõna taastamise seadistused", - "@passwordRecoverySettings": {}, - "createNewAddress": "Loo uus aadress", - "@createNewAddress": {}, - "userRole": "Kasutaja roll", - "@userRole": {}, - "thereAreCountUsersBlocked": "Hetkel on {count} blokeeritud kasutajat.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "searchIn": "Otsi vestlusest „{chat}“...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Otsi veel...", - "@searchMore": {}, - "knockRestricted": "Koputa piiratud ligipääsuga jututoa uksele", - "@knockRestricted": {}, - "restricted": "Piiratud", - "@restricted": {}, - "gallery": "Galerii", - "@gallery": {}, - "files": "Failid", - "@files": {}, - "swipeRightToLeftToReply": "Vastamiseks viipa paremalt vasakule", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_eu.arb b/assets/l10n/intl_eu.arb deleted file mode 100644 index bb7b8dfa2..000000000 --- a/assets/l10n/intl_eu.arb +++ /dev/null @@ -1,2708 +0,0 @@ -{ - "@@locale": "eu", - "@@last_modified": "2021-08-14 12:41:10.062383", - "about": "Honi buruz", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Onartu", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username}(e)k gonbidapena onartu du", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Kontua", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username}(e)k ertzetik ertzerako zifraketa gaitu du", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "Administratzailea", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "ezizena", - "@alias": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName}(e)k deia erantzun du", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Edonor batu daiteke", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "Fitxategia", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Batu daitezke bisitan dauden erabiltzaileak?", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Ziur zaude?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Beste pertsona egiaztatzeko, sartu zure biltegiratze segururako pasaesaldia edo berreskuratze-gakoa.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "{username}(r)en egiaztaketa-eskaera onartu?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banFromChat": "Txatera batzeko debekua ezarri", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Kanporatuta", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username}(e)k {targetName}(r)i debekua ezarri dio", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blokeatu gailua", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "cancel": "Utzi", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username}(e)k txataren abatarra aldatu du", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username}(e)k txataren deskribapena aldatu du: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username}(e)k txataren izena '{chatname}'(e)ra aldatu du", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username}(e)k txataren baimenak aldatu ditu", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username}(e)k bere ezizena aldatu du. Aurrerantzean '{displayname}' izango da", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username}(e)k bisitarien sarbide-arauak aldatu ditu", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username}(e)k bisitarien arauak aldatu ditu: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username}(e)k historiaren ikusgaitasuna aldatu du", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username}(e)k historiaren ikusgaitasuna {rules}-(e)ra aldatu du", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username}(e)k batzeko arauak aldatu ditu", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username}(e)k batzeko arauak aldatu ditu: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username}(e)k profileko abatarra aldatu du", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username}(e)k gelaren ezizena aldatu du", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username}(e)k gonbidapen-esteka aldatu du", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeTheHomeserver": "Aldatu zerbitzaria", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Aldatu itxura", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Taldearen izena aldatu", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Zifraketa hondatu egin da", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Txata", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Txataren xehetasunak", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Aukeratu pasahitz sendo bat", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Itxi", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Konparatu emojiak", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Konparatu zenbakiak", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Baieztatu", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Konektatu", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontaktua taldera gonbidatu da", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Arbelera kopiatu da", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopiatu", - "@copy": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Ezin izan da mezua deszifratu: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} partaide", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Sortu", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username}(e)k txata sortu du", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Une honetan aktibo", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Iluna", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{month}/{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{year}/{month}/{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "delete": "Ezabatu", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Mezuak ezabatu", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Gailua", - "@device": { - "type": "text", - "placeholders": {} - }, - "devices": "Gailuak", - "@devices": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Ezizena aldatu da", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Deskargatu fitxategia", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Editatu ezizena", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emotea badago lehendik ere!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Emotearen laburdura ez da baliozkoa!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emote-ezarpenak", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Laburdura", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Emote-laburdura eta irudi bat aukeratu behar dituzu!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Txata hutsik dago", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Ezingo duzu zifraketa ezgaitu. Ziur zaude?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encryption": "Zifraketa", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Zifraketa ez dago gaituta", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName}(e)k deia amaitu du", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterYourHomeserver": "Sartu zure zerbitzaria", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "fileName": "Fitxategiaren izena", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Birbidali", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Batzeaz geroztik", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Gonbidapenaz geroztik", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "Taldea", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Taldea publikoa da", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "{displayname} duen taldea", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Ez, bisitariak ez daude baimenduta", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Bai, bisitariak batu daitezke", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username}(e)k {targetName}(r)en gonbidapena atzera bota du", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Laguntza", - "@help": { - "type": "text", - "placeholders": {} - }, - "id": "IDa", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identitatea", - "@identity": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Pasaesaldi edo berreskuratze-gakoa ez da zuzena", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Kontaktuak gonbidatu", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Gonbidatu kontaktua {groupName}(e)ra", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Gonbidatuta", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username}(e)k {targetName} gonbidatu du", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Gonbidatutako erabiltzaileak solik", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username}(e)k FluffyChatera gonbidatu zaitu.\n1. Bisitatu https://fluffychat.im eta instalatu aplikazioa\n2. Eman izena edo hasi saioa\n3. Ireki gonbidapen-esteka:\n{link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "idazten ari da…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} txatera batu da", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Batu gelara", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username}(e)k {targetName} kanporatu du", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username}(e)k {targetName} kanporatu eta debekua ezarri dio", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Txatetik kanporatu", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Azkenekoz aktibo: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Irten", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Txatetik irten da", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Lizentzia", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Argia", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Kargatu {count} partaide gehiago", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Kargatzen… itxaron.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Kargatu gehiago…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Hasi saioa", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Hasi saioa {homeserver}(e)n", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Amaitu saioa", - "@logout": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderatzailea", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Mututu txata", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Kontuan izan oraingoz Pantalaimon behar duzula puntuz puntuko zifraketarako.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Mezu berria FluffyChaten", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Egiaztaketa-eskaera berria!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "no": "Ez", - "@no": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Ez da emoterik aurkitu. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Ez dirudi Firebase Cloud Messaging zure mugikorrean erabilgarri dagoenik. Jakinarazpenak jasotzeko ntfy instalatzea gomendatzen dugu. ntfy edo beste Unified Push hornitzaileren batekin, push jakinarazpenak jaso ditzazkezu datuentzako segurua den modu batean. ntfy PlayStore edo F-Droid dendetatik deskarga dezakezu.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Bat ere ez", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Baimenik gabe", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Ez da gelarik aurkitu…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "ok": "Ados", - "@ok": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Gakoen online babeskopia gaituta dago", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Hara, zerbaitek huts egin du…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Ireki aplikazioa mezuak irakurtzeko", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Ireki kamera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "pasaesaldia edo berreskuratze-gakoa", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Pasahitza", - "@password": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Aukeratu irudi bat", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Finkatu", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Abiarazi {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseEnterYourPassword": "Sartu zure pasahitza", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Sartu zure erabiltzaile-izena", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Gela publikoak", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "recording": "Grabatzen", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username}(e)k gertaera bat atzera bota du", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Baztertu", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username}(e)k gonbidapena baztertu du", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Batu berriro", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Kendu", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Kendu gainerako gailu guztiak", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "{username}(e)k kendu du", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Kendu gailua", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Kendu txatean duen debekua", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Kargatu mezu aberatseko edukia", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "Erantzun", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Eskatu baimena", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Gela bertsio-berritu da", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "{username}(e)k ikusi du", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Bidali", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Bidali mezua", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Bidali audioa", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Bidali fitxategia", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Bidali irudia", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Bidali jatorrizkoa", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Bidali bideoa", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username}(e)k fitxategia bidali du", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username}(e)k audioa bidali du", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username}(e)k irudia bidali du", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username}(e)k pegatina bidali du", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username}(e)k bideoa bidali du", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName}(e)k deiaren informazioa bidali du", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setInvitationLink": "Gonbidapen-esteka ezarri", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Ezarri egoera", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Ezarpenak", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Partekatu", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username}(e)k kokapena partekatu du", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "skip": "Saltatu", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Iturburu kodea", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName}(e)k deia hasi du", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "statusExampleMessage": "Zer moduz zaude gaur?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Bidali", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistemak darabilena", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Ez datoz bat", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Bat datoz", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Saiatu berriro bidaltzen", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username}(e)k {targetName}(r)i debekua kendu dio", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Desblokeatu gailua", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Gailu ezezaguna", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Zifraketa-algoritmo ezezaguna", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "'{type}' gertaera ezezaguna", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Utzi txata mututzeari", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Utzi finkatzeari", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "userAndOthersAreTyping": "{username} eta beste {count} idazten ari dira…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} eta {username2} idazten ari dira…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} idazten ari da…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username}(e)k txata utzi du", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Erabiltzaile-izena", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username}(e)k {type} gertaera bat bidali du", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "Egiaztatu", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Abiarazi egiaztaketa", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Ondo egiaztatu duzu!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Beste kontua egiaztatzen", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Bideo-deia", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Txat-historiaren ikusgaitasuna", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Partaide guztientzat ikusgai", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Edonorentzat ikusgai", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Ahozko mezua", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Kideak eskaera onartuko zain…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Kideak emojia onartuko zain…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Kideak zenbakiak onartuko zain…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Horma-irudia:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Nor batu daiteke talde honetara?", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Idatzi mezua…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Bai", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Zeu", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Ez duzu txat honetan parte hartzen honezkero", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Txat honetan debekua ezarri dizute", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Editatu gelaren aliasak", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "chats": "Txatak", - "@chats": { - "type": "text", - "placeholders": {} - }, - "emojis": "Emojiak", - "@emojis": {}, - "placeCall": "Egin deia", - "@placeCall": {}, - "voiceCall": "Ahozko deia", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Android bertsioa ez da bateragarria", - "@unsupportedAndroidVersion": {}, - "unsupportedAndroidVersionLong": "Funtzio honek Android bertsio berriago bat behar du. Egiaztatu eguneraketak ote dauden edo begiratu Lineage OS-ek zure gailuarentzat aukerarik eskaintzen duen.", - "@unsupportedAndroidVersionLong": {}, - "commandHint_ban": "Debekatu erabiltzailea gela honetan", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_clearcache": "Ezabatu katxea", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Sortu taldeko-txat huts bat\nErabili --no-encyption zifratzea desgaitzeko", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_op": "Zehaztu erabiltzaile honen botere-maila (defektuz: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Bidali formaturik gabeko testua", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Bidali erantzuna erreakzio gisa", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Bidali testua", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "createNewSpace": "Gune berria", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Editatu blokeatutako zerbitzariak", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Gelaren abatarra editatu", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Zifratuta", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "enterAnEmailAddress": "Sartu helbide elektroniko bat", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Zerbitzaria", - "@homeserver": {}, - "errorObtainingLocation": "Errorea kokapena lortzerakoan: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Dena prest!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Izugarri iraingarria", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Joan gela berrira", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "groups": "Taldeak", - "@groups": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Ezkutatu atzera botatako gertaerak", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Ezkutatu gertaera ezezagunak", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Niretzako gonbidapenak", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Gaitu kontu honentzako jakinarazpenak", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} erabiltzaile idazten ari dira…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "notifications": "Jakinarazpenak", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "Zure gailuetako batek saioa amaitu du", - "@oneClientLoggedOut": {}, - "addAccount": "Gehitu kontua", - "@addAccount": {}, - "editBundlesForAccount": "Editatu kontu honetarako sortak", - "@editBundlesForAccount": {}, - "oopsPushError": "Hara! Zoritxarrez, errore bat gertatu da push jakinarazpenak ezartzerakoan.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Aukeratu", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Gorde fitxategia", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Single Sign on", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{irakurri gabeko txat 1} other {irakurri gabeko {unreadCount} txat}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "videoCallsBetaWarning": "Kontuan izan bideo-deiak beta fasean daudela. Litekeena da behar bezala erabili ezin izatea —erabili ahal badira—.", - "@videoCallsBetaWarning": {}, - "toggleMuted": "Ikusi / Ezkutatu mutututakoak", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "all": "Guztia", - "@all": { - "type": "text", - "placeholders": {} - }, - "next": "Hurrengoa", - "@next": { - "type": "text", - "placeholders": {} - }, - "experimentalVideoCalls": "Bideo-dei esperimentalak", - "@experimentalVideoCalls": {}, - "emailOrUsername": "ePosta edo erabiltzaile-izena", - "@emailOrUsername": {}, - "enableMultiAccounts": "(BETA) Gaitu kontu bat baino gehiago gailu honetan", - "@enableMultiAccounts": {}, - "openVideoCamera": "Ireki kamera bideorako", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "removeFromBundle": "Kendu sorta honetatik", - "@removeFromBundle": {}, - "serverRequiresEmail": "Zerbitzari honek zure posta elektronikoa egiaztatu behar du izena eman dezazun.", - "@serverRequiresEmail": {}, - "or": "Edo", - "@or": { - "type": "text", - "placeholders": {} - }, - "link": "Esteka", - "@link": {}, - "privacy": "Pribatutasuna", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Bota mezua atzera", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Eman izena", - "@register": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Jarraitu webguneko argibideak eta sakatu 'Hurrengoa'.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "reason": "Arrazoia", - "@reason": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Salatu mezua", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "status": "Egoera", - "@status": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Zure gako publikoa", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "messageType": "Mezu mota", - "@messageType": {}, - "time": "Ordua", - "@time": {}, - "dismiss": "Baztertu", - "@dismiss": {}, - "switchToAccount": "Aldatu {number} kontura", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "previousAccount": "Aurreko kontua", - "@previousAccount": {}, - "edit": "Editatu", - "@edit": { - "type": "text", - "placeholders": {} - }, - "mention": "Aipatu", - "@mention": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Idatzi berriro pasahitza", - "@repeatPassword": {}, - "addEmail": "Gehitu ePosta", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Ziur zaude saioa amaitu nahi duzula?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopiatu arbelera", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Ez ikusia egindako erabiltzaileak", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "security": "Segurtasuna", - "@security": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "Automatikoki abiarazi pegatina eta emote animatuak", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "sendOnEnter": "Bidali enter sakatuz", - "@sendOnEnter": {}, - "badServerVersionsException": "Zerbitzariak ondorengo ezaugarriak onartzen ditu:\n{serverVersions}\nBaina aplikazioak hauek onartzen ditu bakarrik: {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "botMessages": "Boten mezuak", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Ezin da {uri} URIa ireki", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Aldatu gailuaren izena", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changePassword": "Aldatu pasahitza", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Aldatu abatarra", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Txataren babeskopia", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Txat zaharrak berreskuratze-gako batekin daude babestuta. Ez galdu gako hori.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Txata gune honetara gehitu da", - "@chatHasBeenAddedToThisSpace": {}, - "configureChat": "Txata konfiguratu", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Edukia zerbitzariko administrariei jakinarazi zaie", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Kideen aldaketak", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Ezarri alias nagusi bezala", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Ezarri zure emoteak", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "appLock": "Aplikazioa blokeatzea", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Gehitu gunera", - "@addToSpace": {}, - "allChats": "Txat guztiak", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "Zerbitzariak ondorengo aukerak onartzen ditu saioa hasteko:\n{serverVersions}\nBaina aplikazioak hauek onartzen ditu bakarrik:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "commandHint_dm": "Hasi banakako txat bat\nErabili --no-encyption zifratzea desgaitzeko", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_leave": "Utzi gela hau", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "blocked": "Blokeatuta", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "commandInvalid": "Komandoa ez da baliozkoa", - "@commandInvalid": { - "type": "text" - }, - "commandHint_myroomnick": "Ezarri zure ezizena gela honetarako", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "ignore": "Ezikusi", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Erabiltzaile-izena dauka", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Ezizena dauka", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Kokapen zerbitzuak ezgaituta daude. Gaitu zure kokapena partekatu ahal izateko.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "directChats": "Banakako txatak", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Gaitu zifraketa", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Estekan sakatu dut", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Oraindik ez duzu pasahitza berreskuratzeko modurik gehitu.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "online": "Linean", - "@online": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Push arauak", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Sartu lau zenbaki edo utzi hutsik aplikazioa babestu nahi ez baduzu.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Ordezkatu gela bertsio berriago batekin", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "search": "Bilatu", - "@search": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Helbide hauekin pasahitza berreskuratu dezakezu.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Zergatik salatu nahi duzu?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "videoWithSize": "Bideoa ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "openGallery": "Ireki bilduma", - "@openGallery": {}, - "pinMessage": "Finkatu gelan", - "@pinMessage": {}, - "reactedWith": "{sender}(e)k {reaction}(r)ekin erreakzionatu du", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "confirmEventUnpin": "Ziur zaude gertaera finaktzeari utzi nahi diozula?", - "@confirmEventUnpin": {}, - "nextAccount": "Hurrengo kontua", - "@nextAccount": {}, - "markAsRead": "Markatu irakurritzat", - "@markAsRead": {}, - "yourChatBackupHasBeenSetUp": "Txaten babeskopiak ezarri dira.", - "@yourChatBackupHasBeenSetUp": {}, - "clearArchive": "Ezabatu artxiboa", - "@clearArchive": {}, - "commandHint_html": "Bidali testua HTML formatuan", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Gonbidatu erabiltzailea gela honetara", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Batu gelara", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Kendu erabiltzaile hori gela honetatik", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_me": "Deskribatu zure burua", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Ezarri zure irudia gela honetarako (mxc-uri bidez)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_unban": "Kendu erabiltzaileak gela honetan duen debekua", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandMissing": "{command} ez da komandoa.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "commandHint_discardsession": "Baztertu saioa", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "deactivateAccountWarning": "Honek zure kontua desaktibatuko du. Ezin da desegin! Ziur zaude?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Defektuzko botere-maila", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Ezabatu kontua", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Gailuaren IDa", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Gelarako emote-sortak", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Gaitu emote-sorta txat guztietarako", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Letraren tamaina", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Zenbaterainoko iraingarria da eduki hau?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Ez da iraingarria", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Kokapen baimena ukatu da. Eman zure kokapena partekatzeko baimena.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "messages": "Mezuak", - "@messages": { - "type": "text", - "placeholders": {} - }, - "newChat": "Txat berria", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Ez dago konexiorik zerbitzariarekin", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Zifraketa aktiba dezakezu soilik gelak publikoa izateari utzi badio.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} ez da matrix zerbitzari bat, {server2} erabili nahi duzu haren ordez?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "scanQrCode": "Eskaneatu QR kodea", - "@scanQrCode": {}, - "obtainingLocation": "Kokapena atzitzen…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Iraingarria", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Lineaz kanpo", - "@offline": { - "type": "text", - "placeholders": {} - }, - "addToBundle": "Gehitu sortara", - "@addToBundle": {}, - "bundleName": "Sortaren izena", - "@bundleName": {}, - "openInMaps": "Ireki mapen aplikazioan", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "participant": "Partaide", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Pasahitza ahaztu dut", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Pasahitza aldatu da", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Pasahitzaren berreskurapena", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Jendea", - "@people": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Aukeratu sartzeko kode bat", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Sakatu ePostako estekan eta ondoren jarraitu.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Sartu zure PINa", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Kendu zure abatarra", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Gelaren bertsioa", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Bidali testu bezala", - "@sendAsText": { - "type": "text" - }, - "sendMessages": "Mezuak bidali", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Bidali pegatina", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Ezarri baimen-maila", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Partekatu kokapena", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Erakutsi pasahitza", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Gunea publikoa da", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Gunearen izena", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Sinkronizatzen… itxaron.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Ikusi / Ezkutatu gogokoak", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Markatu irakurrita / irakurri gabe", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Eskaera gehiegi. Saiatu berriro geroago!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Beste gailu batetik transferitu", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Ez dago eskuragai", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unverified": "Egiaztatu gabe(a)", - "@unverified": {}, - "verified": "Egiaztatuta", - "@verified": { - "type": "text", - "placeholders": {} - }, - "warning": "Kontuz!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "ePosta bat bidali dizugu", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Nork zer egin dezakeen", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Ezabatu txataren babeskopia berreskuratze-gako berria sortzeko?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "messageInfo": "Mezuaren xehetasunak", - "@messageInfo": {}, - "sender": "Igorlea", - "@sender": {}, - "removeFromSpace": "Kendu gunetik", - "@removeFromSpace": {}, - "addToSpaceDescription": "Hautatu gune bat txat hau bertara gehitzeko.", - "@addToSpaceDescription": {}, - "start": "Hasi", - "@start": {}, - "publish": "Argitaratu", - "@publish": {}, - "reportUser": "Salatu erabiltzailea", - "@reportUser": {}, - "openChat": "Ireki txata", - "@openChat": {}, - "addWidget": "Gehitu widgeta", - "@addWidget": {}, - "widgetVideo": "Bideoa", - "@widgetVideo": {}, - "widgetEtherpad": "Testu-oharra", - "@widgetEtherpad": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Norberak ezarritakoa", - "@widgetCustom": {}, - "widgetName": "Izena", - "@widgetName": {}, - "youJoinedTheChat": "Txatera batu zara", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Gonbidapena onartu duzu", - "@youAcceptedTheInvitation": {}, - "youBannedUser": "{user}(r)i debekua ezarri diozu", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "{user}(r)i luzatutako gonbidapena baliogabetu duzu", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 {user}(e)k gonbidatu zaitu", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 {user} gonbidatu duzu", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 {user} kanporatu duzu", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 {user} kanporatu eta debekua ezarri diozu", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "{user}(r)i debekua kendu diozu", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "youRejectedTheInvitation": "Gonbidapena baztertu duzu", - "@youRejectedTheInvitation": {}, - "separateChatTypes": "Bereizi banakako mezuak eta taldeak", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "widgetUrlError": "Ez da baliozko URLa.", - "@widgetUrlError": {}, - "widgetNameError": "Zehaztu ezizen bat.", - "@widgetNameError": {}, - "errorAddingWidget": "Errorea widgeta gehitzerakoan.", - "@errorAddingWidget": {}, - "pleaseEnterRecoveryKey": "Sartu berreskuratze-gakoa:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKey": "Berreskuratze-gakoa", - "@recoveryKey": {}, - "recoveryKeyLost": "Berreskuratze-gakoa galdu duzu?", - "@recoveryKeyLost": {}, - "users": "Erabiltzaileak", - "@users": {}, - "storeInAndroidKeystore": "Gorde Android KeyStore-n", - "@storeInAndroidKeystore": {}, - "dehydrate": "Esportatu saioa eta ezabatu gailua", - "@dehydrate": {}, - "dehydrateWarning": "Ekintza hau ezin da desegin. Egiaztatu babeskopia toki seguruan gorde duzula.", - "@dehydrateWarning": {}, - "hydrate": "Lehengoratu babeskopia bat erabiliz", - "@hydrate": {}, - "pleaseEnterRecoveryKeyDescription": "Mezu zaharrak ikusi ahal izateko, sartu aurreko saioan sortu zen berreskuratze-gakoa. Berreskuratze-gakoa EZ da zure pasahitza.", - "@pleaseEnterRecoveryKeyDescription": {}, - "indexedDbErrorLong": "Mezuen artxibatzea ez dago defektuz gaituta modu pribatua erabiltzean.\nGaitzeko:\n - about:config\n - dom.indexedDB.privateBrowsing.enabled aukerak true erakutsi dezala\nBestela ezin da FluffyChat erabili.", - "@indexedDbErrorLong": {}, - "storeSecurlyOnThisDevice": "Gorde gailu honetan modu seguruan", - "@storeSecurlyOnThisDevice": {}, - "countFiles": "{count} fitxategi", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "user": "Erabiltzailea", - "@user": {}, - "custom": "Neurrira egindakoa", - "@custom": {}, - "storeInSecureStorageDescription": "Gorde berreskuratze-gakoa gailu honetako biltegiratze seguruan.", - "@storeInSecureStorageDescription": {}, - "storeInAppleKeyChain": "Gorde Apple KeyChain-en", - "@storeInAppleKeyChain": {}, - "unlockOldMessages": "Desblokeatu mezu zaharrak", - "@unlockOldMessages": {}, - "dehydrateTorLong": "TOR erabiltzaileentzat gomendioa leihoa itxi baino lehen saioa esportatzea da.", - "@dehydrateTorLong": {}, - "hydrateTorLong": "Esportatu al zenuen zure saioa TOR erabili zenuen azken aldian? Inportatu segidan eta jarraitu txateatzen.", - "@hydrateTorLong": {}, - "dehydrateTor": "TOR Erabiltzaileak: Esportatu saioa", - "@dehydrateTor": {}, - "hydrateTor": "TOR Erabiltzaileak: Inportatu esportatutako saioa", - "@hydrateTor": {}, - "saveKeyManuallyDescription": "Gorde eskuz gako hau gailuko partekatze-menua edo arbela erabiliz.", - "@saveKeyManuallyDescription": {}, - "indexedDbErrorTitle": "Arazoak modu pribatuan", - "@indexedDbErrorTitle": {}, - "confirmMatrixId": "Baieztatu zure Matrix IDa kontua ezabatu ahal izateko.", - "@confirmMatrixId": {}, - "newSpace": "Gune berria", - "@newSpace": {}, - "enterRoom": "Sartu gelara", - "@enterRoom": {}, - "whyIsThisMessageEncrypted": "Zergatik ezin da mezu hau irakurri?", - "@whyIsThisMessageEncrypted": {}, - "allSpaces": "Gune guztiak", - "@allSpaces": {}, - "newGroup": "Talde berria", - "@newGroup": {}, - "enterSpace": "Sartu gunera", - "@enterSpace": {}, - "appearOnTopDetails": "Aplikazioa goikaldean agertzea baimentzen du (ez da beharrezkoa FluffyChat deitzeko kontutzat ezarri baduzu)", - "@appearOnTopDetails": {}, - "screenSharingTitle": "pantaila-partekatzea", - "@screenSharingTitle": {}, - "screenSharingDetail": "Pantaila FluffyChaten partekatzen ari zara", - "@screenSharingDetail": {}, - "callingPermissions": "Deitzeko baimenak", - "@callingPermissions": {}, - "callingAccount": "Deitzen ari den kontua", - "@callingAccount": {}, - "callingAccountDetails": "Baimendu FluffyChat Android gailuko telefono-markagailua erabiltzea.", - "@callingAccountDetails": {}, - "appearOnTop": "Gainean erakutsi", - "@appearOnTop": {}, - "otherCallingPermissions": "Mikrofono, kamera eta FluffyChaten beste baimen batzuk", - "@otherCallingPermissions": {}, - "numChats": "{number} txat", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Ezkutatu garrantzirik gabeko gertaerak", - "@hideUnimportantStateEvents": {}, - "noKeyForThisMessage": "Mezua gailu honetan saioa hasi baino lehen bidali bazen gertatu daiteke.\n\nBeste aukera bat igorleak zure gailua blokeatu izana da, edo zerbaitek huts egin izana interneteko konexioan.\n\nMezua beste saio batean irakur dezakezu? Hala bada, mezua transferitu dezakezu! Zoaz Ezrpenetara > Gailuak eta baieztatu zure gailuek bata bestea egiaztatu dutela. Gela irakiko duzun hurrengo aldian eta bi saioak aurreko planoan irekita daudenean, gakoak automatikoki partekatuko dira.\n\nEz duzu gakorik galdu nahi saioa amaitu edo gailuak aldatzen dituzunean? Baieztatu ezarpenetan txaten babeskopiak gaituta dituzula.", - "@noKeyForThisMessage": {}, - "supposedMxid": "Hau {mxid} izan behar da", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasgroup": "Markatu talde bezala", - "@commandHint_markasgroup": {}, - "foregroundServiceRunning": "Jakinarazpen hau zerbitzua martxan dagoenean agertzen da.", - "@foregroundServiceRunning": {}, - "commandHint_markasdm": "Markatu mezu-zuzen gela bezala Matrix ID jakin honentzat", - "@commandHint_markasdm": {}, - "wasDirectChatDisplayName": "Txata hutsik dago ({oldDisplayName} zen lehen)", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "deviceKeys": "Gailuaren gakoak:", - "@deviceKeys": {}, - "noBackupWarning": "Adi! Txataren babeskopia gaitzen ez baduzu, ezingo dituzu zifratutako txatak atzitu. Oso gomendagarria da txaten babeskopia gaitzea saioa amaitu baino lehen.", - "@noBackupWarning": {}, - "doNotShowAgain": "Ez erakutsi berriro", - "@doNotShowAgain": {}, - "fileIsTooBigForServer": "Zerbitzariak dio fitxategia handiegia dela bidali ahal izateko.", - "@fileIsTooBigForServer": {}, - "noOtherDevicesFound": "Ez da beste gailurik aurkitu", - "@noOtherDevicesFound": {}, - "startFirstChat": "Hasi zure lehen txata", - "@startFirstChat": {}, - "newSpaceDescription": "Guneek txatak taldekatzea ahalbidetzen dute eta komunitate pribatu edo publikoak osatzea.", - "@newSpaceDescription": {}, - "disableEncryptionWarning": "Segurtasun arrazoiak direla-eta, ezin duzu lehendik zifratuta zegoen txat bateko zifraketa ezgaitu.", - "@disableEncryptionWarning": {}, - "encryptThisChat": "Zifratu txata", - "@encryptThisChat": {}, - "commandHint_hug": "Bidali besarkada", - "@commandHint_hug": {}, - "hugContent": "{senderName}(e)k besarkatu zaitu", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "sorryThatsNotPossible": "Barka… hori ez da posible", - "@sorryThatsNotPossible": {}, - "reopenChat": "Ireki txata berriro", - "@reopenChat": {}, - "commandHint_googly": "Bidali begi dibertigarri batzuk", - "@commandHint_googly": {}, - "commandHint_cuddle": "Bidali besarkada samurra", - "@commandHint_cuddle": {}, - "googlyEyesContent": "{senderName}(e)k begi dibertigarri batzuk bidali dizkizu", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "allRooms": "Talde-txat guztiak", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "jumpToLastReadMessage": "Joan irakurritako azken mezura", - "@jumpToLastReadMessage": {}, - "reportErrorDescription": "😭 O ez! Zerbaitek huts egin du. Nahi izanez gero, eman garatzaileei errorearen berri.", - "@reportErrorDescription": {}, - "cuddleContent": "{senderName}(e)k samurki besarkatu zaitu", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "readUpToHere": "Honaino irakurrita", - "@readUpToHere": {}, - "fileHasBeenSavedAt": "Fitxategia {path}(e)n gorde da", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jump": "Joan", - "@jump": {}, - "openLinkInBrowser": "Ireki esteka nabigatzailean", - "@openLinkInBrowser": {}, - "report": "salatu", - "@report": {}, - "signInWithPassword": "Hasi saioa pasahitzarekin", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Saiatu geroago edo aukeratu beste zerbitzari bat.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "Hasi saioa {provider}(r)ekin", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Ez da irudi-fitxategia.", - "@notAnImage": {}, - "importNow": "Inportatu orain", - "@importNow": {}, - "importEmojis": "Inportatu emojiak", - "@importEmojis": {}, - "importFromZipFile": "Inportatu .zip fitxategi batetik", - "@importFromZipFile": {}, - "exportEmotePack": "Esportatu emote-sorta .zip gisa", - "@exportEmotePack": {}, - "replace": "Ordezkatu", - "@replace": {}, - "sendTypingNotifications": "Jakinarazi idazten nagoela", - "@sendTypingNotifications": {}, - "setColorTheme": "Ezarri kolore-gaia:", - "@setColorTheme": {}, - "tryAgain": "Saiatu berriro", - "@tryAgain": {}, - "messagesStyle": "Mezuak:", - "@messagesStyle": {}, - "chatDescription": "Txataren deskribapena", - "@chatDescription": {}, - "invalidServerName": "Zerbitzari-izenak ez du balio", - "@invalidServerName": {}, - "chatPermissions": "Txataren baimenak", - "@chatPermissions": {}, - "setChatDescription": "Ezarri txataren deskribapena", - "@setChatDescription": {}, - "redactedBy": "{username}(e)k atzera bota du", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "optionalRedactReason": "(Aukerakoa) Mezua atzera botatzearen arrazoia…", - "@optionalRedactReason": {}, - "inviteContactToGroupQuestion": "{contact} \"{groupName}\" txatera gonbidatu nahi duzu?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "{username}(e)k atzera bota du \"{reason}\" dela-eta", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "redactMessageDescription": "Mezua elkarrizketa honetako partaide guztientzat botako da atzera. Ezin da desegin.", - "@redactMessageDescription": {}, - "addChatDescription": "Gehitu txat honen deskribapena…", - "@addChatDescription": {}, - "directChat": "Banakako txata", - "@directChat": {}, - "wrongPinEntered": "PIN okerra! Saiatu berriro {seconds} segundu barru…", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "noChatDescriptionYet": "Ez da txaterako deskribapenik sortu oraindik.", - "@noChatDescriptionYet": {}, - "chatDescriptionHasBeenChanged": "Txataren deskribapena aldatu da", - "@chatDescriptionHasBeenChanged": {}, - "profileNotFound": "Ezin izan da erabiltzailea zerbitzarian aurkitu. Agian arazo bat dago konexioarekin edo erabiltzailea ez da existitzen.", - "@profileNotFound": {}, - "shareInviteLink": "Partekatu gonbidapen-esteka", - "@shareInviteLink": {}, - "emoteKeyboardNoRecents": "Oraintsu erabilitako emoteak hemen ageriko dira…", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Ezarri gaia:", - "@setTheme": {}, - "createGroup": "Sortu taldea", - "@createGroup": {}, - "invite": "Gonbidatu", - "@invite": {}, - "invalidInput": "Sartu duzunak ez du balio!", - "@invalidInput": {}, - "inviteGroupChat": "📨 Gonbidatu taldeko txatera", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Gonbidatu txat pribatura", - "@invitePrivateChat": {}, - "banUserDescription": "Erabiltzailea txatetik kanporatu eta berriro sartzeko debekua ezarriko zaio; ezingo da berriro sartu debekua kendu arte.", - "@banUserDescription": {}, - "removeDevicesDescription": "Gailu honetako saioa amaituko da eta ezingo duzu mezurik jaso aurrerantzean.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "Erabiltzailea txatera berriro sartu ahal izango da berak nahi izanez gero.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Push jakinarazpenak ez daude erabilgarri", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Behin erabiltzaile hau administratzaile eginda, litekeena da desegin ezin izatea zuk dituzun baimenak izango dituelako.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Txata artxibategira mugituko da. Beste erabiltzaileek txatetik alde egin duzula ikusi ahal izango dute.", - "@archiveRoomDescription": {}, - "hasKnocked": "🚪 {user}(e)k baimena eskatu du", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "learnMore": "Gehiago irakurri", - "@learnMore": {}, - "roomUpgradeDescription": "Gela bertsio berri gisa birsortuko da txata. Partaide guztiei jakinaraziko zaie txat berrira aldatu behar direla. Gehiago irakur dezakezu gela bertsioei buruz ondorengo estekan: https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Sartu 0 baino zenbaki handiago bat", - "@pleaseEnterANumber": {}, - "kickUserDescription": "Erabiltzailea txatetik kanporatu da baina ez zaio debekua ezarri. Txat publikoen kasuan, edozein momentutan batu daiteke berriro.", - "@kickUserDescription": {}, - "createGroupAndInviteUsers": "Sortu talde bat eta gonbidatu partaideak", - "@createGroupAndInviteUsers": {}, - "startConversation": "Hasi elkarrizketa", - "@startConversation": {}, - "groupCanBeFoundViaSearch": "Bilaketa erabiliz aurkitu daiteke taldea", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "Zoritxarrez ez da \"{query}\" duen erabiltzailerik aurkitu. Egiaztatu zuzen idatzi duzula.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "yourGlobalUserIdIs": "Zure erabiltzaile-ID orokorra: ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "Bidali json gordina", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Barka baina ez dirudi berreskuratze-gako zuzena denik.", - "@wrongRecoveryKey": {}, - "groupName": "Taldearen izena", - "@groupName": {}, - "searchChatsRooms": "Bilatu #txatak, @erabiltzaileak…", - "@searchChatsRooms": {}, - "blockListDescription": "Gogaitzen zaituzten erabiltzaileak blokeatu ditzakezu. Ez duzu blokeatutakoen zerrendan dituzun erabiltzaileen mezurik edo gelara batzeko gonbidapenik jasoko.", - "@blockListDescription": {}, - "blockedUsers": "Blokeatutako erabiltzaileak", - "@blockedUsers": {}, - "block": "Blokeatu", - "@block": {}, - "blockUsername": "Ezikusi erabiltzaile-izena", - "@blockUsername": {}, - "databaseMigrationTitle": "Datu-basea optimizatu da", - "@databaseMigrationTitle": {}, - "databaseMigrationBody": "Itxaron, litekeena da tarte bat behar izatea.", - "@databaseMigrationBody": {}, - "publicSpaces": "Gune publikoak", - "@publicSpaces": {}, - "passwordIsWrong": "Sartu duzun pasahitza okerra da", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Sartu oraingo pasahitza", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "Esteka publikoa", - "@publicLink": {}, - "nothingFound": "Ez da ezer aurkitu…", - "@nothingFound": {}, - "newPassword": "Pasahitz berria", - "@newPassword": {}, - "passwordsDoNotMatch": "Pasahitzak ez datoz bat", - "@passwordsDoNotMatch": {}, - "subspace": "Azpi-gunea", - "@subspace": {}, - "select": "Hautatu", - "@select": {}, - "pleaseChooseAStrongPassword": "Aukeratu pasahitz sendo bat", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "Gehitu txata edo azpi-gunea", - "@addChatOrSubSpace": {}, - "leaveEmptyToClearStatus": "Utzi hutsik zure egoera garbitzeko.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Batu gunera", - "@joinSpace": {}, - "searchForUsers": "Bilatu @erabiltzaileak…", - "@searchForUsers": {}, - "thisDevice": "Gailu hau:", - "@thisDevice": {}, - "decline": "Baztertu", - "@decline": {}, - "databaseBuildErrorBody": "Ezin izan da SQlite datu-basea eraiki. Aplikazioa aurreko datu-basea erabiltzen saiatuko da oraingoz. Jakinarazi errorea garatzaileei {url} helbidean. Errorearen mezua ondorengoa da: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "Errorea aplikazioa abiaraztean", - "@initAppError": {}, - "sessionLostBody": "Zure saioa galdu da. Jakinarazi errorea garatzaileei {url} helbidean. Errorearen mezua ondorengoa da: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "Aplikazioa babeskopia erabiliz saioa leheneratzen saiatuko da. Jakinarazi errorea garatzaileei {url} helbidean. Errorearen mezua ondorengoa da: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "youInvitedToBy": "📩 Esteka baten bidez gonbidatu zaituzte:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "transparent": "Gardena", - "@transparent": {}, - "sendReadReceipts": "Bidali irakurri izanaren adierazlea", - "@sendReadReceipts": {}, - "formattedMessages": "Formatua duten mezuak", - "@formattedMessages": {}, - "verifyOtherDevice": "🔐 Egiaztatu beste gailu bat", - "@verifyOtherDevice": {}, - "acceptedKeyVerification": "{sender}(e)k gakoaren egiaztapena onartu du", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender}(e)k gakoen egiaztapena ezeztatu du", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender}(e)k gakoen egiaztapena galdegin du", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "sendReadReceiptsDescription": "Txateko beste kideek mezu bat irakurri duzula ikus dezakete.", - "@sendReadReceiptsDescription": {}, - "forwardMessageTo": "Birbidali mezua {roomName}(e)ra?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "completedKeyVerification": "{sender}(e)k gakoen egiaztapena osatu du", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} gakoak egiaztatzeko prest dago", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "verifyOtherDeviceDescription": "Beste gailu bat egiaztatzean, gailu horiek gakoak truka ditzakete, eta segurtasun orokorra handitu. 💪 Egiaztapena hasten duzunean, laster-leiho bat agertuko da bi gailuetan. Bertan, elkarrekin alderatu behar diren emoji edo zenbaki batzuk ikusiko dituzu. Hobe da bi gailuak eskura izatea egiaztapena hasi aurretik. 🤳", - "@verifyOtherDeviceDescription": {}, - "verifyOtherUserDescription": "Beste erabiltzaile bat egiaztatzen baduzu, ziur egon zaitezke nori idazten ari zaren. 💪\n\nEgiaztapena hasten duzunean, zuk eta beste erabiltzaileak laster-leiho bat ikusiko duzue aplikazioan. Bertan, elkarrekin alderatu behar diren emoji edo zenbaki batzuk erakutsiko dira.\n\nBideo-dei bat hastea edo aurrez-aurre batzea da horretarako modurik onena. 👭", - "@verifyOtherUserDescription": {}, - "formattedMessagesDescription": "Erakutsi mezu aberatsen edukia markdown erabiliz, testu lodia esaterako.", - "@formattedMessagesDescription": {}, - "sendTypingNotificationsDescription": "Txateko beste kideek mezu berri bat idazten ari zarela ikus dezakete.", - "@sendTypingNotificationsDescription": {}, - "verifyOtherUser": "🔐 Egiaztatu beste erabiltzaile bat", - "@verifyOtherUser": {}, - "startedKeyVerification": "{sender}(e)k gakoen egiaztapena hasi du", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "presencesToggle": "Erakutsi beste erabiltzaileen egoera-mezuak", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "presenceStyle": "Presentzia:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "incomingMessages": "Jasotako mezuak", - "@incomingMessages": {}, - "hidePresences": "Ezkutatu Egoeren Zerrenda?", - "@hidePresences": {}, - "discover": "Arakatu", - "@discover": {}, - "stickers": "Pegatinak", - "@stickers": {}, - "commandHint_unignore": "Utzi Matrix ID honi muzin egiteari", - "@commandHint_unignore": {}, - "commandHint_ignore": "Muzin egin Matrix ID honi", - "@commandHint_ignore": {}, - "unreadChatsInApp": "{appname}: {unread} mezu irakurri gabe", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "noDatabaseEncryption": "Plataforma honetan ezin da datu-basea zifratu", - "@noDatabaseEncryption": {}, - "usersMustKnock": "Erabiltzaileek baimena eskatu behar dute", - "@usersMustKnock": {}, - "userWouldLikeToChangeTheChat": "{user}(e)k txatera batu nahiko luke.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "knock": "Eskatu baimena", - "@knock": {}, - "knocking": "Baimena eskatzen", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Txata {server}(e)n bilaketa eginez aurkitu daiteke", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "thereAreCountUsersBlocked": "Une honetan {count} erabiltzaile daude blokeatuta.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "appLockDescription": "Blokeatu aplikazioa pin kode batekin erabiltzen ari ez zarenean", - "@appLockDescription": {}, - "accessAndVisibility": "Sarbidea eta ikusgaitasuna", - "@accessAndVisibility": {}, - "accessAndVisibilityDescription": "Nork du txat honetara batzeko baimena eta nola aurkitu daiteke txata.", - "@accessAndVisibilityDescription": {}, - "customEmojisAndStickers": "Emoji eta pegatina propioak", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Gehitu edo partekatu edozein txatetan erabil daitezkeen emoji edo pegatina propioak.", - "@customEmojisAndStickersBody": {}, - "hideRedactedMessages": "Ezkutatu atzera botatako mezuak", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "Norbaitek mezuren bat atzera botaz gero, mezua txatetik kenduko da, abisurik gabe.", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "Ezkutatu mezuen formatu ezezagun edo baliogabea", - "@hideInvalidOrUnknownMessageFormats": {}, - "overview": "Ikuspegi orokorra", - "@overview": {}, - "notifyMeFor": "Jakinarazi…", - "@notifyMeFor": {}, - "passwordRecoverySettings": "Pasahitza berreskuratzeko ezarpenak", - "@passwordRecoverySettings": {}, - "hideMemberChangesInPublicChats": "Ezkutatu kideen egoera aldaketak txat publikoetan", - "@hideMemberChangesInPublicChats": {}, - "globalChatId": "Txat ID orokorra", - "@globalChatId": {}, - "calls": "Deiak", - "@calls": {}, - "hideMemberChangesInPublicChatsBody": "Ez erakutsi txataren denbora-lerroan norbait txat publikora batu edo txatetik irteten dela, irakurgaitasuna hobetzeko.", - "@hideMemberChangesInPublicChatsBody": {}, - "noOneCanJoin": "Ezin da inor batu", - "@noOneCanJoin": {}, - "noPublicLinkHasBeenCreatedYet": "Oraindik ez da esteka publikorik sortu", - "@noPublicLinkHasBeenCreatedYet": {}, - "userRole": "Erabiltzailearen rola", - "@userRole": {}, - "minimumPowerLevel": "{level} da gutxieneko botere maila.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "publicChatAddresses": "Txataren helbide publikoak", - "@publicChatAddresses": {}, - "createNewAddress": "Sortu helbide berria", - "@createNewAddress": {}, - "files": "Fitxategiak", - "@files": {}, - "gallery": "Galeria", - "@gallery": {}, - "searchIn": "Bilatu {chat} txatean...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Bilatu gehiago...", - "@searchMore": {}, - "restricted": "Mugatuta", - "@restricted": {} -} diff --git a/assets/l10n/intl_fa.arb b/assets/l10n/intl_fa.arb deleted file mode 100644 index b51439b8e..000000000 --- a/assets/l10n/intl_fa.arb +++ /dev/null @@ -1,2377 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:10.061080", - "repeatPassword": "تکرار رمزعبور", - "@repeatPassword": {}, - "about": "درباره", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "پذیرش", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} دعوت را پذیرفت", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "حساب", - "@account": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "به فضا اضافه کنید", - "@addToSpace": {}, - "appLock": "قفل برنامه", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "all": "همه", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "همه گپ‌ها", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "addEmail": "افزودن ایمیل", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} پاسخ تماس را داد", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "هرکسی می‌تواند بپیوندد", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "بایگانی", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "مطمئن هستید؟", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "مطمئن هستید می‌خواهید خارج شوید؟", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} رمزگذاری سرتاسر را فعال کرد", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "ادمین", - "@admin": { - "type": "text", - "placeholders": {} - }, - "supposedMxid": "این باید {mxid} باشد", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "botMessages": "پیام‌های روبات", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "changedTheDisplaynameTo": "{username} نام نمایشی خود را تغییر داد به: «{displayname}»", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "confirmMatrixId": "برای حذف حسابتان، لطفا هویت ماتریکستان را تایید کنید.", - "@confirmMatrixId": {}, - "changeDeviceName": "نام دستگاه را تغییر دهید", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "alias": "نام مستعار", - "@alias": { - "type": "text", - "placeholders": {} - }, - "banFromChat": "از گپ محروم کنید", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "این درخواست تایید را از {username} می‌پذیرید؟", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "areGuestsAllowedToJoin": "آیا کاربران مهمان اجازه پیوستن دارند", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "اموجی و برچسب‌های متحرک به طور خودکار پخش شوند", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "sendOnEnter": "ارسال با کلید تعويض سطر", - "@sendOnEnter": {}, - "cancel": "لغو", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changedTheChatDescriptionTo": "{username} توصیف گپ را تغییر داد به: «{description}»", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatPermissions": "{username} اجازه‌های گپ را تغییر داد", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatNameTo": "{username} نام گپ را تغییر داد به: «{chatname}»", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "cantOpenUri": "نمی‌توانیم این آدرس اینترنتی را باز کنیم: {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "banned": "محروم شده", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} {targetName} را محروم کرد", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "دستگاه را مسدود کنید", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "مسدود شده", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "سرور می‌تواند این گونه‌های ورود‮ را پشتیباتی کند:\n{serverVersions}\nولی این برنامه فقط می‌تواند این‌ها را پشتیبانی کند:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "سرور می‌تواند این نسخه‌های مشخصات را پشتیبانی کند:\n{serverVersions}\nولی این برنامه فقط می‌تواند این‌ها را پشتیبانی کند:\n{supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "changedTheChatAvatar": "{username} تصویر گپ را تغییر داد", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRules": "{username} قوانین دسترسی مهمان را تغییر داد", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheProfileAvatar": "{username} عکس پروفایل خود را تغییر داد", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "chats": "گپ‌ها", - "@chats": { - "type": "text", - "placeholders": {} - }, - "messages": "پیام‌ها", - "@messages": { - "type": "text", - "placeholders": {} - }, - "send": "ارسال", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "ارسال صدا", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "ارسال اصل", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "changedTheRoomAliases": "{username} نام‌های مستعار اتاق را تغییر داد", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} لینک دعوت را تغییر داد", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "close": "بستن", - "@close": { - "type": "text", - "placeholders": {} - }, - "sendImage": "ارسال تصویر", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "ارسال پیام‌ها", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "changedTheHistoryVisibility": "{username} قابليت‌ ديدن‌ تاریخچه را تغییر داد", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} قوانین دسترسی مهمان را تغییر داد به: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRulesTo": "{username} قوانین پیوستن را تغییر داد به: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} قابليت‌ ديدن‌ تاریخچه را تغییر داد به: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "chooseAStrongPassword": "رمز عبور قوی انتخاب کنید", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "پشتیبان گپ‌تان تنظیم شده است.", - "@yourChatBackupHasBeenSetUp": {}, - "changeTheme": "سبک خود را تغییر دهید", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "نام گروه را تغییر دهید", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "عکس پروفایل خود را تغییر دهید", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "رمزگذاری مخدوش شده‌ است", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "بایگانی را پاک کنید", - "@clearArchive": {}, - "commandHint_create": "یک گپ گروهی خالی بسازید\nاز «--no-encryption» برای غیرفعال کردن رمزگذاری استفاده کنید", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_dm": "یک گپ مستقیم شروع کنید\nاز «--no-encryption» برای غیرفعال کردن رمزگذاری استفاده کنید", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "sendSticker": "ارسال برچسب", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "ارسال ویدئو", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sender": "فرستنده", - "@sender": {}, - "changedTheJoinRules": "{username} قوانین پیوستن را تغییر داد", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "chatDetails": "جزئیات گپ", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "commandHint_markasdm": "برای دادن شناسه ماتریکس به عنوان اتاق پیام‌های مستقیم علامت بگذارید", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "به عنوان گروه علامت بگذارید", - "@commandHint_markasgroup": {}, - "commandHint_clearcache": "حافظه پنھان را پاک کنید", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_discardsession": "طرد نشست", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "groups": "گروه‌ها", - "@groups": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "برای خواندن پیام‌ها، برنامه را باز کنید", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "ارسال پیام", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sentCallInformations": "{senderName} اطلاعات تماس را فرستاد", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "sendAsText": "ارسال به عنوان متن", - "@sendAsText": { - "type": "text" - }, - "sendFile": "ارسال فایل", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} تماسی را شروع کرد", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "tryToSendAgain": "تلاش برای ارسال مجدد", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "reactedWith": "{sender} با {reaction} واکنش نشان داد", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "askSSSSSign": "لطفا عبارت عبور یا کلید بازیابی حافظه امن خود را وارد کنید تا بتوانید شخص دیگر را امضا کنید.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "گپ به این فضا اضافه شده است", - "@chatHasBeenAddedToThisSpace": {}, - "chat": "گپ", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "پشتیبان گپ", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "changePassword": "تغییر رمز عبور", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "تغییر سرور خانه", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "separateChatTypes": "گپ‌های مستقیم را از گروه‌ها جدا کنید", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "sentAPicture": "🖼️ {username} یک عکس فرستاد", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} یک ویدئو فرستاد", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "commandInvalid": "دستور نامعتبر", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} یک دستور نیست.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "contactHasBeenInvitedToTheGroup": "مخاطب به گروه دعوت شده است", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} یک فایل فرستاد", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} یک صدای ضبط شده فرستاد", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userSentUnknownEvent": "{username} یک رویداد {type} فرستاد", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "weSentYouAnEmail": "یک ایمیل برایتان فرستادیم", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "بارگیری {count} شرکت کنندۀ بیشتر", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "sentASticker": "😊 {username} یک برچسب فرستاد", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "connect": "اتصال", - "@connect": { - "type": "text", - "placeholders": {} - }, - "confirm": "تایید", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "allSpaces": "همه فضاها", - "@allSpaces": {}, - "commandHint_ban": "کاربر مشخص شده را از این اتاق محروم کنید", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_kick": "کاربر مشخص شده را از این اتاق حذف کنید", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_plain": "متن بی‌فرمت بفرستید", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_unban": "محرومیت کاربر مشخص شده را از این اتاق لغو کنید", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "containsDisplayName": "شامل نام نمایشی است", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "شامل نام کاربری است", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "device": "دستگاه", - "@device": { - "type": "text", - "placeholders": {} - }, - "copy": "کپی", - "@copy": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "درجه اجازۀ پیشفرض", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "حذف", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "حساب را حذف کنید", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "پیام را حذف کنید", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "commandHint_html": "متن با فرمت HTML بفرستید", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_join": "به اتاق مشخص شده بپیوندید", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_leave": "این اتاق را ترک کنید", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_myroomnick": "نام نمایشی خود را برای این اتاق تنظیم کنید", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_myroomavatar": "عکس پروفایل خود را برای این اتاق تنظیم کنید (با mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_op": "درجه اختیار کاربر مشخص شده را تنظیم کنید (پیشفرض: ۵۰)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_react": "پاسخ را به عنوان یک واکنش بفرستید", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "compareEmojiMatch": "لطفا ایموجی‌ها را مقایسه کنید", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "در حافظه کپی کنید", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} شرکت کننده", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "ایجاد", - "@create": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "فضای جدید", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "dateWithYear": "{year}-{month}-{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deviceId": "هویت دستگاه", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "دستگاه‌ها", - "@devices": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "نام نمایشی تغییر یافته است", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "بارگیری فایل", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "ویرایش", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "سرور‌های مسدود را ویرایش کنید", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "نام‌های مستعار اتاق را ویرایش کنید", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "عکس اتاق را ویرایش کنید", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "شکلک از پیش وجود دارد!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "باید یک کد کوتاه شکلک و یک تصویر انتخاب کنید!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "کد کوتاه شکلک نامعتبر!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "گپ خالی", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "در حافظه کپی شد", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} گپ را ایجاد کرد", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "darkTheme": "تاریک", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "directChats": "گپ‌های مستقیم", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "بسته‌های شکلک برای اتاق", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "‏تنظیمات شکلک", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "کد کوتاه شکلک", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "commandHint_me": "خود را توصیف کنید", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_send": "متن را بفرستید", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "couldNotDecryptMessage": "نتوانستیم پیام را رمزگشایی کنیم: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "chatBackupDescription": "پیام‌های قدیمی‌تان با یک کلید باز یابی، امن می‌شوند. لطفا مطمئن شوید که آن را گم نمی‌کنید.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "deactivateAccountWarning": "این کار حساب کاربری‌تان را غیرفعال خواهد کرد. این عمل قابل جبران و بازگشت نیست! آیا اطمینان دارید؟", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "commandHint_invite": "کاربر مشخص شده را به این اتاق دعوت کنید", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "compareNumbersMatch": "لطفا اعداد را مقایسه کنید", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "گپ را تنظیم کنید", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "currentlyActive": "اکنون فعال", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}، {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "editDisplayname": "ویرایش نام نمایشی", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "id": "آی‌دی", - "@id": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} دعوت‌نامه {targetName} را پس گرفته است", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "guestsAreForbidden": "مهمان‌ها ممنوع شده‌اند", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "پنهان کردن رویدادهای ویرایش شده", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "پنهان کردن رویدادهای ناشناخته", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "محتوا به مدیران سرور گزارش شده است", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "از پیوستن", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "از دعوت", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "به اتاق جدید بروید", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "گروه", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "گروه عمومی است", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "گروه با {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "howOffensiveIsThisContent": "این محتوا چه مقدار توهین آمیز است؟", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "بسته شکلک را به طور سراسری فعال کنید", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "رمزگذاری را فعال کنید", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "شما دیگر قادر به غیرفعال کردن رمزگذاری نخواهید بود. آیا مطمئن هستید؟", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "رمزگذاری شده", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "رمزگذاری", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "رمزگذاری فعال نیست", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "enterAnEmailAddress": "یک آدرس رایانامه(ایمیل) وارد کنید", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} به تماس پایان داد", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "homeserver": "سرور خانه", - "@homeserver": {}, - "enterYourHomeserver": "سرور خانه خود را وارد کنید", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "خطا هنگام بدست آوردن مکان: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "همه‌چیز آماده است!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "به شدت توهین آمیز", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "نام فایل", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "فلافی‌چت", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "اندازه قلم", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "ارسال", - "@forward": { - "type": "text", - "placeholders": {} - }, - "help": "کمک", - "@help": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "مهمان‌ها می‌توانند بپیوندند", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "کاربران نادیده‌گرفته شده", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "ارسال چند چشم گوگولی", - "@commandHint_googly": {}, - "googlyEyesContent": "{senderName} به شما چشمان گوگولی می‌فرستد", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "ignore": "نادیده‌گرفتن", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "cuddleContent": "{senderName} شما را در آغوش می‌گیرد", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "identity": "هویت", - "@identity": { - "type": "text", - "placeholders": {} - }, - "hugContent": "{senderName} شما را بغل می‌کند", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_cuddle": "ارسال آغوش", - "@commandHint_cuddle": {}, - "commandHint_hug": "ارسال بغل", - "@commandHint_hug": {}, - "editBundlesForAccount": "بسته‌های این حساب را ویرایش کنید", - "@editBundlesForAccount": {}, - "logout": "خارج شدن", - "@logout": { - "type": "text", - "placeholders": {} - }, - "mention": "نام‌‌بردن‌", - "@mention": { - "type": "text", - "placeholders": {} - }, - "muteChat": "بی‌صدا کردن گپ", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "newChat": "گپ جدید", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 پیام جدید در فلافی‌چت", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "عدم اتصال به سرور", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "no": "نه", - "@no": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "شما هنوز راهی برای بازیابی رمز عبور خود اضافه نکرده‌اید.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "اعلان‌ها برای این حساب فعال شد", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "or": "یا", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "شرکت‌کننده", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "عبارت عبور یا کلید بازیابی", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "رمز عبور", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "رمز عبور تغییر کرد", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "بازیابی رمز عبور", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "pin": "سنجاق کردن", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "پخش {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseEnter4Digits": "لطفا ۴ رقم وارد کنید یا خالی بگذارید تا قفل برنامه غیرفعال شود.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "لطفا کد خود را وارد کنید", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "لطفا رمزعبور خود را وارد کنید", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "لطفا دستورالعمل‌های وب‌سایت را دنبال کنید و روی بعدی بزنید.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "اتاق‌های عمومی", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "به دست آوردن مکان…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "اوه، مشکلی پیش آمد…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "addToBundle": "به بسته نرم‌افزاری اضافه کنید", - "@addToBundle": {}, - "passwordForgotten": "رمز عبور را فراموش کرده‌ام", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterRecoveryKey": "لطفا کلید بازیابی خود را وارد کنید:", - "@pleaseEnterRecoveryKey": {}, - "link": "پیوند", - "@link": {}, - "iHaveClickedOnLink": "من روی پیوند کلیک کردم", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "عبارت عبور یا کلید بازیابی اشتباه است", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "بی ضرر", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "دعوت از مخاطب به {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invitedUsersOnly": "فقط کاربران دعوت شده", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "دعوت برای من", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "isTyping": "در حال نوشتن…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "پیوستن به اتاق", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} {targetName} را بیرون کرد", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "از گفتگو بیرون کردن", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "گپ را ترک کرد", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "dehydrate": "صدور جلسه و پاک کردن دستگاه", - "@dehydrate": {}, - "hydrateTorLong": "آیا آخرین بار جلسه خود را با تور (TOR) صادر کردید؟ به سرعت آن را وارد کنید و به گپ‌زنی ادامه دهید.", - "@hydrateTorLong": {}, - "loadingPleaseWait": "در حال بارگیری... لطفا صبر کنید.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "بارگیری بیشتر…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "مجوز مکان رد شد. برای به اشتراک گذاشتن موقعیت مکانی شما لطفا به آن اجازه دهید.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "logInTo": "وارد شدن به {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "memberChanges": "تغییرات اعضا", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "moderator": "مدیر", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "درخواست تایید جدید!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "noPermission": "بدون اجازه", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "اتاقی پیدا نشد…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "offline": "آفلاین", - "@offline": { - "type": "text", - "placeholders": {} - }, - "online": "آنلاین", - "@online": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "اوه! متاسفانه هنگام تنظیم اعلان‌ها خطایی روی داد.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "openCamera": "باز کردن دوربین", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "addAccount": "اضافه کردن حساب کاربری", - "@addAccount": {}, - "people": "مردم", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "یک عکس انتخاب کنید", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "لطفا انتخاب کنید", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "لطفا یک کد عبور انتخاب کنید", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "لطفا نام‌کاربری خود را وارد کنید", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "privacy": "حریم خصوصی", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "license": "پروانه", - "@license": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} کاربر در حال نوشتن…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "invited": "دعوت شده", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} از {targetName} دعوت کرد", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "joinedTheChat": "👋 {username} به گپ پیوست", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "kickedAndBanned": "🙅 {username} {targetName} را بیرون و محروم کرد", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "dehydrateWarning": "این عمل قابل لغو نیست. مطمئن شوید که فایل پشتیبان را به صورت امن ذخیره می کنید.", - "@dehydrateWarning": {}, - "locationDisabledNotice": "خدمات مکان غیرفعال است. لطفا آن را فعال کنید تا بتوانید موقعیت مکانی خود را به اشتراک بگذارید.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "dehydrateTorLong": "برای کاربران تور (TOR)، توصیه می شود قبل از بستن پنجره، جلسه را صادر کنند.", - "@dehydrateTorLong": {}, - "needPantalaimonWarning": "لطفا توجه داشته باشید که در حال حاضر برای استفاده از رمزگذاری انتها به انتها به Pantalaimon نیاز دارید.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "next": "بعدی", - "@next": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "هیچ شکلکی پیدا نشد. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "به نظر می رسد که شما سرویس‌های گوگل را در گوشی خود ندارید. این تصمیم خوبی برای حفظ حریم خصوصی شماست! برای دریافت اعلان‌ها در فلافی‌چت توصیه می‌کنیم ازhttps://ntfy.sh استفاده کنید. با ntfy یا یک ارائه دهنده UnifiedPush می توانید اعلان‌های فشار را به روش داده امن دریافت کنید. می توانید ntfy را از پلی استور یا از اف‌دروید بارگیری کنید.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "فقط زمانی می‌توانید رمزگذاری را فعال کنید که اتاق، دیگر در دسترس عموم نباشد.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "پشتیبان‌گیری آنلاین از کلید فعال است", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "enableMultiAccounts": "(آزمایشی) چند حساب را در این دستگاه فعال کنید", - "@enableMultiAccounts": {}, - "pleaseClickOnLink": "لطفا روی لینک موجود در رایانامه(ایمیل) کلیک کنید و سپس ادامه دهید.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "hydrateTor": "کاربران تور (TOR): صادرات جلسه را وارد کنید", - "@hydrateTor": {}, - "hydrate": "بازیابی از فایل پشتیبان", - "@hydrate": {}, - "inviteContact": "دعوت از مخاطب", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} سرور ماتریکس نیست، به جای آن از {server2} استفاده شود؟", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "openVideoCamera": "بازکردن دوربین برای فیلم‌برداری", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "یکی از کلاینت(برنامه)های شما از سیستم خارج شده است", - "@oneClientLoggedOut": {}, - "removeFromBundle": "از این بسته حذف کنید", - "@removeFromBundle": {}, - "bundleName": "اسم بسته", - "@bundleName": {}, - "openInMaps": "باز کردن در نقشه", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "برای ثبت‌نام، این سرور باید آدرس ایمیل شما را تایید کند.", - "@serverRequiresEmail": {}, - "inviteText": "{username} شما را به فلافی‌چت دعوت کرد.\n۱. به fluffychat.im مراجعه کرده و کاره را نصب کنید\n۲. ثبت نام کنید یا وارد شوید.\n۳. لینک دعوت را باز کنید:\n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "leave": "ترک کردن", - "@leave": { - "type": "text", - "placeholders": {} - }, - "none": "هیچ‌کدام", - "@none": { - "type": "text", - "placeholders": {} - }, - "offensive": "توهین آمیز", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "کد QR را اسکن کنید", - "@scanQrCode": {}, - "lastActiveAgo": "آخرین فعالیت: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "lightTheme": "روشن", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "dehydrateTor": "کاربران تور (TOR): صدور جلسه", - "@dehydrateTor": {}, - "login": "وارد شدن", - "@login": { - "type": "text", - "placeholders": {} - }, - "notifications": "اعلان‌ها", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "ok": "تایید", - "@ok": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "اتاق ارتقا پیدا کرد", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "register": "ثبت نام", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "رد کردن", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} دعوت را رد کرد", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "دوباره پیوستن", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "لغو محرومیت از گپ", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "reply": "پاسخ", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "درخواست اجازه", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "نسخه اتاق", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "search": "جستجو", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "امنیت", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "دیده شده توسط {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "setAsCanonicalAlias": "به عنوان نام مستعار اصلی تنظیم کنید", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "آواتار(عکس حساب) خود را حذف کنید", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "recording": "در حال ضبط", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} یک رویداد را ویرایش کرد", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "remove": "حذف کردن", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "حذف تمام دستگاه‌های دیگر", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "حذف شده توسط {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "حذف دستگاه", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "تبدیل و نمایش محتوای پیام به صورت کامل", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "گزارش دادن پیام", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "saveFile": "ذخیره فایل", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "recoveryKey": "کلید بازیابی", - "@recoveryKey": {}, - "setInvitationLink": "تنظیم پیوند دعوت", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "pushRules": "قواعد دریافت اعلان", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "دلیل", - "@reason": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "شکلک سفارشی را تنظیم کنید", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "ویرایش پیام", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "اتاق را با نسخه جدیدتر جایگزین کنید", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "recoveryKeyLost": "کلید بازیابی را گم کردید؟", - "@recoveryKeyLost": {}, - "fileHasBeenSavedAt": "فایل در {path} ذخیره شده است", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "enterSpace": "ورود به فضا", - "@enterSpace": {}, - "wasDirectChatDisplayName": "گپ خالی ({oldDisplayName} بود)", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "newSpaceDescription": "فضاها به شما امکان می‌دهند گپ‌های خود را یکپارچه کنید و جوامع خصوصی یا عمومی بسازید.", - "@newSpaceDescription": {}, - "encryptThisChat": "این گپ را رمزگذاری کنید", - "@encryptThisChat": {}, - "sorryThatsNotPossible": "متاسفم... این امکان‌پذیر نیست", - "@sorryThatsNotPossible": {}, - "deviceKeys": "کلیدهای دستگاه:", - "@deviceKeys": {}, - "fileIsTooBigForServer": "سرور گزارش می‌دهد که فایل برای ارسال بسیار بزرگ است.", - "@fileIsTooBigForServer": {}, - "jumpToLastReadMessage": "پرش به آخرین پیام خوانده شده", - "@jumpToLastReadMessage": {}, - "hideUnimportantStateEvents": "رویدادهای غیر مهم مربوط به وضعیت را پنهان کنید", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "دوباره نشان نده", - "@doNotShowAgain": {}, - "readUpToHere": "تا اینجا خوانده شده", - "@readUpToHere": {}, - "noBackupWarning": "هشدار! بدون فعال کردن پشتیبان گپ، دسترسی به پیام های رمزگذاری شده خود را از دست خواهید داد. قویا توصیه می‌شود قبل از خروج از سیستم، ابتدا پشتیبان‌گیری گپ را فعال کنید.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "دستگاه دیگری پیدا نشد", - "@noOtherDevicesFound": {}, - "countFiles": "{count} فایل", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "callingAccountDetails": "به فلافی‌چت اجازه می‌دهد تا از برنامه شماره‌گیر بومی اندروید استفاده کند.", - "@callingAccountDetails": {}, - "noKeyForThisMessage": "اگر پیام قبل از ورود به حسابتان در این دستگاه ارسال شده باشد، ممکن است این اتفاق بیفتد.\n\nهمچنین ممکن است فرستنده، دستگاه شما را مسدود کرده باشد یا مشکلی در اتصال اینترنت رخ داده باشد.\n\nآیا می توانید پیام را در نشست دیگری بخوانید؟ بنابراین می توانید پیام را از آن منتقل کنید! به تنظیمات > دستگاه‌ها بروید و مطمئن شوید که دستگاه های شما یکدیگر را تایید کرده‌اند. هنگامی که دفعه بعد اتاق را باز می‌کنید و هر دو جلسه در پیش‌زمینه هستند، کلیدها به طور خودکار منتقل می‌شوند.\n\nآیا نمی‌خواهید هنگام خروج از سیستم یا تعویض دستگاه، کلیدها را گم کنید؟ مطمئن شوید که پشتیبان گپ را در تنظیمات فعال کرده‌اید.", - "@noKeyForThisMessage": {}, - "numChats": "{number} گپ", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "disableEncryptionWarning": "به دلایل امنیتی نمی‌توانید رمزگذاری را در گپ غیرفعال کنید، در حالی که از قبل فعال شده است.", - "@disableEncryptionWarning": {}, - "enterRoom": "ورود به اتاق", - "@enterRoom": {}, - "newGroup": "گروه جدید", - "@newGroup": {}, - "foregroundServiceRunning": "این اعلان زمانی وقتی ظاهر می شود که سرویس پیش‌زمینه در حال اجرا است.", - "@foregroundServiceRunning": {}, - "appearOnTopDetails": "به برنامه اجازه می‌دهد در بالا ظاهر شود (اگر قبلا فلافی‌‌چت را به عنوان حساب تماس تنظیم کرده‌اید، لازم نیست)", - "@appearOnTopDetails": {}, - "storeSecurlyOnThisDevice": "به طور ایمن در دستگاه ذخیره کنید", - "@storeSecurlyOnThisDevice": {}, - "screenSharingDetail": "شما در حال به اشتراک‌گذاری صفحه‌نمایش خود در فلافی‌چت هستید", - "@screenSharingDetail": {}, - "newSpace": "فضای جدید", - "@newSpace": {}, - "saveKeyManuallyDescription": "این کلید را به صورت دستی با فعال کردن گفتگوی اشتراک گذاری سیستم یا کلیپ بورد ذخیره کنید.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "در Android KeyStore ذخیره کنید", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "در Apple KeyChain ذخیره کنید", - "@storeInAppleKeyChain": {}, - "user": "کاربر", - "@user": {}, - "custom": "سفارشی", - "@custom": {}, - "screenSharingTitle": "اشتراک گذاری صفحه نمایش", - "@screenSharingTitle": {}, - "callingPermissions": "اجازه‌های تماس", - "@callingPermissions": {}, - "callingAccount": "حساب تماس", - "@callingAccount": {}, - "appearOnTop": "در بالا ظاهر شود", - "@appearOnTop": {}, - "otherCallingPermissions": "میکروفون، دوربین و سایر مجوزهای فلافی‌چت", - "@otherCallingPermissions": {}, - "whyIsThisMessageEncrypted": "چرا این پیام قابل خواندن نیست؟", - "@whyIsThisMessageEncrypted": {}, - "reopenChat": "گپ را دوباره باز کنید", - "@reopenChat": {}, - "unmuteChat": "بازکردن صدای گپ", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "nextAccount": "حساب بعدی", - "@nextAccount": {}, - "unlockOldMessages": "گشودن قفل پیام‌های قدیمی", - "@unlockOldMessages": {}, - "share": "اشتراک‌گذاری", - "@share": { - "type": "text", - "placeholders": {} - }, - "skip": "رد شدن", - "@skip": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "سیستم", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "با هم منطبق نیستند", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "تغییر حالت محبوبیت", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "تغییر حالت بی‌صدا", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "علامت‌گذاشتن به عنوان خوانده‌شده/خوانده‌نشده", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "unavailable": "خارج از دسترس", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unblockDevice": "برداشتن مسدود بودن دستگاه", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "شروع بازبینی و تایید", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "بازبینی و تایید با موفقیت انجام شد!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "در انتظار پذیرفتن شکلک از جانب فرد دیگر…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "کاغذدیواری:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "چه کسی توان انجام کدام عمل را داراست", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "نوشتن پیام…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "widgetVideo": "ویدئو", - "@widgetVideo": {}, - "youHaveBeenBannedFromThisChat": "شما از این گپ محروم شده‌اید", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "تنظیم درجه اجازه‌ها", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "تنظیم وضعیت", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "تنظیمات", - "@settings": { - "type": "text", - "placeholders": {} - }, - "showPassword": "نمایش رمز عبور", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "شناسایی یگانه(Single Sign on)", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "spaceName": "نام فضا", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startFirstChat": "اولین گپ خود را شروع کنید", - "@startFirstChat": {}, - "theyMatch": "با هم منطبق هستند", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "فلافی‌چت", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "تعداد درخواست‌های بیش از حد. لطفا بعدا دوباره امتحان کنید!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} محرومیت {targetName} را برداشت", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unknownEncryptionAlgorithm": "الگوریتم رمزگذاری ناشناخته", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unpin": "برداشتن سنجاق", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "userAndUserAreTyping": "{username} و {username2} در حال تایپ کردن…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "videoCall": "تماس تصویری", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "قابل رویت برای تمام شرکت‌کنندگان", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "قابل رویت برای همه", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "پیام صوتی", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "در انتظار پذیرفتن درخواست از جانب فرد دیگر…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "warning": "هشدار!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "شما دیگر در این گپ شرکت نمی‌کنید", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "messageInfo": "اطلاعات پیام", - "@messageInfo": {}, - "time": "زمان", - "@time": {}, - "messageType": "نوع پیام", - "@messageType": {}, - "addToSpaceDescription": "فضایی برای افزودن این گپ به آن انتخاب کنید.", - "@addToSpaceDescription": {}, - "start": "شروع", - "@start": {}, - "videoWithSize": "ویدئو ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "userIsTyping": "{username} در حال تایپ کردن…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "نام‌کاربری", - "@username": { - "type": "text", - "placeholders": {} - }, - "yes": "بله", - "@yes": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "کلید عمومی شما", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "publish": "انتشار", - "@publish": {}, - "shareLocation": "اشتراک‌گذاری وضعیت مکانی", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "youInvitedUser": "📩 شما {user} را دعوت کردید", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "unverified": "تاییدنشده", - "@unverified": {}, - "verify": "بازبینی و تایید", - "@verify": { - "type": "text", - "placeholders": {} - }, - "openChat": "بازکردن گپ", - "@openChat": {}, - "dismiss": "رد كردن‌", - "@dismiss": {}, - "unsupportedAndroidVersion": "نسخه اندروید پشتیبانی نشده", - "@unsupportedAndroidVersion": {}, - "youUnbannedUser": "شما محرومیت {user} را برداشتید", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "verified": "تاییدشده", - "@verified": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "چرا می‌خواهید گزارش دهید؟", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "you": "شما", - "@you": { - "type": "text", - "placeholders": {} - }, - "widgetJitsi": "جیتسی‌میت(Jitsi Meet)", - "@widgetJitsi": {}, - "sourceCode": "کد منبع", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "فضا عمومی است", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "در حال همگام‌سازی... لطفا صبر کنید.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "رویداد ناشناخته «{type}»", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "userAndOthersAreTyping": "{username} و {count} نفر دیگر در حال تایپ کردن…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userLeftTheChat": "🚪{username} گپ را ترک کرد", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "verifyTitle": "در حال تایید حساب دیگر", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "قابلیت دیدن تاریخچه گپ", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "چه کسی اجازه پیوستن به این گروه را دارد", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "در انتظار پذیرفتن اعداد از جانب فرد دیگر…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "برای ایجاد کلید بازیابی جدید، پشتیبان گپ خود را پاک می‌کنید؟", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "با این آدرس‌ها می‌توانید رمز خود را بازیابی کنید.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "openGallery": "بازکردن گالری", - "@openGallery": {}, - "removeFromSpace": "حذف از فضا", - "@removeFromSpace": {}, - "pleaseEnterRecoveryKeyDescription": "برای گشودن قفل پیام‌های قدیمیتان، لطفا کلید بازیابی‌ای که در یک نشست پیشین تولید شده را وارد کنید. کلید بازیابی شما، رمز عبور شما نیست.", - "@pleaseEnterRecoveryKeyDescription": {}, - "confirmEventUnpin": "آیا از برداشتن سنجاق رویداد به صورت دائمی مطمئن هستید؟", - "@confirmEventUnpin": {}, - "indexedDbErrorLong": "متاسفانه فضای ذخیره‌سازی پیام‌ها، به صورت پیش‌فرض در حالت خصوصی فعال نیست.\nلطفا آدرس زیر را باز کنید:\nabout:config\nمقدار «dom.indexedDB.privateBrowsing.enabled» را به «true» تغییر دهید\nدر غیر این صورت، امکان اجرای فلافی‌چت وجود ندارد.", - "@indexedDbErrorLong": {}, - "widgetEtherpad": "یادداشت متنی", - "@widgetEtherpad": {}, - "youKickedAndBanned": "🙅 شما {user} را بیرون و محروم کردید", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "statusExampleMessage": "امروز حالتان چطور است؟", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "ارسال", - "@submit": { - "type": "text", - "placeholders": {} - }, - "youRejectedTheInvitation": "شما دعوت را رد کردید", - "@youRejectedTheInvitation": {}, - "youAcceptedTheInvitation": "👍 شما دعوت را پذیرفتید", - "@youAcceptedTheInvitation": {}, - "emailOrUsername": "رایانامه(ایمیل) یا نام کاربری", - "@emailOrUsername": {}, - "transferFromAnotherDevice": "انتقال از دستگاهی دیگر", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "videoCallsBetaWarning": "لطفا توجه داشته باشید که تماس‌های تصویری در حال حاضر آزمایشی هستند. ممکن است طبق انتظار کار نکنند یا روی همه پلتفرم‌ها اصلا کار نکنند.", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "تماس‌های تصویری آزمایشی", - "@experimentalVideoCalls": {}, - "placeCall": "برقراری تماس", - "@placeCall": {}, - "unsupportedAndroidVersionLong": "این ویژگی به نسخه تازه‌تری از اندروید نیاز دارد. لطفا به‌روزرسانی یا پشتیبانی لینیج‌اواس(LineageOS) را بررسی کنید.", - "@unsupportedAndroidVersionLong": {}, - "sharedTheLocation": "{username} وضعیت مکانی خود را به اشتراک گذاشت", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "unreadChats": "{unreadCount, plural, other{{unreadCount} گپ خوانده نشده}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "status": "وضعیت", - "@status": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "دستگاه ناشناس", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "markAsRead": "علامت‌گذاشتن به عنوان خوانده شده", - "@markAsRead": {}, - "reportUser": "گزارش دادن کاربر", - "@reportUser": {}, - "pinMessage": "سنجاق کردن به اتاق", - "@pinMessage": {}, - "emojis": "شکلک‌ها", - "@emojis": {}, - "voiceCall": "تماس صوتی", - "@voiceCall": {}, - "indexedDbErrorTitle": "اشکالات حالت خصوصی", - "@indexedDbErrorTitle": {}, - "switchToAccount": "تغییر به حساب {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "previousAccount": "حساب قبلی", - "@previousAccount": {}, - "addWidget": "افزودن ویجت", - "@addWidget": {}, - "widgetCustom": "سفارشی", - "@widgetCustom": {}, - "widgetName": "نام", - "@widgetName": {}, - "widgetUrlError": "این آدرس وب معتبر نیست.", - "@widgetUrlError": {}, - "widgetNameError": "لطفا یک نام نمایشی مشخص کنید.", - "@widgetNameError": {}, - "errorAddingWidget": "بروز خطا هنگام افزودن ویجت.", - "@errorAddingWidget": {}, - "youJoinedTheChat": "شما به گپ پیوستید", - "@youJoinedTheChat": {}, - "youBannedUser": "شما {user} را محروم کردید", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "شما دعوت {user} را پس‌گرفتید", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 شما توسط {user} دعوت شده‌اید", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 شما {user} را بیرون کردید", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "users": "کاربرها", - "@users": {}, - "storeInSecureStorageDescription": "کلید بازیابی را در محل ذخیره‌سازی امن این دستگاه ذخیره کنید.", - "@storeInSecureStorageDescription": {}, - "jump": "پرش", - "@jump": {}, - "allRooms": "تمام چت‌های گروهی", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "report": "گزارش", - "@report": {}, - "openLinkInBrowser": "بازکردن پیوند در مرورگر", - "@openLinkInBrowser": {}, - "reportErrorDescription": "اوه نه. اشتباهی رخ داد. اگر تمایل دارید، می‌توانید این اشکال را با توسعه‌دهندگان گزارش دهید.", - "@reportErrorDescription": {}, - "signInWithPassword": "ورود با رمزعبور", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "لطفا بعدا تلاش کنید یا سرور دیگری انتخاب کنید.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@setColorTheme": {}, - "@banUserDescription": {}, - "@removeDevicesDescription": {}, - "@tryAgain": {}, - "@unbanUserDescription": {}, - "@messagesStyle": {}, - "@chatDescription": {}, - "@pushNotificationsNotAvailable": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@makeAdminDescription": {}, - "@setChatDescription": {}, - "@importFromZipFile": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@optionalRedactReason": {}, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@redactMessageDescription": {}, - "@invalidInput": {}, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@invitePrivateChat": {}, - "@importEmojis": {}, - "@noChatDescriptionYet": {}, - "@learnMore": {}, - "notAnImage": "یک فایل تصویری نیست.", - "@notAnImage": {}, - "@chatDescriptionHasBeenChanged": {}, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "@profileNotFound": {}, - "@shareInviteLink": {}, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@replace": {}, - "@createGroup": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@invite": {} -} diff --git a/assets/l10n/intl_fi.arb b/assets/l10n/intl_fi.arb deleted file mode 100644 index 65465acfd..000000000 --- a/assets/l10n/intl_fi.arb +++ /dev/null @@ -1,2413 +0,0 @@ -{ - "repeatPassword": "Salasana uudelleen", - "@repeatPassword": {}, - "about": "Tietoa FluffyChatista", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Hyväksy", - "@accept": { - "type": "text", - "placeholders": {} - }, - "account": "Tili", - "@account": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "{username} hyväksyi kutsun", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "activatedEndToEndEncryption": "🔐 {username} otti käyttöön päästä-päähän salauksen", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "archive": "Arkisto", - "@archive": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Voidaksesi allekirjoittaa toisen henkilön, syötä turvavaraston salalause tai palautusavain.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "addEmail": "Lisää sähköpostiosoite", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Lisää tilaan", - "@addToSpace": {}, - "admin": "Ylläpitäjä", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Kaikki", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Kaikki keskustelut", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} vastasi puheluun", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Kuka tahansa voi liittyä", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Sovelluksen lukitus", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Sallitaanko vieraiden liittyminen", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Haluatko varmasti kirjautua ulos?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Oletko varma?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "Toista animoidut tarrat ja emojit automaattisesti", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "askVerificationRequest": "Hyväksytäänkö tämä varmennuspyyntö käyttäjältä {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sendOnEnter": "Lähetä painamalla rivinvaihtonäppäintä", - "@sendOnEnter": {}, - "badServerVersionsException": "Kotipalvelin tukee Matrix Spec versio(it)a:\n{serverVersions}, mutta tämä sovellus tukee vain versio(it)a {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerLoginTypesException": "Tämä kotipalvelin tukee sisäänkirjautumistapoja: \n{serverVersions},\nmutta tämä sovellus tukee vain -tapoja: \n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Anna porttikielto keskusteluun", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Porttikiellossa", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} antoi porttikiellon käyttäjälle {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Estä laite", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Estetty", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bottien lähettämät viestit", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Peruuta", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Vaihda laitteen nimeä", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} muutti keskustelun kuvaa", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatNameTo": "{username} asetti keskustelun nimeksi: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheDisplaynameTo": "{username} asetti näyttönimekseen: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} muutti vieraspääsyn sääntöjä", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} asetti vieraspääsyn säännö(i)ksi: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} muutti historian näkyvyyttä", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} asetti historian näkymissäännöksi: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} muutti liittymissääntöjä", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} asetti liittymissäännöiksi: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} vaihtoi profiilikuvaansa", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} muutti kutsulinkkiä", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Vaihda salasana", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changedTheRoomAliases": "{username} muutti huoneen aliaksia", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "cantOpenUri": "URI-osoitetta {uri} ei voida avata", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changedTheChatDescriptionTo": "{username} asetti keskustelun kuvaukseksi: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatPermissions": "{username} muutti keskustelun oikeuksia", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeTheme": "Vaihda tyyliäsi", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "Keskustelujesi varmuuskopiointi on asetettu.", - "@yourChatBackupHasBeenSetUp": {}, - "chatBackup": "Keskustelun varmuuskopiointi", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Vanhat viestisi on suojattu palautusavaimella. Varmistathan ettet hävitä sitä.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Keskustelun tiedot", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Keskustelu on lisätty tähän tilaan", - "@chatHasBeenAddedToThisSpace": {}, - "chats": "Keskustelut", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Valitse vahva salasana", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Sulje", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_html": "Lähetä HTML-muotoiltua tekstiä", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_ban": "Anna syötetylle käyttäjälle porttikielto tähän huoneeseen", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_invite": "Kutsu syötetty käyttäjä tähän huoneeseen", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_leave": "Poistu tästä huoneesta", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_myroomavatar": "Aseta profiilikuvasi tähän huoneeseen (syöttämällä mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Aseta näyttönimesi vain tässä huoneessa", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Aseta käyttäjän voimataso (oletus: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Lähetä muotoilematonta tekstiä", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Lähetä vastaus reaktiona", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "create": "Luo", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "{username} loi keskustelun", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Uusi tila", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Aktiivinen nyt", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "dateWithoutYear": "{day}.{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithYear": "{day}.{month}.{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Tämä poistaa tunnuksesi käytöstä. Tätä ei voi kumota! Oletko varma?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Oikeuksien oletustaso", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Poista", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Poista tunnus", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Poista viesti", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Laite", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Laite-ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Laitteet", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Suorat keskustelut", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Näyttönimi on vaihdettu", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Lataa tiedosto", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Muokkaa", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Muokkaa estettyjä palvelimia", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Muokkaa näyttönimeä", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Muokkaa huoneen aliaksia", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Muokkaa huoneen profiilikuvaa", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emote on jo olemassa!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Epäkelpo emote-lyhytkoodi", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Huoneen emote-paketit", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emote-asetukset", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Emote-lyhytkoodi", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Emote-lyhytkoodi ja kuva on valittava!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Tyhjä keskustelu", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Et voi poistaa salausta myöhemmin. Oletko varma?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Salaus ei ole käytössä", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} päätti puhelun", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Syötä sähköposti-osoite", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Kotipalvelin", - "@homeserver": {}, - "enterYourHomeserver": "Syötä kotipalvelimesi", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Virhe paikannuksessa: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Kaikki on valmista!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Erittäin loukkaavaa", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Tiedostonimi", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Alkaen liittymisestä", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Alkaen kutsumisesta", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Mene uuteen huoneeseen", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Ryhmä", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Ryhmä on julkinen", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Ryhmät", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Ryhmä seuralaisina {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Vieraat on kielletty", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Vieraat voivat liittyä", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} on perunnut käyttäjän {targetName} kutsun", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Apua", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Piilota poistetut tapahtumat", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Piilota tuntemattomat tapahtumat", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Kuinka loukkaavaa tämä sisältö on?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identiteetti", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Jätä huomioitta", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Huomiotta jätetyt käyttäjät", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Kutsu yhteystieto", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "invited": "Kutsuttu", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} kutsui käyttäjän {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Vain kutsutut käyttäjät", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Kutsu minua varten", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} kutsui sinut FluffyChattiin.\n1. Viereaile sivulla: https://fluffychat.im ja asenna sovellus\n2. Rekisteröidy tai kirjaudu sisään\n3. Avaa kutsulinkki:\n{link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "kicked": "👞 {username} potki käyttäjän {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} potki ja antoi porttikiellon käyttäjälle {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Potki keskustelusta", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Aktiivinen viimeksi: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Poistu", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Poistui keskustelusta", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Lisenssi", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Vaalea", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadingPleaseWait": "Ladataan... Hetkinen.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Lataa vielä {count} osallistujaa", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadMore": "Lataa lisää…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Sijaintipalvelut ovat poissa käytöstä. Otathan ne käyttöön jakaaksesi sijaintisi.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "SIjaintioikeus on estetty. Myönnäthän sen jakaaksesi sijaintisi.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Kirjaudu sisään", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Kirjaudu sisään palvelimelle {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Kirjaudu ulos", - "@logout": { - "type": "text", - "placeholders": {} - }, - "mention": "Mainitse", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Viestit", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Valvoja", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Vaienna keskustelu", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "newChat": "Uusi keskustelu", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Uusi viesti FluffyChätissä", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Uusi varmennuspyyntö!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Seuraava", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Ei", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Ei yhteyttä palvelimeen", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Voit ottaa salauksen käyttöön vasta kun huone ei ole julkisesti liityttävissä.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} ei ole Matrix-palvelin, käytetäänkö {server2} sen sijaan?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "scanQrCode": "Skannaa QR-koodi", - "@scanQrCode": {}, - "none": "Ei yhtään", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Et ole vielä lisännyt tapaa salasanasi palauttamiseksi.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Huoneita ei löytynyt…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Ilmoitukset", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} käyttäjää kirjoittavat…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Paikannetaan sijantia…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Loukkaava", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Poissa verkosta", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Linjoilla", - "@online": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Kopioitu leikepöydälle", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopioi", - "@copy": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Vaihda profiilikuvasi", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "chat": "Keskustelu", - "@chat": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Tyhjennä arkisto", - "@clearArchive": {}, - "forward": "Edelleenlähetä", - "@forward": { - "type": "text", - "placeholders": {} - }, - "commandHint_join": "Liity syötettyyn huoneeseen", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_me": "Kuvaile itseäsi", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "compareEmojiMatch": "Vertaa hymiöitä", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Vahvista", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Sisältää käyttäjätunnuksen", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} osallistujaa", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "changeTheHomeserver": "Vaihda kotipalvelinta", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Vaihda ryhmän nimeä", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Salaus on korruptoitunut", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "commandHint_kick": "Poista syötetty käyttäjä huoneesta", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_unban": "Poista syötetyn käyttäjän porttikielto tästä huoneesta", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandMissing": "{command} ei ole komento.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "commandHint_send": "Lähetä tekstiä", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandInvalid": "Epäkelvollinen komento", - "@commandInvalid": { - "type": "text" - }, - "compareNumbersMatch": "Vertaa numeroita", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Määritä keskustelu", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "connect": "Yhdistä", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Yhteystieto on kutsuttu ryhmään", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Sisältää näyttönimen", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Sisältö on ilmoitettu palvelimen ylläpitäjille", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopioi leikepöydälle", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Viestin salausta ei voitu purkaa: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "encrypted": "Salattu", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Salaus", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Loukkaamatonta", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Kutsu yhteystieto ryhmään {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "isTyping": "kirjoittaa…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Ota emote-paketti käyttöön kaikkialla", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Tumma", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Ota salaus käyttöön", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Fonttikoko", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Olen klikannut linkkiä", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Virheellinen salasana tai palautusavain", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} liittyi keskusteluun", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "notificationsEnabledForThisAccount": "Tämän tunnuksen ilmoitukset ovat käytössä", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "Liity huoneeseen", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Jäsenmuutoksia", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Tiedäthän tarvitsevasi toistaiseksi Pantalaimonin käyttääksesi päästä-päähän-salausta.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Emoteja ei löytynyt. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Firebase Cloud Messaging -palvelu ei vaikuta olevan saatavilla laitteellasi. Saadaksesi push-ilmoituksia silti, suosittelemme Ntfy-sovelluksen asentamista. Käyttämällä Ntfy-sovellusta tai muuta Unified Push -tarjoajaa, saat push-ilmoitukset tietoturvallisella tavalla. Voit ladata Ntfy-sovelluksen Play Kaupasta tai F-Droidista.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Ei lupaa", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "enableMultiAccounts": "(BETA) Ota käyttöön tuki usealle tilille tällä laitteella", - "@enableMultiAccounts": {}, - "onlineKeyBackupEnabled": "Verkkkoavainvarmuuskopio on käytössä", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Hups! Valitettavasti push-ilmoituksia käyttöönotettaessa tapahtui virhe.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Hups, jotakin meni pieleen…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Avaa sovellus lukeaksesi viestit", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Avaa kamera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "Yksi tunnuksistasi on kirjattu ulos", - "@oneClientLoggedOut": {}, - "addAccount": "Lisää tili", - "@addAccount": {}, - "editBundlesForAccount": "Muokkaa tämän tilin kääröjä", - "@editBundlesForAccount": {}, - "addToBundle": "Lisää kääreeseen", - "@addToBundle": {}, - "removeFromBundle": "Poista tästä kääreestä", - "@removeFromBundle": {}, - "bundleName": "Kääreen nimi", - "@bundleName": {}, - "openInMaps": "Avaa kartoissa", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Tai", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Osallistuja", - "@participant": { - "type": "text", - "placeholders": {} - }, - "password": "Salasana", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Salasana on vaihdettu", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Salasanan palautus", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Ihmiset", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Valitse kuva", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Kiinnitä", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Toista {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Valitse", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Valitse pääsykoodi", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Klikkaa linkkiä sähköpostissa ja sitten jatka.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Syötä 4 numeroa tai jätä tyhjäksi poistaaksesi sovelluksen lukituksen.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Syötä PIN-koodisi", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Syötä käyttäjätunnuksesi", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Seuraa ohjeita verkkosivulla ja paina seuraava.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Yksityisyys", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "recording": "Tallenne", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} poisti tapahtuman", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Poista viesti", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Rekisteröidy", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Hylkää", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} hylkäsi kutsun", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Liity uudelleen", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Poista", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Poista kaikki muut laitteet", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Poistanut {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Poista laite", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Poista porttikielto keskusteluun", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Nähnyt {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sendAMessage": "Lähetä viesti", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "send": "Lähetä", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Lähetä tekstinä", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Lähetä ääniviesti", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Lähetä tiedosto", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Lähetä kuva", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Lähetä viestejä", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Lähetä alkuperäinen", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Aseta pääalias", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Aseta mukautetut emotet", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Aseta kutsulinkki", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Aseta oikeustasot", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Aseta tila", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Asetukset", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Jaa", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} jakoi sijaintinsa", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "singlesignon": "Kertakirjautuminen", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Ohita", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Lähdekoodi", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Tila on julkinen", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Tilan nimi", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "status": "Tila", - "@status": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Synkronoidaan... Hetkinen.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Järjestelmä", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Ne eivät täsmää", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Ne täsmäävät", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Mykistetty-kytkin", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Liikaa pyyntöjä. Yritä myöhemmin uudelleen!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Merkitse lukemattomaksi/luetuksi", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Siirrä toiselta laitteelta", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Yritä uudelleenlähettämistä", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} poisti käyttäjän {targetName} porttikiellon", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Poista laitteen esto", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Tuntematon laite", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Tuntematon salausalgoritmi", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Tuntematon tapahtuma '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "userAndOthersAreTyping": "{username} ja {count} muuta kirjoittavat…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} ja {username2} kirjoittavat…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} kirjoittaa…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} poistui keskustelusta", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userSentUnknownEvent": "{username} lähetti {type}-tapahtuman", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "unverified": "Varmistamaton", - "@unverified": {}, - "verified": "Varmistettu", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Aloita varmennus", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Varmensit onnistuneesti!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Varmistetaan toista tunnusta", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Keskusteluhistorian näkyvyys", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Näkyy kaikille osallistujille", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Näkyy kaikille", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Ääniviesti", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Odotetaan kumppanin varmistavan pyynnön…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Odotetaan kumppanin hyväksyvän emojit…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Odotetaan kumppanin hyväksyvän numerot…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Taustakuva:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Varoitus!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Lähetimme sinulle sähköpostia", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Kuka voi suorittaa minkä toimenpiteen", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Kenen on sallittua liittyä ryhmään", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Miksi haluat ilmoittaa tämän?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Pyyhi keskusteluvarmuuskopio luodaksesi uuden palautusavaimen?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Näillä osoitteilla voit palauttaa salasanasi.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Et enää osallistu tähän keskusteluun", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Sinulle on annettu porttikielto tähän keskusteluun", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "removeFromSpace": "Poista tilasta", - "@removeFromSpace": {}, - "addToSpaceDescription": "Valitse tila, johon tämä keskustelu lisätään.", - "@addToSpaceDescription": {}, - "start": "Aloita", - "@start": {}, - "serverRequiresEmail": "Tämän palvelimen täytyy tarkistaa sähköposti-osoitteesi rekisteröitymistä varten.", - "@serverRequiresEmail": {}, - "roomVersion": "Huoneen versio", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "sentCallInformations": "{senderName} lähetti puhelutiedot", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "unavailable": "Ei saatavilla", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "verify": "Varmista", - "@verify": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "salalause tai palautusavain", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Syötä salasanasi", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Huone on päivitetty", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "search": "Hae", - "@search": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} lähetti tiedoston", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} lähetti ääniviestin", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "link": "Linkki", - "@link": {}, - "passwordForgotten": "Salasana unohtunut", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Poista profiilikuvasi", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Renderöi rikas-viestisisältö", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "Vastaa", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Ilmoita viesti", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Pyydä lupaa", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Tallenna tiedosto", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "security": "Turvallisuus", - "@security": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Lähetä tarra", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Julkiset huoneet", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Push-säännöt", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Syy", - "@reason": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Korvaa huone uudemmalla versiolla", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Lähetä video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAPicture": "🖼️ {username} lähetti kuvan", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} lähetti tarran", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} lähetti videon", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Jaa sijainti", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Näytä salasana", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Millainen on vointisi?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 lukematon keskustelu} other{{unreadCount} lukematonta keskustelua}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "videoCall": "Videopuhelu", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "sender": "Lähettäjä", - "@sender": {}, - "startedACall": "{senderName} aloitti puhelun", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "submit": "Lähetä", - "@submit": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Suosikki-kytkin", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "unmuteChat": "Poista keskustelun mykistys", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Poista kiinnitys", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "time": "Aika", - "@time": {}, - "messageType": "Viestin tyyppi", - "@messageType": {}, - "username": "Käyttäjätunnus", - "@username": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Kirjoita viesti…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Kyllä", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Sinä", - "@you": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Julkinen avaimesi", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "messageInfo": "Viestin tiedot", - "@messageInfo": {}, - "openGallery": "Avaa galleria", - "@openGallery": {}, - "commandHint_clearcache": "Tyhjennä välimuisti", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Luo tyhjä ryhmäkeskustelu\nKäytä parametria --no-encryption poistaaksesi salauksen käytöstä", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_dm": "Aloita yksityiskeskustelu\nKäytä parametria --no-encryption poistaaksesi salauksen käytöstä", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_discardsession": "Hylkää istunto", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "openVideoCamera": "Avaa kamera videokuvausta varten", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "publish": "Julkaise", - "@publish": {}, - "markAsRead": "Merkitse luetuksi", - "@markAsRead": {}, - "dismiss": "Hylkää", - "@dismiss": {}, - "emojis": "Hymiöt", - "@emojis": {}, - "unsupportedAndroidVersionLong": "Tämä ominaisuus vaatii uudemman Android-version. Tarkista päivitykset tai LineageOS-tuki.", - "@unsupportedAndroidVersionLong": {}, - "unsupportedAndroidVersion": "Ei tuettu Android-versio", - "@unsupportedAndroidVersion": {}, - "reportUser": "Ilmianna käyttäjä", - "@reportUser": {}, - "voiceCall": "Äänipuhelu", - "@voiceCall": {}, - "videoCallsBetaWarning": "Huomaathan videopuheluiden ovan beta-asteella. Ne eivät ehkä toimi odotetusti tai toimi ollenkaan kaikilla alustoilla.", - "@videoCallsBetaWarning": {}, - "placeCall": "Soita", - "@placeCall": {}, - "reactedWith": "{sender} reagoi {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "openChat": "Avaa Keskustelu", - "@openChat": {}, - "pinMessage": "Kiinnitä huoneeseen", - "@pinMessage": {}, - "confirmEventUnpin": "Haluatko varmasti irrottaa tapahtuman pysyvästi?", - "@confirmEventUnpin": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Mukautettu", - "@widgetCustom": {}, - "widgetName": "Nimi", - "@widgetName": {}, - "widgetUrlError": "Epäkelvollinen URL.", - "@widgetUrlError": {}, - "errorAddingWidget": "Virhe lisättäessä pienoissovellusta.", - "@errorAddingWidget": {}, - "nextAccount": "Seuraava tili", - "@nextAccount": {}, - "switchToAccount": "Siirry tilille {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "experimentalVideoCalls": "Kokeelliset videopuhelut", - "@experimentalVideoCalls": {}, - "emailOrUsername": "Sähköposti-osoite tai käyttäjätunnus", - "@emailOrUsername": {}, - "previousAccount": "Edellinen tili", - "@previousAccount": {}, - "widgetEtherpad": "Tekstimuotoinen muistiinpano", - "@widgetEtherpad": {}, - "widgetNameError": "Syötä näyttönimi.", - "@widgetNameError": {}, - "addWidget": "Lisää pienoissovellus", - "@addWidget": {}, - "youRejectedTheInvitation": "Kieltäydyit kutsusta", - "@youRejectedTheInvitation": {}, - "youJoinedTheChat": "Liityit keskusteluun", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Hyväksyit kutsun", - "@youAcceptedTheInvitation": {}, - "youBannedUser": "Annoit porttikiellon käyttäjälle {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Olet perunut kutsun käyttäjälle {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 {user} kutsui sinut", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 Potkit käyttäjän {user} keskustelusta", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Kutsuit käyttäjän {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Potkit ja annoit porttikiellon käyttäjälle {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Poistit käyttäjän {user} porttikiellon", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "separateChatTypes": "Erota yksityiskeskustelut ryhmistä", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "dehydrateTor": "TOR-käyttäjät: vie istunto", - "@dehydrateTor": {}, - "hydrateTor": "TOR-käyttäjät: tuo viety istunto", - "@hydrateTor": {}, - "hydrateTorLong": "Veitkö edellisen istuntosi käyttäessäsi TORia? Tuo se nopeasti ja jatka jutustelua.", - "@hydrateTorLong": {}, - "pleaseEnterRecoveryKey": "Syötä palautusavaimesi:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKey": "Palautusavain", - "@recoveryKey": {}, - "recoveryKeyLost": "Kadonnut palautusavain?", - "@recoveryKeyLost": {}, - "dehydrateTorLong": "Tor-käyttäjille suositellaan istunnon vientiä ennen ikkunan sulkemista.", - "@dehydrateTorLong": {}, - "hydrate": "Palauta varmuuskopiotiedostosta", - "@hydrate": {}, - "dehydrate": "Vie istunto ja tyhjennä laite", - "@dehydrate": {}, - "dehydrateWarning": "Tätä toimenpidettä ei voi kumota.\nVarmista varmuuskopiotiedoston turvallinen tallennus.", - "@dehydrateWarning": {}, - "users": "Käyttäjät", - "@users": {}, - "storeSecurlyOnThisDevice": "Tallenna turvallisesti tälle laitteelle", - "@storeSecurlyOnThisDevice": {}, - "pleaseEnterRecoveryKeyDescription": "Avataksesi vanhojen viestiesi salauksen, syötä palautusavaimesi, joka luotiin edellisessä istunnossa. Palautusavaimesi EI OLE salasanasi.", - "@pleaseEnterRecoveryKeyDescription": {}, - "unlockOldMessages": "Pura vanhojen viestien salaus", - "@unlockOldMessages": {}, - "indexedDbErrorLong": "Viestivarasto ei ole käytössä yksityisselauksessa oletuksena.\nKäythän osoitteessa\n - about:config\n - Aseta dom.indexedDB.privateBrowsing.enabled arvoon true\nMuuten FluffyChatin käyttäminen ei ole mahdollista.", - "@indexedDbErrorLong": {}, - "saveKeyManuallyDescription": "Tallenna tämä avain manuaalisesti käyttäen järjestelmän jakodialogia tai leikepöytää.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Tallenna Android KeyStoreen", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "Tallenna Applen avainnippuun", - "@storeInAppleKeyChain": {}, - "countFiles": "{count} tiedostoa", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "storeInSecureStorageDescription": "Tallenna palautusavain tämän laitteen turvavarastoon.", - "@storeInSecureStorageDescription": {}, - "indexedDbErrorTitle": "Yksityisen selauksen ongelmat", - "@indexedDbErrorTitle": {}, - "user": "Käyttäjä", - "@user": {}, - "custom": "Mukautettu", - "@custom": {}, - "confirmMatrixId": "Kirjoita Matrix IDsi uudelleen poistaaksesi tunnuksesi.", - "@confirmMatrixId": {}, - "supposedMxid": "Tämän pitäisi olla {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasgroup": "Merkitse ryhmäksi", - "@commandHint_markasgroup": {}, - "whyIsThisMessageEncrypted": "Miksei tätä viestiä voida lukea?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "Tämä voi tapahtua mikäli viesti lähetettiin ennen sisäänkirjautumistasi tälle laitteelle.\n\nOn myös mahdollista, että lähettäjä on estänyt tämän laitteen tai jokin meni pieleen verkkoyhteyden kanssa.\n\nPystytkö lukemaan viestin toisella istunnolla? Siinä tapauksessa voit siirtää viestin siltä! Mene Asetukset > Laitteet ja varmista, että laitteesi ovat varmistaneet toisensa. Seuraavankerran avatessasi huoneen ja molempien istuntojen ollessa etualalla, avaimet siirretään automaattisesti.\n\nHaluatko varmistaa ettet menetä avaimia uloskirjautuessa tai laitteita vaihtaessa? Varmista avainvarmuuskopion käytössäolo asetuksista.", - "@noKeyForThisMessage": {}, - "commandHint_markasdm": "Merkitse yksityiskeskusteluksi syötetyn Matrix IDn kanssa", - "@commandHint_markasdm": {}, - "foregroundServiceRunning": "Tämä ilmoitus näkyy etualapalvelun ollessa käynnissä.", - "@foregroundServiceRunning": {}, - "callingPermissions": "Puheluoikeudet", - "@callingPermissions": {}, - "callingAccount": "Soittamistunnus", - "@callingAccount": {}, - "callingAccountDetails": "Sallii FluffyChatin käyttää Androidin omaa Puhelut-sovellusta.", - "@callingAccountDetails": {}, - "appearOnTop": "Näy päällä", - "@appearOnTop": {}, - "appearOnTopDetails": "Sallii sovelluksen näkyä muiden sovellusten päällä (tätä ei tarvita, mikäli olet jo määrittänyt FluffyChatin puhelin-tunnukseksi)", - "@appearOnTopDetails": {}, - "newSpace": "Uusi tila", - "@newSpace": {}, - "enterSpace": "Siirry tilaan", - "@enterSpace": {}, - "enterRoom": "Siirry huoneeseen", - "@enterRoom": {}, - "allSpaces": "Kaikki tilat", - "@allSpaces": {}, - "screenSharingTitle": "ruudunjako", - "@screenSharingTitle": {}, - "otherCallingPermissions": "Mikrofoni, kamera ja muut FluffyChatin oikeudet", - "@otherCallingPermissions": {}, - "newGroup": "Uusi ryhmä", - "@newGroup": {}, - "screenSharingDetail": "Jaat ruutuasi FluffyChatissä", - "@screenSharingDetail": {}, - "hugContent": "{senderName} halaa sinua", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} kokovartalohalaa sinua", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_hug": "Lähetä halaus", - "@commandHint_hug": {}, - "googlyEyesContent": "{senderName} lähettää askartelusilmiä", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "numChats": "{number} keskustelua", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "commandHint_googly": "Lähetä askartelusilmiä", - "@commandHint_googly": {}, - "commandHint_cuddle": "Lähetä kokovartaluhalaus", - "@commandHint_cuddle": {}, - "hideUnimportantStateEvents": "Piilota ei-niin-tärkeät tilatapahtumat", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Älä näytä uudelleen", - "@doNotShowAgain": {}, - "fileHasBeenSavedAt": "Tiedosto on tallennettu sijaintiin {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "disableEncryptionWarning": "Turvallisuuden vuoksi et voi poistaa salausta käytöstä huoneista, joissa se on aiemmin otettu käyttöön.", - "@disableEncryptionWarning": {}, - "allRooms": "Kaikki ryhmäkeskustelut", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "startFirstChat": "Aloita ensimmäinen keskustelusi", - "@startFirstChat": {}, - "newSpaceDescription": "Tilat mahdollistavat keskusteluidesi keräämisen ja yksityisten tai julkisten yhteisöjen rakentamisen.", - "@newSpaceDescription": {}, - "deviceKeys": "Laite-avaimet:", - "@deviceKeys": {}, - "reopenChat": "Avaa keskustelu uudelleen", - "@reopenChat": {}, - "noOtherDevicesFound": "Muita laitteita ei löytynyt", - "@noOtherDevicesFound": {}, - "jumpToLastReadMessage": "Hyppää viimeiseen luettuun viestiin", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Luettu tähän asti", - "@readUpToHere": {}, - "jump": "Hyppää", - "@jump": {}, - "openLinkInBrowser": "Avaa linkki selaimessa", - "@openLinkInBrowser": {}, - "report": "ilmoita", - "@report": {}, - "encryptThisChat": "Salaa tämä keskustelu", - "@encryptThisChat": {}, - "noBackupWarning": "Varoitus! Ilman avainvarmuuskopion käyttöönottoa menetät pääsyn salattuihin viesteihisi. Suosittelemme ehdottomasti avainvarmuuskopion käyttöönottoa ennen uloskirjautumista.", - "@noBackupWarning": {}, - "fileIsTooBigForServer": "Palvelimen mukaan tiedosto on liian suuri lähetettäväksi.", - "@fileIsTooBigForServer": {}, - "reportErrorDescription": "Voi ei. Jokin meni pieleen. Yritäthän myöhemmin uudelleen. Halutessasi voit ilmoittaa ongelman kehittäjille.", - "@reportErrorDescription": {}, - "wasDirectChatDisplayName": "Tyhjä keskustelu (oli {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "sorryThatsNotPossible": "Anteeksi... se ei ole mahdollista", - "@sorryThatsNotPossible": {}, - "signInWithPassword": "Kirjaudu sisään salasanalla", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Yritä myöhemmin uudelleen tai valitse toinen palvelin.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "setColorTheme": "Aseta väriteema:", - "@setColorTheme": {}, - "tryAgain": "Yritä uudelleen", - "@tryAgain": {}, - "messagesStyle": "Viestit:", - "@messagesStyle": {}, - "chatDescription": "Keskustelun kuvaus", - "@chatDescription": {}, - "invalidServerName": "Virheellinen palvelimen nimi", - "@invalidServerName": {}, - "chatPermissions": "Keskustelun oikeudet", - "@chatPermissions": {}, - "setChatDescription": "Asetti keskustelun kuvauksen", - "@setChatDescription": {}, - "importFromZipFile": "Tuo .zip -tiedostosta", - "@importFromZipFile": {}, - "redactedBy": "Poistanut {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "signInWith": "Kirjaudu sisään palvelulla {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "optionalRedactReason": "(Vapaaehtoinen) Syy tämän viestin poistamiselle...", - "@optionalRedactReason": {}, - "archiveRoomDescription": "Keskustelu siirretään arkistoon. Muut käyttäjät näkevät sinun poistuneen keskustelusta.", - "@archiveRoomDescription": {}, - "exportEmotePack": "Vie emotepaketti .zip-tiedostona", - "@exportEmotePack": {}, - "inviteContactToGroupQuestion": "Tahdotko kutsua yhteystiedon {contact} keskusteluun \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Poistanut {username} syystä: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "redactMessageDescription": "Viesti poistetaan kaikilta keskustelun osallistujilta. Tätä ei voida kumota.", - "@redactMessageDescription": {}, - "invalidInput": "Virheellinen syöte!", - "@invalidInput": {}, - "addChatDescription": "Lisää keskustelulle kuvaus", - "@addChatDescription": {}, - "hasKnocked": "{user} on koputtanut", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "directChat": "Yksityiskeskustelu", - "@directChat": {}, - "wrongPinEntered": "Väärä pin-koodi! Yritä uudelleen {seconds} sekuntin kuluttua...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "Lähetä kirjoitusilmoituksia", - "@sendTypingNotifications": {}, - "inviteGroupChat": "Kutsu ryhmäkeskusteluun", - "@inviteGroupChat": {}, - "invitePrivateChat": "Kutsu yksityiskeskusteluun", - "@invitePrivateChat": {}, - "importEmojis": "Tuo emojit", - "@importEmojis": {}, - "noChatDescriptionYet": "Keskustelun kuvausta ei ole vielä luotu.", - "@noChatDescriptionYet": {}, - "notAnImage": "Tämä ei ole kuvatiedosto.", - "@notAnImage": {}, - "chatDescriptionHasBeenChanged": "Keskustelun kuvaus muutettu", - "@chatDescriptionHasBeenChanged": {}, - "roomUpgradeDescription": "Keskustelu luodaan uudelleen uudella huoneversiolla. Kaikille osallistujille ilmoitetaan, että heidän tulee siirtyä uuteen keskusteluun. Voit lukea lisää huoneversioista osoitteesta https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Syötä suurempi luku kuin 0", - "@pleaseEnterANumber": {}, - "profileNotFound": "Käyttäjää ei löydy palvelimelta. Tämä voi olla yhteysongelma tai käyttäjä ei ole olemassa.", - "@profileNotFound": {}, - "shareInviteLink": "Jaa kutsulinkki", - "@shareInviteLink": {}, - "emoteKeyboardNoRecents": "Viimeaikoina käytetyt emotet tulevat näkymään täällä...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Aseta teema:", - "@setTheme": {}, - "replace": "Korvaa", - "@replace": {}, - "createGroup": "Luo ryhmä", - "@createGroup": {}, - "importNow": "Tuo nyt", - "@importNow": {}, - "invite": "Kutsu", - "@invite": {}, - "@banUserDescription": {}, - "@removeDevicesDescription": {}, - "@unbanUserDescription": {}, - "@pushNotificationsNotAvailable": {}, - "@makeAdminDescription": {}, - "@learnMore": {}, - "@kickUserDescription": {} -} diff --git a/assets/l10n/intl_ga.arb b/assets/l10n/intl_ga.arb deleted file mode 100644 index c4ba3b5bd..000000000 --- a/assets/l10n/intl_ga.arb +++ /dev/null @@ -1,2248 +0,0 @@ -{ - "you": "Tú", - "@you": { - "type": "text", - "placeholders": {} - }, - "yes": "Tá", - "@yes": { - "type": "text", - "placeholders": {} - }, - "warning": "Rabhadh!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Cúlbhrat", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "verify": "Deimhnigh", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verified": "Deimhnithe", - "@verified": { - "type": "text", - "placeholders": {} - }, - "username": "Ainm úsáideora", - "@username": { - "type": "text", - "placeholders": {} - }, - "unpin": "Bain biorán", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Níl ar fáil", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "systemTheme": "Córas", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "submit": "Cuir isteach", - "@submit": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Conas atá tú inniu?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "status": "Staid", - "@status": { - "type": "text", - "placeholders": {} - }, - "skip": "Léim", - "@skip": { - "type": "text", - "placeholders": {} - }, - "share": "Roinn", - "@share": { - "type": "text", - "placeholders": {} - }, - "settings": "Socruithe", - "@settings": { - "type": "text", - "placeholders": {} - }, - "send": "Seol", - "@send": { - "type": "text", - "placeholders": {} - }, - "security": "Slándáil", - "@security": { - "type": "text", - "placeholders": {} - }, - "search": "Cuardaigh", - "@search": { - "type": "text", - "placeholders": {} - }, - "reply": "Freagair", - "@reply": { - "type": "text", - "placeholders": {} - }, - "remove": "Bain", - "@remove": { - "type": "text", - "placeholders": {} - }, - "rejoin": "Téigh ar ais isteach", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "reject": "Diúltaigh", - "@reject": { - "type": "text", - "placeholders": {} - }, - "register": "Cláraigh", - "@register": { - "type": "text", - "placeholders": {} - }, - "recording": "Ag Taifeadadh", - "@recording": { - "type": "text", - "placeholders": {} - }, - "reason": "Fáth", - "@reason": { - "type": "text", - "placeholders": {} - }, - "privacy": "Príobháideacht", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "pin": "Biorán", - "@pin": { - "type": "text", - "placeholders": {} - }, - "people": "Daoine", - "@people": { - "type": "text", - "placeholders": {} - }, - "password": "Pasfhocal", - "@password": { - "type": "text", - "placeholders": {} - }, - "participant": "Rannpháirtí", - "@participant": { - "type": "text", - "placeholders": {} - }, - "directChats": "Comhráite Díreacha", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID gléis", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Scrios an teachtaireacht", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Scrios an cuntas", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Spás nua", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} rannpháirtithe", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "or": "Nó", - "@or": { - "type": "text", - "placeholders": {} - }, - "online": "Ar líne", - "@online": { - "type": "text", - "placeholders": {} - }, - "ok": "togha", - "@ok": { - "type": "text", - "placeholders": {} - }, - "offline": "As líne", - "@offline": { - "type": "text", - "placeholders": {} - }, - "offensive": "Maslach", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "notifications": "Fógraí", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "none": "Aon cheann", - "@none": { - "type": "text", - "placeholders": {} - }, - "no": "Níl", - "@no": { - "type": "text", - "placeholders": {} - }, - "next": "Ar Aghaidh", - "@next": { - "type": "text", - "placeholders": {} - }, - "moderator": "Modhnóir", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "messages": "Teachtaireachtaí", - "@messages": { - "type": "text", - "placeholders": {} - }, - "mention": "Luaigh", - "@mention": { - "type": "text", - "placeholders": {} - }, - "logout": "Logáil amach", - "@logout": { - "type": "text", - "placeholders": {} - }, - "login": "Logáil isteach", - "@login": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Solas", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "license": "Ceadúnas", - "@license": { - "type": "text", - "placeholders": {} - }, - "leave": "Fág", - "@leave": { - "type": "text", - "placeholders": {} - }, - "invited": "Le cuireadh", - "@invited": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Neamhurchóideach", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "ignore": "Tabhair neamhaird ar", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "identity": "Aitheantas", - "@identity": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "help": "Cabhair", - "@help": { - "type": "text", - "placeholders": {} - }, - "groups": "Grúpaí", - "@groups": { - "type": "text", - "placeholders": {} - }, - "group": "Grúpa", - "@group": { - "type": "text", - "placeholders": {} - }, - "forward": "Seol ar aghaidh", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Freastalaí baile", - "@homeserver": {}, - "encryption": "Criptiúchán", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Criptithe", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "edit": "Cuir in eagar", - "@edit": { - "type": "text", - "placeholders": {} - }, - "devices": "Gléasanna", - "@devices": { - "type": "text", - "placeholders": {} - }, - "device": "Gléas", - "@device": { - "type": "text", - "placeholders": {} - }, - "delete": "Scrios", - "@delete": { - "type": "text", - "placeholders": {} - }, - "dateWithYear": "{day}/{month}/{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "dateWithoutYear": "{day}/{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "containsUserName": "Coinníonn sé ainm úsáideora", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Cumraigh comhrá", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "commandInvalid": "Ordú neamhbhailí", - "@commandInvalid": { - "type": "text" - }, - "commandHint_send": "Seol téacs", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_me": "Déan cur síos ort féin", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "clearArchive": "Glan an cartlann", - "@clearArchive": {}, - "chatDetails": "Sonraí comhrá", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Cúltaca comhrá", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "D'athraigh {username} abhatár an chomhrá", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeDeviceName": "Athraigh ainm an ghléis", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Ní féidir an URI {uri} a oscailt", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "cancel": "Cealaigh", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Teachtaireachtaí bota", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "blocked": "Bactha", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "blockDevice": "Bac Gléas", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "Chuir {username} cosc ar {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "banned": "Coiscthe", - "@banned": { - "type": "text", - "placeholders": {} - }, - "banFromChat": "Toirmisc ón gcomhrá", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "Seol ar iontráil", - "@sendOnEnter": {}, - "archive": "Cartlann", - "@archive": { - "type": "text", - "placeholders": {} - }, - "appLock": "Bac aip", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "anyoneCanJoin": "Is féidir le aon duine dul isteach", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "D'fhreagair {senderName} an glao", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "allChats": "Gach comhrá", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "all": "Gach", - "@all": { - "type": "text", - "placeholders": {} - }, - "alias": "ailias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "admin": "Riarthóir", - "@admin": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Cuir go spás", - "@addToSpace": {}, - "addEmail": "Cuir ríomhphoist", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "Thosaigh {username} an criptiú ó dheireadh go deireadh", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Cuntas", - "@account": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "Ghlac {username} leis an cuireadh", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "accept": "Glac", - "@accept": { - "type": "text", - "placeholders": {} - }, - "about": "Faoi", - "@about": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Glac leis an iarratas fíoraithe seo ó {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "areYouSureYouWantToLogout": "An bhfuil tú cinnte gur mhaith leat logáil amach?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "An bhfuil tú cinnte?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "An bhfuil cead ag aoi-úsáideoirí a bheith páirteach", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "Thug {username} cuireadh do {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "hideRedactedEvents": "Folaigh imeachtaí athdhéanta", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Is féidir le haíonna páirt a ghlacadh", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "guestsAreForbidden": "Tá cosc ar aíonna", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grúpa le {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "groupIsPublic": "Tá an grúpa poiblí", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Ón gcuireadh", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Cuir isteach do fhreastalaí baile", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Gearrchód emote neamhbhailí!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Tá iomaite ann cheana féin!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Cuir in eagar abhatár an tseomra", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Cuir ailiasanna an tseomra in eagar", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Cuir freastalaí blocáilte in eagar", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Leibhéal ceada réamhshocraithe", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "unblockDevice": "Díbhlocáil Gléas", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Tugadh cuireadh don theagmháil a thar isteach sa grúpa", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Déan comparáid idir na huimhreacha seo a leanas agus déan cinnte go bhfuil na huimhreacha seo a leanas ag teacht le huimhreacha an ghléis eile:", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Déan comparáid agus déan cinnte go bhfuil an emoji seo a leanas comhoiriúnach le emoji an ghléis eile:", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "commandMissing": "Ní ordú é {command}.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "commandHint_react": "Seol freagra mar fhreagairt", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_op": "Socraigh leibhéal cumhachta an úsáideora áirithe (réamhshocrú: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_myroomnick": "Socraigh d'ainm taispeána don seomra seo", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_myroomavatar": "Cuir do phictiúr don seomra seo (le mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_kick": "Bain an t-úsáideoir áirithe den seomra seo", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_join": "Téigh isteach sa seomra áirithe", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_ban": "Cuir cosc ar an úsáideoir áirithe ón seomra seo", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_invite": "Cuir cosc ar an úsáideoir áirithe ón seomra seo", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "chooseAStrongPassword": "Roghnaigh pasfhocal láidir", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Cuireadh comhrá leis an spás seo", - "@chatHasBeenAddedToThisSpace": {}, - "chatBackupDescription": "Tá do chúltaca comhrá daingnithe le heochair slándála. Déan cinnte nach gcaillfidh tú é.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Truaillíodh an criptiú", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Athraigh ainm an ghrúpa", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changedTheRoomInvitationLink": "D'athraigh {username} nasc an chuiridh", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "D'athraigh {username} ailiasanna an tseomra", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheProfileAvatar": "D'athraigh {username} a n-abhatár", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "D'athraigh {username} na rialacha ceangail go: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheJoinRules": "D'athraigh {username} na rialacha ceangail", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "D'athraigh {username} infheictheacht na staire go: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "D'athraigh {username} infheictheacht na staire", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "D'athraigh {username} a n-ainm taispeána go: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheChatPermissions": "D'athraigh {username} na ceadanna comhrá", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatNameTo": "D'athraigh {username} an t-ainm comhrá go: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatDescriptionTo": "D'athraigh {username} an cur síos comhrá go: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "autoplayImages": "Seinn greamáin agus straoiseog beoite go huathoibríoch", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "createdTheChat": "Rinne {username} an comhrá", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "copyToClipboard": "Cóipeáil ar an ghearrthaisce", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Cóipeáilte ar an ghearrthaisce", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Coinníonn sé ainm taispeána", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "commandHint_plain": "Seol téacs neamhfhoirmithe", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_leave": "Fág an seomra seo", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_html": "Seol téacs HTML-formáidithe", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "changeYourAvatar": "Athraigh do abhatár", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Athraigh do stíl", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Athraigh an freastalaí baile", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Glórphost", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Físghlao", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Tosaigh Fíorú", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "unmuteChat": "Neamhciúnaigh comhrá", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Folaigh imeachtaí anaithnide", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Gléas anaithnid", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Marcáil Léite/Neamhléite", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Scoránaigh mar ciúnaithe", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Scoránaigh mar ceann is fearr leat", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Tá siad céanna", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Ainm an spáis", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Cód foinseach", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Taispeáin pasfhocal", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Roinn suíomh", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Cuir stádas", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Seol físeán", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Seol greamán", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Seol an bunchóip", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Seol teachtaireachtaí", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Seol íomhá", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Seol comhad", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Seol fuaim", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Sábháil comhad", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Leagan seomra", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Iarr cead", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Tuairiscigh teachtaireacht", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "removeDevice": "Bain gléas", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Bain teachtaireacht amach", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Rialacha na bhfógraí", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Seomraí Poiblí", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Roghnaigh le do thoil", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "play": "Seinn {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "passwordRecovery": "Aisfháil pasfhocail", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Pasfhocal dearmadta", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Oscail ceamara", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "ag Aimsiú an suíomh…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Gan cead", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "newChat": "Comhrá nua", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Ciúnaigh comhrá", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Athruithe ball", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Lódáil níos mó…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "Téigh isteach sa seomra", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "isTyping": "ag clóscríobh…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Tabhair cuireadh do theagmháil", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Úsáideoirí a dtugann tú neamhaird orthu", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Ó tar isteach", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Méid cló", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Tosaigh criptiú", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Cuir ainm taispeána in eagar", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Gníomhach faoi láthair", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Ainm an chomhaid", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Gach rud réidh!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Comhrá folamh", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Gearrchód straoiseoige", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Socruithe straoiseoige", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Íoslódáil comhad", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "changePassword": "Athraigh an pasfhocal", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Dorcha", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "create": "Cruthaigh", - "@create": { - "type": "text", - "placeholders": {} - }, - "copy": "Cóipeáil", - "@copy": { - "type": "text", - "placeholders": {} - }, - "connect": "Ceangail", - "@connect": { - "type": "text", - "placeholders": {} - }, - "confirm": "Deimhnigh", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "close": "Dún", - "@close": { - "type": "text", - "placeholders": {} - }, - "chats": "Comhráite", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chat": "Comhrá", - "@chat": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "Scan cód QR", - "@scanQrCode": {}, - "inviteText": "Thug {username} cuireadh duit chuig FluffyChat.\n1. Suiteáil FluffyChat: https://fluffychat.im\n2. Cláraigh nó sínigh isteach\n3. Oscail an nasc cuiridh: {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "noMatrixServer": "Níl {server1} freastalaí Matrix. Úsáid {server2} ina áit sin?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "noGoogleServicesWarning": "Dealraíonn sé nach bhfuil aon seirbhísí google agat ar do ghuthán. Sin cinneadh maith le do phríobháideacht! Chun fógraí brú a fháil i FluffyChat molaimid https://microg.org/ nó https://unifiedpush.org/ a úsáid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Ní féidir leat criptiú a ghníomhachtú ach a luaithe nach bhfuil an seomra inrochtana go poiblí a thuilleadh.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Níor aimsíodh aon straoiseoga. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Gan aon nasc leis an bhfreastalaí", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Iarratas fíoraithe nua!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "Teachtaireacht nua i FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Bí ar an eolas go dteastaíonn Pantalaimon uait chun criptiú ó cheann go ceann a úsáid anois.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Logáil isteach chuig {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "locationPermissionDeniedNotice": "Diúltaíodh cead suímh. Deonaigh dóibh le do thoil go mbeidh tú in ann do shuíomh a roinnt.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Tá seirbhísí suímh díchumasaithe. Cuir ar a gcumas le do thoil a bheith in ann do shuíomh a roinnt.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "loadingPleaseWait": "Ag lódáil… Fan, le do thoil.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Lódáil {count} níos mó rannpháirtithe", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "leftTheChat": "Fágadh an comhrá", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Gníomhach deireanach: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "kickFromChat": "Caith é amach as an comhrá", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "kicked": "Chaith {username} {targetName} amach", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "Chaith {username} amach agus chuir cosc ar {targetName} freisin", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "joinedTheChat": "Tháinig {username} isteach sa chomhrá", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "invitedUsersOnly": "Úsáideoirí le cuireadh amháin", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Tabhair cuireadh do theagmháil chuig {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "incorrectPassphraseOrKey": "Pasfhrása nó eochair téarnaimh mícheart", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Chliceáil mé ar an nasc", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Cé chomh maslach atá an t-ábhar seo?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Fíor-maslach", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "Tharraing {username} an cuireadh do {targetName} siar", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "goToTheNewRoom": "Téigh go dtí an seomra nua", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Earráid maidir le suíomh a fháil: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "enterAnEmailAddress": "Cuir isteach seoladh ríomhphoist", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "Chuir {senderName} deireadh leis an nglao", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "encryptionNotEnabled": "Ní chumasaítear criptiú", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Ní bheidh in ann an criptiú a dhíchumasú níos mó. An bhfuil tú cinnte?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Cumasaigh pacáiste straoiseoige go huilíoch", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Caithfidh tú gearrchód straoiseoige agus íomhá a roghnú!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Pacáistí straoiseoige don seomra", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Athraíodh an t-ainm taispeána", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "deactivateAccountWarning": "Díghníomhachtaeoidh sé seo do chuntas úsáideora. Ní féidir é seo a chealú! An bhfuil tú cinnte?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Níorbh fhéidir teachtaireacht a dhíchriptiú: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "contentHasBeenReported": "Tuairiscíodh an t-ábhar do lucht riaracháin an fhreastalaí", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "commandHint_unban": "Cuir deireadh an cosc den úsáideoir áirithe ón seomra seo", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "changedTheGuestAccessRulesTo": "D'athraigh {username} na rialacha maidir le rochtain aoi chuig: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheGuestAccessRules": "D'athraigh {username} na rialacha rochtana aoi", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerVersionsException": "Tá na leaganacha sonraíochta seo ar fáil faoin freastalaí baile:\n{serverVersions}\nAch níl ach na ceann seo ar fáil faoin aip seo {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerLoginTypesException": "Tá na cineálacha logála isteach seo ar fáil faoin freastalaí baile:\n{serverVersions}\nAch níl ach na ceann seo ar fáil faoin aip seo:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "askSSSSSign": "Chun a bheith in ann an duine eile a shíniú, cuir isteach do phasfhrása stóir sábháilte nó d'eochair téarnaimh.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "D'eochair phoiblí", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Cuireadh cosc ort ón gcomhrá seo", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Níl tú ag glacadh páirte sa chomhrá seo a thuilleadh", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Scríobh teachtaireacht…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Leis na seoltaí seo is féidir leat do phasfhocal a athshlánú.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Glan do cúltaca comhrá a chruthú eochair slándála nua?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Cén fáth ar mhaith leat é seo a thuairisciú?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Cé a bhfuil cead aige/aici dul isteach sa ghrúpa seo", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Cé atá in ann an gníomh a dhéanamh", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "D'fhíoraigh tú go rathúil!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "userLeftTheChat": "D'fhág {username} an comhrá", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userAndUserAreTyping": "Tá {username} agus {username2} ag clóscríobh…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userAndOthersAreTyping": "tá {username} agus {count} daoine eile ag clóscríobh…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "unreadChats": "{unreadCount, plural, =1{1 comhrá neamhléite} other{{unreadCount} comhráite neamhléite}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "unknownEncryptionAlgorithm": "Algartam criptithe anaithnid", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "Chuir {username} deireadh an cosc {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "tryToSendAgain": "Déan iarracht a sheoladh arís", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Aistriú ó ghléas eile", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "An iomarca iarratas. Bain triail eile as níos déanaí!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Níl siad céanna", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "Roinn {username} an suíomh", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "setPermissionsLevel": "Socraigh leibhéal ceadanna", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Socraigh nasc cuiridh", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Socraigh straoiseoga saincheaptha", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Socraigh mar phríomh-ailias", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "sentCallInformations": "Sheol {senderName} faisnéis maidir le glaonna", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "sentAVideo": "Sheol {username} físeán", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "Sheol {username} greamán", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "Sheol {username} pictiúr", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "replaceRoomWithNewerVersion": "Cuir leagan seomra níos nuaí in ionad an tseomra", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Taispeáin ábhar teachtaireachta saibhir", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Bain d'abhatár", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Cuir deireadh an cosc ón gcomhrá", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Bainte de ag {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeAllOtherDevices": "Bain gach gléas eile", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "Dhiúltaigh {username} don chuireadh", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactedAnEvent": "Rinne {username} cinsire imeacht", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "pleaseFollowInstructionsOnWeb": "Lean na treoracha ar an suíomh gréasáin agus tapáil \"ar aghaidh\".", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Cuir isteach d'ainm úsáideora le do thoil", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Cuir isteach d'uimhir PIN le do thoil", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Iontráil do phasfhocal le do thoil", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Iontráil 4 dhigit le do thoil nó fág folamh chun glas aipe a dhíchumasú.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Cliceáil ar an nasc sa ríomhphost agus ansin lean ar aghaidh.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Roghnaigh paschód le do thoil", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Roghnaigh íomhá", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Athraíodh an pasfhocal", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "pasfhrása nó eochair téarnaimh", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "Ní mór don fhreastalaí seo do sheoladh ríomhphoist a bhailíochtú le haghaidh clárúcháin.", - "@serverRequiresEmail": {}, - "openInMaps": "Oscail i léarscáileanna", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Oscail an aip chun teachtaireachtaí a léamh", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Úps, chuaigh rud éigin mícheart …", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Hoips! Ar an drochuair, tharla earráid nuair a bhí na fógraí brú á mbunú.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Tá Cúltaca Eochair Ar Líne cumasaithe", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "Tá {count} úsáideoirí ag clóscríobh…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "notificationsEnabledForThisAccount": "Fógraí cumasaithe don chuntas seo", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Níor aimsíodh aon seomraí…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Níor chuir tú bealach leis do phasfhocal a aisghabháil fós.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Tabhair cuireadh dom", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Sheolamar ríomhphost chugat", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Ag fanacht le comhpháirtí glacadh leis na huimhreacha …", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Ag fanacht le comhpháirtí glacadh leis na straoiseoga…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Ag fanacht le comhpháirtí glacadh leis an iarratas…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Infheicthe do gach duine", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Infheicthe do na rannpháirtithe go léir", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Infheictheacht stair na comhrá", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Ag fíorú cuntas eile", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "Sheol {username} imeacht {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "userIsTyping": "Tá {username} ag clóscríobh…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "unknownEvent": "Imeacht anaithnid '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "synchronizingPleaseWait": "Ag sioncrónú... Fan, le do thoil.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "startedACall": "Thosaigh {senderName} glao", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "spaceIsPublic": "Tá an spás poiblí", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Sínigh Aonair ar", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "sentAnAudio": "Sheol {username} fuaim", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAFile": "Sheol {username} comhad", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sendAsText": "Seol mar théacs", - "@sendAsText": { - "type": "text" - }, - "sendAMessage": "Seol teachtaireacht", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Le feiceáil ag {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "roomHasBeenUpgraded": "Uasghrádaíodh an seomra", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "addAccount": "Breisigh cuntas", - "@addAccount": {}, - "enableMultiAccounts": "(BÉITE) Cumasaigh cuntais iomadúla ar an gléas seo", - "@enableMultiAccounts": {}, - "commandHint_create": "Cruthaigh comhrá grúpa folamh\nÚsáid --no-encryption chun criptiúchán a dhíchumasú", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "link": "Nasc", - "@link": {}, - "commandHint_clearcache": "Glan an taisce", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "videoCallsBetaWarning": "Tabhair faoi deara go bhfuil físglaonna i béite. B'fhéidir nach bhfeidhmíonn siad ar gach ardán chomh atá súil aige ná ar bith.", - "@videoCallsBetaWarning": {}, - "emailOrUsername": "Ríomhphost nó ainm úsáideora", - "@emailOrUsername": {}, - "repeatPassword": "Scríobh an pasfhocal arís", - "@repeatPassword": {}, - "yourChatBackupHasBeenSetUp": "Bunaíodh do chúltaca comhrá.", - "@yourChatBackupHasBeenSetUp": {}, - "openVideoCamera": "Oscail físcheamara", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@reportErrorDescription": {}, - "@unsupportedAndroidVersion": {}, - "@widgetJitsi": {}, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@startFirstChat": {}, - "@callingAccount": {}, - "@setColorTheme": {}, - "@nextAccount": {}, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@user": {}, - "@youAcceptedTheInvitation": {}, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@widgetUrlError": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@previousAccount": {}, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@widgetNameError": {}, - "@addToBundle": {}, - "@addWidget": {}, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@commandHint_markasgroup": {}, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@storeInAppleKeyChain": {}, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@signInWithPassword": {}, - "@makeAdminDescription": {}, - "@saveKeyManuallyDescription": {}, - "@editBundlesForAccount": {}, - "@whyIsThisMessageEncrypted": {}, - "@setChatDescription": {}, - "@importFromZipFile": {}, - "@dehydrateWarning": {}, - "@noOtherDevicesFound": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@fileIsTooBigForServer": {}, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@optionalRedactReason": {}, - "@dehydrate": {}, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@reportUser": {}, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@redactMessageDescription": {}, - "@recoveryKey": {}, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@dehydrateTorLong": {}, - "@doNotShowAgain": {}, - "@report": {}, - "@unverified": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@foregroundServiceRunning": {}, - "@voiceCall": {}, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@removeFromBundle": {}, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@markAsRead": {}, - "@widgetName": {}, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@newSpace": {}, - "@emojis": {}, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@hydrateTorLong": {}, - "@time": {}, - "@custom": {}, - "@noBackupWarning": {}, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@pinMessage": {}, - "@invite": {}, - "@indexedDbErrorTitle": {}, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@placeCall": {} -} \ No newline at end of file diff --git a/assets/l10n/intl_gl.arb b/assets/l10n/intl_gl.arb deleted file mode 100644 index 2fe2464f5..000000000 --- a/assets/l10n/intl_gl.arb +++ /dev/null @@ -1,2712 +0,0 @@ -{ - "@@locale": "gl", - "@@last_modified": "2021-08-14 12:41:10.040321", - "about": "Acerca de", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Aceptar", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} aceptou o convite", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Conta", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} activou a cifraxe extremo-a-extremo", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Engadir email", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Todos", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Todas as conversas", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} respondeu á chamada", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Calquera pode unirse", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Bloqueo da app", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arquivo", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Permitir o acceso de convidadas", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Tes a certeza?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Tes a certeza de querer saír?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Para poder asinar a outra persoa, escribe a túa frase de paso ou chave de recuperación.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Aceptar a solicitude de verificación de {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Reproducir automáticamente adhesivos e emotes", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "O servidor soporta as seguintes formas de conexión:\n{serverVersions}\nPero esta app só soporta:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "O servidor soporta as seguintes características:\n{serverVersions}\nPero esta app só soporta {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Vetar na conversa", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Vetada", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} vetou a {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Bloquear dispositivo", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Bloqueado", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Mensaxes de Bot", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Cancelar", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Non se pode abrir o URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Cambiar nome do dispositivo", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} cambiou o avatar da conversa", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} mudou a descrición da conversa a: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} mudou o nome da conversa a: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} mudou os permisos da conversa", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} cambiou o nome público a: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} mudou as regras de acceso para convidadas", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} mudou as regras de acceso para convidadas a: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} mudou a visibilidade do historial", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} mudou a visibilidade do historial a: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} mudou as regras de acceso", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} mudou as regras de acceso a: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} mudou o avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} mudou os alias da sala", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} mudou a ligazón de convite", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Mudar contrasinal", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Mudar de servidor de inicio", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Cambiar o estilo", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Mudar o nome do grupo", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Cambia o avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "A cifraxe está estragada", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Conversa", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Copia de apoio", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "As mensaxes antigas están protexidas cunha chave de recuperación. Pon coidado e non a perdas.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Detalles da conversa", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Conversas", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Escolle un contrasinal forte", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Baleirar arquivo", - "@clearArchive": {}, - "close": "Pechar", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Vetar a usuaria indicada desta sala", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Enviar texto con formato HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Convidar á usuaria a esta sala", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Unirte á sala indicada", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Eliminar a usuaria indicada desta sala", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Saír desta sala", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Conta algo sobre ti", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Establece a túa imaxe para esta sala (por mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Establece o teu nome público para esta sala", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Establecer o nivel de responsabilidade da usuaria (por defecto: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Enviar texto sen formato", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Enviar resposta como reacción", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Enviar texto", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Retirar veto á usuaria para esta sala", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Comando non válido", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} non é un comando.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Compara estes emojis", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Compara estes números", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Configurar conversa", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Confirmar", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Conectar", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "O contacto foi convidado ao grupo", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Contén nome público", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Contén nome de usuaria", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "O contido foi denunciado á administración do servidor", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Copiado ao portapapeis", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Copiar", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Copiar ao portapapeis", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Non se descifrou a mensaxe: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} participantes", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Crear", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} creou a conversa", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Novo espazo", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Actualmente activo", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Escuro", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Esto desactivará a conta. Esto non ten volta atrás. Estás segura?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Nivel de permisos por omisión", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Eliminar", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Eliminar conta", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Eliminar mensaxe", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Dispositivo", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID do dispositivo", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Dispositivos", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Conversas Directas", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "O nome público mudou", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Descargar ficheiro", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Editar", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Editar servidores bloqueados", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Editar nome público", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Editar alias da sala", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Editar avatar da sala", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Xa existe ese emote!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Atallo do emote non é válido!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Paquetes de Emotes para a sala", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Axustes de Emote", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Atallo de Emote", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Escribe un atallo e asocialle unha imaxe!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Conversa baleira", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Activar paquete emote globalmente", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Activar cifraxe", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Non poderás desactivar a cifraxe posteriormente, tes certeza?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Cifrado", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Cifraxe", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "A cifraxe non está activada", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} rematou a chamada", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Escribe un enderezo de email", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Escribe o teu servidor de inicio", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Erro ao obter a localización: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Todo preparado!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extremadamente ofensivo", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nome do ficheiro", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Tamaño da letra", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Reenviar", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Desde que se una", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Desde o convite", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Ir á nova sala", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Grupo", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "O grupo é público", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Grupos", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grupo con {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Non se permiten convidadas", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Permítense convidadas", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} retirou o convite para {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Axuda", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Agochar eventos editados", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Agochar eventos descoñecidos", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "É moi ofensivo este contido?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identidade", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorar", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Usuarias ignoradas", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Premín na ligazón", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Frase de paso ou chave de recuperación incorrecta", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Inofensivo", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Convidar contacto", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Convidar contacto a {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Convidado", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} convidou a {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Só usuarias convidadas", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Convite para min", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} convidoute a FluffyChat.\n1. Visita fluffychat.im e instala a app\n2. Crea unha conta ou Accede\n3. Abre a ligazón do convite: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "está escribindo…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} uníuse á conversa", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Unirse á sala", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} expulsou a {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} expulsou e vetou a {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Expulsar da conversa", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Última actividade: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Saír", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Deixar a conversa", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licenza", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Claro", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Cargar {count} participantes máis", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Cargando... Agarda.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Cargar máis…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Os servizos de localización están desactivados. Actívaos para poder compartir a localización.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Permiso de localización denegado. Concede este permiso para poder compartir a localización.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Acceder", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Entrar en {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Pechar sesión", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Cambios de participantes", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Mención", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Mensaxes", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderadora", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Acalar conversa", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Ten en conta que polo de agora precisas Pantalaimon para a cifraxe extremo-a-extremo.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Nova conversa", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Nova mensaxe en FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nova solicitude de verificación!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Seguinte", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Non", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Sen conexión co servidor", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Non hai emotes. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Só podes activar a cifraxe tan pronto como a sala non sexa públicamente accesible.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Semella que non tes Firebase Cloud Messaging dispoñible no teu dispositivo. Para recibir notificacións push recomendamos que instales ntfy. Con ntfy ou outro provedor Unified Push podes recibir notificacións push de xeito seguro. Podes descargar ntfy desde a PlayStore ou F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} non é un servidor matrix, usar {server2} no seu lugar?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "none": "Ningún", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Aínda non engaiches ningún xeito de recuperar o contrasinal.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Sen permiso", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Non se atoparon salas…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notificacións", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Notificacións activadas para a conta", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} usuarias están escribindo…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Obtendo a localización…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Ofensivo", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Desconectada", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "En liña", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Copia de Apoio en liña das Chaves activada", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Vaites! Desgraciadamente algo fallou ao configurar as notificacións push.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Ooooi, algo fallou…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Abrir a app e ler mensaxes", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Abrir cámara", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Abrir en mapas", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Ou", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Participante", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "frase de paso ou chave de recuperación", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Contrasinal", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Contrasinal esquecido", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Cambiouse o contrasinal", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Recuperación do contrasinal", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Persoas", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Elixe unha imaxe", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Fixar", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Reproducir {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Por favor elixe", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Escolle un código de acceso", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Preme na ligazón do email e segue as instrucións.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Escribe 4 díxitos ou deíxao baleiro para non activar o bloqueo.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Escribe o teu contrasinal", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Escribe o teu pin", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Escribe o teu nome de usuaria", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Segue as instruccións do sitio web e toca en seguinte.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privacidade", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Salas públicas", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Regras de envío", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Razón", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Gravando", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} editou un evento", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Eliminar mensaxe", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Crear conta", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Rexeitar", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} rexeitou o convite", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Volta a unirte", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Quitar", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Quitar todos os outros dispositivos", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Eliminado por {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Quitar dispositivo", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Retirar veto na conversa", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Elimina o avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Mostrar contido enriquecido da mensaxe", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Substituír sala pola nova versión", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Responder", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Denunciar mensaxe", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Solicitar permiso", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "A sala foi actualizada", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Versión da sala", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Gardar ficheiro", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Buscar", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Seguridade", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Visto por {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Enviar", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Enviar unha mensaxe", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Enviar como texto", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Enviar audio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Enviar ficheiro", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Enviar imaxe", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Enviar mensaxes", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Enviar orixinal", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Enviar adhesivo", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Enviar vídeo", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} enviou un ficheiro", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} enviou un audio", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} enviou unha imaxe", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} enviou un adhesivo", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} enviou un vídeo", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} enviou información da chamada", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Establecer como alias principal", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Establecer emotes personalizados", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Establecer ligazón do convite", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Establecer nivel de permisos", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Establecer estado", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Axustes", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Compartir", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} compartiu a súa localización", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Compartir localización", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Amosar contrasinal", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Conexión Unificada SSO", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Saltar", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Código fonte", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "O Espazo é público", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Nome do Espazo", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} iniciou unha chamada", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Estado", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "¿Que tal estás hoxe?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Enviar", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Sincronizando... Agarda.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistema", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Non concordan", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Concordan", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Marcar Favorito", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Cambia Noificacións", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Marcar como Lido/Non lido", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Demasiadas solicitudes. Inténtao máis tarde!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Transferir desde outro dispositivo", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Inténtao outra vez", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Non dispoñible", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} retirou o veto a {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Desbloquear dispositivo", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Dispositivo descoñecido", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Algoritmo de cifraxe descoñecido", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Evento descoñecido '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Reactivar notificacións", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Desafixar", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 conversa sen ler} other{{unreadCount} conversas sen ler}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} e {count} máis están escribindo…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} e {username2} están escribindo…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} está escribindo…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} deixou a conversa", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Nome de usuaria", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} enviou un evento {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Verificado", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verificar", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Comezar verificación", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Verificaches correctamente!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verificando a outra conta", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Chamada de vídeo", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Visibilidade do historial da conversa", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Visible para todas as participantes", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Visible para todas", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Mensaxe de voz", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Agardando a que a outra parte acepte a solicitude…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Agardando a que a outra parte acepte as emoticonas…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Agardando a que a outra parte acepte os números…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Imaxe de fondo:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Aviso!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Enviamosche un email", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Quen pode realizar determinada acción", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Quen se pode unir a este grupo", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Por que queres denunciar esto?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Queres eliminar a copia de apoio da conversa e crear unha nova chave de recuperación?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Con estos enderezos podes recuperar o contrasinal.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Escribe unha mensaxe…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Si", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Ti", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Xa non participas desta conversa", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Foches vetada nesta conversa", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "A túa chave pública", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Engadiuse a conversa a este espazo", - "@chatHasBeenAddedToThisSpace": {}, - "addToSpace": "Engadir ao espazo", - "@addToSpace": {}, - "scanQrCode": "Escanear código QR", - "@scanQrCode": {}, - "sendOnEnter": "Enter para enviar", - "@sendOnEnter": {}, - "homeserver": "Servidor de inicio", - "@homeserver": {}, - "serverRequiresEmail": "O servidor precisa validar o teu enderezo de email para rexistrarte.", - "@serverRequiresEmail": {}, - "enableMultiAccounts": "(BETA) Activar varias contas neste dispositivo", - "@enableMultiAccounts": {}, - "addAccount": "Engadir conta", - "@addAccount": {}, - "oneClientLoggedOut": "Un dos teus clientes foi desconectado", - "@oneClientLoggedOut": {}, - "link": "Ligazón", - "@link": {}, - "yourChatBackupHasBeenSetUp": "Configurouse a copia de apoio do chat.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "Sen verificar", - "@unverified": {}, - "repeatPassword": "Repite o contrasinal", - "@repeatPassword": {}, - "messageInfo": "Info da mensaxe", - "@messageInfo": {}, - "time": "Hora", - "@time": {}, - "sender": "Remitente", - "@sender": {}, - "openGallery": "Galería pública", - "@openGallery": {}, - "addToSpaceDescription": "Elixe un espazo ao que engadir esta conversa.", - "@addToSpaceDescription": {}, - "messageType": "Tipo de mensaxe", - "@messageType": {}, - "removeFromSpace": "Retirar do espazo", - "@removeFromSpace": {}, - "start": "Comezar", - "@start": {}, - "commandHint_discardsession": "Descartar sesión", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_create": "Crear un grupo de conversa baleiro\nUsa --no-encryption para desactivar a cifraxe", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_clearcache": "Baleirar caché", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_dm": "Iniciar un chat directo\nUsa --no-encryption para desactivar a cifraxe", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "openVideoCamera": "Abrir a cámara para un vídeo", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "videoWithSize": "Vídeo ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "publish": "Publicar", - "@publish": {}, - "dismiss": "Desbotar", - "@dismiss": {}, - "markAsRead": "Marcar como lido", - "@markAsRead": {}, - "reportUser": "Denunciar usuaria", - "@reportUser": {}, - "openChat": "Abrir Conversa", - "@openChat": {}, - "voiceCall": "Chamada de voz", - "@voiceCall": {}, - "emojis": "Emojis", - "@emojis": {}, - "placeCall": "Chamar", - "@placeCall": {}, - "unsupportedAndroidVersionLong": "Esta característica require unha vesión máis recente de Android. Mira se hai actualizacións ou soporte de LineageOS.", - "@unsupportedAndroidVersionLong": {}, - "videoCallsBetaWarning": "Ten en conta que as chamadas de vídeo están en fase beta. Poderían non funcionar correctamente ou non funcionar nalgunhas plataformas.", - "@videoCallsBetaWarning": {}, - "unsupportedAndroidVersion": "Version de Android non soportada", - "@unsupportedAndroidVersion": {}, - "reactedWith": "{sender} reaccionou con {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "pinMessage": "Fixar na sala", - "@pinMessage": {}, - "confirmEventUnpin": "Tes a certeza de querer desafixar o evento?", - "@confirmEventUnpin": {}, - "experimentalVideoCalls": "Chamadas de vídeo en probas", - "@experimentalVideoCalls": {}, - "emailOrUsername": "Email ou nome de usuaria", - "@emailOrUsername": {}, - "switchToAccount": "Cambiar á conta {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "previousAccount": "Conta anterior", - "@previousAccount": {}, - "nextAccount": "Conta seguinte", - "@nextAccount": {}, - "bundleName": "Nome do feixe", - "@bundleName": {}, - "widgetVideo": "Vídeo", - "@widgetVideo": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Personalizado", - "@widgetCustom": {}, - "widgetName": "Nome", - "@widgetName": {}, - "widgetUrlError": "Non é un URL válido.", - "@widgetUrlError": {}, - "widgetNameError": "Escribe un nome público.", - "@widgetNameError": {}, - "addWidget": "Engadir widget", - "@addWidget": {}, - "widgetEtherpad": "Nota de texto", - "@widgetEtherpad": {}, - "errorAddingWidget": "Erro ao engadir o widget.", - "@errorAddingWidget": {}, - "editBundlesForAccount": "Editar os feixes desta conta", - "@editBundlesForAccount": {}, - "addToBundle": "Engadir ao feixe", - "@addToBundle": {}, - "removeFromBundle": "Eliminar deste feixe", - "@removeFromBundle": {}, - "separateChatTypes": "Separar Conversas directas e Grupos", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youRejectedTheInvitation": "Rexeitaches o convite", - "@youRejectedTheInvitation": {}, - "youBannedUser": "Vetaches a {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 {user} convidoute", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youJoinedTheChat": "Unícheste á conversa", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Aceptaches o convite", - "@youAcceptedTheInvitation": {}, - "youHaveWithdrawnTheInvitationFor": "Retiraches o convite para {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Convidaches a {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 Expulsaches a {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Expulsaches e vetaches a {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Retiraches o veto a {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "saveKeyManuallyDescription": "Garda esta chave manualmente usando o sistema para compartir do dispositivo ou portapapeis.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Gardar en Android KeyStore", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "Gardar en Apple KeyChain", - "@storeInAppleKeyChain": {}, - "recoveryKeyLost": "Perdeches a chave de recuperación?", - "@recoveryKeyLost": {}, - "pleaseEnterRecoveryKey": "Escribe a túa chave de recuperación:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKey": "Chave de recuperación", - "@recoveryKey": {}, - "storeSecurlyOnThisDevice": "Gardar de xeito seguro no dispositivo", - "@storeSecurlyOnThisDevice": {}, - "pleaseEnterRecoveryKeyDescription": "Para desbloquear as mensaxes antigas, escribe a chave de recuperación creada nunha sesión existente. A chave de recuperación NON é o teu contrasinal.", - "@pleaseEnterRecoveryKeyDescription": {}, - "users": "Usuarias", - "@users": {}, - "storeInSecureStorageDescription": "Gardar a chave de recuperación na almacenaxe segura deste dispositivo.", - "@storeInSecureStorageDescription": {}, - "countFiles": "{count} ficheiros", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "unlockOldMessages": "Desbloquear mensaxes antigas", - "@unlockOldMessages": {}, - "dehydrateTorLong": "Para usuarias de TOR, é recomendable exportar a sesión antes de pechar a ventál.", - "@dehydrateTorLong": {}, - "hydrateTor": "Usuarias TOR: Importar a sesión exportada", - "@hydrateTor": {}, - "hydrateTorLong": "Exportaches a túa sesión a última vez en TOR? Importaa rápidamente e segue conversando.", - "@hydrateTorLong": {}, - "hydrate": "Restablecer desde copia de apoio", - "@hydrate": {}, - "dehydrateWarning": "Esta acción non é reversible. Pon coidado en gardar o ficheiro de apoio.", - "@dehydrateWarning": {}, - "dehydrate": "Exportar sesión e eliminar dispositivo", - "@dehydrate": {}, - "dehydrateTor": "Usuarias TOR: Exportar sesión", - "@dehydrateTor": {}, - "indexedDbErrorTitle": "Problemas no modo privado", - "@indexedDbErrorTitle": {}, - "indexedDbErrorLong": "A almacenaxe de mensaxes non está activada por defecto no modo privado.\nMira en\n- about:config\n- establece dom.indexedDB.privateBrowsing.enabled como true\nSe non, non é posible executar FluffyChat.", - "@indexedDbErrorLong": {}, - "user": "Usuaria", - "@user": {}, - "custom": "Personal", - "@custom": {}, - "confirmMatrixId": "Confirma o teu ID Matrix para poder eliminar a conta.", - "@confirmMatrixId": {}, - "supposedMxid": "Debería ser {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasdm": "Marcar como sala de mensaxe directa para o ID Matrix indicado", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "Marcar como grupo", - "@commandHint_markasgroup": {}, - "whyIsThisMessageEncrypted": "Por que non podo ler esta mensaxe?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "Pode ser que a mensaxe fose enviada antes de que ti accedeses á túa conta neste dispositivo.\n\nTamén é posible que a remitente non validase o teu dispositivo ou tamén que algo fallase na conexión a internet.\n\nPodes ler a mensaxe noutro dispositivo? Entón podes transferila desde el! Vai a Axustes > Dispositivos e comproba que tes tódolos dispositivos verificados. Entón cando abras a sala a próxima vez a sincronización realizarase e as chaves transmitiranse automáticamente.\n\nNon desexas perder as chaves cando pechas sesión ou cambias de dispositivo? Comproba nos axustes que activaches a copia de apoio das conversas.", - "@noKeyForThisMessage": {}, - "appearOnTop": "Aparecer arriba", - "@appearOnTop": {}, - "otherCallingPermissions": "Micrófono, cámara e outros permisos para FluffyChat", - "@otherCallingPermissions": {}, - "newGroup": "Novo grupo", - "@newGroup": {}, - "newSpace": "Novo espazo", - "@newSpace": {}, - "foregroundServiceRunning": "Esta notificación aparece cando se está a executar o servizo en segundo plano.", - "@foregroundServiceRunning": {}, - "screenSharingTitle": "compartición da pantalla", - "@screenSharingTitle": {}, - "callingPermissions": "Permisos de chamada", - "@callingPermissions": {}, - "callingAccount": "Conta que chama", - "@callingAccount": {}, - "callingAccountDetails": "Permítelle a FluffyChat usar a app marcador nativa de android.", - "@callingAccountDetails": {}, - "appearOnTopDetails": "Permítelle á app aparecer por enrriba (non é preciso se xa configuraches FluffyChat como unha conta para chamadas)", - "@appearOnTopDetails": {}, - "enterSpace": "Entrar no espazo", - "@enterSpace": {}, - "enterRoom": "Entrar na sala", - "@enterRoom": {}, - "allSpaces": "Todos os espazos", - "@allSpaces": {}, - "screenSharingDetail": "Estás compartindo a túa pantalla en FluffyChat", - "@screenSharingDetail": {}, - "numChats": "{number} conversas", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Agochar os eventos de menor relevancia", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Non mostrar outra vez", - "@doNotShowAgain": {}, - "commandHint_googly": "Envía uns ollos desos grandes", - "@commandHint_googly": {}, - "googlyEyesContent": "{senderName} enviouche uns ollos grandes", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} mándache un achuche", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_cuddle": "Envía un agarimo", - "@commandHint_cuddle": {}, - "commandHint_hug": "Envía un abrazo", - "@commandHint_hug": {}, - "hugContent": "{senderName} abrázate", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "encryptThisChat": "Cifrar esta conversa", - "@encryptThisChat": {}, - "disableEncryptionWarning": "Por razóns de seguridade non podes desactivar a cifraxe dunha conversa onde foi activada previamente.", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "Lamentámolo... iso non é posible", - "@sorryThatsNotPossible": {}, - "deviceKeys": "Chaves do dispositivo:", - "@deviceKeys": {}, - "newSpaceDescription": "Os Espazos permítenche consolidar as túas conversas e construir comunidades públicas ou privadas.", - "@newSpaceDescription": {}, - "startFirstChat": "Abre a túa primeira conversa", - "@startFirstChat": {}, - "wasDirectChatDisplayName": "Conversa baleira (era {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "reopenChat": "Reabrir conversa", - "@reopenChat": {}, - "noOtherDevicesFound": "Non se atopan outros dispositivos", - "@noOtherDevicesFound": {}, - "noBackupWarning": "Aviso! Se non activas a copia de apoio da conversa, perderás o acceso ás túas mensaxes cifradas. É moi recomendable activar a copia de apoio da conversa antes de pechar a sesión.", - "@noBackupWarning": {}, - "fileIsTooBigForServer": "O servidor informa de que o ficheiro é demasiado grande para envialo.", - "@fileIsTooBigForServer": {}, - "fileHasBeenSavedAt": "Gardouse o ficheiro en {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Ir á última mensaxe lida", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Lin ate aquí", - "@readUpToHere": {}, - "openLinkInBrowser": "Abrir ligazón no navegador", - "@openLinkInBrowser": {}, - "jump": "Ir alá", - "@jump": {}, - "report": "informar", - "@report": {}, - "allRooms": "Todas as Conversas en grupo", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "😭 Vaia! Algo fallou. Se queres, podes informar do problema ás persoas desenvolvedoras.", - "@reportErrorDescription": {}, - "signInWithPassword": "Accede con contrasinal", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Inténtao máis tarde ou elixe un servidor diferente.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "Accede con {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Non é un ficheiro de imaxe.", - "@notAnImage": {}, - "importNow": "Importar agora", - "@importNow": {}, - "importEmojis": "Importar Emojis", - "@importEmojis": {}, - "importFromZipFile": "Importar desde ficheiro .zip", - "@importFromZipFile": {}, - "exportEmotePack": "Exportar paquete Emote como .zip", - "@exportEmotePack": {}, - "replace": "Substituír", - "@replace": {}, - "sendTypingNotifications": "Permitir ver que estás escribindo", - "@sendTypingNotifications": {}, - "createGroup": "Crear grupo", - "@createGroup": {}, - "messagesStyle": "Mensaxes:", - "@messagesStyle": {}, - "profileNotFound": "Non se atopa a usuaria no servidor. Pode que haxa un problema coa conexión ou que a usuaria non exista.", - "@profileNotFound": {}, - "shareInviteLink": "Comparte ligazón de convite", - "@shareInviteLink": {}, - "setColorTheme": "Cor do decorado:", - "@setColorTheme": {}, - "setTheme": "Establecer decorado:", - "@setTheme": {}, - "inviteContactToGroupQuestion": "Queres convidar a {contact} para que se una á conversa \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "Intentar outra vez", - "@tryAgain": {}, - "optionalRedactReason": "(Optativo) Razón para editar a mensaxe...", - "@optionalRedactReason": {}, - "redactedBy": "Editada por {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactedByBecause": "Editada por {username} debido a: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "redactMessageDescription": "A mensaxe vai ser editada para todas as participantes na conversa. Non ten volta atrás.", - "@redactMessageDescription": {}, - "invite": "Convidar", - "@invite": {}, - "addChatDescription": "Engadir descrición da conversa...", - "@addChatDescription": {}, - "chatPermissions": "Permisos da conversa", - "@chatPermissions": {}, - "chatDescription": "Descrición da conversa", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Cambiou a descrición da conversa", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "Aínda non se escribeu a descrición da conversa.", - "@noChatDescriptionYet": {}, - "invalidServerName": "Nome de servidor non válido", - "@invalidServerName": {}, - "directChat": "Conversa Directa", - "@directChat": {}, - "setChatDescription": "Escribir descrición da conversa", - "@setChatDescription": {}, - "inviteGroupChat": "📨 Convidar a conversa en grupo", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Convidar a conversa privada", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "Os emotes usados recentemente aparecerán aquí...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "banUserDescription": "Vaise vetar a usuaria na conversa e non poderá entrar outra vez ata que se retire o veto.", - "@banUserDescription": {}, - "removeDevicesDescription": "Vas pechar a sesión neste dispositivo e xa non poderás recibir mensaxes nel.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "A usuaria vai poder entrar outra vez na conversa se quere.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Non están dispoñibles as notificacións push", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Cando convirtas a esta usuaria en admin non poderás desfacer a acción xa que terá os mesmos permisos ca ti.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Vaise mover o chat ao arquivo. Outras usuarias poderán ver que saíches da conversa.", - "@archiveRoomDescription": {}, - "invalidInput": "Contido non válido!", - "@invalidInput": {}, - "hasKnocked": "🚪 {user} petou na porta", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "wrongPinEntered": "PIN incorrecto! Inténtao outra vez en {seconds} segundos...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "learnMore": "Saber máis", - "@learnMore": {}, - "roomUpgradeDescription": "Vaise recrear o chat coa nova versión da sala. Todas as participantes recibirán unha notificación para que cambien ao novo chat. Podes ler máis información acerca das versións das salas en https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Escribe un número maior de cero", - "@pleaseEnterANumber": {}, - "kickUserDescription": "A usuaria foi expulsada pero non vetada. En conversas públicas a usuaria pode volver cando queira.", - "@kickUserDescription": {}, - "createGroupAndInviteUsers": "Crear un grupo e convidar usuarias", - "@createGroupAndInviteUsers": {}, - "groupCanBeFoundViaSearch": "O grupo pódese atopar ao buscar", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "Lamentamos non atopar ningunha usuaria con \"{query}\". Comproba se está ben escrito.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "yourGlobalUserIdIs": "O teu ID-usuaria global é: ", - "@yourGlobalUserIdIs": {}, - "groupName": "Nome do grupo", - "@groupName": {}, - "searchChatsRooms": "Buscar #conversas, @usuarias...", - "@searchChatsRooms": {}, - "startConversation": "Iniciar conversa", - "@startConversation": {}, - "commandHint_sendraw": "Enviar json sen editar", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Desculpa... non semella ser o xeito correcto de recuperar a chave.", - "@wrongRecoveryKey": {}, - "blockListDescription": "Podes bloquear usuarias que che molesten. Non recibirás mensaxes nin convites para salas procedentes das usuarias da túa lista persoal de bloqueo.", - "@blockListDescription": {}, - "blockedUsers": "Usuarias bloqueadas", - "@blockedUsers": {}, - "block": "Bloquer", - "@block": {}, - "blockUsername": "Ignorar identificador", - "@blockUsername": {}, - "thisDevice": "Este dispositivo:", - "@thisDevice": {}, - "publicSpaces": "Espazos públicos", - "@publicSpaces": {}, - "passwordIsWrong": "O contrasinal escrito non é correcto", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Escribe o contrasinal actual", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "Ligazón pública", - "@publicLink": {}, - "nothingFound": "Non atopamos nada...", - "@nothingFound": {}, - "decline": "Desbotar", - "@decline": {}, - "newPassword": "Novo contrasinal", - "@newPassword": {}, - "passwordsDoNotMatch": "Os contrasinais non concordan", - "@passwordsDoNotMatch": {}, - "subspace": "Subespazo", - "@subspace": {}, - "select": "Escolle", - "@select": {}, - "pleaseChooseAStrongPassword": "Elixe un contrasinal forte", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "Engadir chat ou sub espazo", - "@addChatOrSubSpace": {}, - "leaveEmptyToClearStatus": "Deixa baleiro para limpar o teu estado.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Únete ao espazo", - "@joinSpace": {}, - "searchForUsers": "Buscar @persoas...", - "@searchForUsers": {}, - "databaseMigrationTitle": "Base de datos optimizada", - "@databaseMigrationTitle": {}, - "databaseMigrationBody": "Agarda, podería levarnos un pouco.", - "@databaseMigrationBody": {}, - "databaseBuildErrorBody": "Non se puido crear a base de datos SQlite. A app intentará usar a base de datos clásica. Por favor informa deste fallo ás desenvolvedoras en {url}. A mensaxe do erro é: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "Houbo un fallo ao iniciar a app", - "@initAppError": {}, - "sessionLostBody": "Estragouse a túa sesión. Por favor informa deste fallo ás desenvolvedoras en {url}. A mensaxe do erro é: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "A app vai intentar restablecer a sesión desde a copia de apoio. Por favor informa deste erro ás desenvolvedoras en {url}. A mensaxe do erro é: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "youInvitedToBy": "📩 Convidáronte cunha ligazón a:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "transparent": "Transparente", - "@transparent": {}, - "sendReadReceipts": "Enviar confirmación de lectura", - "@sendReadReceipts": {}, - "sendReadReceiptsDescription": "Outras participantes na conversa poden ver cando liches unha mensaxe.", - "@sendReadReceiptsDescription": {}, - "formattedMessages": "Mensaxes con formato", - "@formattedMessages": {}, - "verifyOtherDevice": "🔐 Verificar outro dispositivo", - "@verifyOtherDevice": {}, - "verifyOtherUser": "🔐 Verificar outra usuaria", - "@verifyOtherUser": {}, - "verifyOtherDeviceDescription": "Ao verificar outro dispositivo estás compartindo as chaves, aumentando a túa seguridade 💪. Ao iniciar a verificación aparecerá unha ventá emerxente nos dous dispositivos. Nesa ventá verás varios emojis ou números que tes que comparar entre eles. O mellor xeito de facelo é ter os dous dispositivos contigo cando inicias o proceso de verificación. 🤳", - "@verifyOtherDeviceDescription": {}, - "canceledKeyVerification": "{sender} desbotou a verificación da chave", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} xa pode verificar a chave", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "forwardMessageTo": "Reenviar a mensaxe a {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendTypingNotificationsDescription": "As outras participantes da conversa poden ver cando estás a escribir unha mensaxe.", - "@sendTypingNotificationsDescription": {}, - "formattedMessagesDescription": "Mostrar texto enriquecido nas mensaxes como letra grosa usando markdown.", - "@formattedMessagesDescription": {}, - "verifyOtherUserDescription": "Se verificas a outra usuaria, podes ter a certeza de que sabes con quen estás a conversar. 💪\n\nAo iniciar a verificación, ti mais a outra usuaria veredes unha ventá emerxente na app onde aparecerán varios emojis ou números que teredes que comparar entre vós.\n\nO mellor xeito de facelo é en persoa o cunha chamada de vídeo. 👭", - "@verifyOtherUserDescription": {}, - "requestedKeyVerification": "{sender} solicitou verificar a chave", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "acceptedKeyVerification": "{sender} aceptou a verificación da chave", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} completou a verificación da chave", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} comezou coa verificación da chave", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "presenceStyle": "Presenza:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "hidePresences": "Agochar Lista de estados?", - "@hidePresences": {}, - "presencesToggle": "Mostra mensaxes de estado de outras usuarias", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "incomingMessages": "Mensaxes recibidas", - "@incomingMessages": {}, - "stickers": "Adhesivos", - "@stickers": {}, - "discover": "Descubrir", - "@discover": {}, - "commandHint_ignore": "Ignorar o ID matrix indicado", - "@commandHint_ignore": {}, - "commandHint_unignore": "Non ignorar o ID matrix indicado", - "@commandHint_unignore": {}, - "unreadChatsInApp": "{appname}: {unread} chats sen ler", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "noDatabaseEncryption": "Nesta plataforma non temos soporte para cifrar a base de datos", - "@noDatabaseEncryption": {}, - "accessAndVisibility": "Acceso e Visibilidade", - "@accessAndVisibility": {}, - "accessAndVisibilityDescription": "Quen pode unirse a este chat de que xeito pode ser atopado.", - "@accessAndVisibilityDescription": {}, - "customEmojisAndStickers": "Emojis personais e adhesivos", - "@customEmojisAndStickers": {}, - "calls": "Chamadas", - "@calls": {}, - "hideRedactedMessages": "Agochar mensaxes editadas", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "Se alguén corrixe unha mensaxe entón esta xa non será visible no chat.", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "Agochar formatos de mensaxe non válidos ou descoñecidos", - "@hideInvalidOrUnknownMessageFormats": {}, - "hideMemberChangesInPublicChats": "Agochar cambios dos membros nos chats públicos", - "@hideMemberChangesInPublicChats": {}, - "notifyMeFor": "Notificarme sobre", - "@notifyMeFor": {}, - "hideMemberChangesInPublicChatsBody": "Non mostrar na cronoloxía se alguén se une ou deixa un chat público, para mellorar a lexibilidade.", - "@hideMemberChangesInPublicChatsBody": {}, - "usersMustKnock": "As usuarias teñen que pedir entrar", - "@usersMustKnock": {}, - "userWouldLikeToChangeTheChat": "{user} quere unirse ao chat.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "knocking": "A solicitar", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "O chat pode ser atopado ao buscar en {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "createNewAddress": "Crear novos enderezos", - "@createNewAddress": {}, - "appLockDescription": "Bloquear a app cun código PIN cando non a uses", - "@appLockDescription": {}, - "globalChatId": "ID Global do chat", - "@globalChatId": {}, - "customEmojisAndStickersBody": "Engade ou comparte emojis personais e adhesivos que poden usarse nos chats.", - "@customEmojisAndStickersBody": {}, - "overview": "Vista xeral", - "@overview": {}, - "passwordRecoverySettings": "Axustes de recuperación do contrasinal", - "@passwordRecoverySettings": {}, - "noPublicLinkHasBeenCreatedYet": "Aínda non se creou unha ligazón pública", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "Solicitar acceso", - "@knock": {}, - "noOneCanJoin": "Ninguén pode unirse", - "@noOneCanJoin": {}, - "thereAreCountUsersBlocked": "Agora mesmo hai {count} usuarias bloqueadas.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "publicChatAddresses": "Enderezos públicos do chat", - "@publicChatAddresses": {}, - "userRole": "Rol da usuaria", - "@userRole": {}, - "minimumPowerLevel": "{level} é o nivel mínimo de responsabilidade.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "searchIn": "Buscar no chat \"{chat}\"...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Buscar máis...", - "@searchMore": {}, - "gallery": "Galería", - "@gallery": {}, - "files": "Ficheiros", - "@files": {}, - "knockRestricted": "Peta á porta", - "@knockRestricted": {}, - "restricted": "Non accesible", - "@restricted": {}, - "swipeRightToLeftToReply": "Despraza hacia a esquerda para responder", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_hi.arb b/assets/l10n/intl_hi.arb deleted file mode 100644 index fc7c50735..000000000 --- a/assets/l10n/intl_hi.arb +++ /dev/null @@ -1,1887 +0,0 @@ -{ - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@connect": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@chats": { - "type": "text", - "placeholders": {} - }, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@admin": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@addAccount": {}, - "@close": { - "type": "text", - "placeholders": {} - }, - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "@chatHasBeenAddedToThisSpace": {}, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@device": { - "type": "text", - "placeholders": {} - }, - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@encryption": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersionLong": {}, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@invited": { - "type": "text", - "placeholders": {} - }, - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@password": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "remove": "निकालना", - "@remove": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "@id": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "@blocked": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@sendOnEnter": {}, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@fileName": { - "type": "text", - "placeholders": {} - }, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@create": { - "type": "text", - "placeholders": {} - }, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@alias": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@all": { - "type": "text", - "placeholders": {} - }, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@edit": { - "type": "text", - "placeholders": {} - }, - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@copy": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@none": { - "type": "text", - "placeholders": {} - }, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "importFromZipFile": ".zip फ़ाइल से आयात करें", - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@storeSecurlyOnThisDevice": {}, - "@yourChatBackupHasBeenSetUp": {}, - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@help": { - "type": "text", - "placeholders": {} - }, - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "@people": { - "type": "text", - "placeholders": {} - }, - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "पासवर्ड दोहराएं", - "@repeatPassword": {}, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "@callingPermissions": {}, - "@delete": { - "type": "text", - "placeholders": {} - }, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@start": {}, - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@identity": { - "type": "text", - "placeholders": {} - }, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@moderator": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@send": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "@banned": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "exportEmotePack": "इमोट पैक को .zip के रूप में निर्यात करें", - "@exportEmotePack": {}, - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@account": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {}, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@notifications": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@chat": { - "type": "text", - "placeholders": {} - }, - "@group": { - "type": "text", - "placeholders": {} - }, - "@leave": { - "type": "text", - "placeholders": {} - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@allChats": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@license": { - "type": "text", - "placeholders": {} - }, - "@addToSpace": {}, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@forward": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@about": { - "type": "text", - "placeholders": {} - }, - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@cancel": { - "type": "text", - "placeholders": {} - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@clearArchive": {}, - "@appLock": { - "type": "text", - "placeholders": {} - }, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "importEmojis": "इमोजी आयात करें", - "@importEmojis": {}, - "@confirm": { - "type": "text", - "placeholders": {} - }, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@you": { - "type": "text", - "placeholders": {} - }, - "notAnImage": "कोई छवि फ़ाइल नहीं।", - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@search": { - "type": "text", - "placeholders": {} - }, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@logout": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterANumber": {}, - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "@messages": { - "type": "text", - "placeholders": {} - }, - "@login": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@archive": { - "type": "text", - "placeholders": {} - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "@devices": { - "type": "text", - "placeholders": {} - }, - "@accept": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@pin": { - "type": "text", - "placeholders": {} - }, - "importNow": "अभी आयात करें", - "@importNow": {}, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@screenSharingDetail": {}, - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "@invite": {}, - "@enableMultiAccounts": {}, - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - } -} \ No newline at end of file diff --git a/assets/l10n/intl_hr.arb b/assets/l10n/intl_hr.arb deleted file mode 100644 index a3f981b2d..000000000 --- a/assets/l10n/intl_hr.arb +++ /dev/null @@ -1,2712 +0,0 @@ -{ - "@@locale": "hr", - "@@last_modified": "2021-08-14 12:41:10.025984", - "about": "Informacije", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Prihvati", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} je prihvatio/la poziv", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Račun", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} je aktivirao/la obostrano šifriranje", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Dodaj e-mail", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Administrator", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "pseudonim", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Svi", - "@all": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} je odgovorio/la na poziv", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Svatko se može pridružiti", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Zaključavanje programa", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arhiv", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Smiju li se gosti pridružiti", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Stvarno to želiš?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Stvarno se želiš odjaviti?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Za potpisivanje druge osobe, upiši svoju sigurnosnu lozinku ili ključ za oporavak.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Prihvatiti ovaj zahtjev za potvrđivanje od {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerLoginTypesException": "Domaći poslužitelj podržava vrste prijave:\n{serverVersions}\nMeđutim ovaj program podržava samo:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "Domaći poslužitelj podržava verzije specifikacije:\n{serverVersions}\nMeđutim ovaj program podržava samo {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Isključi iz razgovora", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Isključen", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} je isključio/la {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blokiraj uređaj", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Blokirano", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Poruke bota", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Odustani", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "URI adresa {uri} se ne može otvoriti", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Promijeni ime uređaja", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} je promijenio/la avatar razgovora", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} je promijenio/la opis razgovora u: „{description}”", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} je promijenio/la ime razgovora u: „{chatname}”", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} je promijenio/la dozvole razgovora", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} je promijenio/la ime u: „{displayname}”", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} je promijenio/la pravila pristupa za goste", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} je promijenio/la pravila pristupa za goste u: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} je promijenio/la vidljivost kronologije", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} je promijenio/la vidljivost kronologije u: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} je promijenio/la pravila pridruživanja", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} je promijenio/la pravila pridruživanja u: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} je promijenio/la svoj avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} je promijenio/la pseudonime soba", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} je promijenio/la poveznicu poziva", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Promijeni lozinku", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Promijeni domaćeg poslužitelja", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Promijeni tvoj stil", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Promijeni ime grupe", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Promijeni svoj avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Šifriranje je oštećeno", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Razgovor", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Sigurnosna kopija razgovora", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Tvoji su stari razgovori osigurani s ključem za obnavljanje. Pazi da ga ne izgubiš.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Detalji razgovora", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Razgovori", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Odaberi snažnu lozinku", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Isprazni arhiv", - "@clearArchive": {}, - "close": "Zatvori", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Isključi navedenog korisnika iz ove sobe", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Pošalji HTML formatirani tekst", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Pozovi navedenog korisnika u ovu sobu", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Pridruži se navedenoj sobi", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Ukloni navedenog korisnika iz ove sobe", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Napusti ovu sobu", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Opiši se", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Postavi svoju sliku za ovu sobu (mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Postavi svoje ime za ovu sobu", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Postavi razinu prava navedenog korisnika (standardno: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Pošalji neformatirani tekst", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Pošalji odgovor kao reakciju", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Pošalji tekst", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Ponovo uključi navedenog korisnika u ovu sobu", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Naredba nevaljana", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} nije naredba.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Usporedi emoji sličice", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Usporedi brojeve", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Konfiguriraj razgovor", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Potvrdi", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Spoji", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakt je pozvan u grupu", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Sadržava prikazano ime", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Sadrži korisničko ime", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Sadržaj je prijavljen administratorima poslužitelja", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Kopirano u međuspremnik", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopiraj", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopiraj u međuspremnik", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Neuspjelo dešifriranje poruke: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} sudionika", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Stvori", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} je započeo/la razgovor", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Novi prostor", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Trenutačno aktivni", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Tamna", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}. {month}.", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}. {month}. {year}.", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Ovo će nepovratno deaktivirati tvoj korisnički račun. Stvarno to želiš?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Standardna razina dozvole", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Izbriši", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Izbriši račun", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Izbriši poruku", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Uređaj", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID oznaka uređaja", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Uređaji", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Izravni razgovori", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Prikazno ime je promijenjeno", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Preuzmi datoteku", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Uredi", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Uredi blokirane poslužitelje", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Uredi prikazano ime", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Uredi pseudonime sobe", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Uredi avatar sobe", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emotikon već postoji!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Neispravna kratica emotikona!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Paketi emotikona za sobu", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Postavke emotikona", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Kratica emotikona", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Moraš odabrati jednu kraticu emotikona i sliku!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Prazan razgovor", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Aktiviraj paket emotikona globalno", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Aktiviraj šifriranje", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Više nećeš moći deaktivirati šifriranje. Stvarno to želiš?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Šifrirano", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Šifriranje", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Šifriranje nije aktivirano", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} je završio/la poziv", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Upiši e-adressu", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Upiši svoj domaći poslužitelj", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Sve je spremno!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Izrazito uvredljiv", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Ime datoteke", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Veličina fonta", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Proslijedi", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Od pridruživanja", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Od poziva", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Idi u novu sobu", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Grupiraj", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Grupa je javna", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Grupe", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grupa s {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Gosti su zabranjeni", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Gosti se mogu pridružiti", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} je povukao/la poziv za {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Pomoć", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Sakrij promijenjene događaje", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Sakrij nepoznate događaje", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Koliko je ovaj sadržaj uvredljiv?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identitet", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Zanemari", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Zanemareni korisnici", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Pritisnuo/la sam poveznicu", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Neispravna lozinka ili ključ za obnavljanje", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Neuvredljiv", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Pozovi kontakt", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Pozovi kontakt u {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Pozvan/a", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} je pozvao/la {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Samo pozvani korisnici", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Poziv za mene", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} te je pozvao/la u FluffyChat. \n1. Posjeti strnicu fluffychat.im i instaliraj aplikaciju \n2. Registriraj ili prijavi se \n3. Otvori poveznicu poziva: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "piše …", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} se pridružio/la razgovoru", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Pridruži se sobi", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} je izbacio/la {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} je izbacio/la i blokirao/la {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Izbaci iz razgovora", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Zadnja aktivnost: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Napusti", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Napustio/la je razgovor", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licenca", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Svijetla", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Učitaj još {count} sudionika", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Učitava se … Pričekaj.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Učitaj još …", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Prijava", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Prijavi se na {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Odjava", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Promjene člana", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Spominjanje", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Poruke", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Voditelj", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Isključi zvuk razgovora", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Za trenutačno korištenje obostranog šifriranja trebaš Pantalaimon.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Novi razgovor", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Nova poruka u FluffyChatu", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Novi zahtjev za potvrđivanje!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Dalje", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Ne", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Ne postoji veza s poslužiteljem", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Nema emotikona. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Šifriranje možeš aktivirati samo nakon što soba više nije javno dostupna.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "none": "Ništa", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Još nisi dodao/la način za obnavljanje lozinke.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Bez dozvole", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Nema soba …", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Obavijesti", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Obavijesti su aktivirane za ovaj račun", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} korisnika pišu …", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "offensive": "Uvredljiv", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Nepovezano s internetom", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "U redu", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Povezano s internetom", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Internetski ključ sigurnosnih kopija je aktiviran", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Ups! Nažalost se dogodila greška prilikom postavljanja automatskog primanja obavijesti.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Ups, dogodila se greška …", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Za čitanje poruka, otvori program", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Otvori kameru", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "or": "Ili", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Sudionik", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "tajni izraz ili ključ za obnavljanje", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Lozinka", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Zaboravljena lozinka", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Lozinka je promijenjena", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Obnavljanje lozinke", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Ljudi", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Odaberi sliku", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Prikvači", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Sviraj {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Odaberi", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Odaberi lozinku", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Pritisni poveznicu u e-poruci, zatim nastavi.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Upiši 4 znamenke ili ostavi prazno, za deaktiviranje zaključavanja programa.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Upiši svoju lozinku", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Upiši svoj pin", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Upiši svoje korisničko ime", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Slijedi upute na web-stranici i dodirni „Dalje”.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privatnost", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Javne sobe", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Pravila slanja", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Razlog", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Snimanje", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} je preuredio/la događaj", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Ispravi poruku", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Registracija", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Odbij", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} je odbio/la poziv", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Ponovo se pridruži", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Ukloni", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Ukloni sve druge uređaje", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Uklonjeno od {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Ukloni uređaj", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Ponovo uključi u razgovor", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Ukloni svoj avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Prikaži formatirani sadržaj poruke", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Zamijeni sobu s novom verzijom", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Odgovori", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Prijavi poruku", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Zatraži dozvolu", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Soba je nadograđena", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Verzija sobe", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Spremi datoteku", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Traži", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Sigurnost", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Viđeno od {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Pošalji", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Pošalji poruku", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Pošalji kao tekst", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Pošalji audio datoteku", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Pošalji datoteku", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Pošalji sliku", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Šalji poruke", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Pošalji original", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Pošalji naljepnicu", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Pošalji video datoteku", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} ja poslao/la datoteku", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} ja poslao/la audio snimku", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} ja poslao/la sliku", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} je poslao/la naljepnicu", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} je poslao/la video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} je poslao/la podatke poziva", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Postavi kao glavni pseudonim", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Postavi prilagođene emotikone", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Pošalji poveznicu poziva", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Postavi razinu dozvola", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Postavi stanje", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Postavke", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Dijeli", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} je dijelio/la svoje mjesto", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "showPassword": "Pokaži lozinku", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Jednokratna prijava", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Preskoči", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Izvorni kȏd", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Prostor je javan", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Ime prostora", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} ja započeo/la poziv", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Stanje", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Kako si danas?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Pošalji", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Sinkronizira se … Pričekaj.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sustav", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Ne poklapaju se", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Poklapaju se", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Uklj/Isklj favorite", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Uklj/Isklj isključene", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Označi kao pročitano/nepročitano", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Previše zahtjeva. Pokušaj ponovo kasnije!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Prenesi s jednog drugog uređaja", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Pokušaj ponovo poslati", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Nedostupno", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} je ponovo uključio/la {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Deblokiraj uređaj", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Nepoznat uređaj", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Nepoznat algoritam šifriranja", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Nepoznat događaj „{type}”", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Uključi zvuk razgovora", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Otkvači", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 nepročitan razgovor} few{{unreadCount} nepročitana razgovora} other{{unreadCount} nepročitanih razgovora}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} i još {count} korisnika pišu …", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} i {username2} pišu …", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} piše …", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} je napustio/la razgovor", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Korisničko ime", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} ja poslao/la {type} događaj", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Potvrđeno", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Potvrdi", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Pokreni potvrđivanje", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Uspješno si potvrdio/la!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Potvrđivanje drugog računa", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Video poziv", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Vidljivost povijesti razgovora", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Vidljivo za sve sudionike", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Vidljivo za sve", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Glasovna poruka", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Čeka se na sugovornika da prihvati zahtjev …", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Čeka se na sugovornika da prihvati emoji …", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Čeka se na sugovornika da prihvati brojeve …", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Pozadina:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Upozorenje!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Poslali smo ti e-poruku", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Tko može izvršiti koju radnju", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Tko se smije pridružiti grupi", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Zašto želiš ovo prijaviti?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Izbrisati sigurnosnu kopiju razgovora za stvaranje novog sigurnosnog ključa za obnavljanje?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Lozinku možeš obnoviti pomoću ovih adresa.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Napiši poruku …", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Da", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Ti", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Više ne sudjeluješ u ovom razgovoru", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Isključen/a si iz ovog razgovora", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Tvoj javni ključ", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Dijeli lokaciju", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Lokacijske dozvole su odbijene. Za dijeljenje tvoje lokacije dozvoli ih.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Lokacijske usluge su deaktivirane. Za dijeljenje tvoje lokacije aktiviraj ih.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Dohvaćanje lokacije …", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Greška u dohvaćanju lokacije: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "openInMaps": "Otvori u kartama", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} nije matrix poslužitelj. Da li umjesto njega koristiti {server2}?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "autoplayImages": "Automatski pokreni animirane naljepnice i emotikone", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "allChats": "Svi razgovori", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Razgovor je dodan u ovaj prostor", - "@chatHasBeenAddedToThisSpace": {}, - "addToSpace": "Dodaj u prostor", - "@addToSpace": {}, - "serverRequiresEmail": "Za registraciju ovaj poslužitelj mora potvrditi tvoju e-mail adresu.", - "@serverRequiresEmail": {}, - "scanQrCode": "Snimi QR kod", - "@scanQrCode": {}, - "homeserver": "Domaći poslužitelj", - "@homeserver": {}, - "sendOnEnter": "Pošalji pritiskom tipke enter", - "@sendOnEnter": {}, - "link": "Poveznica", - "@link": {}, - "enableMultiAccounts": "(BETA) Omogući korištenje više računa na ovom uređaju", - "@enableMultiAccounts": {}, - "bundleName": "Ime paketa", - "@bundleName": {}, - "removeFromBundle": "Ukloni iz ovog paketa", - "@removeFromBundle": {}, - "addToBundle": "Dodaj u paket", - "@addToBundle": {}, - "editBundlesForAccount": "Uredi pakete za ovaj račun", - "@editBundlesForAccount": {}, - "addAccount": "Dodaj račun", - "@addAccount": {}, - "oneClientLoggedOut": "Jedan od tvojih klijenata je odjavljen", - "@oneClientLoggedOut": {}, - "unverified": "Nepotvrđeno", - "@unverified": {}, - "yourChatBackupHasBeenSetUp": "Sigurnosna kopija tvog razgovora je postavljena.", - "@yourChatBackupHasBeenSetUp": {}, - "repeatPassword": "Ponovi lozinku", - "@repeatPassword": {}, - "messageInfo": "Informacija poruke", - "@messageInfo": {}, - "messageType": "Vrsta poruke", - "@messageType": {}, - "sender": "Pošiljatelj", - "@sender": {}, - "openGallery": "Otvori galeriju", - "@openGallery": {}, - "time": "Vrijeme", - "@time": {}, - "removeFromSpace": "Ukloni iz prostora", - "@removeFromSpace": {}, - "addToSpaceDescription": "Odaberi prostor kojem će se ovaj razgovor dodati.", - "@addToSpaceDescription": {}, - "start": "Početak", - "@start": {}, - "commandHint_clearcache": "Isprazni predmemoriju", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Stvori prazan grupni razgovor\nKoristi --no-encryption za deaktiviranje šifriranja", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_discardsession": "Odbaci sesiju", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Započni izravni razgovor\nKoristi --no-encryption za deaktiviranje šifriranja", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "openVideoCamera": "Otvori kameru za video", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "publish": "Objavi", - "@publish": {}, - "markAsRead": "Označi kao pročitano", - "@markAsRead": {}, - "reportUser": "Prijavi korisnika", - "@reportUser": {}, - "openChat": "Otvori razgovor", - "@openChat": {}, - "dismiss": "Odbaci", - "@dismiss": {}, - "unsupportedAndroidVersion": "Nepodržana Android verzija", - "@unsupportedAndroidVersion": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetEtherpad": "Tekstna bilješka", - "@widgetEtherpad": {}, - "widgetCustom": "Prilagođeno", - "@widgetCustom": {}, - "widgetName": "Ime", - "@widgetName": {}, - "widgetUrlError": "Ovo nije valjan URL.", - "@widgetUrlError": {}, - "switchToAccount": "Prijeđi na račun {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Sljedeći račun", - "@nextAccount": {}, - "emailOrUsername": "E-mail ili korisničko ime", - "@emailOrUsername": {}, - "unsupportedAndroidVersionLong": "Ova funkcija zahtijeva noviju verziju Androida. Provjeri, postoje li nove verzije ili podrška za Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "previousAccount": "Prethodni račun", - "@previousAccount": {}, - "recoveryKey": "Ključ za obnavljanje", - "@recoveryKey": {}, - "recoveryKeyLost": "Izgubio/la si ključ za obnavljanje?", - "@recoveryKeyLost": {}, - "youKickedAndBanned": "🙅 Izbacio/la si i blokirao/la korisnika {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "dehydrateWarning": "Ovo je nepovratna radnja. Spremi datoteku sigurnosne kopije na sigurno mjeto.", - "@dehydrateWarning": {}, - "hydrateTor": "Korisnici TOR-a: Uzvezite izvoz sesije", - "@hydrateTor": {}, - "dehydrateTor": "Korisnici TOR-a: izvezite sesiju", - "@dehydrateTor": {}, - "emojis": "Emojiji", - "@emojis": {}, - "indexedDbErrorLong": "Spremište poruka nažalost nije standarno uključena u privatnom modusu.\nOtvori stranicu\n - about:config\n - postavi dom.indexedDB.privateBrowsing.enabled na true\nFluffyChat se inače neće moći pokrenuti.", - "@indexedDbErrorLong": {}, - "storeSecurlyOnThisDevice": "Spremi sigurno na ovom uređaju", - "@storeSecurlyOnThisDevice": {}, - "countFiles": "Broj datoteka: {count}", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "reactedWith": "{sender} je reagirao/la sa {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "pinMessage": "Prikvači na sobu", - "@pinMessage": {}, - "confirmEventUnpin": "Stvarno želiš trajno otkvačiti događaj?", - "@confirmEventUnpin": {}, - "voiceCall": "Glasovni poziv", - "@voiceCall": {}, - "placeCall": "Nazovi", - "@placeCall": {}, - "videoCallsBetaWarning": "Napominjemo da se funkcija videopoziva trenutačno nalazi u beta stanju. Možda neće raditi ispravno ili uopće neće raditi na svim platformama.", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "Eksperimentalni videopozivi", - "@experimentalVideoCalls": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "addWidget": "Dodaj widget", - "@addWidget": {}, - "widgetNameError": "Zadaj prikazno ime.", - "@widgetNameError": {}, - "youRejectedTheInvitation": "Odbio/la si poziv", - "@youRejectedTheInvitation": {}, - "errorAddingWidget": "Greška prilikom dodavanja widgeta.", - "@errorAddingWidget": {}, - "youJoinedTheChat": "Pridružio/la si se razgovoru", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Prihvatio/la si poziv", - "@youAcceptedTheInvitation": {}, - "youHaveWithdrawnTheInvitationFor": "Povukao/la si poziv za korisnika {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 {user} te je pozvao/la", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Pozvao/la si korisnika {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 Izbacio/la si korisnika {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Ponovo si uključio/la korisnika {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "dehydrate": "Izvezi sesiju i izbriši uređaj", - "@dehydrate": {}, - "unlockOldMessages": "Otključaj stare poruke", - "@unlockOldMessages": {}, - "storeInSecureStorageDescription": "Ključ za obnavljanje spremi u sigurno spremište na ovom uređaju.", - "@storeInSecureStorageDescription": {}, - "saveKeyManuallyDescription": "Spremi ovaj ključ ručno pokretanjem dijaloga za dijeljenje sustava ili međuspremnika.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Spremi u Android KeyStore", - "@storeInAndroidKeystore": {}, - "separateChatTypes": "Odvojeni izravni razgovori, grupe i prostori", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "dehydrateTorLong": "Korisnicima TOR-a preporučuje se izvoz sesije prije zatvaranja prozora.", - "@dehydrateTorLong": {}, - "hydrateTorLong": "Je li zadnji izvoz sesije bio na TOR-u? Brzo ga uvezi i nastavi razgovarati.", - "@hydrateTorLong": {}, - "hydrate": "Obnovi pomoću sigurnosne kopije", - "@hydrate": {}, - "pleaseEnterRecoveryKey": "Upiši svoj ključ za obnavljanje:", - "@pleaseEnterRecoveryKey": {}, - "users": "Korisnici", - "@users": {}, - "pleaseEnterRecoveryKeyDescription": "Za otključavanje starih poruka upiši ključ za obnavljanje koji je generiran u prethodnoj sesiji. Tvoj ključ za obnavljanje NIJE tvoja lozinka.", - "@pleaseEnterRecoveryKeyDescription": {}, - "indexedDbErrorTitle": "Problemi u privatnom modusu", - "@indexedDbErrorTitle": {}, - "youBannedUser": "Isključio/la si korisnika {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "storeInAppleKeyChain": "Spremi u Apple KeyChain", - "@storeInAppleKeyChain": {}, - "user": "Korisnik", - "@user": {}, - "custom": "Prilagođeno", - "@custom": {}, - "fileHasBeenSavedAt": "Datoteka je spremljena u {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "numChats": "{number} razgovora", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "fileIsTooBigForServer": "Poslužitelj javlja da je datoteka prevelika za slanje.", - "@fileIsTooBigForServer": {}, - "jumpToLastReadMessage": "Skoči na zadnju pročitanu poruku", - "@jumpToLastReadMessage": {}, - "commandHint_markasdm": "Označi kao sobu za izravnu razmjenu poruka za zadani Matrix ID", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "Označi kao grupu", - "@commandHint_markasgroup": {}, - "hideUnimportantStateEvents": "Sakrij nevažna stanja događaja", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Nemoj više prikazivati", - "@doNotShowAgain": {}, - "readUpToHere": "Pročitaj do ovdje", - "@readUpToHere": {}, - "wasDirectChatDisplayName": "Prazan razgovor (zvao se {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noBackupWarning": "Upozorenje! Bez aktiviranja spremanja sigurnosne kopije razgovora, izgubit ćeš pristup tvojim šifriranim porukama. Preporučujemo spremanje sigurnosne kopije razgovora prije odjave.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "Nijedan drugi uređaj nije pronađen", - "@noOtherDevicesFound": {}, - "whyIsThisMessageEncrypted": "Zašto nije moguće čitati ovu poruku?", - "@whyIsThisMessageEncrypted": {}, - "jump": "Skoči", - "@jump": {}, - "startFirstChat": "Započni svoj prvi razgovor", - "@startFirstChat": {}, - "newSpaceDescription": "Prostori omogućuju konsolidiranje tvojih razgovora i izgradnju privatne ili javne zajednice.", - "@newSpaceDescription": {}, - "encryptThisChat": "Šifiraj ovaj razgovor", - "@encryptThisChat": {}, - "deviceKeys": "Ključevi uređaja:", - "@deviceKeys": {}, - "foregroundServiceRunning": "Ova se obavijest pojavljuje kada se pokreće usluga u prvom planu.", - "@foregroundServiceRunning": {}, - "callingPermissions": "Dozvole za pozivanje", - "@callingPermissions": {}, - "callingAccountDetails": "Omogućuje FluffyChatu korištenje izvorne Android aplikacije za pozivanje.", - "@callingAccountDetails": {}, - "callingAccount": "Račun za pozivanje", - "@callingAccount": {}, - "commandHint_hug": "Pošalji grljenje", - "@commandHint_hug": {}, - "commandHint_googly": "Pošalji kotrljajuće oči", - "@commandHint_googly": {}, - "commandHint_cuddle": "Pošalji maženje", - "@commandHint_cuddle": {}, - "confirmMatrixId": "Za brisanje tvog računa potvrdi svoj Matrix ID.", - "@confirmMatrixId": {}, - "supposedMxid": "Trebao bi biti {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "enterRoom": "Uđi u sobu", - "@enterRoom": {}, - "screenSharingDetail": "Dijeliš svoj ekran u FuffyChatu", - "@screenSharingDetail": {}, - "appearOnTopDetails": "Omogućuje prikaz aplikacije ispred drugih (nije potrebno ako je FluffyChat već postavljen kao račun za pozivanje)", - "@appearOnTopDetails": {}, - "appearOnTop": "Prikaz ispred drugih", - "@appearOnTop": {}, - "newGroup": "Nova grupa", - "@newGroup": {}, - "allSpaces": "Svi prostori", - "@allSpaces": {}, - "screenSharingTitle": "dijeljenje ekrana", - "@screenSharingTitle": {}, - "otherCallingPermissions": "Mikrofon, kamera i druge FluffyChat dozvole", - "@otherCallingPermissions": {}, - "enterSpace": "Uđi u prostor", - "@enterSpace": {}, - "newSpace": "Novi prostor", - "@newSpace": {}, - "sorryThatsNotPossible": "Žao nam je … to nije moguće", - "@sorryThatsNotPossible": {}, - "disableEncryptionWarning": "Iz sigurnosnih razloga ne možeš deaktivirati šifriranje u razgovoru u kojem je prije bilo aktivirano.", - "@disableEncryptionWarning": {}, - "googlyEyesContent": "{senderName} ti šalje kotrljajuće oči", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} te mazi", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} te grli", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "noKeyForThisMessage": "To se može dogoditi ako je poruka poslana prije prijave na tvoj račun na ovom uređaju.\n\nTakođer je moguće da je pošiljatelj blokirao tvoj uređaj ili je došlo do greške s internetskom vezom.\n\nMožeš li pročitati poruku na jednoj drugoj sesiji? U tom slučaju možeš prenijeti poruku iz nje! Idi na Postavke > Uređaji i uvjeri se da su se tvoji uređaji međusobno provjerili. Kada sljedeći put otvoriš sobu i obje sesije su u prednjem planu, ključevi će se automatski prenijeti.\n\nNe želiš izgubiti ključeve kada se odjaviš ili zamijeniš uređaje? Aktiviraj spremanje sigurnosne kopije razgovora u postavkama.", - "@noKeyForThisMessage": {}, - "reopenChat": "Ponovo otvori razgovor", - "@reopenChat": {}, - "openLinkInBrowser": "Otvori poveznicu u pregledniku", - "@openLinkInBrowser": {}, - "report": "prijavi", - "@report": {}, - "allRooms": "Svi grupni razgovori", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "😭 Joj! Dogodila se greška. Pokušaj ponovo kasnije. Ako želiš, grešku možeš prijaviti programerima.", - "@reportErrorDescription": {}, - "signInWithPassword": "Prijavi se s lozinkom", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Pokušaj ponovo kasnije ili odaberi jedan drugi poslužitelj.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "Prijavi se pomoću {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Nije slikovna datoteka.", - "@notAnImage": {}, - "importNow": "Uvezi sada", - "@importNow": {}, - "importEmojis": "Uvezi emoji slike", - "@importEmojis": {}, - "importFromZipFile": "Uvezi iz .zip datoteke", - "@importFromZipFile": {}, - "replace": "Zamijeni", - "@replace": {}, - "exportEmotePack": "Izvezi paket emotikona kao .zip", - "@exportEmotePack": {}, - "sendTypingNotifications": "Pošalji pismene obavijesti", - "@sendTypingNotifications": {}, - "setColorTheme": "Postavi boju teme:", - "@setColorTheme": {}, - "tryAgain": "Pokušaj ponovo", - "@tryAgain": {}, - "messagesStyle": "Poruke:", - "@messagesStyle": {}, - "chatDescription": "Opis razgovora", - "@chatDescription": {}, - "invalidServerName": "Neispravno ime servera", - "@invalidServerName": {}, - "chatPermissions": "Dozvole za razgovor", - "@chatPermissions": {}, - "setChatDescription": "Postavi opis rzgovora", - "@setChatDescription": {}, - "redactedBy": "Preuređeno od {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "optionalRedactReason": "(Opcionalno) Razlog za redigiranje ove poruke …", - "@optionalRedactReason": {}, - "inviteContactToGroupQuestion": "Želiš li pozvati {contact} u razgovor grupe „{groupName}”?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Preuređeno od {username} zbog: „{reason}”", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "redactMessageDescription": "Poruka će se redigirati za sve sudionike u ovom razgovoru. To se ne može poništiti.", - "@redactMessageDescription": {}, - "addChatDescription": "Dodaj opis razgovora …", - "@addChatDescription": {}, - "directChat": "Izravni razgovor", - "@directChat": {}, - "inviteGroupChat": "📨 Pozovi u grupni razgovor", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Pozovi u privatni razgovor", - "@invitePrivateChat": {}, - "noChatDescriptionYet": "Opis razgovora još nije stvoren.", - "@noChatDescriptionYet": {}, - "chatDescriptionHasBeenChanged": "Opis razgovora je promijenjen", - "@chatDescriptionHasBeenChanged": {}, - "profileNotFound": "Korisnik nije pronađen na poslužitelju. Možda postoji problem s vezom ili korisnik ne postoji.", - "@profileNotFound": {}, - "shareInviteLink": "Dijeli poveznicu za poziv", - "@shareInviteLink": {}, - "emoteKeyboardNoRecents": "Ovdje će se pojaviti nedavno korišteni emotikoni …", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Postavi temu:", - "@setTheme": {}, - "createGroup": "Stvori grupu", - "@createGroup": {}, - "invite": "Pozovi", - "@invite": {}, - "invalidInput": "Neispravan unos!", - "@invalidInput": {}, - "wrongPinEntered": "Unesen je pogrešan PIN! Pokušaj ponovo za {seconds} sekunde …", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "hasKnocked": "🚪 {user} je pokucao/la", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "pleaseEnterANumber": "Upiši broj veći od 0", - "@pleaseEnterANumber": {}, - "pushNotificationsNotAvailable": "Automatsko slanje obavijesti nije dostupno", - "@pushNotificationsNotAvailable": {}, - "learnMore": "Saznaj više", - "@learnMore": {}, - "createGroupAndInviteUsers": "Stvori grupu i pozovi korisnike", - "@createGroupAndInviteUsers": {}, - "startConversation": "Pokreni konverzaciju", - "@startConversation": {}, - "blockedUsers": "Blokirani korisnici", - "@blockedUsers": {}, - "groupCanBeFoundViaSearch": "Grupa se može pronaći putem pretrage", - "@groupCanBeFoundViaSearch": {}, - "block": "Blokiraj", - "@block": {}, - "yourGlobalUserIdIs": "Tvoj globalni korisnički ID je: ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "Pošalji neobrađeni json", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Oprosti … čini se da ovo nije ispravan ključ za obnavljanje.", - "@wrongRecoveryKey": {}, - "blockUsername": "Zanemari korisničko ime", - "@blockUsername": {}, - "groupName": "Ime grupe", - "@groupName": {}, - "databaseMigrationTitle": "Baza podataka je optimirana", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "Traži #chats, @users …", - "@searchChatsRooms": {}, - "databaseMigrationBody": "Pričekaj. Ovo može potrajati.", - "@databaseMigrationBody": {}, - "transparent": "Prozirno", - "@transparent": {}, - "formattedMessages": "Formatirane poruke", - "@formattedMessages": {}, - "incomingMessages": "Dolazne poruke", - "@incomingMessages": {}, - "passwordsDoNotMatch": "Lozinke se ne poklapaju", - "@passwordsDoNotMatch": {}, - "accessAndVisibility": "Pristup i vidljivost", - "@accessAndVisibility": {}, - "calls": "Pozivi", - "@calls": {}, - "customEmojisAndStickers": "Prilagođeni emojiji i naljepnice", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Dodaj ili dijeli prilagođene emojije ili naljepnice koje se mogu koristiti u bilo kojem razgovoru.", - "@customEmojisAndStickersBody": {}, - "accessAndVisibilityDescription": "Tko se smije pridružiti ovom razgovoru i kako se razgovor može otkriti.", - "@accessAndVisibilityDescription": {}, - "stickers": "Naljepnice", - "@stickers": {}, - "discover": "Otkrij", - "@discover": {}, - "formattedMessagesDescription": "Prikaži formatirani sadržaj poruke poput podebljanog teksta koristeći markdown.", - "@formattedMessagesDescription": {}, - "nothingFound": "Ništa nije pronađeno...", - "@nothingFound": {}, - "select": "Odaberi", - "@select": {}, - "newPassword": "Nova lozinka", - "@newPassword": {}, - "unbanUserDescription": "Korisnik će se ponovo moći pridružiti razgovoru ako pokuša.", - "@unbanUserDescription": {}, - "publicSpaces": "Javni prostori", - "@publicSpaces": {}, - "subspace": "Podprostori", - "@subspace": {}, - "decline": "Odbij", - "@decline": {}, - "thisDevice": "Ovaj uređaj:", - "@thisDevice": {}, - "presenceStyle": "Prisutnost:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Prikaži poruke stanja od drugih korisnika", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "noPublicLinkHasBeenCreatedYet": "Još nije stvorena nijedna javna poveznica", - "@noPublicLinkHasBeenCreatedYet": {}, - "hidePresences": "Sakriti popis stanja?", - "@hidePresences": {}, - "pleaseEnterYourCurrentPassword": "Upiši svoju trenutačnu lozinku", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "Javna poveznica", - "@publicLink": {}, - "passwordIsWrong": "Tvoja upisana lozinka je kriva", - "@passwordIsWrong": {}, - "initAppError": "Dogodila se greška prilikom inicijaliziranja aplikacije", - "@initAppError": {}, - "hideRedactedMessagesBody": "Ako netko redigira poruku, ta poruka više neće biti vidljiva u razgovoru.", - "@hideRedactedMessagesBody": {}, - "kickUserDescription": "Korisnik je izbačen iz razgovora, ali nije blokiran. U javnim razgovorima se korisnik može ponovo pridružiti u bilo kojem trenutku.", - "@kickUserDescription": {}, - "addChatOrSubSpace": "Dodaj razgovor ili podpodručje", - "@addChatOrSubSpace": {}, - "appLockDescription": "Zaključaj aplikaciju kada je ne koristiš s PIN kodom", - "@appLockDescription": {}, - "globalChatId": "Globalni ID razgovora", - "@globalChatId": {}, - "hideRedactedMessages": "Sakrij redigirane poruke", - "@hideRedactedMessages": {}, - "hideInvalidOrUnknownMessageFormats": "Sakrij nevažeće ili nepoznate formate poruka", - "@hideInvalidOrUnknownMessageFormats": {}, - "overview": "Pregled", - "@overview": {}, - "notifyMeFor": "Obavijesit me za", - "@notifyMeFor": {}, - "passwordRecoverySettings": "Postavke za obnavljanje lozinke", - "@passwordRecoverySettings": {}, - "hideMemberChangesInPublicChats": "Sakrij promjene članova u javnim razgovorima", - "@hideMemberChangesInPublicChats": {}, - "youInvitedToBy": "📩 Pozvan/a si putem poveznice na:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "usersMustKnock": "Korisnici moraju pokucati", - "@usersMustKnock": {}, - "noOneCanJoin": "Nitko se ne može pridružiti", - "@noOneCanJoin": {}, - "userWouldLikeToChangeTheChat": "{user} se želi pridružiti razgovoru.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "knock": "Pokucaj", - "@knock": {}, - "knocking": "Kucanje", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Razgovor se može otkriti pretraživanjem servera {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "searchForUsers": "Traži @users...", - "@searchForUsers": {}, - "pleaseChooseAStrongPassword": "Odaberi snažnu lozinku", - "@pleaseChooseAStrongPassword": {}, - "joinSpace": "Pridruži se prostoru", - "@joinSpace": {}, - "publicChatAddresses": "Adrese javnih razgovora", - "@publicChatAddresses": {}, - "createNewAddress": "Stvori novu adresu", - "@createNewAddress": {}, - "userRole": "Korisnička uloga", - "@userRole": {}, - "verifyOtherUser": "🔐 Potvrdi drugog korisnika", - "@verifyOtherUser": {}, - "sendTypingNotificationsDescription": "Drugi sudionici u razgovoru mogu vidjeti kada pišeš novu poruku.", - "@sendTypingNotificationsDescription": {}, - "sendReadReceiptsDescription": "Drugi sudionici u raygovoru mogu vidjeti kada pročitaš poruku.", - "@sendReadReceiptsDescription": {}, - "searchIn": "Traži u razgovoru „{chat}”...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Traži više...", - "@searchMore": {}, - "gallery": "Galerija", - "@gallery": {}, - "files": "Datoteke", - "@files": {}, - "verifyOtherDevice": "🔐 Potvrdi drugi uređaj", - "@verifyOtherDevice": {}, - "unreadChatsInApp": "{appname}: Nroj nepročitanih razgovora: {unread}", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "commandHint_ignore": "Zanemari navedeni matrix ID", - "@commandHint_ignore": {}, - "blockListDescription": "Možeš blokirati korisnike koji te ometaju. Nećeš moći primati poruke ili pozivnice za sobe od korisnika koji se nalaze u tvom osobnom popisu blokiranih.", - "@blockListDescription": {}, - "isReadyForKeyVerification": "{sender} je spreman/na za potvrđivanje ključa", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "banUserDescription": "Korisnik će biti isključen iz razgovora i moći će ponovo prisustvovati razgovoru kad ga se deblokira.", - "@banUserDescription": {}, - "sessionLostBody": "Tvoja je sesija izgubljena. Prijavi ovu grešku programerima na {url}. Poruka o grešci glasi: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "completedKeyVerification": "{sender} je dovršio/la potvrđivanje ključa", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "archiveRoomDescription": "Razgovor će se premjestiti u arhivu. Drugi korisnici će moći vidjeti da si napustio/la razgovor.", - "@archiveRoomDescription": {}, - "removeDevicesDescription": "Bit ćeš odjavljen/a s ovog uređaja i više nećeš moći primati poruke.", - "@removeDevicesDescription": {}, - "noUsersFoundWithQuery": "Nažalost nije pronađen nijedan korisnik s „{query}”. Provjeri točnost upisa.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "restoreSessionBody": "Aplikacija sada pokušava obnoviti tvoju sesiju iz sigurnosne kopije. Prijavi ovu grešku programerima na {url}. Poruka o grešci glasi: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "requestedKeyVerification": "{sender} je zatražio/la potvrđivanje ključa", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "restricted": "Ograničeni", - "@restricted": {}, - "roomUpgradeDescription": "Razgovor će se tada ponovo stvoriti s novom verzijom sobe. Svi sudionici će biti obaviješteni da se moraju prebaciti na novi razgovor. Više o verzijama soba možeš saznati na https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "noGoogleServicesWarning": "Čini se da Firebase Cloud Messaging nije dostupan na tvom uređaju. Za daljnje primanje push obavijesti, preporučujemo da instaliraš ntfy. S ntfy ili drugim pružateljem usluge Unified Push možeš primati push obavijesti na podatkovno siguran način. Ntfy možeš preuzeti s PlayStorea ili s F-Droida.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "verifyOtherDeviceDescription": "Kada potvrdiš jedan drugi uređaj, ti uređaji mogu razmjenjivati ključeve, povećavajući tvoju ukupnu sigurnost. 💪 Kada pokreneš provjeru, pojavit će se skočni prozor u aplikaciji na oba uređaja. Tamo ćeš tada vidjeti niz emojija ili brojeve koje moraš međusobno usporediti. Najbolje je imati oba uređaja pri ruci prije nego što započneš provjeru. 🤳", - "@verifyOtherDeviceDescription": {}, - "verifyOtherUserDescription": "Ako potvrdiš jednog drugog korisnika, možeš biti siguran/na da znaš kome zapravo pišeš. 💪\n\nKada pokreneš provjeru, vi i drugi korisnik vidjet ćete skočni prozor u aplikaciji. Tamo ćeš tada vidjeti niz emojija ili brojeve koje morate međusobno usporediti.\n\nNajbolji način za to je da se nađete zajedno ili započnete videopoziv. 👭", - "@verifyOtherUserDescription": {}, - "knockRestricted": "Pokucaj na ograničene sobe", - "@knockRestricted": {}, - "hideMemberChangesInPublicChatsBody": "Za bolju čitljivosti, na vremenskoj traci razgovora nemoj prikazivati kad se netko pridruži ili napusti javni razgovor.", - "@hideMemberChangesInPublicChatsBody": {}, - "makeAdminDescription": "Nakon postavljanja ovog korisnika kao administratora, to možda nećeš moći poništiti jer će on tada imati iste dozvole kao i ti.", - "@makeAdminDescription": {}, - "leaveEmptyToClearStatus": "Ostavi prazno za brisanje tvog stanja.", - "@leaveEmptyToClearStatus": {}, - "forwardMessageTo": "Proslijediti poruku u sobu {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "minimumPowerLevel": "{level} je najmanja razina prava.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "databaseBuildErrorBody": "Nije moguće izgraditi SQlite bazu podataka. Aplikacija za sada pokušava koristiti staru bazu podataka. Prijavi ovu grešku programerima na {url}. Poruka o grešci glasi: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sendReadReceipts": "Šalji potvrde o čitanju", - "@sendReadReceipts": {}, - "acceptedKeyVerification": "{sender} je prihvatio/la potvrđivanje ključa", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender} je prekinuo/la potvrđivanje ključa", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} je pokrenuo/la potvrđivanje ključa", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "commandHint_unignore": "Poništi zanemarivanje navedenog matrix ID-a", - "@commandHint_unignore": {}, - "noDatabaseEncryption": "Šifriranje baze podataka nije podržano na ovoj platformi", - "@noDatabaseEncryption": {}, - "thereAreCountUsersBlocked": "Broj trenutačno blokiranih korisnika: {count}.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "swipeRightToLeftToReply": "Za odgovaranje povuci prstom zdesna ulijevo", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_hu.arb b/assets/l10n/intl_hu.arb deleted file mode 100644 index 185a04816..000000000 --- a/assets/l10n/intl_hu.arb +++ /dev/null @@ -1,2710 +0,0 @@ -{ - "@@locale": "hu", - "@@last_modified": "2021-08-14 12:41:10.016566", - "about": "Névjegy", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Elfogadás", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} elfogadta a meghívást", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Fiók", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} aktiválta a végpontok közötti titkosítást", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "álnév", - "@alias": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} felvette a hívást", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Bárki csatlakozhat", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "Archívum", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Csatlakozhatnak-e vendégek", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Biztos benne?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "A másik fél igazolásához meg kell adni a biztonságos tároló jelmondatát vagy a visszaállítási kulcsot.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Elfogadja {username} hitelesítési kérelmét?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banFromChat": "Kitiltás csevegésből", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Kitiltva", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} kitiltotta: {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Eszköz blokkolása", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "cancel": "Mégse", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Eszköznév módosítása", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} módosította a csevegési profilképét", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} módosította a csevegés leírását erre: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} módosította a csevegés nevét erre: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} módosította a csevegési engedélyeket", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} módosította a megjelenített nevét erre: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} módosította a vendégek hozzáférési szabályokat", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} módosította a vendégek hozzáférési szabályait erre: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} módosította az előzmények láthatóságát", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} módosította az előzmények láthatóságát erre: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} módosított a csatlakozási szabályokat", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} módosította a csatlakozási szabályokat erre: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} módosította a profilképét", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} módosította a szoba álneveit", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} módosította a meghívó hivatkozást", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Jelszó módosítása", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Matrix-kiszolgáló váltás", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Stílus módosítása", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Csoport nevének módosítása", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "A titkosítás megsérült", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Csevegés", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Csevegés részletei", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Válasszon egy erős jelszót", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Bezárás", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Hasonlítsa össze az emojikat", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Kérem hasonlítsa össze a számokat", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Megerősítés", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Csatlakozás", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Meghívta ismerősét a csoportba", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Vágólapra másolva", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Másolás", - "@copy": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Nem sikerült visszafejteni az üzenetet: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} résztvevő", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Létrehozás", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} csevegést hozott létre", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Jelenleg aktív", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Sötét", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{month}. {day}.", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{year}. {month}. {day}.", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Ez deaktiválja a felhasználói fiókját. Ez nem vonható vissza! Biztos benne?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "delete": "Törlés", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Fiók törlése", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Üzenet törlése", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Eszköz", - "@device": { - "type": "text", - "placeholders": {} - }, - "devices": "Eszközök", - "@devices": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Megjelenítési név megváltozott", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Fájl letöltése", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Megjelenítési név szerkesztése", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "A hangulatjel már létezik!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Érvénytelen emoji rövidkód!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Emoji csomagok a szobához", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emoji Beállítások", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Emoji rövidkód", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Az emojihoz egy képet és egy rövidkódot kell választani!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Üres csevegés", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Emoji csomag engedélyezése globálisan", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Többé nem fogja tudni kikapcsolni a titkosítást. Biztos benne?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encryption": "Titkosítás", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Titkosítás nincs engedélyezve", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} befejezte a hívást", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterYourHomeserver": "Adja meg a Matrix-kiszolgálót", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "fileName": "Fájlnév", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Továbbítás", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Csatlakozás óta", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Meghívás óta", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "Csoport", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "A csoport nyilvános", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Csoport {displayname}-al", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Nem lehetnek vendégek", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Csatlakozhatnak vendégek", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} visszavonta {targetName} meghívását", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Súgó", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Visszavont események elrejtése", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Ismeretlen események elrejtése", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Azonosító", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Figyelmen kívül hagyott felhasználók", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Hibás jelmondat vagy visszaállítási kulcs", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Ismerős meghívása", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Ismerős meghívása a(z) {groupName} csoportba", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Meghívott", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} meghívta {targetName}-t", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Csak meghívott felhasználók", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} meghívott a FluffyChat-be.\n1. Keresse fel a fluffychat.im oldalt, és telepítse az alkalmazást \n2. Regisztráljon vagy jelentkezzen be \n3. Nyissa meg a meghívó linket: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "gépel…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} csatlakozott a csevegéshez", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Csatlakozás a szobához", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} kirúgta {targetName}-t", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} kirúgta és kitiltotta {targetName}-t", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Kirúgás a csevegésből", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Utoljára aktív: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Elhagyás", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Elhagyta a csevegést", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licensz", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Világos", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "További {count} résztvevő betöltése", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Betöltés… Kérem, várjon.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Továbbiak betöltése…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Bejelentkezés", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Bejelentkezés a(z) {homeserver} Matrix-kiszolgálóra", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Kijelentkezés", - "@logout": { - "type": "text", - "placeholders": {} - }, - "mention": "Megemlítés", - "@mention": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderátor", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Csevegés némítása", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Jelenleg a Pantalaimon szükséges a végpontok közötti titkosítás használatához.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Új FluffyChat üzenet", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Új hitelesítési kérelem!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "no": "Nem", - "@no": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Emojik nem elérhetőek. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Úgy tűnik a Firebase Cloud Messaging nem elérhető a készülékén. Ha mégis push értesítéseket kíván kapni, javasoljuk a ntfy telepítését. A ntfy vagy más egyéb Egyesített Push szolgáltató esetében úgy kaphat értesítést, hogy adatai biztonságban maradnak. Letöltheti a ntfy-t a PLayStore-ból, vagy F-Droid-ról is.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Nincs", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Nincs engedély", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Nem találhatóak szobák…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "offline": "Offline", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Rendben", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Online", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Online kulcsmentés engedélyezve", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Hoppá, valami hiba lépett fel…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Alkalmazás megnyitása az üzenetek elolvasásához", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Kamera megnyitása", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "jelmondat vagy visszaállítási kulcs", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Jelszó", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "A jelszó módosításra került", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Kép választása", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Rögzítés", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "{fileName} lejátszása", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseEnterYourPassword": "Kérem adja meg jelszavát", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Adja meg a felhasználónevét", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "privacy": "Adatvédelem", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Nyilvános szobák", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "recording": "Felvétel", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} visszavont egy eseményt", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Elutasít", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} elutasította a meghívást", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Újra csatlakozás", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Eltávolítás", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Minden más eszköz eltávolítása", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "{username} által törölve", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Eszköz eltávolítása", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Csevegés kitiltás feloldása", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Formázott üzenetek megjelenítése", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "Válasz", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Jogosultság igénylése", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "A szoba frissítve lett", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "{username} látta", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Küldés", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Üzenet küldése", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Hangüzenet küldése", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Fájl küldése", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Kép küldése", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Eredeti küldése", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Videó küldése", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} küldött egy fájlt", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} hangüzenetet küldött", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} képüzenetet küldött", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} matricát küldött", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} videót küldött", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} hívásinformációt küldött", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setInvitationLink": "Meghívó hivatkozás beállítása", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Állapot beállítása", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Beállítások", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Megosztás", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} megosztotta a pozícióját", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "skip": "Kihagyás", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Forráskód", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} hívást indított", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "statusExampleMessage": "Hogy érzi ma magát?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Beküldés", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Rendszer", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Nem egyeznek", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Egyeznek", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Újraküldés megpróbálása", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Nem elérhető", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} feloldotta {targetName} kitiltását", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Eszköz blokkolásának megszüntetése", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Ismeretlen eszköz", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Ismeretlen titkosítási algoritmus", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Ismeretlen esemény: '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Csevegés némítás feloldása", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Rögzítés megszüntetése", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 olvasatlan csevegés} other{{unreadCount} olvasatlan csevegés}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} és {count} másik résztvevő gépel…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} és {username2} gépel…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} gépel…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} elhagyta a csevegést", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Felhasználónév", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} {type} eseményt küldött", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "Hitelesít", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Hitelesítés megkezdése", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Sikeres hitelesítés!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Másik fiók hitelesítése", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videóhívás", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Csevegési előzmény láthatósága", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Minden résztvevő számára látható", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Bárki számára látható", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Hangüzenet", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Várakozás a partnerre, hogy elfogadja a kérést…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Várakozás a partnerre, hogy elfogadja az emojit…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Várakozás a partnerre, hogy elfogadja a számokat…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Háttér:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Figyelmeztetés!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Ki csatlakozhat a csoporthoz", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Írjon egy üzenetet…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Igen", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Ön", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Immáron nem vesz részt ebben a csevegésben", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Kitiltották ebből a csevegésből", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Ezekkel a címekkel vissza tudja állítani a jelszavát.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Küldtünk Önnek egy emailt", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Jelszó visszaállítás", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Még nem adott meg semmilyen módot a jelszava visszaállítására.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Meghívás nekem", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Rákattintottam a linkre", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "enterAnEmailAddress": "Adjon meg egy email címet", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Titkosított", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "edit": "Szerkeszt", - "@edit": { - "type": "text", - "placeholders": {} - }, - "directChats": "Közvetlen csevegések", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Eszköz ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bot üzenetek", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Jelszó megismétlése", - "@repeatPassword": {}, - "addEmail": "E-mail-cím hozzáadása", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "all": "Összes", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Összes csevegés", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "Animált matricák és hangulatjelek automatikus lejátszása", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "sendOnEnter": "Küldés Enterrel", - "@sendOnEnter": {}, - "cantOpenUri": "Nem sikerült az URI megnyitása: {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeYourAvatar": "Profilkép módosítása", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Hozzáadás térhez", - "@addToSpace": {}, - "areYouSureYouWantToLogout": "Biztosan kijelentkezik?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "A kiszolgáló a következő bejelentkezéseket támogatja:\n{serverVersions}\nDe ez az alkalmazást csak ezeket támogatja:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "blocked": "Blokkolva", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "appLock": "Alkalmazás zár", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "commandHint_myroomnick": "Az ebben a szobában megjelenített neved megváltoztatása", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_plain": "Formázatlan szöveg küldése", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_send": "Szöveg küldése", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "contentHasBeenReported": "A tartalom jelentve lett a szerver üzemeltetőinek", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "commandHint_myroomavatar": "Az ebben a szobában megjelenített profilképed megváltoztatása (mxc URI használatával)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "copyToClipboard": "Vágólapra másolás", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Szoba álnevek szerkesztése", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Szoba profilképének szerkesztése", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Titkosítás engedélyezése", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Rendkívül sértő", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Betűméret", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Minden kész!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "groups": "Csoportok", - "@groups": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Mennyire sértő ez a tartalom?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Nem sértő", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "A helymeghatározás nem engedélyezett az alkalmazás számára. Kérem engedélyezze, hogy meg tudja osztani helyzetét.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "newChat": "Új csevegés", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "QR kód beolvasása", - "@scanQrCode": {}, - "notificationsEnabledForThisAccount": "Értesítések bekapcsolása ebben a fiókban", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "offensive": "Sértő", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Hoppá! Sajnos hiba lépett fel a push értesítések beállításakor.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "commandHint_create": "Egy üres csevegő csoport létrehozása\nA --no-encryption kapcsolóval titkosítatlan szoba hozható létre", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_invite": "Adott felhasználó meghívása ebbe a szobába", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "locationDisabledNotice": "A helymeghatározás ki van kapcsolva. Kérem, kapcsolja be, hogy meg tudja osztani helyzetét.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Matrix szerver", - "@homeserver": {}, - "chatBackup": "Beszélgetések mentése", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "ignore": "Figyelmen kívül hagyás", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "next": "Következő", - "@next": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "A beszélgetések mentése be lett állítva.", - "@yourChatBackupHasBeenSetUp": {}, - "chatBackupDescription": "A régebbi beszélgetései egy biztonsági kulccsal vannak védve. Bizonyosodjon meg róla, hogy nem veszíti el.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Tartalmazza a megjelenített nevet", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Tartalmazza a felhasználónevet", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Új szoba megnyitása", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Nem elérhető a szerver", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Csak akkor kapcsolható be a titkosítás, ha a szoba nem nyilvánosan hozzáférhető.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "A beszélgetés hozzá lett adva ehhez a térhez", - "@chatHasBeenAddedToThisSpace": {}, - "chats": "Csevegések", - "@chats": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Archívum törlése", - "@clearArchive": {}, - "commandHint_ban": "Felhasználó kitiltása ebből a szobából", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_clearcache": "Gyorsítótár törlése", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_discardsession": "Munkamenet elvetése", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Közvetlen csevegés indítása\nA --no-encryption kapcsolóval titkosítatlan beszélgetést hozhat létre", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_html": "HTML formázott üzenet küldése", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_join": "Csatlakozás a megadott szobához", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "A megadott felhasználó kirúgása a szobából", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Szoba elhagyása", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandInvalid": "Érvénytelen parancs", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} nem egy parancs.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "configureChat": "Csevegés konfigurálása", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Új tér", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Alapértelmezett hozzáférési szint", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Hiba a tartózkodási hely meghatározása közben: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "memberChanges": "Tagsági változások", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "messages": "Üzenetek", - "@messages": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} nem egy Matrix szerver, használja a {server2} szervert inkább?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "notifications": "Értesítések", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} felhasználó gépel…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Tartózkodási hely lekérése…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "openVideoCamera": "Kamera megnyitása videóhoz", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "A Matrix szerver ezeket a specifikáció verziókat támogatja:\n{serverVersions}\nAzonban ez az app csak ezeket: {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "commandHint_me": "Jellemezd magad", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_op": "Az adott felhasználó hozzáférési szintjének megadása (alapértelmezett: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_react": "Válasz küldése reakcióként", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_unban": "Adott felhasználó kitiltásának feloldása a szobához", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "editBlockedServers": "Blokkolt szerverek szerkesztése", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "dehydrate": "Munkamenet exportálása és az eszköz törlése", - "@dehydrate": {}, - "dehydrateWarning": "Ez nem visszavonható. Bizonyosodjon meg róla, hogy biztonságos helyen tárolja a mentett fájlt.", - "@dehydrateWarning": {}, - "dehydrateTor": "TOR felhasználók: munkamenet exportálása", - "@dehydrateTor": {}, - "dehydrateTorLong": "TOR felhasználóknak ajánlott a munkamenet exportálása az ablak bezárása előtt.", - "@dehydrateTorLong": {}, - "hydrateTor": "TOR felhasználóknak: munkamenet export importálása", - "@hydrateTor": {}, - "hydrate": "Visszaállítás mentett fájlból", - "@hydrate": {}, - "link": "Hivatkozás", - "@link": {}, - "redactMessage": "Üzenet visszavonása", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "people": "Emberek", - "@people": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Írja be PIN kódját", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "cuddleContent": "{senderName} hozzád bújik", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_markasgroup": "Csoportnak jelölés", - "@commandHint_markasgroup": {}, - "addAccount": "Fiók hozzáadása", - "@addAccount": {}, - "search": "Keresés", - "@search": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "Gülüszemek küldése", - "@commandHint_googly": {}, - "commandHint_cuddle": "Összebújás küldése", - "@commandHint_cuddle": {}, - "sendMessages": "Üzenetek küldése", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Matrica küldése", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Üzenet jelentése", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "participant": "Résztvevő", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Elfelejtett jelszó", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Szoba verzió", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "confirmMatrixId": "A fiók törléséhez adja meg a Matrix ID-t.", - "@confirmMatrixId": {}, - "or": "Vagy", - "@or": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Kérjük válasszon", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "commandHint_hug": "Ölelés küldése", - "@commandHint_hug": {}, - "reason": "Indok", - "@reason": { - "type": "text", - "placeholders": {} - }, - "register": "Regisztráció", - "@register": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Fájl mentése", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "googlyEyesContent": "{senderName} gülüszemeket küld", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "openInMaps": "Megnyitás térképen", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Írjon be 4 számjegyet, vagy hagyja üresen a zár kikapcsolásához.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "security": "Biztonság", - "@security": { - "type": "text", - "placeholders": {} - }, - "notAnImage": "Nem kép fájl.", - "@notAnImage": {}, - "showPassword": "Jelszó mutatása", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "hugContent": "{senderName} megölelt", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "jumpToLastReadMessage": "Az utoljára olvasott üzenethez ugrás", - "@jumpToLastReadMessage": {}, - "allRooms": "Minden csoport csevegés", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "widgetVideo": "Videó", - "@widgetVideo": {}, - "dismiss": "Elvetés", - "@dismiss": {}, - "reportErrorDescription": "😭 Sajnos valami félresiklott. Ha kívánja jelezheti a bugot a fejlesztőknek.", - "@reportErrorDescription": {}, - "setPermissionsLevel": "Jogok beállítása", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Profilkép törlése", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "unsupportedAndroidVersion": "Nem támogatott Android verzió", - "@unsupportedAndroidVersion": {}, - "widgetJitsi": "Jitsi Találkozó", - "@widgetJitsi": {}, - "messageType": "Üzenet típus", - "@messageType": {}, - "indexedDbErrorLong": "Sajnos az üzenet mentés alapból nincs bekapcsolva privát módban.\nKeresse meg a\n - about:config\n - állítsa a dom.indexedDB.privateBrowsing.enabled \"true\"-ra\nMáskülönben nem lehetséges a FluffyChat futtatása.", - "@indexedDbErrorLong": {}, - "oneClientLoggedOut": "Az egyik kliense kijelentkezett", - "@oneClientLoggedOut": {}, - "toggleMuted": "Némítottak mutatása", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "startFirstChat": "Kezdje meg első csevegését", - "@startFirstChat": {}, - "callingAccount": "Hívási fiók", - "@callingAccount": {}, - "setColorTheme": "Szín téma beállítása:", - "@setColorTheme": {}, - "nextAccount": "Következő fiók", - "@nextAccount": {}, - "singlesignon": "Egyszeri bejelentkezés", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "allSpaces": "Minden tér", - "@allSpaces": {}, - "supposedMxid": "{mxid}-nek kell lennie", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "user": "Felhasználó", - "@user": {}, - "youAcceptedTheInvitation": "👍 Elfogadta a meghívást", - "@youAcceptedTheInvitation": {}, - "youInvitedBy": "📩 Meghívást kapott {user}-tól", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "banUserDescription": "A felhasználó kitiltásra kerül a csevegésből, és nem fog tudni visszajönni egészen a kitiltás feloldásáig.", - "@banUserDescription": {}, - "widgetEtherpad": "Szöveges megjegyzés", - "@widgetEtherpad": {}, - "removeDevicesDescription": "Ki fog jelentkezni a készülékről, és többi nem fog tudni fogadni üzeneteket.", - "@removeDevicesDescription": {}, - "separateChatTypes": "Csoportok és közvetlen üzenetek elkülönítése", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "tryAgain": "Próbálja újra", - "@tryAgain": {}, - "youKickedAndBanned": "🙅 Kirúgta és kitiltotta {user}-t", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "unbanUserDescription": "A felhasználó vissza tud jönni a csevegésbe ha akar.", - "@unbanUserDescription": {}, - "pleaseClickOnLink": "Kérem kattintson a linkre az emailben, és folytassa a műveletet.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "youRejectedTheInvitation": "Visszautasította a meghívást", - "@youRejectedTheInvitation": {}, - "otherCallingPermissions": "Mikrofon, kamera, és más egyéb FluffyChat engedélyek", - "@otherCallingPermissions": {}, - "messagesStyle": "Üzenetek:", - "@messagesStyle": {}, - "widgetUrlError": "Ez nem egy valós cím.", - "@widgetUrlError": {}, - "emailOrUsername": "Email vagy felhasználónév", - "@emailOrUsername": {}, - "newSpaceDescription": "A terek lehetővé teszik a csevegések konszolidációját, ezáltal létrehozva publikus vagy privát közösségeket.", - "@newSpaceDescription": {}, - "chatDescription": "Csevegés leírás", - "@chatDescription": {}, - "callingAccountDetails": "Engedélyezés a FluffyChat számára hogy használja a natív android hívás applikációt.", - "@callingAccountDetails": {}, - "pleaseFollowInstructionsOnWeb": "Kérem kövesse az instrukciókat az oldalon, és nyomjon a tovább gombra.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "enterSpace": "Belépés a térre", - "@enterSpace": {}, - "encryptThisChat": "A csevegés titkosítása", - "@encryptThisChat": {}, - "previousAccount": "Előző fiók", - "@previousAccount": {}, - "reopenChat": "Csevegés újranyitása", - "@reopenChat": {}, - "pleaseEnterRecoveryKey": "Kérem adja meg a visszaállító kódját:", - "@pleaseEnterRecoveryKey": {}, - "toggleFavorite": "Kedvencek mutatása", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "widgetNameError": "Kérem adjon meg egy megjeleníthető nevet.", - "@widgetNameError": {}, - "addToBundle": "Hozzáadás fiókcsoporthoz", - "@addToBundle": {}, - "spaceIsPublic": "A tér publikus", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "addWidget": "Widget hozzáadása", - "@addWidget": {}, - "countFiles": "{count} fájl", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "noKeyForThisMessage": "Akkor fordulhat elő, ha az üzenet az eszközre való bejelentkezés előtt került küldésre.\n\nAz is elképzelhető, hogy a küldő blokkolta az eszközét, vagy valami probléma lépett fel az internet kapcsolatban.\n\nMás helyen látja az üzenetet? Akkor át tudja másolni ide is! Menjen a Beállítások > Eszközök részbe, és győződjön meg róla, hogy az eszközei megerősítették egymást. Legközelebb amikor ezt a szobát megnyitja, és mind a két kliens az előtérben van, akkor szikronizálódni fognak.\n\nNem akarja elveszíteni a kulcsokat amikor kijelentkezik, vagy eszközt cserél? Győződjön meg róla, hogy bekapcsolta a chat mentést a beállításokban.", - "@noKeyForThisMessage": {}, - "shareLocation": "Pozíció megosztása", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "pushNotificationsNotAvailable": "Push értesítések nem elérhetőek", - "@pushNotificationsNotAvailable": {}, - "storeInAppleKeyChain": "Tárolás az Apple KeyChain-be", - "@storeInAppleKeyChain": {}, - "replaceRoomWithNewerVersion": "Szoba cserélése egy újabb verzióra", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "invalidServerName": "Hibás szerver név", - "@invalidServerName": {}, - "chatPermissions": "Csevegés engedélyek", - "@chatPermissions": {}, - "wipeChatBackup": "Le kívánja törölni a chat mentését, hogy létrehozhasson egy új visszaállítási kulcsot?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "sender": "Küldő", - "@sender": {}, - "storeInAndroidKeystore": "Tárolás az Android KeyStore-ba", - "@storeInAndroidKeystore": {}, - "signInWithPassword": "Bejelentkezés jelszóval", - "@signInWithPassword": {}, - "makeAdminDescription": "Miután a felhasználóból admin lesz, nem fogja tudni visszavonni döntését, mivel azonos jogosultsági szinttel fognak rendelkezni.", - "@makeAdminDescription": {}, - "synchronizingPleaseWait": "Szinkronizálás...kérem várjon.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Másik eszközről való átköltözés", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Push szabályok", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "saveKeyManuallyDescription": "A kulcs manuális mentése rendszer megosztás vagy vágólap másolás segítségével.", - "@saveKeyManuallyDescription": {}, - "editBundlesForAccount": "Fiókcsoportok szerkesztése ehhez a fiókhoz", - "@editBundlesForAccount": {}, - "whyIsThisMessageEncrypted": "Miért nem olvasható ez az üzenet?", - "@whyIsThisMessageEncrypted": {}, - "setChatDescription": "Csevegés leírás beállítása", - "@setChatDescription": {}, - "spaceName": "Tér neve", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "importFromZipFile": "Importálás zip fájlból", - "@importFromZipFile": {}, - "toggleUnread": "Jelölés olvasottként/olvasatlanként", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "noOtherDevicesFound": "Nem található más eszköz", - "@noOtherDevicesFound": {}, - "redactedBy": "{username} által szerkesztve", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "videoCallsBetaWarning": "Kérem vegye figyelembe, hogy a videó hívások jelenleg béta fázisban vannak. Nem biztos, hogy megfelelően fognak működni, vagy egyáltalán elindulnak egyes platformokon.", - "@videoCallsBetaWarning": {}, - "signInWith": "Bejelentkezés a következővel: {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "fileIsTooBigForServer": "A szerver számára túl nagy a fájl a küldéshez.", - "@fileIsTooBigForServer": {}, - "verified": "Visszaigazolt", - "@verified": { - "type": "text", - "placeholders": {} - }, - "callingPermissions": "Hívási engedélyek", - "@callingPermissions": {}, - "readUpToHere": "Ezidáig elolvasva", - "@readUpToHere": {}, - "start": "Kezdés", - "@start": {}, - "unlockOldMessages": "Régi üzenetek feloldása", - "@unlockOldMessages": {}, - "numChats": "{number} csevegés", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "optionalRedactReason": "(Tetszőleges) A szerkesztés oka...", - "@optionalRedactReason": {}, - "sendAsText": "Szövegként küldés", - "@sendAsText": { - "type": "text" - }, - "archiveRoomDescription": "A csevegés bekerül az archívumba. Más felhasználók látni fogják, hogy elhagyta a csevegést.", - "@archiveRoomDescription": {}, - "exportEmotePack": "Emojik exportálása zip-be", - "@exportEmotePack": {}, - "switchToAccount": "A {number} számú fiókra váltás", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "setAsCanonicalAlias": "Beállítás mint alapértelmezett álnév", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Miért kívánja ezt bejelenteni?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "experimentalVideoCalls": "Kísérleti videó hívások", - "@experimentalVideoCalls": {}, - "pleaseEnterRecoveryKeyDescription": "A régi üzenetei feloldásához adja meg a korábban generált visszaállítási jelszavát. A visszaállítási jelszó NEM UGYANAZ mint a jelszó.", - "@pleaseEnterRecoveryKeyDescription": {}, - "inviteContactToGroupQuestion": "Meg kívánja hívni {contact}-ot a \"{groupName}\" csevegő csoportba?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "{username} által szerkesztve, mivel: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Visszavonta a meghívást {user}-tól", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "appearOnTopDetails": "Engedélyezi az app számára, hogy mindig legfelül jelenjen meg (nem szükséges, ha a FluffyChat hívó fiókként lett beállítva)", - "@appearOnTopDetails": {}, - "enterRoom": "Belépés a szobába", - "@enterRoom": {}, - "pleaseChooseAPasscode": "Kérem válasszon egy kódot", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "reportUser": "Felhasználó jelentése", - "@reportUser": {}, - "confirmEventUnpin": "Biztosan végleg le akarja venni a kitűzött eseményt?", - "@confirmEventUnpin": {}, - "youInvitedUser": "📩 Meghívta {user}-t", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "fileHasBeenSavedAt": "A fájl mentésre került a következő elérési úton {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "redactMessageDescription": "A társalgásban összes résztvevője számára módosításra kerül az üzenet. Ez nem visszavonható.", - "@redactMessageDescription": {}, - "recoveryKey": "Visszaállító kulcs", - "@recoveryKey": {}, - "invalidInput": "Hibás bevitel!", - "@invalidInput": {}, - "yourPublicKey": "A publikus kulcsa", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Túl sok egyidejű kérelem. Kérem próbálja meg később!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "doNotShowAgain": "Ne mutassa újra", - "@doNotShowAgain": {}, - "report": "bejelentés", - "@report": {}, - "status": "Státusz", - "@status": { - "type": "text", - "placeholders": {} - }, - "unverified": "Nem visszaigazolt", - "@unverified": {}, - "serverRequiresEmail": "Ehhez a szerverhez szükséges az email címének visszaigazolása.", - "@serverRequiresEmail": {}, - "hideUnimportantStateEvents": "Jelentéktelen esemény státuszok elrejtése", - "@hideUnimportantStateEvents": {}, - "screenSharingTitle": "képernyő megosztás", - "@screenSharingTitle": {}, - "widgetCustom": "Egyéni", - "@widgetCustom": {}, - "addToSpaceDescription": "Válassza ki melyik térhez kívánja hozzáadni a csevegést.", - "@addToSpaceDescription": {}, - "youBannedUser": "Letitotta {user}-t", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "addChatDescription": "Chat leírás hozzáadása...", - "@addChatDescription": {}, - "hasKnocked": "🚪 {user} bekopogott", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "publish": "Közzététel", - "@publish": {}, - "openLinkInBrowser": "Hivatkozás megnyitása böngészőben", - "@openLinkInBrowser": {}, - "messageInfo": "Üzenet információ", - "@messageInfo": {}, - "disableEncryptionWarning": "Biztonsági okokból nem kapcsolható ki egy korábban bekapcsolt csevegés titkosítás.", - "@disableEncryptionWarning": {}, - "directChat": "Közvetlen csevegés", - "@directChat": {}, - "wrongPinEntered": "Hibás pinkód került beírásra. Próbálja újra {seconds} mp múlva...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "Gépelési infó megjelenítése", - "@sendTypingNotifications": {}, - "inviteGroupChat": "📨 Meghívó a csoportba", - "@inviteGroupChat": {}, - "appearOnTop": "Mindig legfelül jelenik meg", - "@appearOnTop": {}, - "invitePrivateChat": "📨 Meghívó csevegéshez", - "@invitePrivateChat": {}, - "foregroundServiceRunning": "Ez az értesítés akkor jelenik meg ha az előtéri szolgáltatás fut.", - "@foregroundServiceRunning": {}, - "voiceCall": "Hang hívás", - "@voiceCall": {}, - "importEmojis": "Emojik importálása", - "@importEmojis": {}, - "wasDirectChatDisplayName": "Üres csevegés (korábban {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noChatDescriptionYet": "Még nincs csevegő szoba leírás.", - "@noChatDescriptionYet": {}, - "removeFromBundle": "Eltávolítás a fiókcsoportból", - "@removeFromBundle": {}, - "whoCanPerformWhichAction": "Ki milyen műveletet végezhet", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "learnMore": "Tudjon meg többet", - "@learnMore": {}, - "users": "Felhasználók", - "@users": {}, - "openGallery": "Galéria megnyitása", - "@openGallery": {}, - "chatDescriptionHasBeenChanged": "Csevegés leírás megváltozott", - "@chatDescriptionHasBeenChanged": {}, - "newGroup": "Új csoport", - "@newGroup": {}, - "bundleName": "Fiókcsoport neve", - "@bundleName": {}, - "removeFromSpace": "Eltávolítás a térről", - "@removeFromSpace": {}, - "roomUpgradeDescription": "A csevegés újra elkészül az új verzióval. Minden résztvevő értesítést kap, hogy át kell állniuk az új csevegésre. További információkért a szoba verziókról látogasson el a https://spec.matrix.org/latest/rooms/ címre", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Adjon meg egy 0-nál nagyobb számot", - "@pleaseEnterANumber": {}, - "youKicked": "👞 Kirúgta {user}-t", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "profileNotFound": "A felhasználó nem található a szerveren. Lehetséges, hogy csatlakozási problémák adódtak, vagy nem létezik a felhasználó.", - "@profileNotFound": {}, - "jump": "Ugrás", - "@jump": {}, - "reactedWith": "{sender} a következőt reagálta: {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "sorryThatsNotPossible": "Ez sajnos nem lehetséges", - "@sorryThatsNotPossible": {}, - "videoWithSize": "Videó ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "shareInviteLink": "Meghívó link megosztása", - "@shareInviteLink": {}, - "commandHint_markasdm": "Szoba megjelölése mint közvetlen csevegő szoba az adott Matrix ID-nél", - "@commandHint_markasdm": {}, - "recoveryKeyLost": "Elveszett visszaállító kulcs?", - "@recoveryKeyLost": {}, - "deviceKeys": "Eszköz kulcsok:", - "@deviceKeys": {}, - "emoteKeyboardNoRecents": "Nemrég használt emojik fognak itt megjelenni...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Egyéni emojik beállítása", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Téma beállítása:", - "@setTheme": {}, - "youJoinedTheChat": "Becsatlakozott a csevegésbe", - "@youJoinedTheChat": {}, - "markAsRead": "Olvasottként megjelölés", - "@markAsRead": {}, - "widgetName": "Név", - "@widgetName": {}, - "errorAddingWidget": "Hiba lépett fel a widget hozzáadásánál.", - "@errorAddingWidget": {}, - "replace": "Kicserél", - "@replace": {}, - "youUnbannedUser": "Levette a letiltást {user}-ről", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "newSpace": "Új tér", - "@newSpace": {}, - "emojis": "Emojik", - "@emojis": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Próbálja meg máskor, vagy válasszon másik szervert.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Csoport létrehozása", - "@createGroup": {}, - "hydrateTorLong": "Legutóbb TOR segítségével exportálta korábbi munkamenetét? Gyorsan importálja őket vissza, és folytassa a csevegést.", - "@hydrateTorLong": {}, - "time": "Idő", - "@time": {}, - "custom": "Egyéni", - "@custom": {}, - "noBackupWarning": "Figyelem! Ha nem kapcsolja be a csevegés mentést, elveszíti a hozzáférést a tikosított üzeneteihez. Erősen ajánlott a csevegés mentés bekapcsolása kijelentkezés előtt.", - "@noBackupWarning": {}, - "storeInSecureStorageDescription": "Tárolja a visszaállítási kulcsot az eszköz biztonsági tárjában.", - "@storeInSecureStorageDescription": {}, - "openChat": "Csevegés megnyitása", - "@openChat": {}, - "kickUserDescription": "A felhasználó kirúgásra került a csevegésből, de nincs kitiltva. Publikus csevegés esetén a felhasználó bármikor visszatérhet.", - "@kickUserDescription": {}, - "importNow": "Importálás most", - "@importNow": {}, - "pinMessage": "Kitűzés a szobában", - "@pinMessage": {}, - "invite": "Meghívás", - "@invite": {}, - "enableMultiAccounts": "(BÉTA) Több fiók bekapcsolása az eszközön", - "@enableMultiAccounts": {}, - "indexedDbErrorTitle": "Privát mód problémák", - "@indexedDbErrorTitle": {}, - "unsupportedAndroidVersionLong": "Ehhez a funkcióhoz egy újabb Android verzió kell. Kérem ellenőrizze be van e frissítve teljesen készüléke, esetlegesen van e LineageOS támogatás hozzá.", - "@unsupportedAndroidVersionLong": {}, - "storeSecurlyOnThisDevice": "Biztonságos tárolás az eszközön", - "@storeSecurlyOnThisDevice": {}, - "screenSharingDetail": "Megosztja a képernyőjét a FluffyChat-ben", - "@screenSharingDetail": {}, - "placeCall": "Tér hívás", - "@placeCall": {}, - "block": "Blokkolás", - "@block": {}, - "blockedUsers": "Blokkolt felhasználók", - "@blockedUsers": {}, - "blockListDescription": "Az Önt zavaró felhasználókat blokkolhatja. A blokkolt listán található felhasználóktól nem tud fogadni üzenetet vagy szoba meghívást.", - "@blockListDescription": {}, - "blockUsername": "Felhasználónév mellőzése", - "@blockUsername": {}, - "presenceStyle": "Jelenlét:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Mások státusz üzenetének megjelenítése", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "youInvitedToBy": "📩 Meghívást kapott linken keresztül a következőhöz:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "decline": "Elutasítás", - "@decline": {}, - "yourGlobalUserIdIs": "A globális felhasználó-ID-je: ", - "@yourGlobalUserIdIs": {}, - "noUsersFoundWithQuery": "\"{query}\" néven nem található felhasználó. Ellenőrizze nincs e elírás.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "acceptedKeyVerification": "{sender} elfogadta a kulcs megerősítést", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "searchForUsers": "Keressen @felhasználókat...", - "@searchForUsers": {}, - "joinSpace": "Csatlakozás a térre", - "@joinSpace": {}, - "publicSpaces": "Nyilvános terek", - "@publicSpaces": {}, - "databaseMigrationTitle": "Adatbázis optimalizálása", - "@databaseMigrationTitle": {}, - "leaveEmptyToClearStatus": "Hagyja üresen a státusz kitörléséhez.", - "@leaveEmptyToClearStatus": {}, - "pleaseEnterYourCurrentPassword": "Kérem adja meg jelenlegi jelszavát", - "@pleaseEnterYourCurrentPassword": {}, - "newPassword": "Új jelszó", - "@newPassword": {}, - "addChatOrSubSpace": "Csevegés vagy al-tér hozzáadása", - "@addChatOrSubSpace": {}, - "pleaseChooseAStrongPassword": "Kérem válasszon egy erős jelszót", - "@pleaseChooseAStrongPassword": {}, - "passwordsDoNotMatch": "A jelszavak nem egyeznek", - "@passwordsDoNotMatch": {}, - "passwordIsWrong": "A beírt jelszava hibás", - "@passwordIsWrong": {}, - "subspace": "Al-tér", - "@subspace": {}, - "thisDevice": "Ez az eszköz:", - "@thisDevice": {}, - "forwardMessageTo": "Üzenet továbbítása a {roomName} szobába?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendTypingNotificationsDescription": "A csevegés többi tagja látja amikor gépel.", - "@sendTypingNotificationsDescription": {}, - "sendReadReceiptsDescription": "A csevegés többi tagja látja melyik üzenetet látta.", - "@sendReadReceiptsDescription": {}, - "sendReadReceipts": "Olvasási igazolás küldése", - "@sendReadReceipts": {}, - "formattedMessages": "Formázott üzenetek", - "@formattedMessages": {}, - "formattedMessagesDescription": "Formázott szöveg - mint például félkövér - megjelenítése \"markdown\"-al.", - "@formattedMessagesDescription": {}, - "verifyOtherUser": "🔐 Más felhasználók igazolása", - "@verifyOtherUser": {}, - "verifyOtherDevice": "🔐 Más eszköz megerősítése", - "@verifyOtherDevice": {}, - "sessionLostBody": "A munkamenete elvesződött. Kérem jelentse ezt a fejlesztőknek a {url} címen. A hiba szövege a következő: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "databaseBuildErrorBody": "Nem lehetséges az SQlite adatbázis létrehozása. Az app megpróbálja a régi típusú adatbázist használni. Kérem jelentse a hibát a fejlesztőknek a {url} linken. A hiba szövege a következő: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "Megpróbálkozunk visszaállítani a munkamenetét egy korábbi mentésből. Kérem jelezze a hibát a fejlesztőknek a {url} címen. A hiba szövege a következő: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "hidePresences": "El kívánja menteni a státusz listát?", - "@hidePresences": {}, - "searchChatsRooms": "Keressen #csevegéseket, @felhasználókat...", - "@searchChatsRooms": {}, - "wrongRecoveryKey": "Sajnos, úgy tűnik hibásan adta meg a visszaállítási kulcsot.", - "@wrongRecoveryKey": {}, - "startConversation": "Beszélgetés indítása", - "@startConversation": {}, - "commandHint_sendraw": "Tiszta json küldése", - "@commandHint_sendraw": {}, - "databaseMigrationBody": "Kérem várjon. Ez igénybe vehet valamennyi időt.", - "@databaseMigrationBody": {}, - "initAppError": "Hiba lépett fel az app indítása során", - "@initAppError": {}, - "canceledKeyVerification": "{sender} nem fogadta el a kulcs megerősítést", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} befejezte a kulcs megerősítést", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} készen áll a kulcs megerősítésre", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} kulcs megerősítést kér", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} elkezdte a kulcs megerősítést", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "Átlátszó", - "@transparent": {}, - "incomingMessages": "Bejövő üzenetek", - "@incomingMessages": {}, - "nothingFound": "Nincs találat...", - "@nothingFound": {}, - "publicLink": "Nyilvános hivatkozás", - "@publicLink": {}, - "select": "Kiválaszt", - "@select": {}, - "stickers": "Matrica", - "@stickers": {}, - "discover": "Felfedezés", - "@discover": {}, - "groupName": "Csoport név", - "@groupName": {}, - "createGroupAndInviteUsers": "Hozzon létre egy csoportot és hívjon meg felhasználókat", - "@createGroupAndInviteUsers": {}, - "groupCanBeFoundViaSearch": "Kereséssel megtalálhatja a kívánt csoportot", - "@groupCanBeFoundViaSearch": {}, - "verifyOtherUserDescription": "Ha megerősít egy másik felhasználót, akkor teljesen biztos lehet abban kivel cseveg. 💪\n\nA megerősítési folyamat kezdetekor megjelenik egy felugró ablak mindkettejüknél. Ekkor egy emoji vagy szám sor összehasonlítási folyamat veszi kezdetét.\n\nA legpraktikusabb módja ennek, hogy találkozzanak, vagy videó hívás során beszéljék meg. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "Amikor egy másik eszközt erősít meg, az eszközök kulcsokat cserélnek egymás között, ezáltal növelve az összbiztonságot. 💪 Amikor megkezdődik a folyamat, mind a két eszközön megjelenik egy felugró üzenet. Emojik és számok sorozata fog megjelenni, amit össze tud hasonlítani a két eszközön. Érdemes tehát mind a két eszközt a közelben tartani. 🤳", - "@verifyOtherDeviceDescription": {}, - "accessAndVisibility": "Hozzáférés és láthatóság", - "@accessAndVisibility": {}, - "accessAndVisibilityDescription": "Kinek engedélyezett a csevegéshez való csatlakozás és a csevegést hogyan lehet megtalálni.", - "@accessAndVisibilityDescription": {}, - "calls": "Hívások", - "@calls": {}, - "hideInvalidOrUnknownMessageFormats": "Érvénytelen vagy ismeretlen üzenetformátum elrejtése", - "@hideInvalidOrUnknownMessageFormats": {}, - "hideMemberChangesInPublicChatsBody": "Ne mutassa ha valaki be- vagy kilép a csevegésből az olvashatóság javítása végett.", - "@hideMemberChangesInPublicChatsBody": {}, - "notifyMeFor": "Értesítsen engem", - "@notifyMeFor": {}, - "passwordRecoverySettings": "Jelszó-helyreállítási beállítások", - "@passwordRecoverySettings": {}, - "noOneCanJoin": "Senki sem csatlakozhat", - "@noOneCanJoin": {}, - "userWouldLikeToChangeTheChat": "{user} szeretne csatlakozni a csevegéshez.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "Még nem lett létrehozva nyilvános link", - "@noPublicLinkHasBeenCreatedYet": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Csevegés felfedezhető a {server} szerveren történő kereséssel", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "appLockDescription": "Alkalmazás zárolása PIN-kód használat hiányában", - "@appLockDescription": {}, - "customEmojisAndStickers": "Egyedi emotikonok és matricák", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Egyedi emotikonok és matricák létrehozása, amelyek bármely csevegésben használhatóak.", - "@customEmojisAndStickersBody": {}, - "overview": "Áttekintés", - "@overview": {}, - "publicChatAddresses": "Nyilvános csevegés címek", - "@publicChatAddresses": {}, - "userRole": "Felhasználói szerep", - "@userRole": {}, - "createNewAddress": "Új cím létrehozása", - "@createNewAddress": {}, - "noDatabaseEncryption": "Adatbázis titkosítása nem támogatott ezen a platformon", - "@noDatabaseEncryption": {}, - "thereAreCountUsersBlocked": "Jelenleg {count} felhasználó van letiltva.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "unreadChatsInApp": "{appname}: {unread} olvasatlan csevegések", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "searchIn": "Keresés a csevegésben \"{chat}\"...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "files": "Fájlok", - "@files": {}, - "commandHint_unignore": "Adott matrix ID figyelembe vétele", - "@commandHint_unignore": {}, - "restricted": "Korlátozott", - "@restricted": {}, - "knockRestricted": "Kopogás korlátozva", - "@knockRestricted": {}, - "globalChatId": "Globális csevegő azonosító", - "@globalChatId": {}, - "hideRedactedMessages": "Szerkesztett üzenetek elrejtése", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "Ha valaki szerkeszti az üzenetét, ez az üzenet nem jelenik meg a csevegés során.", - "@hideRedactedMessagesBody": {}, - "hideMemberChangesInPublicChats": "Tag változások elrejtése a publikus csevegésben", - "@hideMemberChangesInPublicChats": {}, - "knocking": "Bekopogás", - "@knocking": {}, - "usersMustKnock": "A felhasználóknak be kell kopogniuk", - "@usersMustKnock": {}, - "knock": "Kopogás", - "@knock": {}, - "minimumPowerLevel": "{level} a minimum szint.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "searchMore": "További keresés...", - "@searchMore": {}, - "gallery": "Galéria", - "@gallery": {}, - "commandHint_ignore": "Adott matrix ID figyelmen kívül hagyása", - "@commandHint_ignore": {} -} diff --git a/assets/l10n/intl_id.arb b/assets/l10n/intl_id.arb deleted file mode 100644 index 34f821c5e..000000000 --- a/assets/l10n/intl_id.arb +++ /dev/null @@ -1,2692 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:10.002360", - "setAsCanonicalAlias": "Atur sebagai alias utama", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Versi ruangan", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "people": "Orang-orang", - "@people": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Pergi ke ruangan yang baru", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "chats": "Obrolan", - "@chats": { - "type": "text", - "placeholders": {} - }, - "blockDevice": "Blokir Perangkat", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Apakah kamu yakin ingin keluar?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Apakah kamu yakin?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "archive": "Arsip", - "@archive": { - "type": "text", - "placeholders": {} - }, - "anyoneCanJoin": "Siapa saja dapat bergabung", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} menjawab panggilan", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "account": "Akun", - "@account": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} menerima undangannya", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "accept": "Terima", - "@accept": { - "type": "text", - "placeholders": {} - }, - "about": "Tentang", - "@about": { - "type": "text", - "placeholders": {} - }, - "isTyping": "sedang mengetik…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} mengundang kamu ke FluffyChat. \n1. Kunjungi fluffychat.im dan instal aplikasi\n2. Daftar atau masuk \n3. Buka tautan undangan: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "inviteForMe": "Undangan untuk saya", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "invitedUsersOnly": "Pengguna yang diundang saja", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} mengundang {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invited": "Diundang", - "@invited": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Undang kontak ke {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "inviteContact": "Undang kontak", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Frasa sandi atau kunci pemulihan yang salah", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Saya sudah klik tautannya", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Pengguna yang diabaikan", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "identity": "Identitas", - "@identity": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Sembunyikan peristiwa tidak dikenal", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Sembunyikan peristiwa yang dihapus", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "help": "Bantuan", - "@help": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} telah mencabut undangan untuk {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "guestsCanJoin": "Tamu bisa bergabung", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "guestsAreForbidden": "Tamu dilarang", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grup dengan {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "groupIsPublic": "Grup bersifat publik", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "group": "Grup", - "@group": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Dari undangan", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Dari bergabung", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "forward": "Teruskan", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nama file", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Semua siap!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Masukkan homeserver-mu", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "enterAnEmailAddress": "Masukkan alamat email", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} mengakhiri panggilan", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "encryption": "Enkripsi", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Terenkripsi", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Kamu tidak akan bisa menonaktifkan enkripsi. Apakah kamu yakin?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Aktifkan paket emote secara global", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Chat kosong", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Kamu harus memilih shortcode emote dan gambar!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Shortcode emote", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Pengaturan Emote", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Paket emote untuk ruangan", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Shortcode emote tidak valid!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emote sudah ada!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Edit alias ruangan", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Edit nama tampilan", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "edit": "Edit", - "@edit": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Unduh berkas", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Nama tampilan telah diubah", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "directChats": "Chat Langsung", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "devices": "Perangkat", - "@devices": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID Perangkat", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "device": "Perangkat", - "@device": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Hapus pesan", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Hapus akun", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "delete": "Hapus", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deactivateAccountWarning": "Ini akan menonaktifkan akun penggunamu. Ini tidak bisa dibatalkan! Apakah kamu yakin?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateAndTimeOfDay": "{timeOfDay}, {date}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "currentlyActive": "Aktif", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} membuat obrolan ini", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "create": "Buat", - "@create": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} anggota", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "couldNotDecryptMessage": "Tidak dapat mendekripsikan pesan: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "copyToClipboard": "Salin ke papan klip", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Salin", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Disalin ke papan klip", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Cadangan obrolan", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chat": "Obrolan", - "@chat": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Enkripsi telah rusak", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Ubah avatarmu", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Ubah nama grup", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Ubah homeserver", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changePassword": "Ubah kata sandi", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changedTheRoomInvitationLink": "{username} mengubah tautan undangan", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} mengubah alias ruangan", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheProfileAvatar": "{username} mengubah avatarnya", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} mengubah aturan bergabung ke: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheJoinRules": "{username} mengubah aturan bergabung", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} mengubah visibilitas sejarah ke: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} mengubah visibilitas sejarah", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} mengubah aturan akses tamu ke: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheGuestAccessRules": "{username} mengubah aturan akses tamu", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} mengubah nama tampilan ke: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheChatPermissions": "{username} mengubah izin obrolan", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatNameTo": "{username} mengubah nama obrolan ke: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatDescriptionTo": "{username} mengubah deskripsi obrolan ke: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatAvatar": "{username} mengubah avatar obrolan", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeDeviceName": "Ganti nama perangkat", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Tidak bisa membuka URI ini {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "cancel": "Batal", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Pesan bot", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "blocked": "Diblokir", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} mencekal {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "banned": "Dicekal", - "@banned": { - "type": "text", - "placeholders": {} - }, - "banFromChat": "Cekal dari obrolan", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "Homeserver ini mendukung versi Spec ini:\n{serverVersions}\nTetapi aplikasi ini hanya mendukung {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "sendOnEnter": "Kirim dengan enter", - "@sendOnEnter": {}, - "badServerLoginTypesException": "Homeserver ini mendukung tipe masuk ini:\n{serverVersions}\nTetapi aplikasi ini mendukung:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "autoplayImages": "Mainkan stiker beranimasi dan emote secara otomatis", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "askVerificationRequest": "Terima permintaan verifikasi dari {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "askSSSSSign": "Untuk dapat menandatangani orang lain, silakan masukkan frasa sandi atau kunci pemulihan penyimpanan aman kamu.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Apakah pengguna tamu diizinkan untuk bergabung", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Kunci aplikasi", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "allChats": "Semua obrolan", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "all": "Semua", - "@all": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Tambah ke space", - "@addToSpace": {}, - "addEmail": "Tambah email", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Enkripsi tidak diaktifkan", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Berisi nama pengguna", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Berisi nama tampilan", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontak telah diundang ke grup", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "connect": "Hubungkan", - "@connect": { - "type": "text", - "placeholders": {} - }, - "confirm": "Konfirmasi", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Bandingkan angka", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Bandingkan emoji", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "close": "Tutup", - "@close": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Bersihkan arsip", - "@clearArchive": {}, - "chooseAStrongPassword": "Pilih kata sandi yang kuat", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Detail obrolan", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Pesan lamamu diamankan dengan sebuah kunci pemulihan. Pastikan kamu tidak menghilangkannya.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} mengaktifkan enkripsi ujung ke ujung", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "loadingPleaseWait": "Memuat… Mohon tunggu.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Muat {count} anggota", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "license": "Lisensi", - "@license": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Keluar dari obrolan", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "leave": "Tinggalkan", - "@leave": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Terakhir aktif: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "kickFromChat": "Keluarkan dari obrolan", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "kickedAndBanned": "🙅 {username} mengeluarkan dan mencekal {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kicked": "👞 {username} mengeluarkan {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "joinRoom": "Bergabung dengan ruangan", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} telah bergabung dengan obrolan", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "loadMore": "Muat lebih banyak…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Tidak ada izin", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Kamu belum menambahkan cara untuk memulihkan kata sandimu.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "none": "Tidak Ada", - "@none": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Perpesanan Awan Firebase sepertinya tidak tersedia di perangkatmu. Untuk dapat menerima notifikasi dorongan, kami menyarankan memasang ntfy. Dengan ntfy atau penyedia UnifiedPush lainnya, kamu bisa menerima notifikasi dorongan dengan cara yang aman. Kamu bisa mengunduh ntfy dari Play Store atau F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Kamu hanya bisa mengaktifkan enkripsi setelah ruangan tidak lagi dapat diakses secara publik.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Tidak ada emote yang ditemukan. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "next": "Lanjut", - "@next": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Permintaan verifikasi baru!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Pesan baru di FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newChat": "Chat baru", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Perlu diketahui bahwa kamu memerlukan Pantalaimon untuk menggunakan enkripsi ujung-ke-ujung untuk saat ini.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Bisukan obrolan", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "mention": "Sebutkan", - "@mention": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Perubahan anggota", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "logout": "Keluar", - "@logout": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Masuk ke {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "login": "Masuk", - "@login": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Tidak ada ruangan yang ditemukan…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "verified": "Terverifikasi", - "@verified": { - "type": "text", - "placeholders": {} - }, - "userLeftTheChat": "🚪 {username} keluar dari obrolan", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "unavailable": "Tidak tersedia", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Transfer dari perangkat lain", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Tampilkan kata sandi", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Hapus avatarmu", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "register": "Daftar", - "@register": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Aturan push", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Mohon ikuti petunjuk di situs web dan tekan lanjut.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Mohon pilih", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Ups! Sayangnya, terjadi kesalahan saat mengatur pemberitahuan push.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Cadangan Kunci Online dinyalakan", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "online": "Online", - "@online": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "offline": "Offline", - "@offline": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Notifikasi diaktifkan untuk akun ini", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notifikasi", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Kunci publikmu", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Kamu telah dicekal dari obrolan ini", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Kamu tidak berpartisipasi lagi di obrolan ini", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "you": "Kamu", - "@you": { - "type": "text", - "placeholders": {} - }, - "yes": "Ya", - "@yes": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Tulis pesan…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Dengan alamat ini kamu bisa memulihkan kata sandimu.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Hapus cadangan obrolan untuk membuat kunci pemulihan baru?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Kenapa kamu ingin melaporkannya?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Siapa yang dapat bergabung ke grup ini", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Siapa yang dapat melakukan tindakan apa", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Kami mengirim kamu sebuah email", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "warning": "Peringatan!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Latar belakang:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Menunggu pengguna untuk menerima angka…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Menunggu pengguna untuk menerima emoji…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Menunggu pengguna untuk menerima permintaan…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Pesan suara", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Terlihat untuk semua orang", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Terlihat untuk semua anggota", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Visibilitas sejarah obrolan", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Panggilan video", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Memverifikasi akun lain", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Kamu berhasil memverifikasi!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Mulai Verifikasi", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verify": "Verifikasi", - "@verify": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} mengirim peristiwa {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "username": "Nama Pengguna", - "@username": { - "type": "text", - "placeholders": {} - }, - "userIsTyping": "{username} sedang mengetik…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userAndUserAreTyping": "{username} dan {username2} sedang mengetik…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userAndOthersAreTyping": "{username} dan {count} lainnya sedang mengetik…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "unreadChats": "{unreadCount, plural, =1{1 obrolan belum dibaca} other{{unreadCount} obrolan belum dibaca}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "unpin": "Lepaskan pin", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unmuteChat": "Bunyikan obrolan", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Peristiwa tidak dikenal '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unknownEncryptionAlgorithm": "Algoritma enkripsi tidak dikenal", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Perangkat tidak dikenal", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unblockDevice": "Hilangkan Pemblokiran Perangkat", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} menghilangkan cekalan {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "tryToSendAgain": "Coba kirim lagi", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Terlalu banyak permintaan. Coba lagi nanti!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Tandai Baca/Belum Dibaca", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Beralih Bisuan", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Beralih Favorit", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "theyMatch": "Cocok", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Tidak Cocok", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistem", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Menyinkronkan... Mohon tunggu.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "submit": "Kirim", - "@submit": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Apa kabar hari ini?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} memulai panggilan", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "spaceName": "Nama space", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Space publik", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Kode sumber", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "skip": "Lewat", - "@skip": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Login Masuk Tunggal", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Bagikan lokasi", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} membagikan lokasinya", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "share": "Bagikan", - "@share": { - "type": "text", - "placeholders": {} - }, - "settings": "Pengaturan", - "@settings": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Tetapkan status", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Tetapkan level izin", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Tetapkan tautan undangan", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Tetapkan emote kustom", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "sentCallInformations": "{senderName} mengirim informasi panggilan", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "sentAVideo": "🎥 {username} mengirim video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} mengirim stiker", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} mengirim gambar", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} mengirim suara", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAFile": "📁 {username} mengirim file", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "seenByUser": "Dilihat oleh {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "security": "Keamanan", - "@security": { - "type": "text", - "placeholders": {} - }, - "search": "Cari", - "@search": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Minta izin", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Laporkan pesan", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "reply": "Balas", - "@reply": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Menggantikan ruangan dengan versi baru", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Render konten pesan kaya", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Hilangkan cekalan dari obrolan", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "remove": "Hapus", - "@remove": { - "type": "text", - "placeholders": {} - }, - "rejoin": "Gabung kembali", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} menolak undangannya", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Tolak", - "@reject": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Hapus pesan", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} menghapus sebuah peristiwa", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "pleaseEnterYourPassword": "Mohon masukkan kata sandimu", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Mohon klik tautan di email dan lanjut.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Mohon pilih kode sandi", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "play": "Mainkan {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pin": "Pin", - "@pin": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Pemulihan kata sandi", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Kata sandi telah diubah", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Lupa kata sandi", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "password": "Kata sandi", - "@password": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "frasa sandi atau kunci pemulihan", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "participant": "Peserta", - "@participant": { - "type": "text", - "placeholders": {} - }, - "or": "Atau", - "@or": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "Server ini harus memvalidasi alamat email kamu untuk registrasi.", - "@serverRequiresEmail": {}, - "openInMaps": "Buka di peta", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "enableMultiAccounts": "(BETA) Aktifkan multi-akun di perangkat ini", - "@enableMultiAccounts": {}, - "bundleName": "Nama bundel", - "@bundleName": {}, - "removeFromBundle": "Hilangkan dari bundel ini", - "@removeFromBundle": {}, - "addToBundle": "Tambah ke bundel", - "@addToBundle": {}, - "editBundlesForAccount": "Edit bundel untuk akun ini", - "@editBundlesForAccount": {}, - "addAccount": "Tambah akun", - "@addAccount": {}, - "oneClientLoggedOut": "Salah satu klienmu telah keluar", - "@oneClientLoggedOut": {}, - "openCamera": "Buka kamera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Buka aplikasi untuk membaca pesan", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Ups, ada yang salah…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "offensive": "Menyinggung", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Mendapatkan lokasi…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} pengguna sedang mengetik…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "scanQrCode": "Pindai kode QR", - "@scanQrCode": {}, - "noMatrixServer": "{server1} itu bukan server Matrix, gunakan {server2} saja?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "no": "Tidak", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Tidak ada koneksi ke server", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "messages": "Pesan", - "@messages": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Layanan lokasi dinonaktifkan. Mohon diaktifkan untuk bisa membagikan lokasimu.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Izin lokasi ditolak. Mohon memberikan izin untuk bisa membagikan lokasimu.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Terang", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Tidak menyinggung", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "ignore": "Abaikan", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Seberapa menyinggungnya konten ini?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "groups": "Grup", - "@groups": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Ukuran font", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Gagal mendapat lokasi: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "homeserver": "Homeserver", - "@homeserver": {}, - "enableEncryption": "Aktifkan enkripsi", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Edit avatar ruangan", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Edit server yang diblokir", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Level izin default", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Gelap", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Space baru", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Konten telah dilaporkan ke admin server", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Konfigurasi obrolan", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "commandMissing": "{command} bukan sebuah perintah.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "commandInvalid": "Perintah tidak valid", - "@commandInvalid": { - "type": "text" - }, - "commandHint_unban": "Hilangkan cekalan untuk pengguna yang dicantumkan dari ruangan ini", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandHint_send": "Kirim teks", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_react": "Kirim balasan sebagai reaksi", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_plain": "Kirim teks yang tidak diformat", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_op": "Tetapkan tingkat kekuatan pengguna yang dicantum (default: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_myroomnick": "Tetapkan nama tampilanmu untuk ruangan ini", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_myroomavatar": "Tetapkan gambarmu untuk ruangan ini (oleh uri-mxc)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_me": "Jelaskan dirimu", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_leave": "Tinggalkan ruangan ini", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_kick": "Keluarkan pengguna yang dicantum dari ruangan ini", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_join": "Gabung ke ruangan yang dicantum", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_invite": "Undang pengguna yang dicantum ke ruangan ini", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_html": "Kirim teks yang diformat dengan HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_ban": "Cekal pengguna yang dicantumkan dari ruangan ini", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "chatHasBeenAddedToThisSpace": "Obrolan telah ditambahkan ke space ini", - "@chatHasBeenAddedToThisSpace": {}, - "changeTheme": "Ubah tema", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Sangat menyinggung", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Kirim video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Kirim stiker", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Kirim yang asli", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Kirim pesan", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Kirim gambar", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Kirim file", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Kirim suara", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Kirim sebagai teks", - "@sendAsText": { - "type": "text" - }, - "sendAMessage": "Kirim pesan", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "send": "Kirim", - "@send": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Simpan file", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Ruangan telah ditingkatkan", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "removeDevice": "Hapus perangkat", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Dihapus oleh {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeAllOtherDevices": "Hapus semua perangkat lain", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "recording": "Merekam", - "@recording": { - "type": "text", - "placeholders": {} - }, - "reason": "Alasan", - "@reason": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Ruangan Publik", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privasi", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Mohon masukkan nama penggunamu", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Mohon masukkan 4 digit atau tinggalkan kosong untuk menonaktifkan kunci aplikasi.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Masukkan pin", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Pilih gambar", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "link": "Tautan", - "@link": {}, - "yourChatBackupHasBeenSetUp": "Cadangan obrolanmu telah disiapkan.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "Tidak terverifikasi", - "@unverified": {}, - "repeatPassword": "Ulangi kata sandi", - "@repeatPassword": {}, - "messageInfo": "Informasi pesan", - "@messageInfo": {}, - "time": "Waktu", - "@time": {}, - "messageType": "Tipe Pesan", - "@messageType": {}, - "sender": "Pengirim", - "@sender": {}, - "openGallery": "Buka galeri", - "@openGallery": {}, - "addToSpaceDescription": "Pilih sebuah space untuk menambahkan obrolan ke spacenya.", - "@addToSpaceDescription": {}, - "start": "Mulai", - "@start": {}, - "removeFromSpace": "Hilangkan dari space", - "@removeFromSpace": {}, - "commandHint_clearcache": "Bersihkan tembolok", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_discardsession": "Buang sesi", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Mulai sebuah obrolan langsung\nGunakan --no-encryption untuk menonaktifkan enkripsi", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_create": "Buat sebuah grup obrolan kosong\nGunakan --no-encryption untuk menonaktifkan enkripsi", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "openVideoCamera": "Buka kamera untuk merekam video", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "publish": "Publikasi", - "@publish": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "dismiss": "Abaikan", - "@dismiss": {}, - "markAsRead": "Tandai sebagai dibaca", - "@markAsRead": {}, - "reportUser": "Laporkan pengguna", - "@reportUser": {}, - "openChat": "Buka Chat", - "@openChat": {}, - "reactedWith": "{sender} bereaksi dengan {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "emojis": "Emoji", - "@emojis": {}, - "pinMessage": "Sematkan ke ruangan", - "@pinMessage": {}, - "confirmEventUnpin": "Apakah kamu yakin untuk melepaskan pin peristiwa ini secara permanen?", - "@confirmEventUnpin": {}, - "unsupportedAndroidVersionLong": "Fitur ini memerlukan versi Android yang baru. Mohon periksa untuk pembaruan atau dukungan LineageOS.", - "@unsupportedAndroidVersionLong": {}, - "unsupportedAndroidVersion": "Versi Android tidak didukung", - "@unsupportedAndroidVersion": {}, - "placeCall": "Lakukan panggilan", - "@placeCall": {}, - "voiceCall": "Panggilan suara", - "@voiceCall": {}, - "videoCallsBetaWarning": "Dicatat bahwa panggilan video sedang dalam beta. Fitur ini mungkin tidak berkerja dengan benar atau tidak berkerja sama sekali pada semua platform.", - "@videoCallsBetaWarning": {}, - "emailOrUsername": "Email atau nama pengguna", - "@emailOrUsername": {}, - "experimentalVideoCalls": "Panggilan video eksperimental", - "@experimentalVideoCalls": {}, - "previousAccount": "Akun sebelumnya", - "@previousAccount": {}, - "switchToAccount": "Ganti ke akun {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Akun berikutnya", - "@nextAccount": {}, - "widgetEtherpad": "Catatan teks", - "@widgetEtherpad": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Kustom", - "@widgetCustom": {}, - "errorAddingWidget": "Terjadi kesalahan menambahkan widget.", - "@errorAddingWidget": {}, - "widgetName": "Nama", - "@widgetName": {}, - "addWidget": "Tambahkan widget", - "@addWidget": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetUrlError": "Ini bukan URL yang valid.", - "@widgetUrlError": {}, - "widgetNameError": "Mohon sediakan sebuah nama tampilan.", - "@widgetNameError": {}, - "separateChatTypes": "Pisahkan Pesan Langsung dan Grup", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youInvitedBy": "📩 Kamu telah diundang oleh {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Kamu mengundang {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 Kamu mengeluarkan {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Kamu mengeluarkan dan mencekal {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youRejectedTheInvitation": "Kamu menolak undangannya", - "@youRejectedTheInvitation": {}, - "youJoinedTheChat": "Kamu bergabung ke obrolan", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Kamu menerima undangannya", - "@youAcceptedTheInvitation": {}, - "youBannedUser": "Kamu mencekal {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Kamu telah membatalkan undangan untuk {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Kamu membatalkan cekalan {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "pleaseEnterRecoveryKeyDescription": "Untuk mengakses pesan lamamu, mohon masukkan kunci pemulihanmu yang telah dibuat di sesi sebelumnya. Kunci pemulihanmu BUKAN kata sandimu.", - "@pleaseEnterRecoveryKeyDescription": {}, - "users": "Pengguna", - "@users": {}, - "storeInSecureStorageDescription": "Simpan kunci pemulihan di penyimpanan aman perangkat ini.", - "@storeInSecureStorageDescription": {}, - "saveKeyManuallyDescription": "Simpan kunci ini secara manual dengan memicu dialog pembagian atau papan klip sistem.", - "@saveKeyManuallyDescription": {}, - "recoveryKey": "Kunci pemulihan", - "@recoveryKey": {}, - "storeInAppleKeyChain": "Simpan di Apple KeyChain", - "@storeInAppleKeyChain": {}, - "pleaseEnterRecoveryKey": "Mohon masukkan kunci pemulihanmu:", - "@pleaseEnterRecoveryKey": {}, - "unlockOldMessages": "Akses pesan lama", - "@unlockOldMessages": {}, - "recoveryKeyLost": "Kunci pemulihan hilang?", - "@recoveryKeyLost": {}, - "storeInAndroidKeystore": "Simpan di Android KeyStore", - "@storeInAndroidKeystore": {}, - "storeSecurlyOnThisDevice": "Simpan secara aman di perangkat ini", - "@storeSecurlyOnThisDevice": {}, - "countFiles": "{count} file", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "hydrate": "Pulihkan dari file cadangan", - "@hydrate": {}, - "indexedDbErrorTitle": "Masalah dengan mode privat", - "@indexedDbErrorTitle": {}, - "indexedDbErrorLong": "Penyimpanan pesan sayangnya tidak diaktifkan dalam mode privat secara default.\nMohon kunjungi\n- about:config\n- tetapkan dom.indexedDB.privateBrowsing.enabled ke true\nJika tidak ditetapkan, FluffyChat tidak akan dapat dijalankan.", - "@indexedDbErrorLong": {}, - "dehydrate": "Ekspor sesi dan bersihkan perangkat", - "@dehydrate": {}, - "dehydrateWarning": "Tindakan ini tidak dapat diurungkan. Pastikan kamu telah menyimpan file cadangan dengan aman.", - "@dehydrateWarning": {}, - "dehydrateTor": "Pengguna Tor: Ekspor sesi", - "@dehydrateTor": {}, - "hydrateTorLong": "Apakah kamu mengekspor sesimu terakhir kali di Tor? Impor dengan cepat dan lanjut mengobrol.", - "@hydrateTorLong": {}, - "dehydrateTorLong": "Pengguna Tor disarankan untuk mengekspor sesi sebelum menutup jendela.", - "@dehydrateTorLong": {}, - "hydrateTor": "Pengguna Tor: Impor eksporan sesi", - "@hydrateTor": {}, - "custom": "Kustom", - "@custom": {}, - "user": "Pengguna", - "@user": {}, - "confirmMatrixId": "Mohon konfirmasi ID Matrix Anda untuk menghapus akun Anda.", - "@confirmMatrixId": {}, - "supposedMxid": "Ini seharusnya {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasdm": "Tandai sebagai ruangan pesan langsung untuk ID Matrix yang ditentukan", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "Tandai sebagai grup", - "@commandHint_markasgroup": {}, - "screenSharingTitle": "membagikan layar", - "@screenSharingTitle": {}, - "appearOnTopDetails": "Memperbolehkan aplikasi untuk ditampilkan di atas (tidak dibutuhkan jika kamu memiliki FluffyChat ditetapkan sebagai akun pemanggilan)", - "@appearOnTopDetails": {}, - "callingAccountDetails": "Memperbolehkan FluffyChat untuk menggunakan aplikasi penelepon Android bawaan.", - "@callingAccountDetails": {}, - "noKeyForThisMessage": "Hal ini bisa terjadi jika pesan dikirim sebelum kamu masuk ke akunmu di perangkat ini.\n\nMungkin juga pengirim telah memblokir perangkatmu atau ada yang tidak beres dengan koneksi internet.\n\nApakah kamu bisa membaca pesan pada sesi lain? Maka kamu bisa mentransfer pesan dari sesi tersebut! Buka Pengaturan > Perangkat dan pastikan bahwa perangkat Anda telah ditandatangani secara silang. Ketika kamu membuka ruangan di lain waktu dan kedua sesi berada di latar depan, kunci akan ditransmisikan secara otomatis.\n\nApakah kamu tidak mau kehilangan kunci saat keluar atau berpindah perangkat? Pastikan bahwa kamu telah mengaktifkan cadangan obrolan dalam pengaturan.", - "@noKeyForThisMessage": {}, - "foregroundServiceRunning": "Notifikasi ini ditampilkan ketika layanan latar depan berjalan.", - "@foregroundServiceRunning": {}, - "callingPermissions": "Perizinan panggilan", - "@callingPermissions": {}, - "appearOnTop": "Tampilkan di atas", - "@appearOnTop": {}, - "callingAccount": "Akun pemanggilan", - "@callingAccount": {}, - "otherCallingPermissions": "Mikrofon, kamera dan perizinan FluffyChat lainnya", - "@otherCallingPermissions": {}, - "whyIsThisMessageEncrypted": "Mengapa pesan ini tidak bisa dibaca?", - "@whyIsThisMessageEncrypted": {}, - "newGroup": "Grup baru", - "@newGroup": {}, - "newSpace": "Space baru", - "@newSpace": {}, - "enterSpace": "Masuk space", - "@enterSpace": {}, - "enterRoom": "Masuk ruangan", - "@enterRoom": {}, - "allSpaces": "Semua space", - "@allSpaces": {}, - "screenSharingDetail": "Kamu membagikan layarmu di FluffyChat", - "@screenSharingDetail": {}, - "numChats": "{number} obrolan", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Sembunyikan peristiwa keadaan yang tidak penting", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Jangan tampilkan lagi", - "@doNotShowAgain": {}, - "hugContent": "{senderName} memeluk kamu", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "googlyEyesContent": "{senderName} mengirim mata googly", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} berpelukan dengan kamu", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_googly": "Kirim mata googly", - "@commandHint_googly": {}, - "commandHint_hug": "Kirim pelukan", - "@commandHint_hug": {}, - "commandHint_cuddle": "Kirim berpelukan", - "@commandHint_cuddle": {}, - "wasDirectChatDisplayName": "Obrolan kosong (sebelumnya {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "startFirstChat": "Mulai obrolan pertamamu", - "@startFirstChat": {}, - "newSpaceDescription": "Fitur space bisa membantu untuk memisahkan obrolanmu dan membuat komunitas pribadi atau publik.", - "@newSpaceDescription": {}, - "sorryThatsNotPossible": "Maaf... itu tidak mungkin", - "@sorryThatsNotPossible": {}, - "deviceKeys": "Kunci perangkat:", - "@deviceKeys": {}, - "encryptThisChat": "Enkripsi obrolan ini", - "@encryptThisChat": {}, - "disableEncryptionWarning": "Demi keamanan kamu tidak bisa menonaktifkan enkripsi dalam sebuah obrolan di mana sebelumbya sudah diaktifkan.", - "@disableEncryptionWarning": {}, - "reopenChat": "Buka obrolan lagi", - "@reopenChat": {}, - "noBackupWarning": "Peringatan! Tanpa mengaktifkan cadangan percakapan, kamu akan kehilangan akses ke pesan terenkripsimu. Disarankan untuk mengaktifkan cadangan percakapan terlebih dahulu sebelum keluar dari akun.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "Tidak ada perangkat lain yang ditemukan", - "@noOtherDevicesFound": {}, - "fileIsTooBigForServer": "Server melaporkan bahwa file terlalu besar untuk dikirim.", - "@fileIsTooBigForServer": {}, - "fileHasBeenSavedAt": "Berkas telah disimpan di {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Pergi ke pesan terakhir dibaca", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Baca sampai sini", - "@readUpToHere": {}, - "jump": "Lompat", - "@jump": {}, - "openLinkInBrowser": "Buka tautan dalam peramban", - "@openLinkInBrowser": {}, - "allRooms": "Semua Percakapan Grup", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "report": "laporkan", - "@report": {}, - "reportErrorDescription": "😭 Aduh. Ada yang salah. Jika kamu mau, kamu bisa melaporkan kutu ini kepada para pengembang.", - "@reportErrorDescription": {}, - "signInWithPassword": "Masuk dengan kata sandi", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Silakan coba lagi nanti atau pilih server yang lain.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "Masuk dengan {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Bukan berkas gambar.", - "@notAnImage": {}, - "importNow": "Impor sekarang", - "@importNow": {}, - "importFromZipFile": "Impor dari berkas .zip", - "@importFromZipFile": {}, - "exportEmotePack": "Ekspor paket Emote sebagai .zip", - "@exportEmotePack": {}, - "replace": "Ganti", - "@replace": {}, - "importEmojis": "Impor Emoji", - "@importEmojis": {}, - "sendTypingNotifications": "Kirim notifikasi pengetikan", - "@sendTypingNotifications": {}, - "createGroup": "Buat grup", - "@createGroup": {}, - "inviteContactToGroupQuestion": "Apakah kamu ingin mengundang {contact} ke chat \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "Coba ulang", - "@tryAgain": {}, - "messagesStyle": "Pesan:", - "@messagesStyle": {}, - "shareInviteLink": "Bagikan tautan undangan", - "@shareInviteLink": {}, - "setTheme": "Atur tema:", - "@setTheme": {}, - "invalidServerName": "Nama server tidak valid", - "@invalidServerName": {}, - "addChatDescription": "Tambahkan deskripsi chat...", - "@addChatDescription": {}, - "chatPermissions": "Perizinan chat", - "@chatPermissions": {}, - "chatDescription": "Deskripsi chat", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Deskripsi chat diubah", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "Deskripsi chat belum dibuat.", - "@noChatDescriptionYet": {}, - "redactMessageDescription": "Pesan akan dihilangkan untuk semua anggota dalam percakapan ini. Ini tidak dapat diurungkan.", - "@redactMessageDescription": {}, - "optionalRedactReason": "(Opsional) Alasan menghilangkan pesan ini...", - "@optionalRedactReason": {}, - "redactedBy": "Dihilangkan oleh {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "directChat": "Chat langsung", - "@directChat": {}, - "redactedByBecause": "Dihilangkan oleh {username} karena: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "setChatDescription": "Lihat deskripsi chat", - "@setChatDescription": {}, - "profileNotFound": "Pengguna ini tidak dapat ditemukan di server. Mungkin ada masalah koneksi atau penggunanya tidak ada.", - "@profileNotFound": {}, - "setColorTheme": "Atur tema warna:", - "@setColorTheme": {}, - "invite": "Undang", - "@invite": {}, - "inviteGroupChat": "📨 Undang percakapan grup", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Undang percakapan privat", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "Emote yang telah digunakan akan muncul di sini...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "invalidInput": "Masukan tidak valid!", - "@invalidInput": {}, - "wrongPinEntered": "PIN yang dimasukkan salah! Coba lagi dalam {seconds} detik...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "banUserDescription": "Pengguna akan dicekal dari percakapan dan tidak akan dapat memasuki percakapan lagi sampai dibatalkan cekalannya.", - "@banUserDescription": {}, - "removeDevicesDescription": "Kamu akan dikeluarkan dari perangkat ini dan tidak akan dapat menerima pesan lagi.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "Pengguna akan dapat memasuki percakapannya lagi jika dicoba.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Notifikasi dorongan tidak tersedia", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Setelah kamu membuat pengguna ini admin, kamu tidak akan dapat mengurungkan ini karena penggunanya akan memiliki perizinan yang sama seperti kamu.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Percakapan akan dipindahkan ke arsip. Pengguna lain akan melihat bahwa kamu telah meninggalkan percakapan.", - "@archiveRoomDescription": {}, - "hasKnocked": "🚪 {user} telah dikeluarkan", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "learnMore": "Pelajari lebih lanjut", - "@learnMore": {}, - "roomUpgradeDescription": "Percakapannya akan dibuat ulang dengan versi ruangan yang baru. Semua anggota akan diberi tahu bahwa mereka harus ganti ke percakapan yang baru. Kamu bisa mempelajari lebih lanjut tentang versi ruangan di https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Silakan masukkan angka lebih dari 0", - "@pleaseEnterANumber": {}, - "kickUserDescription": "Pengguna ini dikeluarkan dari percakapan tetapi tidak dicekal. Dalam percakapan publik, penggunanya dapat bergabung ulang kapan pun.", - "@kickUserDescription": {}, - "groupCanBeFoundViaSearch": "Grup dapat dicari melalui pencarian", - "@groupCanBeFoundViaSearch": {}, - "groupName": "Nama grup", - "@groupName": {}, - "wrongRecoveryKey": "Maaf... ini sepertinya bukan kunci pemulihan yang benar.", - "@wrongRecoveryKey": {}, - "addChatOrSubSpace": "Tambahkan percakapan atau subspace", - "@addChatOrSubSpace": {}, - "pleaseChooseAStrongPassword": "Silakan pilih kata sandi yang kuat", - "@pleaseChooseAStrongPassword": {}, - "joinSpace": "Bergabung ke space", - "@joinSpace": {}, - "acceptedKeyVerification": "{sender} menerima verifikasi kunci", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender} membatalkan verifikasi kunci", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} siap untuk verifikasi kunci", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "verifyOtherDevice": "🔐 Verifikasi perangkat lain", - "@verifyOtherDevice": {}, - "requestedKeyVerification": "{sender} meminta verifikasi kunci", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} memulai verifikasi kunci", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "formattedMessagesDescription": "Tampilkan konten pesan kaya seperti teks tebal menggunakan Markdown.", - "@formattedMessagesDescription": {}, - "noUsersFoundWithQuery": "Sayangnya tidak ada pengguna yang dapat ditemukan dengan \"{query}\". Silakan periksa jika ada tipo.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "databaseBuildErrorBody": "Tidak dapat membangun basis data SQLite. Aplikasi mencoba menggunakan basis data lawas untuk sekarang. Silakan laporkan kesalahan ini kepada pengembang di {url}. Pesan kesalahannya adalah: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "passwordIsWrong": "Kata sandi yang kamu masukkan salah", - "@passwordIsWrong": {}, - "searchChatsRooms": "Cari #percakapan, @pengguna...", - "@searchChatsRooms": {}, - "createGroupAndInviteUsers": "Buat sebuah grup dan undang pengguna", - "@createGroupAndInviteUsers": {}, - "pleaseEnterYourCurrentPassword": "Silakan masukkan kata sandimu saat ini", - "@pleaseEnterYourCurrentPassword": {}, - "passwordsDoNotMatch": "Kata sandi tidak cocok", - "@passwordsDoNotMatch": {}, - "publicLink": "Tautan publik", - "@publicLink": {}, - "sendTypingNotificationsDescription": "Anggota lain dalam percakapan dapat melihat ketika kamu sedang mengetik sebuah pesan baru.", - "@sendTypingNotificationsDescription": {}, - "forwardMessageTo": "Teruskan pesan ke {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendReadReceipts": "Kirim laporan dibaca", - "@sendReadReceipts": {}, - "formattedMessages": "Pesan yang diformat", - "@formattedMessages": {}, - "verifyOtherUser": "🔐 Verifikasi pengguna lain", - "@verifyOtherUser": {}, - "sessionLostBody": "Sesimu hilang. Silakan laporkan kesalahan ini kepada pengembang di {url}. Pesan kesalahannya adalah: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "Aplikasi sekarang mencoba memulihkan sesimu dari cadangan. Silakan laporkan kesalahan ini kepada pengembang di {url}. Pesan kesalahannya adalah: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "presenceStyle": "Presensi:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Tampilkan pesan status dari pengguna lain", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "youInvitedToBy": "📩 Kamu telah diundang melalui surel ke:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "publicSpaces": "Space publik", - "@publicSpaces": {}, - "commandHint_sendraw": "Kirim JSON mentah", - "@commandHint_sendraw": {}, - "sendReadReceiptsDescription": "Anggota lain dalam percakapan dapat melihat ketika kamu membaca sebuah pesan.", - "@sendReadReceiptsDescription": {}, - "block": "Blokir", - "@block": {}, - "blockedUsers": "Pengguna yang terblokir", - "@blockedUsers": {}, - "blockListDescription": "Kamu bisa memblokir pengguna yang sedang menganggumu. Kamu tidak akan mendapatkan pesan atau undangan ruangan dari pengguna dalam daftar blokiran pribadimu.", - "@blockListDescription": {}, - "blockUsername": "Abaikan nama pengguna", - "@blockUsername": {}, - "hidePresences": "Sembunyikan Daftar Status?", - "@hidePresences": {}, - "transparent": "Transparan", - "@transparent": {}, - "stickers": "Stiker", - "@stickers": {}, - "discover": "Jelajahi", - "@discover": {}, - "startConversation": "Mulai percakapan", - "@startConversation": {}, - "yourGlobalUserIdIs": "ID pengguna globalmu adalah: ", - "@yourGlobalUserIdIs": {}, - "select": "Pilih", - "@select": {}, - "subspace": "Subspace", - "@subspace": {}, - "decline": "Tolak", - "@decline": {}, - "nothingFound": "Tidak ada yang ditemukan...", - "@nothingFound": {}, - "thisDevice": "Perangkat ini:", - "@thisDevice": {}, - "newPassword": "Kata sandi baru", - "@newPassword": {}, - "incomingMessages": "Pesan masuk", - "@incomingMessages": {}, - "databaseMigrationTitle": "Basis data sudah dioptimalkan", - "@databaseMigrationTitle": {}, - "searchForUsers": "Cari @pengguna...", - "@searchForUsers": {}, - "completedKeyVerification": "{sender} menyelesaikan verifikasi kunci", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "databaseMigrationBody": "Silakan tunggu. Ini dapat membutuhkan beberapa waktu.", - "@databaseMigrationBody": {}, - "leaveEmptyToClearStatus": "Tinggalkan kosong untuk menghapus statusmu.", - "@leaveEmptyToClearStatus": {}, - "initAppError": "Terjadi kesalahan saat init aplikasi", - "@initAppError": {}, - "verifyOtherDeviceDescription": "Saat kamu memverifikasi perangkat lain, perangkat tersebut dapat bertukar kunci, sehingga meningkatkan keamananmu secara keseluruhan. 💪 Saat Anda memulai verifikasi, sebuah pemberitahuan akan muncul di aplikasi pada kedua perangkat. Di situ kemudian akan melihat serangkaian emoji atau angka yang harus dibandingkan satu sama lain. Sebaiknya siapkan kedua perangkat sebelum kamu memulai verifikasi. 🤳", - "@verifyOtherDeviceDescription": {}, - "verifyOtherUserDescription": "Jika kamu memverifikasi pengguna lain, kamu bisa yakin bahwa kamu tahu kepada siapa sebenarnya kamu menulis pesan kepadanya. 💪\n\nSaat kamu memulai verifikasi, kamu dan pengguna lain akan melihat pemberitahuan di aplikasi. Di sana kemudian akan melihat serangkaian emoji atau angka yang harus dibandingkan satu sama lain.\n\nCara terbaik untuk melakukannya adalah dengan bertemu secara langsung atau memulai panggilan video. 👭", - "@verifyOtherUserDescription": {}, - "commandHint_ignore": "Abaikan ID Matrix yang diberikan", - "@commandHint_ignore": {}, - "commandHint_unignore": "Batalkan pengabaian ID Matrix yang diberikan", - "@commandHint_unignore": {}, - "unreadChatsInApp": "{appname}: {unread} obrolan belum dibaca", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "noDatabaseEncryption": "Enkripsi basis data tidak didukung di platform ini", - "@noDatabaseEncryption": {}, - "customEmojisAndStickersBody": "Tambakan atau bagikan emoji atau stiker kustom yang dapat digunakan dalam obrolan apa pun.", - "@customEmojisAndStickersBody": {}, - "hideRedactedMessages": "Sembunyikan pesan yang dihapus", - "@hideRedactedMessages": {}, - "appLockDescription": "Kunci aplikasi ketika tidak digunakan dengan kode PIN", - "@appLockDescription": {}, - "accessAndVisibility": "Akses dan keterlihatan", - "@accessAndVisibility": {}, - "globalChatId": "ID obrolan global", - "@globalChatId": {}, - "accessAndVisibilityDescription": "Siapa yang diperbolehkan bergabung ke obrolan ini dan bagaimana obrolannya dapat ditemukan.", - "@accessAndVisibilityDescription": {}, - "calls": "Panggilan", - "@calls": {}, - "customEmojisAndStickers": "Emoji dan stiker kustom", - "@customEmojisAndStickers": {}, - "hideRedactedMessagesBody": "Jika seseorang menghapus pesan, pesannya tidak akan terlihat lagi dalam obrolan.", - "@hideRedactedMessagesBody": {}, - "hideMemberChangesInPublicChatsBody": "Jangan tampilkan dalam lini masa obrolan jika seseorang bergabung atau keluar dari obrolan untuk meningkatkan keterlihatan.", - "@hideMemberChangesInPublicChatsBody": {}, - "notifyMeFor": "Beri tahu aku untuk", - "@notifyMeFor": {}, - "hideInvalidOrUnknownMessageFormats": "Sembunyikan format pesan yang tidak valid atau tidak diketahui", - "@hideInvalidOrUnknownMessageFormats": {}, - "hideMemberChangesInPublicChats": "Sembunyikan perubahan anggota dalam obrolan publik", - "@hideMemberChangesInPublicChats": {}, - "overview": "Ikhtisar", - "@overview": {}, - "passwordRecoverySettings": "Pengaturan pemulihan kata sandi", - "@passwordRecoverySettings": {}, - "usersMustKnock": "Pengguna harus mengetuk", - "@usersMustKnock": {}, - "noOneCanJoin": "Tidak ada siapa pun yang dapat bergabung", - "@noOneCanJoin": {}, - "userWouldLikeToChangeTheChat": "{user} ingin bergabung dengan obrolan.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "Belum ada tautan publik yang dibuat", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "Ketuk", - "@knock": {}, - "knocking": "Mengetuk", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Obrolan dapat ditemukan melalui pencarian di {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "thereAreCountUsersBlocked": "Saat ini ada {count} pengguna yang diblokir.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "publicChatAddresses": "Alamat obrolan umum", - "@publicChatAddresses": {}, - "createNewAddress": "Buat alamat baru", - "@createNewAddress": {}, - "userRole": "Peran pengguna", - "@userRole": {}, - "minimumPowerLevel": "{level} adalah tingkat daya minimum.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - } -} diff --git a/assets/l10n/intl_ie.arb b/assets/l10n/intl_ie.arb deleted file mode 100644 index eea5fe54a..000000000 --- a/assets/l10n/intl_ie.arb +++ /dev/null @@ -1,2124 +0,0 @@ -{ - "group": "Gruppe", - "@group": { - "type": "text", - "placeholders": {} - }, - "identity": "Identitá", - "@identity": { - "type": "text", - "placeholders": {} - }, - "close": "Cluder", - "@close": { - "type": "text", - "placeholders": {} - }, - "confirm": "Confirmar", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "admin": "Administrator", - "@admin": { - "type": "text", - "placeholders": {} - }, - "chats": "Conversationes", - "@chats": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Contene li nómine", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Contene li visibil nómine", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Copiat al Paperiere", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Copiar al Paperiere", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} participantes", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "createNewSpace": "Crear un spacie", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Activ actualmen", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "deleteAccount": "Destructer li conto", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Remover li missage", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Modificar blocat servitores", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Omni es pret!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extremmen offensiv", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nómine de file", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Dimension de fonde", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Pro adhesion", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Provide vor hem-servitor", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Pro invitation", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Gruppe es public", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "help": "Auxilie", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Celar ínconosset evenimentes", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Ignorat usatores", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "invitedUsersOnly": "Solmen invitat usatores", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "login": "Aperter li session", - "@login": { - "type": "text", - "placeholders": {} - }, - "isTyping": "tippa…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "Adherer al chambre", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Cargar plu…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Invitationes por me", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Ultim activité: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "mention": "Mentionar", - "@mention": { - "type": "text", - "placeholders": {} - }, - "next": "Sequent", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "No", - "@no": { - "type": "text", - "placeholders": {} - }, - "offensive": "Offensiv", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "For del rete", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "OK", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "In li rete", - "@online": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Cambios inter membres", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Assurdar li conversation", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "newChat": "Crear un conversation", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nov demanda de verification!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "Scannar un code QR", - "@scanQrCode": {}, - "noRoomsFound": "Null chambres trovat…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Aperter in mappas", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "password": "Contrasigne", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Li contrasigne esset obliviat", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Reganiar li contrasigne", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Ples selecter", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Regules de push-notificationes", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Redacter li missage", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "removeDevice": "Remover li aparate", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Gardar li file", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "recoveryKey": "Clave de regania", - "@recoveryKey": {}, - "sendMessages": "Inviar missages", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Inviar video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Partir un localisation", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Nómine de spacie", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Índisponibil", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Marcar quam (ín)leet", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "unblockDevice": "Deblocar li aparate", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Ínconosset aparate", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Voce-missage", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Tapete", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "messageType": "Tip de missage", - "@messageType": {}, - "start": "Iniciar", - "@start": {}, - "messageInfo": "Information pri li missage", - "@messageInfo": {}, - "openGallery": "Aperter li galerie", - "@openGallery": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "reportUser": "Raportar li usator", - "@reportUser": {}, - "voiceCall": "Telefonada", - "@voiceCall": {}, - "nextAccount": "Sequent conto", - "@nextAccount": {}, - "previousAccount": "Precedent conto", - "@previousAccount": {}, - "countFiles": "{count} files", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "all": "Omni", - "@all": { - "type": "text", - "placeholders": {} - }, - "create": "Crear", - "@create": { - "type": "text", - "placeholders": {} - }, - "connect": "Conexer", - "@connect": { - "type": "text", - "placeholders": {} - }, - "copy": "Copiar", - "@copy": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Obscur", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "messages": "Missages", - "@messages": { - "type": "text", - "placeholders": {} - }, - "none": "Null", - "@none": { - "type": "text", - "placeholders": {} - }, - "rejoin": "Re-adherer", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Remover", - "@remove": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notificationes", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "reply": "Responder", - "@reply": { - "type": "text", - "placeholders": {} - }, - "dateWithYear": "{day}.{month}.{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "delete": "Remover", - "@delete": { - "type": "text", - "placeholders": {} - }, - "search": "Sercha", - "@search": { - "type": "text", - "placeholders": {} - }, - "devices": "Aparates", - "@devices": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Lucid", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "edit": "Redacter", - "@edit": { - "type": "text", - "placeholders": {} - }, - "security": "Securitá", - "@security": { - "type": "text", - "placeholders": {} - }, - "settings": "Parametres", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Partir", - "@share": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Del sistema", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "username": "Nómine de usator", - "@username": { - "type": "text", - "placeholders": {} - }, - "verify": "Verificar", - "@verify": { - "type": "text", - "placeholders": {} - }, - "submit": "Inviar", - "@submit": { - "type": "text", - "placeholders": {} - }, - "unpin": "Defixar", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "verified": "Verificat", - "@verified": { - "type": "text", - "placeholders": {} - }, - "warning": "Avise!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "yes": "Yes", - "@yes": { - "type": "text", - "placeholders": {} - }, - "time": "Hora", - "@time": {}, - "publish": "Publicar", - "@publish": {}, - "sender": "Autor", - "@sender": {}, - "dismiss": "Demisser", - "@dismiss": {}, - "custom": "Personalisat", - "@custom": {}, - "emojis": "Emoji", - "@emojis": {}, - "widgetCustom": "Personalisat", - "@widgetCustom": {}, - "users": "Usatores", - "@users": {}, - "user": "Usator", - "@user": {}, - "forward": "Avan", - "@forward": { - "type": "text", - "placeholders": {} - }, - "groups": "Gruppes", - "@groups": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorar", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Ínoffensiv", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "invited": "Invitat", - "@invited": { - "type": "text", - "placeholders": {} - }, - "leave": "Forlassar", - "@leave": { - "type": "text", - "placeholders": {} - }, - "license": "Licentie", - "@license": { - "type": "text", - "placeholders": {} - }, - "or": "O", - "@or": { - "type": "text", - "placeholders": {} - }, - "link": "Ligament", - "@link": {}, - "participant": "Participante", - "@participant": { - "type": "text", - "placeholders": {} - }, - "reason": "Cause", - "@reason": { - "type": "text", - "placeholders": {} - }, - "people": "Homes", - "@people": { - "type": "text", - "placeholders": {} - }, - "pin": "Fixar", - "@pin": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privatie", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "recording": "Registrante", - "@recording": { - "type": "text", - "placeholders": {} - }, - "register": "Inregistrar se", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Refuser", - "@reject": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Repetir li contrasigne", - "@repeatPassword": {}, - "addEmail": "Adjunter e-post", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "changePassword": "Cambiar li contrasigne", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Vacuar li archive", - "@clearArchive": {}, - "commandHint_clearcache": "Vacuar li cache", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_send": "Inviar li textu", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "configureChat": "Configurar li conversation", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "directChats": "Direct conversationes", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Activar li ciffration", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Descargar li file", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Parametres de emotiones", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Curt-code de emotion", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Vacui conversation", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videotelefonada", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "openChat": "Aperter li conversation", - "@openChat": {}, - "reportMessage": "Raportar li missage", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Sin permission", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Aperter li cámera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Monstrar li contrasigne", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Inviar un file", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Inviar un image", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Inviar li originale", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Corresponde", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "anyoneCanJoin": "Alquí posse adherer se", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Obtenente li localisation…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "addWidget": "Adjunter un widget", - "@addWidget": {}, - "addAccount": "Adjunter un conto", - "@addAccount": {}, - "publicRooms": "Public chambres", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Iniciar li verification", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Version del chambre", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Inviar audio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Inviar un nota adhesiv", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Assignar li statu", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Code de fonte", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "play": "Reproducter {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "about": "Pri", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Acceptar", - "@accept": { - "type": "text", - "placeholders": {} - }, - "confirmMatrixId": "Ples confirmar vor Matrix ID por destructer vor conto.", - "@confirmMatrixId": {}, - "allChats": "Omni conversationes", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Adjunter al spacie", - "@addToSpace": {}, - "askVerificationRequest": "Esque acceptar ti demanda de verification de {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Automaticmen reproducter animat images", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "sendOnEnter": "Inviar per Enter", - "@sendOnEnter": {}, - "blocked": "Blocat", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "blockDevice": "Blocar li aparate", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Missages de robots", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Cambiar li nómine de aparate", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Cambiar li hem-servitor", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "chat": "Conversation", - "@chat": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Cambiar vor avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Archive de conversation", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Detallies del conversation", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "commandHint_me": "Ples descrir vos", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_leave": "Forlassar ti chambre", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandInvalid": "Comande es ínvalid", - "@commandInvalid": { - "type": "text" - }, - "widgetEtherpad": "Textual nota", - "@widgetEtherpad": {}, - "banFromChat": "Bannir del conversation", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Cambiar li stil", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "commandHint_markasgroup": "Marcar quam gruppe", - "@commandHint_markasgroup": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "screenSharingTitle": "partir li ecran", - "@screenSharingTitle": {}, - "callingPermissions": "Permissiones de telefonada", - "@callingPermissions": {}, - "callingAccount": "Conto telefonante", - "@callingAccount": {}, - "bannedUser": "{username} ha bannit {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "commandHint_html": "Inviar contenete HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_plain": "Inviar textu sin formate", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "editRoomAliases": "Modificar pseudonimos del chambre", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emotion ja existe!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Modificar li avatar del chambre", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Gruppe con {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "invitedUser": "{username} invitat {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "leftTheChat": "Surtit ex li conversation", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "loadingPleaseWait": "Cargante... ples atender.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "{username} ha acceptat li invitation", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "supposedMxid": "To deve esser {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "areYouSureYouWantToLogout": "Esque vu vole cluder li session?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "Li hem-servitor supporta ti tipes de autentication:\n{serverVersions}\nMa ti-ci application supporta solmen:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "cantOpenUri": "Ne successat aperter li adresse {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "badServerVersionsException": "Li hem-servitor supporta ti versiones de specification:\n{serverVersions}\nMa ti-ci application supporta solmen {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "dateWithoutYear": "{day}.{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "device": "Aparate", - "@device": { - "type": "text", - "placeholders": {} - }, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetName": "Nómine", - "@widgetName": {}, - "account": "Conto", - "@account": { - "type": "text", - "placeholders": {} - }, - "alias": "pseudonim", - "@alias": { - "type": "text", - "placeholders": {} - }, - "archive": "Archive", - "@archive": { - "type": "text", - "placeholders": {} - }, - "banned": "Bannit", - "@banned": { - "type": "text", - "placeholders": {} - }, - "cancel": "Anullar", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Ciffrat", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Ciffration", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Hem-servitor", - "@homeserver": {}, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "newGroup": "Crear un gruppe", - "@newGroup": {}, - "newSpace": "Crear un spacie", - "@newSpace": {}, - "enterSpace": "Intrar li spacie", - "@enterSpace": {}, - "enterRoom": "Intrar li chambre", - "@enterRoom": {}, - "allSpaces": "Omni spacies", - "@allSpaces": {}, - "numChats": "{number} conversationes", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "logout": "Cluder li session", - "@logout": { - "type": "text", - "placeholders": {} - }, - "send": "Inviar", - "@send": { - "type": "text", - "placeholders": {} - }, - "you": "Vu", - "@you": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "skip": "Omisser", - "@skip": { - "type": "text", - "placeholders": {} - }, - "status": "Statu", - "@status": { - "type": "text", - "placeholders": {} - }, - "unverified": "Ínverificat", - "@unverified": {}, - "deviceId": "ID de aparate", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Redacter li visibil nómine", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Invitar un contacte", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Demandar li permission", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Esque vu es cert?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@chatHasBeenAddedToThisSpace": {}, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersionLong": {}, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "@setColorTheme": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@youAcceptedTheInvitation": {}, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@encryptThisChat": {}, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@addToBundle": {}, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@importFromZipFile": {}, - "@dehydrateWarning": {}, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@storeSecurlyOnThisDevice": {}, - "@yourChatBackupHasBeenSetUp": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@unlockOldMessages": {}, - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@optionalRedactReason": {}, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {}, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@doNotShowAgain": {}, - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@report": {}, - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@openLinkInBrowser": {}, - "@appLock": { - "type": "text", - "placeholders": {} - }, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@chatDescriptionHasBeenChanged": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@pleaseEnterANumber": {}, - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@hydrateTorLong": {}, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@noBackupWarning": {}, - "@storeInSecureStorageDescription": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@importNow": {}, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@screenSharingDetail": {}, - "@invite": {}, - "@enableMultiAccounts": {}, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - } -} \ No newline at end of file diff --git a/assets/l10n/intl_it.arb b/assets/l10n/intl_it.arb deleted file mode 100644 index 06ca97e8f..000000000 --- a/assets/l10n/intl_it.arb +++ /dev/null @@ -1,2522 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.992206", - "about": "Informazioni", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Accetta", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} ha accettato l'invito", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Account", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} ha abilitato la crittografia end to end", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Aggiungi e-mail", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Amministratore", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Tutto", - "@all": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} ha risposto alla chiamata", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Tutti possono partecipare", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Blocco dell'app", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Archivia", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Gli utenti ospiti possono partecipare", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Sei sicuro/a?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Sei sicuro/a di voler uscire?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Per far accedere l'altra persona, per favore inserisci la tua frase segreta o chiave di recupero.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Accettare questa richiesta di verifica da {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerLoginTypesException": "L'homeserver supporta i tipi di accesso:\n{serverVersions}\nMa questa applicazione supporta solo:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "L'homeserver supporta le versioni Spec:\n{serverVersions}\nMa questa applicazione supporta solo {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Bandisci dalla chat", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Bandito", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} ha bandito {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blocca dispositivo", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Bloccato", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Messaggi bot", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Cancella", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Cambia nome dispositivo", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} ha cambiato l'avatar della discussione", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} ha cambiato la descrizione della chat in: «{description}»", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} ha cambiato il nome della discussione in: «{chatname}»", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} ha cambiato i permessi della chat", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} ha cambiato nome in: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} ha cambiato le regole di accesso per ospiti", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} ha cambiato le regole di accesso per ospiti con: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} ha cambiato la visibilità della cronologia", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} ha cambiato la visibilità della cronologia in: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} ha cambiato le regole per unirsi", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} ha cambiato le regole per unirsi in: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} ha cambiato il loro avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} ha cambiato il nome delle stanze", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} ha cambiato il link di invito", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Cambia la password", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Cambia il server principale", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Cambia il tuo stile", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Cambia il nome del gruppo", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "La crittografia è corrotta", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Backup delle discussioni", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "I tuoi vecchi messaggi sono protetti da una chiave di sicurezza. Assicurati di non perderla.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Dettagli chat", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Discussioni", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Scegli una password complessa", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Chiudi", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Per favore confronta gli emoji", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Per favore confronta i numeri", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Configura la discussione", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Conferma", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Connetti", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Il contatto è stato invitato nel gruppo", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Contiene nome visibile", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Contiene nome utente", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Il contenuto è stato segnalato agli amministratori del server", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Copiato negli Appunti", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Copia", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Copia negli appunti", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Impossibile decriptare messaggio: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} partecipanti", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Crea", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} ha creato la chat", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Attualmente attivo", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Scuro", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}/{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}/{month}/{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Disabiliterà il tuo account. Non puoi tornare indietro! Sei sicuro/a?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Livello di autorizzazione predefinito", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Cancella", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Elimina l'account", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Elimina il messaggio", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Dispositivo", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID del dispositivo", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Dispositivi", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Discussioni dirette", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Il nominativo è stato cambiato", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Scarica il file", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Modifica", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Modifica i server bloccati", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Modifica il nominativo", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Modifica l'avatar della stanza", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "L'emote già esiste!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Shortcode emote invalido!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Pacchetti emotes della stanza", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Impostazioni emote", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Scorciatoia emote", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Devi scegliere una scorciatoia emote e aggiungere un immagine!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Discussione vuota", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Abilita i pacchetti emotes globalmente", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Abilita la crittografia", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Non potrai disabilitare la crittografia in futuro. Sei sicuro?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Crittografato", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Crittografia", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Crittografia non abilitata", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} è entrato in chiamata", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Inserisci un indirizzo e-mail", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Inserisci il tuo server principale", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Tutto pronto!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Estremamente offensivo", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nome del file", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Dimensione carattere", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Inoltra", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Dall'adesione", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Dall'invito", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Vai nella nuova stanza", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Gruppo", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Il gruppo è pubblico", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Gruppi", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Gruppo con {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Gli ospiti sono vietati", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Gli ospiti possono partecipare", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} ha ritirato l'invito per {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Aiuto", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Nascondi gli eventi eliminati", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Nascondi gli eventi sconosciuti", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Quanto è offensivo questo contenuto?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identità", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignora", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Utenti ignorati", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Ho cliccato sul collegamento", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Frase segrata o chiave di ripristino errate", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Inoffensivo", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Invita contatto", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Invita un contatto a {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Invitato/a", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} ha invitato {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Solo per gli utenti invitati", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Invita per me", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} ti ha invitato/a a FluffyChat.\n1. Visita fluffychat.im e installa l'applicazione\n2. Iscriviti o accedi\n3. Apri il collegamento di invito: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "sta scrivendo…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} si è unito/a alla chat", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Unisciti alla stanza", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} ha espulso {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} ha espulso e bandito {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Espulsa dalla discussione", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Ultima attività: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Lascia", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Ha lasciato la chat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licenza", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Chiaro", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Carica altri {count} partecipanti", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Caricamento… Attendere prego.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Carica di più…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Accedi", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Accedi a {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Esci", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Cambiamenti di membri", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Menzione", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Messaggi", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderatore", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Silenzia discussione", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Tieni presente che per ora hai bisogno di Pantalaimon per utilizzare la crittografia dall'inizio alla fine.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Nuova discussione", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Nuovo messaggio in FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nuova richiesta di verifica!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Avanti", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "No", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Nessuna connessione al server", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Nessun emote trovato. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Puoi attivare la crittografia solo quando la stanza non è più accessibile pubblicamente.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Sembra che tu non abbia Firebase Cloud Messaging sul tuo telefono. Per ricevere notifiche push consigliamo di installare ntfy. Con ntfy, o altro provided Unified Push, puoi ricevere le notifiche push in modo sicuro. Puoi scaricare ntfy dal PlayStore o fa F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Nessuno", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Non hai ancora aggiunto un modo per recuperare la tua password.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Nessuna autorizzazione", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Nessuna stanza trovata…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notifiche", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Notifiche abilitate per questo account", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} utenti stanno scrivendo…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "offensive": "Offensivo", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Fuori linea", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "In linea", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Il backup delle chiavi in linea è abilitato", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Ops, qualcosa è andato storto…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Apri l'app per leggere i messaggi", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Apri fotocamera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "participant": "Partecipante", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "frase segreta o chiave di recupero", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Password", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Password dimenticata", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "La password è stata cambiata", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Recupero della password", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Persone", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Scegli un'immagine", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Fissa", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Riproduci {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChooseAPasscode": "Si prega di scegliere un codice di accesso", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Clicca sul collegamenti nell'e-mail e poi procedi.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Inserisci 4 cifre o lascia vuoto per disabilitare il blocco dell'app.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Inserisci la tua password", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Inserisci il tuo nome utente", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Segui le istruzioni sul sito web e tocca Avanti.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privacy", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Stanze pubbliche", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Regole notifiche", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Motivo", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Registrazione", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} ha eliminato un evento", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Elimina un messaggio", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "reject": "Rifiuta", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} ha rifiutato l'invito", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Riunisciti", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Rimuovi", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Rimuovi tutti gli altri dispositivi", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Rimosso da {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Rimuovi il dispositivo", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Rimuovi il ban dalla chat", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Mostra i contenuti ricchi dei messaggi", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Sostituisci la stanza con la versione più recente", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Rispondi", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Segnala il messaggio", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Richiedi l'autorizzazione", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "La stanza è stata aggiornata", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Versione della stanza", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "search": "Cerca", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Sicurezza", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Visto da {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Invia", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Invia un messaggio", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Invia un file audio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Invia un file", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Invia un'immagine", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Invia messaggi", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Invia l'originale", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Invia un video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} ha inviato un file", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} ha inviato un file audio", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} ha inviato un'immagine", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} ha inviato un adesivo", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} ha inviato un video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} ha inviato informazioni sulla chiamata", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setCustomEmotes": "Imposta emoticon personalizzate", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Imposta il collegamento di invito", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Imposta il livello di autorizzazione", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Imposta lo stato", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Impostazioni", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Condividi", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} ha condiviso la sua posizione", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "showPassword": "Mostra la password", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "skip": "Ignora", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Codice sorgente", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} ha iniziato una chiamata", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Stato", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Come stai oggi?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Invia", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistema", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Non corrispondono", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Corrispondono", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Attiva/disattiva preferito", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Attiva/disattiva il silenziatore", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Segna come letto / non letto", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Troppe richieste. Per favore riprova più tardi!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Trasferimento da un altro dispositivo", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Prova a inviare di nuovo", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Non disponibile", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} ha rimosso il bando di {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Sblocca il dispositivo", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Dispositivo sconosciuto", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Algoritmo di crittografia sconosciuto", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Evento sconosciuto «{type}»", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Riattiva l'audio della discussione", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Rimuovi", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 discussione non letta} other{{unreadCount} discussioni non lette}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} e {count} altri stanno scrivendo…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} e {username2} stanno scrivendo…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} sta scrivendo…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} ha lasciato la chat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Nome utente", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} ha inviato un evento {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Verificato", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verifica", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Avvia la verifica", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Hai verificato con successo!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verifica dell'altro account", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videochiamata", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Visibilità della cronologia della discussione", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Visibile a tutti i partecipanti", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Visibile a tutti", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Messaggio vocale", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "In attesa che il partner accetti la richiesta…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "In attesa che il partner accetti l'emoji…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "In attesa che il partner accetti i numeri…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Immagine di sfondo:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Attenzione!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Ti abbiamo inviato un'e-mail", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Chi può eseguire quale azione", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Chi è autorizzato a unirsi a questo gruppo", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Perché vuoi segnalarlo?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Cancellare il backup della discussione per creare una nuova chiave di ripristino?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Con questi indirizzi puoi recuperare la tua password se necessario.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Scrivi un messaggio…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Sì", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Tu", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Non stai più partecipando a questa chat", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Sei stato/a bandito/a da questa chat", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "La tua chiave pubblica", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Accesso singolo", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Imposta come alias principale", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Rimuovi il tuo avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "register": "Registrati", - "@register": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Per favore inserisci il tuo PIN", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Si prega di scegliere", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "or": "O", - "@or": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Ops! Purtroppo si è verificato un errore durante l'impostazione delle notifiche push.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Modifica gli alias della stanza", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Cancella archivio", - "@clearArchive": {}, - "changeYourAvatar": "Cambia il tuo avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "allChats": "Tutte le chat", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Aggiungi a uno spazio", - "@addToSpace": {}, - "commandHint_leave": "Lascia questa stanza", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_ban": "Banna l'utente specificato da questa stanza", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "sendSticker": "Invia sticker", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "commandHint_html": "Invia testo formattato in HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_plain": "Invia testo non formattato", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_send": "Invia testo", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "locationDisabledNotice": "I servizi di localizzazione sono disabilitati. Per favore abilitali per poter condividere la tua posizione.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Salva file", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "Questo server ha bisogno di validare la tua email per la registrazione.", - "@serverRequiresEmail": {}, - "openInMaps": "Apri in maps", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "Scansiona codice QR", - "@scanQrCode": {}, - "addAccount": "Aggiungi account", - "@addAccount": {}, - "unverified": "Non verificato", - "@unverified": {}, - "sendAsText": "Invia come testo", - "@sendAsText": { - "type": "text" - }, - "repeatPassword": "Ripeti password", - "@repeatPassword": {}, - "autoplayImages": "Riproduci automaticamente sticker animati ed emoticon", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "cantOpenUri": "Impossibile aprire l'URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "commandInvalid": "Comando non valido", - "@commandInvalid": { - "type": "text" - }, - "link": "Link", - "@link": {}, - "shareLocation": "Condividi posizione", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "Il tuo backup delle chat è stato configurato.", - "@yourChatBackupHasBeenSetUp": {}, - "hugContent": "{senderName} ti abbraccia", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "jumpToLastReadMessage": "Salta all'ultimo messaggio letto", - "@jumpToLastReadMessage": {}, - "allRooms": "Tutte le chat di gruppo", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Ottengo la posizione…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "commandHint_cuddle": "Invia una coccola", - "@commandHint_cuddle": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "dismiss": "Chiudi", - "@dismiss": {}, - "reportErrorDescription": "😭 Oh no. Qualcosa è andato storto. Se vuoi, puoi segnalare questo bug agli sviluppatori.", - "@reportErrorDescription": {}, - "chatHasBeenAddedToThisSpace": "La chat è stata aggiunta a questo spazio", - "@chatHasBeenAddedToThisSpace": {}, - "unsupportedAndroidVersion": "Versione di Android non supportata", - "@unsupportedAndroidVersion": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "messageType": "Tipo del Messaggio", - "@messageType": {}, - "indexedDbErrorLong": "Sfortunatamente l'archiviazione dei messaggi non è abilitata in modalità privata per impostazione predefinita.\nPer favore visita\n - about:config\n - imposta dom.indexedDB.privateBrowsing.enabled su true\nAltrimenti, non è possibile eseguire FluffyChat.", - "@indexedDbErrorLong": {}, - "oneClientLoggedOut": "Uno dei tuoi client è stato disconnesso", - "@oneClientLoggedOut": {}, - "startFirstChat": "Inizia la tua prima chat", - "@startFirstChat": {}, - "callingAccount": "Account di chiamata", - "@callingAccount": {}, - "setColorTheme": "Imposta tema colore:", - "@setColorTheme": {}, - "nextAccount": "Account successivo", - "@nextAccount": {}, - "commandHint_create": "Crea una chat di gruppo vuota\nUtilizza --no-encryption per disattivare la criptazione", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "allSpaces": "Tutti gli spazi", - "@allSpaces": {}, - "supposedMxid": "Dovrebbe essere {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "user": "Utente", - "@user": {}, - "youAcceptedTheInvitation": "👍 Hai accettato l'invito", - "@youAcceptedTheInvitation": {}, - "noMatrixServer": "{server1} non è un server matrix, vuoi invece usare {server2}?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "youInvitedBy": "📩 Sei stato invitato/a da {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "banUserDescription": "L'utente sarà bannato dalla chat e non sarà in grado di rientrare finché non verrà sbannato.", - "@banUserDescription": {}, - "widgetEtherpad": "Nota di testo", - "@widgetEtherpad": {}, - "removeDevicesDescription": "Sarai disconnesso da questo dispositivo e non potrai più ricevere messaggi.", - "@removeDevicesDescription": {}, - "separateChatTypes": "Separa Chat Dirette e Gruppi", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "tryAgain": "Riprova", - "@tryAgain": {}, - "youKickedAndBanned": "🙅 Hai rimosso e bannato {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "unbanUserDescription": "L'utente potrà rientrare nella chat.", - "@unbanUserDescription": {}, - "sendOnEnter": "Invia quando premi Invio", - "@sendOnEnter": {}, - "youRejectedTheInvitation": "Hai rifiutato l'invito", - "@youRejectedTheInvitation": {}, - "otherCallingPermissions": "Microfono, fotocamera e altri permessi di FluffyChat", - "@otherCallingPermissions": {}, - "messagesStyle": "Messaggi:", - "@messagesStyle": {}, - "widgetUrlError": "Questo non è un URL valido.", - "@widgetUrlError": {}, - "emailOrUsername": "Email o nome utente", - "@emailOrUsername": {}, - "newSpaceDescription": "Gli spazi ti permettono di consolidare le tue chat e di creare comunità private o pubbliche.", - "@newSpaceDescription": {}, - "chatDescription": "Descrizione della chat", - "@chatDescription": {}, - "callingAccountDetails": "Dai l'autorizzazione a FluffyChat di usare l'app di composizione Android nativa.", - "@callingAccountDetails": {}, - "enterSpace": "Unirsi allo spazio", - "@enterSpace": {}, - "encryptThisChat": "Cifra questa chat", - "@encryptThisChat": {}, - "previousAccount": "Account precedente", - "@previousAccount": {}, - "reopenChat": "Riapri la chat", - "@reopenChat": {}, - "pleaseEnterRecoveryKey": "Per favore inserisci la tua chiave di recupero:", - "@pleaseEnterRecoveryKey": {}, - "widgetNameError": "Per favore fornire un nome da visualizzare.", - "@widgetNameError": {}, - "addToBundle": "Aggiungi al bundle", - "@addToBundle": {}, - "spaceIsPublic": "Lo spazio è pubblico", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "addWidget": "Aggiungi widget", - "@addWidget": {}, - "countFiles": "{count} file", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "noKeyForThisMessage": "Questo può accadere se il messaggio è stato inviato prima che hai fatto l'accesso in questo dispositivo.\n\nÈ anche possibile che il mittente abbia bloccato il tuo dispositivo o che qualcosa sia andato storto con la tua connessione ad internet.\n\nSei in grado di leggere il messaggio su altre sessioni? Allora puoi trasferire il messaggio da lì! Vai su Impostazioni > Dispositivi e verifica che i tuoi dispositivi siano verificati l'un l'altro. Quando aprirai la stanza la prossima volta ed entrambe le sessioni sono in primo piano, le chiavi saranno trasmesse automaticamente.\n\nNon vuoi perdere le chiavi quando ti disconnetti o cambi dispositivo? Assicurati di aver attivato il backup delle chat nelle impostazioni.", - "@noKeyForThisMessage": {}, - "commandHint_markasgroup": "Segna come gruppo", - "@commandHint_markasgroup": {}, - "errorObtainingLocation": "Errore cercando di ottenere la posizione: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "hydrateTor": "Utenti TOR: Importa l'esportazione della sessione", - "@hydrateTor": {}, - "pushNotificationsNotAvailable": "Notifiche push non disponibili", - "@pushNotificationsNotAvailable": {}, - "storeInAppleKeyChain": "Salva nel portachiavi di Apple", - "@storeInAppleKeyChain": {}, - "hydrate": "Ripristina dal file di backup", - "@hydrate": {}, - "invalidServerName": "Nome server non valido", - "@invalidServerName": {}, - "chatPermissions": "Permessi della chat", - "@chatPermissions": {}, - "sender": "Mittente", - "@sender": {}, - "storeInAndroidKeystore": "Salva nel KeyStore di Android", - "@storeInAndroidKeystore": {}, - "signInWithPassword": "Accedi con la password", - "@signInWithPassword": {}, - "makeAdminDescription": "Una volta che fai questo utente amministratore, potresti non essere in grado di rimuoverlo, in quanto avrà i tuoi stessi privilegi.", - "@makeAdminDescription": {}, - "synchronizingPleaseWait": "Sincronizzazione... Attendere prego.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "commandHint_clearcache": "Pulisci cache", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "saveKeyManuallyDescription": "Salva questa chiave manualmente attivando la finestra di condivisione o gli appunti.", - "@saveKeyManuallyDescription": {}, - "editBundlesForAccount": "Modifica i bundle per questo account", - "@editBundlesForAccount": {}, - "whyIsThisMessageEncrypted": "Perché questo messaggio è illeggibile?", - "@whyIsThisMessageEncrypted": {}, - "setChatDescription": "Imposta la descrizione della chat", - "@setChatDescription": {}, - "spaceName": "Nome dello spazio", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "importFromZipFile": "Importa da file .zip", - "@importFromZipFile": {}, - "dehydrateWarning": "Questa azione non può essere annullata. Assicurarsi di aver salvato il file di backup.", - "@dehydrateWarning": {}, - "noOtherDevicesFound": "Nessun altro dispositivo trovato", - "@noOtherDevicesFound": {}, - "redactedBy": "Rimosso da {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "videoCallsBetaWarning": "Nota che le video chiamate sono attualmente in beta. Potrebbero non funzionare come previsto o non funzionare del tutto su alcune piattaforme.", - "@videoCallsBetaWarning": {}, - "signInWith": "Accedi con {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "fileIsTooBigForServer": "Il server segnala che il file è troppo grande per essere inviato.", - "@fileIsTooBigForServer": {}, - "homeserver": "Homeserver", - "@homeserver": {}, - "callingPermissions": "Permessi di chiamata", - "@callingPermissions": {}, - "readUpToHere": "Leggi fino a qui", - "@readUpToHere": {}, - "start": "Inizio", - "@start": {}, - "unlockOldMessages": "Sblocca i vecchi messaggi", - "@unlockOldMessages": {}, - "numChats": "{number} chat", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "optionalRedactReason": "(Opzionale) Ragione per rimuovere questo messaggio...", - "@optionalRedactReason": {}, - "dehydrate": "Esporta la sessione e cancella il dispositivo", - "@dehydrate": {}, - "locationPermissionDeniedNotice": "Permesso per accedere alla posizione negato. Per favore concedilo per essere in grado di condividere la tua posizione.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "archiveRoomDescription": "Questa chat sarà archiviata. Gli altri utenti saranno in grado di vedere che hai lasciato la chat.", - "@archiveRoomDescription": {}, - "exportEmotePack": "Esporta pack di Emote come .zip", - "@exportEmotePack": {}, - "switchToAccount": "Passa all'account {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "experimentalVideoCalls": "Video chiamate sperimentali", - "@experimentalVideoCalls": {}, - "pleaseEnterRecoveryKeyDescription": "Per sbloccare i tuoi vecchi messaggi, per favore inserisci la tua chiave di recupero che è stata generata nella tua sessione precedente. La tua chiave di recupero NON è la tua password.", - "@pleaseEnterRecoveryKeyDescription": {}, - "inviteContactToGroupQuestion": "Vuoi invitare {contact} nella chat \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Rimosso da {username} per: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Hai revocato l'invito per {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "appearOnTopDetails": "Permetti all'app di apparire in alto (non necessario se hai già impostato Fluffychat come account di chiamata)", - "@appearOnTopDetails": {}, - "enterRoom": "Unirsi alla stanza", - "@enterRoom": {}, - "reportUser": "Segnala utente", - "@reportUser": {}, - "confirmEventUnpin": "Sei sicuro di voler permanentemente sfissare l'evento?", - "@confirmEventUnpin": {}, - "youInvitedUser": "📩 Hai invitato {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "fileHasBeenSavedAt": "Il file è stato salvato in {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "commandMissing": "{command} non è un comando.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "redactMessageDescription": "Questo messaggio sarà rimosso per tutti i partecipanti di questa conversazione. Questa operazione non può essere annullata.", - "@redactMessageDescription": {}, - "recoveryKey": "Chiave di recupero", - "@recoveryKey": {}, - "commandHint_discardsession": "Scarta sessione", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "invalidInput": "Contenuto non valido!", - "@invalidInput": {}, - "dehydrateTorLong": "Per gli utenti TOR, è raccomandato esportare la sessione prima di chiudere la finestra.", - "@dehydrateTorLong": {}, - "commandHint_myroomnick": "Imposta il nome visualizzato per questa stanza", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "doNotShowAgain": "Non mostrare più", - "@doNotShowAgain": {}, - "report": "segnala", - "@report": {}, - "hideUnimportantStateEvents": "Nascondi gli eventi di stato non importanti", - "@hideUnimportantStateEvents": {}, - "screenSharingTitle": "condivisione schermo", - "@screenSharingTitle": {}, - "widgetCustom": "Personalizzati", - "@widgetCustom": {}, - "addToSpaceDescription": "Seleziona una spazio a cui aggiungere questa chat.", - "@addToSpaceDescription": {}, - "googlyEyesContent": "{senderName} ti ha inviato degli occhi finti", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "youBannedUser": "Hai bannato {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "addChatDescription": "Aggiungi una descrizione chat...", - "@addChatDescription": {}, - "commandHint_myroomavatar": "Importa la foto profilo per questa stanza ( mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "hasKnocked": "{user} ha bussato", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "publish": "Pubblicare", - "@publish": {}, - "openLinkInBrowser": "Apri il collegamento nel browser", - "@openLinkInBrowser": {}, - "commandHint_react": "Rispondi con una reazione", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_me": "Descriviti", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "messageInfo": "Informazioni del messaggio", - "@messageInfo": {}, - "disableEncryptionWarning": "Per motivi di sicurezza non puoi disabilitare la crittografia in una chat, se era stata abilitata in precedenza.", - "@disableEncryptionWarning": {}, - "directChat": "Chat diretta", - "@directChat": {}, - "wrongPinEntered": "È stato inserito il pin sbagliato! Riprova tra {seconds} secondi...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "Invia notifiche di scrittura", - "@sendTypingNotifications": {}, - "inviteGroupChat": "📨 Invita a una chat di gruppo", - "@inviteGroupChat": {}, - "appearOnTop": "Appare in alto", - "@appearOnTop": {}, - "invitePrivateChat": "📨 Invita a una chat privata", - "@invitePrivateChat": {}, - "foregroundServiceRunning": "Questa notifica viene mostrata quando il servizio in primo piano è in esecuzione.", - "@foregroundServiceRunning": {}, - "voiceCall": "Chiamata vocale", - "@voiceCall": {}, - "commandHint_kick": "Rimuovi l'utente fornito da questa stanza", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "createNewSpace": "Nuovo spazio", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "commandHint_unban": "Sbanna l'utente fornito da questa stanza", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "importEmojis": "Importa Emoji", - "@importEmojis": {}, - "wasDirectChatDisplayName": "Chat vuota (era {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noChatDescriptionYet": "La descrizione della chat non è ancora stata creata.", - "@noChatDescriptionYet": {}, - "removeFromBundle": "Rimuovi da questo bundle", - "@removeFromBundle": {}, - "confirmMatrixId": "Conferma il tuo ID Matrix per cancellare il tuo account.", - "@confirmMatrixId": {}, - "learnMore": "Scopri di più", - "@learnMore": {}, - "notAnImage": "Non è un file immagine.", - "@notAnImage": {}, - "users": "Utenti", - "@users": {}, - "openGallery": "Apri la galleria", - "@openGallery": {}, - "chatDescriptionHasBeenChanged": "Descrizione della chat cambiata", - "@chatDescriptionHasBeenChanged": {}, - "newGroup": "Nuovo gruppo", - "@newGroup": {}, - "bundleName": "Nome del bundle", - "@bundleName": {}, - "dehydrateTor": "Utenti TOR: Esporta la sessione", - "@dehydrateTor": {}, - "removeFromSpace": "Rimuovi dallo spazio", - "@removeFromSpace": {}, - "commandHint_op": "Imposta il livello di permessi dell'utente specificato (predefinito: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_join": "Unisciti alla stanza fornita", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "roomUpgradeDescription": "Questa chat sarà ricreata con la nuova versione della stanza. Tutti i partecipanti saranno avvertiti che devono passare alla nuova chat. Puoi leggere di più riguardo le versioni delle stanze su https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "commandHint_invite": "Invia l utente fornito in questa stanza", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "pleaseEnterANumber": "Per favore inserisci un numero maggiore di 0", - "@pleaseEnterANumber": {}, - "youKicked": "👞 Hai rimosso {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "profileNotFound": "Impossibile trovare l'utente sul server. Forse c'è un problema di connessione oppure l'utente non esiste.", - "@profileNotFound": {}, - "jump": "Salta", - "@jump": {}, - "reactedWith": "{sender} ha reagito con {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "sorryThatsNotPossible": "Scusa... questo non è possibile", - "@sorryThatsNotPossible": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "shareInviteLink": "Condividi link d'invito", - "@shareInviteLink": {}, - "commandHint_markasdm": "Segna come stanza messaggi diretti per questo ID Matrix", - "@commandHint_markasdm": {}, - "recoveryKeyLost": "Chiave di recupero smarrita?", - "@recoveryKeyLost": {}, - "cuddleContent": "{senderName} ti coccola", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "deviceKeys": "Chiavi del dispositivo:", - "@deviceKeys": {}, - "emoteKeyboardNoRecents": "Le emoticon recentemente usate appariranno qui...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Imposta tema:", - "@setTheme": {}, - "youJoinedTheChat": "Sei entrato/a nella chat", - "@youJoinedTheChat": {}, - "openVideoCamera": "Apri la fotocamera per un video", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "markAsRead": "Segna come letto", - "@markAsRead": {}, - "widgetName": "Nome", - "@widgetName": {}, - "errorAddingWidget": "Errore aggiungendo il widget.", - "@errorAddingWidget": {}, - "commandHint_dm": "Avvia una chat diretta\nUtilizza --no-encryption per disattivare la criptazione", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_hug": "Invia un abbraccio", - "@commandHint_hug": {}, - "replace": "Sostituisci", - "@replace": {}, - "youUnbannedUser": "Hai sbannato {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "newSpace": "Nuovo spazio", - "@newSpace": {}, - "emojis": "Emoji", - "@emojis": {}, - "commandHint_googly": "Invia degli occhi finti", - "@commandHint_googly": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Per favore riprova più tardi o scegli un server diverso.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Crea gruppo", - "@createGroup": {}, - "hydrateTorLong": "Hai esportato la tua sessione l'ultima volta con TOR? Importala velocemente e continua a chattare.", - "@hydrateTorLong": {}, - "time": "Tempo", - "@time": {}, - "custom": "Personalizzato", - "@custom": {}, - "noBackupWarning": "Attenzione! Senza abilitare il backup della chat, perderai l'accesso ai tuoi messaggi crittografati. Si consiglia vivamente di abilitare il backup della chat prima di disconnettersi.", - "@noBackupWarning": {}, - "storeInSecureStorageDescription": "Salva la chiave di recupero nell'archivio sicuro di questo dispositivo.", - "@storeInSecureStorageDescription": {}, - "openChat": "Apri la Chat", - "@openChat": {}, - "kickUserDescription": "L'utente è stato rimosso, ma non bannato. Nelle chat pubbliche, l'utente potrà rientrare quando vuole.", - "@kickUserDescription": {}, - "importNow": "Importa ora", - "@importNow": {}, - "pinMessage": "Fissa alla stanza", - "@pinMessage": {}, - "invite": "Invitare", - "@invite": {}, - "enableMultiAccounts": "(BETA) Abilita account multipli su questo dispositivo", - "@enableMultiAccounts": {}, - "indexedDbErrorTitle": "Problemi con la modalità privata", - "@indexedDbErrorTitle": {}, - "unsupportedAndroidVersionLong": "Questa funzionalità richiede una versione di Android più recente. Si prega di verificare la presenza di aggiornamenti o supporto per Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "storeSecurlyOnThisDevice": "Salva in modo sicuro su questo dispositivo", - "@storeSecurlyOnThisDevice": {}, - "screenSharingDetail": "Stai condividendo il tuo schermo in FuffyChat", - "@screenSharingDetail": {}, - "placeCall": "Fai una chiamata", - "@placeCall": {}, - "blockListDescription": "Puoi bloccare gli utenti che ti disturbano. Non sarai più in grado di ricevere messaggi o inviti alle stanze dalle persone che hai bloccato.", - "@blockListDescription": {}, - "blockedUsers": "Utenti bloccati", - "@blockedUsers": {}, - "blockUsername": "Nome utente da ignorare", - "@blockUsername": {}, - "createGroupAndInviteUsers": "Crea un gruppo e invita gli utenti", - "@createGroupAndInviteUsers": {}, - "startConversation": "Inizia una conversazione", - "@startConversation": {}, - "groupCanBeFoundViaSearch": "Il gruppo può essere cercato", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "Sfortunatamente non è stato trovato nessun utente con \"{query}\". Per favore controlla se hai fatto un errore di battitura.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "block": "bloccare", - "@block": {}, - "yourGlobalUserIdIs": "Il tuo ID dell'utente globale è: ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "Manda un json grezzo", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Mi dispiace... questa non sembra essere la chiave di recupero corretta.", - "@wrongRecoveryKey": {}, - "groupName": "Nome gruppo", - "@groupName": {}, - "databaseMigrationTitle": "Il database è ottimizzato", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "Cerca per #chat, @utenti...", - "@searchChatsRooms": {}, - "databaseMigrationBody": "Attendere prego. L'operazione potrebbe richiedere un momento.", - "@databaseMigrationBody": {}, - "youInvitedToBy": "📩 Sei stato invitato via collegamento in:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "addChatOrSubSpace": "Aggiungi chat o sotto spazio", - "@addChatOrSubSpace": {}, - "subspace": "Sottospazio", - "@subspace": {}, - "publicSpaces": "Spazio pubblico", - "@publicSpaces": {}, - "hidePresences": "Nascondi Lista Stato?", - "@hidePresences": {}, - "pleaseEnterYourCurrentPassword": "Per favore inserisci la tua password attuale", - "@pleaseEnterYourCurrentPassword": {}, - "passwordIsWrong": "La password inserita è sbagliata", - "@passwordIsWrong": {}, - "databaseBuildErrorBody": "Impossibile costruire il database SQlite. L'applicazione proverà ad usare il database legacy per ora. Per favore segnala questo errore agli sviluppatori su {url}. Il messaggio di errore è: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "select": "Seleziona", - "@select": {}, - "newPassword": "Nuova password", - "@newPassword": {}, - "pleaseChooseAStrongPassword": "Per favore scegli una password forte", - "@pleaseChooseAStrongPassword": {}, - "thisDevice": "Questo dispositivo:", - "@thisDevice": {}, - "forwardMessageTo": "Inoltra messaggio in {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "verifyOtherUser": "🔐 Verifica altro utente", - "@verifyOtherUser": {}, - "verifyOtherUserDescription": "Se verifichi un altro utente, puoi stare certo di conoscere con chi tu stia parlando veramente. 💪\n\nQuando inizi una verifica, tu e l'altro utente vedrete un popup nell'applicazione. Lì vedrete una serie di emoji o numeri che dovrete confrontare l'uno con l'altro.\n\nIl miglior modo per farlo è di incontrarsi o iniziare una chiamata video. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDevice": "🔐 Verifica altro dispositivo", - "@verifyOtherDevice": {}, - "verifyOtherDeviceDescription": "Quando verifichi un altro dispositivo, quei dispositivi possono scambiarsi chiavi, aumentando la tua sicurezza generale. 💪 Quando inizia una verifica, apparirà un popup su entrambi i dispositivi. Lì vedrai una serie di emoji o numeri che dovrai confrontare l'uno con l'altro. È meglio avere entrambi i dispositivi a portata di mano prima di iniziare la verifica. 🤳", - "@verifyOtherDeviceDescription": {}, - "discover": "Scopri", - "@discover": {}, - "presencesToggle": "Mostra messaggi di stato degli altri utenti", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "publicLink": "Collegamento pubblico", - "@publicLink": {}, - "leaveEmptyToClearStatus": "Lasciare vuoto per cancellare il tuo stato.", - "@leaveEmptyToClearStatus": {}, - "decline": "Declina", - "@decline": {}, - "transparent": "Trasparente", - "@transparent": {}, - "incomingMessages": "Messaggi in arrivo", - "@incomingMessages": {} -} diff --git a/assets/l10n/intl_ka.arb b/assets/l10n/intl_ka.arb deleted file mode 100644 index 8c99e3c9a..000000000 --- a/assets/l10n/intl_ka.arb +++ /dev/null @@ -1,744 +0,0 @@ -{ - "alias": "მეტსახელი", - "@alias": { - "type": "text", - "placeholders": {} - }, - "appLockDescription": "პინკოდის გამოყენების გარეშე აპლიკაციის ბლოკირება", - "@appLockDescription": {}, - "commandHint_hug": "მეგობრული ჩახუტვის გაგზავნა", - "@commandHint_hug": {}, - "areYouSure": "დარწმუნებული ხართ?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "დარწმუნებული ხართ, რომ გამოსვლა გსურთ?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "hugContent": "{senderName} მეგობრულად გეხუტება", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "askSSSSSign": "სხვა მომხმარებლის დადასტურებლად, გთხოვთ, ჩაწეროთ თქვენი ან საიდუმლო ფრაზა, ან აღდგენის გასაღები.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "ანიმირებული სტიკერებისა და ემოჯების ავტომატური ჩართვა", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "banFromChat": "ჩატიდან გაგდება და ბლოკირება", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "დაბლოკილია", - "@banned": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "ამ სერვერს აქვს შესვლის მეთოდების მხარდაჭერა:\n{serverVersions}\nმაგრამ ამ აპლიკაციას აქვს მხარდაჭერა მხოლოდ:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "sendOnEnter": "გაგზავნა enter-ის დაჭერისას", - "@sendOnEnter": {}, - "bannedUser": "{username} დაბლოკა {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "მოწყობილების ბლოკირება", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "დაბლოკილია", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "ბოტის შეტყობინებები", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "გაუქმება", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changedTheHistoryVisibilityTo": "{username} შეცვალა ისტორიის ხილვადობა: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} გაწევრიანების წესები შეცვალა", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheProfileAvatar": "{username} შეცვალა პროფილის ფოტო", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "chat": "ჩატი", - "@chat": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "პროფილის ფოტოს შეცვლა", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "თქვენი ჩატის სარეზერვო საშუალება კონფიგურირებული იქნა.", - "@yourChatBackupHasBeenSetUp": {}, - "channelCorruptedDecryptError": "დაშიფვრა დაზიანდა", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "თქვენი ძველი შეტყობინებები დაცულია აღდგების გასაღებით. არ დაკარგოთ ის.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "commandHint_discardsession": "სესიის გაუქმება", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_invite": "მოცემული მომხმარებლის მოწვევა ამ ოთახში", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_plain": "არაფორმატირებული ტექსტის გაგზავნა", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_send": "ტექსტის გაგზავნა", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandMissing": "{command} არაა ბრძანება.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "confirm": "დადასტურება", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "დაკავშირება", - "@connect": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} მონაწილე", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "createGroup": "ჯგუფის შექმნა", - "@createGroup": {}, - "deactivateAccountWarning": "ეს გააუქმებს თქვენს ანგარიშს. ამის გაუქმება შეუძლებელია. დარწმუნებული ხართ?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "devices": "მოწყობილებები", - "@devices": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "ბნელი", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "chatPermissions": "ჩატის უფლებები", - "@chatPermissions": {}, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "editRoomAliases": "ოთახის მეტსახელების შეცვლა", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "ეს ემოცია უკვე არსებობს!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "ემოციის არასწორი მოკლე კოდი!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "importNow": "იმპორტი", - "@importNow": {}, - "importEmojis": "ემოჯის იმპორტი", - "@importEmojis": {}, - "importFromZipFile": "იმპორტი .zip ფაილიდან", - "@importFromZipFile": {}, - "exportEmotePack": "ემოციების .zip ფაილში ექსპორტი", - "@exportEmotePack": {}, - "replace": "ჩანაცვლება", - "@replace": {}, - "accept": "თანხმობა", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} მიიღო მოწვევა", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "ანგარიში", - "@account": { - "type": "text", - "placeholders": {} - }, - "addEmail": "ელ.ფოსტის დამატება", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "confirmMatrixId": "გთხოვთ, დაადასტუროთ თქვენი Matrix ID ანგარიშის წაშლისათვის.", - "@confirmMatrixId": {}, - "addChatDescription": "ჩატის აღწერილობის დამატება...", - "@addChatDescription": {}, - "addToSpace": "სივრცეში დამატება", - "@addToSpace": {}, - "admin": "ადმინი", - "@admin": { - "type": "text", - "placeholders": {} - }, - "all": "ყველა", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "ყველა ჩატი", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "commandHint_cuddle": "ჩახუტების გაგზავნა", - "@commandHint_cuddle": {}, - "answeredTheCall": "{senderName} უპასუხა ზარს", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "ყველას შეუძლია გაწევრიანება", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "აპლიკაციის ბლოკირება", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "არქივი", - "@archive": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "გამოშტერილი თვალების გაგზავნა", - "@commandHint_googly": {}, - "googlyEyesContent": "{senderName} გამოშტერილ თვალებს გიგზავნის", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} გეხუტება", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "areGuestsAllowedToJoin": "შეუძლიათ თუ არა სტუმარ მომხმარებლებს გაწევრიანება", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "მიიღებთ {username} დადასტურების მოთხოვნას?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sendTypingNotifications": "წერის შეტყობინების გაგზავნა", - "@sendTypingNotifications": {}, - "cantOpenUri": "ვერ იხსნება ბმული {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "მოწყობილების გადარქმევა", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} ჩატის ფოტო შეცვალა", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} ჩატის ახალი აღწერილობა დააყენა: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} ჩატი გადაარქვა: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} ჩატის უფლებები შეცვალა", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRules": "{username} შეცვალა სტუმრების წვდომის წესები", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} შეცვალა სტუმრების წვდომის წესები: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} შეცვალა ისტორიის ხილვადობა", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} გაწევრიანების წესები შეცვალა: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheRoomAliases": "{username} ოთახის მეტსახელები შეცვალა", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} მოწვევის ბმული შეცვალა", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "პაროლის შეცვლა", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "სახლის სერვერის შეცვლა", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "სტილის შეცვლა", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "ჯგუფის გადარქმევა", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "ჩატის სარეზერვო საშუალება", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "ჩატის დეტალები", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "ჩატი დაემატა ამ სივრცეს", - "@chatHasBeenAddedToThisSpace": {}, - "chats": "ჩატები", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "ძლიერი პაროლი აარჩიეთ", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "არქივის გაწმენდა", - "@clearArchive": {}, - "close": "დახურვა", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_markasgroup": "აღნიშვნა, როგორც ჯგუფის", - "@commandHint_markasgroup": {}, - "commandHint_ban": "მოცემული მომხმარებლის ბლოკირება ამ ოთახში", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_clearcache": "­ქეშის გაწმენდა", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_join": "მოცემულ ოთახში გაწევრიანება", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "მოცემული მომხმარებლის წაშლა ამ ოთახიდან", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "ამ ოთახიდან გასვლა", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "აღწერეთ თქვენი თავი", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_unban": "ამ ოთახში მომხმარებლისგან ბლოკის მოხსნა", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "არასწორი ბრძანება", - "@commandInvalid": { - "type": "text" - }, - "compareEmojiMatch": "გთხოვთ, შეადაროთ ეს ემოჯი", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "გთხოვთ, შეადაროთ ეს რიცხვები", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "ჩატის კონფიგურაცია", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "კონტაქტი მოწვეული იქნა ჯგუფში", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "შეიცავს სახელს", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "კოპირებულია ბუფერში", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "კოპირება", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "კოპირება ბუფერში", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "შეტყობინების გაშიფვრის შეცდომა: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "create": "შექმნა", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} შექმნა ჩატი", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "ახალი სივრცე", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "ახლა აქტიურია", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "delete": "წაშლა", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "ანგარიშის წაშლა", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "შეტყობინების წაშლა", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "მოწყობილება", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "მოწყობილების ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "directChats": "პირდაპირი ჩატები", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "allRooms": "ყველა ჯგუფური ჩატები", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "ფაილის ჩატვირთვა", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "რედაქტირება", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "ბლოკირებული სერვერების რედაქტირება", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "ოთახის ფოტოს შეცვლა", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "ემოციების პარამეტრები", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "globalChatId": "გლობალური ჩატის ID", - "@globalChatId": {}, - "repeatPassword": "გაიმეორეთ პაროლი", - "@repeatPassword": {}, - "notAnImage": "ფაილი არაა სურათი.", - "@notAnImage": {}, - "remove": "წაშლა", - "@remove": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} გააქტიურა end to end დაშიფვრა", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "supposedMxid": "ეს უნდა იყოს {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "about": "შესახებ", - "@about": { - "type": "text", - "placeholders": {} - }, - "changedTheDisplaynameTo": "{username} შეცვალა ნაჩვენები სახელი: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "commandHint_create": "ცარიელი ჯგუფური ჩატის შექმნა\nგამოიყენეთ --no-encryption გაშიფვრის გასათიშად", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_dm": "პირდაპირი ჩატის დაწყება\nგამოიყენეთ --no-encryption გაშიფვრის გასათიშად", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_html": "HTML ფორმატირებული ტექსტის გაგზავნა", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_myroomavatar": "თქვენი ფოტოს დაყენება ამ ოთახისათვის(mxc-uri-ს დახმარებით)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "ამ ოთახისათვის ნაჩვენები სახელის დაყენება", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "მოცემული მომხმარებლისათვის უფლებების დონის დაყენება (ჩვეულებრივ: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_react": "რეაქციის სახით პასუხის გაგზავნა", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "containsDisplayName": "ნაჩვენებ სახელს შეიცავს", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "ეს კონტენტი გაგზავნილ იქნა სერვერის ადმინისტრატორებთან", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "ნაგულისხმევი უფლების დონე", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "ნაჩვენები სახელი შეიცვალა", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "ნაჩვენები სახელის შეცვლა", - "@editDisplayname": { - "type": "text", - "placeholders": {} - } -} diff --git a/assets/l10n/intl_ko.arb b/assets/l10n/intl_ko.arb deleted file mode 100644 index 18d59f90a..000000000 --- a/assets/l10n/intl_ko.arb +++ /dev/null @@ -1,2711 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.975135", - "about": "소개", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "수락", - "@accept": { - "type": "text", - "placeholders": {} - }, - "allChats": "모든 채팅", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "URI {uri}를 열 수 없습니다", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "chats": "채팅", - "@chats": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "이 방에서 주어진 유저 영구 추방하기", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "HTML 형식의 문자 보내기", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "주어진 유저 이 룸에 초대하기", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_leave": "이 룸 나가기", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "자신을 소개하세요", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_plain": "형식이 지정되지 않은 문자 보내기", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_send": "문자 보내기", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "주어진 유저를 이 방에서 영구추방 해제하기", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "loadMore": "더 불러오기…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "{count}명의 참가자 더 표시", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "lightTheme": "라이트", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "license": "라이선스", - "@license": { - "type": "text", - "placeholders": {} - }, - "help": "도움", - "@help": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "게스트가 들어올 수 있음", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "groups": "그룹 채팅", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "그룹 채팅 공개됨", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "group": "그룹 채팅", - "@group": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "새로운 방 가기", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "초대받은 후부터", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "들어온 후부터", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "forward": "전달", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fontSize": "폰트 크기", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fileName": "파일 이름", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "매우 공격적임", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "모든 것이 준비됐어요!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "당신의 홈서버를 입력하세요", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "homeserver": "홈서버", - "@homeserver": {}, - "enterAnEmailAddress": "이메일 주소 입력", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} 이 통화를 종료했습니다", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "encryptionNotEnabled": "암호화가 비활성화됨", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "encryption": "암호화", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encrypted": "암호화됨", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "당신은 다시 암호화를 비활성화할 수 없습니다. 확실한가요?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "암호화 켜기", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "이모트 팩 항상 사용하기", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "빈 채팅", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "이모트 단축키와 이미지를 골라야 합니다!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "이모트 단축키", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "이모트 설정", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "방을 위한 이모트 팩", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "올바르지 않은 이모트 단축키!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "이모트가 이미 존재합니다!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "방 아바타 수정", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "방 별명 수정", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "표시 이름 수정", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "edit": "수정", - "@edit": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "파일 다운로드", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "표시 이름이 변경되었습니다", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "devices": "기기", - "@devices": { - "type": "text", - "placeholders": {} - }, - "deviceId": "기기 ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "device": "기기", - "@device": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "메시지 삭제", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "계정 삭제", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "delete": "삭제", - "@delete": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "기본 권한 레벨", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "deactivateAccountWarning": "이것은 당신의 계정을 비활성화할 것입니다. 이것은 되돌릴 수 없습니다! 확실한가요?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "현재 활동 중", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "새로운 스페이스", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username}님이 채팅을 생성함", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "create": "생성", - "@create": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} 참여자", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "couldNotDecryptMessage": "메시지 복호화할 수 없음: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "copyToClipboard": "클립보드에 복사", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "복사", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "클립보드에 복사됨", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "콘텐츠가 서버 운영자에게 신고되었습니다", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "유저 이름 포함", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "표시 이름 포함", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "연락처가 채팅에 초대되었습니다", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "connect": "연결", - "@connect": { - "type": "text", - "placeholders": {} - }, - "confirm": "확인", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "configureChat": "채팅 설정", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "아래의 숫자가 일치하는지 비교하세요", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "아래의 이모지가 일치하는지 비교하세요", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "commandMissing": "{command} 는 명령어가 아닙니다.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "commandInvalid": "잘못된 명령어", - "@commandInvalid": { - "type": "text" - }, - "commandHint_react": "답장 반응으로 보내기", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_op": "주어진 유저의 권한 레벨 설정 (기본:50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_myroomnick": "이 방의 표시 이름 설정하기", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_myroomavatar": "이 방의 사진 설정하기 (by mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_kick": "주어진 유저 방에서 삭제하기", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_join": "주어진 방 들어가기", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "close": "닫기", - "@close": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "저장 지우기", - "@clearArchive": {}, - "chooseAStrongPassword": "안전한 비밀번호를 설정하세요", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "이 스페이스에 채팅이 추가되었습니다", - "@chatHasBeenAddedToThisSpace": {}, - "chatDetails": "채팅 정보", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "당신의 오래된 메시지는 보안 키로 보호됩니다. 이 키를 잃어버리지 마세요.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "채팅 백업", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chat": "채팅", - "@chat": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "암호화가 손상되었습니다", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "아바타 바꾸기", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "채팅의 이름 바꾸기", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "스타일 바꾸기", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "홈서버 바꾸기", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changePassword": "비밀번호 바꾸기", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changedTheRoomInvitationLink": "{username}님이 초대 링크를 바꿈", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username}님이 방 별명을 바꿈", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheProfileAvatar": "{username}님이 자신의 아바타를 바꿈", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username}님이 참가 규칙을 {joinRules} 로 바꿈", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheJoinRules": "{username}님이 참가 규칙을 바꿈", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username}님이 대화 기록 설정을 {rules} 로 바꿈", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username}님이 대화 기록 설정을 변경함", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username}님이 게스트 접근 규칙을 {rules} 로 변경함", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheGuestAccessRules": "{username}님이 게스트 접근 규칙을 변경함", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username}님이 닉네임을 '{displayname}' 로 바꿈", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheChatPermissions": "{username}님이 채팅 권한을 바꿈", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatNameTo": "{username}님이 채팅 이름을 '{chatname}' 으로 바꿈", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatDescriptionTo": "{username}님이 채팅 설명을 '{description}' 으로 변경함", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatAvatar": "{username}님이 채팅 아바타를 바꿈", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeDeviceName": "기기 이름 바꾸기", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "cancel": "취소", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "botMessages": "봇 메시지", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "blocked": "차단됨", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "blockDevice": "기기 차단", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username}님이 {targetName}님을 영구 추방함", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "banned": "영구 추방됨", - "@banned": { - "type": "text", - "placeholders": {} - }, - "banFromChat": "채팅에서 영구 추방", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "이 홈서버가 지원하는 Spec 버전:\n{serverVersions}\n하지만 이 앱은 {supportedVersions}만 지원합니다", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "sendOnEnter": "엔터로 보내기", - "@sendOnEnter": {}, - "badServerLoginTypesException": "홈서버가 지원하는 로그인 유형:\n{serverVersions}\n하지만 이 앱에서 지원하는 것은:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "autoplayImages": "자동으로 움직이는 스티커와 이모트 재생", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "askVerificationRequest": "{username}님의 인증 요청을 수락할까요?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "askSSSSSign": "다른 사람을 서명하기 위해서, 저장 비밀번호나 복구 키를 입력해주세요.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "로그아웃하고 싶은 것이 확실한가요?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "확실한가요?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "게스트 유저가 참가 여부", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "저장", - "@archive": { - "type": "text", - "placeholders": {} - }, - "appLock": "앱 잠금", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "anyoneCanJoin": "누구나 들어올 수 있음", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName}님이 전화에 응답했습니다", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "alias": "별명", - "@alias": { - "type": "text", - "placeholders": {} - }, - "admin": "운영자", - "@admin": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "스페이스에 추가", - "@addToSpace": {}, - "addEmail": "이메일 추가", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username}님이 종단간 암호화를 활성화함", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "계정", - "@account": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username}님이 초대를 수락함", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "ignore": "무시", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "identity": "신원", - "@identity": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "이 콘텐츠가 얼마나 모욕적인가요?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "알 수 없는 이벤트 숨기기", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "지워진 이벤트 숨기기", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username}님이 {targetName}님에 대한 초대를 철회함", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "guestsAreForbidden": "게스트는 금지되어 있습니다", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "groupWith": "{displayname}님과의 그룹", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "errorObtainingLocation": "위치 얻는 중 오류: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "editBlockedServers": "차단된 서버 수정", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "directChats": "다이렉트 채팅", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "dateWithYear": "{year}-{month}-{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "darkTheme": "다크", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "yes": "확인", - "@yes": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "메시지 작성…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "이 주소로 당신의 비밀번호를 복구할 수 있습니다.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "새로운 복구키를 생성하기 위해 채팅 백업을 초기화할까요?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "왜 이것을 신고하려고 하나요?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "누가 이 그룹 채팅에 들어오도록 허용할지", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "누가 어떤 행동을 할 수 있는지", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "우리가 당신에게 이메일을 보냈습니다", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "warning": "경고!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "배경:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "상대가 숫자를 수락하길 기다리는 중…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "상대가 이모지를 수락하길 기다리는 중…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "상대가 요청을 수락하길 기다리는 중…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "음성 메시지", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "모두에게 보임", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "모든 참가자에게 보임", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "videoCall": "영상 통화", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "다른 계정 확인 중", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "성공적으로 확인했어요!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "확인 시작", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verify": "확인", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verified": "확인됨", - "@verified": { - "type": "text", - "placeholders": {} - }, - "username": "유저 이름", - "@username": { - "type": "text", - "placeholders": {} - }, - "userLeftTheChat": "🚪 {username}님이 채팅을 나감", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userIsTyping": "{username}님이 입력 중…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userAndUserAreTyping": "{username}님과 {username2}님이 입력 중…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userAndOthersAreTyping": "{username}님 + {count}명이 입력 중…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "unpin": "고정 해제", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "알 수 없는 암호화 알고리즘", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unblockDevice": "기기 차단 해제", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "pin": "고정", - "@pin": { - "type": "text", - "placeholders": {} - }, - "pickImage": "이미지 고르기", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "비밀번호 복구", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "비밀번호 까먹음", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "password": "비밀번호", - "@password": { - "type": "text", - "placeholders": {} - }, - "participant": "참여자", - "@participant": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "지도에서 열기", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "addAccount": "계정 추가", - "@addAccount": {}, - "openCamera": "카메라 열기", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "앱을 열어서 메시지를 읽으세요", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "앗, 무언가가 잘못되었습니다…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "앗! 안타깝게도, 푸시 알림을 설정하는 중 오류가 발생했습니다.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "online": "온라인", - "@online": { - "type": "text", - "placeholders": {} - }, - "ok": "확인", - "@ok": { - "type": "text", - "placeholders": {} - }, - "offline": "오프라인", - "@offline": { - "type": "text", - "placeholders": {} - }, - "offensive": "모욕적임", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "위치 얻는 중…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count}명이 입력 중…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "notificationsEnabledForThisAccount": "이 계정에서 알림이 활성화되었습니다", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "notifications": "알림", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "noPermission": "권한 없음", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "QR 코드 스캔", - "@scanQrCode": {}, - "noMatrixServer": "{server1}은 matrix 서버가 아닙니다, {server2}를 대신 사용할까요?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "next": "다음", - "@next": { - "type": "text", - "placeholders": {} - }, - "logInTo": "{homeserver} 에 로그인", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "login": "로그인", - "@login": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "위치 권한이 거부되었습니다. 위치를 공유하기 위해서 허용해주세요.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "위치 서비스가 비활성화되었습니다. 위치를 공유하려면 활성화시켜주세요.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "no": "아니요", - "@no": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "새로운 확인 요청!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 FluffyChat에서 새로운 메시지", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newChat": "새 채팅", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "muteChat": "채팅 음소거", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "messages": "메시지", - "@messages": { - "type": "text", - "placeholders": {} - }, - "mention": "멘션", - "@mention": { - "type": "text", - "placeholders": {} - }, - "logout": "로그아웃", - "@logout": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{읽지 않은 채팅 1} other{{unreadCount} 개}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "renderRichContent": "풍부한 메시지 콘텐츠 렌더링", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "unavailable": "사용할 수 없음", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "all": "모두", - "@all": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "당신의 공개 키", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "당신은 이 채팅에서 영구 추방되었습니다", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "당신은 더 이상 이 채팅에 참여하지 않습니다", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "you": "당신", - "@you": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "대화 기록 설정", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username}님이 {type} 이벤트 보냄", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "unmuteChat": "음소거 해제", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "알 수 없는 이벤트 '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unknownDevice": "알 수 없는 기기", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username}님이 {targetName}님에대한 영구추방을 해제함", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "tryToSendAgain": "다시 보내도록 시도", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "다른 기기에서 가져오기", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "너무 많은 요청. 잠시 후에 다시 시도해주세요!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "메시지 안/읽음 으로 표시", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "음소거 토글", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "즐겨찾기 토글", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "theyMatch": "일치합니다", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "일치하지 않습니다", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "시스템", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "동기화 중... 기다려주세요.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "submit": "제출", - "@submit": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "오늘은 어떤 기분인가요?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "status": "상태", - "@status": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} 가 통화 시작함", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "spaceName": "스페이스 이름", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "스페이스가 공개됨", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "단일 계정 로그인(SSO)", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "pushRules": "푸시 규칙", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "마지막 활동: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "ignoredUsers": "무시된 사용자", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "4자리 숫자를 입력하거나 앱 잠금을 사용하지 않도록 하려면 비워두세요.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "비밀번호를 골라주세요", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "선택해주세요", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "play": "{fileName} 재생", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "people": "사람들", - "@people": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "비밀번호가 변경됨", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "비밀번호나 복구 키", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "or": "이나", - "@or": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "이 서버는 가입을 위해 당신의 이메일을 확인해야 합니다.", - "@serverRequiresEmail": {}, - "enableMultiAccounts": "(베타) 이 기기에서 다중 계정 활성화", - "@enableMultiAccounts": {}, - "bundleName": "번들 이름", - "@bundleName": {}, - "removeFromBundle": "이 번들에서 삭제", - "@removeFromBundle": {}, - "addToBundle": "번들에 추가", - "@addToBundle": {}, - "editBundlesForAccount": "이 계정의 번들 수정", - "@editBundlesForAccount": {}, - "oneClientLoggedOut": "당신의 클라이언트 중 하나가 로그아웃 됨", - "@oneClientLoggedOut": {}, - "onlineKeyBackupEnabled": "온라인 키 백업이 활성화됨", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "아무 방도 발견되지 않았어요…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "당신은 비밀번호를 복구할 방법을 추가하지 않았습니다.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "none": "없음", - "@none": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "이 휴대폰에 Firebase Cloud Messaging 서비스가 없는 것 같습니다. FluffyChat에서 푸시 알림을 받으려면 ntfy 사용을 추천합니다. ntfy 혹은 다른 푸시 알림 제공자를 사용하면 알림을 보안적인 방법으로 받을 수 있습니다. ntfy는 PlayStore와 F-Droid에서 설치 가능합니다.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "당신은 방이 공개적으로 접근 가능하지 않을 때만 암호화를 켤 수 있습니다.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "이모트 발견되지 않음. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "서버에 연결 없음", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "지금 종단간 암호화를 사용하기 위해서는 Pantalaimon이 필요하다는 것을 알아주세요.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "moderator": "관리자", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "참가자 변경", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "loadingPleaseWait": "로딩 중... 기다려 주세요.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "채팅을 나갔습니다", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "leave": "나가기", - "@leave": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "소스 코드", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "skip": "스킵", - "@skip": { - "type": "text", - "placeholders": {} - }, - "showPassword": "비밀번호 보이기", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "위치 보내기", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username}님이 위치를 공유함", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "share": "공유", - "@share": { - "type": "text", - "placeholders": {} - }, - "settings": "설정", - "@settings": { - "type": "text", - "placeholders": {} - }, - "setStatus": "상태 설정", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "권한 레벨 설정", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "초대 링크 설정", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "맞춤 이모트 설정", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "주 별명으로 설정", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "sentCallInformations": "{senderName} 이 통화 정보 보냄", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "sentAVideo": "🎥 {username}님이 영상을 보냄", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sendOriginal": "원본 보내기", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "메시지 보내기", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendImage": "이미지 보내기", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendFile": "파일 보내기", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "오디오 보내기", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "텍스트로 보내기", - "@sendAsText": { - "type": "text" - }, - "sendAMessage": "메시지 보내기", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "send": "보내기", - "@send": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "{username}님이 읽음", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "security": "보안", - "@security": { - "type": "text", - "placeholders": {} - }, - "search": "검색", - "@search": { - "type": "text", - "placeholders": {} - }, - "saveFile": "파일 저장", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "방 버전", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "방이 업그레이드되었습니다", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "권한 요청", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "reason": "이유", - "@reason": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "공개 방", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "privacy": "프라이버시", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "웹사이트의 가이드를 따르고 다음 버튼을 눌러주세요.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "유저 이름을 입력해주세요", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "PIN을 입력해주세요", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "비밀번호를 입력해주세요", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "방 들어가기", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username}님이 채팅에 참가함", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "isTyping": "가 입력 중…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username}님이 당신을 FluffyChat에 초대했습니다.\n1. FluffyChat 설치: https://fluffychat.im \n2. 가입하거나 로그인 \n3. 초대 링크 열기: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "inviteForMe": "나를 위해 초대", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "invitedUsersOnly": "초대된 유저만", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username}님이 {targetName}님을 초대함", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invited": "초대됨", - "@invited": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "연락처를 {groupName}에 초대", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "inviteContact": "연락처 초대", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "모욕적이지 않음", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "올바르지 않은 복구 키나 비밀번호", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "링크를 클릭했어요", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "sentASticker": "😊 {username}님이 스티커를 보냄", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username}님이 사진을 보냄", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username}님이 오디오를 보냄", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAFile": "📁 {username}님이 파일을 보냄", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sendVideo": "영상 보내기", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "스티커 보내기", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "메시지 신고", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "reply": "답장", - "@reply": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "방 새로운 버전으로 대체하기", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "아바타 지우기", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "채팅에서 영구추방 해제됨", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeDevice": "기기 삭제", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "removedBy": "{username}에 의해 지워짐", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeAllOtherDevices": "모든 다른 기기에서 지우기", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "remove": "지우기", - "@remove": { - "type": "text", - "placeholders": {} - }, - "rejoin": "다시 가입", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username}님이 초대를 거절함", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "거절", - "@reject": { - "type": "text", - "placeholders": {} - }, - "register": "가입", - "@register": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "메시지 지우기", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username}님이 이벤트를 지움", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "recording": "녹음", - "@recording": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "이메일의 링크를 클릭하고 진행해주세요.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "kickFromChat": "채팅에서 추방", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "kickedAndBanned": "🙅 {username}님이 {targetName}님을 추방하고 차단함", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kicked": "👞 {username}님이 {targetName}님을 추방함", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "link": "링크", - "@link": {}, - "unverified": "확인되지 않음", - "@unverified": {}, - "yourChatBackupHasBeenSetUp": "당신의 채팅 백업이 설정되었습니다.", - "@yourChatBackupHasBeenSetUp": {}, - "time": "시간", - "@time": {}, - "messageType": "메시지 유형", - "@messageType": {}, - "openGallery": "갤러리 열기", - "@openGallery": {}, - "sender": "발신자", - "@sender": {}, - "messageInfo": "메시지 정보", - "@messageInfo": {}, - "repeatPassword": "비밀번호 다시 입력", - "@repeatPassword": {}, - "start": "시작", - "@start": {}, - "removeFromSpace": "스페이스에서 삭제", - "@removeFromSpace": {}, - "addToSpaceDescription": "이 채팅을 추가할 스페이스를 선택하세요.", - "@addToSpaceDescription": {}, - "commandHint_discardsession": "세션 삭제", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "다이렉트 채팅 시작\t\n--no-encryption을 사용해 암호화 비활성화", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_clearcache": "캐시 지우기", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "빈 그룹 채팅을 생성\n--no-encryption을 사용해 암호화를 비활성화", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "openVideoCamera": "영상용 카메라 열기", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "publish": "공개", - "@publish": {}, - "videoWithSize": "영상 ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "dismiss": "닫기", - "@dismiss": {}, - "markAsRead": "읽음으로 표시하기", - "@markAsRead": {}, - "reportUser": "유저 신고", - "@reportUser": {}, - "openChat": "채팅 열기", - "@openChat": {}, - "reactedWith": "{sender}가 {reaction}로 반응함", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "confirmEventUnpin": "이벤트를 영구적으로 고정 해제할 것이 확실한가요?", - "@confirmEventUnpin": {}, - "pinMessage": "방에 고정", - "@pinMessage": {}, - "emojis": "이모지", - "@emojis": {}, - "voiceCall": "음성 통화", - "@voiceCall": {}, - "placeCall": "전화 걸기", - "@placeCall": {}, - "experimentalVideoCalls": "실험적인 영상 통화", - "@experimentalVideoCalls": {}, - "unsupportedAndroidVersion": "지원되지 않는 안드로이드 버전", - "@unsupportedAndroidVersion": {}, - "unsupportedAndroidVersionLong": "이 기능은 새로운 안드로이드 버전을 요구합니다. Lineage OS 지원이나 업데이트를 확인해주세요.", - "@unsupportedAndroidVersionLong": {}, - "videoCallsBetaWarning": "영상 통화는 베타임을 확인해주세요. 의도한 대로 작동하지 않거나 모든 플랫폼에서 작동하지 않을 수 있습니다.", - "@videoCallsBetaWarning": {}, - "emailOrUsername": "이메일이나 유저 이름", - "@emailOrUsername": {}, - "confirmMatrixId": "계정을 삭제하려면 Matrix ID를 입력해 주세요.", - "@confirmMatrixId": {}, - "commandHint_googly": "왕눈이 눈알 보내기", - "@commandHint_googly": {}, - "googlyEyesContent": "{senderName} 님이 왕눈이 눈알을 보냈습니다", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_markasgroup": "그룹 채팅으로 만들기", - "@commandHint_markasgroup": {}, - "dehydrate": "세션을 내보내고 기기 초기화 하기", - "@dehydrate": {}, - "dehydrateWarning": "이 동작은 되돌릴 수 없습니다. 백업 파일을 꼭 안전하게 보관하세요.", - "@dehydrateWarning": {}, - "hugContent": "{senderName}님이 당신을 허그합니다", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "jumpToLastReadMessage": "마지막으로 읽은 메시지로 이동", - "@jumpToLastReadMessage": {}, - "allRooms": "모든 그룹 채팅", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "commandHint_cuddle": "미소 보내기", - "@commandHint_cuddle": {}, - "widgetVideo": "영상", - "@widgetVideo": {}, - "reportErrorDescription": "😭 이런. 무언가 잘못되었습니다. 원한다면, 개발자에게 버그를 신고할 수 있습니다.", - "@reportErrorDescription": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "indexedDbErrorLong": "메시지 저장은 기본적으로 사생활 보호 모드에서 사용할 수 없습니다.\n- about:config 로 이동\n- dom.indexedDB.privateBrowsing.enabled 를 true로 설정\n그렇지 않으면 FluffyChat을 실행할 수 없습니다.", - "@indexedDbErrorLong": {}, - "startFirstChat": "첫 번째 채팅을 시작하기", - "@startFirstChat": {}, - "callingAccount": "통화 계정", - "@callingAccount": {}, - "setColorTheme": "색상 테마 설정:", - "@setColorTheme": {}, - "nextAccount": "다음 계정", - "@nextAccount": {}, - "allSpaces": "모든 스페이스", - "@allSpaces": {}, - "supposedMxid": "{mxid} 이어야 함", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "user": "유저", - "@user": {}, - "youAcceptedTheInvitation": "👍 초대를 수락했습니다", - "@youAcceptedTheInvitation": {}, - "youInvitedBy": "📩 {user}에 의해 초대되었습니다", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "banUserDescription": "유저는 채팅에서 영구 추방되며 추방 해제 전까지 채팅을 다시 입력할 수 없습니다.", - "@banUserDescription": {}, - "widgetEtherpad": "텍스트 메모", - "@widgetEtherpad": {}, - "removeDevicesDescription": "이 기기에서 로그아웃되며 더 이상 메시지를 받을 수 없습니다.", - "@removeDevicesDescription": {}, - "separateChatTypes": "다이렉트 채팅과 그룹 채팅 분리", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "tryAgain": "다시 시도하기", - "@tryAgain": {}, - "youKickedAndBanned": "🙅 {user}를 영구 추방했습니다", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "unbanUserDescription": "유저가 다시 채팅을 입력할 수 있습니다.", - "@unbanUserDescription": {}, - "youRejectedTheInvitation": "초대를 거부했습니다", - "@youRejectedTheInvitation": {}, - "otherCallingPermissions": "마이크, 카메라 그리고 다름 FluffyChat 권한", - "@otherCallingPermissions": {}, - "messagesStyle": "메세지:", - "@messagesStyle": {}, - "widgetUrlError": "유효한 URL이 아닙니다.", - "@widgetUrlError": {}, - "newSpaceDescription": "스페이스를 사용하면 채팅을 통합하고 비공개 또는 공개 커뮤니티를 구축할 수 있습니다.", - "@newSpaceDescription": {}, - "chatDescription": "채팅 설명", - "@chatDescription": {}, - "callingAccountDetails": "FluffyChat이 android 전화앱을 사용 할 수 있도록 허가.", - "@callingAccountDetails": {}, - "enterSpace": "스페이스에 입장", - "@enterSpace": {}, - "encryptThisChat": "이 채팅을 암호화", - "@encryptThisChat": {}, - "previousAccount": "이전 계정", - "@previousAccount": {}, - "reopenChat": "채팅 다시 열기", - "@reopenChat": {}, - "pleaseEnterRecoveryKey": "당신의 복구키를 입력하세요:", - "@pleaseEnterRecoveryKey": {}, - "widgetNameError": "표시 이름을 입력하세요.", - "@widgetNameError": {}, - "addWidget": "위젯 추가", - "@addWidget": {}, - "countFiles": "{count}개의 파일", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "noKeyForThisMessage": "이것은 이 메시지가 당신이 이 기기를 서명하기 전에 발송되었기 때문에 일어났을 수 있습니다.\n\n이것은 또한 발송자가 당신의 기기를 차단하였거나 혹은 인터넷 연결이 잘못되었을 수 있습니다.\n\n다른 세션에서 이 메시지를 읽을 수 있나요? 그렇다면 그 메시지를 옮길 수 있습니다! 설정 > 기기로 가서 기기를 서로 증명하세요. 다음번에 방을 열었을 때 두 세션이 모두 작동중이라면, 키가 자동으로 옮겨질것입니다.\n\n로그아웃하거나 기기를 바꿀 때 키를 잃고싶지 않으신가요? 설정에서 채팅 백업을 사용중인지 확인하세요.", - "@noKeyForThisMessage": {}, - "hydrateTor": "TOR 사용자: 내보낸 세션 불러오기", - "@hydrateTor": {}, - "pushNotificationsNotAvailable": "푸시 알림 사용 불가", - "@pushNotificationsNotAvailable": {}, - "storeInAppleKeyChain": "Apple KeyChain에 저장하기", - "@storeInAppleKeyChain": {}, - "hydrate": "백업 파일로부터 가져오기", - "@hydrate": {}, - "invalidServerName": "잘못된 서버 이름", - "@invalidServerName": {}, - "chatPermissions": "채팅 권한", - "@chatPermissions": {}, - "storeInAndroidKeystore": "Android KeyStore에 저장하기", - "@storeInAndroidKeystore": {}, - "signInWithPassword": "비밀번호로 로그인", - "@signInWithPassword": {}, - "makeAdminDescription": "유저를 한 번 관리자로 만들면, 당신과 같은 권한을 가지기때문에 권한 회수가 불가능합니다.", - "@makeAdminDescription": {}, - "saveKeyManuallyDescription": "공유나 클립보드를 이용해 수동으로 키를 저장합니다.", - "@saveKeyManuallyDescription": {}, - "whyIsThisMessageEncrypted": "왜 이 메시지를 읽을 수 없나요?", - "@whyIsThisMessageEncrypted": {}, - "setChatDescription": "채팅 설명 설정", - "@setChatDescription": {}, - "importFromZipFile": ".zip 파일에서 불러오기", - "@importFromZipFile": {}, - "noOtherDevicesFound": "다른 기기 발견되지 않음", - "@noOtherDevicesFound": {}, - "redactedBy": "{username}님이 삭제함", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "signInWith": "{provider}로 로그인", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "fileIsTooBigForServer": "서버가 파일을 전송하기 너무 크다고 보고합니다.", - "@fileIsTooBigForServer": {}, - "callingPermissions": "통화 권한", - "@callingPermissions": {}, - "readUpToHere": "여기까지 읽음", - "@readUpToHere": {}, - "unlockOldMessages": "오래된 메시지 잠금 해제하기", - "@unlockOldMessages": {}, - "numChats": "{number}개의 채팅", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "optionalRedactReason": "(선택) 이 메시지를 편집하는 이유...", - "@optionalRedactReason": {}, - "archiveRoomDescription": "채팅이 보관함으로 이동합니다. 다른 유저들은 당신이 떠난다는것을 볼 수 있습니다.", - "@archiveRoomDescription": {}, - "exportEmotePack": ".zip 파일로 이모트 내보내기", - "@exportEmotePack": {}, - "switchToAccount": "계정 {number}로 전환", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "pleaseEnterRecoveryKeyDescription": "오래된 메시지를 잠금 해제하려면, 이전 세션에서 생성된 복호화 키를 입력하세요. 복호화 키는 비밀번호가 아닙니다.", - "@pleaseEnterRecoveryKeyDescription": {}, - "inviteContactToGroupQuestion": "{contact} 를 \"{groupName}\"에 초대할까요?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "{username}님이 삭제함. 사유: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "{user}에 대한 초대를 철회함", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "appearOnTopDetails": "앱이 상단에 표시되도록 허용 (이미 FluffyChat을 통화 계정으로 설정한 경우에는 필요하지 않음)", - "@appearOnTopDetails": {}, - "enterRoom": "방에 입장", - "@enterRoom": {}, - "youInvitedUser": "📩 {user}를 초대했습니다", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "fileHasBeenSavedAt": "{path}에 파일 저장됨", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "redactMessageDescription": "메시지는 이 대화의 모든 참여자에게 삭제될 것 입니다. 되돌릴 수 없습니다.", - "@redactMessageDescription": {}, - "recoveryKey": "복구키", - "@recoveryKey": {}, - "invalidInput": "잘못된 입력!", - "@invalidInput": {}, - "dehydrateTorLong": "TOR 사용자들은 창을 닫기 전에 세션을 내보내는것이 권장됩니다.", - "@dehydrateTorLong": {}, - "doNotShowAgain": "다시 보지 않기", - "@doNotShowAgain": {}, - "report": "신고", - "@report": {}, - "hideUnimportantStateEvents": "중요하지 않은 상태 이벤트 숨기기", - "@hideUnimportantStateEvents": {}, - "screenSharingTitle": "화면 공유", - "@screenSharingTitle": {}, - "widgetCustom": "사용자 정의", - "@widgetCustom": {}, - "youBannedUser": "{user}을 영구 추방함", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "addChatDescription": "채팅 설명 추가하기...", - "@addChatDescription": {}, - "hasKnocked": "🚪 {user}가 참가를 요청했습니다", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "openLinkInBrowser": "브라우저에서 링크 열기", - "@openLinkInBrowser": {}, - "disableEncryptionWarning": "보안상의 이유로 암호화가 활성화된 채팅에서 암호화를 비활성화 할 수 없습니다.", - "@disableEncryptionWarning": {}, - "directChat": "다이렉트 채팅", - "@directChat": {}, - "wrongPinEntered": "잘못된 pin입니다! {seconds}초 후에 다시 시도하세요...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "입력 알림 보내기", - "@sendTypingNotifications": {}, - "inviteGroupChat": "📨 그룹 채팅에 초대", - "@inviteGroupChat": {}, - "appearOnTop": "상단에 표시", - "@appearOnTop": {}, - "invitePrivateChat": "📨 비공개 채팅에 초대", - "@invitePrivateChat": {}, - "foregroundServiceRunning": "이 알림은 백그라운드 서비스가 실행중일때 표시됩니다.", - "@foregroundServiceRunning": {}, - "importEmojis": "이모지 불러오기", - "@importEmojis": {}, - "wasDirectChatDisplayName": "빈 채팅 (전 {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noChatDescriptionYet": "채팅 설명이 아직 추가되지 않음.", - "@noChatDescriptionYet": {}, - "learnMore": "더 알아보기", - "@learnMore": {}, - "notAnImage": "이미지 파일이 아닙니다.", - "@notAnImage": {}, - "users": "유저", - "@users": {}, - "chatDescriptionHasBeenChanged": "채팅 설명 변경됨", - "@chatDescriptionHasBeenChanged": {}, - "newGroup": "새 그룹 채팅", - "@newGroup": {}, - "dehydrateTor": "TOR 사용자: 세션 내보내기", - "@dehydrateTor": {}, - "roomUpgradeDescription": "채팅이 새로운 방 버전으로 다시 생성됩니다. 모든 참가자는 새로운 채팅으로 전환해야합니다. https://spec.matrix.org/latest/rooms/ 에서 방 버전에 대해 자세히 알아볼 수 있습니다.", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "0보다 큰 숫자를 입력하세요", - "@pleaseEnterANumber": {}, - "youKicked": "👞 {user}를 추방했습니다", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "profileNotFound": "유저를 서버에서 찾을 수 있습니다. 연결 문제가 있거나 유저가 존재하지 않을 수 있습니다.", - "@profileNotFound": {}, - "jump": "점프", - "@jump": {}, - "sorryThatsNotPossible": "죄송합니다...그것은 불가능합니다", - "@sorryThatsNotPossible": {}, - "shareInviteLink": "초대 링크 공유", - "@shareInviteLink": {}, - "commandHint_markasdm": "Matrix ID를 위한 다이렉트 메시지 방으로 표시", - "@commandHint_markasdm": {}, - "recoveryKeyLost": "복구키를 분실하셨나요?", - "@recoveryKeyLost": {}, - "cuddleContent": "{senderName} 님이 당신에게 미소짓습니다", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "deviceKeys": "기기 키:", - "@deviceKeys": {}, - "emoteKeyboardNoRecents": "최근 사용한 이모트가 여기 나타납니다...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "테마 설정:", - "@setTheme": {}, - "youJoinedTheChat": "채팅에 참여했습니다", - "@youJoinedTheChat": {}, - "widgetName": "이름", - "@widgetName": {}, - "errorAddingWidget": "위젯 추가중 오류 발생.", - "@errorAddingWidget": {}, - "commandHint_hug": "허그 보내기", - "@commandHint_hug": {}, - "replace": "대체", - "@replace": {}, - "youUnbannedUser": "{user}의 영구 추방을 해제했습니다", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "newSpace": "새 스페이스", - "@newSpace": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "나중에 다시 시도하거나 다른 서버를 선택하십시오.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "새 그룹 채팅", - "@createGroup": {}, - "hydrateTorLong": "지난 TOR 이용에서 세션을 내보내셨나요? 빠르게 불러오고 채팅을 계속하세요.", - "@hydrateTorLong": {}, - "custom": "커스텀", - "@custom": {}, - "noBackupWarning": "경고! 채팅 백업을 켜지 않을경우, 당신은 암호화된 메시지에대한 접근권한을 잃을것입니다. 로그아웃 하기 전에 채팅을 백업하는것이 강력히 권장됩니다.", - "@noBackupWarning": {}, - "storeInSecureStorageDescription": "이 기기의 보안 스토리지에 복구키를 저장합니다.", - "@storeInSecureStorageDescription": {}, - "kickUserDescription": "유저는 채팅에서 추방되지만 영구 추방되지 않습니다. 공개 채팅의 경우, 언제든 유저가 다시 들어올 수 있습니다.", - "@kickUserDescription": {}, - "importNow": "지금 불러오기", - "@importNow": {}, - "invite": "초대", - "@invite": {}, - "indexedDbErrorTitle": "사생활 보호 모드의 문제", - "@indexedDbErrorTitle": {}, - "storeSecurlyOnThisDevice": "이 기기에 안전하게 저장", - "@storeSecurlyOnThisDevice": {}, - "screenSharingDetail": "FluffyChat에 당신의 화면을 공유하는중", - "@screenSharingDetail": {}, - "blockUsername": "유저 이름 무시", - "@blockUsername": {}, - "block": "차단", - "@block": {}, - "blockedUsers": "차단된 유저", - "@blockedUsers": {}, - "groupName": "그룹 채팅 이름", - "@groupName": {}, - "commandHint_sendraw": "raw json 전송", - "@commandHint_sendraw": {}, - "pleaseChooseAStrongPassword": "강력한 비밀번호를 사용하세요", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "채팅 또는 하위 스페이스 추가", - "@addChatOrSubSpace": {}, - "subspace": "하위 스페이스", - "@subspace": {}, - "youInvitedToBy": "📩 링크를 통해 초대되셨습니다:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "databaseMigrationBody": "잠시만 기다리세요. 시간이 걸릴 수 있습니다.", - "@databaseMigrationBody": {}, - "select": "선택", - "@select": {}, - "joinSpace": "스페이스 가입", - "@joinSpace": {}, - "decline": "거절", - "@decline": {}, - "formattedMessagesDescription": "마크다운을 이용한 볼드등의 서식이 있는 메시지를 봅니다.", - "@formattedMessagesDescription": {}, - "completedKeyVerification": "{sender}가 키 검증을 완료함", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender}가 키 검증을 취소함", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "createGroupAndInviteUsers": "그룹 채팅을 생성하고 유저를 초대", - "@createGroupAndInviteUsers": {}, - "passwordsDoNotMatch": "비밀번호가 일치하지 않습니다", - "@passwordsDoNotMatch": {}, - "passwordIsWrong": "비밀번호가 틀립니다", - "@passwordIsWrong": {}, - "publicLink": "공개 링크", - "@publicLink": {}, - "thisDevice": "이 기기:", - "@thisDevice": {}, - "sendReadReceipts": "읽음 확인 보내기", - "@sendReadReceipts": {}, - "sendReadReceiptsDescription": "채팅의 다른 참가자들이 당신이 메시지를 읽었는지 볼 수 있습니다.", - "@sendReadReceiptsDescription": {}, - "verifyOtherUser": "🔐 다른 유저 확인", - "@verifyOtherUser": {}, - "hidePresences": "상태 목록을 숨길까요?", - "@hidePresences": {}, - "searchChatsRooms": "#chats, @users 검색...", - "@searchChatsRooms": {}, - "groupCanBeFoundViaSearch": "검색으로 그룹 채팅을 찾을 수 있음", - "@groupCanBeFoundViaSearch": {}, - "restoreSessionBody": "앱이 백업에서 세션을 복원하려 시도중입니다. {url} 에서 개발자에게 오류를 신고하세요. 오류 메시지는 다음과 같습니다: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "acceptedKeyVerification": "{sender}가 키 검증을 수락함", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "presencesToggle": "다른 유저의 상태 메시지 표시", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "wrongRecoveryKey": "죄송합니다... 올바른 복구키가 아닌것 같습니다.", - "@wrongRecoveryKey": {}, - "newPassword": "새 비밀번호", - "@newPassword": {}, - "searchForUsers": "@users 검색...", - "@searchForUsers": {}, - "leaveEmptyToClearStatus": "비워서 상태를 지우세요.", - "@leaveEmptyToClearStatus": {}, - "commandHint_ignore": "주어진 matrix ID를 무시", - "@commandHint_ignore": {}, - "commandHint_unignore": "주어진 matrix ID 무시 해제", - "@commandHint_unignore": {}, - "blockListDescription": "당신은 당신을 방해하는 유저들을 차단할 수 있습니다. 당신은 당신의 개인 차단 목록에 있는 어떠한 유저의 메시지와 방 초대도 받지 않을것 입니다.", - "@blockListDescription": {}, - "presenceStyle": "상태:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "sessionLostBody": "세션을 잃었습니다. {url} 에서 개발자에게 오류를 신고하세요. 오류 메시지는 다음과 같습니다: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "yourGlobalUserIdIs": "글로벌 유저 ID: ", - "@yourGlobalUserIdIs": {}, - "noUsersFoundWithQuery": "안타깝게도 \"{query}\"로 유저를 찾을 수 없습니다. 오타가 없는지 확인하십시오.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "nothingFound": "아무것도 찾지 못했습니다...", - "@nothingFound": {}, - "startConversation": "대화 시작", - "@startConversation": {}, - "databaseMigrationTitle": "데이터베이스가 최적화됨", - "@databaseMigrationTitle": {}, - "pleaseEnterYourCurrentPassword": "현재 비밀번호 입력", - "@pleaseEnterYourCurrentPassword": {}, - "publicSpaces": "공개 스페이스들", - "@publicSpaces": {}, - "initAppError": "앱 초기화중 오류 발생", - "@initAppError": {}, - "databaseBuildErrorBody": "SQlite 데이터베이스를 구축할 수 없습니다. 현재 레거시 데이터베이스 사용을 시도중입니다. {url} 에서 개발자에게 오류를 신고하세요. 오류 메시지는 다음과 같습니다: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sendTypingNotificationsDescription": "채팅의 다른 참가자들이 당신이 새 메시지를 입력중인것을 볼 수 있습니다.", - "@sendTypingNotificationsDescription": {}, - "formattedMessages": "형식이 지정된 메시지", - "@formattedMessages": {}, - "forwardMessageTo": "{roomName}에 메시지를 전달할까요?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "verifyOtherDevice": "🔐 다른 기기를 확인", - "@verifyOtherDevice": {}, - "verifyOtherUserDescription": "다른 유저를 확인하면, 당신은 당신이 누구에게 말하고있는지 알 수 있습니다. 💪\n\n확인을 시작할 때, 다른 유저는 앱에서 팝업을 볼 수 있습니다. 당신은 그런 다음 서로 비교해야 이모지 또는 숫자의 목록을 볼 수 있습니다.\n\n이 작업을 수행하는 가장 좋은 방법은 직접 만나거나 영상통화를 하는것입니다. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "다른 장치를 확인하면, 장치와 키를 교환하고, 전반적인 보안을 증가시킵니다. 💪 확인을 시작하면 팝업은 두 장치에 나타납니다. 그런 다음 서로 비교해야 이모지 또는 숫자의 목록를 볼 수 있습니다. 확인을 시작하기 전에 모든 장치를 준비하세요. 🤳", - "@verifyOtherDeviceDescription": {}, - "isReadyForKeyVerification": "{sender}가 키 검증 준비를 완료함", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender}가 키 검증을 요청함", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender}가 키 검증을 시작함", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "투명", - "@transparent": {}, - "incomingMessages": "메시지 수신함", - "@incomingMessages": {}, - "stickers": "스티커", - "@stickers": {}, - "discover": "탐색", - "@discover": {}, - "unreadChatsInApp": "{appname}: {unread}개의 읽지 않은 채팅", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "appLockDescription": "앱을 사용하지 않을 때 pin으로 잠금", - "@appLockDescription": {}, - "calls": "전화", - "@calls": {}, - "globalChatId": "글로벌 채팅 ID", - "@globalChatId": {}, - "customEmojisAndStickers": "커스텀 이모지와 스티커", - "@customEmojisAndStickers": {}, - "accessAndVisibilityDescription": "채팅에 참여 할 수 있는 사람과 채팅을 볼 수 있는 범위", - "@accessAndVisibilityDescription": {}, - "accessAndVisibility": "채팅 가입과 대화 기록", - "@accessAndVisibility": {}, - "customEmojisAndStickersBody": "모든 채팅에서 사용할 수있는 커스텀 이모지와 스티커를 추가하거나 공유합니다.", - "@customEmojisAndStickersBody": {}, - "hideRedactedMessages": "삭제된 메시지 숨기기", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "누군가가 메시지를 삭제하면 메시지를 더 이상 볼 수 없습니다.", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "잘못되거나 알 수 없는 메시지 형식 숨김", - "@hideInvalidOrUnknownMessageFormats": {}, - "overview": "개요", - "@overview": {}, - "notifyMeFor": "나에게 알림", - "@notifyMeFor": {}, - "passwordRecoverySettings": "비밀번호 복구 설정", - "@passwordRecoverySettings": {}, - "hideMemberChangesInPublicChats": "공개 채팅에서의 참가자 변화 숨김", - "@hideMemberChangesInPublicChats": {}, - "userWouldLikeToChangeTheChat": "{user}가 참가를 희망합니다.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "공개 링크가 아직 생성되지 않았음", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "참가 요청", - "@knock": {}, - "usersMustKnock": "유저들이 참가를 허가받아야함", - "@usersMustKnock": {}, - "knocking": "참가 요청중", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "채팅은 {server} 에서 검색하여 찾을 수 있습니다.", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "noOneCanJoin": "아무도 들어올 수 없음", - "@noOneCanJoin": {}, - "thereAreCountUsersBlocked": "여기 {count}명의 차단된 유저가 있습니다.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "minimumPowerLevel": "{level}은 최소 권한 레벨입니다.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "noDatabaseEncryption": "데이터베이스 암호화는 이 플랫폼에서 지원되지 않음", - "@noDatabaseEncryption": {}, - "publicChatAddresses": "공개 채팅 주소", - "@publicChatAddresses": {}, - "userRole": "유저 역할", - "@userRole": {}, - "createNewAddress": "새 주소 만들기", - "@createNewAddress": {}, - "hideMemberChangesInPublicChatsBody": "공개채팅에 누군가가 가입하거나 떠날때 타임라인에 표시하지 않습니다.", - "@hideMemberChangesInPublicChatsBody": {}, - "searchMore": "더 검색...", - "@searchMore": {}, - "files": "파일", - "@files": {}, - "searchIn": "{chat}에서 검색...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "gallery": "갤러리", - "@gallery": {}, - "restricted": "스페이스 멤버로 제한", - "@restricted": {}, - "knockRestricted": "스페이스 멤버만 참가 요청 가능", - "@knockRestricted": {}, - "swipeRightToLeftToReply": "오른쪽에서 왼쪽으로 스와이프해서 답장", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_lv.arb b/assets/l10n/intl_lv.arb deleted file mode 100644 index 03543548d..000000000 --- a/assets/l10n/intl_lv.arb +++ /dev/null @@ -1,2687 +0,0 @@ -{ - "showPassword": "Rādīt paroli", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "hugContent": "{senderName} apskauj Tevi", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "darkTheme": "Tumšs", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "paroles vārdkopa vai atkopšanas atslēga", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Lūgums ievadīt savu paroli", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Tie sakrīt", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "connect": "Savienot", - "@connect": { - "type": "text", - "placeholders": {} - }, - "jumpToLastReadMessage": "Pārlēkt uz pēdējo izlasīto ziņu", - "@jumpToLastReadMessage": {}, - "allRooms": "Visas kopu tērzēšanas", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Iegūst atrašanās vietu…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "commandHint_cuddle": "Nosūtīt samīļojienu", - "@commandHint_cuddle": {}, - "chats": "Tērzēšanas", - "@chats": { - "type": "text", - "placeholders": {} - }, - "widgetVideo": "Video", - "@widgetVideo": {}, - "dismiss": "Atmest", - "@dismiss": {}, - "unknownDevice": "Nezināma ierīce", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Emocijas īskods", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Šifrēšanu var iespējot tikai tad, kad istaba vairs nav publiski pieejama.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "admin": "Pārvaldītājs", - "@admin": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "😭 Ak nē! Kaut kas nogāja greizi. Ja ir vēlēšanas, par šo nepilnību var ziņot izstrādātājiem.", - "@reportErrorDescription": {}, - "directChats": "Tiešās tērzēšanas", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Iestatīt atļauju līmeni", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Uzaicināt kontaktpersonu {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "addAccount": "Pievienot kontu", - "@addAccount": {}, - "close": "Aizvērt", - "@close": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Konfigurēt tērzēšanu", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Šai vietai tika pievienota tērzēšana", - "@chatHasBeenAddedToThisSpace": {}, - "reply": "Atbildēt", - "@reply": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Pašreiz darbīgi", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Noņemt savu attēlu", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "unsupportedAndroidVersion": "Neatbalstīta Android versija", - "@unsupportedAndroidVersion": {}, - "device": "Ierīce", - "@device": { - "type": "text", - "placeholders": {} - }, - "blockDevice": "Liegt ierīci", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "commandHint_html": "Nosūtīt ar HTML formatētu tekstu", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "youAreNoLongerParticipatingInThisChat": "Tu vairs nepiedalies šajā tērzēšanā", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "encryption": "Šifrēšana", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "messageType": "Ziņas veids", - "@messageType": {}, - "indexedDbErrorLong": "Diemžēl ziņu krātuve pēc noklusējuma nav iespējota privātajā režīmā.\nLūgums apmeklēt\n - about:config\n - iestatīt dom.indexedDB.privateBrowsing.enabled kā true\nPretējā gadījumā nav iespējams palaist FluffyChat.", - "@indexedDbErrorLong": {}, - "oneClientLoggedOut": "Viens no klientiem ir atteicies", - "@oneClientLoggedOut": {}, - "toggleMuted": "Pārslēgt apklusināšanu", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "unsupportedAndroidVersionLong": "Šai iespējai ir nepieciešama jaunāka Android versija. Lūgums pārbaudīt atjauninājumus vai Lineage OS atbalstu.", - "@unsupportedAndroidVersionLong": {}, - "kicked": "👞 {username} izmeta {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Mainīt kopas nosaukumu", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} nomainīja tērzēšanas attēlu", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "verifySuccess": "Apliecināšana veiksmīga.", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Nosūtīt datni", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Jauns apliecināšanas pieprasījums.", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "startFirstChat": "Uzsāc savu pirmo tērzēšanu", - "@startFirstChat": {}, - "callingAccount": "Zvanīšanas konts", - "@callingAccount": {}, - "requestPermission": "Pieprasīt atļauju", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "sentAPicture": "🖼️ {username} nosūtīja attēlu", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "invited": "Uzaicināts", - "@invited": { - "type": "text", - "placeholders": {} - }, - "changedTheDisplaynameTo": "{username} nomainīja savu attēlojamo vārdu uz '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "setColorTheme": "Iestatīt krāsu izskatu:", - "@setColorTheme": {}, - "nextAccount": "Nākamais konts", - "@nextAccount": {}, - "commandHint_create": "Izveidot tukšu kopas tērzēšanu\nLai atspējotu šifrēšanu, jāizmanto --no-encryption", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "singlesignon": "Vienotā pieteikšanās", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "warning": "Uzmanību!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "password": "Parole", - "@password": { - "type": "text", - "placeholders": {} - }, - "allSpaces": "Visas vietas", - "@allSpaces": {}, - "supposedMxid": "Tam būtu jābūt {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "editDisplayname": "Labot attēlojamo vārdu", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "user": "Lietotājs", - "@user": {}, - "roomVersion": "Istabas versija", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} nosūtīja datni", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "videoCall": "Videozvans", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "youAcceptedTheInvitation": "👍 Tu pieņēmi uzaicinājumu", - "@youAcceptedTheInvitation": {}, - "banFromChat": "Izslēgt no tērzēšanas", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} nav Matrix serveris, tā vietā izmantot {server2}?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "userAndOthersAreTyping": "{username} un {count} citi raksta…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "youInvitedBy": "📩 {user} Tevi uzaicināja", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "userIsTyping": "{username} raksta…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "openAppToReadMessages": "Atvērt lietotni, lai lasītu ziņas", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "sentAVideo": "🎥 {username} nosūtīja video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banUserDescription": "Lietotājam tiks liegta piekļuve tērzēšanai, un vairs nevarēs vēlreiz pievienoties tērzēšanai, līdz liegums tiks atcelts.", - "@banUserDescription": {}, - "inviteContact": "Uzaicināt kontaktpersonu", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Lai varētu parakstīt otru cilvēku, lūgums ievadīt savu drošo krātuves paroles vārdkopu vai atkopšanas atslēgu.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "widgetEtherpad": "Teksta piezīme", - "@widgetEtherpad": {}, - "waitingPartnerAcceptRequest": "Gaida, līdz biedrs apstiprinās pieprasījumu…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "remove": "Noņemt", - "@remove": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Rakstīt ziņu…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Mainīt izskatu", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "id": "Id", - "@id": { - "type": "text", - "placeholders": {} - }, - "removeDevicesDescription": "Tu tiksi izrakstīts no šīs ierīces un vairs nevarēsi saņemt ziņas.", - "@removeDevicesDescription": {}, - "changedTheChatDescriptionTo": "{username} nomainīja tērzēšanas aprakstu uz '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "countParticipants": "{count} dalībnieki", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "separateChatTypes": "Atdalīt tiešās tērzēšanas un kopas", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "tryAgain": "Jāmēģina vēlreiz", - "@tryAgain": {}, - "areGuestsAllowedToJoin": "Vai vieslietotājiem ir ļauts pievienoties", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "blocked": "Liegta", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "youKickedAndBanned": "🙅 Izraidīji {user} un liedzi piekļuvi", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "dateWithoutYear": "{day}.{month}.", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "removeDevice": "Noņemt ierīci", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanUserDescription": "Lietotājs varēs atkal pievienoties tērzēšanai, ja mēģinās.", - "@unbanUserDescription": {}, - "userAndUserAreTyping": "{username} un {username2} raksta…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "pleaseClickOnLink": "Lūgums klikšķināt uz saites e-pastā un tad turpināt.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Saglabāt datni", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "Nosūtīt ar Enter", - "@sendOnEnter": {}, - "pickImage": "Izvēlēties attēlu", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} atbildēja uz zvanu", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "youRejectedTheInvitation": "Tu noraidīji uzaicinājumu", - "@youRejectedTheInvitation": {}, - "otherCallingPermissions": "Mikrofons, kamera un citas FluffyChat atļaujas", - "@otherCallingPermissions": {}, - "messagesStyle": "Ziņas:", - "@messagesStyle": {}, - "couldNotDecryptMessage": "Nevarēja atšifrēt ziņu: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "invitedUsersOnly": "Tikai uzaicināti lietotāji", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "link": "Saite", - "@link": {}, - "widgetUrlError": "Tas nav derīgs URL.", - "@widgetUrlError": {}, - "emailOrUsername": "E-pasta adrese vai lietotājvārds", - "@emailOrUsername": {}, - "newSpaceDescription": "Vietas ļauj apvienot tērzēšanas un būvēt privātas vai publiskas kopienas.", - "@newSpaceDescription": {}, - "chatDescription": "Tērzēšanas apraksts", - "@chatDescription": {}, - "callingAccountDetails": "Ļauj FluffyChat izmantot iebūvēto Android zvanīšanas lietotni.", - "@callingAccountDetails": {}, - "next": "Nākamais", - "@next": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Lūgums sekot norādēm tīmekļvietnē un piesist \"Nākamais\".", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "changedTheGuestAccessRules": "{username} nomainīja viesu piekļuves nosacījumus", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "dateWithYear": "{day}.{month}.{year}.", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "editRoomAliases": "Labot istabu aizstājvārdus", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "enterSpace": "Ieiet vietā", - "@enterSpace": {}, - "encryptThisChat": "Šifrēt šo tērzēšanu", - "@encryptThisChat": {}, - "fileName": "Datnes nosaukums", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Nav pieejams", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "previousAccount": "Iepriekšējais konts", - "@previousAccount": {}, - "publicRooms": "Publiskas istabas", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "No uzaicinājuma", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Nosūtīt ziņas", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Nepareiza paroles vārdkopa vai atkopšanas atslēga", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Nepieciešams izvēlēties emocijas īskodu un attēlu.", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "reopenChat": "Atkārtoti atvērt tērzēšanu", - "@reopenChat": {}, - "pleaseEnterRecoveryKey": "Lūgums ievadīt savu atkopšanas atslēgu:", - "@pleaseEnterRecoveryKey": {}, - "create": "Izveidot", - "@create": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Pārslēgt iecienīto", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "no": "Nē", - "@no": { - "type": "text", - "placeholders": {} - }, - "alias": "aizstājvārds", - "@alias": { - "type": "text", - "placeholders": {} - }, - "widgetNameError": "Lūgums norādīt attēlojamo nosaukumu.", - "@widgetNameError": {}, - "inoffensive": "Nav aizskarošs", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "unpin": "Atspraust", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "addToBundle": "Pievienot komplektam", - "@addToBundle": {}, - "reportMessage": "Ziņot par ziņu", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Vieta ir publiska", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "addWidget": "Pievienot logrīku", - "@addWidget": {}, - "all": "Viss", - "@all": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Noņemt visas pārējās ierīces", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "unblockDevice": "Atslēgt ierīci", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "countFiles": "{count} datnes", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "noKeyForThisMessage": "Tas var notikt, ja ziņa tika nosūtīta, pirms pieteicies savā kontā šajā ierīcē.\n\nIr arī iespējams, ka sūtītājs noliedza Tavu ierīci vai kaut kas nogāja greizi ar interneta savienojumu.\n\nVai ziņas ir lasāmas citā sesijā? Tad Tu vari pārsūtīt ziņo no tās. Jādodas uz Iestatījumi > Ierīces un jāpārliecinās, ka ierīces viena otru ir apliecinājušas. Kad nākamreiz atvērsi istabu un abas sesijas būs priekšplānā, atslēgas tiks automātiski pārsūtītas.\n\nVai nevēlies zaudēt atslēgas, kad atsakies vai maini ierīces? Jāpārliecinās, ka iestatījumos ir iespējota tērzēšanas rezerves kopija.", - "@noKeyForThisMessage": {}, - "enableEncryptionWarning": "Vairs nebūs iespējams atspējot šifrēšanu. Vai tiešām to darīt?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} uzaicināja pievienoties FluffyChat.\n1. Jāapmeklē fluffychat.im un jāuzstāda lietotne \n2. Jāizveido konts vai jāpiesakās \n3. Jāatver uzaicinājuma saite: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "shareLocation": "Kopīgot atrašanās vietu", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "reason": "Iemesls", - "@reason": { - "type": "text", - "placeholders": {} - }, - "commandHint_markasgroup": "Atzīmēt kā kopu", - "@commandHint_markasgroup": {}, - "errorObtainingLocation": "Kļūda atrašanās vietas iegūšanā: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "hydrateTor": "TOR lietotāji: ievietot sesijas izguvi", - "@hydrateTor": {}, - "pushNotificationsNotAvailable": "Pašpiegādes paziņojumi nav pieejami", - "@pushNotificationsNotAvailable": {}, - "passwordRecovery": "Paroles atjaunošana", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "storeInAppleKeyChain": "Glabāt Apple KeyChain", - "@storeInAppleKeyChain": {}, - "replaceRoomWithNewerVersion": "Aizvietot istabu ar jaunāku versiju", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "hydrate": "Atjaunot no rezerves kopijas datnes", - "@hydrate": {}, - "invalidServerName": "Nederīgs servera nosaukums", - "@invalidServerName": {}, - "chatPermissions": "Tērzēšanas atļaujas", - "@chatPermissions": {}, - "voiceMessage": "Balss ziņa", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "Mājasserveris nodrošina pieteikšanās veidus:\n{serverVersions}\nSavukārt, šī lietotne atbalsta tikai:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "wipeChatBackup": "Notīrīt tērzēšanas rezerves kopiju, lai izveidotu jaunu atkopšanas atslēgu?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Nevar atvērt adresi {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "sender": "Sūtītājs", - "@sender": {}, - "storeInAndroidKeystore": "Glabāt Android KeyStore", - "@storeInAndroidKeystore": {}, - "hideRedactedEvents": "Paslēpt labošanas notikumus", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "online": "Tiešsaistē", - "@online": { - "type": "text", - "placeholders": {} - }, - "signInWithPassword": "Pieteikties ar paroli", - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Pēdējoreiz redzēts: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} nomainīja viesu piekļuves nosacījumus uz {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "weSentYouAnEmail": "Mēs nosūtīja e-pasta ziņu", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "offensive": "Aizskarošs", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Lūgums ņemt vērā, ka pagaidām ir nepieciešams Pantalaimon, lai izmantotu pilnīgu šifrēšanu.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "makeAdminDescription": "Tiklīdz šis lietotājs tiks padarīts par pārvaldītāju, to vairs nevarēs atdarīt, jo tad tam būs tādas pašas atļaujas kā Tev.", - "@makeAdminDescription": {}, - "edit": "Labot", - "@edit": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Ielādēt vēl…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Netika atrastas emocijas. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Sinhronizē... Lūgums uzgaidīt.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Pārnest no citas ierīces", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Parole tikai nomainīta", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Pašpiegādes nosacījumi", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Doties uz jauno istabu", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "commandHint_clearcache": "Iztīrīt kešatmiņu", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "loadingPleaseWait": "Ielādē... Lūgums uzgaidīt.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "copy": "Ievietot starpliktuvē", - "@copy": { - "type": "text", - "placeholders": {} - }, - "saveKeyManuallyDescription": "Šo atslēgu var pašrocīgi saglabāt ar sistēmas kopīgošanas dialogloga vai starpliktuves izsaukšanu.", - "@saveKeyManuallyDescription": {}, - "none": "Neviens", - "@none": { - "type": "text", - "placeholders": {} - }, - "editBundlesForAccount": "Labot šī konta komplektus", - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Iespējot šifrēšanu", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "whyIsThisMessageEncrypted": "Kādēļ šī ziņa ir nelasāma?", - "@whyIsThisMessageEncrypted": {}, - "unreadChats": "{unreadCount, plural, zero{{unreadCount} nelasītu tērzēšanu} =1{{unreadCount} nelasīta tērzēšana} other{{unreadCount} nelasītas tērzēšanas}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "rejectedTheInvitation": "{username} noraidīja uzaicinājumu", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "setChatDescription": "Iestatīt tērzēšanas aprakstu", - "@setChatDescription": {}, - "userLeftTheChat": "🚪 {username} pameta tērzēšanu", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "spaceName": "Vietas nosaukums", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "importFromZipFile": "Ievietot no .zip datnes", - "@importFromZipFile": {}, - "toggleUnread": "Atzīmēt kā lasītu/nelasītu", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "or": "Vai", - "@or": { - "type": "text", - "placeholders": {} - }, - "dehydrateWarning": "Šī darbība nav atdarāma. Jānodrošina, ka rezerves kopijas datne tiek droši uzglabāta.", - "@dehydrateWarning": {}, - "sendOriginal": "Nosūtīt sākotnējo", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "noOtherDevicesFound": "Netika atrastas citas ierīces", - "@noOtherDevicesFound": {}, - "whoIsAllowedToJoinThisGroup": "Kuram ir ļauts pievienoties šai kopai", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Tukša tērzēšana", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "{username} redzēja", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "storeSecurlyOnThisDevice": "Droši uzglabāt šajā ierīcē", - "@storeSecurlyOnThisDevice": {}, - "yourChatBackupHasBeenSetUp": "Tērzēšanas rezerves kopēšana tika iestatīta.", - "@yourChatBackupHasBeenSetUp": {}, - "chatBackup": "Tērzēšanas rezerves kopēšana", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "redactedBy": "Laboja {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "submit": "Iesniegt", - "@submit": { - "type": "text", - "placeholders": {} - }, - "videoCallsBetaWarning": "Lūgums ņemt vērā, ka video zvani pašreiz ir beta stāvoklī. Tie visās platformās var nedarboties kā paredzēs vai pat nedarboties vispār.", - "@videoCallsBetaWarning": {}, - "unmuteChat": "Atcelt tērzēšanas apklusināšanu", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} izveidoja tērzēšanu", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactedAnEvent": "{username} laboja notikumu", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Automātiski atskaņot animētas uzlīmes un emocijas", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "compareEmojiMatch": "Lūgums salīdzināt emocijzīmes", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "participant": "Dalībnieks", - "@participant": { - "type": "text", - "placeholders": {} - }, - "logInTo": "PIeteikties {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "yes": "Jā", - "@yes": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Satur attēlojamo vārdu", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "signInWith": "Pieteikties ar {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "username": "Lietotājvārds", - "@username": { - "type": "text", - "placeholders": {} - }, - "changedTheRoomAliases": "{username} nomainīja istabas aizstājvārdus", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "fileIsTooBigForServer": "Serveris ziņo, ka datne ir pārāk liela, lai to nosūtītu.", - "@fileIsTooBigForServer": {}, - "homeserver": "Mājasserveris", - "@homeserver": {}, - "help": "Palīdzība", - "@help": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Tērzēšanas izvērsums", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "people": "Cilvēki", - "@people": { - "type": "text", - "placeholders": {} - }, - "changedTheHistoryVisibilityTo": "{username} nomainīja vēstures redzamību uz {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "leftTheChat": "Pameta tērzēšanu", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "verified": "Apliecināta", - "@verified": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Atkārtot paroli", - "@repeatPassword": {}, - "setStatus": "Iestatīt stāvokli", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Kopa ar {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "callingPermissions": "Zvanīšanas atļaujas", - "@callingPermissions": {}, - "delete": "Izdzēst", - "@delete": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Jauna ziņa FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "readUpToHere": "Izlasīts līdz šejienei", - "@readUpToHere": {}, - "start": "Uzsākt", - "@start": {}, - "downloadFile": "Lejupielādēt datni", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Ierīces Id", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "register": "Reģistrēties", - "@register": { - "type": "text", - "placeholders": {} - }, - "unlockOldMessages": "Atslēgt vecās ziņas", - "@unlockOldMessages": {}, - "identity": "Identitāte", - "@identity": { - "type": "text", - "placeholders": {} - }, - "numChats": "{number} tērzēšanas", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "changedTheJoinRulesTo": "{username} nomainīja pievienošanās nosacījumus uz {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "recording": "Ieraksta", - "@recording": { - "type": "text", - "placeholders": {} - }, - "changedTheChatPermissions": "{username} nomainīja tērzēšanas atļaujas", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "moderator": "Moderators", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "optionalRedactReason": "(Pēc izvēles) Ziņas labošanas iemesls...", - "@optionalRedactReason": {}, - "acceptedTheInvitation": "👍 {username} pieņēma uzaicinājumu", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "waitingPartnerEmoji": "Gaida, līdz biedrs apstiprinās emocijzīmi…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Šifrēšana tika bojāta", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Mēģināt nosūtīt vēlreiz", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Viesi var pievienoties", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "ok": "Labi", - "@ok": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Ievietot starpliktuvē", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "dehydrate": "Izgūt sesiju un iztīrīt ierīci", - "@dehydrate": {}, - "locationPermissionDeniedNotice": "Atrašanās vietas atļauja noliegta. Lūgums nodrošināt to, lai būtu iespējams kopīgot savu atrašanās vietu.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "send": "Nosūtīt", - "@send": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} atsauca uzaicinājumu {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "visibleForAllParticipants": "Redzama visiem dalībniekiem", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Istabas netika atrastas…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "banned": "Izslēgts", - "@banned": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Nosūtīt kā tekstu", - "@sendAsText": { - "type": "text" - }, - "inviteForMe": "Uzaicinājums man", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "archiveRoomDescription": "Tērzēšana tiks pārvietota uz arhīvu. Citi lietotāji redzēs, ka pameti tērzēšanu.", - "@archiveRoomDescription": {}, - "exportEmotePack": "Izgūt emociju paku kā .zip", - "@exportEmotePack": {}, - "changedTheChatNameTo": "{username} nomainīja tērzēšanas nosaukumu uz '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "sendSticker": "Nosūtīt uzlīmi", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "account": "Konts", - "@account": { - "type": "text", - "placeholders": {} - }, - "switchToAccount": "Pārslēgties uz kontu {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "commandInvalid": "Nederīga komanda", - "@commandInvalid": { - "type": "text" - }, - "setAsCanonicalAlias": "Iestatīt kā galveno aizstājvārdu", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Kādēļ vēlies ziņot par šo?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Atrašanās vietas pakalpojumi ir atspējoti. Lūgums tos iespējot, lai būtu iespējams kopīgot savu atrašanās vietu.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "placeCall": "Veikt zvanu", - "@placeCall": {}, - "removedBy": "Noņēma {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} nomainīja uzaicinājuma saiti", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "newChat": "Jauna tērzēšana", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "notifications": "Paziņojumi", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "commandHint_plain": "Nosūtīt neformatētu tekstu", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "emoteSettings": "Emociju iestatījumi", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "experimentalVideoCalls": "Izmēģinājuma video zvani", - "@experimentalVideoCalls": {}, - "openCamera": "Atvērt kameru", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterRecoveryKeyDescription": "Lai atslēgtu savas vecās ziņas, lūgums ievadīt savu atkopšanas atslēgu, kas tika izveidota iepriekšējā sesijā. Atkopšanas atslēga NAV parole.", - "@pleaseEnterRecoveryKeyDescription": {}, - "guestsAreForbidden": "Viesi nav ļauti", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "mention": "Pieminēt", - "@mention": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Atvērt kartēs", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Ar šīm adresēm var atjaunot savu paroli.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroupQuestion": "Vai vēlies uzaicināt {contact} uz tērzēšanu \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "emoteExists": "Emocija jau pastāv.", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "redactedByBecause": "Laboja {username}, jo: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "isTyping": "raksta…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "youHaveWithdrawnTheInvitationFor": "Tu atsauci {user} uzaicinājumu", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "chat": "Tērzēšana", - "@chat": { - "type": "text", - "placeholders": {} - }, - "group": "Kopa", - "@group": { - "type": "text", - "placeholders": {} - }, - "leave": "Pamest", - "@leave": { - "type": "text", - "placeholders": {} - }, - "skip": "Izlaist", - "@skip": { - "type": "text", - "placeholders": {} - }, - "appearOnTopDetails": "Ļauj lietotnei parādīties virspusē (nav nepieciešams, ja FluffyChat jau ir iestatīts kā zvanīšanas konts)", - "@appearOnTopDetails": {}, - "roomHasBeenUpgraded": "Istaba tika atjaunināta", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "enterRoom": "Ieiet istabā", - "@enterRoom": {}, - "enableEmotesGlobally": "Iespējot kā vispārēju emociju paku", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Vai tiešām?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Lūgums izvēlēties piekļuves kodu", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Vēl nav pievienots paroles atjaunošanas veids.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "changedTheProfileAvatar": "{username} nomainīja savu attēlu", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "allChats": "Visas tērzēšanas", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "reportUser": "Ziņot par lietotāju", - "@reportUser": {}, - "sharedTheLocation": "{username} kopīgoja savu atrašanās vietu", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "commandHint_send": "Nosūtīt tekstu", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "onlineKeyBackupEnabled": "Tiešsaistes atslēgas rezerves kopēšana ir iespējota", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} atcēla {targetName} piekļuves liegumu", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "confirmEventUnpin": "Vai tiešām neatgriezeniski atspraust šo notikumu?", - "@confirmEventUnpin": {}, - "badServerVersionsException": "Mājasserveris nodrošina specifikācijas versijas:\n{serverVersions}\nSavukārt, lietotne atbalsta tikai {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "youInvitedUser": "📩 Tu uzaicināji {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "kickedAndBanned": "🙅 {username} izmeta {targetName} un liedza piekļuvi", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "noConnectionToTheServer": "Nav savienojuma ar serveri", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "fileHasBeenSavedAt": "Datne tika saglabāta {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "license": "Licence", - "@license": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Pievienot vietai", - "@addToSpace": {}, - "unbanFromChat": "Atcelt liegumu tērzēšanā", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "commandMissing": "{command} nav komanda.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "redactMessageDescription": "Ziņa tiks labota visiem šīs sarunas dalībniekiem. To nevar atdarīt.", - "@redactMessageDescription": {}, - "rejoin": "Pievienoties atkārtoti", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "recoveryKey": "Atkopšanas atslēga", - "@recoveryKey": {}, - "redactMessage": "Labot ziņu", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "forward": "Pārsūtīt", - "@forward": { - "type": "text", - "placeholders": {} - }, - "commandHint_discardsession": "Atmest sesiju", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "invalidInput": "Nederīga ievade.", - "@invalidInput": {}, - "about": "Par", - "@about": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Jāizvēlas spēcīga parole", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "dehydrateTorLong": "TOR lietotājiem ir ieteicams izgūt sesiju pirms loga aizvēršanas.", - "@dehydrateTorLong": {}, - "yourPublicKey": "Tava publiskā atslēga", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Pārāk daudz pieprasījumu. Lūgums vēlāk mēģināt vēlreiz.", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} uzaicināja {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Izmest no tērzēšanas", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "commandHint_myroomnick": "Iestatīt savu attēlojamo vārdu šajā istabā", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "offline": "Bezsaistē", - "@offline": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Nav atļaujas", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "doNotShowAgain": "Vairs nerādīt", - "@doNotShowAgain": {}, - "activatedEndToEndEncryption": "🔐 {username} iespējoja pilnīgu šifrēšanu", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "report": "ziņot", - "@report": {}, - "status": "Stāvoklis", - "@status": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Lūgums salīdzināt skaitļus", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Kopa ir publiska", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Uzsākt apliecināšanu", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Dalībnieku izmaiņas", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "Pievienoties istabai", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "unverified": "Neapliecināta", - "@unverified": {}, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Cik aizskarošs ir šis saturs?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "Šim serverim ir nepieciešams pārbaudīt Tavu e-pasta adresi reģistrācijai.", - "@serverRequiresEmail": {}, - "hideUnimportantStateEvents": "Paslēpt nebūtiskus stāvokļa notikumus", - "@hideUnimportantStateEvents": {}, - "screenSharingTitle": "ekrāna kopīgošana", - "@screenSharingTitle": {}, - "widgetCustom": "Pielāgots", - "@widgetCustom": {}, - "sentCallInformations": "{senderName} nosūtīja informāciju par zvanu", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "addToSpaceDescription": "Atlasīt vietu, kurai pievienot šo tērzēšanu.", - "@addToSpaceDescription": {}, - "googlyEyesContent": "{senderName} sūta izbolītas acis", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "youBannedUser": "Tu {user} liedzi piekļuvi", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "theyDontMatch": "Tie nesakrīt", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Tev tika liegta piekļuve šai tērzēšanai", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Attēlojamais vārds tika nomainīts", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "addChatDescription": "Pievienot tērzēšanas aprakstu...", - "@addChatDescription": {}, - "sentAnAudio": "🎤 {username} nosūtīja skaņu", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "editRoomAvatar": "Labot istabas attēlu", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Šifrēta", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "commandHint_leave": "Pamest šo istabu", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_myroomavatar": "Iestatīt savu attēlu šajā istabā (ar mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "cancel": "Atcelt", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "hasKnocked": "🚪 {user} pieklauvēja", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "publish": "Publicēt", - "@publish": {}, - "openLinkInBrowser": "Atvērt saiti pārlūkā", - "@openLinkInBrowser": {}, - "clearArchive": "Iztīrīt arhīvu", - "@clearArchive": {}, - "appLock": "Lietotnes aizslēgšana", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "commandHint_react": "Nosūtīt atbildi kā reakciju", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "changedTheHistoryVisibility": "{username} mainīja vēstures redzamību", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "commandHint_me": "Apraksti sevi", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "pleaseEnterYourUsername": "Lūgums ievadīt savu lietotājvārdu", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "messageInfo": "Informācija par ziņu", - "@messageInfo": {}, - "disableEncryptionWarning": "Drošības iemeslu dēļ tērzēšanā nevar atspējot šifrēšanu, ja tā ir pirms tam ir bijusi iespējota.", - "@disableEncryptionWarning": {}, - "directChat": "Tiešā tērzēšana", - "@directChat": {}, - "encryptionNotEnabled": "Šifrēšana nav iespējota", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "wrongPinEntered": "Ievadīts nepareizs PIN. Lūgums mēģināt vēlreiz pēc {seconds} sekundēm...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "Nosūtīt rakstīšanas paziņojumus", - "@sendTypingNotifications": {}, - "lightTheme": "Gaišs", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "inviteGroupChat": "📨 Uzaicināt kopas tērzēšanu", - "@inviteGroupChat": {}, - "appearOnTop": "Parādīt virspusē", - "@appearOnTop": {}, - "invitePrivateChat": "📨 Uzaicināt privātu tērzēšanu", - "@invitePrivateChat": {}, - "verifyTitle": "Apliecina citu kontu", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "foregroundServiceRunning": "Šis paziņojums parādās, kad darbojas priekšplāna pakalpojums.", - "@foregroundServiceRunning": {}, - "enterAnEmailAddress": "Jāievada e-pasta adrese", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "voiceCall": "Balss zvans", - "@voiceCall": {}, - "commandHint_kick": "Noņemt norādīto lietotāju no šīs istabas", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "copiedToClipboard": "Ievietots starpliktuvē", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Jauna vieta", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "commandHint_unban": "Atcelt norādītā lietotāja izslēgšanu no šīs istabas", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "unknownEncryptionAlgorithm": "Nezināms šifrēšanas algoritms", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Izslēgt norādīto lietotāju no šīs istabas", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "importEmojis": "Ievietot emocijzīmes", - "@importEmojis": {}, - "confirm": "Apstiprināt", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "wasDirectChatDisplayName": "Tukša tērzēšana (bija {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noChatDescriptionYet": "Vēl nav izveidots tērzēšanas apraksts.", - "@noChatDescriptionYet": {}, - "defaultPermissionLevel": "Noklusējuma atļauju līmenis", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "removeFromBundle": "Noņemt no šī komplekta", - "@removeFromBundle": {}, - "numUsersTyping": "{count} lietotāji raksta…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "fontSize": "Fonta izmērs", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Kurš var veikt kādas darbības", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "confirmMatrixId": "Lūgums apliecināt savu Matrix Id, lai varētu izdzēst savu kontu.", - "@confirmMatrixId": {}, - "learnMore": "Uzzināt vairāk", - "@learnMore": {}, - "iHaveClickedOnLink": "Es uzklikšķināju uz saites", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "you": "Tu", - "@you": { - "type": "text", - "placeholders": {} - }, - "notAnImage": "Nav attēla datne.", - "@notAnImage": {}, - "users": "Lietotāji", - "@users": {}, - "openGallery": "Atvērt galeriju", - "@openGallery": {}, - "chatDescriptionHasBeenChanged": "Tērzēšanas apraksts ir mainījies", - "@chatDescriptionHasBeenChanged": {}, - "search": "Meklēt", - "@search": { - "type": "text", - "placeholders": {} - }, - "newGroup": "Jauna kopa", - "@newGroup": {}, - "bundleName": "Komplekta nosaukums", - "@bundleName": {}, - "dehydrateTor": "TOR lietotāji: izgūt sesiju", - "@dehydrateTor": {}, - "removeFromSpace": "Noņemt no vietas", - "@removeFromSpace": {}, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "commandHint_op": "Iestatīt norādītā lietotāja spēka līmeni (noklusējums: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_join": "Pievienoties norādītajai istabai", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "sourceCode": "Pirmkods", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "roomUpgradeDescription": "Tērzēšana tad tiks atkārtoti izveidota ar jauno istabas versiju. Visiem dalībniekiem tiks paziņots, ka viņiem ir jāpārslēdzas uz jauno tērzēšanu. Vairāk par istabu versijām var atrast https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "commandHint_invite": "Uzaicināt norādīto lietotāju šajā istabā", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "userSentUnknownEvent": "{username} nosūtīja notikumu {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "scanQrCode": "Nolasīt kvadrātkodu", - "@scanQrCode": {}, - "logout": "Atteikties", - "@logout": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterANumber": "Lūgums ievadīt skaitli lielāku par 0", - "@pleaseEnterANumber": {}, - "contactHasBeenInvitedToTheGroup": "Kontaktpersona tika uzaicināta kopā", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "youKicked": "👞 Tu izraidīji {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "areYouSureYouWantToLogout": "Vai tiešām atteikties?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "changedTheJoinRules": "{username} nomainīja pievienošanās nosacījumus", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "profileNotFound": "Lietotāju serverī nevarēja atrast. Varbūt ir nebūšanas ar savienojumu vai lietotājs nepastāv.", - "@profileNotFound": {}, - "jump": "Pārlēkt", - "@jump": {}, - "groups": "Kopas", - "@groups": { - "type": "text", - "placeholders": {} - }, - "reactedWith": "{sender} atsaucās ar {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "bannedUser": "{username} izslēdza {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "sorryThatsNotPossible": "Atvaino! Tas nav iespējams", - "@sorryThatsNotPossible": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "oopsSomethingWentWrong": "Ups! Kaut kas nogāja greizi…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Ielādēt vēl {count} dalībniekus", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "shareInviteLink": "Kopīgot uzaicinājuma saiti", - "@shareInviteLink": {}, - "commandHint_markasdm": "Atzīmēt kā tiešo ziņu istabu norādītajam Matrix Id", - "@commandHint_markasdm": {}, - "recoveryKeyLost": "Pazaudēta atkopšanas atslēga?", - "@recoveryKeyLost": {}, - "cuddleContent": "{senderName} samīļo Tevi", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "askVerificationRequest": "Pieņemt apliecināšanas pieprasījumu no {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "containsUserName": "Satur lietotājvārdu", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "messages": "Ziņas", - "@messages": { - "type": "text", - "placeholders": {} - }, - "login": "Pieteikties", - "@login": { - "type": "text", - "placeholders": {} - }, - "deviceKeys": "Ierīces atslēgas:", - "@deviceKeys": {}, - "waitingPartnerNumbers": "Gaida, līdz biedrs apstiprinās skaitļus…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Izskatās, ka Firebase mākoņziņojumapmaiņa nav pieejama šajā ierīcē. Lai joprojām saņemtu pašpiegādes paziņojumus, mēs iesakām uzstādīt ntfy. Ar ntfy vai citu Vienotās pašpiegādes nodrošinātāju ir iespējams saņemt pašpiegādes paziņojumus drošā veidā. ntfy var lejupielādēt no PlayStore vai F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Viss ir gatavs!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "addEmail": "Pievienot e-pasta adresi", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "emoteKeyboardNoRecents": "Nesen izmantotās emocijas parādīsies šeit...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Iestatīt pielāgotas emocijas", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} uzsāka zvanu", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "emoteInvalid": "Nederīgs emocijas īskods.", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistēmas", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Paziņojumi iespējoti šim kontam", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Izdzēst ziņu", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Tērzēšanas vēstures redzamība", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "settings": "Iestatījumi", - "@settings": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Iestatīt izskatu:", - "@setTheme": {}, - "changeTheHomeserver": "Mainīt mājasserveri", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "youJoinedTheChat": "Tu pievienojies tērzēšanai", - "@youJoinedTheChat": {}, - "wallpaper": "Ekrāntapete:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "openVideoCamera": "Atvērt kameru video uzņemšanai", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "play": "Atskaņot {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "chatBackupDescription": "Iepriekšējās ziņas ir aizsargātas ar atkopšanas atslēgu. Lūgums nodrošināt, ka tā netiek pazaudēta.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Mainīt ierīces nosaukumu", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Aizmirsta parole", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Kā Tev šodien klājas?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "security": "Drošība", - "@security": { - "type": "text", - "placeholders": {} - }, - "markAsRead": "Atzīmēt kā lasītu", - "@markAsRead": {}, - "sendAudio": "Nosūtīt skaņu", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "widgetName": "Nosaukums", - "@widgetName": {}, - "sentASticker": "😊 {username} nosūtīja uzlīmi", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "errorAddingWidget": "Kļūda logrīka pievienošanā.", - "@errorAddingWidget": {}, - "commandHint_dm": "Uzsākt tiešu tērzēšanu\nLai atspējotu šifrēšanu, jāizmanto --no-encryption", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_hug": "Nosūtīt apskāvienu", - "@commandHint_hug": {}, - "replace": "Aizstāt", - "@replace": {}, - "reject": "Noraidīt", - "@reject": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Īpaši aizskarošs", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Labot liegtos serveros", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Ups! Diemžēl atgadījās kļūda pašpiegādes paziņojumu iestatīšanas laikā.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "youUnbannedUser": "Tu atcēli {user} piekļuves liegumu", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "deactivateAccountWarning": "Tas atspējos Tavu lietotāja kontu. To nevar atdarīt. Vai tiešām?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "archive": "Arhīvs", - "@archive": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} pievienojās tērzēšanai", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "visibleForEveryone": "Redzama visiem", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Lūgums ievadīt 4 ciparus vai atstāt tukšu, lai atspējotu lietotnes slēgu.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "newSpace": "Jauna vieta", - "@newSpace": {}, - "changePassword": "Nomainīt paroli", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "devices": "Ierīces", - "@devices": { - "type": "text", - "placeholders": {} - }, - "accept": "Pieņemt", - "@accept": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Nezināms notikums '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "emojis": "Emocijzīmes", - "@emojis": {}, - "pleaseEnterYourPin": "Lūgums ievadīt savu PIN", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Lūgums izvēlēties", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "share": "Kopīgot", - "@share": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "Nosūtīt izbolītu acu pāri", - "@commandHint_googly": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Lūgums vēlāk mēģināt vēlreiz vai izvēlēties citu serveri.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Izveidot kopu", - "@createGroup": {}, - "privacy": "Privātums", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Mainīt savu attēlu", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Nosūtīt attēlu", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "hydrateTorLong": "Vai sesija pēdējoreiz tika izgūta TOR? Ātri ievieto to un turpini tērzēšanu!", - "@hydrateTorLong": {}, - "time": "Laiks", - "@time": {}, - "enterYourHomeserver": "Jāievada mājasserveris", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Robotprogrammatūras ziņas", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Par saturu tika ziņos servera pārvaldītājiem", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "custom": "Pielāgots", - "@custom": {}, - "noBackupWarning": "Uzmanību! Bez tērzēšanas rezerves kopijas iespējošanas tiks zaudēta piekļuve savām šifrētajām ziņām. Ir ļoti ieteicams iespējot tērzēšanas rezerves kopiju pirms atteikšanās.", - "@noBackupWarning": {}, - "fromJoining": "No pievienošanās", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "verify": "Apliecināt", - "@verify": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Nosūtīt video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "storeInSecureStorageDescription": "Glabāt atkopšanas atslēgu šīs ierīces drošajā krātuvē.", - "@storeInSecureStorageDescription": {}, - "openChat": "Atvērt tērzēšanu", - "@openChat": {}, - "kickUserDescription": "Lietotājs ir izmests no tērzēšanas, bet piekļuve nav liegta. Publiskās tērzēšanās lietotājs var atkārtoti pievienoties jebkurā laikā.", - "@kickUserDescription": {}, - "sendAMessage": "Nosūtīt ziņu", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "pin": "PIN", - "@pin": { - "type": "text", - "placeholders": {} - }, - "importNow": "Ievietot tagad", - "@importNow": {}, - "deleteAccount": "Izdzēst kontu", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Iestatīt uzaicinājumu saiti", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "pinMessage": "Piespraust istabai", - "@pinMessage": {}, - "screenSharingDetail": "Tu kopīgo savu ekrānu FluffyChat", - "@screenSharingDetail": {}, - "muteChat": "Apklusināt tērzēšanu", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "invite": "Uzaicināt", - "@invite": {}, - "enableMultiAccounts": "(BETA) Iespējot vairākus kontus šajā ierīcē", - "@enableMultiAccounts": {}, - "anyoneCanJoin": "Ikviens var pievienoties", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Emociju pakas istabai", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "indexedDbErrorTitle": "Privātā režīma nebūšanas", - "@indexedDbErrorTitle": {}, - "endedTheCall": "{senderName} beidza zvanu", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "appLockDescription": "Aizslēgt lietotni ar PIN kodu, kad tā netiek izmantota", - "@appLockDescription": {}, - "globalChatId": "Vispārējais tērzēšanas Id", - "@globalChatId": {}, - "accessAndVisibilityDescription": "Kam ir ļauts pievienoties šai tērzēšanai un kā tērzēšana var tikt atklāta.", - "@accessAndVisibilityDescription": {}, - "customEmojisAndStickers": "Pielāgotas emocijzīmes un uzlīmes", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Pievienot vai kopīgot pielāgotas emocijzīmes vai uzlīmes, kas var tikt izmantotas jebkurā tērzēšanā.", - "@customEmojisAndStickersBody": {}, - "hideInvalidOrUnknownMessageFormats": "Paslēpt nederīgus vai nezināmus ziņu formātus", - "@hideInvalidOrUnknownMessageFormats": {}, - "blockUsername": "Neņemt vērā lietotājvārdu", - "@blockUsername": {}, - "accessAndVisibility": "Piekļuve un redzamība", - "@accessAndVisibility": {}, - "calls": "Zvani", - "@calls": {}, - "hideRedactedMessages": "Paslēpt labošanas ziņas", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "Ja kāds labo ziņu, tā vairs nebūs redzama tērzēšanā.", - "@hideRedactedMessagesBody": {}, - "blockListDescription": "Ir iespējams atslēgt traucējošus lietotājus. Nebūs iespējams saņem jebkādas ziņas vai uzaicinājumus uz istabām no lietotājiem, kas ir personīgajā izslēgšanas sarakstā.", - "@blockListDescription": {}, - "hideMemberChangesInPublicChatsBody": "Nerādīt tērzēšanas plūsmā, ja kāds pievienojas publiskai tērzēšanai vai pamet to, lai uzlabotu lasāmību.", - "@hideMemberChangesInPublicChatsBody": {}, - "overview": "Pārskats", - "@overview": {}, - "notifyMeFor": "Paziņot man par", - "@notifyMeFor": {}, - "wrongRecoveryKey": "Atvaino... Nešķiet, ka šī būtu pareiza atkopšanas atslēga.", - "@wrongRecoveryKey": {}, - "block": "Izslēgt", - "@block": {}, - "hideMemberChangesInPublicChats": "Paslēpt dalībnieku izmaiņas publiskajās tērzēšanās", - "@hideMemberChangesInPublicChats": {}, - "passwordRecoverySettings": "Paroles atjaunošanas iestatījumi", - "@passwordRecoverySettings": {}, - "blockedUsers": "Atslēgtie lietotāji", - "@blockedUsers": {}, - "transparent": "Caurspīdīgs", - "@transparent": {}, - "searchForUsers": "Meklēt @lietotājus...", - "@searchForUsers": {}, - "pleaseEnterYourCurrentPassword": "Lūgums ievadīt savu pašreizējo paroli", - "@pleaseEnterYourCurrentPassword": {}, - "publicSpaces": "Publiskas vietas", - "@publicSpaces": {}, - "decline": "Atteikt", - "@decline": {}, - "joinSpace": "Pievienoties vietai", - "@joinSpace": {}, - "createGroupAndInviteUsers": "Izveidot kopu un uzaicināt lietotājus", - "@createGroupAndInviteUsers": {}, - "groupCanBeFoundViaSearch": "Kopu var atrast meklēšanā", - "@groupCanBeFoundViaSearch": {}, - "commandHint_sendraw": "Nosūtīt neapstrādātu JSON", - "@commandHint_sendraw": {}, - "newPassword": "Jauna parole", - "@newPassword": {}, - "forwardMessageTo": "Pārsūtīt ziņu uz {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendReadReceipts": "Nosūtīt lasīšanas atskaites", - "@sendReadReceipts": {}, - "verifyOtherUser": "🔐 Apliecināt otru lietotāju", - "@verifyOtherUser": {}, - "verifyOtherDevice": "🔐 Apliecināt otru ierīci", - "@verifyOtherDevice": {}, - "yourGlobalUserIdIs": "Vispārējais lietotāja Id ir: ", - "@yourGlobalUserIdIs": {}, - "select": "Atlasīt", - "@select": {}, - "initAppError": "Atgadījās kļūda lietotnes sāknēšanas laikā", - "@initAppError": {}, - "formattedMessages": "Formatētas ziņas", - "@formattedMessages": {}, - "canceledKeyVerification": "{sender} atcēla atslēgas apliecināšanu", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} pabeidza atslēgas apliecināšanu", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} pieprasīja atslēgas apliecināšanu", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} uzsāka atslēgas apliecināšanu", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "incomingMessages": "Ienākošās ziņas", - "@incomingMessages": {}, - "isReadyForKeyVerification": "{sender} ir gatavs atslēgas apliecināšanai", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "commandHint_unignore": "Atcelt norādītā Matrix Id neņemšanu vērā", - "@commandHint_unignore": {}, - "commandHint_ignore": "Neņemt vērā norādīto Matrix Id", - "@commandHint_ignore": {}, - "searchChatsRooms": "Meklēt #tērzēšanas, @lietotājus...", - "@searchChatsRooms": {}, - "groupName": "Kopas nosaukums", - "@groupName": {}, - "presenceStyle": "Klātesamība:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "youInvitedToBy": "📩 Tu tiki uzaicināts ar saiti:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "userWouldLikeToChangeTheChat": "{user} vēlas pievienoties tērzēšanai.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "Vēl nav izveidota neviena publiska saite", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "Pieklauvēt", - "@knock": {}, - "stickers": "Uzlīmes", - "@stickers": {}, - "usersMustKnock": "Lietotājiem jāpieklauvē", - "@usersMustKnock": {}, - "noOneCanJoin": "Neviens nevar pievienoties", - "@noOneCanJoin": {}, - "hidePresences": "Paslēpt stāvokļu sarakstu?", - "@hidePresences": {}, - "knocking": "Klauvē", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Tērzēšana var tikt atklāta ar meklēšanu {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "nothingFound": "Nekas netika atrasts...", - "@nothingFound": {}, - "startConversation": "Uzsākt sarunu", - "@startConversation": {}, - "databaseMigrationTitle": "Datubāze ir optimizēta", - "@databaseMigrationTitle": {}, - "leaveEmptyToClearStatus": "Atstāt tukšu, lai notīrītu savu stāvokli.", - "@leaveEmptyToClearStatus": {}, - "pleaseChooseAStrongPassword": "Lūgums izvēlēties spēcīgu paroli", - "@pleaseChooseAStrongPassword": {}, - "passwordIsWrong": "Ievadītā parole ir nepareiza", - "@passwordIsWrong": {}, - "publicLink": "Publiska saite", - "@publicLink": {}, - "thisDevice": "Šī ierīce:", - "@thisDevice": {}, - "acceptedKeyVerification": "{sender} apstiprināja atslēgas apliecināšanu", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "userRole": "Lietotāja loma", - "@userRole": {}, - "noDatabaseEncryption": "Šajā platformā datubāzes šifrēšana netiek nodrošināta", - "@noDatabaseEncryption": {}, - "presencesToggle": "Rādīt citu lietotāju stāvokļa ziņas", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "databaseMigrationBody": "Lūgums uzgaidīt. Tas var aizņemt kādu brīdi.", - "@databaseMigrationBody": {}, - "passwordsDoNotMatch": "Paroles nesakrīt", - "@passwordsDoNotMatch": {}, - "publicChatAddresses": "Publiskas tērzēšanas adreses", - "@publicChatAddresses": {}, - "createNewAddress": "Izveidot jaunu adresi", - "@createNewAddress": {}, - "minimumPowerLevel": "{level} ir zemākais spēka līmenis.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "discover": "Atklāt", - "@discover": {}, - "unreadChatsInApp": "{appname}: {unread} nelasītas tērzēšanas", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "subspace": "Apakšvieta", - "@subspace": {}, - "addChatOrSubSpace": "Pievienot tērzēšanu vai apakšvietu", - "@addChatOrSubSpace": {}, - "formattedMessagesDescription": "Attēlot bagātinātu ziņu saturu, piemēram, ar Markdown iezīmētu treknrakstu.", - "@formattedMessagesDescription": {}, - "databaseBuildErrorBody": "Nebija iespējams izveidot SQlite datubāzi. Lietotne pagaidām mēģina izmantot iepriekšējo datubāzi. Lūgums ziņot par šo kļūdu izstrādātājiem {url}. Kļūdas ziņojums ir: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sessionLostBody": "Sesija ir zaudēta. Lūgums ziņot par šo kļūdu izstrādātājiem {url}. Kļūdas ziņojums ir: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "verifyOtherUserDescription": "Ar cita lietotāja apliecināšanu vari pārliecināties, ka zini, kam Tu tiešām raksti. 💪\n\nKad uzsāc apliecināšanu, Tu un otrs lietotājs lietotnē redzēs uznirstošo logu. Tajā jūs redzēsiet dažādas emocijzīmes vai skaitļus, kas ir jāsalīdzina savā starpā.\n\nLabākais veids, kā to izdarīt, ir satikties vai uzsākt videozvanu. 👭", - "@verifyOtherUserDescription": {}, - "sendTypingNotificationsDescription": "Citi tērzēšanas dalībnieki var redzēt, kad raksti jaunu ziņu.", - "@sendTypingNotificationsDescription": {}, - "noUsersFoundWithQuery": "Diemžēl ar \"{query}\" netika atrasts neviens lietotājs. Lūgums pārbaudīt, vai ir pieļauta drukas kļūda.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "restoreSessionBody": "Lietotne tagad mēģina atjaunot sesiju no rezerves kopijas. Lūgums ziņot par šo kļūdu izstrādātājiem {url}. Kļūdas ziņojums ir: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sendReadReceiptsDescription": "Citi tērzēšanas dalībnieki var redzēt, kad izlasīji ziņu.", - "@sendReadReceiptsDescription": {}, - "thereAreCountUsersBlocked": "Šobrīd ir izslēgti {count} lietotāji.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "verifyOtherDeviceDescription": "Kad apliecini citu ierīci, šīs ierīces var apmainīt atslēgas, palielinot vispārējo drošību. 💪 Kad uzsāc apliecināšanu, abās ierīcēs lietotnē parādīsies uznirstošais logs. Tajā būs redzamas dažādas emocijzīmes vai skaitļi, kas jāsalīdzina abās ierīcēs. Vislabāk, ja abas ierīces ir pieejams, pirms tiek uzsākta apliecināšana. 🤳", - "@verifyOtherDeviceDescription": {} -} diff --git a/assets/l10n/intl_nl.arb b/assets/l10n/intl_nl.arb deleted file mode 100644 index 67d79c2b5..000000000 --- a/assets/l10n/intl_nl.arb +++ /dev/null @@ -1,2421 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.955292", - "about": "Over ons", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Accepteren", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} heeft de uitnodiging geaccepteerd", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Account", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} heeft eind-tot-eindversleuteling geactiveerd", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Email toevoegen", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Aan space toevoegen", - "@addToSpace": {}, - "admin": "Beheerder", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Alle", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Alle chats", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} heeft de oproep beantwoord", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Iedereen kan deelnemen", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "App-vergrendeling", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Archief", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Mogen gasten deelnemen", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Weet je het zeker?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Weet je zeker dat je wilt uitloggen?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Voer je beveiligde opslag wachtwoordzin of herstelsleutel in om de andere persoon te kunnen ondertekenen.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Accepteer je dit verificatieverzoek van {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Automatisch geanimeerde stickers en emoticons afspelen", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "De homeserver ondersteunt de login types:\n{serverVersions}\nMaar deze app ondersteunt alleen:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "De homeserver ondersteunt de Spec-versies:\n{serverVersions}\nMaar deze app ondersteunt alleen {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Van chat verbannen", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Verbannen", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} verbant {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Apparaat blokkeren", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Geblokkeerd", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bot-berichten", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Annuleren", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Kan de URI {uri} niet openen", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Apparaatnaam wijzigen", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} heeft de chatavatar gewijzigd", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} heeft de chatomschrijving gewijzigd in: {description}", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} heeft de chatnaam gewijzigd in: {chatname}", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} heeft de chatrechten gewijzigd", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username}'s naam is nu {displayname}", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} heeft de toegangsregels voor gasten gewijzigd", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} heeft de gastenregels gewijzigd in: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} heeft de zichtbaarheid van de geschiedenis gewijzigd", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} heeft de zichtbaarheid van de geschiedenis gewijzigd in: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} heeft de deelnameregels gewijzigd", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} heeft de deelnameregels gewijzigd in: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username}'s avatar is gewijzigd", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} heeft de kameraliassen gewijzigd", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} heeft de uitnodigingslink gewijzigd", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Wachtwoord wijzigen", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Homeserver wijzigen", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Stijl veranderen", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Groepsnaam wijzigen", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Jouw avatar veranderen", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "De versleuteling is beschadigd", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Chatback-up", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Je oude berichten zijn beveiligd met een herstelsleutel. Zorg ervoor dat je deze niet verliest.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Chatdetails", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Chat is toegevoegd aan deze space", - "@chatHasBeenAddedToThisSpace": {}, - "chats": "Chats", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Kies een sterk wachtwoord", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Archief wissen", - "@clearArchive": {}, - "close": "Sluiten", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Persoon uit deze kamer verbannen", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Tekst met HTML-opmaak versturen", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Persoon in deze kamer uitnodigen", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Deelnemen aan de kamer", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Persoon uit deze kamer verwijderen", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Deze kamer verlaten", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Beschrijf jezelf", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Jouw avatar voor deze kamer instellen (met mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Jouw naam voor deze kamer instellen", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Machtsniveau van de persoon instellen (standaard: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Niet-opgemaakte tekst versturen", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Antwoord als reactie versturen", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Tekst versturen", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Persoon weer in deze kamer toestaan", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Opdracht ongeldig", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} is geen opdracht.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Vergelijk de emoji's", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Vergelijk de cijfers", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Chat configureren", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Bevestigen", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Verbinden", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Contact is voor de groep uitgenodigd", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Bevat naam", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Bevat gebruikersnaam", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "De inhoud is gerapporteerd aan de serverbeheerders", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Gekopieerd naar klembord", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Bericht kopiëren", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopieer naar klembord", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Kan het bericht niet ontsleutelen: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} personen", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Aanmaken", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} heeft de chat gemaakt", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Nieuwe space", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Momenteel actief", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Donker", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Hierdoor wordt je account gedeactiveerd. Dit kan niet ongedaan gemaakt worden! Weet je het zeker?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Standaardmachtigingsniveau", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Verwijderen", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Account verwijderen", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Bericht verwijderen", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Apparaat", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Apparaat-ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Apparaten", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Directe chats", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "De naam is gewijzigd", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Bestand downloaden", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Wijzig", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Geblokkeerde servers wijzigen", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Naam wijzigen", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Kameraliassen wijzigen", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Kameravatar wijzigen", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emoticon bestaat al!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Ongeldige emoticon korte code!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Emoticonpakketten voor de kamer", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emoticon-instellingen", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Emoticon korte code", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Je moet een emoticon korte code en afbeelding kiezen!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Lege chat", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Emoticonpakket overal inschakelen", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Versleuteling inschakelen", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Je kunt de versleuteling hierna niet meer uitschakelen. Weet je het zeker?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Versleuteld", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Versleuteling", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Versleuteling is niet ingeschakeld", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} heeft het gesprek beëindigd", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Voer een email in", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Vul je homeserver in", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Locatie ophalen fout: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Alles klaar!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extreem beledigend", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Bestandsnaam", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Lettergrootte", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Stuur door", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Vanaf deelname", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Vanaf uitnodiging", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Ga naar de nieuwe kamer", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Groep", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Groep is openbaar", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Groepen", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Groep met {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Gasten zijn verboden", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Gasten kunnen deelnemen", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} heeft de uitnodiging voor {targetName} ingetrokken", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Help", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Bewerkte gebeurtenissen verbergen", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Onbekende gebeurtenissen verbergen", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Hoe beledigend is deze inhoud?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identiteit", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Negeer", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Genegeerde personen", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Ik heb op de link geklikt", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Onjuiste wachtwoordzin of herstelsleutel", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Niet beledigend", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Contact uitnodigen", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Contact voor {groupName} uitnodigen", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Uitgenodigd", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} heeft {targetName} uitgenodigd", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Alleen uitgenodigde personen", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Persoonlijke uitnodiging", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} heeft je uitgenodigd voor FluffyChat.\n1. Bezoek https://fluffychat.im en installeer de app\n2. Registreer of log in\n3. Open deze uitnodigingslink:\n{link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "is aan het typen…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} is toegetreden tot de chat", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Deelnemen", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} heeft {targetName} verwijderd", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} heeft {targetName} verwijderd en verbannen", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Uit chat verwijderen", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Laatst actief: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Chat verlaten", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Verliet de chat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licentie", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Licht", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Laad nog {count} personen", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Bezig met laden… Even geduld.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Meer laden…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Locatievoorzieningen is uitgeschakeld. Zet dit eerst aan om je locatie te delen.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Locatievoorzieningen is geweigerd. Zet hem aan om locatie delen te gebruiken.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Inloggen", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Inloggen bij {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Uitloggen", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Persoon wijzigingen", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Vermeld", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Berichten", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Meldingen uitschakelen", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Houd er rekening mee dat je voorlopig Pantalaimon nodig hebt om eind-tot-eindversleuteling te gebruiken.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Nieuwe chat", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Nieuw bericht in FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nieuw verificatieverzoek!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Volgende", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Nee", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Geen verbinding met de server", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Geen emoticons gevonden. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Je kunt de versleuteling pas activeren zodra de kamer niet meer openbaar toegankelijk is.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Firebase Cloud Messaging lijkt niet beschikbaar op je apparaat. Om nog steeds meldingen te krijgen, adviseren we om ntfy te installeren. Met ntfy of een andere Unified Push provider kun je meldingen ontvangen op een veilige manier. Je kunt ntfy downloaden van de PlayStore of van F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} is geen Matrix-server, wil je {server2} gebruiken?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "none": "Geen", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Je hebt nog geen manier toegevoegd om je wachtwoord te herstellen.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Geen toestemming", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Geen kamers gevonden …", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notificaties", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Meldingen ingeschakeld voor dit account", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} personen typen…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Locatie ophalen…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Beledigend", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Offline", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "OK", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Online", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Online sleutelback-up is ingeschakeld", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Oeps! Helaas is er een fout opgetreden bij het instellen van de pushmeldingen.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Oeps, er ging iets mis…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Open app om de berichten te lezen", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Camera openen", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "In kaarten openen", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Of", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Personen", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "wachtwoordzin of herstelsleutel", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Wachtwoord", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Wachtwoord vergeten", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Wachtwoord gewijzigd", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Wachtwoordherstel", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Personen", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Kies een afbeelding", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Pin", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Speel {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Maak een keuze", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Kies een toegangscode", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Klik op de link in de email en ga dan verder.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Voer 4 cijfers in of laat leeg om app-vergrendeling uit te schakelen.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Voer jouw wachtwoord in", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Voer je pincode in", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Voer je inlognaam in", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Volg de instructies op de website en tik op volgende.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privacy", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Publieke Kamers", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Meldingsinstellingen", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Reden", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Opnemen", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} heeft een event verwijderd", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Aangepast bericht", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Registeren", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Afwijzen", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} heeft de uitnodiging afgewezen", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Opnieuw deelnemen", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Verwijder", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Verwijder alle andere apparaten", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Verwijderd door {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Verwijder apparaat", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Verbanning opheffen", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Jouw avatar verwijderen", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Uitgebreide berichtinhoud weergeven", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Kamerversie upgraden", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Antwoord", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Bericht rapporteren", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Vraag toestemming", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Kamer is geüpgrade", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Kamerversie", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Bestand opslaan", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Zoeken", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Beveiliging", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Gezien door {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Verstuur", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Stuur een bericht", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Als tekst versturen", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Audio versturen", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Bestand versturen", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Afbeelding versturen", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Berichten versturen", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Origineel versturen", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Sticker versturen", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Video versturen", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} heeft een bestand verzonden", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} heeft een audio verzonden", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} heeft een afbeelding verzonden", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} heeft een sticker verzonden", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} heeft een video verzonden", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} heeft oproepgegevens verzonden", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Als hoofdalias instellen", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Aangepaste emoticons instellen", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Uitnodigingslink instellen", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Machtigingsniveau instellen", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Status instellen", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Instellingen", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Delen", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} heeft deze locatie gedeeld", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Locatie delen", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Wachtwoord weergeven", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Eenmalig Inloggen", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Overslaan", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Broncode", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Space is openbaar", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Spacenaam", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} heeft een gesprek gestart", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Hoe gaat het met jouw vandaag?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Indienen", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Synchroniseren... Even geduld.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Systeem", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Ze komen niet overeen", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Ze komen overeen", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Favoriet in- of uitschakelen", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Meldingen in- of uitschakelen", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Markeer gelezen/ongelezen", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Te veel verzoeken. Probeer het later nog eens!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Overzetten vanaf een ander apparaat", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Probeer nogmaals te verzenden", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Niet beschikbaar", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} heeft verbanning {targetName} ongedaan gemaakt", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Deblokkeer apparaat", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Onbekend apparaat", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Onbekend versleutelingsalgoritme", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Onbekend evenement '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Meldingen inschakelen", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Losmaken", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 ongelezen chat} other{{unreadCount} ongelezen chats}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} en {count} anderen zijn aan het typen …", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} en {username2} zijn aan het typen …", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} is aan het typen …", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} is vertrokken uit de chat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Gebruikersnaam", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} heeft een {type} -gebeurtenis gestuurd", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Geverifieerd", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verifieer", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Verificatie starten", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Je bent succesvol geverifieerd!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Ander account verifiëren", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videogesprek", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Chatgeschiedenis zichtbaarheid", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Zichtbaar voor alle personen", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Zichtbaar voor iedereen", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Spraakbericht versturen", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Wachten tot partner het verzoek accepteert …", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Wachten tot partner de emoji accepteert …", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Wachten tot partner de nummers accepteert …", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Achtergrond:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Waarschuwing!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "We hebben je een email gestuurd", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Wie kan welke actie uitvoeren", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Wie mag deelnemen aan deze groep", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Waarom wil je dit rapporteren?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Wil je de chatback-up wissen om een nieuwe herstelsleutel te kunnen maken?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Met deze adressen kan je je wachtwoord herstellen.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Schrijf een bericht…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Ja", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Jij", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Je neemt niet langer deel aan deze chat", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Je bent verbannen uit deze chat", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Je publieke sleutel", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "QR-code scannen", - "@scanQrCode": {}, - "sendOnEnter": "Verstuur met enter", - "@sendOnEnter": {}, - "homeserver": "Server", - "@homeserver": {}, - "serverRequiresEmail": "Deze server wil je email laten bevestigen bij de registratie.", - "@serverRequiresEmail": {}, - "oneClientLoggedOut": "Één van jouw apparaten is uitgelogd", - "@oneClientLoggedOut": {}, - "enableMultiAccounts": "(BETA) Multi-accounts inschakelen op dit apparaat", - "@enableMultiAccounts": {}, - "bundleName": "Bundelnaam", - "@bundleName": {}, - "removeFromBundle": "Van bundel verwijderen", - "@removeFromBundle": {}, - "addToBundle": "Aan bundel toevoegen", - "@addToBundle": {}, - "editBundlesForAccount": "Bundels voor dit account wijzigen", - "@editBundlesForAccount": {}, - "addAccount": "Account toevoegen", - "@addAccount": {}, - "link": "Link", - "@link": {}, - "yourChatBackupHasBeenSetUp": "Jouw chatback-up is ingesteld.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "Niet geverifieerd", - "@unverified": {}, - "repeatPassword": "Wachtwoord herhalen", - "@repeatPassword": {}, - "messageInfo": "Berichtinfo", - "@messageInfo": {}, - "time": "Tijd", - "@time": {}, - "messageType": "Berichttype", - "@messageType": {}, - "sender": "Afzender", - "@sender": {}, - "openGallery": "Galerij openen", - "@openGallery": {}, - "addToSpaceDescription": "Selecteer een space om deze chat aan toe te voegen.", - "@addToSpaceDescription": {}, - "removeFromSpace": "Uit de space verwijderen", - "@removeFromSpace": {}, - "start": "Start", - "@start": {}, - "commandHint_clearcache": "Cache wissen", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Maak een lege groepschat\nGebruik --no-encryption om de versleuteling uit te schakelen", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_dm": "Start een directe chat\nGebruik --no-encryption om de versleuteling uit te schakelen", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_discardsession": "Sessie weggooien", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "openVideoCamera": "Videocamera openen", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "publish": "Publiceren", - "@publish": {}, - "dismiss": "Sluiten", - "@dismiss": {}, - "markAsRead": "Markeer als gelezen", - "@markAsRead": {}, - "reportUser": "Persoon rapporteren", - "@reportUser": {}, - "openChat": "Chat openen", - "@openChat": {}, - "reactedWith": "{sender} reageerde met {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "pinMessage": "Maak vast aan kamer", - "@pinMessage": {}, - "emojis": "Emoji's", - "@emojis": {}, - "placeCall": "Bellen", - "@placeCall": {}, - "unsupportedAndroidVersion": "Niet-ondersteunde Android-versie", - "@unsupportedAndroidVersion": {}, - "unsupportedAndroidVersionLong": "Voor deze functie is een nieuwere Android-versie vereist. Controleer op updates of Lineage OS-ondersteuning.", - "@unsupportedAndroidVersionLong": {}, - "videoCallsBetaWarning": "Houd er rekening mee dat videogesprekken momenteel in bèta zijn. Ze werken misschien niet zoals je verwacht of werken niet op alle platformen.", - "@videoCallsBetaWarning": {}, - "voiceCall": "Spraakoproep", - "@voiceCall": {}, - "confirmEventUnpin": "Weet je zeker dat je de gebeurtenis definitief wilt losmaken?", - "@confirmEventUnpin": {}, - "experimentalVideoCalls": "Videogesprekken (experimenteel)", - "@experimentalVideoCalls": {}, - "emailOrUsername": "Email of inlognaam", - "@emailOrUsername": {}, - "nextAccount": "Volgende account", - "@nextAccount": {}, - "switchToAccount": "Naar account {number} overschakelen", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "previousAccount": "Vorige account", - "@previousAccount": {}, - "widgetCustom": "Aangepast", - "@widgetCustom": {}, - "widgetName": "Naam", - "@widgetName": {}, - "widgetUrlError": "Dit is geen geldige link.", - "@widgetUrlError": {}, - "widgetNameError": "Geef een naam op.", - "@widgetNameError": {}, - "errorAddingWidget": "Fout bij het toevoegen van de widget.", - "@errorAddingWidget": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "addWidget": "Widget toevoegen", - "@addWidget": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetEtherpad": "Tekstnotitie", - "@widgetEtherpad": {}, - "separateChatTypes": "Gescheiden directe chats en groepen", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youAcceptedTheInvitation": "👍 Je hebt de uitnodiging geaccepteerd", - "@youAcceptedTheInvitation": {}, - "youRejectedTheInvitation": "Je hebt de uitnodiging afgewezen", - "@youRejectedTheInvitation": {}, - "youJoinedTheChat": "Je bent toegetreden tot de chat", - "@youJoinedTheChat": {}, - "youBannedUser": "Je hebt {user} verbannen", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Je hebt de uitnodiging voor {user} ingetrokken", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 Je bent uitgenodigd door {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Je hebt {user} uitgenodigd", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 Je hebt {user} weggestuurd", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Je hebt weggestuurd en verbannen {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Je hebt de ban op {user} opgeheven", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "recoveryKey": "Herstelsleutel", - "@recoveryKey": {}, - "recoveryKeyLost": "Herstelsleutel verloren?", - "@recoveryKeyLost": {}, - "pleaseEnterRecoveryKey": "Voer jouw herstelsleutel in:", - "@pleaseEnterRecoveryKey": {}, - "users": "Personen", - "@users": {}, - "unlockOldMessages": "Oude berichten ontgrendelen", - "@unlockOldMessages": {}, - "storeInAndroidKeystore": "In Android KeyStore opslaan", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "In Apple KeyChain opslaan", - "@storeInAppleKeyChain": {}, - "saveKeyManuallyDescription": "Sla deze sleutel handmatig op via delen of het klembord.", - "@saveKeyManuallyDescription": {}, - "pleaseEnterRecoveryKeyDescription": "Om je oude berichten te ontgrendelen voer je jouw herstelsleutel in die gemaakt is in je vorige sessie. Je sleutel is niet je wachtwoord.", - "@pleaseEnterRecoveryKeyDescription": {}, - "storeInSecureStorageDescription": "Sla de herstelsleutel op in de beveiligde opslag van dit apparaat.", - "@storeInSecureStorageDescription": {}, - "storeSecurlyOnThisDevice": "Veilig opslaan op dit apparaat", - "@storeSecurlyOnThisDevice": {}, - "dehydrate": "Sessie exporteren en apparaat wissen", - "@dehydrate": {}, - "dehydrateWarning": "Deze actie kan niet ongedaan worden gemaakt. Zorg ervoor dat je het back-upbestand veilig opslaat.", - "@dehydrateWarning": {}, - "dehydrateTor": "TOR-sessies: Exporteer sessie", - "@dehydrateTor": {}, - "dehydrateTorLong": "Voor TOR-sessies is het aanbevolen de sessie te exporteren alvorens het venster te sluiten.", - "@dehydrateTorLong": {}, - "hydrateTor": "TOR-sessie: Importeren sessie export", - "@hydrateTor": {}, - "hydrateTorLong": "Heb je de vorige keer jouw sessie geëxporteerd met TOR? Importeer het dan snel en ga verder met chatten.", - "@hydrateTorLong": {}, - "hydrate": "Herstellen vanuit back-upbestand", - "@hydrate": {}, - "indexedDbErrorTitle": "Problemen met privémodus", - "@indexedDbErrorTitle": {}, - "indexedDbErrorLong": "Het opslaan van berichten is helaas niet standaard ingeschakeld in de privémodus.\nBezoek alsjeblieft\n - about:config\n - stel dom.indexedDB.privateBrowsing.enabled in op true\nAnders is het niet mogelijk om FluffyChat op te starten.", - "@indexedDbErrorLong": {}, - "countFiles": "{count} bestanden", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "user": "Persoon", - "@user": {}, - "custom": "Aangepast", - "@custom": {}, - "confirmMatrixId": "Bevestig jouw Matrix-ID om je account te verwijderen.", - "@confirmMatrixId": {}, - "supposedMxid": "Dit moet {mxid} zijn", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasdm": "Markeer als privéberichtenkamer voor Matrix ID", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "Markeer als groep", - "@commandHint_markasgroup": {}, - "whyIsThisMessageEncrypted": "Waarom is dit bericht onleesbaar?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "Dit kan gebeuren als het bericht is verzonden voordat je bij je account op dit apparaat hebt aangemeld.\n\nHet is ook mogelijk dat de afzender je apparaat heeft geblokkeerd of dat er iets mis is gegaan met de internetverbinding.\n\nKan je het bericht wel lezen op een andere sessie? Dan kan je het bericht daarvandaan overzetten! Ga naar Instellingen > Apparaten en zorg ervoor dat je apparaten elkaar hebben geverifieerd. Wanneer je de kamer de volgende keer opent en beide sessies op de voorgrond staan, zullen de sleutels automatisch worden verzonden.\n\nWil je de sleutels niet verliezen als je uitlogt of van apparaat wisselt? Zorg er dan voor dat je de chatback-up hebt aangezet in de instellingen.", - "@noKeyForThisMessage": {}, - "enterSpace": "Space betreden", - "@enterSpace": {}, - "allSpaces": "Alle spaces", - "@allSpaces": {}, - "foregroundServiceRunning": "Deze melding verschijnt wanneer de voorgronddienst draait.", - "@foregroundServiceRunning": {}, - "screenSharingTitle": "scherm delen", - "@screenSharingTitle": {}, - "screenSharingDetail": "Je deelt je scherm in FuffyChat", - "@screenSharingDetail": {}, - "callingPermissions": "Telefoon-rechten", - "@callingPermissions": {}, - "callingAccount": "Telefoon-account", - "@callingAccount": {}, - "callingAccountDetails": "Hiermee kan FluffyChat de Android telefoon-app gebruiken.", - "@callingAccountDetails": {}, - "appearOnTop": "Bovenaan verschijnen", - "@appearOnTop": {}, - "appearOnTopDetails": "Laat de app bovenaan verschijnen (niet nodig als je FluffyChat al hebt ingesteld als een belaccount)", - "@appearOnTopDetails": {}, - "otherCallingPermissions": "Microfoon, camera en andere FluffyChat-rechten", - "@otherCallingPermissions": {}, - "newGroup": "Nieuwe groep", - "@newGroup": {}, - "newSpace": "Nieuwe space", - "@newSpace": {}, - "enterRoom": "Kamer betreden", - "@enterRoom": {}, - "numChats": "{number} chats", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Onbelangrijke statusgebeurtenissen verbergen", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Niet meer tonen", - "@doNotShowAgain": {}, - "googlyEyesContent": "{senderName} stuurt je wiebelogen", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_googly": "Wat wiebelogen versturen", - "@commandHint_googly": {}, - "commandHint_cuddle": "Een knuffel versturen", - "@commandHint_cuddle": {}, - "commandHint_hug": "Een knuffel versturen", - "@commandHint_hug": {}, - "cuddleContent": "{senderName} knuffelt je", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} omhelst je", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "wasDirectChatDisplayName": "Lege chat (was {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "disableEncryptionWarning": "Om veiligheidsredenen kun je versleuteling niet uitschakelen in een chat, waar deze eerder is ingeschakeld.", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "Sorry, dat is niet mogelijk", - "@sorryThatsNotPossible": {}, - "reopenChat": "Chat heropenen", - "@reopenChat": {}, - "encryptThisChat": "Versleutel deze chat", - "@encryptThisChat": {}, - "deviceKeys": "Apparaatsleutels:", - "@deviceKeys": {}, - "startFirstChat": "Begin je eerste chat", - "@startFirstChat": {}, - "newSpaceDescription": "Met spaces kun je je chats samenvoegen en privé- of openbare community's bouwen.", - "@newSpaceDescription": {}, - "noOtherDevicesFound": "Geen andere apparaten gevonden", - "@noOtherDevicesFound": {}, - "noBackupWarning": "Waarschuwing! Zonder de chatback-up in te schakelen, verlies je de toegang tot je versleutelde berichten. Het is sterk aanbevolen om eerst de chatback-up in te schakelen voordat je uitlogt.", - "@noBackupWarning": {}, - "fileIsTooBigForServer": "De server meldt dat het bestand te groot is om te verzenden.", - "@fileIsTooBigForServer": {}, - "fileHasBeenSavedAt": "Het bestand is opgeslagen op {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Spring naar het laatst gelezen bericht", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Lees tot hier", - "@readUpToHere": {}, - "jump": "Spring", - "@jump": {}, - "openLinkInBrowser": "Link in browser openen", - "@openLinkInBrowser": {}, - "allRooms": "Alle groepschats", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "signInWith": "Aanmelden met {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Geen afbeeldingsbestand.", - "@notAnImage": {}, - "importNow": "Nu importeren", - "@importNow": {}, - "importEmojis": "Emoji's importeren", - "@importEmojis": {}, - "importFromZipFile": "Uit zip-bestand importeren", - "@importFromZipFile": {}, - "exportEmotePack": "Emote-pakket als zip exporteren", - "@exportEmotePack": {}, - "replace": "Vervang", - "@replace": {}, - "report": "rapporteer", - "@report": {}, - "reportErrorDescription": "Oh nee. Er is iets misgegaan. Probeer het later nog eens. Als je wilt, kun je de bug rapporteren aan de ontwikkelaars.", - "@reportErrorDescription": {}, - "sendTypingNotifications": "Typemeldingen verzenden", - "@sendTypingNotifications": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Probeer het later nog eens of kies een andere server.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWithPassword": "Aanmelden met wachtwoord", - "@signInWithPassword": {}, - "chatPermissions": "Chat toestemmingen", - "@chatPermissions": {}, - "chatDescription": "Chatbeschrijving", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Chatbeschrijving gewijzigd", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "Nog geen chatbeschrijving gemaakt.", - "@noChatDescriptionYet": {}, - "tryAgain": "Opnieuw proberen", - "@tryAgain": {}, - "redactMessageDescription": "Het bericht zal worden aangepast voor alle deelnemers in dit gesprek. Dit kan niet ongedaan gemaakt worden.", - "@redactMessageDescription": {}, - "redactedByBecause": "Aangepast door {username}, reden: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "profileNotFound": "De persoon kan niet gevonden worden op de server. Misschien is er een verbindingsprobleem of de persoon bestaat niet.", - "@profileNotFound": {}, - "createGroup": "Groep aanmaken", - "@createGroup": {}, - "inviteContactToGroupQuestion": "Wil je {contact} uitnodigingen voor de chat \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "optionalRedactReason": "(Optioneel) Reden voor aanpassing van dit bericht...", - "@optionalRedactReason": {}, - "addChatDescription": "Voeg een chatbeschrijving toe", - "@addChatDescription": {}, - "invalidServerName": "Foute servernaam", - "@invalidServerName": {}, - "messagesStyle": "Berichten:", - "@messagesStyle": {}, - "shareInviteLink": "Uitnodigingslink delen", - "@shareInviteLink": {}, - "redactedBy": "Aangepast door {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "directChat": "Directe chat", - "@directChat": {}, - "setChatDescription": "Chatbeschrijving instellen", - "@setChatDescription": {}, - "setTheme": "Thema instellen:", - "@setTheme": {}, - "setColorTheme": "Kleurthema instellen:", - "@setColorTheme": {}, - "invite": "Uitnodigen", - "@invite": {}, - "inviteGroupChat": "📨 Groeps-chat uitnodiging", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Privé-chat uitnodiging", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "Recent-gebruikte emoticons zullen hier verschijnen...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "invalidInput": "Ongeldige invoer!", - "@invalidInput": {}, - "wrongPinEntered": "Verkeerde pin ingevoerd! Probeer het nog eens over {seconds} seconden...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "banUserDescription": "De persoon zal worden verbannen van de chat en kan niet meer toetreden totdat de verbanning is opgeheven.", - "@banUserDescription": {}, - "removeDevicesDescription": "Je wordt op dit apparaat uitgelogd en zal niet langer in staat zijn om berichten te ontvangen.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "De persoon zal weer in staat zijn om de chat te betreden als ze het proberen.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Meldingen zijn niet beschikbaar", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Wanneer je deze persoon beheerder maakt kun je dit niet ongedaan maken als jullie dezelfde rechten hebben.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "De chat zal naar het archief worden verplaatst. Andere personen zullen in staat zijn te zien dat je de chat hebt verlaten.", - "@archiveRoomDescription": {}, - "hasKnocked": "{user} heeft geklopt", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "learnMore": "Lees meer", - "@learnMore": {}, - "roomUpgradeDescription": "De chat zal dan opnieuw gemaakt worden met de nieuwe kamerversie. Alle deelnemers worden geïnformeerd dat ze moeten overstappen naar de nieuwe chat. Je kan meer lezen over kamerversies op https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Vul een getal in groter dan 0", - "@pleaseEnterANumber": {}, - "kickUserDescription": "De persoon is verwijderd uit de chat, maar is niet verbannen. In publieke chats kan de persoon op elk moment opnieuw deelnemen.", - "@kickUserDescription": {} -} diff --git a/assets/l10n/intl_pl.arb b/assets/l10n/intl_pl.arb deleted file mode 100644 index 506b85f6d..000000000 --- a/assets/l10n/intl_pl.arb +++ /dev/null @@ -1,2436 +0,0 @@ -{ - "@@locale": "pl", - "@@last_modified": "2021-08-14 12:41:09.943634", - "about": "O aplikacji", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Akceptuj", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} zaakceptował/-a zaproszenie", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Konto", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} aktywował/-a szyfrowanie od końca do końca", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Dodaj adres email", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Administrator", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} odebrał połączenie", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Każdy może dołączyć", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "Archiwum", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Czy użytkownicy-goście mogą dołączyć", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Czy na pewno?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Czy na pewno chcesz się wylogować?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Aby zalogować inną osobę, proszę wpisać hasło przechowywania lub klucz odzyskiwania.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Zaakceptować tą prośbę weryfikacji od {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerLoginTypesException": "Serwer wspiera typy logowania:\n{serverVersions}\nAle ta aplikacja wpiera tylko:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "Serwer wspiera wersje Spec:\n{serverVersions}\nAle aplikacja wspiera tylko {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Ban na czacie", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Zbanowany/-a", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} zbanował/-a {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Zablokuj Urządzenie", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Zablokowane", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Wiadomości Botów", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Anuluj", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Zmień nazwę urządzenia", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} zmienił/-a zdjęcie profilowe", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} zmienił/-a opis czatu na: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} zmienił/-a nick na: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} zmienił/-a uprawnienia czatu", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} zmienił/-a swój nick na: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} zmienił/-a zasady dostępu dla gości", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} zmienił/-a zasady dostępu dla gości na: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} zmienił/-a widoczność historii", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} zmienił/-a widoczność historii na: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} zmienił/-a zasady wejścia", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} zmienił/-a zasady wejścia na: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} zmienił/-a zdjęcie profilowe", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} zmienił/-a skrót pokoju", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} zmienił/-a link do zaproszenia do pokoju", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Zmień hasło", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Zmień serwer domyślny", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Zmień swój styl", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Zmień nazwę grupy", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Szyfrowanie zostało uszkodzone", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Rozmowa", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Kopia zapasowa Rozmów", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Twoje stare wiadomości są zabezpieczone kluczem odzyskiwania. Uważaj żeby go nie zgubić.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Szczegóły czatu", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Rozmowy", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Wybierz silne hasło", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Wyczyść archiwum", - "@clearArchive": {}, - "close": "Zamknij", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Zablokuj użytkownika w tym pokoju", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Wyślij tekst sformatowany w HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Zaproś użytkownika do pokoju", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Dołącz do podanego pokoju", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Usuń tego użytkownika z tego pokoju", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Wyjdź z tego pokoju", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Opisz siebie", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Ustaw awatar dla tego pokoju (przez mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Ustaw nazwę wyświetlaną dla tego pokoju", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Ustaw moc uprawnień użytkownika (domyślnie: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Wyślij niesformatowany tekst", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Wyślij odpowiedź jako reakcję", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Wyślij wiadomość", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Odblokuj użytkownika w tym pokoju", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Nieprawidłowe polecenie", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} nie jest poleceniem.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Porównaj emoji", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Porównaj cyfry", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Potwierdź", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Połącz", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakt został zaproszony do grupy", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Posiada wyświetlaną nazwę", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Posiada nazwę użytkownika", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Skopiowano do schowka", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopiuj", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Skopiuj do schowka", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Nie można odszyfrować wiadomości: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} uczestników", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Stwórz", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} zaczął/-ęła rozmowę", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Obecnie aktywny/-a", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Ciemny", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}.{month}.{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "To zdezaktywuje twoje konto. To jest nieodwracalne! Na pewno chcesz to zrobić?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "delete": "Usuń", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Usuń konto", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Usuń wiadomość", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Urządzenie", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID Urządzenia", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Urządzenia", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Rozmowy bezpośrednie", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Wyświetlany nick został zmieniony", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Pobierz plik", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Edytuj", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Edytuj wyświetlany nick", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Zmień aliasy pokoju", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emotikon już istnieje!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Nieprawidłowy kod emotikony!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Paczki emotikon dla pokoju", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Ustawienia Emotikon", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Kod Emotikony", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Musisz wybrać kod emotikony oraz obraz!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Pusty czat", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Włącz paczkę emotikon globalnie", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Nie będziesz już mógł wyłączyć szyfrowania. Jesteś pewny?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Szyfrowane", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Szyfrowanie", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Szyfrowanie nie jest włączone", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} zakończył połączenie", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Wpisz adres email", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Wpisz swój serwer domowy", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Wszystko gotowe!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nazwa pliku", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Przekaż", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Od dołączenia", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Od zaproszenia", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Przejdź do nowego pokoju", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Grupa", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Grupa jest publiczna", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grupa z {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Goście są zabronieni", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Goście mogą dołączyć", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} wycofał/-a zaproszenie dla {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Pomoc", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Ukryj informacje o zredagowaniu", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Ukryj nieznane wdarzenia", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Tożsamość", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Ignorowani użytkownicy", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Nacisnąłem na link", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Złe hasło bezpieczeństwa lub klucz odzyskiwania", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Zaproś kontakty", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Zaproś kontakty do {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Zaproszono", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} zaprosił/-a {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Tylko zaproszeni użytkownicy", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Zaproszenie dla mnie", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} zaprosił/-a cię do FluffyChat. \n1. Odwiedź fluffychat.im i zainstaluj aplikację\n2. Zarejestuj się lub zaloguj \n3. Otwórz link zaproszenia:\n{link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "pisze…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} dołączył/-a do czatu", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Dołącz do pokoju", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} wyrzucił/-a {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} wyrzucił/-a i zbanował/-a {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Wyrzuć z czatu", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Ostatnio widziano: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Opuść", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Opuścił/-a czat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licencja", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Jasny", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Załaduj jeszcze {count} uczestników", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Ładowanie… Proszę czekać.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Załaduj więcej…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Zaloguj się", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Zaloguj się do {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Wyloguj się", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Zmiany członków", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Wzmianka", - "@mention": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Wycisz czat", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Należy pamiętać, że Pantalaimon wymaga na razie szyfrowania end-to-end.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Nowa rozmowa", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Nowa wiadomość w FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nowa prośba o weryfikację!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Dalej", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Nie", - "@no": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Możesz aktywować szyfrowanie dopiero kiedy pokój nie będzie publicznie dostępny.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Wygląda na to, że nie masz usług Google w swoim telefonie. To dobra decyzja dla twojej prywatności! Aby otrzymywać powiadomienia wysyłane w FluffyChat, zalecamy korzystanie z https://microg.org/ lub https://unifiedpush.org/.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Brak", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Nie dodałeś jeszcze sposobu aby odzyskać swoje hasło.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Brak uprawnień", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Nie znaleziono pokoi…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Powiadomienia", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Powiadomienia są włączone dla tego konta", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Ups! Coś poszło nie tak…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Otwórz aplikację by odczytać wiadomości", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Otwórz aparat", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "password": "Hasło", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Hasło zostało zmienione", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "people": "Osoby", - "@people": { - "type": "text", - "placeholders": {} - }, - "pin": "Przypnij", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Otwórz {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseEnterYourPassword": "Wprowadź swoje hasło", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Wpisz swój nick", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Wykonaj instrukcje na stronie internetowej i naciśnij dalej.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Publiczne pokoje", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Zasady push", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "recording": "Nagranie", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} stworzył/-a wydarzenie", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "register": "Zarejestruj", - "@register": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} odrzucił/-a zaproszenie", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Dołącz ponownie", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Usuń", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Usuń wszystkie inne urządzenia", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Usunięta przez {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Usuń urządzenie", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Odbanuj z czatu", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "reply": "Odpowiedz", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Prośba o pozwolenie", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Wersja pokoju", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Zobaczone przez {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Wyślij", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Wyślij wiadomość", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Wyślij plik", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Wyślij obraz", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} wysłał/-a plik", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} wysłał/-a plik audio", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} wysłał/-a zdjęcie", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} wysłał/-a naklejkę", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} wysłał/-a film", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "setAsCanonicalAlias": "Ustaw jako główny alias", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Ustaw link zaproszeniowy", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Ustaw status", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Ustawienia", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Udostępnij", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} udostępnił/-a swoją lokalizacje", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "showPassword": "Pokaż hasło", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Kod żródłowy", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Jak się masz dziś?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Synchronizacja… Proszę czekać.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "System", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Przenieś z innego urządzenia", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Spróbuj wysłać ponownie", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} odbanował/-a {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unknownDevice": "Nieznane urządzenie", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Nieznany algorytm szyfrowania", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Nieznane zdarzenie '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Wyłącz wyciszenie", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Odepnij", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 unread chat} other{{unreadCount} unread chats}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} oraz {count} innych pisze…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} oraz {username2} piszą…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} pisze…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} opuścił/-a czat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Nazwa użytkownika", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} wysłał/-a wydarzenie {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Zweryfikowane", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "zweryfikuj", - "@verify": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Rozmowa wideo", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Widoczność historii czatu", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Widoczny dla wszystkich użytkowników", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Widoczny dla każdego", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Wiadomość głosowa", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Tapeta:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Kto może dołączyć do tej grupy", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Napisz wiadomość…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Tak", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Ty", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Nie uczestniczysz już w tym czacie", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Zostałeś/-aś zbanowany/-a z tego czatu", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "allChats": "Wszystkie", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignoruj", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Brak połączenia z serwerem", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Uzyskiwanie lokalizacji…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "addAccount": "Dodaj konto", - "@addAccount": {}, - "serverRequiresEmail": "Ten serwer wymaga potwierdzenia twojego adresu email w celu rejestracji.", - "@serverRequiresEmail": {}, - "or": "Lub", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Uczestnik", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Zapomniano hasła", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Proszę wybierz", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Proszę kliknij w odnośnik wysłany na email aby kontynuować.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Proszę podaj 4 cyfry. By wyłączyć blokadę pozostaw puste.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Usuń swój avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Pokazuj w wiadomościach pogrubienia i podkreślenia", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Zamień pokój na nową wersję", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Zgłoś wiadomość", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Zapisz plik", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "security": "Bezpieczeństwo", - "@security": { - "type": "text", - "placeholders": {} - }, - "search": "Szukaj", - "@search": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Wyślij jako tekst", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Wyślij dźwięk", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Wyślij wiadomości", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Wyślij oryginał", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Wyślij naklejkę", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Wyślij film", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} rozpoczął rozmowę", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "yourPublicKey": "Twój klucz publiczny", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "enableMultiAccounts": "(BETA) Włącza obsługę wiele kont na tym urządzeniu", - "@enableMultiAccounts": {}, - "pickImage": "Wybierz obraz", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Odzyskiwanie hasła", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Otwórz w mapach", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "link": "Link", - "@link": {}, - "roomHasBeenUpgraded": "Pokój zostać zaktualizowany", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Powtórz hasło", - "@repeatPassword": {}, - "all": "Wszystkie", - "@all": { - "type": "text", - "placeholders": {} - }, - "appLock": "Blokada aplikacji", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Pasują", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "Wyślij enterem", - "@sendOnEnter": {}, - "autoplayImages": "Automatycznie odtwarzaj animowane naklejki i emotki", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "cantOpenUri": "Nie można otworzyć linku {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "configureChat": "Konfiguruj chat", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Adres serwera", - "@homeserver": {}, - "locationDisabledNotice": "Usługi lokalizacji są wyłączone. Proszę włącz je aby móc udostępnić swoją lokalizację.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "Jedno z twoich urządzeń zostało wylogowane", - "@oneClientLoggedOut": {}, - "privacy": "Prywatność", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Nie pasują", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Przełącz ulubione", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "Twoja kopia zapasowa chatu została ustawiona.", - "@yourChatBackupHasBeenSetUp": {}, - "chatHasBeenAddedToThisSpace": "Chat został dodany do tej przestrzeni", - "@chatHasBeenAddedToThisSpace": {}, - "contentHasBeenReported": "Zawartość została zgłoszona administratorom serwera", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Edytuj zdjęcie pokoju", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Rozmiar czcionki", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "groups": "Grupy", - "@groups": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Brak uprawnień. Proszę zezwól aplikacji na dostęp do lokalizacji aby móc ją udostępnić.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "openVideoCamera": "Nagraj film", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "messages": "Wiadomości", - "@messages": { - "type": "text", - "placeholders": {} - }, - "offensive": "Agresywne", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Podaj swój PIN", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "reason": "Powód", - "@reason": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Utajnij wiadomość", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Ustaw niestandardowe emotki", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Dzięki tym adresom możesz odzyskać swoje hasło.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Ustaw jako publiczną", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Udostępnij lokalizację", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Ustaw poziom uprawnień", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "skip": "Pomiń", - "@skip": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Nazwa przestrzeni", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Przełącz wyciszone", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Oznacz przeczytane/nieprzeczytane", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Niedostępne", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "publish": "Opublikuj", - "@publish": {}, - "scanQrCode": "Skanuj kod QR", - "@scanQrCode": {}, - "createNewSpace": "Nowa przestrzeń", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "offline": "Offline", - "@offline": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Dodaj do przestrzeni", - "@addToSpace": {}, - "changeYourAvatar": "Zmień avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "commandHint_clearcache": "Wyczyść pamięć podręczną", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Stwórz pusty chat\nUżyj --no-encryption by wyłączyć szyfrowanie", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_dm": "Rozpocznij bezpośredni chat\nUżyj --no-encryption by wyłączyć szyfrowanie", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "editBlockedServers": "Edytuj blokowane serwery", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Aktywuj szyfowanie", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Domyślny poziom uprawnień", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Ups! Wystąpił błąd podczas ustawiania powiadomień push.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "reject": "Odrzuć", - "@reject": { - "type": "text", - "placeholders": {} - }, - "online": "Online", - "@online": { - "type": "text", - "placeholders": {} - }, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Zbyt wiele zapytań. Proszę spróbuj ponownie później.", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "commandHint_discardsession": "Odrzuć sesję", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "warning": "Uwaga!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "messageInfo": "Informacje o wiadomości", - "@messageInfo": {}, - "time": "Czas", - "@time": {}, - "messageType": "Rodzaj wiadomości", - "@messageType": {}, - "separateChatTypes": "Oddzielenie czatów bezpośrednich i grupowych", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Oczekiwanie na zaakceptowanie prośby przez drugą osobę…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Oczekiwanie na zaakceptowanie emoji przez drugą osobę…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Wybierz kod dostępu", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "unblockDevice": "Odblokuj urządzenie", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Dlaczego chcesz to zgłosić?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "removeFromSpace": "Usuń z przestrzeni", - "@removeFromSpace": {}, - "extremeOffensive": "Bardzo obraźliwe", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Błąd w ustalaniu lokalizacji: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "howOffensiveIsThisContent": "Jak bardzo obraźliwe są te treści?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Nieobraźliwe", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "recoveryKey": "Klucz odzyskiwania", - "@recoveryKey": {}, - "recoveryKeyLost": "Utracono klucz odzyskiwania?", - "@recoveryKeyLost": {}, - "sentCallInformations": "{senderName} wysłał/-a informacje o połączeniu", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "singlesignon": "Pojedyncze logowanie", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "startFirstChat": "Rozpocznij swój pierwszy czat", - "@startFirstChat": {}, - "verifyStart": "Rozpocznij weryfikację", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Pomyślnie zweryfikowano!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Weryfikowanie innego konta", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Oczekiwanie na zaakceptowanie numerów przez drugą osobę…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "sender": "Nadawca", - "@sender": {}, - "openGallery": "Otwórz galerię", - "@openGallery": {}, - "start": "Start", - "@start": {}, - "pleaseEnterRecoveryKeyDescription": "Aby odblokować wcześniejsze wiadomości, wprowadź swój klucz odzyskiwania, który został wygenerowany w poprzedniej sesji. Twój klucz odzyskiwania NIE jest Twoim hasłem.", - "@pleaseEnterRecoveryKeyDescription": {}, - "videoWithSize": "Film ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "hydrateTorLong": "Czy ostatnio eksportowałeś/-aś swoją sesję na TOR? Szybko ją zaimportuj i kontynuuj rozmowy.", - "@hydrateTorLong": {}, - "dehydrateTorLong": "W przypadku użytkowników sieci TOR zaleca się eksportowanie sesji przed zamknięciem okna.", - "@dehydrateTorLong": {}, - "hydrate": "Przywracanie z pliku kopii zapasowej", - "@hydrate": {}, - "noMatrixServer": "{server1} nie jest serwerem matriksa, czy chcesz zamiast niego użyć {server2}?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "hydrateTor": "Użytkownicy TOR-a: Importuj eksport sesji", - "@hydrateTor": {}, - "numUsersTyping": "{count} użytkowników pisze…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "onlineKeyBackupEnabled": "Kopia zapasowa kluczy online jest włączona", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterRecoveryKey": "Wprowadź swój klucz odzyskiwania:", - "@pleaseEnterRecoveryKey": {}, - "submit": "Odeślij", - "@submit": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Wysłaliśmy Ci maila", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "unverified": "Niezweryfikowane", - "@unverified": {}, - "wipeChatBackup": "Wymazać kopię zapasową czatu, aby utworzyć nowy klucz odzyskiwania?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Kto może wykonywać jakie czynności", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "reportUser": "Zgłoś użytkownika", - "@reportUser": {}, - "dismiss": "Odrzuć", - "@dismiss": {}, - "markAsRead": "Oznacz jako przeczytane", - "@markAsRead": {}, - "passphraseOrKey": "fraza dostępu lub klucz odzyskiwania", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "openChat": "Otwórz czat", - "@openChat": {}, - "addToSpaceDescription": "Wybierz przestrzeń, do której ten czat ma być dodany.", - "@addToSpaceDescription": {}, - "supposedMxid": "To powinno być {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasdm": "Oznacz jako pokój wiadomości bezpośrednich dla podanego Matrix ID", - "@commandHint_markasdm": {}, - "confirmMatrixId": "Potwierdź swój identyfikator Matrix w celu usunięcia konta.", - "@confirmMatrixId": {}, - "commandHint_markasgroup": "Oznacz jako grupę", - "@commandHint_markasgroup": {}, - "noEmotesFound": "Nie znaleziono żadnych emotek. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "dehydrate": "Eksportuj sesję i wymaż urządzenie", - "@dehydrate": {}, - "dehydrateWarning": "Tego nie można cofnąć. Upewnij się, że plik kopii zapasowej jest bezpiecznie przechowywany.", - "@dehydrateWarning": {}, - "dehydrateTor": "Użytkownicy TOR-a: Eksportuj sesję", - "@dehydrateTor": {}, - "unsupportedAndroidVersion": "Nieobsługiwana wersja systemu Android", - "@unsupportedAndroidVersion": {}, - "widgetCustom": "Własny", - "@widgetCustom": {}, - "widgetEtherpad": "Notatka", - "@widgetEtherpad": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "pinMessage": "Przypnij do pokoju", - "@pinMessage": {}, - "confirmEventUnpin": "Czy na pewno chcesz trwale odpiąć wydarzenie?", - "@confirmEventUnpin": {}, - "youJoinedTheChat": "Dołączono do czatu", - "@youJoinedTheChat": {}, - "user": "Użytkownik", - "@user": {}, - "custom": "Własne", - "@custom": {}, - "newGroup": "Nowa grupa", - "@newGroup": {}, - "newSpace": "Nowa przestrzeń", - "@newSpace": {}, - "fileIsTooBigForServer": "Serwer zgłasza, że plik jest zbyt duży, aby go wysłać.", - "@fileIsTooBigForServer": {}, - "youBannedUser": "Zbanowałeś/-aś {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "users": "Użytkownicy", - "@users": {}, - "countFiles": "{count} plików", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "noOtherDevicesFound": "Nie znaleziono innych urządzeń", - "@noOtherDevicesFound": {}, - "widgetUrlError": "Niepoprawny URL.", - "@widgetUrlError": {}, - "widgetNameError": "Podaj nazwę wyświetlaną.", - "@widgetNameError": {}, - "encryptThisChat": "Zaszyfruj ten czat", - "@encryptThisChat": {}, - "disableEncryptionWarning": "Ze względów bezpieczeństwa nie można wyłączyć szyfrowania w czacie, w którym zostało ono wcześniej włączone.", - "@disableEncryptionWarning": {}, - "deviceKeys": "Klucze urządzenia:", - "@deviceKeys": {}, - "emailOrUsername": "Adres e-mail lub nazwa użytkownika", - "@emailOrUsername": {}, - "indexedDbErrorLong": "Przechowywanie wiadomości niestety nie jest domyślnie włączone w trybie prywatnym.\nOdwiedź\n - about:config\n - ustaw dom.indexedDB.privateBrowsing.enabled na true\nW przeciwnym razie nie jest możliwe uruchomienie FluffyChat.", - "@indexedDbErrorLong": {}, - "saveKeyManuallyDescription": "Zapisz ten klucz ręcznie, uruchamiając systemowe okno dialogowe udostępniania lub schowek.", - "@saveKeyManuallyDescription": {}, - "screenSharingTitle": "udostępnianie ekranu", - "@screenSharingTitle": {}, - "appearOnTopDetails": "Umożliwia wyświetlanie aplikacji nad innymi (nie jest to konieczne, jeśli FluffyChat jest już ustawiony jako konto do dzwonienia)", - "@appearOnTopDetails": {}, - "noKeyForThisMessage": "Może się to zdarzyć, jeśli wiadomość została wysłana przed zalogowaniem się na to konto na tym urządzeniu.\n\nMożliwe jest również, że nadawca zablokował Twoje urządzenie lub coś poszło nie tak z połączeniem internetowym.\n\nJesteś w stanie odczytać wiadomość na innej sesji? W takim razie możesz przenieść z niej wiadomość! Wejdź w Ustawienia > Urządzenia i upewnij się, że Twoje urządzenia zweryfikowały się wzajemnie. Gdy następnym razem otworzysz pokój i obie sesje będą włączone, klucze zostaną przekazane automatycznie.\n\nNie chcesz stracić kluczy podczas wylogowania lub przełączania urządzeń? Upewnij się, że w ustawieniach masz włączoną kopię zapasową czatu.", - "@noKeyForThisMessage": {}, - "sorryThatsNotPossible": "Przepraszamy... to nie jest możliwe", - "@sorryThatsNotPossible": {}, - "noBackupWarning": "Uwaga! Bez włączenia kopii zapasowej czatu, stracisz dostęp do swoich zaszyfrowanych wiadomości. Zaleca się włączenie kopii zapasowej czatu przed wylogowaniem.", - "@noBackupWarning": {}, - "commandHint_googly": "Wyślij kręcące się oczka", - "@commandHint_googly": {}, - "callingPermissions": "Uprawnienia połączeń", - "@callingPermissions": {}, - "storeInAndroidKeystore": "Przechowaj w Android KeyStore", - "@storeInAndroidKeystore": {}, - "commandHint_cuddle": "Wyślij przytulenie", - "@commandHint_cuddle": {}, - "googlyEyesContent": "{senderName} wysyła ci kręcące się oczka", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cuddleContent": "{senderName} przytula cię", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} uściska cię", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_hug": "Wyślij uścisk", - "@commandHint_hug": {}, - "reactedWith": "{sender} zareagował/-a z {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "emojis": "Emoji", - "@emojis": {}, - "placeCall": "Zadzwoń", - "@placeCall": {}, - "voiceCall": "Połączenie głosowe", - "@voiceCall": {}, - "unsupportedAndroidVersionLong": "Ta funkcja wymaga nowszej wersji systemu Android. Sprawdź aktualizacje lub wsparcie Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "videoCallsBetaWarning": "Należy pamiętać, że połączenia wideo są obecnie w fazie beta. Mogą nie działać zgodnie z oczekiwaniami lub nie działać w ogóle na wszystkich platformach.", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "Eksperymentalne połączenia wideo", - "@experimentalVideoCalls": {}, - "indexedDbErrorTitle": "Problemy związane z trybem prywatnym", - "@indexedDbErrorTitle": {}, - "switchToAccount": "Przełącz na konto {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Następne konto", - "@nextAccount": {}, - "previousAccount": "Poprzednie konto", - "@previousAccount": {}, - "addWidget": "Dodaj widżet", - "@addWidget": {}, - "widgetVideo": "Film", - "@widgetVideo": {}, - "widgetName": "Nazwa", - "@widgetName": {}, - "errorAddingWidget": "Błąd podczas dodawania widżetu.", - "@errorAddingWidget": {}, - "youRejectedTheInvitation": "Odrzucono zaproszenie", - "@youRejectedTheInvitation": {}, - "youAcceptedTheInvitation": "👍 Zaakceptowałeś/-aś zaproszenie", - "@youAcceptedTheInvitation": {}, - "youHaveWithdrawnTheInvitationFor": "Wycofano zaproszenie dla {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 Zostałeś/-aś zaproszony/-a przez {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Zaprosiłeś/-aś {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 Wyrzuciłeś/-aś {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Wyrzuciłeś/-aś i zbanowałeś/-aś {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Odbanowałeś/-aś {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "unlockOldMessages": "Odblokuj stare wiadomości", - "@unlockOldMessages": {}, - "storeInSecureStorageDescription": "Przechowaj klucz odzyskiwania w bezpiecznym magazynie tego urządzenia.", - "@storeInSecureStorageDescription": {}, - "storeInAppleKeyChain": "Przechowaj w pęku kluczy Apple", - "@storeInAppleKeyChain": {}, - "storeSecurlyOnThisDevice": "Przechowaj bezpiecznie na tym urządzeniu", - "@storeSecurlyOnThisDevice": {}, - "foregroundServiceRunning": "To powiadomienie pojawia się, gdy usługa w tle jest uruchomiona.", - "@foregroundServiceRunning": {}, - "screenSharingDetail": "Udostępniasz swój ekran w FluffyChat", - "@screenSharingDetail": {}, - "callingAccount": "Konto połączeń", - "@callingAccount": {}, - "callingAccountDetails": "Pozwala FluffyChat używać natywnej aplikacji do wykonywania połączeń w Androidzie.", - "@callingAccountDetails": {}, - "appearOnTop": "Wyświetlaj nad innymi", - "@appearOnTop": {}, - "otherCallingPermissions": "Mikrofon, kamera i inne uprawnienia FluffyChat", - "@otherCallingPermissions": {}, - "whyIsThisMessageEncrypted": "Dlaczego nie można odczytać tej wiadomości?", - "@whyIsThisMessageEncrypted": {}, - "enterSpace": "Wejdź do przestrzeni", - "@enterSpace": {}, - "enterRoom": "Wejdź do pokoju", - "@enterRoom": {}, - "allSpaces": "Wszystkie przestrzenie", - "@allSpaces": {}, - "numChats": "{number} czatów", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Ukryj nieistotne wydarzenia stanu", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Nie pokazuj ponownie", - "@doNotShowAgain": {}, - "wasDirectChatDisplayName": "Pusty czat (wcześniej {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "newSpaceDescription": "Przestrzenie pozwalają na konsolidację czatów i budowanie prywatnych lub publicznych społeczności.", - "@newSpaceDescription": {}, - "reopenChat": "Otwórz ponownie czat", - "@reopenChat": {}, - "fileHasBeenSavedAt": "Plik został zapisany w ścieżce {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "addToBundle": "Dodaj do pakietu", - "@addToBundle": {}, - "bundleName": "Nazwa pakietu", - "@bundleName": {}, - "editBundlesForAccount": "Edytuj paczki dla tego konta", - "@editBundlesForAccount": {}, - "jumpToLastReadMessage": "Przejdź do ostatnio przeczytanej wiadomości", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Czytaj do tego miejsca", - "@readUpToHere": {}, - "jump": "Przejdź", - "@jump": {}, - "removeFromBundle": "Usuń z tej paczki", - "@removeFromBundle": {}, - "openLinkInBrowser": "Otwórz link w przeglądarce", - "@openLinkInBrowser": {}, - "allRooms": "Wszystkie czaty grupowe", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "O nie. Coś poszło nie tak. Spróbuj ponownie później. Jeśli chcesz, możesz zgłosić błąd programistom.", - "@reportErrorDescription": {}, - "setColorTheme": "Ustal styl kolorów:", - "@setColorTheme": {}, - "tryAgain": "Spróbuj ponownie", - "@tryAgain": {}, - "messagesStyle": "Wiadomości:", - "@messagesStyle": {}, - "chatDescription": "Opis czatu", - "@chatDescription": {}, - "invalidServerName": "Nieprawidłowa nazwa serwera", - "@invalidServerName": {}, - "chatPermissions": "Uprawnienia czatu", - "@chatPermissions": {}, - "signInWithPassword": "Zaloguj się z hasłem", - "@signInWithPassword": {}, - "setChatDescription": "Ustaw opis czatu", - "@setChatDescription": {}, - "importFromZipFile": "Zaimportuj z pliku .zip", - "@importFromZipFile": {}, - "redactedBy": "Utajnione przez {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "signInWith": "Zaloguj się z {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "optionalRedactReason": "(Opcjonalnie) Powód utajnienia tej wiadomości...", - "@optionalRedactReason": {}, - "exportEmotePack": "Eksportuj pakiet Emotikon jako .zip", - "@exportEmotePack": {}, - "inviteContactToGroupQuestion": "Czy chcesz zaprosić {contact} do czatu „{groupName}”?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Utajnione przez {username} z powodu: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "redactMessageDescription": "Wiadomość zostanie utajniona u wszystkich uczestników tej rozmowy. Nie można tego cofnąć.", - "@redactMessageDescription": {}, - "invalidInput": "Nieprawidłowe dane!", - "@invalidInput": {}, - "report": "zgłoś", - "@report": {}, - "addChatDescription": "Dodaj opis tego czatu...", - "@addChatDescription": {}, - "directChat": "Rozmowa bezpośrednia", - "@directChat": {}, - "wrongPinEntered": "Wprowadzono nieprawidłowy kod PIN! Spróbuj ponownie za {seconds} sekund...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "Wysyłaj powiadomienie o pisaniu", - "@sendTypingNotifications": {}, - "inviteGroupChat": "📨 Zaproszenie do rozmowy grupowej", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Zaproszenie do rozmowy prywatnej", - "@invitePrivateChat": {}, - "importEmojis": "Zaimportuj Emoji", - "@importEmojis": {}, - "noChatDescriptionYet": "Nie utworzono jeszcze opisu czatu.", - "@noChatDescriptionYet": {}, - "notAnImage": "To nie jest plik obrazu.", - "@notAnImage": {}, - "chatDescriptionHasBeenChanged": "Zmieniono opis czatu", - "@chatDescriptionHasBeenChanged": {}, - "profileNotFound": "Nie można odnaleźć użytkownika na serwerze. Być może wystąpił problem z połączeniem lub użytkownik nie istnieje.", - "@profileNotFound": {}, - "shareInviteLink": "Udostępnij link zaproszenia", - "@shareInviteLink": {}, - "emoteKeyboardNoRecents": "Tutaj pojawiają się ostatnio używane emotikony...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Ustaw wygląd:", - "@setTheme": {}, - "replace": "Zastąp", - "@replace": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Spróbuj ponownie później lub wybierz inny serwer.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Utwórz grupę", - "@createGroup": {}, - "importNow": "Zaimportuj", - "@importNow": {}, - "invite": "Zaproszenie", - "@invite": {}, - "block": "Zablokuj", - "@block": {}, - "blockedUsers": "Zablokowani użytkownicy", - "@blockedUsers": {}, - "blockUsername": "Ignoruj użytkownika", - "@blockUsername": {}, - "publicLink": "Link publiczny", - "@publicLink": {}, - "transparent": "Przezroczystość", - "@transparent": {}, - "select": "Zaznacz", - "@select": {}, - "calls": "Połączenia", - "@calls": {}, - "overview": "Podsumowanie", - "@overview": {}, - "learnMore": "Dowiedz się więcej", - "@learnMore": {}, - "groupName": "Nazwa grupy", - "@groupName": {}, - "startConversation": "Rozpocznij rozmowę", - "@startConversation": {}, - "newPassword": "Nowe hasło", - "@newPassword": {}, - "thisDevice": "To urządzenie:", - "@thisDevice": {}, - "gallery": "Galeria", - "@gallery": {}, - "files": "Pliki", - "@files": {}, - "discover": "Odkrywaj", - "@discover": {}, - "restricted": "Ograniczone", - "@restricted": {}, - "decline": "Odmów", - "@decline": {}, - "nothingFound": "Nic nie odnaleziono...", - "@nothingFound": {}, - "stickers": "Naklejki", - "@stickers": {} -} diff --git a/assets/l10n/intl_pt.arb b/assets/l10n/intl_pt.arb deleted file mode 100644 index c6deaff38..000000000 --- a/assets/l10n/intl_pt.arb +++ /dev/null @@ -1,1903 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.940318", - "copiedToClipboard": "Copiada para a área de transferência", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "login": "Iniciar sessão", - "@login": { - "type": "text", - "placeholders": {} - }, - "about": "Sobre", - "@about": { - "type": "text", - "placeholders": {} - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Tens a certeza?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notificações", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "account": "Conta", - "@account": { - "type": "text", - "placeholders": {} - }, - "cancel": "Cancelar", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "delete": "Eliminar", - "@delete": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "help": "Ajuda", - "@help": { - "type": "text", - "placeholders": {} - }, - "messages": "Mensagens", - "@messages": { - "type": "text", - "placeholders": {} - }, - "reason": "Razão", - "@reason": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privacidade", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Abrir câmara", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "settings": "Configurações", - "@settings": { - "type": "text", - "placeholders": {} - }, - "logout": "Terminar sessão", - "@logout": { - "type": "text", - "placeholders": {} - }, - "search": "Pesquisar", - "@search": { - "type": "text", - "placeholders": {} - }, - "users": "Utilizadores", - "@users": {}, - "close": "Fechar", - "@close": { - "type": "text", - "placeholders": {} - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@connect": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@chats": { - "type": "text", - "placeholders": {} - }, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@addAccount": {}, - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "@chatHasBeenAddedToThisSpace": {}, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@device": { - "type": "text", - "placeholders": {} - }, - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@encryption": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@invited": { - "type": "text", - "placeholders": {} - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@password": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@remove": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "@id": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "@blocked": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@sendOnEnter": {}, - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@fileName": { - "type": "text", - "placeholders": {} - }, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@create": { - "type": "text", - "placeholders": {} - }, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@alias": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@all": { - "type": "text", - "placeholders": {} - }, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@edit": { - "type": "text", - "placeholders": {} - }, - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@copy": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@none": { - "type": "text", - "placeholders": {} - }, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@yourChatBackupHasBeenSetUp": {}, - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "@people": { - "type": "text", - "placeholders": {} - }, - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@repeatPassword": {}, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "@callingPermissions": {}, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@start": {}, - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@identity": { - "type": "text", - "placeholders": {} - }, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@moderator": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@send": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "@banned": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@chat": { - "type": "text", - "placeholders": {} - }, - "@group": { - "type": "text", - "placeholders": {} - }, - "@leave": { - "type": "text", - "placeholders": {} - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@allChats": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@license": { - "type": "text", - "placeholders": {} - }, - "@addToSpace": {}, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@forward": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@clearArchive": {}, - "@appLock": { - "type": "text", - "placeholders": {} - }, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "@importEmojis": {}, - "@confirm": { - "type": "text", - "placeholders": {} - }, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@you": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@pleaseEnterANumber": {}, - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@archive": { - "type": "text", - "placeholders": {} - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "@devices": { - "type": "text", - "placeholders": {} - }, - "@accept": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@pin": { - "type": "text", - "placeholders": {} - }, - "@importNow": {}, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "@invite": {}, - "@enableMultiAccounts": {}, - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@screenSharingDetail": {}, - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {}, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - } -} \ No newline at end of file diff --git a/assets/l10n/intl_pt_BR.arb b/assets/l10n/intl_pt_BR.arb deleted file mode 100644 index 95ba83675..000000000 --- a/assets/l10n/intl_pt_BR.arb +++ /dev/null @@ -1,2709 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.925971", - "about": "Sobre", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Aceitar", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} aceitou o convite", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Conta", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} ativou a criptografia ponta-a-ponta", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Adicionar email", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "cognome", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Todas", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Todas as conversas", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} atendeu à chamada", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Qualquer pessoa pode participar", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Trava do aplicativo", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arquivo", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Usuários convidados podem participar", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Tem certeza?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Tem certeza que deseja encerrar a sessão?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Para poder validar a outra pessoa, por favor, insira sua frase secreta ou chave de recuperação.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Aceitar esta solicitação de verificação de {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Reproduzir automaticamente figurinhas animadas e emojis", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "O servidor matriz suporta os tipos de login:\n{serverVersions}\nMas este app suporta apenas:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "O servidor matriz suporta as versões Spec:\n{serverVersions}\nMas este app suporta apenas {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Banir da conversa", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Banido", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} baniu {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Bloquear dispositivo", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Bloqueado", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Mensagens de robôs", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Cancelar", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Não foi possível abrir a URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Alterar o nome do dispositivo", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} alterou o avatar da conversa", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} alterou a descrição da conversa para: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} alterou o nome da conversa para: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} alterou as permissões na conversa", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} mudou o seu nome de exibição para: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} alterou as regras de acesso dos convidados", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} alterou as regras de acesso dos convidados para: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} alterou a visibilidade do histórico", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} alterou a visibilidade do histórico para: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} alterou as regras para participação", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} alterou as regras para participação para: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} alterou seu avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} alterou os cognomes da sala", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} alterou o link de convite", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Alterar a senha", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Alterar o servidor matriz", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Alterar o tema", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Alterar o nome do grupo", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Alterar seu avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "A criptografia foi corrompida", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Conversas", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Backup da conversa", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Suas mensagens antigas são protegidas com sua chave de recuperação. Por favor, evite perdê-la.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Detalhes da conversa", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Conversas", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Escolha uma senha forte", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Limpar arquivo", - "@clearArchive": {}, - "close": "Fechar", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Banir um(a) usuário(a) desta sala", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Enviar mensagem formatada em HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Convidar um(a) usuário(a) para esta sala", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Entrar numa sala", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Remover um(a) usuário(a) desta sala", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Sair desta sala", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Descrever você mesmo", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Determinar sua imagem para esta sala (via mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Determinar seu nome de exibição para esta sala", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Determinar o grau de poderes de um(a) usuário(a) (padrão: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Enviar mensagem sem formatação", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Enviar uma resposta como reação", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Enviar mensagem", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Revogar o banimento de um(a) usuário(a) desta sala", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Comando inválido", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} não é um comando.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Por favor compare os emojis", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Por favor compare os números", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Configurar conversa", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Confirma", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Conectar", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "O contato foi convidado ao grupo", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Contém nome de exibição", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Contém nome de usuário", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "O conteúdo foi denunciado para quem administra o servidor", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Copiado para área de transferência", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Copiar", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Copiar para a área de transferência", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Não foi possível decriptar a mensagem: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} participantes", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Criar", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} criou a conversa", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Novo espaço", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Ativo", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Escuro", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}/{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}/{month}/{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Isto desativará a conta do usuário. É irreversível! Tem certeza?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Nível de permissão padrão", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Apagar", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Apagar conta", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Apagar mensagem", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Dispositivo", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID do dispositivo", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Dispositivos", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Conversas diretas", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "O nome de exibição foi alterado", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Baixar arquivo", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Editar", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Editar servidores bloqueados", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Editar nome de exibição", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Editar cognome da sala", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Editar o avatar da sala", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emoji já existe!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Código emoji inválido!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Pacote de emoji para a sala", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Configuração dos Emoji", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Código Emoji", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Você tem que escolher um código emoji e uma imagem!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Conversa vazia", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Habilitar globalmente o pacote de emoji", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Habilitar criptografia", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Você não poderá desabilitar a criptografia posteriormente. Tem certeza?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Criptografado", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Criptografia", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "A criptografia não está habilitada", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} finalizou a chamada", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Inserir endereço de e-mail", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Insira um servidor matriz", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Erro ao obter local: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Tudo pronto!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extremamente ofensivo", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Nome do arquivo", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Tamanho da fonte", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Encaminhar", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Desde que entrou", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Desde o convite", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Ir para a sala nova", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Grupo", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Grupo público", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Grupos", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Grupo com {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Convidados estão proibidos", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Convidados podem participar", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} revogou o convite para {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Ajuda", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Ocultar eventos removidos", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Ocultar eventos desconhecidos", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "O quão ofensivo é este conteúdo?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identidade", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorar", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Usuários ignorados", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Eu cliquei no link", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Frase secreta ou chave de recuperação incorreta", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Inofensivo", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Convidar contato", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Convidar contato para {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Foi convidado", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} convidou {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Apenas usuários convidados", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Convite para mim", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} convidou você para o FluffyChat. \n1. Visite fluffychat.im e instale o aplicativo\n2. Entre ou crie uma conta \n3. Abra o link do convite:\n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "está escrevendo…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} entrou na conversa", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Entrar na sala", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} enxotou {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} expulsou e baniu {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Expulso da conversa", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Última vez ativo: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Sair", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Sair da conversa", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licença", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Claro", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Carregue {count} mais participantes", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Carregando... Aguarde.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Carregando mais…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "O serviço de localização está desabilitado. Por favor, habilite-o para compartilhar sua localização.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Permissão de localização negada. Conceda as permissões para habilitar o compartilhamento de localização.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Iniciar sessão", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Conectar a {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Encerrar sessão", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Alterações de membros", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Mencionar", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Mensagens", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderador", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Silenciar", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Por favor, observe que, por enquanto, você precisa do Pantalaimon para usar criptografia ponta-a-ponta.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Nova conversa", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Nova mensagem no FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nova solicitação de verificação!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Próximo", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Não", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Sem conexão com o servidor", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Nenhum emoji encontrado. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Você só pode ativar criptografia quando a sala não for mais publicamente acessível.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Aparentemente você não tem serviços Google no seu celular. Para receber notificações no FluffyChat, recomendamos instalar ntfy.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} não é um servidor matrix, usar {server2} talvez?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "none": "Nenhum", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Você ainda não adicionou uma forma de recuparar sua senha.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Sem permissão", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Nenhuma sala encontrada…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Notificações", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Notificações habilitadas para esta conta", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} usuários estão digitando…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Obtendo localização…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Ofensivo", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Desconectado", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Disponível", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Backup de chaves está ativado", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Opa! Infelizmente, um erro ocorreu ao configurar as notificações.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Opa, algo deu errado…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Abra o app para ler as mensagens", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Abra a câmera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Abrir no mapas", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Ou", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Participante", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "frase secreta ou chave de recuperação", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Senha", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Esqueci a senha", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Senha foi alterada", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Recuperação de senha", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Pessoas", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Escolha uma imagem", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Alfinetar", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Tocar {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Por favor, selecione", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Por favor, escolha um código", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Por favor, clique a ligação no e-mail para prosseguir.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Por favor, insira 4 dígitos ou deixe em branco para desativar a trava do aplicativo.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Por favor, insira sua senha", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Por favor, insira seu PIN", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Por favor, insira seu nome de usuário", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Por favor, siga as instruções no site e toque em próximo.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Privacidade", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Salas públicas", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Regras de notificação", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Motivo", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Gravando", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} removeu um evento", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Retratar mensagem", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Registrar", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Recusar", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} recusou o convite", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Retornar", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Remover", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Remover todos os outros dispositivos", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Removido por {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Remover dispositivo", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Revogar banimento", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Remover seu avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Exibir conteúdo formatado", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Substituir sala por uma nova versão", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Responder", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Denunciar mensagem", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Solicitar permissão", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Sala foi atualizada", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Versão da sala", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Salvar arquivo", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Buscar", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Segurança", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Visto por {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Enviar", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Enviar mensagem", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Enviar como texto", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Enviar audio", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Enviar arquivo", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Enviar imagem", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Enviar mensagens", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Enviar original", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Enviar figurinha", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Enviar vídeo", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} enviou um arquivo", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} enviou um audio", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} enviou uma imagem", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} enviou uma figurinha", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} enviou um vídeo", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} enviou informações de chamada", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Fixar como cognome principal", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Implantar emojis personalizados", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Enviar link de convite", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Determinar níveis de permissão", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Alterar o status", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Configurações", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Compartilhar", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} compartilhou sua localização", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Compartilhar localização", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Mostrar senha", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Identidade Única", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Pular", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Código fonte", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Espaço é público", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Nome do espaço", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} iniciou uma chamada", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Como vai você?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Submeter", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Sincronizando… Por favor, aguarde.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistema", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Não correspondem", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Correspondem", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Alternar favorito", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Alternar Silenciado", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Marcar lido/não lido", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Demasiadas requisições. Por favor, tente novamente mais tarde!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Transferir de outro dispositivo", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Tente enviar novamente", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Indisponível", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} revogou o banimento de {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Desbloquear dispositivo", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Dispositivo desconhecido", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Algoritmo de criptografia desconhecido", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Evento desconhecido '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Cancelar silenciamento", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Desalfinetar", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 conversa não lida} other{{unreadCount} conversas não lidas}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} e mais {count} pessoas estão digitando…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} e {username2} estão digitando…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} está digitando…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} saiu da conversa", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Nome de usuário", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} enviou um evento {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Verificado", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Verificar", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Iniciar verificação", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Verificação efetivada!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verificando outra conta", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Vídeochamada", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Visibilidade do histórico da conversa", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Visível aos participantes", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Visível a qualquer pessoa", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Mensagem de voz", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Esperando que a outra pessoa aceite a solicitação…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Esperando que a outra pessoa aceite os emoji…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Aguardando a outra pessoa aceitar os números…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Pano de fundo:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Atenção!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Enviamos um e-mail para você", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Quem pode desempenhar quais ações", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Quais pessoas são permitidas participar deste grupo", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Por que você quer denunciar isto?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Limpar o backup da conversa para criar uma nova chave de recuperação?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Você pode recuperar a sua senha com estes endereços.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Escreva uma mensagem…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Sim", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Você", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Você não está mais participando desta conversa", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Você foi banido desta conversa", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Sua chave pública", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "Um dos seus clientes foi desvinculado", - "@oneClientLoggedOut": {}, - "addAccount": "Adicionar conta", - "@addAccount": {}, - "unverified": "Não verificado", - "@unverified": {}, - "yourChatBackupHasBeenSetUp": "Seu backup de conversas foi configurado.", - "@yourChatBackupHasBeenSetUp": {}, - "editBundlesForAccount": "Editar coleções para esta conta", - "@editBundlesForAccount": {}, - "serverRequiresEmail": "Este servidor precisa validar seu email para efetuar o registro.", - "@serverRequiresEmail": {}, - "messageInfo": "Informações da mensagem", - "@messageInfo": {}, - "sender": "Remetente", - "@sender": {}, - "publish": "Publicar", - "@publish": {}, - "removeFromSpace": "Remover do espaço", - "@removeFromSpace": {}, - "link": "Link", - "@link": {}, - "start": "Começar", - "@start": {}, - "repeatPassword": "Repita a senha", - "@repeatPassword": {}, - "addToSpace": "Adicionar ao espaço", - "@addToSpace": {}, - "sendOnEnter": "Enviar ao pressionar enter", - "@sendOnEnter": {}, - "homeserver": "Servidor matriz", - "@homeserver": {}, - "chatHasBeenAddedToThisSpace": "A conversa foi adicionada a este espaço", - "@chatHasBeenAddedToThisSpace": {}, - "commandHint_clearcache": "Limpar dados temporários", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Criar uma sala vazia.\nUse --no-encryption para desabilitar a criptografia", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_discardsession": "Descartar sessão", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Iniciar uma conversa direta\nUse --no-encryption para desabilitar a criptografia", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "scanQrCode": "Escanear o código QR", - "@scanQrCode": {}, - "openVideoCamera": "Abra a câmera para um vídeo", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "addToBundle": "Adicionar à coleção", - "@addToBundle": {}, - "removeFromBundle": "Remover desta coleção", - "@removeFromBundle": {}, - "bundleName": "Nome da coleção", - "@bundleName": {}, - "enableMultiAccounts": "(BETA) Habilitar múltiplas contas neste dispositivo", - "@enableMultiAccounts": {}, - "time": "Hora", - "@time": {}, - "messageType": "Tipo da mensagem", - "@messageType": {}, - "openGallery": "Abrir galeria", - "@openGallery": {}, - "addToSpaceDescription": "Selecione um espaço para adicionar esta conversa.", - "@addToSpaceDescription": {}, - "videoWithSize": "Vídeo ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "markAsRead": "Marcar como lido", - "@markAsRead": {}, - "dismiss": "Descartar", - "@dismiss": {}, - "separateChatTypes": "Separar Conversas Diretas e Grupos", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "openChat": "Abrir conversa", - "@openChat": {}, - "reportUser": "Delatar usuário", - "@reportUser": {}, - "emojis": "Emojis", - "@emojis": {}, - "placeCall": "Chamar", - "@placeCall": {}, - "reactedWith": "{sender} reagiu com {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "confirmEventUnpin": "Tem certeza que quer desafixar o evento permanentemente?", - "@confirmEventUnpin": {}, - "pinMessage": "Afixar à sala", - "@pinMessage": {}, - "voiceCall": "Chamada de voz", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Versão Android não suportada", - "@unsupportedAndroidVersion": {}, - "widgetNameError": "Por favor, forneça um nome de exibição.", - "@widgetNameError": {}, - "unsupportedAndroidVersionLong": "Esta funcionalidade requer uma versão mais nova do Android. Por favor, busque atualizações ou suporte ao Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "emailOrUsername": "Email ou nome de usuário", - "@emailOrUsername": {}, - "videoCallsBetaWarning": "Por favor, note que chamadas de vídeo estão atualmente em teste. Podem não funcionar como esperado ou sequer funcionar em algumas plataformas.", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "Vídeo chamadas experimentais", - "@experimentalVideoCalls": {}, - "widgetVideo": "Vídeo", - "@widgetVideo": {}, - "errorAddingWidget": "Erro ao adicionar a ferramenta.", - "@errorAddingWidget": {}, - "addWidget": "Adicionar ferramenta", - "@addWidget": {}, - "widgetEtherpad": "Anotação", - "@widgetEtherpad": {}, - "widgetUrlError": "Isto não é uma URL válida.", - "@widgetUrlError": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Personalizado", - "@widgetCustom": {}, - "widgetName": "Nome", - "@widgetName": {}, - "switchToAccount": "Alternar para a conta {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Próxima conta", - "@nextAccount": {}, - "previousAccount": "Conta anterior", - "@previousAccount": {}, - "youRejectedTheInvitation": "Você rejeitou o convite", - "@youRejectedTheInvitation": {}, - "youBannedUser": "Você baniu {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Você revogou o convite para {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 Você foi convidado por {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Você convidou {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youAcceptedTheInvitation": "👍 Você aceitou o convite", - "@youAcceptedTheInvitation": {}, - "youJoinedTheChat": "Você entrou na conversa", - "@youJoinedTheChat": {}, - "youKicked": "👞 Você expulsou {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Você expulsou e baniu {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Você revogou o banimento de {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "cuddleContent": "{senderName} afagou você", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "pleaseEnterRecoveryKeyDescription": "Para destrancar suas mensagens antigas, por favor, insira sua chave de recuperação gerada numa sessão prévia. Suas chave de recuperação NÃO é sua senha.", - "@pleaseEnterRecoveryKeyDescription": {}, - "indexedDbErrorLong": "Infelizmente, o armazenamento de mensagens não é habilitado por padrão no modo privado.\nPor favor, visite\n- about:config\n- atribua \"true\" a \"dom.indexedDB.privateBrowsing.enabled\"\nDe outro modo, não será possível executar o FluffyChat.", - "@indexedDbErrorLong": {}, - "users": "Usuários", - "@users": {}, - "confirmMatrixId": "Por favor, confirme seu ID Matrix para apagar sua conta.", - "@confirmMatrixId": {}, - "supposedMxid": "Isto deveria ser {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "dehydrateTor": "Usuários TOR: Exportar sessão", - "@dehydrateTor": {}, - "recoveryKey": "Chave de recuperação", - "@recoveryKey": {}, - "recoveryKeyLost": "Perdeu a chave de recuperação?", - "@recoveryKeyLost": {}, - "commandHint_cuddle": "Enviar um afago", - "@commandHint_cuddle": {}, - "commandHint_hug": "Enviar um abraço", - "@commandHint_hug": {}, - "commandHint_googly": "Enviar olhos arregalados", - "@commandHint_googly": {}, - "googlyEyesContent": "{senderName} enviou olhos arregalados", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} abraçou você", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_markasdm": "Marcar como conversa direta para o ID Matrix dado", - "@commandHint_markasdm": {}, - "commandHint_markasgroup": "Marcar como grupo", - "@commandHint_markasgroup": {}, - "hydrateTor": "Usuários TOR: Importar sessão", - "@hydrateTor": {}, - "hydrateTorLong": "Você exportou sua última sessão no TOR? Importe ela rapidamente e continue conversando.", - "@hydrateTorLong": {}, - "hydrate": "Restaurar a partir de arquivo backup", - "@hydrate": {}, - "pleaseEnterRecoveryKey": "Por favor, insira sua chave de recuperação:", - "@pleaseEnterRecoveryKey": {}, - "indexedDbErrorTitle": "Problemas no modo privado", - "@indexedDbErrorTitle": {}, - "storeInSecureStorageDescription": "Guardar a chave de recuperação no armazenamento seguro deste dispositivo.", - "@storeInSecureStorageDescription": {}, - "saveKeyManuallyDescription": "Salvar esta chave manualmente via compartilhamento do sistema ou área de transferência.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Guardar no cofre do Android", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "Guardar no chaveiro da Apple", - "@storeInAppleKeyChain": {}, - "storeSecurlyOnThisDevice": "Guardar de modo seguro neste dispositivo", - "@storeSecurlyOnThisDevice": {}, - "user": "Usuário", - "@user": {}, - "custom": "Personalizado", - "@custom": {}, - "foregroundServiceRunning": "Esta notificação aparece quando um serviço está executando.", - "@foregroundServiceRunning": {}, - "callingPermissions": "Permissões de chamada", - "@callingPermissions": {}, - "callingAccount": "Conta para chamadas", - "@callingAccount": {}, - "callingAccountDetails": "Permitir que o FluffyChat use o app de chamadas nativo do Android.", - "@callingAccountDetails": {}, - "appearOnTop": "Aparecer no topo", - "@appearOnTop": {}, - "appearOnTopDetails": "Permitir que o app apareça no topo (desnecessário caso FluffyChat já esteja configurado como conta para chamadas)", - "@appearOnTopDetails": {}, - "otherCallingPermissions": "Microfone, câmera e outras permissões do FluffyChat", - "@otherCallingPermissions": {}, - "newGroup": "Novo grupo", - "@newGroup": {}, - "newSpace": "Novo espaço", - "@newSpace": {}, - "enterSpace": "Entrar no espaço", - "@enterSpace": {}, - "enterRoom": "Entrar na conversa", - "@enterRoom": {}, - "allSpaces": "Todos espaços", - "@allSpaces": {}, - "hideUnimportantStateEvents": "Ocultar eventos desimportantes", - "@hideUnimportantStateEvents": {}, - "countFiles": "{count} arquivos", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "doNotShowAgain": "Não mostrar novamente", - "@doNotShowAgain": {}, - "unlockOldMessages": "Destrancar mensagens antigas", - "@unlockOldMessages": {}, - "dehydrate": "Exportar sessão e limpar dispositivo", - "@dehydrate": {}, - "dehydrateWarning": "Esta ação não pode ser desfeita. Certifique-se de que o arquivo backup está guardado e seguro.", - "@dehydrateWarning": {}, - "dehydrateTorLong": "Para usuários TOR, é recomendado exportar a sessão antes de fechar a janela.", - "@dehydrateTorLong": {}, - "whyIsThisMessageEncrypted": "Por que esta mensagem está ilegível?", - "@whyIsThisMessageEncrypted": {}, - "screenSharingTitle": "Compartilhar tela", - "@screenSharingTitle": {}, - "screenSharingDetail": "Você está compartilhando sua tela no FluffyChat", - "@screenSharingDetail": {}, - "numChats": "{number} conversas", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "noKeyForThisMessage": "Isto pode ocorrer caso a mensagem tenha sido enviada antes da entrada na sua conta com este dispositivo.\n\nTambém é possível que o remetente tenha bloqueado o seu dispositivo ou ocorreu algum problema com a conexão.\n\nVocê consegue ler as mensagens em outra sessão? Então, pode transferir as mensagens de lá! Vá em Configurações > Dispositivos e confira se os dispositivos verificaram um ao outro. Quando abrir a sala da próxima vez e ambas as sessões estiverem abertas, as chaves serão transmitidas automaticamente.\n\nNão gostaria de perder suas chaves quando sair ou trocar de dispositivos? Certifique-se que o backup de conversas esteja habilitado nas configurações.", - "@noKeyForThisMessage": {}, - "allRooms": "Todos os Chats em Grupo", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "notAnImage": "Não é uma imagem.", - "@notAnImage": {}, - "importNow": "Importar agora", - "@importNow": {}, - "importEmojis": "Importar Emojis", - "@importEmojis": {}, - "importFromZipFile": "Importar de arquivo .zip", - "@importFromZipFile": {}, - "sendTypingNotifications": "Enviar notificações de digitação", - "@sendTypingNotifications": {}, - "startFirstChat": "Comece seu primeiro chat", - "@startFirstChat": {}, - "exportEmotePack": "Exportar pacote de Emotes como .zip", - "@exportEmotePack": {}, - "replace": "Substituir", - "@replace": {}, - "jumpToLastReadMessage": "Pular para a última mensagem lida", - "@jumpToLastReadMessage": {}, - "reportErrorDescription": "😭 Ah, não. Algo deu errado. Se quiser, pode relatar isto aos desenvolvedores.", - "@reportErrorDescription": {}, - "setColorTheme": "Aplicar paleta de cor:", - "@setColorTheme": {}, - "banUserDescription": "O usuário será banido da conversa e não poderá participar novamente até que isto seja revogado.", - "@banUserDescription": {}, - "removeDevicesDescription": "Você encerrará a sessão neste dispositivo e não poderá mais receber mensagens.", - "@removeDevicesDescription": {}, - "tryAgain": "Tente novamente", - "@tryAgain": {}, - "unbanUserDescription": "O usuário poderá ingressar novamente na conversa, caso tente.", - "@unbanUserDescription": {}, - "messagesStyle": "Mensagens:", - "@messagesStyle": {}, - "newSpaceDescription": "Espaços permitem que você consolide suas conversas e construa comunidades públicas ou privadas.", - "@newSpaceDescription": {}, - "chatDescription": "Descrição da conversa", - "@chatDescription": {}, - "encryptThisChat": "Encriptar esta conversa", - "@encryptThisChat": {}, - "reopenChat": "Reabrir conversa", - "@reopenChat": {}, - "pushNotificationsNotAvailable": "Notificações não estão disponíveis", - "@pushNotificationsNotAvailable": {}, - "invalidServerName": "Nome de usuário inválido", - "@invalidServerName": {}, - "chatPermissions": "Permissões da conversa", - "@chatPermissions": {}, - "signInWithPassword": "Autenticar com senha", - "@signInWithPassword": {}, - "makeAdminDescription": "Assim que promover este usuário a administrador, não poderá desfazê-lo e ele terá as mesmas permissões que você.", - "@makeAdminDescription": {}, - "setChatDescription": "Inserir descrição da conversa", - "@setChatDescription": {}, - "noOtherDevicesFound": "Nenhum outro dispositivo encontrado", - "@noOtherDevicesFound": {}, - "redactedBy": "Removido por {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "signInWith": "Autenticar com {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "fileIsTooBigForServer": "O servidor avisa que o arquivo é grande demais para ser enviado.", - "@fileIsTooBigForServer": {}, - "readUpToHere": "Marcar como lido até aqui", - "@readUpToHere": {}, - "optionalRedactReason": "(Opcional) Motivo para remover esta mensagem.", - "@optionalRedactReason": {}, - "archiveRoomDescription": "A conversa será movida para o arquivo. Outros usuários verão que você deixou a conversa.", - "@archiveRoomDescription": {}, - "inviteContactToGroupQuestion": "Você quer convidar {contact} para a conversa \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Removido por {username}, pois: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "fileHasBeenSavedAt": "Arquivo salvo em {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "redactMessageDescription": "A mensagem será removida para todos participantes desta conversa. Isto não poderá ser desfeito.", - "@redactMessageDescription": {}, - "invalidInput": "Inserção inválida!", - "@invalidInput": {}, - "report": "Relatar", - "@report": {}, - "addChatDescription": "Inserir descrição da conversa...", - "@addChatDescription": {}, - "hasKnocked": "🚪 {user} bateu na porta", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "openLinkInBrowser": "Abrir no navegador", - "@openLinkInBrowser": {}, - "disableEncryptionWarning": "Por razões de segurança, não possível desabilitar a encriptação uma vez habilitada.", - "@disableEncryptionWarning": {}, - "directChat": "Conversa direta", - "@directChat": {}, - "wrongPinEntered": "PIN incorreto! Tente novamente em {seconds} segundos...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "inviteGroupChat": "📨 Convidar para o grupo", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Convidar para uma conversa privada", - "@invitePrivateChat": {}, - "wasDirectChatDisplayName": "Conversa vazia (era {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "noChatDescriptionYet": "Nenhuma descrição da conversa disponível.", - "@noChatDescriptionYet": {}, - "learnMore": "Saiba mais", - "@learnMore": {}, - "chatDescriptionHasBeenChanged": "Descrição da conversa alterada", - "@chatDescriptionHasBeenChanged": {}, - "roomUpgradeDescription": "A conversa será recriada com a nova versão de sala. Todos participantes será notificados e terão que migrar para a nova sala. Você pode encontrar mais informações sobre versões de sala em https://spec.matrix.org/latest/room/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Por favor, insira um número maior que 0", - "@pleaseEnterANumber": {}, - "profileNotFound": "O usuário não foi encontrado neste servidor. Talvez um problema de conexão ou o usuário não existe.", - "@profileNotFound": {}, - "jump": "Pular", - "@jump": {}, - "sorryThatsNotPossible": "Desculpe... isto não é possível", - "@sorryThatsNotPossible": {}, - "shareInviteLink": "Compartilhar convite", - "@shareInviteLink": {}, - "deviceKeys": "Chaves de dispositivo:", - "@deviceKeys": {}, - "emoteKeyboardNoRecents": "Emotes recentes aparecem aqui...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Aplicar tema:", - "@setTheme": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Por favor, tente novamente mais tarde ou escolha um servidor diferente.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Criar grupo", - "@createGroup": {}, - "noBackupWarning": "Atenção! Sem habilitar o backup de conversa, você perderá acesso a suas mensagens encriptadas. É altamente recomendável habilitar o backup antes de encerrar a sessão.", - "@noBackupWarning": {}, - "kickUserDescription": "O usuário foi enxotado da conversa, mas não banido. Em conversas públicas, o usuário pode reingressar a qualquer momento.", - "@kickUserDescription": {}, - "invite": "Convidar", - "@invite": {}, - "blockListDescription": "Você pode bloquear usuários que estejam perturbando. Você não receberá mensagens ou convites de usuários na sua lista pessoal de bloqueios.", - "@blockListDescription": {}, - "createGroupAndInviteUsers": "Criar um grupo e convidar pessoas", - "@createGroupAndInviteUsers": {}, - "thisDevice": "Este dispositivo:", - "@thisDevice": {}, - "startConversation": "Começar uma conversa", - "@startConversation": {}, - "publicSpaces": "Espaços públicos", - "@publicSpaces": {}, - "blockedUsers": "Usuários bloqueados", - "@blockedUsers": {}, - "passwordIsWrong": "A senha inserida está incorreta", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Por favor, insira sua senha atual", - "@pleaseEnterYourCurrentPassword": {}, - "groupCanBeFoundViaSearch": "Grupos podem ser encontrados via busca", - "@groupCanBeFoundViaSearch": {}, - "publicLink": "Link público", - "@publicLink": {}, - "noUsersFoundWithQuery": "Infelizmente, não foi encontrado usuário via \"{query}\". Por favor, verifique se digitou corretamente.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "block": "Bloquear", - "@block": {}, - "nothingFound": "Nada foi encontrado...", - "@nothingFound": {}, - "yourGlobalUserIdIs": "Seu ID global é: ", - "@yourGlobalUserIdIs": {}, - "decline": "Rejeitar", - "@decline": {}, - "newPassword": "Nova senha", - "@newPassword": {}, - "passwordsDoNotMatch": "Senhas não batem", - "@passwordsDoNotMatch": {}, - "commandHint_sendraw": "Enviar JSON puro", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Desculpe... esta não parece ser a chave de recuperação correta.", - "@wrongRecoveryKey": {}, - "subspace": "Subespaço", - "@subspace": {}, - "select": "Selecionar", - "@select": {}, - "pleaseChooseAStrongPassword": "Por favor, escolha uma senha forte", - "@pleaseChooseAStrongPassword": {}, - "blockUsername": "Ignore usuário", - "@blockUsername": {}, - "addChatOrSubSpace": "Adicionar conversa ou subespaço", - "@addChatOrSubSpace": {}, - "groupName": "Nome do grupo", - "@groupName": {}, - "leaveEmptyToClearStatus": "Deixe em branco para limpar seu Status.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Ingressar no espaço", - "@joinSpace": {}, - "searchForUsers": "Buscar por @usuários...", - "@searchForUsers": {}, - "databaseMigrationTitle": "Banco de dados otimizado", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "Buscar por #conversas, @usuários...", - "@searchChatsRooms": {}, - "databaseMigrationBody": "Por favor, espere. Isto pode demorar um pouco.", - "@databaseMigrationBody": {}, - "youInvitedToBy": "Você foi convidado através do link para:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "forwardMessageTo": "Encaminhar mensagem para {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "formattedMessagesDescription": "Mostrar mensagens ricas com conteúdos tipo negrito usando markdown.", - "@formattedMessagesDescription": {}, - "verifyOtherUser": "🔐 Verificar outro usuário", - "@verifyOtherUser": {}, - "verifyOtherDevice": "🔐 Verificar outro aparelho", - "@verifyOtherDevice": {}, - "acceptedKeyVerification": "{sender} aceitou sua chave de verificação", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} iniciou a chave de verificação", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "Transparente", - "@transparent": {}, - "databaseBuildErrorBody": "Não foi possível construir o banco de dados SQLite. O aplicativo tentará utilizar o banco de dados legado por enquanto. Por favor, reporte este erro aos desenvolvedores em {url}. A mensagem de erro é: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "Ocorreu um erro enquanto o aplicativo era iniciado", - "@initAppError": {}, - "restoreSessionBody": "O aplicativo tentará agora restaurar sua sessão a partir do backup. Por favor, reporte este ao desenvolvedor em {url}. A mensagem de erro é: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sendReadReceipts": "Enviar recibos de leitura", - "@sendReadReceipts": {}, - "sendTypingNotificationsDescription": "Outros participantes neste chat podem ver quando você está digitando uma nova mensagem.", - "@sendTypingNotificationsDescription": {}, - "formattedMessages": "Mensagens formatadas", - "@formattedMessages": {}, - "presenceStyle": "Presença:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Mostrar o status das mensagens de outros usuários", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "commandHint_ignore": "Ignorar o seguinte ID Matrix", - "@commandHint_ignore": {}, - "commandHint_unignore": "Designorar o seguinte ID Matrix", - "@commandHint_unignore": {}, - "hidePresences": "Esconder lista de status?", - "@hidePresences": {}, - "sessionLostBody": "Sua sessão foi desconectada. Por favor, reporte este ao desenvolvedor em {url}. A mensagem de erro é: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sendReadReceiptsDescription": "Outros participantes neste chat podem ver quando você tiver lido uma mensagem.", - "@sendReadReceiptsDescription": {}, - "verifyOtherUserDescription": "Se você verificar outro usuário, você terá certeza que você conhece com quem está conversando. 💪\n\nQuando iniciar uma verificação, você e o outro usuário receberão um popup no aplicativo. Então vocês receberão uma série de emojis ou números para comparar um com o outro.\n\nA melhor maneira de fazer este procedimento é encontrar pessoalmente ou através de um vídeochamada. 👭", - "@verifyOtherUserDescription": {}, - "requestedKeyVerification": "{sender} enviou uma chave de verificação", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "verifyOtherDeviceDescription": "Quando você verifica outro aparelho, estes aparelhos poderão trocar chaves, aumentando sua segurança. 💪\n\nQuando iniciar a verificação, um popup aparecerá no aplicativo em ambos os aparelhos. Então você verá uma série de emojis ou números que você terá que comparar um com o outro.\n\nÉ melhor fazer esse procedimento com ambos os aparelhos em mãos antes de começar a verificação. 🤳", - "@verifyOtherDeviceDescription": {}, - "canceledKeyVerification": "{sender} cancelou sua chave de verificação", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} está pronto para a chave de verificação", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} completou a chave de verificação", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "stickers": "Stickers", - "@stickers": {}, - "discover": "Descubra", - "@discover": {}, - "incomingMessages": "Mensagens recebidas", - "@incomingMessages": {}, - "unreadChatsInApp": "{appname}: {unread} mensagens não lidas", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "appLockDescription": "Bloquear o app com um código PIN quando não estiver usando", - "@appLockDescription": {}, - "accessAndVisibilityDescription": "Quem é permitido entrar nesse chat e como pode ser descoberto.", - "@accessAndVisibilityDescription": {}, - "calls": "Chamadas", - "@calls": {}, - "customEmojisAndStickers": "Emojis e stickers customizados", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Adicionar ou compartilhar emojis ou stickers customizados que podem ser usados em qualquer chat.", - "@customEmojisAndStickersBody": {}, - "hideRedactedMessages": "Esconder mensagens excluídas", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "Se alguém excluir uma mensagem, esta mensagem não será mais visível no chat.", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "Esconder formatos de mensagem inválidos ou desconhecidos", - "@hideInvalidOrUnknownMessageFormats": {}, - "hideMemberChangesInPublicChats": "Esconder mudanças de membro em chats públicos", - "@hideMemberChangesInPublicChats": {}, - "hideMemberChangesInPublicChatsBody": "Não mostre se alguém entrou ou saiu no chat para melhorar a legibilidade.", - "@hideMemberChangesInPublicChatsBody": {}, - "overview": "Visão geral", - "@overview": {}, - "notifyMeFor": "Notificar me para", - "@notifyMeFor": {}, - "usersMustKnock": "Usuários devem bater na porta", - "@usersMustKnock": {}, - "noOneCanJoin": "Ninguém pode entrar", - "@noOneCanJoin": {}, - "knocking": "Batendo na porta", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "O chat pode ser descoberto pela pesquisa em {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "publicChatAddresses": "Endereços de chat públicos", - "@publicChatAddresses": {}, - "thereAreCountUsersBlocked": "Nesse momento, há {count} usuários bloqueados.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "globalChatId": "ID de chat global", - "@globalChatId": {}, - "accessAndVisibility": "Acesso e visibilidade", - "@accessAndVisibility": {}, - "passwordRecoverySettings": "Configurações de recuperação de senha", - "@passwordRecoverySettings": {}, - "userWouldLikeToChangeTheChat": "{user} gostaria de entrar no chat.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "Nenhum link público foi criado ainda", - "@noPublicLinkHasBeenCreatedYet": {}, - "userRole": "Cargo do usuário", - "@userRole": {}, - "minimumPowerLevel": "{level} é o nível mínimo de poder.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "noDatabaseEncryption": "A criptografia do banco de dados não é suportada nesta plataforma", - "@noDatabaseEncryption": {}, - "createNewAddress": "Criar um novo endereço", - "@createNewAddress": {}, - "knock": "Bater na porta", - "@knock": {}, - "searchIn": "Pesquisar em {chat}...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "restricted": "Restrito", - "@restricted": {}, - "knockRestricted": "Bater na porta restrito", - "@knockRestricted": {}, - "searchMore": "Pesquisar mais...", - "@searchMore": {}, - "gallery": "Galeria", - "@gallery": {}, - "files": "Arquivos", - "@files": {} -} diff --git a/assets/l10n/intl_ru.arb b/assets/l10n/intl_ru.arb deleted file mode 100644 index 7cc58523a..000000000 --- a/assets/l10n/intl_ru.arb +++ /dev/null @@ -1,2712 +0,0 @@ -{ - "@@locale": "ru", - "@@last_modified": "2021-08-14 12:41:09.903021", - "about": "О проекте", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Принять", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} принял(а) приглашение", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Учётная запись", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} активировал(а) сквозное шифрование", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Добавить электронную почту", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "Администратор", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "псевдоним", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Все", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Все чаты", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} ответил(а) на звонок", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Каждый может присоединиться", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Блокировка приложения", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Архив", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Разрешено ли гостям присоединяться", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Вы уверены?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Вы действительно хотите выйти?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Для подписи ключа другого пользователя, пожалуйста, введите вашу парольную фразу или ключ восстановления.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Принять этот запрос подтверждения от {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Автоматически воспроизводить анимированные стикеры и эмодзи", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "Домашний сервер поддерживает следующие типы входа в систему:\n{serverVersions}\nНо это приложение поддерживает только:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "Домашний сервер поддерживает следующие версии спецификации:\n{serverVersions}\nНо это приложение поддерживает только {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Заблокировать в чате", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Заблокирован(а)", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} заблокировал(а) {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Заблокировать устройство", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Заблокировано", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Сообщения ботов", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Отмена", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Не удается открыть URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Изменить имя устройства", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} изменил(а) аватар чата", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} изменил(а) описание чата на: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} изменил(а) имя чата на: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} изменил(а) права доступа к чату", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} изменил(а) отображаемое имя на: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} изменил(а) правила гостевого доступа", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} изменил(а) правила гостевого доступа на: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} изменил(а) видимость истории", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} изменил(а) видимость истории на: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} изменил(а) правила присоединения", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} изменил(а) правила присоединения на: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} изменил(а) аватар", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} изменил(а) псевдонимы комнаты", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} изменил(а) ссылку для приглашения", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Изменить пароль", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Изменить сервер Matrix", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Тема", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Изменить название группы", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Изменить свой аватар", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Шифрование было повреждено", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Чат", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Резервное копирование чата", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Резервная старых сообщений защищена ключом восстановления. Пожалуйста, не потеряйте его.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Детали чата", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "Чаты", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Выберите надёжный пароль", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Очистить архив", - "@clearArchive": {}, - "close": "Закрыть", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Заблокировать данного пользователя в этой комнате", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Отправить текст формата HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Пригласить данного пользователя в эту комнату", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Присоединиться к данной комнате", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Удалить данного пользователя из этой комнаты", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Покинуть эту комнату", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Опишите себя", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Установите свою фотографию для этой комнаты (автор: mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Задайте отображаемое имя для этой комнаты", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Установить уровень прав данного пользователя (по умолчанию: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Отправить неотформатированный текст", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Отправить ответ как реакцию", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Отправить текст", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Разблокировать данного пользователя в этой комнате", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Недопустимая команда", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} не является командой.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Сравните эмодзи", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Сравните числа", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Настроить чат", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Подтвердить", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Присоединиться", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Контакт был приглашен в группу", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Содержит отображаемое имя", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Содержит имя пользователя", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "О контенте было сообщено администраторам сервера", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Скопировано в буфер обмена", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Копировать", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Скопировать в буфер обмена", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Не удалось расшифровать сообщение: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} участника(ов)", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Создать", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} создал(а) чат", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Новое пространство", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "В настоящее время активен(а)", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Тёмная", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{timeOfDay}, {date}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Это деактивирует вашу учётную запись пользователя. Данное действие не может быть отменено! Вы уверены?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Уровень разрешений по умолчанию", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Удалить", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Удалить аккаунт", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Удалить сообщение", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Устройство", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Идентификатор устройства", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Устройства", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Личные чаты", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Отображаемое имя было изменено", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Скачать файл", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Редактировать", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Редактировать заблокированные серверы", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Отображаемое имя", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Редактировать псевдонимы комнаты", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Изменить аватар комнаты", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Эмодзи уже существует!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Недопустимый код эмодзи!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Наборы эмодзи для комнаты", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Настройки эмодзи", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Код эмодзи", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Вам нужно задать код эмодзи и изображение!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Пустой чат", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Включить набор эмодзи глобально", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Включить шифрование", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Вы больше не сможете отключить шифрование. Вы уверены?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Зашифровано", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Шифрование", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Шифрование не включено", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} завершил(а) звонок", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Введите адрес электронной почты", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Введите адрес вашего сервера Matrix", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Ошибка получения местоположения: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Всё готово!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Крайне оскорбительный", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Имя файла", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Размер шрифта", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "Переслать", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "С момента присоединения", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "С момента приглашения", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "В новую комнату", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Группа", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Публичная группа", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Группы", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Группа с {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Гости не могут присоединиться", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Гости могут присоединиться", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} отозвал(а) приглашение для {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Помощь", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Скрыть отредактированные события", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Скрыть неизвестные события", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Насколько оскорбительным является этот контент?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Идентификация", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Игнорировать", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Игнорируемые пользователи", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Я перешёл по ссылке", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Неверный пароль или ключ восстановления", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Безобидный", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Пригласить контакт", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Пригласить контакт в {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Приглашён", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} пригласил(а) {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Только приглашённым пользователям", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Приглашение для меня", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} пригласил(а) вас в FluffyChat. \n1. Посетите https://fluffychat.im и установите приложение \n2. Зарегистрируйтесь или войдите \n3. Откройте ссылку приглашения: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "печатает…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} присоединился(ась) к чату", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Присоединиться к комнате", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} выгнал(а) {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} выгнал(а) и заблокировал(а) {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Выгнать из чата", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Последнее посещение: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Покинуть", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Покинуть чат", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Лицензия", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Светлая", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Загрузить еще {count} участника(ов)", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Загрузка... Пожалуйста, подождите.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Загрузить больше…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Службы определения местоположения отключены. Включите их, чтобы иметь возможность обмениваться информацией о своем местоположении.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Разрешение на определение местоположения отклонено. Пожалуйста, предоставьте это разрешение, чтобы иметь возможность делиться своим местоположением.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Войти", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Войти в {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Выйти", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Изменения участников", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Упомянуть", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Сообщения", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Модератор", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Отключить уведомления", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Помните, что вам нужен Pantalaimon для использования сквозного шифрования.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Новый чат", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Новое сообщение во FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Новый запрос на подтверждение!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Далее", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Нет", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Нет соединения с сервером", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Эмодзи не найдены 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Вы можете активировать шифрование только тогда, когда комната перестает быть общедоступной.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Похоже, у вас нет служб Google на вашем телефоне. Это хорошее решение для вашей конфиденциальности! Для получения push-уведомлений во FluffyChat мы рекомендуем использовать ntfy. С ntfy или другим провайдером единых уведомлений вы можете получать push-уведомления безопасным способом передачи данных. Скачать ntfy можно из F-Droid или из Play Маркета.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} не является matrix-сервером, использовать {server2} вместо него?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "none": "Ничего", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Вы ещё не добавили способ восстановления пароля.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Нет прав доступа", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Комнаты не найдены…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Уведомления", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Уведомления включены для этой учётной записи", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} пользователей печатают…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Получение местоположения…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Оскорбительный", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Не в сети", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Ок", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "В сети", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Резервное копирование ключей на сервере включено", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Ой! К сожалению, при настройке push-уведомлений произошла ошибка.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Ой, что-то пошло не так…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Откройте приложение для чтения сообщений", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Открыть камеру", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Открыть на картах", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Или", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Участник", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "пароль или ключ восстановления", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Пароль", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Забыли пароль", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Пароль был изменён", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Восстановление пароля", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Люди", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Выбрать изображение", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Закрепить", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Проиграть {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Пожалуйста, выберите", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Пожалуйста, выберите код доступа", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Пожалуйста, нажмите на ссылку в электронной почте, для того чтобы продолжить.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Введите 4 цифры или оставьте поле пустым, чтобы отключить блокировку приложения.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Пожалуйста, введите ваш пароль", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Пожалуйста, введите свой пин-код", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Пожалуйста, введите имя пользователя", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Следуйте инструкциям на веб-сайте и нажмите «Далее».", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Конфиденциальность", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Публичные комнаты", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Правила push", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Причина", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Запись", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} отредактировал(а) событие", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Отредактировать сообщение", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Зарегистрироваться", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Отказать", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} отклонил(а) приглашение", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Зайти повторно", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Удалить", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Удалить все другие устройства", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Удалено пользователем {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Удалить устройство", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Разблокировать в чате", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Удалить свой аватар", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Показывать текст с форматированием", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Заменить комнату более новой версией", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Ответить", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Сообщить о сообщении", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Запросить разрешение", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Комната обновлена", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Версия комнаты", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Сохранить файл", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Поиск", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Безопасность", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Просмотрено пользователем {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Прислать", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Отправить сообщение", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Отправить как текст", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Отправить аудио", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Отправить файл", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Отправить изображение", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Отправить сообщения", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Отправить оригинал", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Отправить стикер", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Отправить видео", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} отправил(а) файл", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} отправил(а) аудио", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} отправил(а) изображение", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} отправил(а) стикер", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} отправил(а) видео", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} отправил(а) информацию о звонке", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Установить как основной псевдоним", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Установить пользовательские эмодзи", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Установить ссылку для приглашения", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Установить уровень разрешений", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Задать статус", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Настройки", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Поделиться", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} поделился(ась) местоположением", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Поделиться местоположением", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Показать пароль", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Единая точка входа", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Пропустить", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Исходный код", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Публичное пространство", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Название пространства", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} начал(а) звонок", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Статус", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Как у вас сегодня дела?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Отправить", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Синхронизация… Пожалуйста, подождите.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Системная", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Они не совпадают", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Они совпадают", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Переключить избранное", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Переключить без звука", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Отметить как прочитанное/непрочитанное", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Слишком много запросов. Пожалуйста, повторите попытку позже!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Перенос с другого устройства", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Попробуйте отправить ещё раз", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Недоступен", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} разблокировал(а) {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Разблокировать устройство", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Неизвестное устройство", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Неизвестный алгоритм шифрования", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Неизвестное событие '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Включить уведомления", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Открепить", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, other{{unreadCount} непрочитанных чата(ов)}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} и {count} других участников печатают…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} и {username2} печатают…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} печатает…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} покинул(а) чат", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Имя пользователя", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} отправил(а) событие типа \"{type}\"", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Проверено", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Проверить", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Начать проверку", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Вы успешно проверены!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Проверка другой учётной записи", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Видеозвонок", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Видимость истории чата", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Видима для всех участников", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Видна всем", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Отправить голосовое сообщение", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Жду, когда партнер примет запроc…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Жду, когда партнер примет эмодзи…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "В ожидании партнёра, чтобы принять числа…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Обои:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Предупреждение!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Мы отправили вам электронное письмо", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Кто и какое действие может выполнять", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Кому разрешено вступать в эту группу", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Почему вы хотите сообщить об этом?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Удалить резервную копию чата, чтобы создать новый ключ восстановления?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "По этим адресам вы можете восстановить свой пароль.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Напишите сообщение…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Да", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Вы", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Вы больше не участвуете в этом чате", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Вы были заблокированы в этом чате", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Ваш открытый ключ", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Чат был добавлен в это пространство", - "@chatHasBeenAddedToThisSpace": {}, - "addToSpace": "Добавить в пространство", - "@addToSpace": {}, - "scanQrCode": "Сканировать QR-код", - "@scanQrCode": {}, - "sendOnEnter": "Отправлять по Enter", - "@sendOnEnter": {}, - "homeserver": "Сервер Matrix", - "@homeserver": {}, - "serverRequiresEmail": "Этот сервер должен подтвердить ваш адрес электронной почты для регистрации.", - "@serverRequiresEmail": {}, - "enableMultiAccounts": "(БЕТА) Включить несколько учетных записей на этом устройстве", - "@enableMultiAccounts": {}, - "bundleName": "Название пакета", - "@bundleName": {}, - "removeFromBundle": "Удалить из этого пакета", - "@removeFromBundle": {}, - "addToBundle": "Добавить в пакет", - "@addToBundle": {}, - "editBundlesForAccount": "Изменить пакеты для этой учетной записи", - "@editBundlesForAccount": {}, - "addAccount": "Добавить учетную запись", - "@addAccount": {}, - "link": "Ссылка", - "@link": {}, - "oneClientLoggedOut": "Один из ваших клиентов вышел", - "@oneClientLoggedOut": {}, - "yourChatBackupHasBeenSetUp": "Резервное копирование чата настроено.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "Не проверено", - "@unverified": {}, - "commandHint_clearcache": "Очистить кэш", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_discardsession": "Удалить сеанс", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Начните личный чат\nИспользуйте --no-encryption, чтобы отключить шифрование", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "messageInfo": "Информация о сообщении", - "@messageInfo": {}, - "openGallery": "Открыть галерею", - "@openGallery": {}, - "removeFromSpace": "Удалить из пространства", - "@removeFromSpace": {}, - "commandHint_create": "Создайте пустой групповой чат\nИспользуйте --no-encryption, чтобы отключить шифрование", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "sender": "Отправитель", - "@sender": {}, - "addToSpaceDescription": "Выберите пространство, чтобы добавить к нему этот чат.", - "@addToSpaceDescription": {}, - "start": "Начать", - "@start": {}, - "time": "Время", - "@time": {}, - "messageType": "Тип сообщения", - "@messageType": {}, - "repeatPassword": "Повторите пароль", - "@repeatPassword": {}, - "openVideoCamera": "Открыть камеру для видео", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "videoWithSize": "Видео ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "publish": "Опубликовать", - "@publish": {}, - "dismiss": "Отклонить", - "@dismiss": {}, - "markAsRead": "Отметить как прочитанное", - "@markAsRead": {}, - "reportUser": "Сообщить о пользователе", - "@reportUser": {}, - "openChat": "Открыть чат", - "@openChat": {}, - "reactedWith": "{sender} реагирует с {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "emojis": "Эмодзи", - "@emojis": {}, - "voiceCall": "Голосовой звонок", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Неподдерживаемая версия Android", - "@unsupportedAndroidVersion": {}, - "unsupportedAndroidVersionLong": "Для этой функции требуется более новая версия Android. Проверьте наличие обновлений или поддержку Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "placeCall": "Совершить звонок", - "@placeCall": {}, - "videoCallsBetaWarning": "Обратите внимание, что видеозвонки в настоящее время находятся в бета-версии. Они могут работать не так, как ожидалось, или вообще не работать на всех платформах.", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "Экспериментальные видеозвонки", - "@experimentalVideoCalls": {}, - "emailOrUsername": "Адрес электронной почты или имя пользователя", - "@emailOrUsername": {}, - "pinMessage": "Прикрепить к комнате", - "@pinMessage": {}, - "confirmEventUnpin": "Вы уверены, что хотите навсегда открепить событие?", - "@confirmEventUnpin": {}, - "switchToAccount": "Переключиться на учётную запись {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Следующая учётная запись", - "@nextAccount": {}, - "previousAccount": "Предыдущая учётная запись", - "@previousAccount": {}, - "addWidget": "Добавить виджет", - "@addWidget": {}, - "widgetVideo": "Видео", - "@widgetVideo": {}, - "widgetEtherpad": "Текстовая записка", - "@widgetEtherpad": {}, - "widgetCustom": "Пользовательский", - "@widgetCustom": {}, - "widgetJitsi": "Совещание Jitsi", - "@widgetJitsi": {}, - "widgetName": "Имя", - "@widgetName": {}, - "widgetUrlError": "Этот URL не действителен.", - "@widgetUrlError": {}, - "widgetNameError": "Пожалуйста, укажите отображаемое имя.", - "@widgetNameError": {}, - "errorAddingWidget": "Ошибка при добавлении виджета.", - "@errorAddingWidget": {}, - "separateChatTypes": "Разделять личные чаты и группы", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youRejectedTheInvitation": "Вы отклонили приглашение", - "@youRejectedTheInvitation": {}, - "youAcceptedTheInvitation": "👍 Вы приняли приглашение", - "@youAcceptedTheInvitation": {}, - "youUnbannedUser": "Вы разблокировали {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "youJoinedTheChat": "Вы присоединились к чату", - "@youJoinedTheChat": {}, - "youKickedAndBanned": "🙅 Вы выгнали и заблокировали {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Вы пригласили {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 Вы выгнали {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youHaveWithdrawnTheInvitationFor": "Вы отозвали приглашение для {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youBannedUser": "Вы заблокировали {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 Вы были приглашены {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "recoveryKeyLost": "Ключ восстановления утерян?", - "@recoveryKeyLost": {}, - "users": "Пользователи", - "@users": {}, - "unlockOldMessages": "Разблокировать старые сообщения", - "@unlockOldMessages": {}, - "storeInSecureStorageDescription": "Сохраните ключ восстановления в безопасном хранилище этого устройства.", - "@storeInSecureStorageDescription": {}, - "storeSecurlyOnThisDevice": "Сохранить на этом устройстве", - "@storeSecurlyOnThisDevice": {}, - "saveKeyManuallyDescription": "Сохраните этот ключ вручную, вызвав диалог общего доступа системы или буфера обмена.", - "@saveKeyManuallyDescription": {}, - "recoveryKey": "Ключ восстановления", - "@recoveryKey": {}, - "pleaseEnterRecoveryKey": "Введите ключ восстановления:", - "@pleaseEnterRecoveryKey": {}, - "pleaseEnterRecoveryKeyDescription": "Чтобы разблокировать старые сообщения, введите ключ восстановления, сгенерированный в предыдущем сеансе. Ваш ключ восстановления НЕ является вашим паролем.", - "@pleaseEnterRecoveryKeyDescription": {}, - "storeInAndroidKeystore": "Сохранить в Android KeyStore", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "Сохранить в Apple KeyChain", - "@storeInAppleKeyChain": {}, - "countFiles": "{count} файлов", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "user": "Пользователь", - "@user": {}, - "confirmMatrixId": "Пожалуйста, подтвердите Matrix ID, чтобы удалить свою учётную запись.", - "@confirmMatrixId": {}, - "supposedMxid": "Это должно быть {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "dehydrateTor": "Пользователи TOR: Экспорт сеанса", - "@dehydrateTor": {}, - "indexedDbErrorLong": "К сожалению, по умолчанию хранилище сообщений не включено в приватном режиме.\nПожалуйста, посетите\n- about:config\n- установите для dom.indexedDB.privateBrowsing.enabled значение true\nВ противном случае запуск FluffyChat будет невозможен.", - "@indexedDbErrorLong": {}, - "custom": "Пользовательское", - "@custom": {}, - "hydrate": "Восстановить из файла резервной копии", - "@hydrate": {}, - "hydrateTor": "Пользователи TOR: Импорт экспорта сессии", - "@hydrateTor": {}, - "hydrateTorLong": "В прошлый раз вы экспортировали свою сессию в TOR? Быстро импортируйте его и продолжайте общение.", - "@hydrateTorLong": {}, - "dehydrateTorLong": "Для пользователей TOR рекомендуется экспортировать сессию перед закрытием окна.", - "@dehydrateTorLong": {}, - "dehydrate": "Экспорт сеанса и очистка устройства", - "@dehydrate": {}, - "dehydrateWarning": "Это действие не может быть отменено. Убедитесь, что вы безопасно сохранили файл резервной копии.", - "@dehydrateWarning": {}, - "indexedDbErrorTitle": "Проблемы с приватным режимом", - "@indexedDbErrorTitle": {}, - "otherCallingPermissions": "Микрофон, камера и другие разрешения FluffyChat", - "@otherCallingPermissions": {}, - "enterSpace": "Войти в пространство", - "@enterSpace": {}, - "screenSharingDetail": "Вы делитесь своим экраном в FuffyChat", - "@screenSharingDetail": {}, - "callingAccountDetails": "Позволяет FluffyChat использовать родное android приложение для звонков.", - "@callingAccountDetails": {}, - "newSpace": "Новое пространство", - "@newSpace": {}, - "appearOnTop": "Появляться сверху", - "@appearOnTop": {}, - "commandHint_markasdm": "Пометить как комнату личных сообщений", - "@commandHint_markasdm": {}, - "appearOnTopDetails": "Позволяет приложению отображаться сверху (не требуется, если у вас уже настроен Fluffychat как аккаунт для звонков)", - "@appearOnTopDetails": {}, - "foregroundServiceRunning": "Это уведомление появляется, когда запущена основная служба.", - "@foregroundServiceRunning": {}, - "newGroup": "Новая группа", - "@newGroup": {}, - "enterRoom": "Войти в комнату", - "@enterRoom": {}, - "allSpaces": "Все пространства", - "@allSpaces": {}, - "callingPermissions": "Разрешения на звонки", - "@callingPermissions": {}, - "callingAccount": "Аккаунт для звонков", - "@callingAccount": {}, - "commandHint_markasgroup": "Пометить как группу", - "@commandHint_markasgroup": {}, - "whyIsThisMessageEncrypted": "Почему это сообщение нечитаемо?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "Это может произойти, если сообщение было отправлено до того, как вы вошли в свою учетную запись на данном устройстве.\n\nТакже возможно, что отправитель заблокировал ваше устройство или что-то пошло не так с интернет-соединением.\n\nВы можете прочитать сообщение на другой сессии? Тогда вы можете перенести сообщение с неё! Перейдите в Настройки > Устройства и убедитесь, что ваши устройства проверили друг друга. Когда вы откроете комнату в следующий раз и обе сессии будут открыты, ключи будут переданы автоматически.\n\nВы не хотите потерять ключи при выходе из системы или переключении устройств? Убедитесь, что вы включили резервное копирование чата в настройках.", - "@noKeyForThisMessage": {}, - "screenSharingTitle": "общий доступ к экрану", - "@screenSharingTitle": {}, - "numChats": "{number} чатов", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "fileIsTooBigForServer": "Файл слишком большой.", - "@fileIsTooBigForServer": {}, - "hideUnimportantStateEvents": "Скрыть необязательные события статуса", - "@hideUnimportantStateEvents": {}, - "sorryThatsNotPossible": "Извините... это невозможно", - "@sorryThatsNotPossible": {}, - "openLinkInBrowser": "Открыть ссылку в браузере", - "@openLinkInBrowser": {}, - "fileHasBeenSavedAt": "Файл сохранён в {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "commandHint_cuddle": "Отправить улыбку", - "@commandHint_cuddle": {}, - "readUpToHere": "Дочитать до сюда", - "@readUpToHere": {}, - "commandHint_hug": "Отправить обнимашки", - "@commandHint_hug": {}, - "cuddleContent": "{senderName} улыбнулся(-ась) Вам", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} обнял(а) Вас", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "jump": "Перейти", - "@jump": {}, - "doNotShowAgain": "Не показывать снова", - "@doNotShowAgain": {}, - "newSpaceDescription": "Пространства позволяют объединять Ваши чаты и создавать частные или общедоступные сообщества.", - "@newSpaceDescription": {}, - "disableEncryptionWarning": "В целях безопасности Вы не можете отключить шифрование в чате, где оно было включено.", - "@disableEncryptionWarning": {}, - "deviceKeys": "Ключи устройств:", - "@deviceKeys": {}, - "noBackupWarning": "Внимание! Без резервного копиирования, Вы потеряете доступ к своим зашифрованным сообщениям. Крайне рекомендуется включить резервное копирование перед выходом.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "Другие устройства не найдены", - "@noOtherDevicesFound": {}, - "reportErrorDescription": "😭 О, нет. Что-то пошло не так. При желании вы можете сообщить об этой ошибке разработчикам.", - "@reportErrorDescription": {}, - "report": "пожаловаться", - "@report": {}, - "allRooms": "Все группы", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "startFirstChat": "Начните Ваш первый чат", - "@startFirstChat": {}, - "jumpToLastReadMessage": "Последнее прочитанное сообщение", - "@jumpToLastReadMessage": {}, - "wasDirectChatDisplayName": "Пустой чат (был {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "encryptThisChat": "Зашифровать этот чат", - "@encryptThisChat": {}, - "reopenChat": "Открыть чат заново", - "@reopenChat": {}, - "commandHint_googly": "Отправить выпученные глаза", - "@commandHint_googly": {}, - "signInWith": "Войти с {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Это не картинка.", - "@notAnImage": {}, - "importNow": "Импортировать сейчас", - "@importNow": {}, - "importEmojis": "Импортировать эмодзи", - "@importEmojis": {}, - "importFromZipFile": "Импортировать из ZIP-файла", - "@importFromZipFile": {}, - "exportEmotePack": "Экспортировать набор эмодзи как ZIP", - "@exportEmotePack": {}, - "replace": "Заменить", - "@replace": {}, - "googlyEyesContent": "{senderName} выпучил глаза", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "signInWithPassword": "Войти с помощью пароля", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Повторите попытку позже или выберите другой сервер.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "sendTypingNotifications": "Отправлять уведомления о наборе текста", - "@sendTypingNotifications": {}, - "createGroup": "Создать группу", - "@createGroup": {}, - "inviteContactToGroupQuestion": "Вы хотите пригласить {contact} в чат \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "Повторите попытку", - "@tryAgain": {}, - "addChatDescription": "Добавить описание чата...", - "@addChatDescription": {}, - "chatPermissions": "Права в чате", - "@chatPermissions": {}, - "chatDescription": "Описание чата", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Описание чата изменено", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "Описание чата не создано.", - "@noChatDescriptionYet": {}, - "invalidServerName": "Недопустимое имя сервера", - "@invalidServerName": {}, - "optionalRedactReason": "(Необязательно) Причина редактирования...", - "@optionalRedactReason": {}, - "redactMessageDescription": "Сообщение будет отредактировано для всех участников. Это необратимо.", - "@redactMessageDescription": {}, - "messagesStyle": "Сообщения:", - "@messagesStyle": {}, - "shareInviteLink": "Поделиться приглашением", - "@shareInviteLink": {}, - "redactedBy": "{username} отредактировал это событие", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "directChat": "Личный чат", - "@directChat": {}, - "profileNotFound": "Пользователь не найден на сервере. Это может быть проблемой подключения или пользователь не существует.", - "@profileNotFound": {}, - "setTheme": "Тема:", - "@setTheme": {}, - "redactedByBecause": "{username} отредактировал это событие. Причина: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "setChatDescription": "Изменить описание чата", - "@setChatDescription": {}, - "setColorTheme": "Цветовая тема:", - "@setColorTheme": {}, - "invite": "Пригласить", - "@invite": {}, - "invitePrivateChat": "📨 Пригласить в приватный чат", - "@invitePrivateChat": {}, - "inviteGroupChat": "📨 Пригласить в групповой чат", - "@inviteGroupChat": {}, - "invalidInput": "Недопустимый ввод!", - "@invalidInput": {}, - "wrongPinEntered": "Введён неверный пин-код! Повторите попытку через {seconds} секунд...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "emoteKeyboardNoRecents": "Недавно использованные эмодзи появятся здесь...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "banUserDescription": "Заблокированные в чате пользователи не смогут перезайти в чат, пока они не будут разблокированны.", - "@banUserDescription": {}, - "removeDevicesDescription": "Вы выйдете с этого устройства и больше не будете получать сообщения.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "Пользователь сможет при желании зайти в чат снова.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Push-уведомления недоступны", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Как только вы назначите этого пользователя администратором, вы не сможете этого отменить, так как их права доступа и ваши будут одинаковы.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Чат переместится в архив. Другим пользователям будет видно, что вы вышли из чата.", - "@archiveRoomDescription": {}, - "hasKnocked": "🚪 {user} постучался", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "learnMore": "Узнать больше", - "@learnMore": {}, - "roomUpgradeDescription": "Затем чат будет воссоздан с новой версией комнаты. Все участники будут уведомлены о необходимости перейти в новый чат. Вы можете узнать больше о версиях комнат на https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Пожалуйста введите число больше 0", - "@pleaseEnterANumber": {}, - "kickUserDescription": "Пользователь будет изгнан из чата, но не будет заблокирован. В публичных чатах пользователь может перезайти когда угодно.", - "@kickUserDescription": {}, - "blockListDescription": "Вы можете заглушить тревожащих вас пользователей. Вы не будете получать сообщения или приглашения в комнату от пользователей из вашего личного чёрного списка.", - "@blockListDescription": {}, - "blockedUsers": "Заглушённые пользователи", - "@blockedUsers": {}, - "block": "Заглушить", - "@block": {}, - "blockUsername": "Игнорировать имя пользователя", - "@blockUsername": {}, - "createGroupAndInviteUsers": "Создать и начать приглашать", - "@createGroupAndInviteUsers": {}, - "startConversation": "Начать общение", - "@startConversation": {}, - "groupCanBeFoundViaSearch": "Группа может быть найдена поиском", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "К сожалению пользователей с именем \"{query}\" не найдено. Убедитесь, что вы не совершили опечатку.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "yourGlobalUserIdIs": "Ваш глобальный идентификатор - ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "Отправить сырой json", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Простите... судя по всему это неверный ключ восстановления.", - "@wrongRecoveryKey": {}, - "groupName": "Название группы", - "@groupName": {}, - "databaseMigrationTitle": "База данных оптимизированна", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "Поиск #чатов, @людей...", - "@searchChatsRooms": {}, - "databaseMigrationBody": "Пожалуйста, подождите. Это может занять некоторое время.", - "@databaseMigrationBody": {}, - "publicSpaces": "Публичные пространства", - "@publicSpaces": {}, - "passwordIsWrong": "Вы ввели неверный пароль", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Пожалуйста, введите свой текущий пароль", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "Публичная ссылка", - "@publicLink": {}, - "nothingFound": "Ничего не найдено...", - "@nothingFound": {}, - "newPassword": "Новый пароль", - "@newPassword": {}, - "passwordsDoNotMatch": "Пароли не совпадают", - "@passwordsDoNotMatch": {}, - "select": "Выбрать", - "@select": {}, - "pleaseChooseAStrongPassword": "Пожалуйста, подберите сильный пароль", - "@pleaseChooseAStrongPassword": {}, - "leaveEmptyToClearStatus": "Чтобы очистить статус, оставьте поле пустым.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Присоединиться к пространству", - "@joinSpace": {}, - "searchForUsers": "Поиск @пользователей...", - "@searchForUsers": {}, - "thisDevice": "Данное устройство:", - "@thisDevice": {}, - "decline": "Отклонить", - "@decline": {}, - "databaseBuildErrorBody": "Невозможно собрать базу данных SQlite. Приложение пытается использовать старую базу данных. Пожалуйста, сообщите об этой ошибке разработчикам по адресу {url}. Сообщение об ошибке: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "Произошла ошибка при запуске приложения", - "@initAppError": {}, - "sessionLostBody": "Ваш сеанс утерян. Пожалуйста, сообщите об этой ошибке разработчикам по адресу {url}. Сообщение об ошибке: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "Приложение пытается восстановить сеанс из резервной копии. Пожалуйста, сообщите об этой ошибке разработчикам по адресу {url}. Сообщение об ошибке: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "subspace": "Субпространство", - "@subspace": {}, - "addChatOrSubSpace": "Добавить чат или субпространство", - "@addChatOrSubSpace": {}, - "youInvitedToBy": "📩 Вы были приглашены по ссылке на:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "sendReadReceipts": "Отправка квитанций о прочтении", - "@sendReadReceipts": {}, - "verifyOtherUser": "🔐 Подтвердить другого пользователя", - "@verifyOtherUser": {}, - "verifyOtherDevice": "🔐 Подтвердить другое устройство", - "@verifyOtherDevice": {}, - "forwardMessageTo": "Переслать сообщение в {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendReadReceiptsDescription": "Другие участники чата могут видеть, когда вы прочитали сообщение.", - "@sendReadReceiptsDescription": {}, - "transparent": "Прозрачный", - "@transparent": {}, - "verifyOtherUserDescription": "Если вы подтвердите другого пользователя, то вы можете быть уверены зная, кому вы действительно пишете. 💪\n\nКогда вы начинаете подтверждение, вы и другой пользователь увидите всплывающее окно в приложении. Там вы увидите ряд чисел или эмодзи, которые вы должны сравнить друг с другом.\n\nЛучший способ сделать это - встретиться в реальной жизни или по видео звонку. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "При подтверждении другого устройства эти устройства могут обмениваться ключами, повышая общую безопасность. 💪 При запуске подтверждения в приложении на обоих устройствах появится всплывающее окно. Там вы увидите ряд чисел или эмодзи, которые вы должны сравнить друг с другом. Лучше иметь оба устройства под рукой перед началом проверки. 🤳", - "@verifyOtherDeviceDescription": {}, - "formattedMessagesDescription": "Отображать содержимое расширенных сообщений, такой как жирный текст, с помощью Markdown.", - "@formattedMessagesDescription": {}, - "acceptedKeyVerification": "{sender} принял(а) подтверждение ключей", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender} отклонил(а) подтверждение ключей", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "sendTypingNotificationsDescription": "Другие участники чата могут видеть, когда вы набираете новое сообщение.", - "@sendTypingNotificationsDescription": {}, - "formattedMessages": "Форматированные сообщения", - "@formattedMessages": {}, - "startedKeyVerification": "{sender} начал(а) подтверждение ключей", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} готов(а) к подтверждению ключей", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} запросил(а) подтверждение ключей", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} завершил(а) подтверждение ключей", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "incomingMessages": "Входящие сообщения", - "@incomingMessages": {}, - "presencesToggle": "Показывать сообщения в статусах других пользователей", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "presenceStyle": "Представление:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "hidePresences": "Скрыть список статусов?", - "@hidePresences": {}, - "stickers": "Стикеры", - "@stickers": {}, - "discover": "Исследовать", - "@discover": {}, - "globalChatId": "ID глобального чата", - "@globalChatId": {}, - "customEmojisAndStickersBody": "Добавить или поделиться пользовательскими эмодзи или стикерами, которые могут быть применены в любом чате.", - "@customEmojisAndStickersBody": {}, - "hideMemberChangesInPublicChatsBody": "Для улучшения читаемости не показывать на временной шкале входы и выходы из чата.", - "@hideMemberChangesInPublicChatsBody": {}, - "knocking": "Стучаться", - "@knocking": {}, - "accessAndVisibility": "Доступность и видимость", - "@accessAndVisibility": {}, - "publicChatAddresses": "Адресы публичного чата", - "@publicChatAddresses": {}, - "accessAndVisibilityDescription": "Кому разрешено войти в этот чат и как этот чат может быть обнаружен.", - "@accessAndVisibilityDescription": {}, - "userRole": "Роль пользователя", - "@userRole": {}, - "noDatabaseEncryption": "Шифрование базы данных не поддерживается на этой платформе", - "@noDatabaseEncryption": {}, - "appLockDescription": "Заблокировать приложение когда не используется пин код", - "@appLockDescription": {}, - "calls": "Звонки", - "@calls": {}, - "customEmojisAndStickers": "Пользовательские эмодзи и стикеры", - "@customEmojisAndStickers": {}, - "hideRedactedMessages": "Скрыть редактированные сообщения", - "@hideRedactedMessages": {}, - "hideInvalidOrUnknownMessageFormats": "Скрыть неправильные или неизвестные форматы сообщения", - "@hideInvalidOrUnknownMessageFormats": {}, - "hideRedactedMessagesBody": "Если кто-то редактирует сообщение, оно будет скрыто в чате.", - "@hideRedactedMessagesBody": {}, - "hideMemberChangesInPublicChats": "Скрыть изменения участников в публичных чатах", - "@hideMemberChangesInPublicChats": {}, - "overview": "Обзор", - "@overview": {}, - "notifyMeFor": "Уведомлять меня о", - "@notifyMeFor": {}, - "passwordRecoverySettings": "Настройки восстановления пароля", - "@passwordRecoverySettings": {}, - "userWouldLikeToChangeTheChat": "{user} желает присоединиться к чату.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "knock": "Постучаться", - "@knock": {}, - "usersMustKnock": "Пользователи должны постучаться", - "@usersMustKnock": {}, - "noOneCanJoin": "Никто не может присоединиться", - "@noOneCanJoin": {}, - "noPublicLinkHasBeenCreatedYet": "Публичная ссылка еще не была создана", - "@noPublicLinkHasBeenCreatedYet": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Чат может быть обнаружен через поиск в {server}", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "createNewAddress": "Создать новый адрес", - "@createNewAddress": {}, - "minimumPowerLevel": "{level} является минимальным уровнем.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "commandHint_ignore": "Игнорировать данный matrix ID", - "@commandHint_ignore": {}, - "commandHint_unignore": "Не игнорировать данный matrix ID", - "@commandHint_unignore": {}, - "unreadChatsInApp": "{appname}: {unread} непрочитанные чаты", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "thereAreCountUsersBlocked": "Сейчас заблокировано {count} пользователей.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "restricted": "Запрещено", - "@restricted": {}, - "knockRestricted": "Стук запрещен", - "@knockRestricted": {}, - "searchIn": "Поиск в чате \"{chat}\"...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Найти еще...", - "@searchMore": {}, - "gallery": "Галерея", - "@gallery": {}, - "files": "Файлы", - "@files": {}, - "swipeRightToLeftToReply": "Для ответа проведите с права на лево", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_sk.arb b/assets/l10n/intl_sk.arb deleted file mode 100644 index 4712b9b69..000000000 --- a/assets/l10n/intl_sk.arb +++ /dev/null @@ -1,2117 +0,0 @@ -{ - "@@locale": "sk", - "@@last_modified": "2021-08-14 12:41:09.879987", - "about": "O aplikácii", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Prijať", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "{username} prijali pozvánku", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Účet", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "{username} aktivovali koncové šifrovanie", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "Administrátor", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "anyoneCanJoin": "Ktokoľvek sa môže pripojiť", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "Archivovať", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Môžu sa pripojiť hostia", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Ste si istí?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Na overenie tejto osoby, prosím zadajte prístupovu frázu k \"bezpečému úložisku\" alebo \"klúč na obnovu\".", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Akcepovať žiadosť o verifikáciu od {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banFromChat": "Zabanovať z chatu", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Zabanovaný", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} zabanoval {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Zakázať zariadenie", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "cancel": "Zrušiť", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} si zmenili svôj avatar", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} zmenili popis chatu na: „{description}“", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} zmenili meno chatu na: „{chatname}“", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} zmenili nastavenie oprávnení chatu", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} si zmenili prezývku na: {displayname}", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} zmenili prístupové práva pre hosťov", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} zmenili prístupové práva pro hosťov na: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} zmenili nastavenie viditelnosti histórie chatu", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} zmenili nastavenie viditelnosti histórie chatu na: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} zmenili nastavenie pravidiel pripojenia", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} zmenili nastavenie pravidiel pripojenia na: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} si zmenili profilový obrázok", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} zmenili nastavenie aliasov chatu", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} zmenili odkaz k pozvánke do miestnosti", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeTheHomeserver": "Zmeniť použitý server", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Zmena štýlu", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Zmeniť názov skupiny", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Šifrovanie bolo poškodené", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Podrobnosti o chate", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Vyberte si silné heslo", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Zavrieť", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Porovnajte a uistite sa, že nasledujúce emotikony sa zhodujú na oboch zariadeniach:", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Porovnajte a uistite sa, že nasledujúce čísla sa zhodujú na oboch zariadeniach:", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Potvrdiť", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Pripojiť", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakt bol pozvaný do skupiny", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Skopírované do schránky", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopírovať", - "@copy": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Nebolo možné dešifrovať správu: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} účastníkov", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Vytvoriť", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "{username} založili chat", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Momentálne prítomní", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Tmavá", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}.{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}.{month}.{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "delete": "Odstrániť", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Odstrániť správu", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Zariadenie", - "@device": { - "type": "text", - "placeholders": {} - }, - "devices": "Zariadenia", - "@devices": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Prezývka bola zmenená", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Stiahnuť súbor", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Zmeniť prezývku", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Emotikon už existuje!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Nesprávné označenie emotikonu!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Nastavenie emotikonov", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Kód emotikonu", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Musíte zvoliť kód emotikonu a obrázok!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Prázdny chat", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Šifrovanie už nebude možné vypnúť. Ste si tým istí?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encryption": "Šifrovanie", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Šifrovanie nie je aktívne", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Zadajte svoj homeserver", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "fileName": "Názov súboru", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Preposlať", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Od pripojenia", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Od pozvania", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "Skupina", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Skupina je verejná", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Skupina s {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Hostia sú zakázaní", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Hostia sa môžu pripojiť", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} vzal späť pozvánku pre {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Pomoc", - "@help": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identita", - "@identity": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Nesprávna prístupová fráza alebo kľúč na obnovenie", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Pozvať kontakt", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Pozvať kontakt do {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Pozvanie", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "{username} pozvali {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Len pozvaní používatelia", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} vás pozval na FluffyChat.\n1. Nainštalujte si FluffyChat: https://fluffychat.im\n2. Zaregistrujte sa alebo sa prihláste\n3. Otvorte odkaz na pozvánku: {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "píše…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "{username} sa pripojili do chatu", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "kicked": "{username} vyhodili {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "{username} vyhodili a zabanovali {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Vyhodiť z chatu", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Naposledy prítomní: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Opustiť", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Opustili chat", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licencia", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Svetlá", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Načítať ďalších {count} účastníkov", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Načítava sa… Čakajte prosím.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Načítať viac…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Prihlásiť sa", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Prihlásenie k {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Odhlásiť sa", - "@logout": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderátor", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Stlmiť chat", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Prosím berte na vedomie, že na koncové šifrovanie zatiaľ potrebujete Pantalaimon.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "Nová správa v FluffyChate", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Nová žiadosť o verifikáciu!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Nenašli sa žiadne emotikony. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Zdá sa, že nemáte žiadne služby Googlu v telefóne. To je dobré rozhodnutie pre vaše súkromie! Ak chcete dostávať push notifikácie vo FluffyChat, odporúčame používať microG: https://microg.org/.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Žiadne", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Chýba povolenie", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Nenašli sa žiadne miestnosti…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "ok": "ok", - "@ok": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Online záloha kľúčov je zapnutá", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Och! Niečo sa pokazilo…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Na prečítanie správy otvorte aplikáciu", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Otvoriť fotoaparát", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "prístupová fráza alebo kľúč na obnovenie", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Heslo", - "@password": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Vybrať obrázok", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "play": "Prehrať {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseEnterYourPassword": "Prosím zadajte svoje heslo", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Zadajte svoje používateľské meno", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Verejné miestnosti", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "recording": "Nahrávam", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} odstránili udalosť", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Odmietnuť", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} odmietli pozvánku", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Vrátiť sa", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Odstrániť", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Odstráňiť všetky ostatné zariadenia", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Odstánené užívateľom {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Odstráňiť zariadenie", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Odblokovať", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Zobraziť formátovaný obsah", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "Odpovedať", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Vyžiadať si povolenie", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Miestnosť bola upgradeovaná", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Videné užívateľom {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Odoslať", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Odoslať správu", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Odoslať súbor", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Odoslať obrázok", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "{username} poslali súbor", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "{username} poslali zvukovú nahrávku", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "{username} poslali obrázok", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "{username} poslali nálepku", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "{username} poslali video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "setInvitationLink": "Nastaviť odkaz pre pozvánku", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Nastaviť status", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Nastavenia", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Zdieľať", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} zdieľa lokáciu", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "skip": "Preskočiť", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Zdrojový kód", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Ako sa dnes máte?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Odoslať", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Systémová farba", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Sa nezhodujú", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Zhodujú sa", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Skúsiť znova odoslať", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} odbanovali {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Odblokovať zariadenie", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Neznáme zariadenie", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Neznámy šifrovací algoritmus", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Neznáma udalosť „{type}“", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Zrušiť stlmenie chatu", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, other{{unreadCount} neprečítaných chatov}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} a {count} dalších píšu…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} a {username2} píšu…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} píše…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "{username} opustili chat", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Užívateľské meno", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} poslali udalosť {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "Overiť", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Spustiť verifikáciu", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Verifikácia bola úspešná!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verifikujem protiľahlý účet", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videohovor", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Viditeľnosť histórie chatu", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Viditeľné pre všetkých účastníkov", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Viditeľné pre každého", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Hlasová správa", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Čaká sa, kým partner prijme požiadavku…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Čaká sa, kým partner prijme emotikon…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Čaká sa na to, kým partner prijme čísla…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Pozadie", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Kto môže vstúpiť do tejto skupiny", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Napísať správu…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Áno", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Vy", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Už sa nezúčastňujete tohto chatu", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Máte zablokovaný prístup k tomuto chatu", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "people": "Ľudia", - "@people": { - "type": "text", - "placeholders": {} - }, - "chats": "Čety", - "@chats": { - "type": "text", - "placeholders": {} - }, - "changePassword": "Zmeniť heslo", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Zmeniť názov zariadenia", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "Domovský server podporuje verzie špecifikácie:\n{serverVersions}\nAle táto aplikácie podporuje iba {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "answeredTheCall": "{senderName} prevzal hovor", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "sendAudio": "Poslať zvuk", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "addEmail": "Pridať email", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "appLock": "Uzamknutie aplikácie", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "security": "Bezpečnosť", - "@security": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Nahlásiť správu", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Poslať nálepku", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Verzia miestnosti", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Poslať správy", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "Pripojiť sa k miestnosti", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Nastaviť úroveň oprávnení", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "Server podporuje tieto typy prihlásenia:\n{serverVersions}\nAle táto aplikácia podporuje iba:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "chatBackup": "Záloha chatov", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Pridať do priestoru", - "@addToSpace": {}, - "cantOpenUri": "Nemožno otvoriť identifikátor prostriedku {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "yourChatBackupHasBeenSetUp": "Záloha vašich chatov bola nastavená.", - "@yourChatBackupHasBeenSetUp": {}, - "repeatPassword": "Zopakujte heslo", - "@repeatPassword": {}, - "all": "Všetky", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Všetky chaty", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Ste si istí, že sa chcete odhlásiť?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "Odoslať pri vstupe", - "@sendOnEnter": {}, - "ignoredUsers": "Ignorovaní užívatelia", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorovať", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "search": "Hľadať", - "@search": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Poslať ako text", - "@sendAsText": { - "type": "text" - }, - "sendOriginal": "Poslať originál", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Poslať video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "importNow": "Importovať teraz", - "@importNow": {}, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@addAccount": {}, - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "@chatHasBeenAddedToThisSpace": {}, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@user": {}, - "@youAcceptedTheInvitation": {}, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@blocked": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@edit": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@saveKeyManuallyDescription": {}, - "@editBundlesForAccount": {}, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@setChatDescription": {}, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@noOtherDevicesFound": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCallsBetaWarning": {}, - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@optionalRedactReason": {}, - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@notifications": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@addChatDescription": {}, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@clearArchive": {}, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@scanQrCode": {}, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@messages": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@widgetName": {}, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@pin": { - "type": "text", - "placeholders": {} - }, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@invite": {}, - "@enableMultiAccounts": {}, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {}, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - } -} \ No newline at end of file diff --git a/assets/l10n/intl_sl.arb b/assets/l10n/intl_sl.arb deleted file mode 100644 index c826f047d..000000000 --- a/assets/l10n/intl_sl.arb +++ /dev/null @@ -1,1984 +0,0 @@ -{ - "repeatPassword": "Ponovite geslo", - "@repeatPassword": {}, - "about": "O aplikaciji", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Sprejmi", - "@accept": { - "type": "text", - "placeholders": {} - }, - "account": "Račun", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "Uporabnik {username} je aktiviral šifriranje od konca do konca", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "Dodajte e-pošto", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Dodajte v prostor", - "@addToSpace": {}, - "alias": "vzdevek", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Vse", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Vsi klepeti", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "Oseba {senderName} je odgovorila na klic", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Pridruži se lahko vsak", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Zaklepanje aplikacije", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Če želite podpisati drugo osebo, vnesite geslo za varno trgovino ali obnovitveni ključ.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Ali želite sprejeti to zahtevo za preverjanje od {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Samodejno predvajajte animirane nalepke in čustva", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "Domači strežnik podpira vrste prijave:\n{serverVersions}\nToda ta aplikacija podpira samo:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "sendOnEnter": "Pošlji ob vstopu", - "@sendOnEnter": {}, - "banFromChat": "Prepoved klepeta", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Prepovedano", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} je prepovedan v {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blokirana naprava", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Blokirano", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Botova sporočila", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Prekliči", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "URI-ja {uri} ni mogoče odpreti", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changedTheChatAvatar": "{username} je spremenil avatar za klepet", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatPermissions": "{username} je spremenila dovoljenja za klepet", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} je spremenil svoje prikazno ime v: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} je spremenila pravila dostopa za goste", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} je spremenila pravila dostopa za goste v: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} je spremenil vidnost zgodovine v: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} je spremenil pravila za pridružitev", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} je spremenila pravila pridružitve v: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} je spremenil avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} je spremenil vzdevke sobe", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} je spremenil povezavo za povabilo", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Spremeni geslo", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Spremenite domači strežnik", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Spremenite svoj slog", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Spremenite ime skupine", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Spremenite svoj avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "chat": "Klepet", - "@chat": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "Varnostna kopija klepeta je nastavljena.", - "@yourChatBackupHasBeenSetUp": {}, - "chatBackup": "Varnostno kopiranje klepeta", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Podrobnosti klepeta", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Klepet je bil dodan v ta prostor", - "@chatHasBeenAddedToThisSpace": {}, - "chats": "Klepeti", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Izberite močno geslo", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Počisti arhiv", - "@clearArchive": {}, - "close": "Zapri", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Izključi določenega uporabnika iz te sobe", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "Pošljite besedilo v obliki HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Povabi danega uporabnika v to sobo", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Pridružite se dani sobi", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Odstranite danega uporabnika iz te sobe", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_me": "Opisi sebe", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Nastavite svojo sliko za to sobo", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_op": "Nastavite raven moči danega uporabnika (privzeto: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_react": "Pošljite odgovor kot reakcijo", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Pošlji besedilo", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Prekliči izključitev določenega uporabnika iz te sobe", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Ukaz ni veljaven", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} is not a command.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Primerjajte in se prepričajte, da se naslednji emoji ujemajo s tistimi iz druge naprave:", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Primerjajte in se prepričajte, da se naslednje številke ujemajo s številkami druge naprave:", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Konfigurirajte klepet", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Potrdi", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Vsebuje prikazno ime", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Vsebuje uporabniško ime", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "archive": "Arhiv", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Ali si prepričan?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "{username} je sprejel povabilo", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "areYouSureYouWantToLogout": "Ali ste prepričani, da se želite odjaviti?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "changedTheChatDescriptionTo": "{username} je spremenil opis klepeta v: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "areGuestsAllowedToJoin": "Ali se lahko gostujoči uporabniki pridružijo", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "Domači strežnik podpira različice Spec:\n{serverVersions}\nToda ta aplikacija podpira samo {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "changedTheChatNameTo": "{username} je spremenil ime klepeta v: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changeDeviceName": "Spremenite ime naprave", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheHistoryVisibility": "{username} je spremenila vidnost zgodovine", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "channelCorruptedDecryptError": "Šifriranje je poškodovano", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Vsebina je bila prijavljena skrbnikom strežnika", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Varnostna kopija klepeta je zavarovana z varnostnim ključem. Prosimo, pazite, da ga ne izgubite.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "commandHint_myroomnick": "Nastavite prikazno ime za to sobo", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "connect": "Povežite se", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakt je bil povabljen v skupino", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "commandHint_leave": "Zapusti to sobo", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_plain": "Pošlji neformatirano besedilo", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "copiedToClipboard": "Kopirano v odložišče", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopiraj", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopiraj v odložišče", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Sporočila ni bilo mogoče dešifrirati: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} udeležencev", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Ustvari", - "@create": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Nov prostor", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Trenutno aktiven", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Temno", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Privzeta raven dovoljenja", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "createdTheChat": "{username} je ustvaril klepet", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "deactivateAccountWarning": "S tem boste deaktivirali vaš uporabniški račun. Tega ni mogoče razveljaviti! Ali si prepričan?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@addAccount": {}, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@device": { - "type": "text", - "placeholders": {} - }, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@encryption": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@invited": { - "type": "text", - "placeholders": {} - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@password": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@remove": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@id": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@fileName": { - "type": "text", - "placeholders": {} - }, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@edit": { - "type": "text", - "placeholders": {} - }, - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@none": { - "type": "text", - "placeholders": {} - }, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@help": { - "type": "text", - "placeholders": {} - }, - "@people": { - "type": "text", - "placeholders": {} - }, - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "@callingPermissions": {}, - "@delete": { - "type": "text", - "placeholders": {} - }, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@start": {}, - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@identity": { - "type": "text", - "placeholders": {} - }, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@moderator": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@send": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@notifications": { - "type": "text", - "placeholders": {} - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@group": { - "type": "text", - "placeholders": {} - }, - "@leave": { - "type": "text", - "placeholders": {} - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@license": { - "type": "text", - "placeholders": {} - }, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@forward": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@you": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@search": { - "type": "text", - "placeholders": {} - }, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@logout": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@messages": { - "type": "text", - "placeholders": {} - }, - "@login": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@devices": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@pin": { - "type": "text", - "placeholders": {} - }, - "@importNow": {}, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "@invite": {}, - "@enableMultiAccounts": {}, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@placeCall": {} -} \ No newline at end of file diff --git a/assets/l10n/intl_sv.arb b/assets/l10n/intl_sv.arb deleted file mode 100644 index c9b3f2232..000000000 --- a/assets/l10n/intl_sv.arb +++ /dev/null @@ -1,2607 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.835634", - "about": "Om", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Acceptera", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} accepterade inbjudan", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Konto", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} aktiverade ändpunktskryptering", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "Admin", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "alias", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Alla", - "@all": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} besvarade samtalet", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Vem som helst kan gå med", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "App-lås", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arkiv", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Får gästanvändare gå med", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Är du säker?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Är du säker på att du vill logga ut?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "För att kunna signera den andra personen, vänligen ange din lösenfras eller återställningsnyckel för säker lagring.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Acceptera denna verifikationsförfrågan från {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerVersionsException": "Hemservern stöjder Spec-versionen:\n{serverVersions}\nMen denna app stödjer enbart {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Bannlys från chatt", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Bannlyst", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} bannlös {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blockera Enhet", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bot meddelanden", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Avbryt", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Ändra enhetsnamn", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} ändrade sin chatt-avatar", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} ändrade chatt-beskrivningen till: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} ändrade sitt chatt-namn till: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} ändrade chatt-rättigheterna", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} ändrade visningsnamnet till: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} ändrade reglerna för gästaccess", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} ändrade reglerna för gästaccess till: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} ändrade historikens synlighet", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} ändrade historikens synlighet till: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} ändrade anslutningsreglerna", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} ändrade anslutningsreglerna till {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} ändrade sin avatar", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} ändrade rummets alias", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} ändrade inbjudningslänken", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Ändra lösenord", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Ändra hemserver", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Ändra din stil", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Ändra namn på gruppen", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Krypteringen har blivit korrupt", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Chatt", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Chatt-detaljer", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Välj ett starkt lösenord", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Stäng", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Vänligen jämför uttryckssymbolerna", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Vänligen jämför siffrorna", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Konfigurera chatt", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Bekräfta", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Anslut", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakten har blivit inbjuden till gruppen", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Innehåller visningsnamn", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Innehåller användarnamn", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "Innehållet har rapporterats till server-admins", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Kopierat till urklipp", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopiera", - "@copy": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Kunde ej avkoda meddelande: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} deltagare", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Skapa", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} skapade chatten", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "För närvarande aktiv", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Mörkt", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{year}-{month}-{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Detta kommer att avaktivera ditt konto. Det här går inte att ångra! Är du säker?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Standard behörighetsnivå", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Radera", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Ta bort konto", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Ta bort meddelande", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Enhet", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Enhets-ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Enheter", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Direkt chatt", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Visningsnamn har ändrats", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Ladda ner fil", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Ändra", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "redigera blockerade servrar", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Ändra visningsnamn", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "redigera rumsavatar", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Dekalen existerar redan!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Ogiltig dekal-kod!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Dekalpaket för rummet", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Emote inställningar", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Dekal kod", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Du måste välja en dekal-kod och en bild!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Tom chatt", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Aktivera dekal-paket globalt", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Aktivera kryptering", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Du kommer inte ha fortsatt möjlighet till att inaktivera krypteringen. Är du säker?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Krypterad", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Kryptering", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Kryptering är ej aktiverad", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} avslutade samtalet", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Ange en e-postaddress", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Ange din hemserver", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Extremt stötande", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Filnamn", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Framåt", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Från att gå med", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Från inbjudan", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "Grupp", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Gruppen är publik", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Grupper", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Gruppen med {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Gäster är förbjudna", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Gäster kan ansluta", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} har tagit tillbaka inbjudan för {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Hjälp", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Göm redigerade händelser", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Göm okända händelser", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Hur stötande är detta innehåll?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Identitet", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorera", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Ignorera användare", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Jag har klickat på länken", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Felaktig lösenordsfras eller åsterställningsnyckel", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Oförargligt", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Bjud in kontakt", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Bjud in kontakt till {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Inbjuden", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} bjöd in {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Endast inbjudna användare", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Inbjudning till mig", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} bjöd in dig till FluffyChat.\n1. Besök fluffychat.im och installera appen\n2. Registrera dig eller logga in\n3. Öppna inbjudningslänk:\n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "skriver…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} anslöt till chatten", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Anslut till rum", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} sparkade ut {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} sparkade och bannade {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Sparka från chatt", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Senast aktiv: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Lämna", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Lämnade chatten", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Licens", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Ljust", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Ladda {count} mer deltagare", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Laddar... Var god vänta.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Ladda mer…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Logga in", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Logga in till {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Logga ut", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Medlemsändringar", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Nämn", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Meddelanden", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Tysta chatt", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Var medveten om att du behöver Pantalaimon för att använda ändpunktskryptering tillsvidare.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Ny chatt", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Nya meddelanden i FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Ny verifikationsbegäran!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Nästa", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Nej", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Ingen anslutning till servern", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Hittade inga dekaler. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "De ser ut som att du inte har google-tjänster på din telefon. Det är ett bra beslut för din integritet! För att få aviseringar i FluffyChat rekommenderar vi att använda https://microg.org/ eller https://unifiedpush.org/ .", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Ingen", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Du har inte lagt till något sätt för att återställa ditt lösenord än.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Ingen behörighet", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Hittade inga rum…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Aviseringar", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Aviseringar är påslaget för detta konto", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} användare skriver…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "offensive": "Stötande", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Offline", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "OK", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Online", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Online Nyckel-backup är aktiverad", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Hoppsan, något gick fel…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Öppna app för att lästa meddelanden", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Öppna kamera", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "participant": "Deltagare", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "lösenord eller återställningsnyckel", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Lösenord", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Glömt lösenord", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Lösenordet har ändrats", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Återställ lösenord", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Välj en bild", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Nåla fast", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Spela {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChooseAPasscode": "Ange ett lösenord", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Klicka på länken i e-postmeddelandet för att sedan fortsätta.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Ange 4 siffror eller lämna tom för att inaktivera app-lås.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Ange ditt lösenord", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Ange ditt användarnamn", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Följ instruktionerna på hemsidan och tryck på nästa.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Integritet", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Publika Rum", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Regler", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Anledning", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Spelar in", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} redigerade en händelse", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Redigera meddelande", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "reject": "Avböj", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} avböjde inbjudan", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Återanslut", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Ta bort", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Ta bort alla andra enheter", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Bortagen av {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Ta bort enhet", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Ta bort chatt-blockering", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Återge innehåll med rikt meddelande", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Ersätt rum med nyare version", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Svara", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Rapportera meddelande", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Begär behörighet", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Rummet har blivit uppgraderat", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "search": "Sök", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Säkerhet", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Sedd av {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Skicka", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Skicka ett meddelande", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Skicka ljud", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Skicka fil", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Skicka bild", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Skickade meddelanden", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Skicka orginal", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Skicka video", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} skickade en fil", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} skickade ett ljudklipp", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} skickade en bild", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} skickade ett klistermärke", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} skickade en video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} skickade samtalsinformation", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setCustomEmotes": "Ställ in anpassade dekaler", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Ställ in inbjudningslänk", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Ställ in behörighetsnivå", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Ställ in status", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Inställningar", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Dela", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} delade sin position", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "skip": "Hoppa över", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Källkod", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} startade ett samtal", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Hur mår du i dag?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Skicka in", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "System", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Dom Matchar Inte", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Dom Matchar", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Växla favorit", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Växla tystad", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Markera läst/oläst", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "För många förfrågningar. Vänligen försök senare!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Försök att skicka igen", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Upptagen", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} avbannade {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Avblockera enhet", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Okänd enhet", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Okänd krypteringsalgoritm", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Okänd händelse '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Slå på ljudet för chatten", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Avnåla", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{en oläst chatt} other{{unreadCount} olästa chattar}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} och {count} andra skriver…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} och {username2} skriver…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} skriver…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} lämnade chatten", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Användarnamn", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} skickade en {type} händelse", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "Verifiera", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Starta verifiering", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Du har lyckats verifiera!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Verifiera andra konton", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videosamtal", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Chatt-historikens synlighet", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Synlig för alla deltagare", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Synlig för alla", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Röstmeddelande", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Väntar på att deltagaren accepterar begäran…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Väntar på att deltagaren accepterar emojien…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Väntar på att deltagaren accepterar nummer…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Bakgrund:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Varning!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Vi skickade dig ett e-postmeddelande", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Vem kan utföra vilken åtgärd", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Vilka som är tilllåtna att ansluta till denna grupp", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Varför vill du rapportera detta?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Med dessa addresser kan du återställa ditt lösenord.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Skriv ett meddelande…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Ja", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Du", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Du deltar inte längre i denna chatt", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Du har blivit bannad från denna chatt", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Din publika nyckel", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "commandHint_html": "Skicka HTML-formatted text", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_ban": "Bannlys användaren från detta rum", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "clearArchive": "Rensa arkiv", - "@clearArchive": {}, - "chats": "Chatter", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Chatt har lagts till i detta utrymme", - "@chatHasBeenAddedToThisSpace": {}, - "chatBackup": "Chatt backup", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Ändra din avatar", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Kan inte öppna URL {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "blocked": "Blockerad", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "Hemma servern stödjer följande inloggnings typer :\n {serverVersions}\nMen denna applikation stödjer enbart:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "autoplayImages": "Automatisk spela upp animerade klistermärken och emoji", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "allChats": "Alla chattar", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Lägg till i utrymme", - "@addToSpace": {}, - "addEmail": "Lägg till e-post", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "commandHint_myroomavatar": "Sätt din bild för detta rum (by mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_me": "Beskriv dig själv", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_leave": "Lämna detta rum", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_kick": "Ta bort användare från detta rum", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_join": "Gå med i rum", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_invite": "Bjud in användaren till detta rum", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "locationPermissionDeniedNotice": "Plats åtkomst nekad. Var god godkän detta för att kunna dela din plats.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Platstjänster är inaktiverade. Var god aktivera dom för att kunna dela din plats.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Gå till det nya rummet", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Textstorlek", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Allt är klart!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Fel vid erhållande av plats: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "editRoomAliases": "Redigera rum alias", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Nytt utrymme", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopiera till urklipp", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "commandMissing": "{command} är inte ett kommando.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "commandInvalid": "Felaktigt kommando", - "@commandInvalid": { - "type": "text" - }, - "commandHint_unban": "Tillåt användare i rummet", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandHint_send": "Skicka text", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_react": "Skicka svar som reaktion", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_plain": "Skicka oformaterad text", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_op": "Sätt användarens kraft nivå ( standard: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_myroomnick": "Sätt ditt användarnamn för rummet", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "noEncryptionForPublicRooms": "Du kan endast aktivera kryptering när rummet inte längre är publikt tillgängligt.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} är inte en matrix server, använd {server2} istället?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "obtainingLocation": "Erhåller plats…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Var god välj", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "people": "Människor", - "@people": { - "type": "text", - "placeholders": {} - }, - "or": "Eller", - "@or": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Öppna i karta", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Oj! Tyvärr gick inte aviseringar att slå på.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Synkroniserar… Var god vänta.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Utrymmes namn", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Utrymme är publikt", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Visa lösenord", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Dela plats", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Sätt som primärt alias", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Skicka klistermärke", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Skicka som text", - "@sendAsText": { - "type": "text" - }, - "saveFile": "Spara fil", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Rum version", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Ta bort din avatar", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "register": "Registrera", - "@register": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Ange din pin-kod", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Radera din chatt-backup för att skapa en ny återställningsnyckel?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "verified": "Verifierad", - "@verified": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Överför till annan enhet", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Din chatt backup är skyddad av en säkerhetsnyckel. Se till att du inte förlorar den.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "commandHint_create": "Skapa en tom grupp-chatt\nAnvänd --no-encryption för att inaktivera kryptering", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_discardsession": "Kasta bort sessionen", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "Starta en direkt-chatt\nAnvänd --no-encryption för att inaktivera kryptering", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "homeserver": "Hemserver", - "@homeserver": {}, - "oneClientLoggedOut": "En av dina klienter har loggats ut", - "@oneClientLoggedOut": {}, - "addAccount": "Lägg till konto", - "@addAccount": {}, - "editBundlesForAccount": "Lägg till paket för detta konto", - "@editBundlesForAccount": {}, - "addToBundle": "Utöka paket", - "@addToBundle": {}, - "bundleName": "Paketnamn", - "@bundleName": {}, - "serverRequiresEmail": "Servern behöver validera din e-postadress för registrering.", - "@serverRequiresEmail": {}, - "singlesignon": "Single Sign On", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "unverified": "Ej verifierad", - "@unverified": {}, - "messageInfo": "Meddelandeinformation", - "@messageInfo": {}, - "messageType": "Meddelandetyp", - "@messageType": {}, - "time": "Tid", - "@time": {}, - "sender": "Avsändare", - "@sender": {}, - "removeFromSpace": "Ta bort från utrymme", - "@removeFromSpace": {}, - "addToSpaceDescription": "Välj ett utrymme som chatten skall läggas till i.", - "@addToSpaceDescription": {}, - "start": "Starta", - "@start": {}, - "openGallery": "Öppna galleri", - "@openGallery": {}, - "repeatPassword": "Upprepa lösenord", - "@repeatPassword": {}, - "markAsRead": "Markera som läst", - "@markAsRead": {}, - "commandHint_clearcache": "Rensa cache", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "openVideoCamera": "Aktivera kamera för video", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "link": "Länk", - "@link": {}, - "publish": "Publicera", - "@publish": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "reportUser": "Rapportera användare", - "@reportUser": {}, - "openChat": "Öppna Chatt", - "@openChat": {}, - "sendOnEnter": "Skicka med Enter", - "@sendOnEnter": {}, - "scanQrCode": "Skanna QR-kod", - "@scanQrCode": {}, - "yourChatBackupHasBeenSetUp": "Din chatt-backup har konfigurerats.", - "@yourChatBackupHasBeenSetUp": {}, - "removeFromBundle": "Ta bort från paket", - "@removeFromBundle": {}, - "enableMultiAccounts": "(BETA) Aktivera multi-konton på denna enhet", - "@enableMultiAccounts": {}, - "emojis": "Uttryckssymboler", - "@emojis": {}, - "placeCall": "Ring", - "@placeCall": {}, - "voiceCall": "Röstsamtal", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Inget stöd för denna version av Android", - "@unsupportedAndroidVersion": {}, - "videoCallsBetaWarning": "Videosamtal är för närvarande under testning. De kanske inte fungerar som det är tänkt eller på alla plattformar.", - "@videoCallsBetaWarning": {}, - "unsupportedAndroidVersionLong": "Denna funktion kräver en senare version av Android.", - "@unsupportedAndroidVersionLong": {}, - "dismiss": "Avfärda", - "@dismiss": {}, - "reactedWith": "{sender} reagerade med {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "pinMessage": "Fäst i rum", - "@pinMessage": {}, - "confirmEventUnpin": "Är du säker på att händelsen inte längre skall vara fastnålad?", - "@confirmEventUnpin": {}, - "experimentalVideoCalls": "Experimentella videosamtal", - "@experimentalVideoCalls": {}, - "switchToAccount": "Byt till konto {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Nästa konto", - "@nextAccount": {}, - "previousAccount": "Föregående konto", - "@previousAccount": {}, - "emailOrUsername": "Användarnamn eller e-postadress", - "@emailOrUsername": {}, - "addWidget": "Lägg till widget", - "@addWidget": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "widgetEtherpad": "Anteckning", - "@widgetEtherpad": {}, - "widgetCustom": "Anpassad", - "@widgetCustom": {}, - "widgetName": "Namn", - "@widgetName": {}, - "widgetUrlError": "Detta är inte en giltig URL.", - "@widgetUrlError": {}, - "errorAddingWidget": "Ett fel uppstod när widgeten skulle läggas till.", - "@errorAddingWidget": {}, - "widgetJitsi": "Jitsi-möte", - "@widgetJitsi": {}, - "widgetNameError": "Vänligen ange ett visningsnamn.", - "@widgetNameError": {}, - "storeSecurlyOnThisDevice": "Lagra säkert på denna enhet", - "@storeSecurlyOnThisDevice": {}, - "youJoinedTheChat": "Du gick med i chatten", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Du accepterade inbjudan", - "@youAcceptedTheInvitation": {}, - "youKicked": "👞 Du sparkade ut {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "hugContent": "{senderName} kramar dig", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_markasgroup": "Märk som grupp", - "@commandHint_markasgroup": {}, - "recoveryKeyLost": "Borttappad återställningsnyckel?", - "@recoveryKeyLost": {}, - "indexedDbErrorTitle": "Problem med privat läge", - "@indexedDbErrorTitle": {}, - "youHaveWithdrawnTheInvitationFor": "Du har återkallat inbjudan till {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Du återkallade förbudet för {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "unlockOldMessages": "Lås upp äldre meddelanden", - "@unlockOldMessages": {}, - "newSpace": "Nytt utrymme", - "@newSpace": {}, - "googlyEyesContent": "{senderName} skickar dig googly ögon", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "dehydrate": "Exportera sessionen och rensa enheten", - "@dehydrate": {}, - "dehydrateWarning": "Denna åtgärd kan inte ångras. Försäkra dig om att backupen är i säkert förvar.", - "@dehydrateWarning": {}, - "dehydrateTor": "TOR-användare: Exportera session", - "@dehydrateTor": {}, - "hydrateTor": "TOR-användare: Importera session från tidigare export", - "@hydrateTor": {}, - "hydrateTorLong": "Exporterade du sessionen när du senast använde TOR? Importera den enkelt och fortsätt chatta.", - "@hydrateTorLong": {}, - "recoveryKey": "Återställningsnyckel", - "@recoveryKey": {}, - "separateChatTypes": "Separata direktchattar och grupper", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "startFirstChat": "Starta din första chatt", - "@startFirstChat": {}, - "pleaseEnterRecoveryKeyDescription": "Ange din återställningsnyckel från en tidigare session för att låsa upp äldre meddelanden. Din återställningsnyckel är INTE ditt lösenord.", - "@pleaseEnterRecoveryKeyDescription": {}, - "encryptThisChat": "Kryptera denna chatt", - "@encryptThisChat": {}, - "dehydrateTorLong": "TOR-användare rekommenderas att exportera sessionen innan fönstret stängs.", - "@dehydrateTorLong": {}, - "noBackupWarning": "Varning! Om du inte aktiverar säkerhetskopiering av chattar så tappar du åtkomst till krypterade meddelanden. Det är rekommenderat att du aktiverar säkerhetskopiering innan du loggar ut.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "Inga andra enheter hittades", - "@noOtherDevicesFound": {}, - "disableEncryptionWarning": "Av säkerhetsskäl kan du inte stänga av kryptering i en chatt där det tidigare aktiverats.", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "Det där är inte möjligt", - "@sorryThatsNotPossible": {}, - "confirmMatrixId": "Bekräfta ditt Matrix-ID för att radera ditt konto.", - "@confirmMatrixId": {}, - "supposedMxid": "Detta bör vara {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "pleaseEnterRecoveryKey": "Ange din återställningsnyckel:", - "@pleaseEnterRecoveryKey": {}, - "commandHint_markasdm": "Märk som rum för direktmeddelanden för det givante Matrix ID", - "@commandHint_markasdm": {}, - "user": "Användare", - "@user": {}, - "indexedDbErrorLong": "Meddelandelagring är tyvärr inte aktiverat i privat läge som standard.\nGå till\n - about:config\n - sätt dom.indexedDB.privateBrowsing.enabled till true\nAnnars går det inte att använda FluffyChat.", - "@indexedDbErrorLong": {}, - "storeInSecureStorageDescription": "Lagra återställningsnyckeln på säker plats på denna enhet.", - "@storeInSecureStorageDescription": {}, - "storeInAppleKeyChain": "Lagra i Apples nyckelkedja (KeyChain)", - "@storeInAppleKeyChain": {}, - "foregroundServiceRunning": "Denna avisering visas när förgrundstjänsten körs.", - "@foregroundServiceRunning": {}, - "custom": "Anpassad", - "@custom": {}, - "countFiles": "{count} filer", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "screenSharingTitle": "skärmdelning", - "@screenSharingTitle": {}, - "noKeyForThisMessage": "Detta kan hända om meddelandet skickades innan du loggade in på ditt konto i den här enheten.\n\nDet kan också vara så att avsändaren har blockerat din enhet eller att något gick fel med internetanslutningen.\n\nKan du läsa meddelandet i en annan session? I sådana fall kan du överföra meddelandet från den sessionen! Gå till Inställningar > Enhet och säkerställ att dina enheter har verifierat varandra. När du öppnar rummet nästa gång och båda sessionerna är i förgrunden, så kommer nycklarna att överföras automatiskt.\n\nVill du inte förlora nycklarna vid utloggning eller när du byter enhet? Säkerställ att du har aktiverat säkerhetskopiering för chatten i inställningarna.", - "@noKeyForThisMessage": {}, - "fileIsTooBigForServer": "Servern informerar om att filen är för stor för att skickas.", - "@fileIsTooBigForServer": {}, - "deviceKeys": "Enhetsnycklar:", - "@deviceKeys": {}, - "enterSpace": "Gå till utrymme", - "@enterSpace": {}, - "commandHint_googly": "Skicka några googly ögon", - "@commandHint_googly": {}, - "commandHint_cuddle": "Skicka en omfamning", - "@commandHint_cuddle": {}, - "commandHint_hug": "Skicka en kram", - "@commandHint_hug": {}, - "users": "Användare", - "@users": {}, - "cuddleContent": "{senderName} omfamnar dig", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hydrate": "Återställ från säkerhetskopia", - "@hydrate": {}, - "screenSharingDetail": "Du delar din skärm i FluffyChat", - "@screenSharingDetail": {}, - "youRejectedTheInvitation": "Du avvisade inbjudan", - "@youRejectedTheInvitation": {}, - "youBannedUser": "Du förbjöd {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 Du har blivit inbjuden av {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Du bjöd in {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Du sparkade ut och förbjöd {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "saveKeyManuallyDescription": "Spara nyckeln manuellt genom att aktivera dela-funktionen eller urklippshanteraren på enheten.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Lagra i Androids nyckellagring (KeyStore)", - "@storeInAndroidKeystore": {}, - "callingPermissions": "Samtalsbehörighet", - "@callingPermissions": {}, - "callingAccount": "Samtalskonto", - "@callingAccount": {}, - "callingAccountDetails": "Tillåt FluffyChat att använda Androids ring-app.", - "@callingAccountDetails": {}, - "appearOnTop": "Visa ovanpå", - "@appearOnTop": {}, - "appearOnTopDetails": "Tillåt att appen visas ovanpå (behövs inte om du redan har FluffyChat konfigurerat som ett samtalskonto)", - "@appearOnTopDetails": {}, - "otherCallingPermissions": "Mikrofon, kamera och andra behörigheter för FluffyChat", - "@otherCallingPermissions": {}, - "whyIsThisMessageEncrypted": "Varför kan inte detta meddelande läsas?", - "@whyIsThisMessageEncrypted": {}, - "newGroup": "Ny grupp", - "@newGroup": {}, - "enterRoom": "Gå till rummet", - "@enterRoom": {}, - "allSpaces": "Alla utrymmen", - "@allSpaces": {}, - "numChats": "{number} chattar", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Göm oviktiga tillståndshändelser", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Visa inte igen", - "@doNotShowAgain": {}, - "wasDirectChatDisplayName": "Tom chatt (var {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "newSpaceDescription": "Utrymmen möjliggör konsolidering av chattar och att bygga privata eller offentliga gemenskaper.", - "@newSpaceDescription": {}, - "reopenChat": "Återöppna chatt", - "@reopenChat": {}, - "jumpToLastReadMessage": "Hoppa till det senast lästa meddelandet", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Läs upp till hit", - "@readUpToHere": {}, - "fileHasBeenSavedAt": "Filen har sparats i {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "allRooms": "Alla gruppchattar", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "😭 Åh nej. Något gick fel. Om du vill ian du rapportera denna bugg till utvecklarna.", - "@reportErrorDescription": {}, - "setColorTheme": "Välj färgtema:", - "@setColorTheme": {}, - "banUserDescription": "Användaren kommer bannlysas från chatten och kommer inte kunna gå med i chatten igen tills bannlysningen avslutas.", - "@banUserDescription": {}, - "removeDevicesDescription": "Du kommer att bli utloggad från den här enheten och kommer inte längre kunna få meddelanden.", - "@removeDevicesDescription": {}, - "tryAgain": "Försök igen", - "@tryAgain": {}, - "unbanUserDescription": "Användaren kommer kunna gå med i chatten igen om den försöker.", - "@unbanUserDescription": {}, - "messagesStyle": "Meddelanden:", - "@messagesStyle": {}, - "chatDescription": "Chattbeskrivning", - "@chatDescription": {}, - "pushNotificationsNotAvailable": "Aviseringar är inte tillgängligt", - "@pushNotificationsNotAvailable": {}, - "invalidServerName": "Ogiltigt servernamn", - "@invalidServerName": {}, - "chatPermissions": "Chatt-behörigheter", - "@chatPermissions": {}, - "signInWithPassword": "Logga in med lösenord", - "@signInWithPassword": {}, - "makeAdminDescription": "När du gör denna användare till administratör kommer du inte kunna ångra det eftersom de kommer ha samma behörigheter som du.", - "@makeAdminDescription": {}, - "setChatDescription": "Ändra chattens beskrivning", - "@setChatDescription": {}, - "importFromZipFile": "Importera från .zip-fil", - "@importFromZipFile": {}, - "redactedBy": "Borttaget av {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "signInWith": "Logga in med {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "optionalRedactReason": "(Frivilligt) Anledning till att ta bort det här meddelandet…", - "@optionalRedactReason": {}, - "archiveRoomDescription": "Den här chatten kommer flyttas till arkivet. Andra användare kommer kunna se att du har lämnat chatten.", - "@archiveRoomDescription": {}, - "exportEmotePack": "Exportera Emote-pack som .zip", - "@exportEmotePack": {}, - "inviteContactToGroupQuestion": "Vill du bjuda in {contact} till chatten ”{groupName}”?", - "@inviteContactToGroupQuestion": {}, - "redactedByBecause": "Borttaget av {username} på grund av: ”{reason}”", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "redactMessageDescription": "Meddelandet kommer tas bort för alla medlemmar i denna konversation. Detta kan inte ångras.", - "@redactMessageDescription": {}, - "invalidInput": "Ogiltig input!", - "@invalidInput": {}, - "report": "rapportera", - "@report": {}, - "addChatDescription": "Lägg till en chattbeskrivning…", - "@addChatDescription": {}, - "hasKnocked": "{user} har knackat", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "openLinkInBrowser": "Öppna länk i webbläsare", - "@openLinkInBrowser": {}, - "directChat": "Direktchatt", - "@directChat": {}, - "wrongPinEntered": "Fel pin-kod inslagen! Försök igen om {seconds} sekunder…", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "Skicka skrivnotifikationer", - "@sendTypingNotifications": {}, - "inviteGroupChat": "📨 Bjud in gruppchatt", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Bjud in privat chatt", - "@invitePrivateChat": {}, - "importEmojis": "Importera emojier", - "@importEmojis": {}, - "noChatDescriptionYet": "Ingen chatt-beskrivning än.", - "@noChatDescriptionYet": {}, - "learnMore": "Lär dig mer", - "@learnMore": {}, - "notAnImage": "Inte en bildfil.", - "@notAnImage": {}, - "chatDescriptionHasBeenChanged": "Chattbeskrivningen ändrades", - "@chatDescriptionHasBeenChanged": {}, - "roomUpgradeDescription": "Chatten kommer då att återskapas med den nya rumversionen. Alla medlemmar kommer bli påminda om att de måste byta till den nya chatten. Du kan läsa mer om rumversioner på https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Vänligen ange ett nummer större än 0", - "@pleaseEnterANumber": {}, - "profileNotFound": "Användaren kunde onte hittas på servern. Kanske är det ett anslutningsproblem eller så finns inte användaren.", - "@profileNotFound": {}, - "jump": "Hoppa", - "@jump": {}, - "shareInviteLink": "Dela inbjudningslänk", - "@shareInviteLink": {}, - "emoteKeyboardNoRecents": "Nyligen använda emotes kommer dyka upp här…", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "setTheme": "Välj tema:", - "@setTheme": {}, - "replace": "Ersätt", - "@replace": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Vänligen försök igen eller välj en annan server.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "createGroup": "Skapa grupp", - "@createGroup": {}, - "kickUserDescription": "Användaren sparkas ut ur chatten men bannlyses inte. I offentliga chattar kan användaren gå med igen när som helst.", - "@kickUserDescription": {}, - "importNow": "Importera nu", - "@importNow": {}, - "invite": "Bjud in", - "@invite": {}, - "databaseBuildErrorBody": "Kan inte bygga SQlite-databasen. Appen försöker använda den gamla databasen för nu. Vänligen rapportera problemet till utvecklarna här: {url}. Felmeddelandet är: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "blockListDescription": "Du kan blockera användare som stör dig. Du kommer inte få några meddelanden eller rum-inbjudningar från användarna på din personliga blocklista.", - "@blockListDescription": {}, - "createGroupAndInviteUsers": "Skapa en grupp och bjud in användare", - "@createGroupAndInviteUsers": {}, - "initAppError": "Ett problem skedde när appen initierades", - "@initAppError": {}, - "thisDevice": "Denna enhet:", - "@thisDevice": {}, - "startConversation": "Starta konversation", - "@startConversation": {}, - "publicSpaces": "Offentliga utrymmen", - "@publicSpaces": {}, - "blockedUsers": "Blockerade användare", - "@blockedUsers": {}, - "passwordIsWrong": "Det angivna lösenordet är fel", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Vänligen skriv ditt nuvarande lösenord", - "@pleaseEnterYourCurrentPassword": {}, - "groupCanBeFoundViaSearch": "Gruppen kan hittas genom sökning", - "@groupCanBeFoundViaSearch": {}, - "publicLink": "Offentlig länk", - "@publicLink": {}, - "noUsersFoundWithQuery": "Tyvärr kunde ingen användare hittas med ”{query}”. Vänligen kontrollera om du gjort ett stavfel.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "block": "blockera", - "@block": {}, - "nothingFound": "Inget hittades…", - "@nothingFound": {}, - "yourGlobalUserIdIs": "Ditt globala användar-ID är: ", - "@yourGlobalUserIdIs": {}, - "decline": "Neka", - "@decline": {}, - "newPassword": "Nytt lösenord", - "@newPassword": {}, - "passwordsDoNotMatch": "Lösenorden passar inte", - "@passwordsDoNotMatch": {}, - "commandHint_sendraw": "Skicka rå json", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Tyvärr verkar detta inte vara den korrekta återställningsnyckeln.", - "@wrongRecoveryKey": {}, - "subspace": "Underutrymme", - "@subspace": {}, - "select": "Ange val", - "@select": {}, - "sessionLostBody": "Din session är förlorad. Vänligen rapportera detta fel till utvecklarna här: {url}. Felmeddelandet är: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "pleaseChooseAStrongPassword": "Vänligen välj ett starkt lösenord", - "@pleaseChooseAStrongPassword": {}, - "blockUsername": "Ignorera användarnamn", - "@blockUsername": {}, - "addChatOrSubSpace": "Lägg till chatt eller underutrymme", - "@addChatOrSubSpace": {}, - "groupName": "Gruppnamn", - "@groupName": {}, - "leaveEmptyToClearStatus": "Lämna tom för att ta bort din status.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Gå med i utrymme", - "@joinSpace": {}, - "searchForUsers": "Sök efter @användare…", - "@searchForUsers": {}, - "restoreSessionBody": "Appen försöker nu få tillbaks din session från backupen. Vänligen rapportera detta problem till utvecklarna här: {url}. Felmeddelandet är: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "databaseMigrationTitle": "Databasen är optimerad", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "Sök efter #chattar, @användare…", - "@searchChatsRooms": {}, - "databaseMigrationBody": "Var vänlig vänta. Detta kan ta en stund.", - "@databaseMigrationBody": {}, - "youInvitedToBy": "📩 Du har blivit inbjuden via länk till:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "sendTypingNotificationsDescription": "Andra deltagare i en diskussion kan se när du skriver.", - "@sendTypingNotificationsDescription": {}, - "formattedMessagesDescription": "Visa formaterat meddelandeinnehåll som fet stil med markdown.", - "@formattedMessagesDescription": {}, - "verifyOtherUser": "🔐 Verifiera användaren", - "@verifyOtherUser": {}, - "formattedMessages": "Formaterade meddelanden", - "@formattedMessages": {}, - "canceledKeyVerification": "{sender} avbröt nyckelverifieringen", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} fullbordade nyckelverifieringen", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} begärde nyckelverifiering", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "Transparent", - "@transparent": {}, - "startedKeyVerification": "{sender} påbörjade nyckelverifiering", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "presenceStyle": "Närvaro:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Visa statusmeddelanden från andra användare", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "hidePresences": "Dölj statuslista?", - "@hidePresences": {}, - "sendReadReceipts": "Skicka läskvitton", - "@sendReadReceipts": {}, - "verifyOtherDevice": "🔐 Verifiera enhet", - "@verifyOtherDevice": {}, - "acceptedKeyVerification": "{sender} accepterade nyckelverifieringen", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "incomingMessages": "Inkommande meddelanden", - "@incomingMessages": {}, - "forwardMessageTo": "Vidarebefordra meddelandet till {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "verifyOtherUserDescription": "Om du verifierar en användare så kan du vara säker på vem du verkligen skriver till. 💪\n\nNär du påbörjar en verifiering så ser du och den andra användaren en popup-ruta i appen. I den rutan ser du ett antal tecken som du jämför med vad den andra användaren ser.\n\nDet bästa sättet att göra detta är att träffas fysiskt, eller genom att starta ett videosamtal. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "När du verifierar en enhet så kan era enheter utväxla nycklar, vilket förbättrar säkerheten. 💪 När du påbörjar en verifiering så ser du en popup-ruta på båda enheterna. I den rutan ser du ett antal tecken som du jämför med det som visas på den andra enheten. Det är bäst att ha båda enheterna till hands innan du påbörjar verifieringen. 🤳", - "@verifyOtherDeviceDescription": {}, - "isReadyForKeyVerification": "{sender} är redo för nyckelverifiering", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "sendReadReceiptsDescription": "Andra deltagare i en diskussion kan se när du läst ett meddelande.", - "@sendReadReceiptsDescription": {}, - "stickers": "Klistermärken", - "@stickers": {}, - "discover": "Upptäck", - "@discover": {} -} diff --git a/assets/l10n/intl_ta.arb b/assets/l10n/intl_ta.arb deleted file mode 100644 index 92d897376..000000000 --- a/assets/l10n/intl_ta.arb +++ /dev/null @@ -1,1884 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.826673", - "acceptedTheInvitation": "{username} அழைப்பை ஏற்றுக்கொண்டார்", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "accept": "ஏற்றுக்கொள்", - "@accept": { - "type": "text", - "placeholders": {} - }, - "about": "பற்றி", - "@about": { - "type": "text", - "placeholders": {} - }, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@connect": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@chats": { - "type": "text", - "placeholders": {} - }, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@admin": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@addAccount": {}, - "@close": { - "type": "text", - "placeholders": {} - }, - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "@chatHasBeenAddedToThisSpace": {}, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@device": { - "type": "text", - "placeholders": {} - }, - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@encryption": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@invited": { - "type": "text", - "placeholders": {} - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@password": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@remove": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "@id": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "@blocked": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@sendOnEnter": {}, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@fileName": { - "type": "text", - "placeholders": {} - }, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@create": { - "type": "text", - "placeholders": {} - }, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@alias": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@all": { - "type": "text", - "placeholders": {} - }, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@edit": { - "type": "text", - "placeholders": {} - }, - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@copy": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@none": { - "type": "text", - "placeholders": {} - }, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@yourChatBackupHasBeenSetUp": {}, - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@help": { - "type": "text", - "placeholders": {} - }, - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "@people": { - "type": "text", - "placeholders": {} - }, - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@repeatPassword": {}, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "@callingPermissions": {}, - "@delete": { - "type": "text", - "placeholders": {} - }, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@start": {}, - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@identity": { - "type": "text", - "placeholders": {} - }, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@moderator": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@send": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "@banned": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@account": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@notifications": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@chat": { - "type": "text", - "placeholders": {} - }, - "@group": { - "type": "text", - "placeholders": {} - }, - "@leave": { - "type": "text", - "placeholders": {} - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@allChats": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@license": { - "type": "text", - "placeholders": {} - }, - "@addToSpace": {}, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@forward": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@cancel": { - "type": "text", - "placeholders": {} - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@clearArchive": {}, - "@appLock": { - "type": "text", - "placeholders": {} - }, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "@importEmojis": {}, - "@confirm": { - "type": "text", - "placeholders": {} - }, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@you": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@search": { - "type": "text", - "placeholders": {} - }, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@logout": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterANumber": {}, - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "@messages": { - "type": "text", - "placeholders": {} - }, - "@login": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@archive": { - "type": "text", - "placeholders": {} - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "@devices": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@pin": { - "type": "text", - "placeholders": {} - }, - "@importNow": {}, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "@invite": {}, - "@enableMultiAccounts": {}, - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@screenSharingDetail": {}, - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@placeCall": {}, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - } -} \ No newline at end of file diff --git a/assets/l10n/intl_th.arb b/assets/l10n/intl_th.arb deleted file mode 100644 index 8eac43252..000000000 --- a/assets/l10n/intl_th.arb +++ /dev/null @@ -1,1930 +0,0 @@ -{ - "hugContent": "{senderName} กอดคุณ", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_cuddle": "ส่งเคล้าเคลียให้", - "@commandHint_cuddle": {}, - "admin": "แอดมิน", - "@admin": { - "type": "text", - "placeholders": {} - }, - "supposedMxid": "อันนี้ควรเป็น {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "askSSSSSign": "เพื่อให้สามารถลงนามบุคคลอื่นได้ โปรดป้อนรหัสผ่านร้านค้าที่ปลอดภัยหรือรหัสกู้คืนของคุณ", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "remove": "ลบออก", - "@remove": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "ผู้ใช้ทั่วไปได้รับอนุญาตให้เข้าร่วมหรือไม่", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "ส่งเมื่อกด enter", - "@sendOnEnter": {}, - "answeredTheCall": "{senderName} รับสายแล้ว", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "alias": "นามแฝง", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "ทั้งหมด", - "@all": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "โฮมเซิร์ฟเวอร์รองรับประเภทการเข้าสู่ระบบ:\n{serverVersions}\nแต่แอปนี้รองรับเฉพาะ:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "edit": "แก้ไข", - "@edit": { - "type": "text", - "placeholders": {} - }, - "copy": "คัดลอก", - "@copy": { - "type": "text", - "placeholders": {} - }, - "importFromZipFile": "นำเข้าจากไฟล์ .zip", - "@importFromZipFile": {}, - "autoplayImages": "เล่นสติ๊กเกอร์และอิโมจิแบบเคลื่อนไหวโดยอัตโนมัติ", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "help": "ช่วยเหลือ", - "@help": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "รายละเอียดแชท", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "ใส่รหัสผ่านอีกรอบ", - "@repeatPassword": {}, - "delete": "ลบออก", - "@delete": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} ได้รับการชวนแล้ว", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "ส่ง", - "@send": { - "type": "text", - "placeholders": {} - }, - "exportEmotePack": "ส่งอิโมจิแพ็คออกเป็นไฟล์ .zip", - "@exportEmotePack": {}, - "account": "บัญชี", - "@account": { - "type": "text", - "placeholders": {} - }, - "chat": "แชท", - "@chat": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "คุณแน่ใจไหม?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "allChats": "แชททั้งหมด", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "เพิ่มไปที่ space", - "@addToSpace": {}, - "about": "เกี่ยวกับ", - "@about": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} เปิดใช้งาน end to end encryption", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "googlyEyesContent": "{senderName} ส่งตากวนๆให้คุณ", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "addChatDescription": "เพิ่มคำอธิบายการแชท", - "@addChatDescription": {}, - "appLock": "ล็อคแอป", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "sendTypingNotifications": "ส่งการแจ้งเตือนการพิมพ์", - "@sendTypingNotifications": {}, - "importEmojis": "นำเข้าอ๊โมจิ", - "@importEmojis": {}, - "confirmMatrixId": "กรุณายืนยัน Matrix ID ของคุณเพื่อลบบัญชีของคุณ", - "@confirmMatrixId": {}, - "notAnImage": "ไม่ใช่ไฟล์รูปภาพ", - "@notAnImage": {}, - "areYouSureYouWantToLogout": "คุณแน่ใจว่าคุณต้องการที่จะออกจากระบบ?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "cuddleContent": "{senderName} เคล้าเคลียคุณ", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "askVerificationRequest": "ยอมรับคำขอยืนยันนี้จาก {username} หรือไม่", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "เพิ่มอีเมล", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "commandHint_hug": "ส่งกอดให้", - "@commandHint_hug": {}, - "replace": "แทนที่", - "@replace": {}, - "archive": "คลังเก็บ", - "@archive": { - "type": "text", - "placeholders": {} - }, - "accept": "ยอมรับ", - "@accept": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "ส่งสายตากวนๆ มาให้หน่อย", - "@commandHint_googly": {}, - "pin": "ปักหมุด", - "@pin": { - "type": "text", - "placeholders": {} - }, - "importNow": "นำเข้าเลย", - "@importNow": {}, - "anyoneCanJoin": "ใครๆ ก็สามารถเข้าร่วมได้", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@connect": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@chats": { - "type": "text", - "placeholders": {} - }, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@directChats": { - "type": "text", - "placeholders": {} - }, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "@addAccount": {}, - "@close": { - "type": "text", - "placeholders": {} - }, - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "@chatHasBeenAddedToThisSpace": {}, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@device": { - "type": "text", - "placeholders": {} - }, - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@encryption": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersionLong": {}, - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@invited": { - "type": "text", - "placeholders": {} - }, - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@password": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "@id": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@blocked": { - "type": "text", - "placeholders": {} - }, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@next": { - "type": "text", - "placeholders": {} - }, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@fileName": { - "type": "text", - "placeholders": {} - }, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@create": { - "type": "text", - "placeholders": {} - }, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@no": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@addToBundle": {}, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "@online": { - "type": "text", - "placeholders": {} - }, - "@signInWithPassword": {}, - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@offensive": { - "type": "text", - "placeholders": {} - }, - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@none": { - "type": "text", - "placeholders": {} - }, - "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@storeSecurlyOnThisDevice": {}, - "@yourChatBackupHasBeenSetUp": {}, - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "@participant": { - "type": "text", - "placeholders": {} - }, - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@people": { - "type": "text", - "placeholders": {} - }, - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "@callingPermissions": {}, - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "@readUpToHere": {}, - "@start": {}, - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@identity": { - "type": "text", - "placeholders": {} - }, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "@ignore": { - "type": "text", - "placeholders": {} - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@moderator": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "@banned": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {}, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@newChat": { - "type": "text", - "placeholders": {} - }, - "@notifications": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterRecoveryKeyDescription": {}, - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "@mention": { - "type": "text", - "placeholders": {} - }, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@group": { - "type": "text", - "placeholders": {} - }, - "@leave": { - "type": "text", - "placeholders": {} - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@reportUser": {}, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@license": { - "type": "text", - "placeholders": {} - }, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@forward": { - "type": "text", - "placeholders": {} - }, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "@offline": { - "type": "text", - "placeholders": {} - }, - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@cancel": { - "type": "text", - "placeholders": {} - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@clearArchive": {}, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "@confirm": { - "type": "text", - "placeholders": {} - }, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "@removeFromBundle": {}, - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@learnMore": {}, - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "@you": { - "type": "text", - "placeholders": {} - }, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@search": { - "type": "text", - "placeholders": {} - }, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@logout": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnterANumber": {}, - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@groups": { - "type": "text", - "placeholders": {} - }, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "@messages": { - "type": "text", - "placeholders": {} - }, - "@login": { - "type": "text", - "placeholders": {} - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "@devices": { - "type": "text", - "placeholders": {} - }, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "@share": { - "type": "text", - "placeholders": {} - }, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@screenSharingDetail": {}, - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "@invite": {}, - "@enableMultiAccounts": {}, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - } -} \ No newline at end of file diff --git a/assets/l10n/intl_tr.arb b/assets/l10n/intl_tr.arb deleted file mode 100644 index 18b90caaf..000000000 --- a/assets/l10n/intl_tr.arb +++ /dev/null @@ -1,2712 +0,0 @@ -{ - "@@locale": "tr", - "@@last_modified": "2021-08-14 12:41:09.803728", - "about": "Hakkında", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Kabul et", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} katılma davetini kabul etti", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Hesap", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} uçtan uca şifrelemeyi etkinleştirdi", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "E-posta ekle", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Alana ekle", - "@addToSpace": {}, - "admin": "Yönetici", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "takma ad", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "Tümü", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Tüm sohbetler", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} aramayı yanıtladı", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Herkes katılabilir", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Uygulama kilidi", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arşiv", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Misafir kullanıcıların katılmasına izin veriliyor mu", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Emin misiniz?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Oturumu açmak istediğinizden emin misiniz?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Diğer kişiyi imzalayabilmek için lütfen güvenli depolama parolanızı veya kurtarma anahtarınızı girin.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "{username} kişisinden gelen bu doğrulama isteği kabul edilsin mi?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "autoplayImages": "Canlandırmalı çıkartmaları ve ifadeleri otomatik olarak oynat", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "Ana sunucu aşağıdaki oturum açma türlerini destekliyor:\n{serverVersions}\nAncak bu uygulama yalnızca aşağıdakileri destekliyor:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "Ana sunucu aşağıdaki Spec sürümlerini destekliyor:\n{serverVersions}\nAncak bu uygulama yalnızca {supportedVersions} destekliyor", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "Sohbetten engelle", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Engellendi", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username}, {targetName} kişisini engelledi", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Aygıtı Engelle", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "Engellendi", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bot mesajları", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "İptal", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "{uri} URI'si açılamıyor", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeDeviceName": "Aygıt adını değiştir", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} sohbet avatarını değiştirdi", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} sohbet açıklamasını değiştirdi: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} sohbet adını değiştirdi: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} sohbet izinlerini değiştirdi", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} görünen adını '{displayname}' olarak değiştirdi", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} misafir erişim kurallarını değiştirdi", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} misafir erişim kurallarını değiştirdi: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} geçmiş görünürlüğünü değiştirdi", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} geçmiş görünürlüğünü değiştirdi: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} katılım kurallarını değiştirdi", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} katılım kurallarını değiştirdi: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} avatarını değiştirdi", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} oda takma adlarını değiştirdi", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} davet bağlantısını değiştirdi", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Parolayı değiştir", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Ana sunucuyu değiştir", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Tarzınızı değiştirin", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Grubun adını değiştir", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Avatarınızı değiştirin", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Şifreleme bozuldu", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Sohbet", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Sohbet yedekleme", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Eski mesajlarınız bir kurtarma anahtarı ile güvence altına alındı. Lütfen kaybetmediğinizden emin olun.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Sohbet ayrıntıları", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Sohbet bu alana eklendi", - "@chatHasBeenAddedToThisSpace": {}, - "chats": "Sohbetler", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Güçlü bir parola seçin", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "Arşivi temizle", - "@clearArchive": {}, - "close": "Kapat", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "Verilen kullanıcıyı bu odadan yasaklayın", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "HTML biçimli metin gönderin", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Verilen kullanıcıyı bu odaya davet edin", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "Verilen odaya katılın", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "Verilen kullanıcıyı bu odadan kaldırın", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "Bu odadan ayrılın", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Kendinizi tanımlayın", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "Bu oda için resminizi ayarlayın (mxc-uri ile)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Bu oda için görünen adınızı ayarlayın", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "Verilen kullanıcının güç seviyesini ayarlayın (öntanımlı: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Biçimlendirilmemiş metin gönderin", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Tepki olarak yanıt gönderin", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Metin gönderin", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Verilen kullanıcının bu odadaki yasağını kaldırın", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "Komut geçersiz", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} bir komut değil.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "Lütfen emojileri karşılaştırın", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Lütfen sayıları karşılaştırın", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Sohbeti yapılandır", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Onayla", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Bağlan", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kişi gruba davet edildi", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Görünen ad içerir", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Kullanıcı adı içerir", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "İçerik, sunucu yöneticilerine bildirildi", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Panoya kopyalandı", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Kopyala", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Panoya kopyala", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Mesajın şifresi çözülemedi: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} katılımcı", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Oluştur", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} sohbeti oluşturdu", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "createNewSpace": "Yeni alan", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "currentlyActive": "Şu anda etkin", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Koyu", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day} {month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}/{month}/{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Bu, kullanıcı hesabınızı devre dışı bırakacak. Bu geri alınamaz! Emin misiniz?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Öntanımlı izin seviyesi", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Sil", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Hesabı sil", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Mesajı sil", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Aygıt", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Aygıt kimliği", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Aygıtlar", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Doğrudan Sohbetler", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Görünen ad değiştirildi", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Dosyayı indir", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Düzenle", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Engellenen sunucuları düzenle", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Görünen adı düzenle", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Oda takma adlarını düzenle", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Oda avatarını düzenle", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "İfade zaten var!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Geçersiz ifade kısa kodu!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Oda için ifade paketleri", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "İfade Ayarları", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "İfade kısa kodu", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Bir ifade kısa kodu ve bir resim seçmeniz gerekiyor!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Boş sohbet", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "İfade paketini küresel olarak etkinleştir", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Şifrelemeyi etkinleştir", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Artık şifrelemeyi devre dışı bırakamayacaksınız. Emin misiniz?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Şifreli", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Şifreleme", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Şifreleme etkinleştirilmedi", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} aramayı sonlandırdı", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Bir e-posta adresi girin", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Ana sunucunuzu girin", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Konum alınırken hata oluştu: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "everythingReady": "Herşey hazır!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "Aşırı rahatsız edici", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "Dosya adı", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Yazı tipi boyutu", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "İlet", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Katılmadan", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "Davetten", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "Yeni odaya git", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "Grup", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Grup herkese açık", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "Gruplar", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "{displayname} ile grup", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Misafirlere izin verilmiyor", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Misafirler katılabilir", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username}, {targetName} için daveti geri çekti", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Yardım", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "Düzenlenmiş etkinlikleri gizle", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Bilinmeyen etkinlikleri gizle", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Bu içerik ne kadar rahatsız edici?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "Kimlik", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Kimlik", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Yok say", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Yok sayılan kullanıcılar", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Bağlantıya tıkladım", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Yanlış parola veya kurtarma anahtarı", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Rahatsız edici değil", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Kişi davet et", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Kişiyi {groupName} grubuna davet et", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Davet edildi", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username}, {targetName} kişisini davet etti", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Sadece davet edilen kullanıcılar", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Benim için davet et", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} sizi FluffyChat'e davet etti.\n1. fluffychat.im adresini ziyaret edin ve uygulamayı kurun \n2. Kaydolun veya oturum açın \n3. Davet bağlantısını açın: \n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "yazıyor…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} sohbete katıldı", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Odaya katıl", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username}, {targetName} kişisini attı", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username}, {targetName} kişisini attı ve engelledi", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Sohbetten at", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Son görülen: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Ayrıl", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Sohbetten ayrıldı", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Lisans", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Açık", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "{count} katılımcı daha yükle", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Yükleniyor… Lütfen bekleyin.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Daha fazla yükle…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "Konum hizmetleri devre dışı. Lütfen konumunuzu paylaşabilmek için etkinleştirin.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Konum izni reddedildi. Lütfen konumunuzu paylaşabilmek için izin verin.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "login": "Oturum aç", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "{homeserver} üzerinde oturum aç", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Oturumu kapat", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Üye değişiklikleri", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Bahset", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "Mesajlar", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderatör", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Sohbeti sessize al", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Uçtan uca şifreleme kullanmak için şimdilik Pantalaimon'a ihtiyacınız olduğunu lütfen unutmayın.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Yeni sohbet", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 FluffyChat'te yeni mesaj", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Yeni doğrulama isteği!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "İleri", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "Hayır", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Sunucuyla bağlantı yok", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "İfade bulunamadı. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Şifrelemeyi yalnızca oda artık herkese açık olmadığında etkinleştirebilirsiniz.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Görünüşe göre cihazınızda Firebase Cloud Messaging yok. Buna rağmen bildirim almaya devam etmek için ntfy yüklemenizi öneriyoruz. ntfy veya başka bir Unified Push sağlayıcısı ile anlık bildirimlerinizi güvenli bir şekilde alabilirsiniz. ntfy'ı PlayStore veya F-Droid'den indirebilirsiniz.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} matrix sunucusu değil, onun yerine {server2} kullanılsın mı?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "none": "Yok", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Henüz parolanızı kurtarmak için bir yol eklemediniz.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "İzin yok", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Oda bulunamadı…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Bildirimler", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Bu hesap için bildirimler etkinleştirildi", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} kullanıcı yazıyor…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "obtainingLocation": "Konum alınıyor…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Rahatsız edici", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Çevrim dışı", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "Tamam", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "Çevrim içi", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Çevrim içi anahtar yedekleme etkinleştirildi", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Tüh! Maalesef anlık bildirimlerini ayarlarken bir hata oluştu.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Tüh, bir şeyler yanlış gitti…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Mesajları okumak için uygulamayı aç", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Kamerayı aç", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "Haritalarda aç", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "or": "Veya", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "Katılımcı", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "parola veya kurtarma anahtarı", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Parola", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Parola unutuldu", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Parola değiştirildi", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Parola kurtarma", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "İnsanlar", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Bir resim seç", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "Sabitle", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "{fileName} dosyasını oynat", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "Lütfen seçin", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "Lütfen bir geçiş kodu seçin", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Lütfen e-postadaki bağlantıya tıklayın ve devam edin.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Lütfen 4 basamak girin veya uygulama kilidini devre dışı bırakmak için boş bırakın.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Lütfen parolanızı girin", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Lütfen PIN kodunuzu girin", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Lütfen kullanıcı adınızı girin", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Lütfen web sitesindeki talimatları izleyin ve \"İleri\" düğmesine dokunun.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Gizlilik", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Herkese Açık Odalar", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Gönderme kuralları", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "Neden", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "Kaydediliyor", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} bir etkinliği düzenledi", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "Mesajı düzenle", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Kaydol", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "Reddet", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} daveti reddetti", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Yeniden katıl", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Kaldır", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Diğer tüm aygıtları kaldır", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "{username} tarafından kaldırıldı", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Aygıtı kaldır", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Sohbet engelini kaldır", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Avatarınızı kaldırın", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Zengin mesaj içeriğini görüntüle", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Odayı yeni sürümle değiştir", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Yanıtla", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Mesajı bildir", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "İzin iste", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Oda yükseltildi", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "Oda sürümü", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "Dosyayı kaydet", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "Ara", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Güvenlik", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "{username} tarafından görüldü", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Gönder", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Bir mesaj gönder", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Metin olarak gönder", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "Ses gönder", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Dosya gönder", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Resim gönder", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Mesajları gönder", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Orijinali gönder", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Çıkartma gönder", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Video gönder", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} bir dosya gönderdi", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} bir ses gönderdi", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} bir resim gönderdi", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} bir çıkartma gönderdi", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} bir video gönderdi", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} arama bilgilerini gönderdi", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "Ana takma ad olarak ayarla", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Özel ifadeler ayarla", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "Davet bağlantısı ayarla", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "İzin seviyesini ayarla", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Durumu ayarla", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Ayarlar", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Paylaş", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} konumunu paylaştı", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "shareLocation": "Konumu paylaş", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Parolayı göster", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Tek oturum açma", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "Atla", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Kaynak kodları", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Alan herkese açık", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Alan adı", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} bir arama başlattı", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Durum", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Bugün nasılsınız?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Gönder", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Eşzamanlanıyor… Lütfen bekleyin.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Sistem", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Eşleşmediler", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Eşleştiler", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Sık Kullanılanlara Ekle/Çıkar", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Sessize Al/Sessizden Çıkar", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Okundu/Okunmadı Olarak İşaretle", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Çok fazla istek. Lütfen daha sonra tekrar deneyin!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Başka bir aygıttan aktar", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Tekrar göndermeyi deneyin", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Yok", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username}, {targetName} kişisinin engelini kaldırdı", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Aygıtın Engellemesini Kaldır", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Bilinmeyen aygıt", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Bilinmeyen şifreleme algoritması", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Bilinmeyen etkinlik '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Sohbeti sessizden çıkar", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Sabitlemeyi kaldır", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 okunmamış sohbet} other{{unreadCount} okunmamış sohbet}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} ve {count} diğer kişi yazıyor…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} ve {username2} yazıyor…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} yazıyor…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} sohbetten ayrıldı", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Kullanıcı adı", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} bir {type} etkinliği gönderdi", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "Doğrulandı", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "Doğrula", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Doğrulamayı Başlat", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Başarıyla doğrulandı!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Diğer hesap doğrulanıyor", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Görüntülü arama", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Sohbet geçmişi görünürlüğü", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Tüm katılımcılar için görünür", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Herkes için görünür", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Sesli mesaj", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Ortağın isteği kabul etmesi bekleniyor…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Ortağın emojiyi kabul etmesi bekleniyor…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Ortağın numaraları kabul etmesi bekleniyor…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Duvar kağıdı:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Uyarı!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Size bir e-posta gönderdik", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Kim hangi eylemi gerçekleştirebilir", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Bu gruba kimler katılabilir", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Bunu neden bildirmek istiyorsunuz?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Yeni bir kurtarma anahtarı oluşturmak için sohbet yedeğiniz silinsin mi?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Bu adresler ile parolanızı kurtarabilirsiniz.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Bir mesaj yaz…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Evet", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Sen", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Artık bu sohbette katılımcı değilsiniz", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Bu sohbetten engellendiniz", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Ortak anahtarınız", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "QR kodunu tarayın", - "@scanQrCode": {}, - "sendOnEnter": "Enter tuşu ile gönder", - "@sendOnEnter": {}, - "homeserver": "Ana sunucu", - "@homeserver": {}, - "serverRequiresEmail": "Bu sunucunun kayıt için e-posta adresinizi doğrulaması gerekiyor.", - "@serverRequiresEmail": {}, - "enableMultiAccounts": "(BETA) Bu aygıtta çoklu hesapları etkinleştir", - "@enableMultiAccounts": {}, - "bundleName": "Paket adı", - "@bundleName": {}, - "removeFromBundle": "Bu paketten kaldır", - "@removeFromBundle": {}, - "addToBundle": "Pakete ekle", - "@addToBundle": {}, - "editBundlesForAccount": "Bu hesap için paketleri düzenle", - "@editBundlesForAccount": {}, - "addAccount": "Hesap ekle", - "@addAccount": {}, - "oneClientLoggedOut": "İstemcilerinizden birinin oturumu kapatıldı", - "@oneClientLoggedOut": {}, - "link": "Bağlantı", - "@link": {}, - "yourChatBackupHasBeenSetUp": "Sohbet yedeklemeniz ayarlandı.", - "@yourChatBackupHasBeenSetUp": {}, - "unverified": "Doğrulanmadı", - "@unverified": {}, - "repeatPassword": "Parolayı tekrarlayın", - "@repeatPassword": {}, - "messageInfo": "Mesaj bilgileri", - "@messageInfo": {}, - "time": "Zaman", - "@time": {}, - "messageType": "Mesaj Türü", - "@messageType": {}, - "sender": "Gönderen", - "@sender": {}, - "openGallery": "Galeriyi aç", - "@openGallery": {}, - "removeFromSpace": "Alandan kaldır", - "@removeFromSpace": {}, - "addToSpaceDescription": "Bu sohbeti eklemek için bir alan seçin.", - "@addToSpaceDescription": {}, - "start": "Başla", - "@start": {}, - "commandHint_clearcache": "Önbelleği temizleyin", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_dm": "Doğrudan sohbet başlatın\nŞifrelemeyi devre dışı bırakmak için --no-encryption kullanın", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_create": "Boş bir grup sohbeti oluşturun\nŞifrelemeyi devre dışı bırakmak için --no-encryption kullanın", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_discardsession": "Oturumu silin", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "openVideoCamera": "Bir video için kamerayı aç", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "publish": "Yayınla", - "@publish": {}, - "videoWithSize": "Video ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "dismiss": "Kapat", - "@dismiss": {}, - "markAsRead": "Okundu olarak işaretle", - "@markAsRead": {}, - "reportUser": "Kullanıcıyı bildir", - "@reportUser": {}, - "openChat": "Sohbeti Aç", - "@openChat": {}, - "reactedWith": "{sender}, {reaction} ile tepki verdi", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "emojis": "Emojiler", - "@emojis": {}, - "placeCall": "Arama yap", - "@placeCall": {}, - "voiceCall": "Sesli arama", - "@voiceCall": {}, - "unsupportedAndroidVersion": "Desteklenmeyen Android sürümü", - "@unsupportedAndroidVersion": {}, - "unsupportedAndroidVersionLong": "Bu özellik daha yeni bir Android sürümü gerektiriyor. Lütfen güncellemelere veya LineageOS desteğine bakın.", - "@unsupportedAndroidVersionLong": {}, - "pinMessage": "Odaya sabitle", - "@pinMessage": {}, - "confirmEventUnpin": "Etkinliğin sabitlemesini kalıcı olarak kaldırmak istediğinizden emin misiniz?", - "@confirmEventUnpin": {}, - "videoCallsBetaWarning": "Görüntülü aramaların şu anda beta aşamasında olduğunu lütfen unutmayın. Tüm platformlarda beklendiği gibi veya hiç çalışmayabilirler.", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "Deneysel görüntülü aramalar", - "@experimentalVideoCalls": {}, - "emailOrUsername": "E-posta veya kullanıcı adı", - "@emailOrUsername": {}, - "switchToAccount": "{number}. hesaba geç", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Sonraki hesap", - "@nextAccount": {}, - "previousAccount": "Önceki hesap", - "@previousAccount": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "Özel", - "@widgetCustom": {}, - "widgetUrlError": "Bu geçerli bir URL değil.", - "@widgetUrlError": {}, - "widgetNameError": "Lütfen görünecek bir ad girin.", - "@widgetNameError": {}, - "errorAddingWidget": "Widget eklenirken hata oluştu.", - "@errorAddingWidget": {}, - "widgetVideo": "Video", - "@widgetVideo": {}, - "addWidget": "Widget ekle", - "@addWidget": {}, - "widgetEtherpad": "Metin notu", - "@widgetEtherpad": {}, - "widgetName": "Ad", - "@widgetName": {}, - "separateChatTypes": "Doğrudan Sohbetleri ve Grupları Ayır", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youJoinedTheChat": "Sohbete katıldınız", - "@youJoinedTheChat": {}, - "youAcceptedTheInvitation": "👍 Daveti kabul ettiniz", - "@youAcceptedTheInvitation": {}, - "youKickedAndBanned": "🙅 {user} kullanıcısını attınız ve yasakladınız", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "{user} kullanıcısının yasağını kaldırdınız", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 {user} kullanıcısını attınız", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youRejectedTheInvitation": "Daveti reddettiniz", - "@youRejectedTheInvitation": {}, - "youHaveWithdrawnTheInvitationFor": "{user} için daveti geri çektiniz", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 {user} tarafından davet edildiniz", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 {user} kullanıcısını davet ettiniz", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youBannedUser": "{user} kullanıcısını yasakladınız", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "storeInAppleKeyChain": "Apple KeyChain'de sakla", - "@storeInAppleKeyChain": {}, - "pleaseEnterRecoveryKey": "Lütfen kurtarma anahtarınızı girin:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKeyLost": "Kurtarma anahtarı kayıp mı?", - "@recoveryKeyLost": {}, - "pleaseEnterRecoveryKeyDescription": "Eski mesajlarınızın kilidini açmak için lütfen önceki bir oturumda oluşturulan kurtarma anahtarınızı girin. Kurtarma anahtarınız parolanız DEĞİLDİR.", - "@pleaseEnterRecoveryKeyDescription": {}, - "users": "Kullanıcılar", - "@users": {}, - "storeInSecureStorageDescription": "Kurtarma anahtarını bu aygıtın güvenli deposunda saklayın.", - "@storeInSecureStorageDescription": {}, - "recoveryKey": "Kurtarma anahtarı", - "@recoveryKey": {}, - "storeInAndroidKeystore": "Android KeyStore'da sakla", - "@storeInAndroidKeystore": {}, - "unlockOldMessages": "Eski mesajların kilidini aç", - "@unlockOldMessages": {}, - "saveKeyManuallyDescription": "Sistem paylaşımı iletişim kutusunu veya panoyu tetikleyerek bu anahtarı elle kaydedin.", - "@saveKeyManuallyDescription": {}, - "storeSecurlyOnThisDevice": "Bu aygıtta güvenli bir şekilde sakla", - "@storeSecurlyOnThisDevice": {}, - "countFiles": "{count} dosya", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "dehydrate": "Oturumu dışa aktar ve aygıtı sil", - "@dehydrate": {}, - "dehydrateTorLong": "TOR kullanıcıları için, pencereyi kapatmadan önce oturumu dışa aktarmaları tavsiye edilir.", - "@dehydrateTorLong": {}, - "dehydrateTor": "TOR Kullanıcıları: Oturumu dışa aktar", - "@dehydrateTor": {}, - "hydrateTor": "TOR Kullanıcıları: Dışa aktarılan oturumu içe aktar", - "@hydrateTor": {}, - "hydrate": "Yedekleme dosyasından geri yükle", - "@hydrate": {}, - "indexedDbErrorTitle": "Gizli mod sorunları", - "@indexedDbErrorTitle": {}, - "dehydrateWarning": "Bu eylem geri alınamaz. Yedekleme dosyasını güvenli bir şekilde sakladığınızdan emin olun.", - "@dehydrateWarning": {}, - "hydrateTorLong": "TOR'da en son oturumunuzu dışa aktardınız mı? Hızlıca içe aktarın ve sohbete devam edin.", - "@hydrateTorLong": {}, - "indexedDbErrorLong": "Mesaj saklama özelliği ne yazık ki öntanımlı olarak gizli modda etkin değildir.\nLütfen\n - about:config sayfasına gidin ve\n - dom.indexedDB.privateBrowsing.enabled seçeneğini true olarak ayarlayın\nAksi takdirde FluffyChat çalıştırılamaz.", - "@indexedDbErrorLong": {}, - "user": "Kullanıcı", - "@user": {}, - "custom": "Özel", - "@custom": {}, - "confirmMatrixId": "Hesabınızı silmek için lütfen Matrix kimliğinizi doğrulayın.", - "@confirmMatrixId": {}, - "supposedMxid": "Bu {mxid} olmalıdır", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasgroup": "Grup olarak işaretle", - "@commandHint_markasgroup": {}, - "commandHint_markasdm": "Verilen Matrix kimliği için doğrudan mesaj odası olarak işaretle", - "@commandHint_markasdm": {}, - "whyIsThisMessageEncrypted": "Bu mesaj neden okunamıyor?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "Bu durum, mesaj siz bu aygıtta hesabınızda oturum açmadan önce gönderildiyse meydana gelebilir.\n\nGönderenin aygıtınızı engellemiş olması veya internet bağlantısında bir sorun olması da mümkündür.\n\nMesajı başka bir oturumda okuyabiliyor musunuz? O zaman mesajı oradan aktarabilirsiniz! Ayarlar > Aygıtlar bölümüne gidin ve aygıtlarınızın birbirini doğruladığından emin olun. Odayı bir sonraki sefer açtığınızda ve her iki oturum da ön planda olduğunda, anahtarlar otomatik olarak iletilecektir.\n\nOturumu kapatırken veya aygıt değiştirirken anahtarları kaybetmek istemiyor musunuz? Ayarlarda sohbet yedeklemesini etkinleştirdiğinizden emin olun.", - "@noKeyForThisMessage": {}, - "screenSharingTitle": "ekran paylaşımı", - "@screenSharingTitle": {}, - "callingPermissions": "Arama izinleri", - "@callingPermissions": {}, - "callingAccountDetails": "FluffyChat'in yerel android telefon uygulamasını kullanmasına izin verir.", - "@callingAccountDetails": {}, - "appearOnTop": "Üstte görün", - "@appearOnTop": {}, - "enterSpace": "Alana gir", - "@enterSpace": {}, - "enterRoom": "Odaya gir", - "@enterRoom": {}, - "allSpaces": "Tüm alanlar", - "@allSpaces": {}, - "otherCallingPermissions": "Mikrofon, kamera ve diğer FluffyChat izinleri", - "@otherCallingPermissions": {}, - "foregroundServiceRunning": "Bu bildirim, ön plan hizmeti çalışırken görünür.", - "@foregroundServiceRunning": {}, - "callingAccount": "Arama hesabı", - "@callingAccount": {}, - "appearOnTopDetails": "Uygulamanın üstte görünmesine izin verir (Fluffychat'ı zaten bir arama hesabı olarak ayarladıysanız gerekli değildir)", - "@appearOnTopDetails": {}, - "newGroup": "Yeni grup", - "@newGroup": {}, - "newSpace": "Yeni alan", - "@newSpace": {}, - "screenSharingDetail": "Ekranınızı FuffyChat'te paylaşıyorsunuz", - "@screenSharingDetail": {}, - "numChats": "{number} sohbet", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Önemsiz durum etkinliklerini gizle", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Tekrar gösterme", - "@doNotShowAgain": {}, - "googlyEyesContent": "{senderName} size şaşkın gözler gönderiyor", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_cuddle": "Kucaklama gönder", - "@commandHint_cuddle": {}, - "commandHint_googly": "Şaşkın gözler gönder", - "@commandHint_googly": {}, - "commandHint_hug": "Sarılma gönder", - "@commandHint_hug": {}, - "cuddleContent": "{senderName} sizi kucaklıyor", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} size sarılıyor", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "wasDirectChatDisplayName": "Boş sohbet ({oldDisplayName} idi)", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "startFirstChat": "İlk sohbetinizi başlatın", - "@startFirstChat": {}, - "newSpaceDescription": "Alanlar, sohbetlerinizi birleştirmenize ve özel veya genel topluluklar oluşturmanıza olanak tanır.", - "@newSpaceDescription": {}, - "encryptThisChat": "Bu sohbeti şifrele", - "@encryptThisChat": {}, - "disableEncryptionWarning": "Güvenlik nedeniyle, daha önce etkinleştirildiği bir sohbette şifrelemeyi devre dışı bırakamazsınız.", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "Üzgünüm... bu mümkün değil", - "@sorryThatsNotPossible": {}, - "deviceKeys": "Aygıt anahtarları:", - "@deviceKeys": {}, - "reopenChat": "Sohbeti yeniden aç", - "@reopenChat": {}, - "noBackupWarning": "Uyarı! Sohbet yedeklemesini etkinleştirmezseniz, şifrelenen mesajlarınıza erişiminizi kaybedersiniz. Oturumu kapatmadan önce sohbet yedeklemesini etkinleştirmeniz önemle tavsiye edilir.", - "@noBackupWarning": {}, - "noOtherDevicesFound": "Başka aygıt bulunamadı", - "@noOtherDevicesFound": {}, - "fileIsTooBigForServer": "Sunucu, dosyanın gönderilemeyecek kadar büyük olduğunu bildiriyor.", - "@fileIsTooBigForServer": {}, - "fileHasBeenSavedAt": "Dosya {path} konumuna kaydedildi", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Son okunan mesaja atla", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Buraya kadar oku", - "@readUpToHere": {}, - "jump": "Atla", - "@jump": {}, - "openLinkInBrowser": "Bağlantıyı tarayıcıda aç", - "@openLinkInBrowser": {}, - "allRooms": "Tüm Grup Sohbetleri", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "😭 Olamaz. Bir şeyler yanlış gitti. İsterseniz bu hatayı geliştiricilere bildirebilirsiniz.", - "@reportErrorDescription": {}, - "report": "bildir", - "@report": {}, - "signInWithPassword": "Parola ile oturum aç", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Lütfen daha sonra tekrar deneyin veya farklı bir sunucu seçin.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWith": "{provider} ile oturum aç", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Bir resim dosyası değil.", - "@notAnImage": {}, - "importNow": "Şimdi içe aktar", - "@importNow": {}, - "importEmojis": "İfadeleri İçe Aktar", - "@importEmojis": {}, - "importFromZipFile": ".zip dosyasından içe aktar", - "@importFromZipFile": {}, - "exportEmotePack": "İfade paketini .zip olarak dışa aktar", - "@exportEmotePack": {}, - "replace": "Değiştir", - "@replace": {}, - "sendTypingNotifications": "Yazma bildirimleri gönder", - "@sendTypingNotifications": {}, - "messagesStyle": "Mesajlar:", - "@messagesStyle": {}, - "createGroup": "Grup oluştur", - "@createGroup": {}, - "shareInviteLink": "Davet bağlantısını paylaş", - "@shareInviteLink": {}, - "profileNotFound": "Kullanıcı sunucuda bulunamadı. Belki bir bağlantı sorunu vardır veya kullanıcı mevcut değildir.", - "@profileNotFound": {}, - "setTheme": "Temayı ayarla:", - "@setTheme": {}, - "setColorTheme": "Renk temasını ayarla:", - "@setColorTheme": {}, - "inviteContactToGroupQuestion": "{contact} kişisini \"{groupName}\" sohbetine davet etmek istiyor musunuz?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "Tekrar deneyin", - "@tryAgain": {}, - "redactMessageDescription": "Bu mesaj bu görüşmedeki herkes için düzenlenecek. Bu işlem geri alınamaz.", - "@redactMessageDescription": {}, - "optionalRedactReason": "(İsteğe bağlı) Bu mesajı düzenleme nedeni…", - "@optionalRedactReason": {}, - "invite": "Davet et", - "@invite": {}, - "addChatDescription": "Sohbet açıklaması ekle...", - "@addChatDescription": {}, - "chatPermissions": "Sohbet izinleri", - "@chatPermissions": {}, - "chatDescription": "Sohbet açıklaması", - "@chatDescription": {}, - "noChatDescriptionYet": "Daha sohbet açıklaması oluşturulmadı.", - "@noChatDescriptionYet": {}, - "invalidServerName": "Geçersiz sunucu adı", - "@invalidServerName": {}, - "redactedBy": "{username} tarafından düzenlendi", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactedByBecause": "{username} tarafından \"{reason}\" nedeniyle düzenlendi", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "setChatDescription": "Sohbet açıklamasını ayarla", - "@setChatDescription": {}, - "chatDescriptionHasBeenChanged": "Sohbet açıklaması değişti", - "@chatDescriptionHasBeenChanged": {}, - "directChat": "Doğrudan sohbet", - "@directChat": {}, - "inviteGroupChat": "📨 Grup sohbetine davet et", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Gizli sohbete davet et", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "Son kullanılan ifadeler burada görünecek...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "invalidInput": "Geçersiz giriş!", - "@invalidInput": {}, - "wrongPinEntered": "Yanlış PIN girildi! {seconds} saniye sonra tekrar deneyin...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "banUserDescription": "Kullanıcı sohbetten yasaklanacak ve yasağı kaldırılana kadar sohbete tekrar giremeyecek.", - "@banUserDescription": {}, - "removeDevicesDescription": "Bu aygıttan çıkış yapacaksınız ve artık mesaj alamayacaksınız.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "Kullanıcı denerse sohbete tekrar girebilecektir.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Anlık bildirimler kullanılamıyor", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Bu kullanıcıyı yönetici yaptıktan sonra, sizinle aynı izinlere sahip olacağı için bunu geri alamayabilirsiniz.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Sohbet arşive taşınacak. Diğer kullanıcıları sohbeti terk ettiğinizi görebilecek.", - "@archiveRoomDescription": {}, - "hasKnocked": "🚪 {user} tıklattı", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "learnMore": "Daha fazla bilgi", - "@learnMore": {}, - "roomUpgradeDescription": "Sohbet daha sonra yeni oda sürümüyle yeniden oluşturulacaktır. Tüm katılımcılara yeni sohbete geçmeleri gerektiği bildirilecektir. Oda sürümleri hakkında daha fazla bilgiyi https://spec.matrix.org/latest/rooms/ adresinde bulabilirsiniz.", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Lütfen 0'dan büyük bir sayı girin", - "@pleaseEnterANumber": {}, - "kickUserDescription": "Kullanıcı sohbetten atılır ancak yasaklanmaz. Herkese açık sohbetlerde kullanıcı istediği zaman yeniden katılabilir.", - "@kickUserDescription": {}, - "createGroupAndInviteUsers": "Bir grup oluşturun ve kullanıcıları davet edin", - "@createGroupAndInviteUsers": {}, - "groupCanBeFoundViaSearch": "Grup, arama ile bulunabilir", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "Ne yazık ki \"{query}\" ile kullanıcı bulunamadı. Lütfen bir yazım hatası yapıp yapmadığınızı kontrol edin.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "yourGlobalUserIdIs": "Genel kullanıcı kimliğiniz: ", - "@yourGlobalUserIdIs": {}, - "groupName": "Grup ismi", - "@groupName": {}, - "searchChatsRooms": "#sohbetler, @kullanıcılar... için arama yapın", - "@searchChatsRooms": {}, - "blockListDescription": "Sizi rahatsız eden kullanıcıları engelleyebilirsiniz. Kişisel engelleme listenizdeki kullanıcılardan herhangi bir mesaj veya oda daveti alamazsınız.", - "@blockListDescription": {}, - "startConversation": "Görüşme başlat", - "@startConversation": {}, - "blockedUsers": "Engellenen kullanıcılar", - "@blockedUsers": {}, - "block": "Engelle", - "@block": {}, - "commandHint_sendraw": "Ham JSON gönder", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Üzgünüm... bu doğru kurtarma anahtarı gibi görünmüyor.", - "@wrongRecoveryKey": {}, - "blockUsername": "Kullanıcı adını görmezden gel", - "@blockUsername": {}, - "databaseMigrationTitle": "Veri tabanı iyileştirildi", - "@databaseMigrationTitle": {}, - "databaseMigrationBody": "Lütfen bekleyin. Bu biraz zaman alabilir.", - "@databaseMigrationBody": {}, - "youInvitedToBy": "📩 Bağlantı aracılığıyla davet edildiniz:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "pleaseEnterYourCurrentPassword": "Lütfen geçerli parolanızı girin", - "@pleaseEnterYourCurrentPassword": {}, - "pleaseChooseAStrongPassword": "Lütfen güçlü bir parola seçin", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "Sohbet veya alt alan ekle", - "@addChatOrSubSpace": {}, - "canceledKeyVerification": "{sender} anahtar doğrulamayı iptal etti", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "publicLink": "Herkese açık bağlantı", - "@publicLink": {}, - "joinSpace": "Alana katıl", - "@joinSpace": {}, - "newPassword": "Yeni parola", - "@newPassword": {}, - "databaseBuildErrorBody": "SQlite veri tabanı oluşturulamadı. Uygulama şimdilik eski veri tabanını kullanmaya çalışıyor. Lütfen bu hatayı {url} adresinde geliştiricilere bildirin. Hata mesajı: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sessionLostBody": "Oturumunuz kayboldu. Lütfen bu hatayı {url} adresinde geliştiricilere bildirin. Hata mesajı: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "subspace": "Alt alan", - "@subspace": {}, - "thisDevice": "Bu aygıt:", - "@thisDevice": {}, - "formattedMessagesDescription": "Markdown kullanarak kalın metin gibi zengin mesaj içeriğini görüntüle.", - "@formattedMessagesDescription": {}, - "verifyOtherDevice": "🔐 Diğer aygıtı doğrula", - "@verifyOtherDevice": {}, - "presencesToggle": "Diğer kullanıcıların durum mesajlarını göster", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "presenceStyle": "Bulunma:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "searchForUsers": "@kullanıcıları ara...", - "@searchForUsers": {}, - "commandHint_ignore": "Verilen matrix kimliğini görmezden gel", - "@commandHint_ignore": {}, - "commandHint_unignore": "Verilen matrix kimliğini görmezden gelmeyi iptal et", - "@commandHint_unignore": {}, - "appLockDescription": "Kullanılmadığında PIN kodu ile uygulamayı kilitle", - "@appLockDescription": {}, - "globalChatId": "Genel sohbet kimliği", - "@globalChatId": {}, - "accessAndVisibility": "Erişim ve görünürlük", - "@accessAndVisibility": {}, - "accessAndVisibilityDescription": "Bu sohbete kimlerin katılmasına izin verilir ve sohbet nasıl keşfedilebilir.", - "@accessAndVisibilityDescription": {}, - "calls": "Aramalar", - "@calls": {}, - "customEmojisAndStickers": "Özel emojiler ve çıkartmalar", - "@customEmojisAndStickers": {}, - "customEmojisAndStickersBody": "Herhangi bir sohbette kullanılabilecek özel emojiler veya çıkartmalar ekleyin veya paylaşın.", - "@customEmojisAndStickersBody": {}, - "hideRedactedMessages": "Düzenlenen mesajları gizle", - "@hideRedactedMessages": {}, - "hideRedactedMessagesBody": "Birisi bir mesajı düzenlerse, bu mesaj artık sohbette görünmeyecektir.", - "@hideRedactedMessagesBody": {}, - "hideMemberChangesInPublicChats": "Herkese açık sohbetlerde üye değişikliklerini gizle", - "@hideMemberChangesInPublicChats": {}, - "hideMemberChangesInPublicChatsBody": "Okunabilirliği artırmak için birisi herkese açık bir sohbete katıldığında veya sohbetten ayrıldığında sohbet zaman çizelgesinde gösterme.", - "@hideMemberChangesInPublicChatsBody": {}, - "passwordRecoverySettings": "Parola kurtarma ayarları", - "@passwordRecoverySettings": {}, - "userWouldLikeToChangeTheChat": "{user} sohbete katılmak istiyor.", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "noPublicLinkHasBeenCreatedYet": "Henüz herkese açık bir bağlantı oluşturulmadı", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "Tıklat", - "@knock": {}, - "knocking": "Tıklat", - "@knocking": {}, - "usersMustKnock": "Kullanıcılar tıklatmalı", - "@usersMustKnock": {}, - "noOneCanJoin": "Kimse katılamaz", - "@noOneCanJoin": {}, - "nothingFound": "Hiçbir şey bulunamadı...", - "@nothingFound": {}, - "sendReadReceiptsDescription": "Sohbetteki diğer katılımcılar bir mesajı okuduğunuzu görebilir.", - "@sendReadReceiptsDescription": {}, - "verifyOtherDeviceDescription": "Başka bir aygıtı doğruladığınızda, bu aygıtlar anahtarları değiş tokuş ederek genel güvenliğinizi artırır. 💪 Bir doğrulama başlattığınızda, her iki aygıttaki uygulamada bir açılır pencere görünecektir. Orada birbirleriyle karşılaştırmanız gereken bir dizi emoji veya sayı göreceksiniz. Doğrulamaya başlamadan önce her iki aygıtın da elinizin altında olması en iyisidir. 🤳", - "@verifyOtherDeviceDescription": {}, - "noDatabaseEncryption": "Veri tabanı şifrelemesi bu platformda desteklenmiyor", - "@noDatabaseEncryption": {}, - "thereAreCountUsersBlocked": "Şu anda {count} engellenen kullanıcı var.", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "publicSpaces": "Herkese açık alanlar", - "@publicSpaces": {}, - "initAppError": "Uygulama başlatılırken bir hata oluştu", - "@initAppError": {}, - "userRole": "Kullanıcı rolü", - "@userRole": {}, - "hideInvalidOrUnknownMessageFormats": "Geçersiz veya bilinmeyen mesaj biçimlerini gizle", - "@hideInvalidOrUnknownMessageFormats": {}, - "hidePresences": "Durum listesi gizlensin mi?", - "@hidePresences": {}, - "overview": "Genel görünüm", - "@overview": {}, - "decline": "Reddet", - "@decline": {}, - "notifyMeFor": "Beni bilgilendir", - "@notifyMeFor": {}, - "chatCanBeDiscoveredViaSearchOnServer": "Sohbet {server} üzerinde aranarak keşfedilebilir", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "leaveEmptyToClearStatus": "Durumunuzu temizlemek için boş bırakın.", - "@leaveEmptyToClearStatus": {}, - "select": "Seç", - "@select": {}, - "minimumPowerLevel": "{level} en düşük güç seviyesidir.", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "passwordsDoNotMatch": "Parolalar eşleşmiyor", - "@passwordsDoNotMatch": {}, - "passwordIsWrong": "Girdiğiniz parola yanlış", - "@passwordIsWrong": {}, - "publicChatAddresses": "Herkese açık sohbet adresleri", - "@publicChatAddresses": {}, - "createNewAddress": "Yeni adres oluştur", - "@createNewAddress": {}, - "forwardMessageTo": "Mesajlar {roomName} kişisine iletilsin mi?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "acceptedKeyVerification": "{sender} anahtar doğrulamayı kabul etti", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "restoreSessionBody": "Uygulama şimdi oturumunuzu yedekten geri yüklemeye çalışıyor. Lütfen bu hatayı {url} adresinde geliştiricilere bildirin. Hata mesajı: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sendReadReceipts": "Okundu bilgisi gönder", - "@sendReadReceipts": {}, - "completedKeyVerification": "{sender} anahtar doğrulamayı tamamladı", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "sendTypingNotificationsDescription": "Sohbetteki diğer katılımcılar yeni bir mesaj yazdığınızı görebilir.", - "@sendTypingNotificationsDescription": {}, - "isReadyForKeyVerification": "{sender} anahtar doğrulama için hazır", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "formattedMessages": "Biçimlendirilen mesajlar", - "@formattedMessages": {}, - "requestedKeyVerification": "{sender} anahtar doğrulama istedi", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "verifyOtherUser": "🔐 Diğer kullanıcıyı doğrula", - "@verifyOtherUser": {}, - "startedKeyVerification": "{sender} anahtar doğrulama başlattı", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "Şeffaf", - "@transparent": {}, - "discover": "Keşfet", - "@discover": {}, - "incomingMessages": "Gelen mesajlar", - "@incomingMessages": {}, - "verifyOtherUserDescription": "Başka bir kullanıcıyı doğrularsanız, gerçekten kime yazdığınızı bildiğinizden emin olabilirsiniz. 💪\n\nBir doğrulama başlattığınızda, siz ve diğer kullanıcı uygulamada bir açılır pencere görecektir. Orada birbirinizle karşılaştırmanız gereken bir dizi emoji veya sayı göreceksiniz.\n\nBunu yapmanın en iyi yolu buluşmak veya bir görüntülü arama başlatmaktır. 👭", - "@verifyOtherUserDescription": {}, - "stickers": "Çıkartmalar", - "@stickers": {}, - "unreadChatsInApp": "{appname}: {unread} okunmayan sohbet", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "searchIn": "\"{chat}\" sohbeti içinde ara...", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "searchMore": "Daha fazla ara...", - "@searchMore": {}, - "gallery": "Galeri", - "@gallery": {}, - "files": "Dosyalar", - "@files": {}, - "knockRestricted": "Tıklatma kısıtlı", - "@knockRestricted": {}, - "restricted": "Kısıtlı", - "@restricted": {}, - "swipeRightToLeftToReply": "Yanıtlamak için sağdan sola kaydır", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_uk.arb b/assets/l10n/intl_uk.arb deleted file mode 100644 index 62c59b73e..000000000 --- a/assets/l10n/intl_uk.arb +++ /dev/null @@ -1,2608 +0,0 @@ -{ - "@@locale": "uk", - "@@last_modified": "2021-08-14 12:41:09.790615", - "about": "Про застосунок", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Прийняти", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} приймає запрошення", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Обліковий запис", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} активує наскрізне шифрування", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "Адміністратор", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "псевдонім", - "@alias": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} відповідає на виклик", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Будь-хто може приєднатись", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "Архів", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Чи дозволено гостям приєднуватись", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Ви впевнені?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "Для підпису ключа іншого користувача введіть свою парольну фразу або ключ відновлення.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Прийняти цей запит на підтвердження від {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banFromChat": "Заблокувати в бесіді", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Заблоковано", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} блокує {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Заблокувати пристрій", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "cancel": "Скасувати", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} змінює аватар бесіди", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} змінює опис бесіди на: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} змінює назву бесіди на: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} змінює права доступу бесіди", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} змінює показуване ім'я на: '{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} змінює правила гостьового доступу", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} змінює правила гостьового доступу на: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} змінює видимість історії", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} змінює видимість історії на: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} змінює правила приєднання", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} змінює правила приєднання на: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} змінює аватар", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} змінює псевдоніми кімнати", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} змінює посилання для запрошення", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeTheHomeserver": "Змінити домашній сервер", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Змінити стиль", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Змінити назву групи", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Шифрування було пошкоджено", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Бесіда", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Подробиці бесіди", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Виберіть надійний пароль", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Закрити", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Порівняйте емодзі", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Порівняйте цифри", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "confirm": "Підтвердити", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Під'єднатись", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Контакт був запрошений в групу", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "Скопійовано в буфер обміну", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "Копіювати", - "@copy": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "Помилка розшифрування повідомлення: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "Учасників: {count}", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "Створити", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} створює бесіду", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Зараз у мережі", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "Темний", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{timeOfDay}, {date}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{day}-{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day}-{month}-{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "delete": "Видалити", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Видалити повідомлення", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "Пристрій", - "@device": { - "type": "text", - "placeholders": {} - }, - "devices": "Пристрої", - "@devices": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Показуване ім'я було змінено", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Завантажити файл", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Змінити показуване ім'я", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Емодзі вже існує!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Неприпустимий короткий код емодзі!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Налаштування емодзі", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Короткий код для емодзі", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Укажіть короткий код емодзі та зображення!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Порожня бесіда", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Ви більше не зможете вимкнути шифрування. Ви впевнені?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encryption": "Шифрування", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Шифрування вимкнено", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} завершує виклик", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterYourHomeserver": "Введіть адресу домашнього сервера", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "fileName": "Назва файлу", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "forward": "Переслати", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "З моменту приєднання", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "З моменту запрошення", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "Група", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Загальнодоступна група", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Група з {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Гості не можуть приєднуватись", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Гості можуть приєднуватись", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} відкликає запрошення для {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Довідка", - "@help": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "Ідентифікація", - "@identity": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Неправильна парольна фраза або ключ відновлення", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Запросити контакт", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Запросити контакт до {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Запрошено", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} запрошує {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Лише запрошені користувачі", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} запрошує вас у FluffyChat. \n1. Перейдіть на fluffychat.im й установіть застосунок \n2. Зареєструйтесь або ввійдіть \n3. Відкрийте запрошувальне посилання:\n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "пише…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} приєднується до бесіди", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "kicked": "👞 {username} вилучає {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} вилучає та блокує {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Вилучити з бесіди", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Остання активність: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Вийти", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Виходить з бесіди", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Ліцензія", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Світлий", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Завантажити ще {count} учасників", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Завантаження… Будь ласка, зачекайте.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Завантажити ще…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Увійти", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "Увійти до {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "Вийти", - "@logout": { - "type": "text", - "placeholders": {} - }, - "moderator": "Модератор", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Вимкнути сповіщення", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Майте на увазі, що на цей час вам потрібен Pantalaimon, щоб використовувати наскрізне шифрування.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 Нове повідомлення у FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Новий запит перевірки!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "Емоджі не знайдено. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Схоже, Firebase Cloud Messaging недоступна на вашому пристрої. Щоб отримувати push-сповіщення, радимо встановити ntfy. За допомогою ntfy або іншого постачальника Unified Push ви можете отримувати push-сповіщення у безпечний спосіб. Ви можете завантажити ntfy з PlayStore або з F-Droid.", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Нічого", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Немає прав доступу", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Кімнат не знайдено…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "ok": "Гаразд", - "@ok": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "Резервне онлайн-копіювання ключів увімкнено", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "Халепа, щось пішло не так…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "Відкрийте застосунок читання повідомлень", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "Відкрити камеру", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "парольна фраза або ключ відновлення", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "Пароль", - "@password": { - "type": "text", - "placeholders": {} - }, - "pickImage": "Вибрати зображення", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "play": "Відтворити {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseEnterYourPassword": "Введіть свій пароль", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Введіть своє ім'я користувача", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Загальнодоступні кімнати", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "recording": "Запис", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} змінює подію", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Відхилити", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} відхиляє запрошення", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Приєднатися знову", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Вилучити", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Вилучити всі інші пристрої", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Вилучено користувачем {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Вилучити пристрій", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "Розблокувати у бесіді", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Показувати форматований вміст повідомлення", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "reply": "Відповісти", - "@reply": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Запит дозволу", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Кімнату було оновлено", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Переглянуто {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Надіслати", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Надіслати повідомлення", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Надіслати файл", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Надіслати зображення", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁 {username} надсилає файл", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤 {username} надсилає аудіо", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} надсилає зображення", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} надсилає наліпку", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} надсилає відео", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "setInvitationLink": "Указати посилання для запрошення", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setStatus": "Указати статус", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "Налаштування", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "Поділитися", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} ділиться своїм місцеперебуванням", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "skip": "Пропустити", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Джерельний код", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Як справи сьогодні?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Надіслати", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "Системна", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "Вони відрізняються", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "Вони збігаються", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "Спробуйте надіслати ще раз", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} розблоковує {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Розблокувати пристрій", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "Невідомий пристрій", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "Невідомий алгоритм шифрування", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Невідома подія '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Увімкнути сповіщення", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "userAndOthersAreTyping": "{username} та {count} інших пишуть…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} і {username2} пишуть…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} пише…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪 {username} виходить з бесіди", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Ім'я користувача", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} надсилає подію {type}", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "Перевірити", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Почати перевірку", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Ви успішно перевірені!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Перевірка іншого облікового запису", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Відеовиклик", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Видимість історії бесіди", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Видима для всіх учасників", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Видима для всіх", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Голосове повідомлення", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "Очікування прийняття запиту партнером…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "Очікування прийняття емоджі партнером…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Очікування прийняття чисел партнером…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Шпалери:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Кому дозволено приєднуватися до цієї групи", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Написати повідомлення…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Так", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Ви", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Ви більше не берете участь у цій бесіді", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Ви були заблоковані у цій бесіді", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Правила сповіщень", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Сповіщення ввімкнені для цього облікового запису", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "notifications": "Сповіщення", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Зміни учасників", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "Запрошення для мене", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "enterAnEmailAddress": "Введіть адресу е-пошти", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Зашифровано", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Увімкнути пакунок емоджі глобально", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Набори емоджі для кімнати", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "edit": "Редагувати", - "@edit": { - "type": "text", - "placeholders": {} - }, - "directChats": "Особисті бесіди", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "deviceId": "ID пристрою", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Видалити обліковий запис", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deactivateAccountWarning": "Це деактивує ваш обліковий запис. Це неможливо скасувати! Ви впевнені?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Містить ім’я користувача", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Містить показуване ім’я", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "changePassword": "Змінити пароль", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Змінити назву пристрою", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Повідомлення ботів", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "or": "Або", - "@or": { - "type": "text", - "placeholders": {} - }, - "setAsCanonicalAlias": "Установити основним псевдонімом", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "verified": "Перевірений", - "@verified": { - "type": "text", - "placeholders": {} - }, - "blocked": "Заблоковано", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "no": "Ні", - "@no": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "Надсилати натисканням Enter", - "@sendOnEnter": {}, - "commandHint_ban": "Заблокувати цього користувача кімнати", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_kick": "Вилучити цього користувача з цієї кімнати", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_myroomavatar": "Встановіть зображення для цієї кімнати (від mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "Укажіть показуване ім'я для цієї кімнати", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandMissing": "{command} не є командою.", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "copyToClipboard": "Копіювати до буфера обміну", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "createNewSpace": "Новий простір", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Увімкнути шифрування", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "joinRoom": "Приєднатися до кімнати", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "mention": "Згадати", - "@mention": { - "type": "text", - "placeholders": {} - }, - "next": "Далі", - "@next": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Немає з'єднання з сервером", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "scanQrCode": "Сканувати QR-код", - "@scanQrCode": {}, - "noPasswordRecoveryDescription": "Ви ще не додали спосіб відновлення пароля.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} користувачів пишуть…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "online": "Онлайн", - "@online": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "Дідько! На жаль, сталася помилка під час налаштування push-сповіщень.", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "Забули пароль", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "pleaseChoose": "Виберіть", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "Введіть 4 цифри або залиште порожнім, щоб вимкнути блокування застосунку.", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "redactMessage": "Редагувати повідомлення", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "Зареєструватися", - "@register": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Поскаржитися на повідомлення", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Замінити кімнату новішою версією", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Надіслати аудіо", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "Установити користувацькі емоджі", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Ми надіслали вам електронний лист", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "Стерти резервну копію бесіди, щоб створити новий ключ відновлення?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "Додати простір", - "@addToSpace": {}, - "roomVersion": "Версія кімнати", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "Мною виконано перехід за посиланням", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} розпочинає виклик", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "appLock": "Блокування застосунку", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "commandInvalid": "Неприпустима команда", - "@commandInvalid": { - "type": "text" - }, - "extremeOffensive": "Украй образливий", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Наскільки образливий цей вміст?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "participant": "Учасник", - "@participant": { - "type": "text", - "placeholders": {} - }, - "addEmail": "Додати е-пошту", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "ignore": "Нехтувати", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Розмір шрифту", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "Домашній сервер підтримує такі версії специфікацій:\n{serverVersions}\nАле цей застосунок підтримує лише {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "areYouSureYouWantToLogout": "Ви впевнені, що хочете вийти?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "badServerLoginTypesException": "Домашній сервер підтримує такі типи входу:\n{serverVersions}\nАле цей застосунок підтримує лише:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "all": "Усі", - "@all": { - "type": "text", - "placeholders": {} - }, - "allChats": "Усі бесіди", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "commandHint_join": "Приєднатися до цієї кімнати", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "chats": "Бесіди", - "@chats": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "Змінити аватар", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "link": "Посилання", - "@link": {}, - "security": "Безпека", - "@security": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Надіслати наліпку", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "Помилка під час отримання розташування: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "hideRedactedEvents": "Сховати змінені події", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "Синхронізація… Будь ласка, зачекайте.", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} не є сервером matrix, використовувати {server2} натомість?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "reason": "Причина", - "@reason": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Типовий рівень дозволів", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "Надіслати як текст", - "@sendAsText": { - "type": "text" - }, - "saveFile": "Зберегти файл", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "Автоматично відтворювати анімовані наліпки та емоджі", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "pleaseChooseAPasscode": "Виберіть код доступу", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "Натисніть на посилання в електронному листі, а потім продовжуйте.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Позначити прочитаним/непрочитаним", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Перенесення з іншого пристрою", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Надсилати повідомлення", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "Надіслати оригінал", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Хто і яку дію може виконувати", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Чому ви хочете поскаржитися?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "messages": "Повідомлення", - "@messages": { - "type": "text", - "placeholders": {} - }, - "newChat": "Нова бесіда", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Усе готово!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "homeserver": "Домашній сервер", - "@homeserver": {}, - "goToTheNewRoom": "Перейти до нової кімнати", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "groups": "Групи", - "@groups": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Необразливий", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Активувати шифрування можна лише тоді, коли кімната більше не буде загальнодоступною.", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "Бесіду додано до цього простору", - "@chatHasBeenAddedToThisSpace": {}, - "chatBackupDescription": "Ваші старі повідомлення захищені ключем відновлення. Переконайтеся, що ви не втратите його.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Резервне копіювання бесіди", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "yourChatBackupHasBeenSetUp": "Резервне копіювання бесіди налаштовано.", - "@yourChatBackupHasBeenSetUp": {}, - "clearArchive": "Очистити архів", - "@clearArchive": {}, - "commandHint_html": "Надіслати текст у форматі HTML", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "Запросіть цього користувача до цієї кімнати", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_leave": "Вийти з цієї кімнати", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "Опишіть себе", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "hideUnknownEvents": "Сховати невідомі події", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Нехтувані користувачі", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "obtainingLocation": "Отримання розташування…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "offensive": "Образливий", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "Офлайн", - "@offline": { - "type": "text", - "placeholders": {} - }, - "addAccount": "Додати обліковий запис", - "@addAccount": {}, - "enableMultiAccounts": "(БЕТА) Увімкнути кілька облікових записів на цьому пристрої", - "@enableMultiAccounts": {}, - "openInMaps": "Відкрити в картах", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "serverRequiresEmail": "Цей сервер потребує перевірки вашої адресу е-пошти для реєстрації.", - "@serverRequiresEmail": {}, - "pleaseFollowInstructionsOnWeb": "Виконайте вказівки вебсайту та торкніться далі.", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Надіслати відео", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "Вилучити свій аватар", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "unpin": "Відкріпити", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "Указати рівні дозволів", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "Поділитися місцеперебуванням", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "Єдиний вхід", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "Забагато запитів. Спробуйте пізніше!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "unavailable": "Недоступний", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 непрочитана бесіда} few{{unreadCount} непрочитані бесіди} many{{unreadCount} непрочитаних бесід} other{{unreadCount} непрочитані бесіди}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "withTheseAddressesRecoveryDescription": "За допомогою цих адрес ви можете відновити свій пароль.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "privacy": "Приватність", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "search": "Пошук", - "@search": { - "type": "text", - "placeholders": {} - }, - "sentCallInformations": "{senderName} надсилає відомості про виклик", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "cantOpenUri": "Не вдалося відкрити URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "contentHasBeenReported": "Скаргу на вміст надіслано адміністраторам сервера", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "commandHint_op": "Укажіть рівень повноважень цього користувача (типово: 50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "Надіслати неформатований текст", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "Надіслати відповідь як реакцію", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "Надіслати текст", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "Розблокувати цього користувача у цій кімнаті", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "configureChat": "Налаштувати бесіду", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Редагувати заблоковані сервери", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Показати пароль", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "Змінити псевдоніми кімнати", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Змінити аватар кімнати", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "Пароль змінено", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Відновлення пароля", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "Люди", - "@people": { - "type": "text", - "placeholders": {} - }, - "pin": "Закріпити", - "@pin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "Введіть свій PIN-код", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "spaceName": "Назва простору", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "warning": "Попередження!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Ваш відкритий ключ", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "Простір загальнодоступний", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "status": "Статус", - "@status": { - "type": "text", - "placeholders": {} - }, - "unverified": "Неперевірений", - "@unverified": {}, - "locationDisabledNotice": "Служби визначення місцеположення вимкнені. Увімкніть їх, щоб могти надавати доступ до вашого місцеположення.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "locationPermissionDeniedNotice": "Дозвіл на розташування відхилено. Надайте можливість ділитися своїм місцеперебуванням.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "oneClientLoggedOut": "На одному з ваших клієнтів виконано вихід із системи", - "@oneClientLoggedOut": {}, - "bundleName": "Назва вузла", - "@bundleName": {}, - "toggleFavorite": "Перемикнути вибране", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "removeFromBundle": "Вилучити з цього вузла", - "@removeFromBundle": {}, - "toggleMuted": "Увімкнути/вимкнути звук", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "editBundlesForAccount": "Змінити вузол для цього облікового запису", - "@editBundlesForAccount": {}, - "addToBundle": "Додати до вузлів", - "@addToBundle": {}, - "repeatPassword": "Повторіть пароль", - "@repeatPassword": {}, - "messageInfo": "Відомості про повідомлення", - "@messageInfo": {}, - "time": "Час", - "@time": {}, - "messageType": "Тип повідомлення", - "@messageType": {}, - "openGallery": "Відкрити галерею", - "@openGallery": {}, - "sender": "Відправник", - "@sender": {}, - "addToSpaceDescription": "Виберіть простір, щоб додати до нього цю бесіду.", - "@addToSpaceDescription": {}, - "removeFromSpace": "Вилучити з простору", - "@removeFromSpace": {}, - "start": "Почати", - "@start": {}, - "commandHint_discardsession": "Відкинути сеанс", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_clearcache": "Очистити кеш", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "Створіть порожню групову бесіду\nВикористовуйте --no-encryption, щоб вимкнути шифрування", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_dm": "Початок особистої бесіди\nВикористовуйте --no-encryption, що вимкнути шифрування", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "openVideoCamera": "Відкрити камеру для відео", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "publish": "Опублікувати", - "@publish": {}, - "videoWithSize": "Відео ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "dismiss": "Відхилити", - "@dismiss": {}, - "markAsRead": "Позначити прочитаним", - "@markAsRead": {}, - "reportUser": "Поскаржився на користувача", - "@reportUser": {}, - "openChat": "Відкрити бесіду", - "@openChat": {}, - "reactedWith": "{sender} реагує з {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "emojis": "Емоджі", - "@emojis": {}, - "pinMessage": "Прикріпити в кімнаті", - "@pinMessage": {}, - "confirmEventUnpin": "Ви впевнені, що бажаєте назавжди відкріпите подію?", - "@confirmEventUnpin": {}, - "placeCall": "Здійснити виклик", - "@placeCall": {}, - "unsupportedAndroidVersion": "Непідтримувана версія Android", - "@unsupportedAndroidVersion": {}, - "voiceCall": "Голосовий виклик", - "@voiceCall": {}, - "unsupportedAndroidVersionLong": "Для цієї функції потрібна новіша версія Android. Перевірте наявність оновлень або підтримку Lineage OS.", - "@unsupportedAndroidVersionLong": {}, - "videoCallsBetaWarning": "Зауважте, що відеовиклики на ранньому етапі розробки. Вони можуть працювати не так, як очікувалося, або взагалі не працювати на всіх платформах.", - "@videoCallsBetaWarning": {}, - "emailOrUsername": "Електронна адреса або ім’я користувача", - "@emailOrUsername": {}, - "experimentalVideoCalls": "Експериментальні відеовиклики", - "@experimentalVideoCalls": {}, - "switchToAccount": "Перемкнутися на обліковий запис {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "Наступний обліковий запис", - "@nextAccount": {}, - "previousAccount": "Попередній обліковий запис", - "@previousAccount": {}, - "addWidget": "Додати віджет", - "@addWidget": {}, - "widgetVideo": "Відео", - "@widgetVideo": {}, - "widgetCustom": "Користувацький", - "@widgetCustom": {}, - "widgetName": "Назва", - "@widgetName": {}, - "widgetNameError": "Укажіть коротку назву.", - "@widgetNameError": {}, - "widgetEtherpad": "Текстова примітка", - "@widgetEtherpad": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetUrlError": "Це недійсна URL-адреса.", - "@widgetUrlError": {}, - "errorAddingWidget": "Помилка додавання віджета.", - "@errorAddingWidget": {}, - "separateChatTypes": "Розділіть особисті бесіди та групи", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youInvitedBy": "📩 Ви були запрошені {user}", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youAcceptedTheInvitation": "👍 Ви погодилися на запрошення", - "@youAcceptedTheInvitation": {}, - "youRejectedTheInvitation": "Ви відхилили запрошення", - "@youRejectedTheInvitation": {}, - "youHaveWithdrawnTheInvitationFor": "Ви відкликали запрошення для {user}", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youBannedUser": "Ви заблокували {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 Ви вилучили й заблокували {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "youJoinedTheChat": "Ви приєдналися до бесіди", - "@youJoinedTheChat": {}, - "youKicked": "👞 Ви вилучили {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "Ви розблокували {user}", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 Ви запросили {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "saveKeyManuallyDescription": "Збережіть цей ключ вручну, запустивши діалогове вікно спільного доступу до системи або буфер обміну.", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "Зберегти в Android KeyStore", - "@storeInAndroidKeystore": {}, - "storeInAppleKeyChain": "Зберегти в Apple KeyChain", - "@storeInAppleKeyChain": {}, - "storeSecurlyOnThisDevice": "Зберегти безпечно на цей пристрій", - "@storeSecurlyOnThisDevice": {}, - "pleaseEnterRecoveryKeyDescription": "Щоб розблокувати старі повідомлення, введіть ключ відновлення, згенерований у попередньому сеансі. Ваш ключ відновлення це НЕ ваш пароль.", - "@pleaseEnterRecoveryKeyDescription": {}, - "pleaseEnterRecoveryKey": "Введіть ключ відновлення:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKey": "Ключ відновлення", - "@recoveryKey": {}, - "recoveryKeyLost": "Ключ відновлення втрачено?", - "@recoveryKeyLost": {}, - "users": "Користувачі", - "@users": {}, - "unlockOldMessages": "Розблокувати старі повідомлення", - "@unlockOldMessages": {}, - "storeInSecureStorageDescription": "Збережіть ключ відновлення в безпечному сховищі цього пристрою.", - "@storeInSecureStorageDescription": {}, - "countFiles": "{count} файлів", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "hydrate": "Відновлення з файлу резервної копії", - "@hydrate": {}, - "hydrateTorLong": "Минулого разу ви експортували свій сеанс із TOR? Швидко імпортуйте його та продовжуйте спілкування.", - "@hydrateTorLong": {}, - "indexedDbErrorTitle": "Проблеми приватного режиму", - "@indexedDbErrorTitle": {}, - "indexedDbErrorLong": "На жаль, сховище повідомлень не ввімкнуто у приватному режимі типово.\nВідкрийте\n - about:config\n - установіть для dom.indexedDB.privateBrowsing.enabled значення true\nІнакше запустити FluffyChat буде неможливо.", - "@indexedDbErrorLong": {}, - "dehydrate": "Експортувати сеанс та очистити пристрій", - "@dehydrate": {}, - "dehydrateWarning": "Цю дію не можна скасувати. Переконайтеся, що ви безпечно зберігаєте файл резервної копії.", - "@dehydrateWarning": {}, - "dehydrateTor": "Користувачі TOR: експорт сеансу", - "@dehydrateTor": {}, - "dehydrateTorLong": "Для користувачів TOR рекомендується експортувати сеанс перед закриттям вікна.", - "@dehydrateTorLong": {}, - "hydrateTor": "Користувачі TOR: імпорт експортованого сеансу", - "@hydrateTor": {}, - "user": "Користувач", - "@user": {}, - "custom": "Користувацький", - "@custom": {}, - "supposedMxid": "Це має бути {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "confirmMatrixId": "Підтвердьте свій Matrix ID, щоб видалити свій обліковий запис.", - "@confirmMatrixId": {}, - "commandHint_markasgroup": "Позначити групою", - "@commandHint_markasgroup": {}, - "commandHint_markasdm": "Позначити кімнатою особистого спілкування для надання Matrix ID", - "@commandHint_markasdm": {}, - "whyIsThisMessageEncrypted": "Чому це повідомлення нечитабельне?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "Це може статися, якщо повідомлення було надіслано до того, як ви ввійшли у свій обліковий запис на цьому пристрої.\n\nТакож можливо, що відправник заблокував ваш пристрій або щось пішло не так з під'єднанням до інтернету.\n\nЧи можете ви прочитати повідомлення на іншому сеансі? Тоді ви зможете перенести повідомлення з нього! Перейдіть до Налаштування > Пристрої та переконайтеся, що ваші пристрої перевірили один одного. Коли ви відкриєте кімнату наступного разу й обидва сеанси будуть на активні, ключі будуть передані автоматично.\n\nВи ж не хочете втрачати ключі після виходу або зміни пристроїв? Переконайтеся, що ви ввімкнули резервне копіювання бесід у налаштуваннях.", - "@noKeyForThisMessage": {}, - "foregroundServiceRunning": "Це сповіщення з'являється під час роботи основної служби.", - "@foregroundServiceRunning": {}, - "screenSharingTitle": "спільний доступ до екрана", - "@screenSharingTitle": {}, - "callingPermissions": "Дозволи на виклик", - "@callingPermissions": {}, - "callingAccount": "Обліковий запис для виклику", - "@callingAccount": {}, - "callingAccountDetails": "Дозволяє FluffyChat використовувати основний застосунок Android для набору номера.", - "@callingAccountDetails": {}, - "appearOnTop": "З'являтися зверху", - "@appearOnTop": {}, - "appearOnTopDetails": "Дозволяє застосунку показуватися зверху (не потрібно, якщо Fluffychat вже налаштований обліковим записом для викликів)", - "@appearOnTopDetails": {}, - "newGroup": "Нова група", - "@newGroup": {}, - "newSpace": "Новий простір", - "@newSpace": {}, - "enterSpace": "Увійти в простір", - "@enterSpace": {}, - "enterRoom": "Увійти в кімнату", - "@enterRoom": {}, - "otherCallingPermissions": "Мікрофон, камера та інші дозволи FluffyChat", - "@otherCallingPermissions": {}, - "allSpaces": "Усі простори", - "@allSpaces": {}, - "screenSharingDetail": "Ви ділитеся своїм екраном FuffyChat", - "@screenSharingDetail": {}, - "numChats": "{number} бесід", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "Сховати неважливі державні свята", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "Не показувати знову", - "@doNotShowAgain": {}, - "commandHint_cuddle": "Надіслати пригортайку", - "@commandHint_cuddle": {}, - "googlyEyesContent": "{senderName} надсилає вам гугл-очі", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_googly": "Надіслати кілька гугл-очей", - "@commandHint_googly": {}, - "commandHint_hug": "Надіслати обійми", - "@commandHint_hug": {}, - "cuddleContent": "{senderName} пригортається до вас", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} обіймає вас", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "wasDirectChatDisplayName": "Порожня бесіда (раніше {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "startFirstChat": "Розпочніть свою першу бесіду", - "@startFirstChat": {}, - "newSpaceDescription": "Простори дозволяють об'єднувати ваші бесіди та створювати приватні або загальнодоступні спільноти.", - "@newSpaceDescription": {}, - "encryptThisChat": "Зашифрувати цю бесіду", - "@encryptThisChat": {}, - "disableEncryptionWarning": "З міркувань безпеки ви не можете вимкнути шифрування в бесіді, ув якій воно було ввімкнене раніше.", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "Вибачте... це неможливо", - "@sorryThatsNotPossible": {}, - "deviceKeys": "Ключі пристрою:", - "@deviceKeys": {}, - "reopenChat": "Відновити бесіду", - "@reopenChat": {}, - "noOtherDevicesFound": "Інших пристроїв не знайдено", - "@noOtherDevicesFound": {}, - "noBackupWarning": "Увага! Якщо ви не ввімкнете резервне копіювання бесіди, ви втратите доступ до своїх зашифрованих повідомлень. Наполегливо радимо ввімкнути резервне копіювання бесіди перед виходом.", - "@noBackupWarning": {}, - "fileIsTooBigForServer": "Сервер повідомляє, що файл завеликий для надсилання.", - "@fileIsTooBigForServer": {}, - "fileHasBeenSavedAt": "Файл збережено в {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "jumpToLastReadMessage": "Перейти до останнього прочитаного повідомлення", - "@jumpToLastReadMessage": {}, - "readUpToHere": "Читати тут", - "@readUpToHere": {}, - "jump": "Перейти", - "@jump": {}, - "openLinkInBrowser": "Відкрити посилання у браузері", - "@openLinkInBrowser": {}, - "allRooms": "Усі групові бесіди", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "reportErrorDescription": "О, ні. Щось пішло не так. Якщо хочете, можете повідомити про помилку розробникам.", - "@reportErrorDescription": {}, - "report": "повідомити", - "@report": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Спробуйте пізніше або виберіть інший сервер.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "signInWithPassword": "Увійти за допомогою пароля", - "@signInWithPassword": {}, - "signInWith": "Увійти через {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Не файл зображення.", - "@notAnImage": {}, - "importNow": "Імпортувати зараз", - "@importNow": {}, - "importEmojis": "Імпорт емодзі", - "@importEmojis": {}, - "importFromZipFile": "Імпорт з файлу .zip", - "@importFromZipFile": {}, - "replace": "Замінити", - "@replace": {}, - "exportEmotePack": "Експортувати набір смайликів у форматі .zip", - "@exportEmotePack": {}, - "sendTypingNotifications": "Надсилати сповіщення про ввід тексту", - "@sendTypingNotifications": {}, - "createGroup": "Створити групу", - "@createGroup": {}, - "inviteContactToGroupQuestion": "Хочете запросити {contact} до бесіди \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "messagesStyle": "Повідомлення:", - "@messagesStyle": {}, - "shareInviteLink": "Надіслати запрошувальне посилання", - "@shareInviteLink": {}, - "tryAgain": "Повторіть спробу", - "@tryAgain": {}, - "setTheme": "Налаштувати тему:", - "@setTheme": {}, - "setColorTheme": "Налаштувати колірну тему:", - "@setColorTheme": {}, - "addChatDescription": "Додати опис бесіди...", - "@addChatDescription": {}, - "chatPermissions": "Дозволи бесіди", - "@chatPermissions": {}, - "chatDescription": "Опис бесіди", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "Опис бесіди змінено", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "Опис бесіди ще не створено.", - "@noChatDescriptionYet": {}, - "invalidServerName": "Недійсна назва сервера", - "@invalidServerName": {}, - "optionalRedactReason": "(Необов'язково) Причина редагування цього повідомлення...", - "@optionalRedactReason": {}, - "redactedBy": "Відредаговано {username}", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "directChat": "Особисте повідомлення", - "@directChat": {}, - "redactedByBecause": "Відредаговано {username}, тому що: \"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "profileNotFound": "Не вдалося знайти користувача на сервері. Можливо, проблема зі з'єднанням або користувач не існує.", - "@profileNotFound": {}, - "invite": "Запросити", - "@invite": {}, - "redactMessageDescription": "Повідомлення буде відредаговано для всіх учасників цієї розмови. Це не можна скасувати.", - "@redactMessageDescription": {}, - "setChatDescription": "Налаштувати опис бесіди", - "@setChatDescription": {}, - "inviteGroupChat": "📨 Запросити до групової бесіди", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 Запросити до приватної бесіди", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "Тут з'являться нещодавно використані смайлики...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "invalidInput": "Недійсний ввід!", - "@invalidInput": {}, - "wrongPinEntered": "Введено неправильний PIN! Повторіть спробу за {seconds} секунд...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "banUserDescription": "Користувача буде заблоковано в бесіді, і він не зможе знову увійти в неї, поки його не буде розблоковано.", - "@banUserDescription": {}, - "removeDevicesDescription": "Ви вийдете з цього пристрою і більше не зможете отримувати повідомлення.", - "@removeDevicesDescription": {}, - "unbanUserDescription": "Користувач зможе знову увійти в бесіду, якщо спробує.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Push-сповіщення недоступні", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "Після того, як ви зробите цього користувача адміністратором, ви, можливо, не зможете це скасувати, оскільки він матиме ті самі права, що й ви.", - "@makeAdminDescription": {}, - "archiveRoomDescription": "Бесіду буде переміщено до архіву. Інші користувачі зможуть побачити, що ви вийшли з неї.", - "@archiveRoomDescription": {}, - "hasKnocked": "{user} стукає до вас", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "learnMore": "Докладніше", - "@learnMore": {}, - "roomUpgradeDescription": "Після цього бесіду буде відтворено з новою версією кімнати. Усі учасники отримають сповіщення, що їм потрібно перейти до нової бесіди. Ви можете дізнатися більше про версії кімнат на https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "pleaseEnterANumber": "Введіть число більше ніж 0", - "@pleaseEnterANumber": {}, - "kickUserDescription": "Користувача вигнали з бесіди, але не заблокували. До загальнодоступних бесід користувач може приєднатися будь-коли.", - "@kickUserDescription": {}, - "blockListDescription": "Ви можете заблокувати користувачів, які вас турбують. Ви не зможете отримувати жодних повідомлень або запрошень до кімнати від користувачів з вашого персонального списку блокування.", - "@blockListDescription": {}, - "createGroupAndInviteUsers": "Створити групу та запросити користувачів", - "@createGroupAndInviteUsers": {}, - "startConversation": "Розпочати розмову", - "@startConversation": {}, - "blockedUsers": "Заблоковані користувачі", - "@blockedUsers": {}, - "groupCanBeFoundViaSearch": "Групу можна знайти через пошук", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "На жаль, не знайдено жодного користувача з запитом \"{query}\".Перевірте, чи не було допущено помилки.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "block": "блокування", - "@block": {}, - "yourGlobalUserIdIs": "Ваш глобальний ID користувача: ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "Надіслати необроблений json", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "Вибачте... схоже, це неправильний ключ відновлення.", - "@wrongRecoveryKey": {}, - "blockUsername": "Ігнорувати ім'я користувача", - "@blockUsername": {}, - "groupName": "Назва групи", - "@groupName": {}, - "databaseMigrationTitle": "Базу даних оптимізовано", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "Пошук для #chats, @users...", - "@searchChatsRooms": {}, - "databaseMigrationBody": "Зачекайте, будь ласка. Це може тривати деякий час.", - "@databaseMigrationBody": {}, - "thisDevice": "Цей пристрій:", - "@thisDevice": {}, - "publicSpaces": "Загальнодоступний простір", - "@publicSpaces": {}, - "passwordIsWrong": "Введений пароль неправильний", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "Введіть поточний пароль", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "Загальнодоступне посилання", - "@publicLink": {}, - "nothingFound": "Нічого не знайдено...", - "@nothingFound": {}, - "decline": "Відхилити", - "@decline": {}, - "newPassword": "Новий пароль", - "@newPassword": {}, - "passwordsDoNotMatch": "Паролі відрізняються", - "@passwordsDoNotMatch": {}, - "subspace": "Підпростір", - "@subspace": {}, - "select": "Вибрати", - "@select": {}, - "pleaseChooseAStrongPassword": "Виберіть надійний пароль", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "Додати бесіду або підпростір", - "@addChatOrSubSpace": {}, - "leaveEmptyToClearStatus": "Лишіть порожнім, щоб оновити статус.", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "Приєднатися до простору", - "@joinSpace": {}, - "searchForUsers": "Пошук @користувачів...", - "@searchForUsers": {}, - "sessionLostBody": "Ваш сеанс втрачено. Будь ласка, повідомте про цю помилку розробникам за адресою {url}. Текст помилки: {error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "databaseBuildErrorBody": "Не вдалося створити базу даних SQlite. Застосунок намагається використовувати стару базу даних. Будь ласка, повідомте про цю помилку розробникам за адресою {url}. Текст помилки: {error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "Виникла помилка під час запуску застосунку", - "@initAppError": {}, - "restoreSessionBody": "Наразі застосунок намагається відновити ваш сеанс з резервної копії. Будь ласка, повідомте про цю помилку розробникам за адресою {url}. Текст помилки: {error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "youInvitedToBy": "📩 Вас запрошено за посиланням на:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "acceptedKeyVerification": "{sender} погоджується звірити ключі", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "canceledKeyVerification": "{sender} скасовує звірення ключів", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} просить звірити ключі", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "Прозорий", - "@transparent": {}, - "sendReadReceiptsDescription": "Інші учасники бесіди бачитимуть, що ви прочитали повідомлення.", - "@sendReadReceiptsDescription": {}, - "formattedMessages": "Форматовані повідомлення", - "@formattedMessages": {}, - "forwardMessageTo": "Переслати повідомлення до {roomName}?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendReadReceipts": "Надіслати підтвердження прочитання", - "@sendReadReceipts": {}, - "sendTypingNotificationsDescription": "Інші учасники бесіди бачитимуть, коли ви набираєте нове повідомлення.", - "@sendTypingNotificationsDescription": {}, - "formattedMessagesDescription": "Показувати розширений вміст повідомлень, наприклад, жирний текст, використовуючи markdown.", - "@formattedMessagesDescription": {}, - "verifyOtherUser": "🔐 Звірити іншого користувача", - "@verifyOtherUser": {}, - "verifyOtherUserDescription": "Якщо ви звіряєте іншого користувача, ви можете бути впевнені, що знаєте, кому ви насправді пишете. 💪\n\nКоли ви почнете звірення, ви та інший користувач побачите спливне вікно в застосунку. Там ви побачите набір смайликів або чисел, які вам потрібно буде порівняти між собою.\n\nНайкращий спосіб зробити це — зустрітися або розпочати відеовиклик. 👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "Коли ви звіряєте інший пристрій, ці пристрої можуть обмінюватися ключами, підвищуючи вашу загальну безпеку. 💪 Коли ви розпочнете звірення, в застосунку на обох пристроях з'явиться спливне вікно. Там ви побачите набір смайликів або чисел, які вам потрібно буде порівняти між собою. Найкраще мати обидва пристрої під рукою перед початком звірення. 🤳", - "@verifyOtherDeviceDescription": {}, - "verifyOtherDevice": "🔐 Звірити інший пристрій", - "@verifyOtherDevice": {}, - "completedKeyVerification": "{sender} завершує звірення ключів", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} готовий до звірення ключів", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} розпочинає звірення ключів", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "presenceStyle": "Присутність:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "presencesToggle": "Показувати повідомлення про стан від інших користувачів", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "hidePresences": "Сховати список станів?", - "@hidePresences": {}, - "incomingMessages": "Вхідні повідомлення", - "@incomingMessages": {}, - "discover": "Огляд", - "@discover": {}, - "stickers": "Наліпки", - "@stickers": {} -} diff --git a/assets/l10n/intl_vi.arb b/assets/l10n/intl_vi.arb deleted file mode 100644 index 0dc49651a..000000000 --- a/assets/l10n/intl_vi.arb +++ /dev/null @@ -1,633 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.781172", - "about": "Giới thiệu", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "Đồng ý", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "{username} đã đồng ý lời mời", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Tài khoản", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "{username} đã kích hoạt mã hóa đầu cuối 2 chiều", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "admin": "Quản trị viên", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "bí danh", - "@alias": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} đã trả lời cuộc gọi", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Mọi người đều có thể gia nhập", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "archive": "Lưu trữ", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Khách vãng lai có được tham gia không", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Bạn chắc chứ?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "blockDevice": "Thiết bị bị chặn", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "verified": "Đã xác thực", - "@verified": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "Chuyển từ thiết bị khác", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "showPassword": "Hiển thị mật khẩu", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Vui lòng làm theo hướng dẫn trên trang web và bấm tiếp", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "Bạn chỉ có thể kích hoạt mã hoá khi phòng này không mở", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "next": "Tiếp", - "@next": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Mọi thứ đã sẵn sàng!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Cài đặt biểu tượng cảm xúc", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "Sửa tên hiển thị", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Tải ảnh xuống", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Tên hiển thị đã được thay đổi", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "devices": "Các thiết bị", - "@devices": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Mã xác định thiết bị", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "device": "Thiết bị", - "@device": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "Xoá tin nhắn", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Xoá tài khoản", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "delete": "Xoá", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deactivateAccountWarning": "Việc này sẽ vô hiệu hoá tài khoản của bạn. Điều này không thể đảo ngược được! Bạn chắc là vẫn muốn tiếp tục chứ?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "dateWithYear": "{day}/{month}/{year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "dateWithoutYear": "{day}/{month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "currentlyActive": "Đang hoạt động", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "{username} đã tạo cuộc trò chuyện", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "create": "Tạo", - "@create": { - "type": "text", - "placeholders": {} - }, - "countParticipants": "{count} thành viên", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "couldNotDecryptMessage": "Không thể giải mã tin nhắn: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "copy": "Sao chép", - "@copy": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Liên hệ đã được mời vào nhóm", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "connect": "Kết nối", - "@connect": { - "type": "text", - "placeholders": {} - }, - "confirm": "Xác nhận", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "So sánh và đảm bảo các số sau đây giống trên máy còn lại", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "So sánh và đảm bảo các biểu tượng cảm xúc sau đây giống với các biểu tượng trên máy còn lại", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "close": "Đóng", - "@close": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Chọn một mật khẩu mạnh", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Chi tiết cuộc trò chuyện", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Bản sao lưu cuộc trò chuyện của bạn được bảo mật bằng một khoá bảo mật. Bạn đừng làm mất nó.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Sao lưu cuộc trò chuyện", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chat": "Chat", - "@chat": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Thay đổi tên nhóm", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Thay đổi máy chủ nhà", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changePassword": "Thay đổi mật khẩu", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changedTheRoomInvitationLink": "{username} đã thay đổi đường dẫn mời", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} đã đổi địa chỉ phòng chat", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheProfileAvatar": "{username} đã thay đổi ảnh đại diện của mình", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} đã thay đổi quy tắc truy cập đối với khách thành: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheGuestAccessRules": "{username} đã thay đổi quy tắc truy cập đối với khách", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatPermissions": "{username} đã thay đổi quyền trong phòng chat", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatNameTo": "{username} đã thay đổi tên phòng chat thành: '{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatDescriptionTo": "{username} đã thay đổi mô tả phòng chat thành: '{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatAvatar": "{username} đã thay đổi ảnh phòng chat", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changeDeviceName": "Thay đổi tên thiết bị", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "cancel": "Hủy", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "blocked": "Đã chặn", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} đã cấm {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "banned": "Đã bị cấm", - "@banned": { - "type": "text", - "placeholders": {} - }, - "banFromChat": "Cấm khỏi cuộc trò chuyện", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "badServerVersionsException": "Máy chủ nhà hỗ trợ Spec phiên bản:\n{serverVerions}\nNhưng ứng dụng này chỉ hỗ trợ {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerLoginTypesException": "Máy chủ nhà hỗ trợ kiểu đăng nhập:\n{serverVersions}\nNhưng ứng dụng này chỉ hỗ trợ:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "askVerificationRequest": "Bạn có đồng ý yêu cầu chứng thực từ {username} không?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "areYouSureYouWantToLogout": "Bạn có chắc bạn muốn đăng xuất không?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "addEmail": "Thêm email", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "notifications": "Thông báo", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "newGroup": "Nhóm mới", - "@newGroup": {}, - "pleaseEnterANumber": "Hãy nhập số lớn hơn 0", - "@pleaseEnterANumber": {}, - "newSpaceDescription": "Không gian cho phép bạn hợp nhất các cuộc trò chuyện của mình và xây dựng cộng đồng riêng tư hoặc công khai.", - "@newSpaceDescription": {}, - "disableEncryptionWarning": "Vì lý do bảo mật, bạn không thể tắt tính năng mã hóa trong cuộc trò chuyện đã được bật tính năng này trước đó.", - "@disableEncryptionWarning": {}, - "makeAdminDescription": "Khi bạn đặt người dùng này làm quản trị viên, bạn không thể hoàn tác việc này vì khi đó họ sẽ có quyền ngang bạn.", - "@makeAdminDescription": {}, - "setColorTheme": "Chọn màu giao diện:", - "@setColorTheme": {}, - "callingAccount": "Gọi tài khoản", - "@callingAccount": {}, - "openLinkInBrowser": "Mở đường dẫn trong trình duyệt", - "@openLinkInBrowser": {}, - "setTheme": "Chọn giao diện:", - "@setTheme": {}, - "invitePrivateChat": "📨 Mời trò chuyện riêng tư", - "@invitePrivateChat": {}, - "inviteGroupChat": "📨 Mời nhóm trò chuyện", - "@inviteGroupChat": {}, - "addToSpace": "Thêm vào không gian", - "@addToSpace": {}, - "importEmojis": "Nhập Biểu cảm", - "@importEmojis": {}, - "importFromZipFile": "Nhập vào từ tệp .zip", - "@importFromZipFile": {}, - "exportEmotePack": "Xuất gói biểu cảm bằng tệp .zip", - "@exportEmotePack": {}, - "hideUnimportantStateEvents": "Ẩn các sự kiện không quan trọng", - "@hideUnimportantStateEvents": {}, - "replace": "Thay thế", - "@replace": {}, - "addChatDescription": "Thêm mô tả hội thoại...", - "@addChatDescription": {}, - "report": "báo cáo", - "@report": {}, - "remove": "Loại bỏ", - "@remove": { - "type": "text", - "placeholders": {} - }, - "restricted": "Bị hạn chế", - "@restricted": {}, - "newSpace": "Không gian mới", - "@newSpace": {}, - "enterRoom": "Nhập phòng", - "@enterRoom": {}, - "signInWithPassword": "Đăng nhập với mật khẩu", - "@signInWithPassword": {}, - "all": "Tất cả", - "@all": { - "type": "text", - "placeholders": {} - }, - "appLock": "Khoá ứng dụng", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "allChats": "Tất cả hội thoại", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Nhập lại mật khẩu", - "@repeatPassword": {}, - "confirmMatrixId": "Hãy xác nhận Matrix ID để xoá tài khoản.", - "@confirmMatrixId": {}, - "supposedMxid": "Đây nên là {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "noBackupWarning": "Cẩn thận! Nếu không bật sao lưu trò chuyện, bạn sẽ mất quyền truy cập vào tin nhắn được mã hóa của mình. Chúng tôi khuyên bạn nên bật sao lưu trò chuyện trước khi đăng xuất.", - "@noBackupWarning": {}, - "doNotShowAgain": "Không hiện lại nữa", - "@doNotShowAgain": {}, - "wasDirectChatDisplayName": "Hội thoại trống (từng là {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "reportErrorDescription": "😭 Ôi. Có lỗi xảy ra. Bạn có thể báo cáo lỗi tới nhà phát triển nếu muốn.", - "@reportErrorDescription": {}, - "profileNotFound": "Không tìm thấy người dùng này tại máy chủ. Có thể do lỗi kết nối hoặc người dùng không tồn tại.", - "@profileNotFound": {}, - "banUserDescription": "Người dùng sẽ bị cấm khỏi cuộc trò chuyện và không thể tham gia lại cho tới khi được gỡ cấm.", - "@banUserDescription": {}, - "learnMore": "Tìm hiểu thêm", - "@learnMore": {}, - "incomingMessages": "Tin nhắn đến", - "@incomingMessages": {}, - "encryptThisChat": "Mã hóa cuộc trò chuyện này", - "@encryptThisChat": {}, - "noOtherDevicesFound": "Không tìm thấy thiết bị khác", - "@noOtherDevicesFound": {}, - "fileIsTooBigForServer": "Máy chủ báo cáo rằng tệp tin quá lớn để gửi.", - "@fileIsTooBigForServer": {}, - "signInWith": "Đăng nhập với {provider}", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "notAnImage": "Không phải tệp ảnh.", - "@notAnImage": {}, - "importNow": "Nhập vào", - "@importNow": {}, - "allSpaces": "Tất cả không gian", - "@allSpaces": {}, - "enterSpace": "Nhập không gian", - "@enterSpace": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "Hãy thử lại sau hoặc chọn 1 máy chủ khác.", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "jumpToLastReadMessage": "Đi tới tin nhắn đã đọc mới nhất", - "@jumpToLastReadMessage": {}, - "commandHint_ignore": "Phớt lờ matrix ID này", - "@commandHint_ignore": {}, - "appLockDescription": "Khoá ứng dụng khi không dùng bằng mã pin", - "@appLockDescription": {}, - "notifyMeFor": "Bật thông báo cho", - "@notifyMeFor": {}, - "settings": "Cài đặt", - "@settings": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "Gửi nhãn dán", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "fileHasBeenSavedAt": "Tệp đã được lưu tại {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "readUpToHere": "Đọc tới đây", - "@readUpToHere": {}, - "jump": "Đi tới", - "@jump": {}, - "callingPermissions": "Quyền gọi điện", - "@callingPermissions": {}, - "numChats": "{number} cuộc hội thoại", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hidePresences": "Ẩn danh sách trạng thái?", - "@hidePresences": {}, - "sorryThatsNotPossible": "Xin lỗi... không khả dụng", - "@sorryThatsNotPossible": {}, - "reopenChat": "Mở lại cuộc trò chuyện", - "@reopenChat": {}, - "wrongPinEntered": "Nhập sai mã pin! Thử lại sau {seconds} giây...", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "archiveRoomDescription": "Cuộc trò chuyện sẽ được chuyển tới mục lưu trữ. Người dùng khác sẽ thấy được bạn đã rời khỏi cuộc trò chuyện.", - "@archiveRoomDescription": {}, - "kickUserDescription": "Người dùng bị đuổi khỏi cuộc trò chuyện nhưng không bị cấm. Trong các cuộc trò chuyện công khai, người dùng có thể vào lại bất cứ lúc nào.", - "@kickUserDescription": {}, - "unbanUserDescription": "Người dùng sẽ có thể vào lại cuộc trò chuyện nếu họ thử.", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "Thông báo đẩy không khả dụng", - "@pushNotificationsNotAvailable": {}, - "invite": "Mời", - "@invite": {}, - "invalidInput": "Dữ liệu nhập không hợp lệ!", - "@invalidInput": {}, - "removeDevicesDescription": "Bạn sẽ đăng xuất khỏi thiết bị này và không nhận được tin nhắn nữa.", - "@removeDevicesDescription": {}, - "noUsersFoundWithQuery": "Không tìm thấy người dùng nào với \"{query}\". Hãy kiểm tra xem bạn có nhập nhầm không.", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "commandHint_unignore": "Bỏ phớt lờ matrix ID này", - "@commandHint_unignore": {}, - "discover": "Khám phá", - "@discover": {}, - "stickers": "Nhãn dán", - "@stickers": {}, - "roomUpgradeDescription": "Cuộc trò chuyện sẽ được tạo lại với phiên bản phòng mới. Tất cả những người tham gia sẽ được thông báo rằng họ cần chuyển sang cuộc trò chuyện mới. Bạn có thể tìm hiểu thêm về các phiên bản phòng tại https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {} -} diff --git a/assets/l10n/intl_zh.arb b/assets/l10n/intl_zh.arb deleted file mode 100644 index 8ca5e3153..000000000 --- a/assets/l10n/intl_zh.arb +++ /dev/null @@ -1,2712 +0,0 @@ -{ - "@@locale": "zh", - "@@last_modified": "2021-08-14 12:41:09.767805", - "about": "关于", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "接受", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍 {username} 接受了邀请", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "账户", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐 {username} 激活了端到端加密", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "添加电子邮件", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "管理员", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "别名", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "全部", - "@all": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} 接听了通话", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "任何人都可以加入", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "应用锁", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "存档", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "是否允许访客加入", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "你确定吗?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "你确定要注销吗?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "请输入你的安全存储的密码短语或恢复密钥,以向对方签名。", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "是否接受来自 {username} 的验证请求?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerLoginTypesException": "主服务器支持的登录方式:\n{serverVersions}\n但此应用仅支持:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "主服务器支持的 Spec 版本:\n{serverVersions}\n但此应用仅支持 {supportedVersions} 版本", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "从聊天中封禁", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "已封禁", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} 封禁了 {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "屏蔽设备", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "已屏蔽", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "机器人消息", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "取消", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "更改设备名称", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} 更改了聊天头像", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} 将聊天描述更改为:'{description}'", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} 将聊天名称更改为:'{chatname}'", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} 更改了聊天权限", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} 将昵称更改为:'{displayname}'", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} 更改了访客访问规则", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} 更改了访客访问规则为:{rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} 更改了历史记录可见性", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} 更改了历史记录可见性为:{rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} 更改了加入的规则", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} 更改了加入的规则为:{joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} 更改了头像", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} 更改了聊天室别名", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} 更改了邀请链接", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "更改密码", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "更改主服务器", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "改变风格", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "更改群组名称", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "changeYourAvatar": "更改你的头像", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "加密已被破坏", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "聊天", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "聊天记录备份", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "你的旧消息受恢复密钥保护。请确保你不会丢失它。", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "聊天详情", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chats": "聊天", - "@chats": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "输入一个强密码", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "clearArchive": "清除存档", - "@clearArchive": {}, - "close": "关闭", - "@close": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "在此聊天室封禁指定用户", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_html": "发送 HTML 格式化文本", - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "commandHint_invite": "邀请指定用户加入此聊天室", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "加入指定聊天室", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "在此聊天室移除指定用户", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "退出此聊天室", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_me": "介绍自己", - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "commandHint_myroomavatar": "设置你在此聊天室的头像(通过 mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_myroomnick": "设置你在此聊天室的昵称", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "commandHint_op": "设置指定用户的权限等级(默认:50)", - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "commandHint_plain": "发送纯文本", - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "commandHint_react": "将回复作为回应发送", - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "commandHint_send": "发送文本", - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "commandHint_unban": "在此聊天室解封指定用户", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "commandInvalid": "指令无效", - "@commandInvalid": { - "type": "text" - }, - "commandMissing": "{command} 不是指令。", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "compareEmojiMatch": "请比较表情符号", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "请比较以下数字", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "配置聊天", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "确认", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "连接", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "联系人已被邀请至群组", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "包含昵称", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "包含用户名", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "此内容已被报告至服务器管理员处", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "已复制到剪贴板", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "复制", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "复制到剪贴板", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "不能解密消息: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} 名参与者", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "创建", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "💬 {username} 创建了聊天", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "目前活跃", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "深色", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{year}-{month}-{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "这将停用你的用户账户。这不能被撤销!你确定吗?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "默认权限级别", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "删除", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "删除账户", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "删除消息", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "设备", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "设备 ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "设备", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "私聊", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "昵称已更改", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "下载文件", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "编辑", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "编辑被屏蔽的服务器", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "编辑昵称", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAliases": "编辑聊天室别名", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "编辑聊天室头像", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "表情已存在!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "无效的表情快捷码!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "聊天室的表情包", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "表情设置", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "表情快捷码", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "你需要选择一个表情快捷码和一张图片!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "空聊天", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "在全局启用表情包", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "启用加密", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "你之后将无法停用加密,确定吗?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "已加密", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "加密", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "加密未启用", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} 结束了通话", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "输入一个电子邮件地址", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "输入你的主服务器地址", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "一切就绪!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "令人极度反感", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "文件名", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "字体大小", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "转发", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "自加入起", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "自邀请起", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "goToTheNewRoom": "前往新的聊天室", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "group": "群组", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "群组是公开的", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "群组", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "名称为 {displayname} 的群组", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "访客禁止加入", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "访客可以加入", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} 撤回了对 {targetName} 的邀请", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "帮助", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "隐藏已删除的事件", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "隐藏未知的事件", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "这些内容有多令人反感?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "身份", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "忽略", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "已忽略的用户", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "我已经点击了链接", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "不正确的密码短语或恢复密钥", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "不令人反感", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "邀请联系人", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "邀请联系人到 {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "已邀请", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "📩 {username} 邀请了 {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "仅被邀请用户", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "发给我的邀请", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} 邀请你使用 FluffyChat。 \n1. 安装 FluffyChat:https://fluffychat.im \n2. 注册或登录 \n3. 打开邀请链接:\n {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "正在输入…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "👋 {username} 加入了聊天", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "加入聊天室", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "👞 {username} 踢出了 {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "🙅 {username} 踢出并封禁了 {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "从聊天室踢出", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "上次活跃: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "离开", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "离开了聊天", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "许可证", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "浅色", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "加载 {count} 个更多的参与者", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "加载中…请等待。", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "加载更多…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "登录", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "登录 {homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "注销", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "成员变更", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "提及", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "消息", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "协管员", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "静音聊天", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "请注意当前你需要 Pantalaimon 以使用端到端加密功能。", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "新的聊天", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "💬 FluffyChat 新消息", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "新的验证请求!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "下一步", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "否", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "无法连接服务器", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "未找到表情。😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "你只能在聊天室不可被公众访问时才能启用加密。", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "看起来你手机上没有 Firebase Cloud Messaging。如果仍希望接收 FluffyChat 的推送通知,推荐安装 ntfy。借助 ntfy 或另一个 Unified Push 程序,你可以以一种数据安全的方式接收推送通知。你可以从 PlayStore 或 F-Droid 商店下载 ntfy。", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "无", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "你尚未添加恢复密码的方法。", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "没有权限", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "未找到聊天室…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "通知", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "已为此账户启用通知", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} 人正在输入…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "offensive": "令人反感", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "离线", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "好", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "在线", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "在线密钥备份已启用", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsPushError": "哎呀!十分不幸,配置推送通知时发生了错误。", - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "哎呀,出了点差错…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "打开应用以查看消息", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "打开相机", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "or": "或", - "@or": { - "type": "text", - "placeholders": {} - }, - "participant": "参与者", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "密码短语或恢复密钥", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "密码", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "忘记密码", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "密码已被更改", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "密码恢复", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "people": "联系人", - "@people": { - "type": "text", - "placeholders": {} - }, - "pickImage": "选择图像", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "置顶", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "播放 {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChoose": "请选择", - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "pleaseChooseAPasscode": "请选择一个密码", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "请点击电子邮件中的链接,然后继续。", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "请输入 4 位数字或留空以停用应用锁。", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "请输入你的密码", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPin": "请输入你的 PIN", - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "请输入你的用户名", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "请按照网站上的提示,点击下一步。", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "隐私", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "公开聊天室", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "推送规则", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "原因", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "录制", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} 删除了一个事件", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "删除消息", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "register": "注册", - "@register": { - "type": "text", - "placeholders": {} - }, - "reject": "拒绝", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} 拒绝了邀请", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "重新加入", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "移除", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "移除所有其它设备", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "被 {username} 移除", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "移除设备", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "从聊天中解封", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "removeYourAvatar": "移除你的头像", - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "渲染富文本内容", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "更新聊天室至新版本", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "回复", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "举报信息", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "请求权限", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "聊天室已升级", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "聊天室版本", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "saveFile": "保存文件", - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "search": "搜索", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "安全", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "被 {username} 看见", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "发送", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "发送一条消息", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAsText": "以文本发送", - "@sendAsText": { - "type": "text" - }, - "sendAudio": "发送音频", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "发送文件", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "发送图像", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "发送消息", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "发送原图", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendSticker": "发送贴纸", - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "发送视频", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "📁{username} 发送了文件", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "🎤{username} 发送了音频", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "🖼️ {username} 发送了图片", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "😊 {username} 发送了贴纸", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "🎥 {username} 发送了视频", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} 发送了通话信息", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setAsCanonicalAlias": "设为主要别名", - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "setCustomEmotes": "设置自定义表情", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "设置邀请链接", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "设置权限级别", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "设置状态", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "设置", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "分享", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} 分享了位置", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "showPassword": "显示密码", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "singlesignon": "单点登录", - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "skip": "跳过", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "源代码", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} 开始了通话", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "状态", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "你今天怎么样?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "提交", - "@submit": { - "type": "text", - "placeholders": {} - }, - "synchronizingPleaseWait": "同步中…请等待。", - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "系统", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "它们不匹配", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "它们匹配", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "切换收藏", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "切换静音", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "标记已读/未读", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "请求过多。请稍后再试!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "从其它设备传输", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "尝试重新发送", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "不可用", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username} 解封了 {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "解除屏蔽设备", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "未知设备", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "未知加密算法", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "未知事件 '{type}'", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "取消静音聊天", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "取消置顶", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 个未读聊天} other{{unreadCount} 个未读聊天}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} 和其他 {count} 人正在输入…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} 和 {username2} 正在输入…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} 正在输入…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "🚪{username} 离开了聊天", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "用户名", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} 发送了一个 {type} 事件", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "已验证", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "验证", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "开始验证", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "你已成功验证!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "验证其它账户", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "视频通话", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "聊天记录的可见性", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "对所有参与者可见", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "对所有人可见", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "语音消息", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "等待对方接受请求…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "等待对方接受 emoji…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "等待对方接受数字…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "壁纸:", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "警告!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "我们向你发送了一封电子邮件", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "谁可以执行哪些操作", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "谁可以加入此群组", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "你举报的理由是什么?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "确定要清除你的聊天记录备份以创建新的恢复密钥吗?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "通过这些地址,你可以恢复密码。", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "写一条消息…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "是", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "你", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "你已不再参与此聊天", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "你已被此聊天封禁", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "你的公钥", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "allChats": "所有聊天", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "添加到空间", - "@addToSpace": {}, - "obtainingLocation": "获取位置中…", - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "noMatrixServer": "{server1} 不是一个 Matrix 服务器,试试 {server2}?", - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "locationPermissionDeniedNotice": "位置权限被拒绝。请授予此权限以分享你的位置.", - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "locationDisabledNotice": "位置服务已禁用。请启用此服务以分享你的位置.", - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "errorObtainingLocation": "取得地址错误: {error}", - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "createNewSpace": "创建新空间", - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "无法打开 URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "autoplayImages": "自动播放动态贴纸和表情", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "spaceName": "空间名称", - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "spaceIsPublic": "空间是公开的", - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "shareLocation": "分享位置", - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "openInMaps": "在地图中打开", - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "sendOnEnter": "按 Enter 键发送", - "@sendOnEnter": {}, - "yourChatBackupHasBeenSetUp": "你的聊天记录备份已设置。", - "@yourChatBackupHasBeenSetUp": {}, - "scanQrCode": "扫描二维码", - "@scanQrCode": {}, - "chatHasBeenAddedToThisSpace": "聊天已添加到此空间", - "@chatHasBeenAddedToThisSpace": {}, - "homeserver": "服务器", - "@homeserver": {}, - "oneClientLoggedOut": "你的一个客户端已登出", - "@oneClientLoggedOut": {}, - "removeFromBundle": "从此集合中移除", - "@removeFromBundle": {}, - "unverified": "未经验证", - "@unverified": {}, - "repeatPassword": "重复输入密码", - "@repeatPassword": {}, - "addAccount": "添加账户", - "@addAccount": {}, - "editBundlesForAccount": "编辑此账户的集合", - "@editBundlesForAccount": {}, - "enableMultiAccounts": "(测试功能)在此设备上添加多个账户", - "@enableMultiAccounts": {}, - "addToBundle": "添加到集合", - "@addToBundle": {}, - "bundleName": "集合名称", - "@bundleName": {}, - "link": "链接", - "@link": {}, - "serverRequiresEmail": "此服务器需要验证你的电子邮件地址以进行注册。", - "@serverRequiresEmail": {}, - "messageType": "消息类型", - "@messageType": {}, - "sender": "发送者", - "@sender": {}, - "openGallery": "打开图库", - "@openGallery": {}, - "messageInfo": "消息信息", - "@messageInfo": {}, - "time": "时间", - "@time": {}, - "addToSpaceDescription": "选择一个空间以添加此聊天。", - "@addToSpaceDescription": {}, - "removeFromSpace": "从此空间中移除", - "@removeFromSpace": {}, - "start": "开始", - "@start": {}, - "commandHint_discardsession": "丢弃会话", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "创建私聊\n使用 --no-encryption 选项来禁用加密", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_clearcache": "清除缓存", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "创建空的群聊\n使用 --no-encryption 选项来禁用加密", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "openVideoCamera": "打开相机拍摄视频", - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "publish": "发布", - "@publish": {}, - "videoWithSize": "视频 ({size})", - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "dismiss": "忽略", - "@dismiss": {}, - "markAsRead": "标为已读", - "@markAsRead": {}, - "reportUser": "举报用户", - "@reportUser": {}, - "openChat": "打开聊天", - "@openChat": {}, - "reactedWith": "{sender} 回应了 {reaction}", - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "confirmEventUnpin": "你确定要永久性取消置顶此事件吗?", - "@confirmEventUnpin": {}, - "pinMessage": "置顶到聊天室", - "@pinMessage": {}, - "emojis": "表情符号", - "@emojis": {}, - "unsupportedAndroidVersionLong": "这个功能需要较新版本的 Android 系统。请检查更新或 Lineage OS 支持。", - "@unsupportedAndroidVersionLong": {}, - "unsupportedAndroidVersion": "不受支持的 Android 版本", - "@unsupportedAndroidVersion": {}, - "voiceCall": "语音通话", - "@voiceCall": {}, - "placeCall": "发起通话", - "@placeCall": {}, - "videoCallsBetaWarning": "请注意,视频通话目前处于测试阶段。它们可能不能像预期的那样工作,或者在所有平台上都不能工作。", - "@videoCallsBetaWarning": {}, - "experimentalVideoCalls": "实验性的视频通话", - "@experimentalVideoCalls": {}, - "emailOrUsername": "电子邮箱或用户名", - "@emailOrUsername": {}, - "switchToAccount": "切换到账户 {number}", - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "nextAccount": "下个账户", - "@nextAccount": {}, - "previousAccount": "上个账户", - "@previousAccount": {}, - "widgetVideo": "视频", - "@widgetVideo": {}, - "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, - "widgetCustom": "自定义", - "@widgetCustom": {}, - "widgetNameError": "请提供昵称。", - "@widgetNameError": {}, - "errorAddingWidget": "添加小部件出错。", - "@errorAddingWidget": {}, - "addWidget": "添加小部件", - "@addWidget": {}, - "widgetEtherpad": "文本笔记", - "@widgetEtherpad": {}, - "widgetName": "名称", - "@widgetName": {}, - "widgetUrlError": "这不是有效的 URL。", - "@widgetUrlError": {}, - "separateChatTypes": "分开私聊和群组", - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "youRejectedTheInvitation": "你拒绝了邀请", - "@youRejectedTheInvitation": {}, - "youJoinedTheChat": "你加入了聊天", - "@youJoinedTheChat": {}, - "youBannedUser": "你封禁了 {user}", - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "youInvitedBy": "📩 你受到了 {user} 的邀请", - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "youInvitedUser": "📩 你邀请了 {user}", - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "youKicked": "👞 你踢出了 {user}", - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "youUnbannedUser": "你解除了对 {user} 的封禁", - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "youAcceptedTheInvitation": "👍 你接受了邀请", - "@youAcceptedTheInvitation": {}, - "youHaveWithdrawnTheInvitationFor": "你撤回了对 {user} 的邀请", - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "youKickedAndBanned": "🙅 你踢出并封禁了 {user}", - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "storeInSecureStorageDescription": "将恢复密钥存储在此设备的安全存储中。", - "@storeInSecureStorageDescription": {}, - "storeInAppleKeyChain": "存储在 Apple KeyChain 中", - "@storeInAppleKeyChain": {}, - "unlockOldMessages": "解锁旧消息", - "@unlockOldMessages": {}, - "pleaseEnterRecoveryKey": "请输入你的恢复密钥:", - "@pleaseEnterRecoveryKey": {}, - "recoveryKey": "恢复密钥", - "@recoveryKey": {}, - "recoveryKeyLost": "丢失了恢复密钥?", - "@recoveryKeyLost": {}, - "pleaseEnterRecoveryKeyDescription": "要解锁你的旧邮件,请输入你在之前会话中生成的恢复密钥。 你的恢复密钥不是你的密码。", - "@pleaseEnterRecoveryKeyDescription": {}, - "saveKeyManuallyDescription": "通过触发系统共享对话框或剪贴板手动保存此密钥。", - "@saveKeyManuallyDescription": {}, - "storeInAndroidKeystore": "存储在 Android KeyStore 中", - "@storeInAndroidKeystore": {}, - "storeSecurlyOnThisDevice": "安全地存储在此设备上", - "@storeSecurlyOnThisDevice": {}, - "users": "用户", - "@users": {}, - "countFiles": "{count} 个文件", - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "dehydrateTor": "TOR 用户:导出会话", - "@dehydrateTor": {}, - "dehydrateTorLong": "建议 TOR 用户在关闭窗口之前导出会话。", - "@dehydrateTorLong": {}, - "hydrateTor": "TOR 用户:导入会话导出", - "@hydrateTor": {}, - "hydrate": "从备份文件恢复", - "@hydrate": {}, - "dehydrate": "导出会话并擦除设备", - "@dehydrate": {}, - "dehydrateWarning": "此操作无法撤消。 确保你安全地存储备份文件。", - "@dehydrateWarning": {}, - "indexedDbErrorTitle": "私有模式问题", - "@indexedDbErrorTitle": {}, - "indexedDbErrorLong": "遗憾的是,默认情况下未在私有模式下启用消息存储。\n请访问\n - about:config\n - 将 dom.indexedDB.privateBrowsing.enabled 设置为 true\n否则,无法运行 FluffyChat。", - "@indexedDbErrorLong": {}, - "hydrateTorLong": "你上次是否导出 TOR 会话? 快速导入它并继续聊天。", - "@hydrateTorLong": {}, - "user": "用户", - "@user": {}, - "custom": "自定义", - "@custom": {}, - "confirmMatrixId": "请确认你的 Matrix ID 以删除账户。", - "@confirmMatrixId": {}, - "supposedMxid": "应为 {mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "commandHint_markasgroup": "标记为群组", - "@commandHint_markasgroup": {}, - "commandHint_markasdm": "将给定的 Matrix ID 标为私信聊天室", - "@commandHint_markasdm": {}, - "whyIsThisMessageEncrypted": "为什么此消息不可读?", - "@whyIsThisMessageEncrypted": {}, - "noKeyForThisMessage": "如果消息是在你在此设备上登录账户前发送的,就可能发生这种情况。\n\n也有可能是发送者屏蔽了你的设备或网络连接出了问题。\n\n你能在另一个会话中读取消息吗?如果是的话,你可以从它那里传递信息!点击设置 > 设备,并确保你的设备已经相互验证。当你下次打开聊天室,且两个会话都在前台,密钥就会自动传输。\n\n你不想在注销或切换设备时丢失密钥?请确保在设置中启用了聊天备份。", - "@noKeyForThisMessage": {}, - "newGroup": "新群组", - "@newGroup": {}, - "newSpace": "新的空间", - "@newSpace": {}, - "enterSpace": "进入空间", - "@enterSpace": {}, - "enterRoom": "进入聊天室", - "@enterRoom": {}, - "allSpaces": "所有空间", - "@allSpaces": {}, - "appearOnTop": "显示在其它应用上方", - "@appearOnTop": {}, - "appearOnTopDetails": "允许应用显示在顶部(如果你已经将 Fluffychat 设置为呼叫账户,则不需要授予此权限)", - "@appearOnTopDetails": {}, - "otherCallingPermissions": "麦克风、摄像头和其它 FluffyChat 权限", - "@otherCallingPermissions": {}, - "callingPermissions": "呼叫权限", - "@callingPermissions": {}, - "callingAccountDetails": "允许 FluffyChat 使用本机 android 拨号器应用。", - "@callingAccountDetails": {}, - "foregroundServiceRunning": "此通知在前台服务运行时出现。", - "@foregroundServiceRunning": {}, - "screenSharingTitle": "屏幕共享", - "@screenSharingTitle": {}, - "callingAccount": "呼叫账户", - "@callingAccount": {}, - "screenSharingDetail": "你正在 FluffyChat 中共享屏幕", - "@screenSharingDetail": {}, - "numChats": "{number} 个聊天", - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "hideUnimportantStateEvents": "隐藏不重要的状态事件", - "@hideUnimportantStateEvents": {}, - "doNotShowAgain": "不再显示", - "@doNotShowAgain": {}, - "googlyEyesContent": "{senderName} 向你发送了“大眼”表情", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "commandHint_googly": "发送“大眼”表情", - "@commandHint_googly": {}, - "commandHint_cuddle": "发送“搂抱”", - "@commandHint_cuddle": {}, - "commandHint_hug": "发送“拥抱”", - "@commandHint_hug": {}, - "cuddleContent": "{senderName} 搂抱了你", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "hugContent": "{senderName} 拥抱了你", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "wasDirectChatDisplayName": "空聊天(曾是 {oldDisplayName})", - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "startFirstChat": "发起你的第一个聊天", - "@startFirstChat": {}, - "newSpaceDescription": "空间让你可以整合聊天并建立私人或公共社区。", - "@newSpaceDescription": {}, - "encryptThisChat": "加密此聊天", - "@encryptThisChat": {}, - "disableEncryptionWarning": "出于安全考虑 ,你不能在之前已启用加密的聊天中禁用加密。", - "@disableEncryptionWarning": {}, - "sorryThatsNotPossible": "非常抱歉……这是做不到的", - "@sorryThatsNotPossible": {}, - "deviceKeys": "设备密钥:", - "@deviceKeys": {}, - "report": "举报", - "@report": {}, - "fileIsTooBigForServer": "服务器报告文件过大,无法发送。", - "@fileIsTooBigForServer": {}, - "noOtherDevicesFound": "未找到其它设备", - "@noOtherDevicesFound": {}, - "jumpToLastReadMessage": "跳转到上次已读的消息", - "@jumpToLastReadMessage": {}, - "readUpToHere": "读到此处", - "@readUpToHere": {}, - "jump": "跳转", - "@jump": {}, - "openLinkInBrowser": "在浏览器中打开链接", - "@openLinkInBrowser": {}, - "signInWith": "使用 {provider} 登录", - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "allRooms": "所有群聊", - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "fileHasBeenSavedAt": "文件已保存在 {path}", - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "reportErrorDescription": "😭 哦不。出了点差错。如果你愿意,可以向开发人员报告此错误。", - "@reportErrorDescription": {}, - "noBackupWarning": "警告!如果不启用聊天备份,你将无法访问加密消息。强烈建议在注销前先启用聊天备份。", - "@noBackupWarning": {}, - "signInWithPassword": "使用密码登录", - "@signInWithPassword": {}, - "pleaseTryAgainLaterOrChooseDifferentServer": "请稍后再试或选择其它服务器。", - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "reopenChat": "重新打开聊天", - "@reopenChat": {}, - "importEmojis": "导入表情包", - "@importEmojis": {}, - "notAnImage": "不是图像文件。", - "@notAnImage": {}, - "importNow": "立即导入", - "@importNow": {}, - "importFromZipFile": "从 .zip 文件导入", - "@importFromZipFile": {}, - "replace": "替换", - "@replace": {}, - "exportEmotePack": "以 .zip 格式导出表情包", - "@exportEmotePack": {}, - "sendTypingNotifications": "发送正在输入通知", - "@sendTypingNotifications": {}, - "createGroup": "创建群组", - "@createGroup": {}, - "shareInviteLink": "分享邀请链接", - "@shareInviteLink": {}, - "profileNotFound": "服务器上找不到此用户。可能是连接有问题或者用户不存在。", - "@profileNotFound": {}, - "inviteContactToGroupQuestion": "你是否要邀请 {contact} 参与聊天 \"{groupName}\"?", - "@inviteContactToGroupQuestion": {}, - "tryAgain": "重试", - "@tryAgain": {}, - "addChatDescription": "添加聊天说明…", - "@addChatDescription": {}, - "chatPermissions": "聊天权限", - "@chatPermissions": {}, - "chatDescription": "聊天描述", - "@chatDescription": {}, - "chatDescriptionHasBeenChanged": "聊天描述已被更改", - "@chatDescriptionHasBeenChanged": {}, - "noChatDescriptionYet": "尚未创建聊天描述。", - "@noChatDescriptionYet": {}, - "invalidServerName": "服务器名称无效", - "@invalidServerName": {}, - "redactMessageDescription": "消息将为此对话中所有参与者删除。此操作无法撤销。", - "@redactMessageDescription": {}, - "optionalRedactReason": "(可选)删除此消息的原因...", - "@optionalRedactReason": {}, - "setChatDescription": "设置聊天描述", - "@setChatDescription": {}, - "setTheme": "设置主题:", - "@setTheme": {}, - "setColorTheme": "设置颜色主题:", - "@setColorTheme": {}, - "invite": "邀请", - "@invite": {}, - "messagesStyle": "消息:", - "@messagesStyle": {}, - "redactedBy": "已被 {username} 删除", - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "directChat": "私聊", - "@directChat": {}, - "redactedByBecause": "已被 {username} 删除,原因:\"{reason}\"", - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "inviteGroupChat": "📨 邀请至群聊", - "@inviteGroupChat": {}, - "invitePrivateChat": "📨 邀请至私聊", - "@invitePrivateChat": {}, - "emoteKeyboardNoRecents": "最近使用过的表情会出现在这里...", - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "invalidInput": "无效的输入!", - "@invalidInput": {}, - "wrongPinEntered": "输入的 PIN 码不正确!请 {seconds} 秒后重试…", - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "hasKnocked": "{user} 请求了加入聊天室的邀请", - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "pleaseEnterANumber": "请输入大于 0 的数", - "@pleaseEnterANumber": {}, - "banUserDescription": "该用户将被禁止进入聊天室,在解除封禁之前将不能再进入聊天室。", - "@banUserDescription": {}, - "removeDevicesDescription": "你将注销此设备,无法再接收消息。", - "@removeDevicesDescription": {}, - "unbanUserDescription": "如果用户尝试加入则可以再次进入聊天。", - "@unbanUserDescription": {}, - "pushNotificationsNotAvailable": "推送通知不可用", - "@pushNotificationsNotAvailable": {}, - "makeAdminDescription": "一旦你将该用户设为管理员,你可能无法撤销,因为他们将拥有与你相同的权限。", - "@makeAdminDescription": {}, - "archiveRoomDescription": "聊天将被移至存档。其他用户将能看到你已离开聊天。", - "@archiveRoomDescription": {}, - "learnMore": "了解更多", - "@learnMore": {}, - "roomUpgradeDescription": "聊天之后将以新的聊天室版本重新创建。所有参与者都会收到通知以切换到新的聊天室。有关聊天室版本的更多信息,请访问 https://spec.matrix.org/latest/rooms/", - "@roomUpgradeDescription": {}, - "kickUserDescription": "该用户会被踢出聊天但未被封禁。在公开聊天中,该用户可以随时重新加入。", - "@kickUserDescription": {}, - "blockListDescription": "你可以屏蔽打扰你的用户。你将不会收到来自屏蔽列表中用户的任何消息或聊天室邀请。", - "@blockListDescription": {}, - "createGroupAndInviteUsers": "创建群组并邀请用户", - "@createGroupAndInviteUsers": {}, - "startConversation": "开始对话", - "@startConversation": {}, - "blockedUsers": "已屏蔽的用户", - "@blockedUsers": {}, - "groupCanBeFoundViaSearch": "可通过搜索找到该群组", - "@groupCanBeFoundViaSearch": {}, - "noUsersFoundWithQuery": "很遗憾,没有找到有关\"{query}\"的用户。请检查是否有错别字。", - "@noUsersFoundWithQuery": { - "type": "text", - "placeholders": { - "query": {} - } - }, - "block": "屏蔽", - "@block": {}, - "yourGlobalUserIdIs": "你的全局用户 ID 是: ", - "@yourGlobalUserIdIs": {}, - "commandHint_sendraw": "发送原始 json", - "@commandHint_sendraw": {}, - "wrongRecoveryKey": "抱歉…这似乎不是正确的恢复密钥。", - "@wrongRecoveryKey": {}, - "blockUsername": "忽略用户名", - "@blockUsername": {}, - "groupName": "群组名称", - "@groupName": {}, - "databaseMigrationTitle": "数据库已优化", - "@databaseMigrationTitle": {}, - "searchChatsRooms": "搜索 #聊天,@用户…", - "@searchChatsRooms": {}, - "databaseMigrationBody": "请稍候。可能需要稍等片刻。", - "@databaseMigrationBody": {}, - "thisDevice": "此设备:", - "@thisDevice": {}, - "publicSpaces": "公开空间", - "@publicSpaces": {}, - "passwordIsWrong": "你输入的密码有误", - "@passwordIsWrong": {}, - "pleaseEnterYourCurrentPassword": "请输入你当前的密码", - "@pleaseEnterYourCurrentPassword": {}, - "publicLink": "公开链接", - "@publicLink": {}, - "nothingFound": "未找到任何内容…", - "@nothingFound": {}, - "decline": "拒绝", - "@decline": {}, - "newPassword": "新的密码", - "@newPassword": {}, - "passwordsDoNotMatch": "密码不匹配", - "@passwordsDoNotMatch": {}, - "subspace": "子空间", - "@subspace": {}, - "select": "选择", - "@select": {}, - "pleaseChooseAStrongPassword": "请选择一个强密码", - "@pleaseChooseAStrongPassword": {}, - "addChatOrSubSpace": "添加聊天或子空间", - "@addChatOrSubSpace": {}, - "leaveEmptyToClearStatus": "留空以清除你的状态。", - "@leaveEmptyToClearStatus": {}, - "joinSpace": "加入空间", - "@joinSpace": {}, - "searchForUsers": "搜索 @用户…", - "@searchForUsers": {}, - "databaseBuildErrorBody": "无法构建 SQLite 数据库。目前应用尝试使用旧数据库。请将此错误报告给开发者,网址为 {url}。错误消息为:{error}", - "@databaseBuildErrorBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "initAppError": "在初始化应用时发生错误", - "@initAppError": {}, - "sessionLostBody": "你的会话已丢失。请将此错误报告给开发者,网址为 {url}。错误消息为:{error}", - "@sessionLostBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "restoreSessionBody": "应用现在尝试从备份中恢复你的会话。请将此错误报告给开发者,网址为 {url}。错误消息为:{error}", - "@restoreSessionBody": { - "type": "text", - "placeholders": { - "url": {}, - "error": {} - } - }, - "sendTypingNotificationsDescription": "聊天中的其他参与者可以看到你正在输入新消息。", - "@sendTypingNotificationsDescription": {}, - "formattedMessagesDescription": "使用 Markdown 显示富文本内容,例如加粗文本。", - "@formattedMessagesDescription": {}, - "verifyOtherUserDescription": "如果你验证了其他用户,就可以确保你清楚自己正在与谁进行通信。💪\n\n当你开始验证时,你和其他用户将在应用中看到一个弹出窗口。然后你会看到一系列表情符号或数字,你和其他用户需要比较它们是否一致。\n\n最好的方式是线下会面或开始视频通话。👭", - "@verifyOtherUserDescription": {}, - "verifyOtherDeviceDescription": "当你验证另一个设备时,这些设备可以交换密钥,从而提高整体安全性。 💪 当你开始验证时,两个设备上的应用都将显示一个弹出窗口。然后你会看到一系列表情符号或数字,你需要比较两个设备上显示的内容。在开始验证之前,最好将两个设备都放在手边。🤳", - "@verifyOtherDeviceDescription": {}, - "canceledKeyVerification": "{sender} 取消了密钥验证", - "@canceledKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "sendReadReceipts": "发送已读回执", - "@sendReadReceipts": {}, - "formattedMessages": "格式化的消息", - "@formattedMessages": {}, - "verifyOtherDevice": "🔐 验证其它设备", - "@verifyOtherDevice": {}, - "verifyOtherUser": "🔐 验证其他用户", - "@verifyOtherUser": {}, - "forwardMessageTo": "转发消息至 {roomName} ?", - "@forwardMessageTo": { - "type": "text", - "placeholders": { - "roomName": {} - } - }, - "sendReadReceiptsDescription": "聊天中的其他参与者可以看到你是否读过消息。", - "@sendReadReceiptsDescription": {}, - "acceptedKeyVerification": "{sender} 接受了密钥验证", - "@acceptedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "isReadyForKeyVerification": "{sender} 已准备好进行密钥验证", - "@isReadyForKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "completedKeyVerification": "{sender} 完成了密钥验证", - "@completedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "requestedKeyVerification": "{sender} 请求了密钥验证", - "@requestedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "startedKeyVerification": "{sender} 开始了密钥验证", - "@startedKeyVerification": { - "type": "text", - "placeholders": { - "sender": {} - } - }, - "transparent": "透明", - "@transparent": {}, - "youInvitedToBy": "📩 你已通过链接被邀请到:\n{alias}", - "@youInvitedToBy": { - "placeholders": { - "alias": {} - } - }, - "presencesToggle": "显示其他用户的状态消息", - "@presencesToggle": { - "type": "text", - "placeholders": {} - }, - "presenceStyle": "是否在线:", - "@presenceStyle": { - "type": "text", - "placeholders": {} - }, - "hidePresences": "隐藏状态列表?", - "@hidePresences": {}, - "incomingMessages": "传入消息", - "@incomingMessages": {}, - "stickers": "贴纸", - "@stickers": {}, - "discover": "发现", - "@discover": {}, - "commandHint_ignore": "忽略给定的 matrix ID", - "@commandHint_ignore": {}, - "commandHint_unignore": "取消忽略给定的 matrix ID", - "@commandHint_unignore": {}, - "unreadChatsInApp": "{appname}: {unread} 未读聊天", - "@unreadChatsInApp": { - "type": "text", - "placeholders": { - "appname": {}, - "unread": {} - } - }, - "appLockDescription": "用 pin 码在不用 FluffyChat 时锁定它", - "@appLockDescription": {}, - "globalChatId": "全局聊天 ID", - "@globalChatId": {}, - "accessAndVisibility": "访问和可见性", - "@accessAndVisibility": {}, - "accessAndVisibilityDescription": "谁可以加入此聊天以及怎样发现该聊天。", - "@accessAndVisibilityDescription": {}, - "calls": "通话", - "@calls": {}, - "customEmojisAndStickers": "自定义表情符号和贴纸", - "@customEmojisAndStickers": {}, - "hideRedactedMessages": "隐藏被涂黑的消息", - "@hideRedactedMessages": {}, - "overview": "概览", - "@overview": {}, - "notifyMeFor": "提示内容", - "@notifyMeFor": {}, - "passwordRecoverySettings": "密码发现设置", - "@passwordRecoverySettings": {}, - "noPublicLinkHasBeenCreatedYet": "尚未创建公开链接", - "@noPublicLinkHasBeenCreatedYet": {}, - "knock": "请求", - "@knock": {}, - "noOneCanJoin": "无人可以加入", - "@noOneCanJoin": {}, - "knocking": "正在请求", - "@knocking": {}, - "chatCanBeDiscoveredViaSearchOnServer": "可通过搜索 {server} 发现聊天", - "@chatCanBeDiscoveredViaSearchOnServer": { - "type": "text", - "placeholders": { - "server": {} - } - }, - "thereAreCountUsersBlocked": "目前有 {count} 名用户被封禁。", - "@thereAreCountUsersBlocked": { - "type": "text", - "count": {} - }, - "hideRedactedMessagesBody": "如果某人涂黑了一条消息,那么在聊天中再也看不到这条消息。", - "@hideRedactedMessagesBody": {}, - "hideInvalidOrUnknownMessageFormats": "隐藏无效或未知的消息格式", - "@hideInvalidOrUnknownMessageFormats": {}, - "hideMemberChangesInPublicChats": "在公开聊天中隐藏成员变化", - "@hideMemberChangesInPublicChats": {}, - "hideMemberChangesInPublicChatsBody": "不在聊天时间线中显示某人是否加入或离开了公开聊天来改进可读性。", - "@hideMemberChangesInPublicChatsBody": {}, - "userWouldLikeToChangeTheChat": "{user} 想加入聊天。", - "@userWouldLikeToChangeTheChat": { - "placeholders": { - "user": {} - } - }, - "customEmojisAndStickersBody": "添加或分享可用于任何聊天的表情符号或贴纸。", - "@customEmojisAndStickersBody": {}, - "usersMustKnock": "用户必须请求加入", - "@usersMustKnock": {}, - "noDatabaseEncryption": "数据库加密在此平台上不受支持", - "@noDatabaseEncryption": {}, - "userRole": "用户角色", - "@userRole": {}, - "minimumPowerLevel": "{level} 是最低权限等级。", - "@minimumPowerLevel": { - "type": "text", - "placeholders": { - "level": {} - } - }, - "publicChatAddresses": "公开聊天的地址", - "@publicChatAddresses": {}, - "createNewAddress": "新建地址", - "@createNewAddress": {}, - "searchMore": "搜索更多…", - "@searchMore": {}, - "gallery": "图库", - "@gallery": {}, - "files": "文件", - "@files": {}, - "searchIn": "在 “{chat}” 聊天中搜索…", - "@searchIn": { - "type": "text", - "placeholders": { - "chat": {} - } - }, - "knockRestricted": "“请求加入”请求受限", - "@knockRestricted": {}, - "restricted": "受限", - "@restricted": {}, - "swipeRightToLeftToReply": "从右向左滑动进行回复", - "@swipeRightToLeftToReply": {} -} diff --git a/assets/l10n/intl_zh_Hant.arb b/assets/l10n/intl_zh_Hant.arb deleted file mode 100644 index 8758122cf..000000000 --- a/assets/l10n/intl_zh_Hant.arb +++ /dev/null @@ -1,2240 +0,0 @@ -{ - "@@last_modified": "2021-08-14 12:41:09.708353", - "about": "關於", - "@about": { - "type": "text", - "placeholders": {} - }, - "accept": "接受", - "@accept": { - "type": "text", - "placeholders": {} - }, - "acceptedTheInvitation": "👍{username}已接受邀請", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "帳號", - "@account": { - "type": "text", - "placeholders": {} - }, - "activatedEndToEndEncryption": "🔐{username}已啟用點對點加密", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "addEmail": "新增電子郵件", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "admin": "管理員", - "@admin": { - "type": "text", - "placeholders": {} - }, - "alias": "別稱", - "@alias": { - "type": "text", - "placeholders": {} - }, - "all": "全部", - "@all": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "已開始與{senderName}通話", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "任何人可以加入", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "密碼鎖定", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "封存", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "是否允許訪客加入", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "您確定嗎?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "您確定要登出嗎?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "請輸入您安全儲存的密碼短語或恢復金鑰,以向對方簽名。", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "是否接受來自{username}的驗證申請?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "badServerLoginTypesException": "目前伺服器支援的登入類型:\n{serverVersions}\n但本應用程式僅支援:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "badServerVersionsException": "目前伺服器支援的Spec版本:\n{serverVersions}\n但本應用程式僅支援{supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "banFromChat": "已從聊天室中封禁", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "已被封禁", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username}封禁了{targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "封鎖裝置", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "blocked": "已封鎖", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "botMessages": "機器人訊息", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "取消", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "變更裝置名稱", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username}變更了對話頭貼", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username}變更了對話介紹為:「{description}」", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username}變更了暱稱為:「{chatname}」", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username}變更了對話權限", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} 變更了顯示名稱為:「{displayname}」", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username}變更了訪客訪問規則", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username}變更了訪客訪問規則為:{rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username}變更了歷史記錄觀察狀態", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username}變更了歷史紀錄觀察狀態到:{rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username}變更了加入的規則", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username}變更了加入的規則為:{joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username}變更了頭貼", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username}變更了聊天室名", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username}變更了邀請連結", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "變更密碼", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "變更主機位址", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "變更主題", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "變更了群組名稱", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "加密已被破壞", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "聊天", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "備份聊天室", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "您的過往聊天記錄已被恢復金鑰加密。請您確保不會弄丟它。", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "對話詳細", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "輸入一個較強的密碼", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "關閉", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "對比並確認這些表情符合其他那些裝置:", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "比較以下數字,確保它們和另一個裝置上的相同:", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "設定聊天室", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "確認", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "連接", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "聯絡人已被邀請至群組", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "包含顯示名稱", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "包含使用者名稱", - "@containsUserName": { - "type": "text", - "placeholders": {} - }, - "contentHasBeenReported": "此內容已被回報給伺服器管理員們", - "@contentHasBeenReported": { - "type": "text", - "placeholders": {} - }, - "copiedToClipboard": "已複製到剪貼簿", - "@copiedToClipboard": { - "type": "text", - "placeholders": {} - }, - "copy": "複製", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "複製到剪貼簿", - "@copyToClipboard": { - "type": "text", - "placeholders": {} - }, - "couldNotDecryptMessage": "不能解密訊息:{error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count}個參與者", - "@countParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "create": "建立", - "@create": { - "type": "text", - "placeholders": {} - }, - "createdTheChat": "{username}建立了聊天室", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "目前活躍", - "@currentlyActive": { - "type": "text", - "placeholders": {} - }, - "darkTheme": "夜間模式", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{date}, {timeOfDay}", - "@dateAndTimeOfDay": { - "type": "text", - "placeholders": { - "date": {}, - "timeOfDay": {} - } - }, - "dateWithoutYear": "{month}-{day}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{year}-{month}-{day}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "這將停用您的帳號。這個決定是不能挽回的!您確定嗎?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "預設權限等級", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "刪除", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "刪除帳號", - "@deleteAccount": { - "type": "text", - "placeholders": {} - }, - "deleteMessage": "刪除訊息", - "@deleteMessage": { - "type": "text", - "placeholders": {} - }, - "device": "裝置", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "裝置ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "裝置", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "直接傳訊", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "顯示名稱已被變更", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "下載文件", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "編輯", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "編輯被封鎖的伺服器", - "@editBlockedServers": { - "type": "text", - "placeholders": {} - }, - "editDisplayname": "編輯顯示名稱", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "編輯聊天室頭貼", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "表情已存在!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "無效的表情快捷鍵!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "聊天室的表情符號", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "表情設定", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "表情快捷鍵", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "您需要選取一個表情快捷鍵和一張圖片!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "空的聊天室", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "在全域啟用表情符號", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "啟用加密", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "您將不能再停用加密,確定嗎?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "加密的", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "加密", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "加密未啟用", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName}結束了通話", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "輸入一個電子郵件位址", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "輸入伺服器位址", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "一切就緒!", - "@everythingReady": { - "type": "text", - "placeholders": {} - }, - "extremeOffensive": "極端令人反感", - "@extremeOffensive": { - "type": "text", - "placeholders": {} - }, - "fileName": "檔案名稱", - "@fileName": { - "type": "text", - "placeholders": {} - }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "字體大小", - "@fontSize": { - "type": "text", - "placeholders": {} - }, - "forward": "轉發", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "自加入起", - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "fromTheInvitation": "自邀請起", - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "group": "群組", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "群組是公開的", - "@groupIsPublic": { - "type": "text", - "placeholders": {} - }, - "groups": "群組", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "名稱為{displayname}的群組", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "訪客已被禁止", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "訪客可以加入", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username}收回了對{targetName}的邀請", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "幫助", - "@help": { - "type": "text", - "placeholders": {} - }, - "hideRedactedEvents": "隱藏編輯過的事件", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "隱藏未知事件", - "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "這個內容有多令人反感?", - "@howOffensiveIsThisContent": { - "type": "text", - "placeholders": {} - }, - "id": "ID", - "@id": { - "type": "text", - "placeholders": {} - }, - "identity": "身份", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "無視", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "已無視的使用者", - "@ignoredUsers": { - "type": "text", - "placeholders": {} - }, - "iHaveClickedOnLink": "我已經點擊了網址", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "錯誤的密碼短語或恢復金鑰", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "不令人反感", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "邀請聯絡人", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "邀請聯絡人到{groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "已邀請", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "{username}邀請了{targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "只有被邀請的使用者", - "@invitedUsersOnly": { - "type": "text", - "placeholders": {} - }, - "inviteForMe": "來自我的邀請", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username}邀請您使用FluffyChat\n1. 安裝FluffyChat:https://fluffychat.im\n2. 登入或註冊\n3. 打開該邀請網址:{link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "正在輸入...…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "{username}加入了聊天室", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "加入聊天室", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "{username}踢了{targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "{username}踢了{targetName}並將其封禁", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "從聊天室踢出", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "最後活動時間:{localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "離開", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "離開了聊天室", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "授權", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "日間模式", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "載入{count}個更多的參與者", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "載入中… 請稍候。", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "載入更多…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "登入", - "@login": { - "type": "text", - "placeholders": {} - }, - "logInTo": "登入{homeserver}", - "@logInTo": { - "type": "text", - "placeholders": { - "homeserver": {} - } - }, - "logout": "登出", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "變更成員", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "提及", - "@mention": { - "type": "text", - "placeholders": {} - }, - "messages": "訊息", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "版主", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "將該聊天室靜音", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "請注意您需要Pantalaimon才能使用點對點加密功能。", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "新聊天室", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "來自 FluffyChat 的新訊息", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "新的驗證請求!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "下一個", - "@next": { - "type": "text", - "placeholders": {} - }, - "no": "否", - "@no": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "無法連接到伺服器", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "noEmotesFound": "表情符號不存在。😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noEncryptionForPublicRooms": "您只能在這個聊天室不再被允許公開訪問後,才能啟用加密。", - "@noEncryptionForPublicRooms": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "看起來您手機上沒有Google服務框架。這對於保護您的隱私而言是個好決定!但為了收到FluffyChat的推播通知,我們推薦您使用 https://microg.org/ 或 https://unifiedpush.org/。", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "無", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "您尚未新增恢復密碼的方法。", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "沒有權限", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "找不到聊天室…", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "通知", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "已為此帳號啟用通知", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count}個人正在輸入…", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "offensive": "令人反感", - "@offensive": { - "type": "text", - "placeholders": {} - }, - "offline": "離線", - "@offline": { - "type": "text", - "placeholders": {} - }, - "ok": "OK", - "@ok": { - "type": "text", - "placeholders": {} - }, - "online": "線上", - "@online": { - "type": "text", - "placeholders": {} - }, - "onlineKeyBackupEnabled": "線上金鑰備份已啟用", - "@onlineKeyBackupEnabled": { - "type": "text", - "placeholders": {} - }, - "oopsSomethingWentWrong": "哎呀!出了一點差錯…", - "@oopsSomethingWentWrong": { - "type": "text", - "placeholders": {} - }, - "openAppToReadMessages": "打開應用程式以讀取訊息", - "@openAppToReadMessages": { - "type": "text", - "placeholders": {} - }, - "openCamera": "開啟相機", - "@openCamera": { - "type": "text", - "placeholders": {} - }, - "participant": "參與者", - "@participant": { - "type": "text", - "placeholders": {} - }, - "passphraseOrKey": "密碼短語或恢復金鑰", - "@passphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "password": "密碼", - "@password": { - "type": "text", - "placeholders": {} - }, - "passwordForgotten": "忘記密碼", - "@passwordForgotten": { - "type": "text", - "placeholders": {} - }, - "passwordHasBeenChanged": "密碼已被變更", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "恢復密碼", - "@passwordRecovery": { - "type": "text", - "placeholders": {} - }, - "pickImage": "選擇圖片", - "@pickImage": { - "type": "text", - "placeholders": {} - }, - "pin": "釘選", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "播放{fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseChooseAPasscode": "請選擇一個密碼", - "@pleaseChooseAPasscode": { - "type": "text", - "placeholders": {} - }, - "pleaseClickOnLink": "請點擊電子郵件中的網址,然後繼續。", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnter4Digits": "請輸入4位數字,或留空以停用密碼鎖定。", - "@pleaseEnter4Digits": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "請輸入您的密碼", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "請輸入您的使用者名稱", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "請按照網站上的說明進行操作,然後點擊下一步。", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "隱私", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "公開的聊天室", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "推播規則", - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "reason": "原因", - "@reason": { - "type": "text", - "placeholders": {} - }, - "recording": "錄音中", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username}編輯了一個事件", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "redactMessage": "重新編輯訊息", - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "reject": "拒絕", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username}拒絕了邀請", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "重新加入", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "移除", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "移除所有其他裝置", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "被{username}移除", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "移除裝置", - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "unbanFromChat": "解禁聊天", - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "繪製圖文訊息內容", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "用較新的版本取代聊天室", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "回覆", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "檢舉訊息", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "請求權限", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "聊天室已更新", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "search": "搜尋", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "安全", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "{username}已讀", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "傳送", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "傳送訊息", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "傳送音訊", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "傳送文件", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "傳送圖片", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "傳送訊息", - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "sendOriginal": "傳送原始內容", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "傳送影片", - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "sentAFile": "{username}傳送了一個文件", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "{username}傳送了一個音訊", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "{username}傳送了一張圖片", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "{username} 傳送了貼圖", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "{username} 傳送了影片", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} 傳送了通話資訊", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setCustomEmotes": "自訂表情符號", - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "setInvitationLink": "設定邀請連結", - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "setPermissionsLevel": "設定權限級別", - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "setStatus": "設定狀態", - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "settings": "設定", - "@settings": { - "type": "text", - "placeholders": {} - }, - "share": "分享", - "@share": { - "type": "text", - "placeholders": {} - }, - "sharedTheLocation": "{username} 分享了位置", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "showPassword": "顯示密碼", - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "skip": "跳過", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "原始碼", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName}開始了通話", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "狀態", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "今天過得如何?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "送出", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "自動", - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "theyDontMatch": "它們不相符", - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "theyMatch": "它們相符", - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "title": "FluffyChat", - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "切換收藏夾", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "切換靜音", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "標記為已讀/未讀", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "tooManyRequestsWarning": "太多請求了。請稍候再試!", - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "transferFromAnotherDevice": "從其他裝置傳輸", - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "tryToSendAgain": "再次嘗試傳送", - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "unavailable": "無法取得", - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "unbannedUser": "{username}解除封禁了{targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "解除鎖定裝置", - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "unknownDevice": "未知裝置", - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "unknownEncryptionAlgorithm": "未知的加密演算法", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "未知事件「{type}」", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "取消靜音聊天室", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "取消釘選", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, =1{1 unread chat} other{{unreadCount} 個未讀聊天室}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username}和其他{count}個人正在輸入…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username}和{username2}正在輸入…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username}正在輸入…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "{username}離開了聊天室", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "使用者名稱", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username}傳送了一個{type}事件", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verified": "已驗證", - "@verified": { - "type": "text", - "placeholders": {} - }, - "verify": "驗證", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "開始驗證", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "您成功驗證了!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "正在驗證其他帳號", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "視訊通話", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "聊天記錄的可見性", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "對所有參與者可見", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "對所有人可見", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "語音訊息", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerAcceptRequest": "正在等待夥伴接受請求…", - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerEmoji": "正在等待夥伴接受表情符號…", - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "正在等待夥伴接受數字…", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "桌布", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "警告!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "我們向您傳送了一封電子郵件", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "誰可以執行這個動作", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "誰可以加入這個群組", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "您檢舉的原因是什麼?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "wipeChatBackup": "要清除您的聊天記錄備份以建立新的安全金鑰嗎?", - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "有了這些位址,您就可以恢復密碼。", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "輸入訊息…", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "是", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "您", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "您不再參與這個聊天室了", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "您已經被這個聊天室封禁", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "您的公鑰", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "people": "人", - "@people": { - "type": "text", - "placeholders": {} - }, - "chats": "聊天室", - "@chats": { - "type": "text", - "placeholders": {} - }, - "allChats": "所有會話", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "commandHint_ban": "在此聊天室封禁該使用者", - "@commandHint_ban": { - "type": "text", - "description": "Usage hint for the command /ban" - }, - "commandHint_clearcache": "清除快取", - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "commandHint_create": "建立一個空的群聊\n使用 --no-encryption 選項來禁用加密", - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "commandHint_discardsession": "丟棄工作階段", - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "commandHint_dm": "啟動一對一聊天\n使用 --no-encryption 選項來禁用加密", - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "commandHint_invite": "邀請該使用者加入此聊天室", - "@commandHint_invite": { - "type": "text", - "description": "Usage hint for the command /invite" - }, - "commandHint_join": "加入此聊天室", - "@commandHint_join": { - "type": "text", - "description": "Usage hint for the command /join" - }, - "commandHint_kick": "將這個使用者移出此聊天室", - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "commandHint_leave": "退出此聊天室", - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" - }, - "commandHint_myroomnick": "設定您的聊天室暱稱", - "@commandHint_myroomnick": { - "type": "text", - "description": "Usage hint for the command /myroomnick" - }, - "editRoomAliases": "編輯聊天室名", - "@editRoomAliases": { - "type": "text", - "placeholders": {} - }, - "roomVersion": "聊天室的版本", - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "addToSpace": "加入空間", - "@addToSpace": {}, - "cantOpenUri": "無法打開URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "repeatPassword": "再次輸入密碼", - "@repeatPassword": {}, - "yourChatBackupHasBeenSetUp": "您的聊天記錄備份已設定。", - "@yourChatBackupHasBeenSetUp": {}, - "goToTheNewRoom": "前往新聊天室", - "@goToTheNewRoom": { - "type": "text", - "placeholders": {} - }, - "commandHint_myroomavatar": "設置您的聊天室頭貼(通過 mxc-uri)", - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "commandHint_unban": "在此聊天室解封該使用者", - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "autoplayImages": "自動播放動態貼圖和表情", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "sendOnEnter": "按 Enter 鍵發送", - "@sendOnEnter": {}, - "changeYourAvatar": "更改您的大頭貼", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "chatHasBeenAddedToThisSpace": "聊天室已添加到此空間", - "@chatHasBeenAddedToThisSpace": {}, - "clearArchive": "清除存檔", - "@clearArchive": {}, - "hugContent": "{senderName}擁抱您", - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "commandHint_cuddle": "發送一個摟抱表情", - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@reportErrorDescription": {}, - "@addAccount": {}, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" - }, - "@widgetJitsi": {}, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@startFirstChat": {}, - "@callingAccount": {}, - "@setColorTheme": {}, - "@nextAccount": {}, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "supposedMxid": "此處應爲{mxid}", - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@user": {}, - "@youAcceptedTheInvitation": {}, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@previousAccount": {}, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@widgetNameError": {}, - "@addToBundle": {}, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@storeInAppleKeyChain": {}, - "@hydrate": {}, - "invalidServerName": "伺服器名稱錯誤", - "@invalidServerName": {}, - "@chatPermissions": {}, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@signInWithPassword": {}, - "@makeAdminDescription": {}, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@editBundlesForAccount": {}, - "@whyIsThisMessageEncrypted": {}, - "@setChatDescription": {}, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "importFromZipFile": "從 zip 檔案匯入", - "@importFromZipFile": {}, - "@or": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@noOtherDevicesFound": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCallsBetaWarning": {}, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@fileIsTooBigForServer": {}, - "homeserver": "伺服器", - "@homeserver": {}, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@optionalRedactReason": {}, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@archiveRoomDescription": {}, - "exportEmotePack": "將表情包匯出成 zip 檔案", - "@exportEmotePack": {}, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "commandInvalid": "命令無效", - "@commandInvalid": { - "type": "text" - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@reportUser": {}, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" - }, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "commandMissing": "{command}不是正確的命令。", - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@recoveryKey": {}, - "@invalidInput": {}, - "@dehydrateTorLong": {}, - "@doNotShowAgain": {}, - "@report": {}, - "@unverified": {}, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@addToSpaceDescription": {}, - "googlyEyesContent": "{senderName}向您發送了瞪眼表情", - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "addChatDescription": "新增聊天說明...", - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@commandHint_react": { - "type": "text", - "description": "Usage hint for the command /react" - }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "sendTypingNotifications": "傳送「輸入中」通知", - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@foregroundServiceRunning": {}, - "@voiceCall": {}, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "importEmojis": "匯入表情包", - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@removeFromBundle": {}, - "confirmMatrixId": "如需要刪除你的帳戶,請確認你的Matrix ID。", - "@confirmMatrixId": {}, - "@learnMore": {}, - "notAnImage": "不是圖片檔案。", - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@roomUpgradeDescription": {}, - "@scanQrCode": {}, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "cuddleContent": "{senderName}摟抱您", - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@widgetName": {}, - "@errorAddingWidget": {}, - "commandHint_hug": "發送一個擁抱表情", - "@commandHint_hug": {}, - "replace": "取代", - "@replace": {}, - "@oopsPushError": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@newSpace": {}, - "@emojis": {}, - "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", - "placeholders": {} - }, - "commandHint_googly": "發送一些瞪眼表情", - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@hydrateTorLong": {}, - "@time": {}, - "@custom": {}, - "@noBackupWarning": {}, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "importNow": "立即匯入", - "@importNow": {}, - "@pinMessage": {}, - "@invite": {}, - "@enableMultiAccounts": {}, - "@indexedDbErrorTitle": {}, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@placeCall": {}, - "blockListDescription": "你可以封鎖打擾你的使用者。你不會再收到任何從已封鎖使用者發來的訊息或聊天室邀請。", - "@blockListDescription": {}, - "blockedUsers": "已封鎖的使用者", - "@blockedUsers": {}, - "block": "封鎖", - "@block": {}, - "discover": "探索", - "@discover": {} -} diff --git a/assets/login_wallpaper.png b/assets/login_wallpaper.png deleted file mode 100644 index 2ca9db9ca..000000000 Binary files a/assets/login_wallpaper.png and /dev/null differ diff --git a/assets/logo_transparent.png b/assets/logo_transparent.png new file mode 100644 index 000000000..5c0b08391 Binary files /dev/null and b/assets/logo_transparent.png differ diff --git a/assets/vodozemac/.gitignore b/assets/vodozemac/.gitignore new file mode 100644 index 000000000..d9bc44261 --- /dev/null +++ b/assets/vodozemac/.gitignore @@ -0,0 +1 @@ +vodozemac_bindings_dart* \ No newline at end of file diff --git a/config.sample.json b/config.sample.json index ff37ec238..a1ea6f6fb 100644 --- a/config.sample.json +++ b/config.sample.json @@ -1,10 +1,31 @@ { - "application_name": "FluffyChat", - "application_welcome_message": null, - "default_homeserver": "matrix.org", - "web_base_url": "https://fluffychat.im/web", - "privacy_url": "https://fluffychat.im/en/privacy.html", - "render_html": false, - "hide_redacted_events": false, - "hide_unknown_events": false + "applicationName": "FluffyChat", + "defaultHomeserver": "matrix.org", + "presetHomeserver": "", + "welcomeText": "", + "privacyUrl": "https://github.com/krille-chan/fluffychat/blob/main/PRIVACY.md", + "audioRecordingNumChannels": 1, + "audioRecordingAutoGain": true, + "audioRecordingEchoCancel": false, + "audioRecordingNoiseSuppress": true, + "audioRecordingBitRate": 64000, + "audioRecordingSamplingRate": 44100, + "renderHtml": true, + "fontSizeFactor": 1, + "hideRedactedEvents": false, + "hideUnknownEvents": true, + "separateChatTypes": false, + "autoplayImages": true, + "sendTypingNotifications": true, + "sendPublicReadReceipts": true, + "swipeRightToLeftToReply": true, + "sendOnEnter": false, + "showPresences": true, + "displayNavigationRail": false, + "experimentalVoip": false, + "shareKeysWith": "all", + "noEncryptionWarningShown": false, + "displayChatDetailsColumn": false, + "colorSchemeSeedInt": 4283835834, + "enableSoftLogout": false } \ No newline at end of file diff --git a/docs/.well-known/org.flathub.VerifiedApps.txt b/docs/.well-known/org.flathub.VerifiedApps.txt deleted file mode 100644 index a9a5eb471..000000000 --- a/docs/.well-known/org.flathub.VerifiedApps.txt +++ /dev/null @@ -1,2 +0,0 @@ -# im.fluffychat.Fluffychat -8b25b37b-f160-4350-b4f6-9a04554e8f9e \ No newline at end of file diff --git a/docs/LICENSE b/docs/LICENSE deleted file mode 100644 index 2e59d7230..000000000 --- a/docs/LICENSE +++ /dev/null @@ -1,21 +0,0 @@ -MIT License - -Copyright (c) 2019 Tailwind Toolbox - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/docs/OFL.txt b/docs/OFL.txt deleted file mode 100644 index 075d1aefb..000000000 --- a/docs/OFL.txt +++ /dev/null @@ -1,91 +0,0 @@ -This Font Software is licensed under the SIL Open Font License, Version 1.1. -This license is copied below, and is also available with a FAQ at: -http://scripts.sil.org/OFL - - ------------------------------------------------------------ -SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007 ------------------------------------------------------------ - -PREAMBLE -The goals of the Open Font License (OFL) are to stimulate worldwide -development of collaborative font projects, to support the font creation -efforts of academic and linguistic communities, and to provide a free and -open framework in which fonts may be shared and improved in partnership -with others. - -The OFL allows the licensed fonts to be used, studied, modified and -redistributed freely as long as they are not sold by themselves. The -fonts, including any derivative works, can be bundled, embedded, -redistributed and/or sold with any software provided that any reserved -names are not used by derivative works. The fonts and derivatives, -however, cannot be released under any other type of license. The -requirement for fonts to remain under this license does not apply -to any document created using the fonts or their derivatives. - -DEFINITIONS -"Font Software" refers to the set of files released by the Copyright -Holder(s) under this license and clearly marked as such. This may -include source files, build scripts and documentation. - -"Reserved Font Name" refers to any names specified as such after the -copyright statement(s). - -"Original Version" refers to the collection of Font Software components as -distributed by the Copyright Holder(s). - -"Modified Version" refers to any derivative made by adding to, deleting, -or substituting -- in part or in whole -- any of the components of the -Original Version, by changing formats or by porting the Font Software to a -new environment. - -"Author" refers to any designer, engineer, programmer, technical -writer or other person who contributed to the Font Software. - -PERMISSION & CONDITIONS -Permission is hereby granted, free of charge, to any person obtaining -a copy of the Font Software, to use, study, copy, merge, embed, modify, -redistribute, and sell modified and unmodified copies of the Font -Software, subject to the following conditions: - -1) Neither the Font Software nor any of its individual components, -in Original or Modified Versions, may be sold by itself. - -2) Original or Modified Versions of the Font Software may be bundled, -redistributed and/or sold with any software, provided that each copy -contains the above copyright notice and this license. These can be -included either as stand-alone text files, human-readable headers or -in the appropriate machine-readable metadata fields within text or -binary files as long as those fields can be easily viewed by the user. - -3) No Modified Version of the Font Software may use the Reserved Font -Name(s) unless explicit written permission is granted by the corresponding -Copyright Holder. This restriction only applies to the primary font name as -presented to the users. - -4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font -Software shall not be used to promote, endorse or advertise any -Modified Version, except to acknowledge the contribution(s) of the -Copyright Holder(s) and the Author(s) or with their explicit written -permission. - -5) The Font Software, modified or unmodified, in part or in whole, -must be distributed entirely under this license, and must not be -distributed under any other license. The requirement for fonts to -remain under this license does not apply to any document created -using the Font Software. - -TERMINATION -This license becomes null and void if any of the above conditions are -not met. - -DISCLAIMER -THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF -MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT -OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE -COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, -INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL -DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM -OTHER DEALINGS IN THE FONT SOFTWARE. diff --git a/docs/appstore-badge.png b/docs/appstore-badge.png deleted file mode 100644 index e96d5c069..000000000 Binary files a/docs/appstore-badge.png and /dev/null differ diff --git a/docs/browser-badge.png b/docs/browser-badge.png deleted file mode 100644 index fa6f278ad..000000000 Binary files a/docs/browser-badge.png and /dev/null differ diff --git a/docs/favicon.png b/docs/favicon.png deleted file mode 100644 index d55415b19..000000000 Binary files a/docs/favicon.png and /dev/null differ diff --git a/docs/fdroid_button.png b/docs/fdroid_button.png deleted file mode 100644 index 31e43f283..000000000 Binary files a/docs/fdroid_button.png and /dev/null differ diff --git a/docs/feature1.gif b/docs/feature1.gif deleted file mode 100644 index db6c8beb8..000000000 Binary files a/docs/feature1.gif and /dev/null differ diff --git a/docs/feature2.gif b/docs/feature2.gif deleted file mode 100644 index d6cf974b2..000000000 Binary files a/docs/feature2.gif and /dev/null differ diff --git a/docs/feature3.gif b/docs/feature3.gif deleted file mode 100644 index cd56dc532..000000000 Binary files a/docs/feature3.gif and /dev/null differ diff --git a/docs/feature4.gif b/docs/feature4.gif deleted file mode 100644 index 4f1c35dfd..000000000 Binary files a/docs/feature4.gif and /dev/null differ diff --git a/docs/feature5.gif b/docs/feature5.gif deleted file mode 100644 index b301d8fa0..000000000 Binary files a/docs/feature5.gif and /dev/null differ diff --git a/docs/feature6.gif b/docs/feature6.gif deleted file mode 100644 index d9fdba8d3..000000000 Binary files a/docs/feature6.gif and /dev/null differ diff --git a/docs/feature7.gif b/docs/feature7.gif deleted file mode 100644 index ced2184e1..000000000 Binary files a/docs/feature7.gif and /dev/null differ diff --git a/docs/feature8.gif b/docs/feature8.gif deleted file mode 100644 index 95bf4e817..000000000 Binary files a/docs/feature8.gif and /dev/null differ diff --git a/docs/feature9.gif b/docs/feature9.gif deleted file mode 100644 index a05001d08..000000000 Binary files a/docs/feature9.gif and /dev/null differ diff --git a/docs/firefox_icon.png b/docs/firefox_icon.png deleted file mode 100644 index 6accca90e..000000000 Binary files a/docs/firefox_icon.png and /dev/null differ diff --git a/docs/flathub-badge-en.png b/docs/flathub-badge-en.png deleted file mode 100644 index facf256f8..000000000 Binary files a/docs/flathub-badge-en.png and /dev/null differ diff --git a/docs/google-play-badge.png b/docs/google-play-badge.png deleted file mode 100644 index 6a93e1843..000000000 Binary files a/docs/google-play-badge.png and /dev/null differ diff --git a/docs/index.html b/docs/index.html deleted file mode 100644 index 0d82ae518..000000000 --- a/docs/index.html +++ /dev/null @@ -1,180 +0,0 @@ - - - - - - - FluffyChat Official Website - - - - - - - - - - - - - - - -
- -
- FluffyChat Logo -

The cutest messenger in [matrix] -

- - Mobile and desktop screenshots - -
- - - - - - - - -
- -
-
- Animated dancing woman -

Easy to use

-

FluffyChat is designed to be as easy to use as possible. No one - should be left behind.

-
-
- Animated pencil -

Material You

-

The well polished design is based on Material You and works great on - all platforms.

-
-
- Animated mechanical arm -

Secure

-

With end-to-end encryption, cross-signing and encrypted backups, - FluffyChat is one of the most secure messenger out there.

-
- - -
- Animated planet earth -

Decentral

-

You can choose the server you want to use or - even self-host your own!

-
-
- Animated bell -

Push Notifications

-

You can choose between Firebase Cloud Messaging or the more privacy - focused Unified Push.

-
-
- Animated rocket -

Spaces

-

With spaces you can join or create a community which organizes chats - and users. Using sub-spaces you can even nest your communities.

-
- - -
- Animated glass sphere -

Video calls

-

Still an experimental feature but you can already try out video and - audio calls, compatible with other [matrix] clients.

-
-
- Animated chick -

Stickers

-

Create your own sticker sets and share them with your friends. You - can even use them as inline emojis.

-
-
- Animated whoa emoji -

Compatible

-

FluffyChat is compatible with any other [matrix] client like Element, - Nheko, Cinny - or NeoChat. -

-
-
- - -
- -
- - - - \ No newline at end of file diff --git a/docs/info-logo.png b/docs/info-logo.png deleted file mode 100644 index ceb42f09b..000000000 Binary files a/docs/info-logo.png and /dev/null differ diff --git a/docs/kofi_button_dark.png b/docs/kofi_button_dark.png deleted file mode 100644 index b005e7a39..000000000 Binary files a/docs/kofi_button_dark.png and /dev/null differ diff --git a/docs/mastodon.svg b/docs/mastodon.svg deleted file mode 100644 index 0f8baebfc..000000000 --- a/docs/mastodon.svg +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - - - - diff --git a/docs/screenshots/desktop.png b/docs/screenshots/desktop.png deleted file mode 100644 index 319925885..000000000 Binary files a/docs/screenshots/desktop.png and /dev/null differ diff --git a/docs/screenshots/mobile.png b/docs/screenshots/mobile.png deleted file mode 100644 index 3e8a352d2..000000000 Binary files a/docs/screenshots/mobile.png and /dev/null differ diff --git a/docs/screenshots/product.jpeg b/docs/screenshots/product.jpeg deleted file mode 100644 index 32bf25881..000000000 Binary files a/docs/screenshots/product.jpeg and /dev/null differ diff --git a/docs/screenshots/screenshots.png b/docs/screenshots/screenshots.png deleted file mode 100644 index b974493d6..000000000 Binary files a/docs/screenshots/screenshots.png and /dev/null differ diff --git a/docs/screenshots/showcase1.jpeg b/docs/screenshots/showcase1.jpeg deleted file mode 100644 index 94875ee76..000000000 Binary files a/docs/screenshots/showcase1.jpeg and /dev/null differ diff --git a/docs/screenshots/showcase2.jpeg b/docs/screenshots/showcase2.jpeg deleted file mode 100644 index 4b78b88d1..000000000 Binary files a/docs/screenshots/showcase2.jpeg and /dev/null differ diff --git a/docs/screenshots/showcase3.jpeg b/docs/screenshots/showcase3.jpeg deleted file mode 100644 index 44c2ef47c..000000000 Binary files a/docs/screenshots/showcase3.jpeg and /dev/null differ diff --git a/docs/screenshots/showcase4.jpeg b/docs/screenshots/showcase4.jpeg deleted file mode 100644 index 75978f040..000000000 Binary files a/docs/screenshots/showcase4.jpeg and /dev/null differ diff --git a/docs/screenshots/showcase5.jpeg b/docs/screenshots/showcase5.jpeg deleted file mode 100644 index ca25818af..000000000 Binary files a/docs/screenshots/showcase5.jpeg and /dev/null differ diff --git a/docs/tailwind.config.js b/docs/tailwind.config.js deleted file mode 100644 index 2991816a3..000000000 --- a/docs/tailwind.config.js +++ /dev/null @@ -1,14 +0,0 @@ -module.exports = { - purge: [ - './index.html' - ], - darkMode: false, - theme: { - extend: {}, - }, - variants: { - extend: {}, - }, - plugins: [], - } - \ No newline at end of file diff --git a/fastlane b/fastlane deleted file mode 120000 index 94746b0d7..000000000 --- a/fastlane +++ /dev/null @@ -1 +0,0 @@ -./android/fastlane \ No newline at end of file diff --git a/fdroid/.gitignore b/fdroid/.gitignore deleted file mode 100644 index 5b807a9c7..000000000 --- a/fdroid/.gitignore +++ /dev/null @@ -1,4 +0,0 @@ -repo -srclibs -tmp -chat.fluffy.fluffychat \ No newline at end of file diff --git a/fdroid/config.nightly.py b/fdroid/config.nightly.py deleted file mode 100644 index 86fe4932c..000000000 --- a/fdroid/config.nightly.py +++ /dev/null @@ -1,13 +0,0 @@ -repo_url = "https://fluffychat.im/repo/nightly/repo" -repo_name = "FluffyChat nightly repo" -repo_icon = "fdroid-icon.png" -repo_description = """ -FluffyChat nightly repo -""" - -archive_older = 0 - -local_copy_dir = "/fdroid" - -keystore = "key.nightly.jks" -repo_keyalias = "vmd66783.contaboserver.net" diff --git a/fdroid/config.stable.py b/fdroid/config.stable.py deleted file mode 100644 index d0a3e2e82..000000000 --- a/fdroid/config.stable.py +++ /dev/null @@ -1,13 +0,0 @@ -repo_url = "https://fluffychat.im/repo/stable/repo" -repo_name = "FluffyChat repo" -repo_icon = "fdroid-icon.png" -repo_description = """ -FluffyChat repo -""" - -archive_older = 0 - -local_copy_dir = "/fdroid" - -keystore = "key.jks" -repo_keyalias = "key" diff --git a/fdroid/fdroid-icon.png b/fdroid/fdroid-icon.png deleted file mode 100644 index 0c0d41738..000000000 Binary files a/fdroid/fdroid-icon.png and /dev/null differ diff --git a/fdroid/metadata/chat.fluffy.fluffychat.yml b/fdroid/metadata/chat.fluffy.fluffychat.yml deleted file mode 100644 index 32ffd4a90..000000000 --- a/fdroid/metadata/chat.fluffy.fluffychat.yml +++ /dev/null @@ -1,53 +0,0 @@ -Categories: - - Internet - - Phone & SMS -License: AGPL-3.0-only -AuthorName: Famedly -SourceCode: https://github.com/krille-chan/fluffychat -IssueTracker: https://github.com/krille-chan/fluffychat/-/issues -Translation: https://hosted.weblate.org/projects/fluffychat/ -Changelog: https://gitlab.com/ChristianPauly/fluffychat-flutter/-/blob/main/CHANGELOG.md - -AutoName: FluffyChat -Summary: "Chat with your friends with FluffyChat.\n" -Description: | - FluffyChat is an open, nonprofit and cute matrix messenger app for Ubuntu Touch, Android and iOS. - - Open - Opensource and open development where everyone can join. - - Nonprofit - FluffyChat is donation funded. - - Cute ♥ - Cute design and many theme settings including a dark mode. - - One-to-one and groupchats - Unlimited groups and direct chats. - - Easy - FluffyChat is made as simple to use as possible. - - Free - Free to use for everyone without ads. - - Decentralized - There is no "FluffyChat server" you are forced to use. Use the server you find trustworthy or host - your own. - - Compatible - Compatible with Riot, Fractal, Nekho and all matrix messengers. - - - FluffyChat comes with a dream - - Imagine a world where everyone can choose the messenger they like and is still able to chat with - all of their friends. - A world where there are no companies spying on you when you send selfies to friends and lovers. - And a world where apps are made for fluffyness and not for profit. ♥ - -RepoType: git -Repo: https://github.com/krille-chan/fluffychat.git - -AutoUpdateMode: None -UpdateCheckMode: None diff --git a/fonts/NotoEmoji/NotoColorEmoji.ttf b/fonts/NotoEmoji/NotoColorEmoji.ttf deleted file mode 100644 index 8ebcc8fde..000000000 Binary files a/fonts/NotoEmoji/NotoColorEmoji.ttf and /dev/null differ diff --git a/fonts/Roboto/LICENSE.txt b/fonts/Roboto/LICENSE.txt deleted file mode 100644 index 75b52484e..000000000 --- a/fonts/Roboto/LICENSE.txt +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. diff --git a/fonts/Roboto/Roboto-Black.ttf b/fonts/Roboto/Roboto-Black.ttf deleted file mode 100644 index 0112e7da6..000000000 Binary files a/fonts/Roboto/Roboto-Black.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-BlackItalic.ttf b/fonts/Roboto/Roboto-BlackItalic.ttf deleted file mode 100644 index b2c6aca57..000000000 Binary files a/fonts/Roboto/Roboto-BlackItalic.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-Bold.ttf b/fonts/Roboto/Roboto-Bold.ttf deleted file mode 100644 index 43da14d84..000000000 Binary files a/fonts/Roboto/Roboto-Bold.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-BoldItalic.ttf b/fonts/Roboto/Roboto-BoldItalic.ttf deleted file mode 100644 index bcfdab431..000000000 Binary files a/fonts/Roboto/Roboto-BoldItalic.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-Italic.ttf b/fonts/Roboto/Roboto-Italic.ttf deleted file mode 100644 index 1b5eaa361..000000000 Binary files a/fonts/Roboto/Roboto-Italic.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-Light.ttf b/fonts/Roboto/Roboto-Light.ttf deleted file mode 100644 index e7307e72c..000000000 Binary files a/fonts/Roboto/Roboto-Light.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-LightItalic.ttf b/fonts/Roboto/Roboto-LightItalic.ttf deleted file mode 100644 index 2d277afb2..000000000 Binary files a/fonts/Roboto/Roboto-LightItalic.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-Medium.ttf b/fonts/Roboto/Roboto-Medium.ttf deleted file mode 100644 index ac0f908b9..000000000 Binary files a/fonts/Roboto/Roboto-Medium.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-MediumItalic.ttf b/fonts/Roboto/Roboto-MediumItalic.ttf deleted file mode 100644 index fc36a4785..000000000 Binary files a/fonts/Roboto/Roboto-MediumItalic.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-Regular.ttf b/fonts/Roboto/Roboto-Regular.ttf deleted file mode 100644 index ddf4bfacb..000000000 Binary files a/fonts/Roboto/Roboto-Regular.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-Thin.ttf b/fonts/Roboto/Roboto-Thin.ttf deleted file mode 100644 index 2e0dee6a8..000000000 Binary files a/fonts/Roboto/Roboto-Thin.ttf and /dev/null differ diff --git a/fonts/Roboto/Roboto-ThinItalic.ttf b/fonts/Roboto/Roboto-ThinItalic.ttf deleted file mode 100644 index 084f9c0f5..000000000 Binary files a/fonts/Roboto/Roboto-ThinItalic.ttf and /dev/null differ diff --git a/fonts/Roboto/RobotoMono-Regular.ttf b/fonts/Roboto/RobotoMono-Regular.ttf deleted file mode 100644 index d9371a1bd..000000000 Binary files a/fonts/Roboto/RobotoMono-Regular.ttf and /dev/null differ diff --git a/integration_test/app_test.dart b/integration_test/app_test.dart deleted file mode 100644 index 90f423077..000000000 --- a/integration_test/app_test.dart +++ /dev/null @@ -1,193 +0,0 @@ -import 'package:fluffychat/config/setting_keys.dart'; -import 'package:fluffychat/pages/chat/chat_view.dart'; -import 'package:fluffychat/pages/chat_list/chat_list_body.dart'; -import 'package:fluffychat/pages/chat_list/search_title.dart'; -import 'package:fluffychat/pages/invitation_selection/invitation_selection_view.dart'; - -import 'package:flutter/material.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:hive_flutter/hive_flutter.dart'; -import 'package:integration_test/integration_test.dart'; - -import 'package:fluffychat/main.dart' as app; -import 'package:shared_preferences/shared_preferences.dart'; - -import 'extensions/default_flows.dart'; -import 'extensions/wait_for.dart'; -import 'users.dart'; - -void main() { - IntegrationTestWidgetsFlutterBinding.ensureInitialized(); - - group( - 'Integration Test', - () { - setUpAll( - () async { - // this random dialog popping up is super hard to cover in tests - SharedPreferences.setMockInitialValues({ - SettingKeys.showNoGoogle: false, - }); - try { - Hive.deleteFromDisk(); - Hive.initFlutter(); - } catch (_) {} - }, - ); - - testWidgets( - 'Start app, login and logout', - (WidgetTester tester) async { - app.main(); - await tester.ensureAppStartedHomescreen(); - await tester.ensureLoggedOut(); - }, - ); - - testWidgets( - 'Login again', - (WidgetTester tester) async { - app.main(); - await tester.ensureAppStartedHomescreen(); - }, - ); - - testWidgets( - 'Start chat and send message', - (WidgetTester tester) async { - app.main(); - await tester.ensureAppStartedHomescreen(); - await tester.waitFor(find.byType(TextField)); - await tester.enterText(find.byType(TextField), Users.user2.name); - await tester.pumpAndSettle(); - - await tester.scrollUntilVisible( - find.text('Chats').first, - 500, - scrollable: find - .descendant( - of: find.byType(ChatListViewBody), - matching: find.byType(Scrollable), - ) - .first, - ); - await tester.pumpAndSettle(); - await tester.tap(find.text('Chats')); - await tester.pumpAndSettle(); - await tester.waitFor(find.byType(SearchTitle)); - await tester.pumpAndSettle(); - - await tester.scrollUntilVisible( - find.text(Users.user2.name).first, - 500, - scrollable: find - .descendant( - of: find.byType(ChatListViewBody), - matching: find.byType(Scrollable), - ) - .first, - ); - await tester.pumpAndSettle(); - await tester.tap(find.text(Users.user2.name).first); - - try { - await tester.waitFor( - find.byType(ChatView), - timeout: const Duration(seconds: 5), - ); - } catch (_) { - // in case the homeserver sends the username as search result - if (find.byIcon(Icons.send_outlined).evaluate().isNotEmpty) { - await tester.tap(find.byIcon(Icons.send_outlined)); - await tester.pumpAndSettle(); - } - } - - await tester.waitFor(find.byType(ChatView)); - await tester.enterText(find.byType(TextField).last, 'Test'); - await tester.pumpAndSettle(); - try { - await tester.waitFor(find.byIcon(Icons.send_outlined)); - await tester.tap(find.byIcon(Icons.send_outlined)); - } catch (_) { - await tester.testTextInput.receiveAction(TextInputAction.done); - } - await tester.pumpAndSettle(); - await tester.waitFor(find.text('Test')); - await tester.pumpAndSettle(); - }, - ); - - testWidgets('Spaces', (tester) async { - app.main(); - await tester.ensureAppStartedHomescreen(); - - await tester.waitFor(find.byTooltip('Show menu')); - await tester.tap(find.byTooltip('Show menu')); - await tester.pumpAndSettle(); - - await tester.waitFor(find.byIcon(Icons.workspaces_outlined)); - await tester.tap(find.byIcon(Icons.workspaces_outlined)); - await tester.pumpAndSettle(); - - await tester.waitFor(find.byType(TextField)); - await tester.enterText(find.byType(TextField).last, 'Test Space'); - await tester.pumpAndSettle(); - - await tester.testTextInput.receiveAction(TextInputAction.done); - await tester.pumpAndSettle(); - - await tester.waitFor(find.text('Invite contact')); - - await tester.tap(find.text('Invite contact')); - await tester.pumpAndSettle(); - - await tester.waitFor( - find.descendant( - of: find.byType(InvitationSelectionView), - matching: find.byType(TextField), - ), - ); - await tester.enterText( - find.descendant( - of: find.byType(InvitationSelectionView), - matching: find.byType(TextField), - ), - Users.user2.name, - ); - - await Future.delayed(const Duration(milliseconds: 250)); - await tester.testTextInput.receiveAction(TextInputAction.done); - - await Future.delayed(const Duration(milliseconds: 1000)); - await tester.pumpAndSettle(); - - await tester.tap( - find - .descendant( - of: find.descendant( - of: find.byType(InvitationSelectionView), - matching: find.byType(ListTile), - ), - matching: find.text(Users.user2.name), - ) - .last, - ); - await tester.pumpAndSettle(); - - await tester.waitFor(find.maybeUppercaseText('Yes')); - await tester.tap(find.maybeUppercaseText('Yes')); - await tester.pumpAndSettle(); - - await tester.tap(find.byTooltip('Back')); - await tester.pumpAndSettle(); - - await tester.waitFor(find.text('Load 2 more participants')); - await tester.tap(find.text('Load 2 more participants')); - await tester.pumpAndSettle(); - - expect(find.text(Users.user2.name), findsOneWidget); - }); - }, - ); -} diff --git a/integration_test/data/integration_users.env b/integration_test/data/integration_users.env new file mode 100644 index 000000000..455ce8471 --- /dev/null +++ b/integration_test/data/integration_users.env @@ -0,0 +1,5 @@ +HOMESERVER=localhost +USER1_NAME=alice +USER1_PW=AliceInWonderland +USER2_NAME=bob +USER2_PW=JoWirSchaffenDas \ No newline at end of file diff --git a/integration_test/extensions/default_flows.dart b/integration_test/extensions/default_flows.dart deleted file mode 100644 index 660996900..000000000 --- a/integration_test/extensions/default_flows.dart +++ /dev/null @@ -1,171 +0,0 @@ -import 'dart:developer'; - -import 'package:fluffychat/pages/chat_list/chat_list_body.dart'; -import 'package:fluffychat/pages/homeserver_picker/homeserver_picker.dart'; -import 'package:flutter/material.dart'; -import 'package:flutter_test/flutter_test.dart'; - -import '../users.dart'; -import 'wait_for.dart'; - -extension DefaultFlowExtensions on WidgetTester { - Future login() async { - final tester = this; - - await tester.pumpAndSettle(); - - await tester.waitFor(find.text('Let\'s start')); - - expect(find.text('Let\'s start'), findsOneWidget); - - final input = find.byType(TextField); - - expect(input, findsOneWidget); - - // getting the placeholder in place - await tester.tap(find.byIcon(Icons.search)); - await tester.pumpAndSettle(); - await tester.enterText(input, homeserver); - await tester.pumpAndSettle(); - await tester.testTextInput.receiveAction(TextInputAction.done); - await tester.pumpAndSettle(); - - // in case registration is allowed - // try { - await Future.delayed(const Duration(milliseconds: 50)); - - await tester.scrollUntilVisible( - find.text('Login'), - 500, - scrollable: find.descendant( - of: find.byKey(const Key('ConnectPageListView')), - matching: find.byType(Scrollable).first, - ), - ); - await tester.pumpAndSettle(); - - await tester.tap(find.text('Login')); - await tester.pumpAndSettle(); - /*} catch (e) { - log('Registration is not allowed. Proceeding with login...'); - }*/ - await tester.pumpAndSettle(); - - await Future.delayed(const Duration(milliseconds: 50)); - - final inputs = find.byType(TextField); - - await tester.enterText(inputs.first, Users.user1.name); - await tester.enterText(inputs.last, Users.user1.password); - await tester.pumpAndSettle(); - await tester.testTextInput.receiveAction(TextInputAction.done); - - try { - // pumpAndSettle does not work in here as setState is called - // asynchronously - await tester.waitFor( - find.byType(LinearProgressIndicator), - timeout: const Duration(milliseconds: 1500), - skipPumpAndSettle: true, - ); - } catch (_) { - // in case the input action does not work on the desired platform - if (find.text('Login').evaluate().isNotEmpty) { - await tester.tap(find.text('Login')); - } - } - - try { - await tester.pumpAndSettle(); - } catch (_) { - // may fail because of ongoing animation below dialog - } - - await tester.waitFor( - find.byType(ChatListViewBody), - skipPumpAndSettle: true, - ); - } - - /// ensure PushProvider check passes - Future acceptPushWarning() async { - final tester = this; - - final matcher = find.maybeUppercaseText('Do not show again'); - - try { - await tester.waitFor(matcher, timeout: const Duration(seconds: 5)); - - // the FCM push error dialog to be handled... - await tester.tap(matcher); - await tester.pumpAndSettle(); - } catch (_) {} - } - - Future ensureLoggedOut() async { - final tester = this; - await tester.pumpAndSettle(); - if (find.byType(ChatListViewBody).evaluate().isNotEmpty) { - await tester.tap(find.byTooltip('Show menu')); - await tester.pumpAndSettle(); - await tester.tap(find.text('Settings')); - await tester.pumpAndSettle(); - await tester.scrollUntilVisible( - find.text('Account'), - 500, - scrollable: find.descendant( - of: find.byKey(const Key('SettingsListViewContent')), - matching: find.byType(Scrollable), - ), - ); - await tester.pumpAndSettle(); - await tester.tap(find.text('Logout')); - await tester.pumpAndSettle(); - await tester.tap(find.maybeUppercaseText('Yes')); - await tester.pumpAndSettle(); - } - } - - Future ensureAppStartedHomescreen({ - Duration timeout = const Duration(seconds: 20), - }) async { - final tester = this; - await tester.pumpAndSettle(); - - final homeserverPickerFinder = find.byType(HomeserverPicker); - final chatListFinder = find.byType(ChatListViewBody); - - final end = DateTime.now().add(timeout); - - log( - 'Waiting for HomeserverPicker or ChatListViewBody...', - name: 'Test Runner', - ); - do { - if (DateTime.now().isAfter(end)) { - throw Exception( - 'Timed out waiting for HomeserverPicker or ChatListViewBody', - ); - } - - await pumpAndSettle(); - await Future.delayed(const Duration(milliseconds: 100)); - } while (homeserverPickerFinder.evaluate().isEmpty && - chatListFinder.evaluate().isEmpty); - - if (homeserverPickerFinder.evaluate().isNotEmpty) { - log( - 'Found HomeserverPicker, performing login.', - name: 'Test Runner', - ); - await tester.login(); - } else { - log( - 'Found ChatListViewBody, skipping login.', - name: 'Test Runner', - ); - } - - await tester.acceptPushWarning(); - } -} diff --git a/integration_test/extensions/wait_for.dart b/integration_test/extensions/wait_for.dart deleted file mode 100644 index cfd9d649c..000000000 --- a/integration_test/extensions/wait_for.dart +++ /dev/null @@ -1,49 +0,0 @@ -import 'package:flutter_test/flutter_test.dart'; - -/// Workaround for https://github.com/flutter/flutter/issues/88765 -extension WaitForExtension on WidgetTester { - Future waitFor( - Finder finder, { - Duration timeout = const Duration(seconds: 20), - bool skipPumpAndSettle = false, - }) async { - final end = DateTime.now().add(timeout); - - do { - if (DateTime.now().isAfter(end)) { - throw Exception('Timed out waiting for $finder'); - } - - if (!skipPumpAndSettle) { - await pumpAndSettle(); - } - await Future.delayed(const Duration(milliseconds: 100)); - } while (finder.evaluate().isEmpty); - } -} - -extension MaybeUppercaseFinder on CommonFinders { - /// On Android some button labels are in uppercase while on iOS they - /// are not. This method tries both. - Finder maybeUppercaseText( - String text, { - bool findRichText = false, - bool skipOffstage = true, - }) { - try { - final finder = find.text( - text.toUpperCase(), - findRichText: findRichText, - skipOffstage: skipOffstage, - ); - expect(finder, findsOneWidget); - return finder; - } catch (_) { - return find.text( - text, - findRichText: findRichText, - skipOffstage: skipOffstage, - ); - } - } -} diff --git a/integration_test/login.yaml b/integration_test/login.yaml new file mode 100644 index 000000000..d32c255a1 --- /dev/null +++ b/integration_test/login.yaml @@ -0,0 +1,31 @@ +appId: chat.fluffy.fluffychat +--- +- assertVisible: "Sign in" +- tapOn: "Sign in" +- tapOn: "Search or enter homeserver address" +- inputText: "http://${HOMESERVER}" +- pressKey: "back" +- tapOn: + id: "homeserver_tile_0" +- tapOn: + id: "connect_to_homeserver_button" +- assertVisible: "Log in to http://${HOMESERVER}" +- inputText: "${USER1_NAME}" +- tapOn: "Password" +- inputText: "${USER1_PW}" +- tapOn: "Login" # Click the login button +- tapOn: + id: "store_in_secure_storage" +- tapOn: "Next" +- tapOn: + text: "Close" + index: 1 +- assertVisible: "Push notifications not available" +- tapOn: "Do not show again" +- tapOn: + id: "accounts_and_settings" # Open the popup menu +- tapOn: "Settings" +- scrollUntilVisible: + element: "Logout" +- tapOn: "Logout" +- tapOn: "Logout" # Confirm logout dialog \ No newline at end of file diff --git a/integration_test/users.dart b/integration_test/users.dart deleted file mode 100644 index 8af999e99..000000000 --- a/integration_test/users.dart +++ /dev/null @@ -1,36 +0,0 @@ -abstract class Users { - const Users._(); - - static const user1 = User( - String.fromEnvironment( - 'USER1_NAME', - defaultValue: 'alice', - ), - String.fromEnvironment( - 'USER1_PW', - defaultValue: 'AliceInWonderland', - ), - ); - static const user2 = User( - String.fromEnvironment( - 'USER2_NAME', - defaultValue: 'bob', - ), - String.fromEnvironment( - 'USER2_PW', - defaultValue: 'JoWirSchaffenDas', - ), - ); -} - -class User { - final String name; - final String password; - - const User(this.name, this.password); -} - -const homeserver = 'http://${const String.fromEnvironment( - 'HOMESERVER', - defaultValue: 'localhost', -)}'; diff --git a/ios/FluffyChat Share/Info.plist b/ios/FluffyChat Share/Info.plist index d3a136ec5..876e55957 100644 --- a/ios/FluffyChat Share/Info.plist +++ b/ios/FluffyChat Share/Info.plist @@ -27,11 +27,11 @@ NSExtensionActivationRule NSExtensionActivationSupportsFileWithMaxCount - 1 + 10 NSExtensionActivationSupportsImageWithMaxCount - 1 + 10 NSExtensionActivationSupportsMovieWithMaxCount - 1 + 10 NSExtensionActivationSupportsText NSExtensionActivationSupportsWebURLWithMaxCount diff --git a/ios/FluffyChat Share/ShareViewController.swift b/ios/FluffyChat Share/ShareViewController.swift index 96d921432..4d10e6bd8 100644 --- a/ios/FluffyChat Share/ShareViewController.swift +++ b/ios/FluffyChat Share/ShareViewController.swift @@ -1,335 +1,14 @@ -import UIKit -import Social -import MobileCoreServices -import Photos +// If you get no such module 'receive_sharing_intent' error. +// Go to Build Phases of your Runner target and +// move `Embed Foundation Extension` to the top of `Thin Binary`. +import receive_sharing_intent -class ShareViewController: SLComposeServiceViewController { - // TODO: IMPORTANT: This should be your host app bundle identifier - let hostAppBundleIdentifier = "im.fluffychat.app" - let sharedKey = "ShareKey" - var sharedMedia: [SharedMediaFile] = [] - var sharedText: [String] = [] - let imageContentType = kUTTypeImage as String - let videoContentType = kUTTypeMovie as String - let textContentType = kUTTypeText as String - let urlContentType = kUTTypeURL as String - let fileURLType = kUTTypeFileURL as String; - - override func isContentValid() -> Bool { - return true - } - - override func viewDidLoad() { - super.viewDidLoad(); - } - - override func viewDidAppear(_ animated: Bool) { - super.viewDidAppear(animated) - - // This is called after the user selects Post. Do the upload of contentText and/or NSExtensionContext attachments. - if let content = extensionContext!.inputItems[0] as? NSExtensionItem { - if let contents = content.attachments { - for (index, attachment) in (contents).enumerated() { - if attachment.hasItemConformingToTypeIdentifier(imageContentType) { - handleImages(content: content, attachment: attachment, index: index) - } else if attachment.hasItemConformingToTypeIdentifier(textContentType) { - handleText(content: content, attachment: attachment, index: index) - } else if attachment.hasItemConformingToTypeIdentifier(fileURLType) { - handleFiles(content: content, attachment: attachment, index: index) - } else if attachment.hasItemConformingToTypeIdentifier(urlContentType) { - handleUrl(content: content, attachment: attachment, index: index) - } else if attachment.hasItemConformingToTypeIdentifier(videoContentType) { - handleVideos(content: content, attachment: attachment, index: index) - } - } - } - } - } - - override func didSelectPost() { - print("didSelectPost"); - } - - override func configurationItems() -> [Any]! { - // To add configuration options via table cells at the bottom of the sheet, return an array of SLComposeSheetConfigurationItem here. - return [] - } - - private func handleText (content: NSExtensionItem, attachment: NSItemProvider, index: Int) { - attachment.loadItem(forTypeIdentifier: textContentType, options: nil) { [weak self] data, error in - - if error == nil, let item = data as? String, let this = self { - - this.sharedText.append(item) - - // If this is the last item, save imagesData in userDefaults and redirect to host app - if index == (content.attachments?.count)! - 1 { - let userDefaults = UserDefaults(suiteName: "group.\(this.hostAppBundleIdentifier)") - userDefaults?.set(this.sharedText, forKey: this.sharedKey) - userDefaults?.synchronize() - this.redirectToHostApp(type: .text) - } - - } else { - self?.dismissWithError() - } - } - } - - private func handleUrl (content: NSExtensionItem, attachment: NSItemProvider, index: Int) { - attachment.loadItem(forTypeIdentifier: urlContentType, options: nil) { [weak self] data, error in - - if error == nil, let item = data as? URL, let this = self { - - this.sharedText.append(item.absoluteString) - - // If this is the last item, save imagesData in userDefaults and redirect to host app - if index == (content.attachments?.count)! - 1 { - let userDefaults = UserDefaults(suiteName: "group.\(this.hostAppBundleIdentifier)") - userDefaults?.set(this.sharedText, forKey: this.sharedKey) - userDefaults?.synchronize() - this.redirectToHostApp(type: .text) - } - - } else { - self?.dismissWithError() - } - } - } - - private func handleImages (content: NSExtensionItem, attachment: NSItemProvider, index: Int) { - attachment.loadItem(forTypeIdentifier: imageContentType, options: nil) { [weak self] data, error in - - if error == nil, let url = data as? URL, let this = self { - - // Always copy - let fileName = this.getFileName(from: url, type: .image) - let newPath = FileManager.default - .containerURL(forSecurityApplicationGroupIdentifier: "group.\(this.hostAppBundleIdentifier)")! - .appendingPathComponent(fileName) - let copied = this.copyFile(at: url, to: newPath) - if(copied) { - this.sharedMedia.append(SharedMediaFile(path: newPath.absoluteString, thumbnail: nil, duration: nil, type: .image)) - } - - // If this is the last item, save imagesData in userDefaults and redirect to host app - if index == (content.attachments?.count)! - 1 { - let userDefaults = UserDefaults(suiteName: "group.\(this.hostAppBundleIdentifier)") - userDefaults?.set(this.toData(data: this.sharedMedia), forKey: this.sharedKey) - userDefaults?.synchronize() - this.redirectToHostApp(type: .media) - } - - } else { - self?.dismissWithError() - } - } - } - - private func handleVideos (content: NSExtensionItem, attachment: NSItemProvider, index: Int) { - attachment.loadItem(forTypeIdentifier: videoContentType, options: nil) { [weak self] data, error in - - if error == nil, let url = data as? URL, let this = self { - - // Always copy - let fileName = this.getFileName(from: url, type: .video) - let newPath = FileManager.default - .containerURL(forSecurityApplicationGroupIdentifier: "group.\(this.hostAppBundleIdentifier)")! - .appendingPathComponent(fileName) - let copied = this.copyFile(at: url, to: newPath) - if(copied) { - guard let sharedFile = this.getSharedMediaFile(forVideo: newPath) else { - return - } - this.sharedMedia.append(sharedFile) - } - - // If this is the last item, save imagesData in userDefaults and redirect to host app - if index == (content.attachments?.count)! - 1 { - let userDefaults = UserDefaults(suiteName: "group.\(this.hostAppBundleIdentifier)") - userDefaults?.set(this.toData(data: this.sharedMedia), forKey: this.sharedKey) - userDefaults?.synchronize() - this.redirectToHostApp(type: .media) - } - - } else { - self?.dismissWithError() - } - } - } - - private func handleFiles (content: NSExtensionItem, attachment: NSItemProvider, index: Int) { - attachment.loadItem(forTypeIdentifier: fileURLType, options: nil) { [weak self] data, error in - - if error == nil, let url = data as? URL, let this = self { - - // Always copy - let fileName = this.getFileName(from :url, type: .file) - let newPath = FileManager.default - .containerURL(forSecurityApplicationGroupIdentifier: "group.\(this.hostAppBundleIdentifier)")! - .appendingPathComponent(fileName) - let copied = this.copyFile(at: url, to: newPath) - if (copied) { - this.sharedMedia.append(SharedMediaFile(path: newPath.absoluteString, thumbnail: nil, duration: nil, type: .file)) - } - - if index == (content.attachments?.count)! - 1 { - let userDefaults = UserDefaults(suiteName: "group.\(this.hostAppBundleIdentifier)") - userDefaults?.set(this.toData(data: this.sharedMedia), forKey: this.sharedKey) - userDefaults?.synchronize() - this.redirectToHostApp(type: .file) - } - - } else { - self?.dismissWithError() - } - } - } - - private func dismissWithError() { - print("[ERROR] Error loading data!") - let alert = UIAlertController(title: "Error", message: "Error loading data", preferredStyle: .alert) - - let action = UIAlertAction(title: "Error", style: .cancel) { _ in - self.dismiss(animated: true, completion: nil) - } - - alert.addAction(action) - present(alert, animated: true, completion: nil) - extensionContext!.completeRequest(returningItems: [], completionHandler: nil) - } - - private func redirectToHostApp(type: RedirectType) { - let url = URL(string: "ShareMedia://dataUrl=\(sharedKey)#\(type)") - var responder = self as UIResponder? - let selectorOpenURL = sel_registerName("openURL:") - - while (responder != nil) { - if (responder?.responds(to: selectorOpenURL))! { - let _ = responder?.perform(selectorOpenURL, with: url) - } - responder = responder!.next - } - extensionContext!.completeRequest(returningItems: [], completionHandler: nil) - } - - enum RedirectType { - case media - case text - case file - } - - func getExtension(from url: URL, type: SharedMediaType) -> String { - let parts = url.lastPathComponent.components(separatedBy: ".") - var ex: String? = nil - if (parts.count > 1) { - ex = parts.last - } - - if (ex == nil) { - switch type { - case .image: - ex = "PNG" - case .video: - ex = "MP4" - case .file: - ex = "TXT" - } - } - return ex ?? "Unknown" - } - - func getFileName(from url: URL, type: SharedMediaType) -> String { - var name = url.lastPathComponent - - if (name.isEmpty) { - name = UUID().uuidString + "." + getExtension(from: url, type: type) - } - - return name - } - - func copyFile(at srcURL: URL, to dstURL: URL) -> Bool { - do { - if FileManager.default.fileExists(atPath: dstURL.path) { - try FileManager.default.removeItem(at: dstURL) - } - try FileManager.default.copyItem(at: srcURL, to: dstURL) - } catch (let error) { - print("Cannot copy item at \(srcURL) to \(dstURL): \(error)") - return false - } - return true - } - - private func getSharedMediaFile(forVideo: URL) -> SharedMediaFile? { - let asset = AVAsset(url: forVideo) - let duration = (CMTimeGetSeconds(asset.duration) * 1000).rounded() - let thumbnailPath = getThumbnailPath(for: forVideo) - - if FileManager.default.fileExists(atPath: thumbnailPath.path) { - return SharedMediaFile(path: forVideo.absoluteString, thumbnail: thumbnailPath.absoluteString, duration: duration, type: .video) - } - - var saved = false - let assetImgGenerate = AVAssetImageGenerator(asset: asset) - assetImgGenerate.appliesPreferredTrackTransform = true - // let scale = UIScreen.main.scale - assetImgGenerate.maximumSize = CGSize(width: 360, height: 360) - do { - let img = try assetImgGenerate.copyCGImage(at: CMTimeMakeWithSeconds(600, preferredTimescale: Int32(1.0)), actualTime: nil) - try UIImage.pngData(UIImage(cgImage: img))()?.write(to: thumbnailPath) - saved = true - } catch { - saved = false - } - - return saved ? SharedMediaFile(path: forVideo.absoluteString, thumbnail: thumbnailPath.absoluteString, duration: duration, type: .video) : nil - - } - - private func getThumbnailPath(for url: URL) -> URL { - let fileName = Data(url.lastPathComponent.utf8).base64EncodedString().replacingOccurrences(of: "==", with: "") - let path = FileManager.default - .containerURL(forSecurityApplicationGroupIdentifier: "group.\(hostAppBundleIdentifier)")! - .appendingPathComponent("\(fileName).jpg") - return path - } - - class SharedMediaFile: Codable { - var path: String; // can be image, video or url path. It can also be text content - var thumbnail: String?; // video thumbnail - var duration: Double?; // video duration in milliseconds - var type: SharedMediaType; - - - init(path: String, thumbnail: String?, duration: Double?, type: SharedMediaType) { - self.path = path - self.thumbnail = thumbnail - self.duration = duration - self.type = type - } - - // Debug method to print out SharedMediaFile details in the console - func toString() { - print("[SharedMediaFile] \n\tpath: \(self.path)\n\tthumbnail: \(self.thumbnail)\n\tduration: \(self.duration)\n\ttype: \(self.type)") - } - } - - enum SharedMediaType: Int, Codable { - case image - case video - case file - } - - func toData(data: [SharedMediaFile]) -> Data { - let encodedData = try? JSONEncoder().encode(data) - return encodedData! +class ShareViewController: RSIShareViewController { + + // Use this method to return false if you don't want to redirect to host app automatically. + // Default is true + override func shouldAutoRedirect() -> Bool { + return false } + } - -extension Array { - subscript (safe index: UInt) -> Element? { - return Int(index) < count ? self[Int(index)] : nil - } -} \ No newline at end of file diff --git a/ios/Flutter/AppFrameworkInfo.plist b/ios/Flutter/AppFrameworkInfo.plist index 8c6e56146..ab8e063fe 100644 --- a/ios/Flutter/AppFrameworkInfo.plist +++ b/ios/Flutter/AppFrameworkInfo.plist @@ -20,7 +20,5 @@ ???? CFBundleVersion 1.0 - MinimumOSVersion - 12.0 diff --git a/ios/Flutter/ephemeral/flutter_lldb_helper.py b/ios/Flutter/ephemeral/flutter_lldb_helper.py new file mode 100644 index 000000000..a88caf99d --- /dev/null +++ b/ios/Flutter/ephemeral/flutter_lldb_helper.py @@ -0,0 +1,32 @@ +# +# Generated file, do not edit. +# + +import lldb + +def handle_new_rx_page(frame: lldb.SBFrame, bp_loc, extra_args, intern_dict): + """Intercept NOTIFY_DEBUGGER_ABOUT_RX_PAGES and touch the pages.""" + base = frame.register["x0"].GetValueAsAddress() + page_len = frame.register["x1"].GetValueAsUnsigned() + + # Note: NOTIFY_DEBUGGER_ABOUT_RX_PAGES will check contents of the + # first page to see if handled it correctly. This makes diagnosing + # misconfiguration (e.g. missing breakpoint) easier. + data = bytearray(page_len) + data[0:8] = b'IHELPED!' + + error = lldb.SBError() + frame.GetThread().GetProcess().WriteMemory(base, data, error) + if not error.Success(): + print(f'Failed to write into {base}[+{page_len}]', error) + return + +def __lldb_init_module(debugger: lldb.SBDebugger, _): + target = debugger.GetDummyTarget() + # Caveat: must use BreakpointCreateByRegEx here and not + # BreakpointCreateByName. For some reasons callback function does not + # get carried over from dummy target for the later. + bp = target.BreakpointCreateByRegex("^NOTIFY_DEBUGGER_ABOUT_RX_PAGES$") + bp.SetScriptCallbackFunction('{}.handle_new_rx_page'.format(__name__)) + bp.SetAutoContinue(True) + print("-- LLDB integration loaded --") diff --git a/ios/Flutter/ephemeral/flutter_lldbinit b/ios/Flutter/ephemeral/flutter_lldbinit new file mode 100644 index 000000000..e3ba6fbed --- /dev/null +++ b/ios/Flutter/ephemeral/flutter_lldbinit @@ -0,0 +1,5 @@ +# +# Generated file, do not edit. +# + +command script import --relative-to-command-file flutter_lldb_helper.py diff --git a/ios/Gemfile b/ios/Gemfile index 7a118b49b..0bc467d85 100644 --- a/ios/Gemfile +++ b/ios/Gemfile @@ -1,3 +1,8 @@ source "https://rubygems.org" gem "fastlane" + +# Workaround for ruby 3.4 https://github.com/fastlane/fastlane/issues/29183 +gem "abbrev" +gem "mutex_m" +gem "ostruct" \ No newline at end of file diff --git a/ios/Gemfile.lock b/ios/Gemfile.lock index aaaffc7b4..d7d0fcce1 100644 --- a/ios/Gemfile.lock +++ b/ios/Gemfile.lock @@ -2,27 +2,33 @@ GEM remote: https://rubygems.org/ specs: CFPropertyList (3.0.3) + abbrev (0.1.2) addressable (2.8.4) public_suffix (>= 2.0.2, < 6.0) artifactory (3.0.15) atomos (0.1.3) - aws-eventstream (1.1.1) - aws-partitions (1.469.0) - aws-sdk-core (3.114.3) - aws-eventstream (~> 1, >= 1.0.2) - aws-partitions (~> 1, >= 1.239.0) - aws-sigv4 (~> 1.1) - jmespath (~> 1.0) - aws-sdk-kms (1.44.0) - aws-sdk-core (~> 3, >= 3.112.0) - aws-sigv4 (~> 1.1) - aws-sdk-s3 (1.96.1) - aws-sdk-core (~> 3, >= 3.112.0) + aws-eventstream (1.4.0) + aws-partitions (1.1213.0) + aws-sdk-core (3.242.0) + aws-eventstream (~> 1, >= 1.3.0) + aws-partitions (~> 1, >= 1.992.0) + aws-sigv4 (~> 1.9) + base64 + bigdecimal + jmespath (~> 1, >= 1.6.1) + logger + aws-sdk-kms (1.121.0) + aws-sdk-core (~> 3, >= 3.241.4) + aws-sigv4 (~> 1.5) + aws-sdk-s3 (1.208.0) + aws-sdk-core (~> 3, >= 3.234.0) aws-sdk-kms (~> 1) - aws-sigv4 (~> 1.1) - aws-sigv4 (1.2.3) + aws-sigv4 (~> 1.5) + aws-sigv4 (1.12.1) aws-eventstream (~> 1, >= 1.0.2) babosa (1.0.4) + base64 (0.3.0) + bigdecimal (4.0.1) claide (1.0.3) colored (1.2) colored2 (3.1.2) @@ -36,22 +42,32 @@ GEM dotenv (2.7.6) emoji_regex (3.2.2) excon (0.82.0) - faraday (1.4.2) + faraday (1.10.5) faraday-em_http (~> 1.0) faraday-em_synchrony (~> 1.0) faraday-excon (~> 1.1) + faraday-httpclient (~> 1.0) + faraday-multipart (~> 1.0) faraday-net_http (~> 1.0) - faraday-net_http_persistent (~> 1.1) - multipart-post (>= 1.2, < 3) + faraday-net_http_persistent (~> 1.0) + faraday-patron (~> 1.0) + faraday-rack (~> 1.0) + faraday-retry (~> 1.0) ruby2_keywords (>= 0.0.4) faraday-cookie_jar (0.0.7) faraday (>= 0.8.0) http-cookie (~> 1.0.0) faraday-em_http (1.0.0) - faraday-em_synchrony (1.0.0) + faraday-em_synchrony (1.0.1) faraday-excon (1.1.0) - faraday-net_http (1.0.1) - faraday-net_http_persistent (1.1.0) + faraday-httpclient (1.0.1) + faraday-multipart (1.2.0) + multipart-post (~> 2.0) + faraday-net_http (1.0.2) + faraday-net_http_persistent (1.2.0) + faraday-patron (1.0.0) + faraday-rack (1.0.0) + faraday-retry (1.0.3) faraday_middleware (1.0.0) faraday (~> 1.0) fastimage (2.2.4) @@ -140,14 +156,17 @@ GEM jmespath (1.6.2) json (2.5.1) jwt (2.2.3) + logger (1.7.0) memoist (0.16.2) mini_magick (4.11.0) mini_mime (1.1.0) multi_json (1.15.0) multipart-post (2.0.0) + mutex_m (0.3.0) nanaimo (0.3.0) naturally (2.2.1) os (1.1.1) + ostruct (0.6.3) plist (3.6.0) public_suffix (5.0.3) rake (13.0.3) @@ -156,10 +175,9 @@ GEM trailblazer-option (>= 0.1.1, < 0.2.0) uber (< 0.2.0) retriable (3.1.2) - rexml (3.2.8) - strscan (>= 3.0.9) + rexml (3.4.2) rouge (2.0.7) - ruby2_keywords (0.0.4) + ruby2_keywords (0.0.5) rubyzip (2.3.0) security (0.1.3) signet (0.15.0) @@ -170,7 +188,6 @@ GEM simctl (1.6.8) CFPropertyList naturally - strscan (3.1.0) terminal-notifier (2.0.0) terminal-table (1.8.0) unicode-display_width (~> 1.1, >= 1.1.1) @@ -184,7 +201,7 @@ GEM unf_ext unf_ext (0.0.7.7) unicode-display_width (1.7.0) - webrick (1.7.0) + webrick (1.8.2) word_wrap (1.0.0) xcodeproj (1.19.0) CFPropertyList (>= 2.3.3, < 4.0) @@ -201,7 +218,10 @@ PLATFORMS ruby DEPENDENCIES + abbrev fastlane + mutex_m + ostruct BUNDLED WITH 2.1.4 diff --git a/ios/Localizable.xcstrings b/ios/Localizable.xcstrings new file mode 100644 index 000000000..7895903ad --- /dev/null +++ b/ios/Localizable.xcstrings @@ -0,0 +1,58 @@ +{ + "sourceLanguage" : "en", + "strings" : { + "%lld unread messages" : { + "comment" : "Default notification title", + "localizations" : { + "de" : { + "variations" : { + "plural" : { + "one" : { + "stringUnit" : { + "state" : "translated", + "value" : "Ungelesene Nachricht" + } + }, + "other" : { + "stringUnit" : { + "state" : "translated", + "value" : "%lld ungelesene nachrichten" + } + } + } + } + }, + "en" : { + "variations" : { + "plural" : { + "one" : { + "stringUnit" : { + "state" : "translated", + "value" : "Unread message" + } + }, + "other" : { + "stringUnit" : { + "state" : "new", + "value" : "%lld unread messages" + } + } + } + } + } + } + }, + "New message - open app to read" : { + "comment" : "Default notification body", + "localizations" : { + "de" : { + "stringUnit" : { + "state" : "translated", + "value" : "Neue Nachricht - App öffnen zum lesen" + } + } + } + } + }, + "version" : "1.0" +} \ No newline at end of file diff --git a/ios/Notification Service Extension/Info.plist b/ios/Notification Service Extension/Info.plist new file mode 100644 index 000000000..57421ebf9 --- /dev/null +++ b/ios/Notification Service Extension/Info.plist @@ -0,0 +1,13 @@ + + + + + NSExtension + + NSExtensionPointIdentifier + com.apple.usernotifications.service + NSExtensionPrincipalClass + $(PRODUCT_MODULE_NAME).NotificationService + + + diff --git a/ios/Notification Service Extension/Notification Service Extension.entitlements b/ios/Notification Service Extension/Notification Service Extension.entitlements new file mode 100644 index 000000000..932f3e01e --- /dev/null +++ b/ios/Notification Service Extension/Notification Service Extension.entitlements @@ -0,0 +1,10 @@ + + + + + com.apple.security.application-groups + + group.im.fluffychat.app + + + diff --git a/ios/Notification Service Extension/NotificationService.swift b/ios/Notification Service Extension/NotificationService.swift new file mode 100644 index 000000000..9d464e127 --- /dev/null +++ b/ios/Notification Service Extension/NotificationService.swift @@ -0,0 +1,63 @@ +// +// NotificationService.swift +// Notification Extension +// +// Created by Christian Pauly on 26.08.25. +// + +import UserNotifications +import os + +class NotificationService: UNNotificationServiceExtension { + + var contentHandler: ((UNNotificationContent) -> Void)? + var bestAttemptContent: UNMutableNotificationContent? + + override func didReceive(_ request: UNNotificationRequest, withContentHandler contentHandler: @escaping (UNNotificationContent) -> Void) { + self.contentHandler = contentHandler + bestAttemptContent = (request.content.mutableCopy() as? UNMutableNotificationContent) + + if let bestAttemptContent = bestAttemptContent { + // Uncomment to read the push message payload: + // os_log("[FluffyChatPushHelper] New message received: %{public}@", log: .default, type: .error, bestAttemptContent.userInfo) + os_log("[FluffyChatPushHelper] New message received") + + guard let roomId = bestAttemptContent.userInfo["room_id"] as? String, + let eventId = bestAttemptContent.userInfo["event_id"] as? String else { + os_log("[FluffyChatPushHelper] Room ID or Event ID is missing!") + let emptyContent = UNMutableNotificationContent() + contentHandler(emptyContent) + return + } + bestAttemptContent.threadIdentifier = roomId + + if + let jsonString = bestAttemptContent.userInfo["counts"] as? String, + let jsonData = jsonString.data(using: .utf8), + let jsonMap = try? JSONSerialization.jsonObject(with: jsonData, options: []) as? [String: Any], + let unread = jsonMap["unread"] as? Int { + bestAttemptContent.title = String( + localized: "\(unread) unread messages", + comment: "Default notification title" + ) + bestAttemptContent.badge = NSNumber(integerLiteral: unread) + } + + // TODO: Download and decrypt event to display a better body: + bestAttemptContent.body = String( + localized: "New message - open app to read", + comment: "Default notification body" + ) + + contentHandler(bestAttemptContent) + } + } + + override func serviceExtensionTimeWillExpire() { + // Called just before the extension will be terminated by the system. + // Use this as an opportunity to deliver your "best attempt" at modified content, otherwise the original push payload will be used. + if let contentHandler = contentHandler, let bestAttemptContent = bestAttemptContent { + contentHandler(bestAttemptContent) + } + } +} diff --git a/ios/Podfile b/ios/Podfile index c8df069d3..0b153ece5 100644 --- a/ios/Podfile +++ b/ios/Podfile @@ -1,5 +1,5 @@ # Uncomment this line to define a global platform for your project -platform :ios, '12.0' +platform :ios, '13.0' # CocoaPods analytics sends network stats synchronously affecting flutter build latency. ENV['COCOAPODS_DISABLE_STATS'] = 'true' @@ -32,6 +32,11 @@ target 'Runner' do use_modular_headers! flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__)) + + # From package https://pub.dev/packages/receive_sharing_intent + target 'FluffyChat Share' do + inherit! :search_paths + end end post_install do |installer| @@ -47,7 +52,7 @@ post_install do |installer| config.build_settings['ENABLE_BITCODE'] = 'NO' # see https://github.com/flutter-webrtc/flutter-webrtc/issues/1054 - config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '11.0' + config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '12.0' config.build_settings["EXCLUDED_ARCHS[sdk=iphonesimulator*]"] = 'arm64 i386' config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] ||= [ diff --git a/ios/Runner.xcodeproj/project.pbxproj b/ios/Runner.xcodeproj/project.pbxproj index 8d75b924a..8de7eea1d 100644 --- a/ios/Runner.xcodeproj/project.pbxproj +++ b/ios/Runner.xcodeproj/project.pbxproj @@ -9,6 +9,7 @@ /* Begin PBXBuildFile section */ 1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; }; 3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; }; + 609046320A2D7D2B0D36583B /* Pods_FluffyChat_Share.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = C9EB6E6475A19949A37A2634 /* Pods_FluffyChat_Share.framework */; }; 74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; }; 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; }; 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; }; @@ -18,6 +19,10 @@ C1005C48261071B5002F4F32 /* MainInterface.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = C1005C46261071B5002F4F32 /* MainInterface.storyboard */; }; C1005C4C261071B5002F4F32 /* FluffyChat Share.appex in Embed App Extensions */ = {isa = PBXBuildFile; fileRef = C1005C42261071B5002F4F32 /* FluffyChat Share.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; }; C137635E2AD1446100A8F905 /* notification.caf in Resources */ = {isa = PBXBuildFile; fileRef = C137635D2AD1446100A8F905 /* notification.caf */; }; + C14695592E642D400075F2F7 /* Notification Service Extension.appex in Embed App Extensions */ = {isa = PBXBuildFile; fileRef = C14695522E642D400075F2F7 /* Notification Service Extension.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; }; + C14695662E642E450075F2F7 /* Localizable.xcstrings in Resources */ = {isa = PBXBuildFile; fileRef = C14695652E642E450075F2F7 /* Localizable.xcstrings */; }; + C14695672E642E450075F2F7 /* Localizable.xcstrings in Resources */ = {isa = PBXBuildFile; fileRef = C14695652E642E450075F2F7 /* Localizable.xcstrings */; }; + C14695682E642E450075F2F7 /* Localizable.xcstrings in Resources */ = {isa = PBXBuildFile; fileRef = C14695652E642E450075F2F7 /* Localizable.xcstrings */; }; C149567C25C7274F00A16396 /* GoogleService-Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = C149567B25C7274F00A16396 /* GoogleService-Info.plist */; }; /* End PBXBuildFile section */ @@ -29,6 +34,13 @@ remoteGlobalIDString = C1005C41261071B5002F4F32; remoteInfo = "FluffyChat Share"; }; + C14695572E642D400075F2F7 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 97C146E61CF9000F007C117D /* Project object */; + proxyType = 1; + remoteGlobalIDString = C14695512E642D400075F2F7; + remoteInfo = "Notification Service Extension"; + }; /* End PBXContainerItemProxy section */ /* Begin PBXCopyFilesBuildPhase section */ @@ -49,6 +61,7 @@ dstSubfolderSpec = 13; files = ( C1005C4C261071B5002F4F32 /* FluffyChat Share.appex in Embed App Extensions */, + C14695592E642D400075F2F7 /* Notification Service Extension.appex in Embed App Extensions */, ); name = "Embed App Extensions"; runOnlyForDeploymentPostprocessing = 0; @@ -56,10 +69,12 @@ /* End PBXCopyFilesBuildPhase section */ /* Begin PBXFileReference section */ + 09545B0C8C397F94966EA956 /* Pods-FluffyChat Share.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-FluffyChat Share.debug.xcconfig"; path = "Target Support Files/Pods-FluffyChat Share/Pods-FluffyChat Share.debug.xcconfig"; sourceTree = ""; }; 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = ""; }; 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = ""; }; 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = ""; }; 50DEFC207B70632D9C56ED78 /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + 58F7B95D036AD8E67B27588D /* Pods-FluffyChat Share.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-FluffyChat Share.profile.xcconfig"; path = "Target Support Files/Pods-FluffyChat Share/Pods-FluffyChat Share.profile.xcconfig"; sourceTree = ""; }; 74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = ""; }; 74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; 76737C9A857D5FD6D2634A3F /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = ""; }; @@ -78,11 +93,36 @@ C1005C49261071B5002F4F32 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; C1005C53261072D4002F4F32 /* FluffyChat Share.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = "FluffyChat Share.entitlements"; sourceTree = ""; }; C137635D2AD1446100A8F905 /* notification.caf */ = {isa = PBXFileReference; lastKnownFileType = file; path = notification.caf; sourceTree = ""; }; + C14695522E642D400075F2F7 /* Notification Service Extension.appex */ = {isa = PBXFileReference; explicitFileType = "wrapper.app-extension"; includeInIndex = 0; path = "Notification Service Extension.appex"; sourceTree = BUILT_PRODUCTS_DIR; }; + C14695652E642E450075F2F7 /* Localizable.xcstrings */ = {isa = PBXFileReference; lastKnownFileType = text.json.xcstrings; path = Localizable.xcstrings; sourceTree = ""; }; C149567B25C7274F00A16396 /* GoogleService-Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = "GoogleService-Info.plist"; sourceTree = ""; }; C149567D25C7276200A16396 /* Runner.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = Runner.entitlements; sourceTree = ""; }; + C9EB6E6475A19949A37A2634 /* Pods_FluffyChat_Share.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_FluffyChat_Share.framework; sourceTree = BUILT_PRODUCTS_DIR; }; EA246783222E02DD03959891 /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = ""; }; + F3778959E67CDA0CDB0D97BC /* Pods-FluffyChat Share.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-FluffyChat Share.release.xcconfig"; path = "Target Support Files/Pods-FluffyChat Share/Pods-FluffyChat Share.release.xcconfig"; sourceTree = ""; }; /* End PBXFileReference section */ +/* Begin PBXFileSystemSynchronizedBuildFileExceptionSet section */ + C146955D2E642D400075F2F7 /* Exceptions for "Notification Service Extension" folder in "Notification Service Extension" target */ = { + isa = PBXFileSystemSynchronizedBuildFileExceptionSet; + membershipExceptions = ( + Info.plist, + ); + target = C14695512E642D400075F2F7 /* Notification Service Extension */; + }; +/* End PBXFileSystemSynchronizedBuildFileExceptionSet section */ + +/* Begin PBXFileSystemSynchronizedRootGroup section */ + C14695532E642D400075F2F7 /* Notification Service Extension */ = { + isa = PBXFileSystemSynchronizedRootGroup; + exceptions = ( + C146955D2E642D400075F2F7 /* Exceptions for "Notification Service Extension" folder in "Notification Service Extension" target */, + ); + path = "Notification Service Extension"; + sourceTree = ""; + }; +/* End PBXFileSystemSynchronizedRootGroup section */ + /* Begin PBXFrameworksBuildPhase section */ 97C146EB1CF9000F007C117D /* Frameworks */ = { isa = PBXFrameworksBuildPhase; @@ -93,6 +133,14 @@ runOnlyForDeploymentPostprocessing = 0; }; C1005C3F261071B5002F4F32 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 609046320A2D7D2B0D36583B /* Pods_FluffyChat_Share.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + C146954F2E642D400075F2F7 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; files = ( @@ -106,6 +154,7 @@ isa = PBXGroup; children = ( 50DEFC207B70632D9C56ED78 /* Pods_Runner.framework */, + C9EB6E6475A19949A37A2634 /* Pods_FluffyChat_Share.framework */, ); name = Frameworks; sourceTree = ""; @@ -124,9 +173,11 @@ 97C146E51CF9000F007C117D = { isa = PBXGroup; children = ( + C14695652E642E450075F2F7 /* Localizable.xcstrings */, 9740EEB11CF90186004384FC /* Flutter */, 97C146F01CF9000F007C117D /* Runner */, C1005C43261071B5002F4F32 /* FluffyChat Share */, + C14695532E642D400075F2F7 /* Notification Service Extension */, 97C146EF1CF9000F007C117D /* Products */, E89DCAC000D371640E94E65B /* Pods */, 075EE1BE25359E34308E0B78 /* Frameworks */, @@ -138,6 +189,7 @@ children = ( 97C146EE1CF9000F007C117D /* Runner.app */, C1005C42261071B5002F4F32 /* FluffyChat Share.appex */, + C14695522E642D400075F2F7 /* Notification Service Extension.appex */, ); name = Products; sourceTree = ""; @@ -177,6 +229,9 @@ 76737C9A857D5FD6D2634A3F /* Pods-Runner.debug.xcconfig */, EA246783222E02DD03959891 /* Pods-Runner.release.xcconfig */, 9DB2F3524376810E74C799A8 /* Pods-Runner.profile.xcconfig */, + 09545B0C8C397F94966EA956 /* Pods-FluffyChat Share.debug.xcconfig */, + F3778959E67CDA0CDB0D97BC /* Pods-FluffyChat Share.release.xcconfig */, + 58F7B95D036AD8E67B27588D /* Pods-FluffyChat Share.profile.xcconfig */, ); path = Pods; sourceTree = ""; @@ -195,14 +250,15 @@ 97C146EC1CF9000F007C117D /* Resources */, C1005C4D261071B5002F4F32 /* Embed App Extensions */, 9705A1C41CF9048500538489 /* Embed Frameworks */, - 3B06AD1E1E4923F5004D2608 /* Thin Binary */, F9C8EE392B9AB471149C306E /* [CP] Embed Pods Frameworks */, 064CBD7CE0D4CD6850C6880A /* [CP] Copy Pods Resources */, + 3B06AD1E1E4923F5004D2608 /* Thin Binary */, ); buildRules = ( ); dependencies = ( C1005C4B261071B5002F4F32 /* PBXTargetDependency */, + C14695582E642D400075F2F7 /* PBXTargetDependency */, ); name = Runner; productName = Runner; @@ -213,6 +269,7 @@ isa = PBXNativeTarget; buildConfigurationList = C1005C51261071B5002F4F32 /* Build configuration list for PBXNativeTarget "FluffyChat Share" */; buildPhases = ( + 67579C1EA0B5C7B918473158 /* [CP] Check Pods Manifest.lock */, C1005C3E261071B5002F4F32 /* Sources */, C1005C3F261071B5002F4F32 /* Frameworks */, C1005C40261071B5002F4F32 /* Resources */, @@ -226,13 +283,33 @@ productReference = C1005C42261071B5002F4F32 /* FluffyChat Share.appex */; productType = "com.apple.product-type.app-extension"; }; + C14695512E642D400075F2F7 /* Notification Service Extension */ = { + isa = PBXNativeTarget; + buildConfigurationList = C146955E2E642D400075F2F7 /* Build configuration list for PBXNativeTarget "Notification Service Extension" */; + buildPhases = ( + C146954E2E642D400075F2F7 /* Sources */, + C146954F2E642D400075F2F7 /* Frameworks */, + C14695502E642D400075F2F7 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + fileSystemSynchronizedGroups = ( + C14695532E642D400075F2F7 /* Notification Service Extension */, + ); + name = "Notification Service Extension"; + productName = "Notification Service Extension"; + productReference = C14695522E642D400075F2F7 /* Notification Service Extension.appex */; + productType = "com.apple.product-type.app-extension"; + }; /* End PBXNativeTarget section */ /* Begin PBXProject section */ 97C146E61CF9000F007C117D /* Project object */ = { isa = PBXProject; attributes = { - LastSwiftUpdateCheck = 1240; + LastSwiftUpdateCheck = 1640; LastUpgradeCheck = 1510; ORGANIZATIONNAME = ""; TargetAttributes = { @@ -243,23 +320,28 @@ C1005C41261071B5002F4F32 = { CreatedOnToolsVersion = 12.4; }; + C14695512E642D400075F2F7 = { + CreatedOnToolsVersion = 16.4; + }; }; }; buildConfigurationList = 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */; - compatibilityVersion = "Xcode 9.3"; developmentRegion = en; hasScannedForEncodings = 0; knownRegions = ( en, Base, + de, ); mainGroup = 97C146E51CF9000F007C117D; + preferredProjectObjectVersion = 77; productRefGroup = 97C146EF1CF9000F007C117D /* Products */; projectDirPath = ""; projectRoot = ""; targets = ( 97C146ED1CF9000F007C117D /* Runner */, C1005C41261071B5002F4F32 /* FluffyChat Share */, + C14695512E642D400075F2F7 /* Notification Service Extension */, ); }; /* End PBXProject section */ @@ -274,6 +356,7 @@ C149567C25C7274F00A16396 /* GoogleService-Info.plist in Resources */, C137635E2AD1446100A8F905 /* notification.caf in Resources */, 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */, + C14695672E642E450075F2F7 /* Localizable.xcstrings in Resources */, 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */, ); runOnlyForDeploymentPostprocessing = 0; @@ -282,10 +365,19 @@ isa = PBXResourcesBuildPhase; buildActionMask = 2147483647; files = ( + C14695682E642E450075F2F7 /* Localizable.xcstrings in Resources */, C1005C48261071B5002F4F32 /* MainInterface.storyboard in Resources */, ); runOnlyForDeploymentPostprocessing = 0; }; + C14695502E642D400075F2F7 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + C14695662E642E450075F2F7 /* Localizable.xcstrings in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; /* End PBXResourcesBuildPhase section */ /* Begin PBXShellScriptBuildPhase section */ @@ -320,7 +412,29 @@ ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin"; + shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin\n"; + }; + 67579C1EA0B5C7B918473158 /* [CP] Check Pods Manifest.lock */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputFileListPaths = ( + ); + inputPaths = ( + "${PODS_PODFILE_DIR_PATH}/Podfile.lock", + "${PODS_ROOT}/Manifest.lock", + ); + name = "[CP] Check Pods Manifest.lock"; + outputFileListPaths = ( + ); + outputPaths = ( + "$(DERIVED_FILE_DIR)/Pods-FluffyChat Share-checkManifestLockResult.txt", + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; + showEnvVarsInLog = 0; }; 8C9CCA7C5C45651F90C7BFDD /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; @@ -357,7 +471,7 @@ ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build"; + shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build\n"; }; F9C8EE392B9AB471149C306E /* [CP] Embed Pods Frameworks */ = { isa = PBXShellScriptBuildPhase; @@ -396,6 +510,13 @@ ); runOnlyForDeploymentPostprocessing = 0; }; + C146954E2E642D400075F2F7 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; /* End PBXSourcesBuildPhase section */ /* Begin PBXTargetDependency section */ @@ -404,6 +525,11 @@ target = C1005C41261071B5002F4F32 /* FluffyChat Share */; targetProxy = C1005C4A261071B5002F4F32 /* PBXContainerItemProxy */; }; + C14695582E642D400075F2F7 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = C14695512E642D400075F2F7 /* Notification Service Extension */; + targetProxy = C14695572E642D400075F2F7 /* PBXContainerItemProxy */; + }; /* End PBXTargetDependency section */ /* Begin PBXVariantGroup section */ @@ -475,10 +601,11 @@ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; GCC_WARN_UNUSED_FUNCTION = YES; GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 12.0; + IPHONEOS_DEPLOYMENT_TARGET = 12.1; MTL_ENABLE_DEBUG_INFO = NO; SDKROOT = iphoneos; SUPPORTED_PLATFORMS = iphoneos; + SWIFT_EMIT_LOC_STRINGS = YES; TARGETED_DEVICE_FAMILY = "1,2"; VALIDATE_PRODUCT = YES; }; @@ -492,6 +619,8 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; + CODE_SIGN_IDENTITY = "Apple Development"; + CODE_SIGN_STYLE = Automatic; CURRENT_PROJECT_VERSION = 1; DEVELOPMENT_TEAM = 4NXF6Z997G; ENABLE_BITCODE = NO; @@ -511,6 +640,7 @@ MARKETING_VERSION = 0.32.1; PRODUCT_BUNDLE_IDENTIFIER = im.fluffychat.app; PRODUCT_NAME = "$(TARGET_NAME)"; + PROVISIONING_PROFILE_SPECIFIER = ""; SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; SWIFT_VERSION = 5.0; VERSIONING_SYSTEM = "apple-generic"; @@ -564,10 +694,11 @@ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; GCC_WARN_UNUSED_FUNCTION = YES; GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 12.0; + IPHONEOS_DEPLOYMENT_TARGET = 12.1; MTL_ENABLE_DEBUG_INFO = YES; ONLY_ACTIVE_ARCH = YES; SDKROOT = iphoneos; + SWIFT_EMIT_LOC_STRINGS = YES; TARGETED_DEVICE_FAMILY = "1,2"; }; name = Debug; @@ -613,11 +744,12 @@ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; GCC_WARN_UNUSED_FUNCTION = YES; GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 12.0; + IPHONEOS_DEPLOYMENT_TARGET = 12.1; MTL_ENABLE_DEBUG_INFO = NO; SDKROOT = iphoneos; SUPPORTED_PLATFORMS = iphoneos; SWIFT_COMPILATION_MODE = wholemodule; + SWIFT_EMIT_LOC_STRINGS = YES; SWIFT_OPTIMIZATION_LEVEL = "-O"; TARGETED_DEVICE_FAMILY = "1,2"; VALIDATE_PRODUCT = YES; @@ -632,6 +764,8 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; + CODE_SIGN_IDENTITY = "Apple Development"; + CODE_SIGN_STYLE = Automatic; CURRENT_PROJECT_VERSION = 1; DEVELOPMENT_TEAM = 4NXF6Z997G; ENABLE_BITCODE = NO; @@ -651,6 +785,7 @@ MARKETING_VERSION = 0.32.1; PRODUCT_BUNDLE_IDENTIFIER = im.fluffychat.app; PRODUCT_NAME = "$(TARGET_NAME)"; + PROVISIONING_PROFILE_SPECIFIER = ""; SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; @@ -666,6 +801,8 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; + CODE_SIGN_IDENTITY = "Apple Development"; + CODE_SIGN_STYLE = Automatic; CURRENT_PROJECT_VERSION = 1; DEVELOPMENT_TEAM = 4NXF6Z997G; ENABLE_BITCODE = NO; @@ -685,6 +822,7 @@ MARKETING_VERSION = 0.32.1; PRODUCT_BUNDLE_IDENTIFIER = im.fluffychat.app; PRODUCT_NAME = "$(TARGET_NAME)"; + PROVISIONING_PROFILE_SPECIFIER = ""; SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; SWIFT_VERSION = 5.0; VERSIONING_SYSTEM = "apple-generic"; @@ -693,6 +831,7 @@ }; C1005C4E261071B5002F4F32 /* Debug */ = { isa = XCBuildConfiguration; + baseConfigurationReference = 09545B0C8C397F94966EA956 /* Pods-FluffyChat Share.debug.xcconfig */; buildSettings = { CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; @@ -719,6 +858,7 @@ PRODUCT_NAME = "$(TARGET_NAME)"; SKIP_INSTALL = YES; SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; + SWIFT_ENABLE_EXPLICIT_MODULES = NO; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; @@ -727,6 +867,7 @@ }; C1005C4F261071B5002F4F32 /* Release */ = { isa = XCBuildConfiguration; + baseConfigurationReference = F3778959E67CDA0CDB0D97BC /* Pods-FluffyChat Share.release.xcconfig */; buildSettings = { CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; @@ -751,6 +892,7 @@ PRODUCT_BUNDLE_IDENTIFIER = "im.fluffychat.app.FluffyChat-Share"; PRODUCT_NAME = "$(TARGET_NAME)"; SKIP_INSTALL = YES; + SWIFT_ENABLE_EXPLICIT_MODULES = NO; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; }; @@ -758,6 +900,7 @@ }; C1005C50261071B5002F4F32 /* Profile */ = { isa = XCBuildConfiguration; + baseConfigurationReference = 58F7B95D036AD8E67B27588D /* Pods-FluffyChat Share.profile.xcconfig */; buildSettings = { CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; @@ -782,6 +925,127 @@ PRODUCT_BUNDLE_IDENTIFIER = "im.fluffychat.app.FluffyChat-Share"; PRODUCT_NAME = "$(TARGET_NAME)"; SKIP_INSTALL = YES; + SWIFT_ENABLE_EXPLICIT_MODULES = NO; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Profile; + }; + C146955A2E642D400075F2F7 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CODE_SIGN_ENTITLEMENTS = "Notification Service Extension/Notification Service Extension.entitlements"; + CODE_SIGN_IDENTITY = "Apple Development"; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 1; + DEVELOPMENT_TEAM = 4NXF6Z997G; + ENABLE_USER_SCRIPT_SANDBOXING = YES; + GCC_C_LANGUAGE_STANDARD = gnu17; + GENERATE_INFOPLIST_FILE = YES; + INFOPLIST_FILE = "Notification Service Extension/Info.plist"; + INFOPLIST_KEY_CFBundleDisplayName = "Notification Service Extension"; + INFOPLIST_KEY_NSHumanReadableCopyright = ""; + IPHONEOS_DEPLOYMENT_TARGET = 18.5; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + "@executable_path/../../Frameworks", + ); + LOCALIZATION_PREFERS_STRING_CATALOGS = YES; + MARKETING_VERSION = 1.0; + MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; + MTL_FAST_MATH = YES; + PRODUCT_BUNDLE_IDENTIFIER = "im.fluffychat.app.Notification-Service-Extension"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + SWIFT_ACTIVE_COMPILATION_CONDITIONS = "DEBUG $(inherited)"; + SWIFT_EMIT_LOC_STRINGS = YES; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + C146955B2E642D400075F2F7 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CODE_SIGN_ENTITLEMENTS = "Notification Service Extension/Notification Service Extension.entitlements"; + CODE_SIGN_IDENTITY = "Apple Development"; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 1; + DEVELOPMENT_TEAM = 4NXF6Z997G; + ENABLE_USER_SCRIPT_SANDBOXING = YES; + GCC_C_LANGUAGE_STANDARD = gnu17; + GENERATE_INFOPLIST_FILE = YES; + INFOPLIST_FILE = "Notification Service Extension/Info.plist"; + INFOPLIST_KEY_CFBundleDisplayName = "Notification Service Extension"; + INFOPLIST_KEY_NSHumanReadableCopyright = ""; + IPHONEOS_DEPLOYMENT_TARGET = 18.5; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + "@executable_path/../../Frameworks", + ); + LOCALIZATION_PREFERS_STRING_CATALOGS = YES; + MARKETING_VERSION = 1.0; + MTL_FAST_MATH = YES; + PRODUCT_BUNDLE_IDENTIFIER = "im.fluffychat.app.Notification-Service-Extension"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + SWIFT_EMIT_LOC_STRINGS = YES; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Release; + }; + C146955C2E642D400075F2F7 /* Profile */ = { + isa = XCBuildConfiguration; + buildSettings = { + ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CODE_SIGN_ENTITLEMENTS = "Notification Service Extension/Notification Service Extension.entitlements"; + CODE_SIGN_IDENTITY = "Apple Development"; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 1; + DEVELOPMENT_TEAM = 4NXF6Z997G; + ENABLE_USER_SCRIPT_SANDBOXING = YES; + GCC_C_LANGUAGE_STANDARD = gnu17; + GENERATE_INFOPLIST_FILE = YES; + INFOPLIST_FILE = "Notification Service Extension/Info.plist"; + INFOPLIST_KEY_CFBundleDisplayName = "Notification Service Extension"; + INFOPLIST_KEY_NSHumanReadableCopyright = ""; + IPHONEOS_DEPLOYMENT_TARGET = 18.5; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + "@executable_path/../../Frameworks", + ); + LOCALIZATION_PREFERS_STRING_CATALOGS = YES; + MARKETING_VERSION = 1.0; + MTL_FAST_MATH = YES; + PRODUCT_BUNDLE_IDENTIFIER = "im.fluffychat.app.Notification-Service-Extension"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + SWIFT_EMIT_LOC_STRINGS = YES; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; }; @@ -820,6 +1084,16 @@ defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; + C146955E2E642D400075F2F7 /* Build configuration list for PBXNativeTarget "Notification Service Extension" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + C146955A2E642D400075F2F7 /* Debug */, + C146955B2E642D400075F2F7 /* Release */, + C146955C2E642D400075F2F7 /* Profile */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; /* End XCConfigurationList section */ }; rootObject = 97C146E61CF9000F007C117D /* Project object */; diff --git a/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme b/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme index e67b2808a..fc5ae0316 100644 --- a/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +++ b/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme @@ -26,6 +26,7 @@ buildConfiguration = "Debug" selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" + customLLDBInitFile = "$(SRCROOT)/Flutter/ephemeral/flutter_lldbinit" shouldUseLaunchSchemeArgsEnv = "YES"> @@ -45,11 +46,13 @@ buildConfiguration = "Debug" selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" + customLLDBInitFile = "$(SRCROOT)/Flutter/ephemeral/flutter_lldbinit" launchStyle = "0" useCustomWorkingDirectory = "NO" ignoresPersistentStateOnLaunch = "NO" debugDocumentVersioning = "YES" debugServiceExtension = "internal" + enableGPUValidationMode = "1" allowLocationSimulation = "YES"> diff --git a/ios/Runner/AppDelegate.swift b/ios/Runner/AppDelegate.swift index 9413c6971..6bea1100c 100644 --- a/ios/Runner/AppDelegate.swift +++ b/ios/Runner/AppDelegate.swift @@ -1,16 +1,16 @@ import UIKit import Flutter -@UIApplicationMain -@objc class AppDelegate: FlutterAppDelegate { +@main +@objc class AppDelegate: FlutterAppDelegate, FlutterImplicitEngineDelegate { override func application( _ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]? ) -> Bool { - GeneratedPluginRegistrant.register(with: self) - if #available(iOS 10.0, *) { - UNUserNotificationCenter.current().delegate = self as? UNUserNotificationCenterDelegate - } return super.application(application, didFinishLaunchingWithOptions: launchOptions) } + + func didInitializeImplicitFlutterEngine(_ engineBridge: FlutterImplicitEngineBridge) { + GeneratedPluginRegistrant.register(with: engineBridge.pluginRegistry) + } } diff --git a/ios/Runner/Info.plist b/ios/Runner/Info.plist index f53992f99..51765d1c9 100644 --- a/ios/Runner/Info.plist +++ b/ios/Runner/Info.plist @@ -33,7 +33,7 @@ im.fluffychat.app.uris CFBundleURLSchemes - ShareMedia + ShareMedia-$(PRODUCT_BUNDLE_IDENTIFIER) im.fluffychat matrix @@ -112,5 +112,26 @@ UIApplicationSupportsIndirectInputEvents + UIApplicationSceneManifest + + UIApplicationSupportsMultipleScenes + + UISceneConfigurations + + UIWindowSceneSessionRoleApplication + + + UISceneClassName + UIWindowScene + UISceneDelegateClassName + FlutterSceneDelegate + UISceneConfigurationName + flutter + UISceneStoryboardFile + Main + + + + diff --git a/l10n.yaml b/l10n.yaml index a714613ee..cc496de65 100644 --- a/l10n.yaml +++ b/l10n.yaml @@ -1,5 +1,7 @@ -arb-dir: assets/l10n +arb-dir: lib/l10n template-arb-file: intl_en.arb output-localization-file: l10n.dart output-class: L10n preferred-supported-locales: ["en"] +use-deferred-loading: true +nullable-getter: false \ No newline at end of file diff --git a/lib/config/app_config.dart b/lib/config/app_config.dart index 841d810ec..cedef2c13 100644 --- a/lib/config/app_config.dart +++ b/lib/config/app_config.dart @@ -1,112 +1,65 @@ import 'dart:ui'; -import 'package:matrix/matrix.dart'; - abstract class AppConfig { - static String _applicationName = 'FluffyChat'; - static String get applicationName => _applicationName; - static String? _applicationWelcomeMessage; - static String? get applicationWelcomeMessage => _applicationWelcomeMessage; - static String _defaultHomeserver = 'matrix.org'; - static String get defaultHomeserver => _defaultHomeserver; - static double fontSizeFactor = 1; - static const Color chatColor = primaryColor; - static Color? colorSchemeSeed = primaryColor; - static const double messageFontSize = 15.75; - static const bool allowOtherHomeservers = true; - static const bool enableRegistration = true; + // Const and final configuration values (immutable) static const Color primaryColor = Color(0xFF5625BA); static const Color primaryColorLight = Color(0xFFCCBDEA); static const Color secondaryColor = Color(0xFF41a2bc); - static String _privacyUrl = - 'https://github.com/krille-chan/fluffychat/blob/main/PRIVACY.md'; - static String get privacyUrl => _privacyUrl; - static const String enablePushTutorial = - 'https://github.com/krille-chan/fluffychat/wiki/Push-Notifications-without-Google-Services'; - static const String encryptionTutorial = - 'https://github.com/krille-chan/fluffychat/wiki/How-to-use-end-to-end-encryption-in-FluffyChat'; - static const String startChatTutorial = - 'https://github.com/krille-chan/fluffychat/wiki/How-to-Find-Users-in-FluffyChat'; - static const String appId = 'im.fluffychat.FluffyChat'; - static const String appOpenUrlScheme = 'im.fluffychat'; - static String _webBaseUrl = 'https://fluffychat.im/web'; - static String get webBaseUrl => _webBaseUrl; - static const String sourceCodeUrl = - 'https://github.com/krille-chan/fluffychat'; - static const String supportUrl = - 'https://github.com/krille-chan/fluffychat/issues'; - static final Uri newIssueUrl = Uri( - scheme: 'https', - host: 'github.com', - path: '/krille-chan/fluffychat/issues/new', - ); - static bool renderHtml = true; - static bool hideRedactedEvents = false; - static bool hideUnknownEvents = true; - static bool hideUnimportantStateEvents = true; - static bool separateChatTypes = false; - static bool autoplayImages = true; - static bool sendTypingNotifications = true; - static bool sendPublicReadReceipts = true; - static bool swipeRightToLeftToReply = true; - static bool? sendOnEnter; - static bool showPresences = true; - static bool experimentalVoip = false; + + static const Color chatColor = primaryColor; + static const double messageFontSize = 16.0; + static const bool allowOtherHomeservers = true; + static const bool enableRegistration = true; static const bool hideTypingUsernames = false; - static const bool hideAllStateEvents = false; + static const String inviteLinkPrefix = 'https://matrix.to/#/'; static const String deepLinkPrefix = 'im.fluffychat://chat/'; static const String schemePrefix = 'matrix:'; static const String pushNotificationsChannelId = 'fluffychat_push'; static const String pushNotificationsAppId = 'chat.fluffy.fluffychat'; - static const String pushNotificationsGatewayUrl = - 'https://push.fluffychat.im/_matrix/push/v1/notify'; - static const String pushNotificationsPusherFormat = 'event_id_only'; - static const String emojiFontName = 'Noto Emoji'; - static const String emojiFontUrl = - 'https://github.com/googlefonts/noto-emoji/'; static const double borderRadius = 18.0; + static const double spaceBorderRadius = 11.0; static const double columnWidth = 360.0; - static final Uri homeserverList = Uri( + + static const String website = 'https://fluffy.chat'; + static const String enablePushTutorial = + 'https://fluffy.chat/faq/#push_without_google_services'; + static const String encryptionTutorial = + 'https://fluffy.chat/faq/#how_to_use_end_to_end_encryption'; + static const String startChatTutorial = + 'https://fluffy.chat/faq/#how_do_i_find_other_users'; + static const String howDoIGetStickersTutorial = + 'https://fluffy.chat/faq/#how_do_i_get_stickers'; + static const String appId = 'im.fluffychat.FluffyChat'; + static const String appOpenUrlScheme = 'chat.fluffy'; + + static const String sourceCodeUrl = + 'https://github.com/krille-chan/fluffychat'; + static const String supportUrl = + 'https://github.com/krille-chan/fluffychat/issues'; + static const String changelogUrl = 'https://fluffy.chat/en/changelog/'; + static const String donationUrl = 'https://ko-fi.com/krille'; + + static const Set defaultReactions = {'👍', '❤️', '😂', '😮', '😢'}; + + static final Uri newIssueUrl = Uri( scheme: 'https', - host: 'servers.joinmatrix.org', - path: 'servers.json', + host: 'github.com', + path: '/krille-chan/fluffychat/issues/new', ); - static void loadFromJson(Map json) { - if (json['chat_color'] != null) { - try { - colorSchemeSeed = Color(json['chat_color']); - } catch (e) { - Logs().w( - 'Invalid color in config.json! Please make sure to define the color in this format: "0xffdd0000"', - e, - ); - } - } - if (json['application_name'] is String) { - _applicationName = json['application_name']; - } - if (json['application_welcome_message'] is String) { - _applicationWelcomeMessage = json['application_welcome_message']; - } - if (json['default_homeserver'] is String) { - _defaultHomeserver = json['default_homeserver']; - } - if (json['privacy_url'] is String) { - _webBaseUrl = json['privacy_url']; - } - if (json['web_base_url'] is String) { - _privacyUrl = json['web_base_url']; - } - if (json['render_html'] is bool) { - renderHtml = json['render_html']; - } - if (json['hide_redacted_events'] is bool) { - hideRedactedEvents = json['hide_redacted_events']; - } - if (json['hide_unknown_events'] is bool) { - hideUnknownEvents = json['hide_unknown_events']; - } - } + static final Uri homeserverList = Uri( + scheme: 'https', + host: 'raw.githubusercontent.com', + path: 'krille-chan/fluffychat/refs/heads/main/recommended_homeservers.json', + ); + + static final Uri privacyUrl = Uri( + scheme: 'https', + host: 'fluffy.chat', + path: '/en/privacy', + ); + + static const String mainIsolatePortName = 'main_isolate'; + static const String pushIsolatePortName = 'push_isolate'; } diff --git a/lib/config/app_emojis.dart b/lib/config/app_emojis.dart deleted file mode 100644 index 3c38e2fa8..000000000 --- a/lib/config/app_emojis.dart +++ /dev/null @@ -1,30 +0,0 @@ -abstract class AppEmojis { - static const List emojis = [ - '👍', - '😊', - '😀', - '❤️', - '😍', - '😘', - '😇', - '😅', - '😭', - '😜', - '😱', - '😆', - '😉', - '😡', - '👋', - '🤔', - '🙁', - '🥳', - '😟', - '😄', - '😁', - '🙄', - '😂', - '🤣', - '😌', - '😬', - ]; -} diff --git a/lib/config/isrg_x1.dart b/lib/config/isrg_x1.dart index 6a6d0ac2d..c7b503231 100644 --- a/lib/config/isrg_x1.dart +++ b/lib/config/isrg_x1.dart @@ -1,5 +1,5 @@ // ignore: constant_identifier_names -const String ISRG_X1 = """-----BEGIN CERTIFICATE----- +const String ISRG_X1 = '''-----BEGIN CERTIFICATE----- MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAw TzELMAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2Vh cmNoIEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4 @@ -29,4 +29,4 @@ oyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq 4RgqsahDYVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPA mRGunUHBcnWEvgJBQl9nJEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57d emyPxgcYxn/eR44/KJ4EBs+lVDR3veyJm+kXQ99b21/+jh5Xos1AnX5iItreGCc= ------END CERTIFICATE-----"""; +-----END CERTIFICATE-----'''; diff --git a/lib/config/routes.dart b/lib/config/routes.dart index d11cd56db..a6d2d70ce 100644 --- a/lib/config/routes.dart +++ b/lib/config/routes.dart @@ -3,9 +3,11 @@ import 'dart:async'; import 'package:flutter/material.dart'; import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/themes.dart'; import 'package:fluffychat/pages/archive/archive.dart'; +import 'package:fluffychat/pages/bootstrap/bootstrap_dialog.dart'; import 'package:fluffychat/pages/chat/chat.dart'; import 'package:fluffychat/pages/chat_access_settings/chat_access_settings_controller.dart'; import 'package:fluffychat/pages/chat_details/chat_details.dart'; @@ -15,39 +17,43 @@ import 'package:fluffychat/pages/chat_members/chat_members.dart'; import 'package:fluffychat/pages/chat_permissions_settings/chat_permissions_settings.dart'; import 'package:fluffychat/pages/chat_search/chat_search_page.dart'; import 'package:fluffychat/pages/device_settings/device_settings.dart'; -import 'package:fluffychat/pages/homeserver_picker/homeserver_picker.dart'; +import 'package:fluffychat/pages/intro/intro_page_presenter.dart'; import 'package:fluffychat/pages/invitation_selection/invitation_selection.dart'; import 'package:fluffychat/pages/login/login.dart'; import 'package:fluffychat/pages/new_group/new_group.dart'; import 'package:fluffychat/pages/new_private_chat/new_private_chat.dart'; -import 'package:fluffychat/pages/new_space/new_space.dart'; import 'package:fluffychat/pages/settings/settings.dart'; import 'package:fluffychat/pages/settings_3pid/settings_3pid.dart'; import 'package:fluffychat/pages/settings_chat/settings_chat.dart'; import 'package:fluffychat/pages/settings_emotes/settings_emotes.dart'; +import 'package:fluffychat/pages/settings_homeserver/settings_homeserver.dart'; import 'package:fluffychat/pages/settings_ignore_list/settings_ignore_list.dart'; -import 'package:fluffychat/pages/settings_multiple_emotes/settings_multiple_emotes.dart'; import 'package:fluffychat/pages/settings_notifications/settings_notifications.dart'; import 'package:fluffychat/pages/settings_password/settings_password.dart'; import 'package:fluffychat/pages/settings_security/settings_security.dart'; import 'package:fluffychat/pages/settings_style/settings_style.dart'; +import 'package:fluffychat/pages/sign_in/sign_in_page.dart'; +import 'package:fluffychat/widgets/config_viewer.dart'; import 'package:fluffychat/widgets/layouts/empty_page.dart'; import 'package:fluffychat/widgets/layouts/two_column_layout.dart'; import 'package:fluffychat/widgets/log_view.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import 'package:fluffychat/widgets/share_scaffold_dialog.dart'; abstract class AppRoutes { static FutureOr loggedInRedirect( BuildContext context, GoRouterState state, - ) => - Matrix.of(context).client.isLogged() ? '/rooms' : null; + ) => Matrix.of(context).widget.clients.any((client) => client.isLogged()) + ? '/rooms' + : null; static FutureOr loggedOutRedirect( BuildContext context, GoRouterState state, - ) => - Matrix.of(context).client.isLogged() ? null : '/home'; + ) => Matrix.of(context).widget.clients.any((client) => client.isLogged()) + ? null + : '/home'; AppRoutes(); @@ -55,23 +61,34 @@ abstract class AppRoutes { GoRoute( path: '/', redirect: (context, state) => - Matrix.of(context).client.isLogged() ? '/rooms' : '/home', + Matrix.of(context).widget.clients.any((client) => client.isLogged()) + ? '/rooms' + : '/home', ), GoRoute( path: '/home', - pageBuilder: (context, state) => defaultPageBuilder( - context, - state, - const HomeserverPicker(), - ), + pageBuilder: (context, state) => + defaultPageBuilder(context, state, const IntroPagePresenter()), redirect: loggedInRedirect, routes: [ + GoRoute( + path: 'sign_in', + pageBuilder: (context, state) => + defaultPageBuilder(context, state, SignInPage(signUp: false)), + redirect: loggedInRedirect, + ), + GoRoute( + path: 'sign_up', + pageBuilder: (context, state) => + defaultPageBuilder(context, state, SignInPage(signUp: true)), + redirect: loggedInRedirect, + ), GoRoute( path: 'login', pageBuilder: (context, state) => defaultPageBuilder( context, state, - const Login(), + Login(client: state.extra as Client), ), redirect: loggedInRedirect, ), @@ -79,23 +96,36 @@ abstract class AppRoutes { ), GoRoute( path: '/logs', + pageBuilder: (context, state) => + defaultPageBuilder(context, state, const LogViewer()), + ), + GoRoute( + path: '/configs', + pageBuilder: (context, state) => + defaultPageBuilder(context, state, const ConfigViewer()), + ), + GoRoute( + path: '/backup', + redirect: loggedOutRedirect, pageBuilder: (context, state) => defaultPageBuilder( context, state, - const LogViewer(), + BootstrapDialog(wipe: state.uri.queryParameters['wipe'] == 'true'), ), ), ShellRoute( - pageBuilder: (context, state, child) => defaultPageBuilder( + // Never use a transition on the shell route. Changing the PageBuilder + // here based on a MediaQuery causes the child to briefly be rendered + // twice with the same GlobalKey, blowing up the rendering. + pageBuilder: (context, state, child) => noTransitionPageBuilder( context, state, FluffyThemes.isColumnMode(context) && state.fullPath?.startsWith('/rooms/settings') == false ? TwoColumnLayout( - displayNavigationRail: - state.path?.startsWith('/rooms/settings') != true, mainView: ChatList( activeChat: state.pathParameters['roomid'], + activeSpace: state.uri.queryParameters['spaceId'], displayNavigationRail: state.path?.startsWith('/rooms/settings') != true, ), @@ -114,16 +144,14 @@ abstract class AppRoutes { ? const EmptyPage() : ChatList( activeChat: state.pathParameters['roomid'], + activeSpace: state.uri.queryParameters['spaceId'], ), ), routes: [ GoRoute( path: 'archive', - pageBuilder: (context, state) => defaultPageBuilder( - context, - state, - const Archive(), - ), + pageBuilder: (context, state) => + defaultPageBuilder(context, state, const Archive()), routes: [ GoRoute( path: ':roomid', @@ -142,11 +170,8 @@ abstract class AppRoutes { ), GoRoute( path: 'newprivatechat', - pageBuilder: (context, state) => defaultPageBuilder( - context, - state, - const NewPrivateChat(), - ), + pageBuilder: (context, state) => + defaultPageBuilder(context, state, const NewPrivateChat()), redirect: loggedOutRedirect, ), GoRoute( @@ -154,7 +179,7 @@ abstract class AppRoutes { pageBuilder: (context, state) => defaultPageBuilder( context, state, - const NewGroup(), + NewGroup(spaceId: state.uri.queryParameters['space_id']), ), redirect: loggedOutRedirect, ), @@ -163,7 +188,10 @@ abstract class AppRoutes { pageBuilder: (context, state) => defaultPageBuilder( context, state, - const NewSpace(), + NewGroup( + createGroupType: CreateGroupType.space, + spaceId: state.uri.queryParameters['space_id'], + ), ), redirect: loggedOutRedirect, ), @@ -173,9 +201,9 @@ abstract class AppRoutes { state, FluffyThemes.isColumnMode(context) ? TwoColumnLayout( - mainView: const Settings(), + mainView: Settings(key: state.pageKey), sideView: child, - displayNavigationRail: false, + hasNavigationRail: false, ) : child, ), @@ -230,7 +258,9 @@ abstract class AppRoutes { pageBuilder: (context, state) => defaultPageBuilder( context, state, - const EmotesSettings(), + EmotesSettings( + roomId: state.pathParameters['roomid'], + ), ), ), ], @@ -242,20 +272,49 @@ abstract class AppRoutes { pageBuilder: (context, state) => defaultPageBuilder( context, state, - const HomeserverPicker(), + const IntroPagePresenter(), ), routes: [ + GoRoute( + path: 'sign_in', + pageBuilder: (context, state) => defaultPageBuilder( + context, + state, + SignInPage(signUp: false), + ), + redirect: loggedOutRedirect, + ), + GoRoute( + path: 'sign_up', + pageBuilder: (context, state) => defaultPageBuilder( + context, + state, + SignInPage(signUp: true), + ), + redirect: loggedOutRedirect, + ), GoRoute( path: 'login', pageBuilder: (context, state) => defaultPageBuilder( context, state, - const Login(), + Login(client: state.extra as Client), ), redirect: loggedOutRedirect, ), ], ), + GoRoute( + path: 'homeserver', + pageBuilder: (context, state) { + return defaultPageBuilder( + context, + state, + const SettingsHomeserver(), + ); + }, + redirect: loggedOutRedirect, + ), GoRoute( path: 'security', redirect: loggedOutRedirect, @@ -307,15 +366,25 @@ abstract class AppRoutes { ), GoRoute( path: ':roomid', - pageBuilder: (context, state) => defaultPageBuilder( - context, - state, - ChatPage( - roomId: state.pathParameters['roomid']!, - shareText: state.uri.queryParameters['body'], - eventId: state.uri.queryParameters['event'], - ), - ), + pageBuilder: (context, state) { + final body = state.uri.queryParameters['body']; + var shareItems = state.extra is List + ? state.extra as List + : null; + if (body != null && body.isNotEmpty) { + shareItems ??= []; + shareItems.add(TextShareItem(body)); + } + return defaultPageBuilder( + context, + state, + ChatPage( + roomId: state.pathParameters['roomid']!, + shareItems: shareItems, + eventId: state.uri.queryParameters['event'], + ), + ); + }, redirect: loggedOutRedirect, routes: [ GoRoute( @@ -323,9 +392,7 @@ abstract class AppRoutes { pageBuilder: (context, state) => defaultPageBuilder( context, state, - ChatSearchPage( - roomId: state.pathParameters['roomid']!, - ), + ChatSearchPage(roomId: state.pathParameters['roomid']!), ), redirect: loggedOutRedirect, ), @@ -354,9 +421,7 @@ abstract class AppRoutes { pageBuilder: (context, state) => defaultPageBuilder( context, state, - ChatDetails( - roomId: state.pathParameters['roomid']!, - ), + ChatDetails(roomId: state.pathParameters['roomid']!), ), routes: [ GoRoute( @@ -401,30 +466,12 @@ abstract class AppRoutes { ), redirect: loggedOutRedirect, ), - GoRoute( - path: 'multiple_emotes', - pageBuilder: (context, state) => defaultPageBuilder( - context, - state, - const MultipleEmotesSettings(), - ), - redirect: loggedOutRedirect, - ), GoRoute( path: 'emotes', pageBuilder: (context, state) => defaultPageBuilder( context, state, - const EmotesSettings(), - ), - redirect: loggedOutRedirect, - ), - GoRoute( - path: 'emotes/:state_key', - pageBuilder: (context, state) => defaultPageBuilder( - context, - state, - const EmotesSettings(), + EmotesSettings(roomId: state.pathParameters['roomid']), ), redirect: loggedOutRedirect, ), @@ -439,20 +486,25 @@ abstract class AppRoutes { ), ]; + static Page noTransitionPageBuilder( + BuildContext context, + GoRouterState state, + Widget child, + ) => NoTransitionPage( + key: state.pageKey, + restorationId: state.pageKey.value, + child: child, + ); + static Page defaultPageBuilder( BuildContext context, GoRouterState state, Widget child, - ) => - FluffyThemes.isColumnMode(context) - ? NoTransitionPage( - key: state.pageKey, - restorationId: state.pageKey.value, - child: child, - ) - : MaterialPage( - key: state.pageKey, - restorationId: state.pageKey.value, - child: child, - ); + ) => FluffyThemes.isColumnMode(context) + ? noTransitionPageBuilder(context, state, child) + : MaterialPage( + key: state.pageKey, + restorationId: state.pageKey.value, + child: child, + ); } diff --git a/lib/config/setting_keys.dart b/lib/config/setting_keys.dart index 7c0e50df8..d8522e955 100644 --- a/lib/config/setting_keys.dart +++ b/lib/config/setting_keys.dart @@ -1,37 +1,190 @@ -abstract class SettingKeys { - static const String renderHtml = 'chat.fluffy.renderHtml'; - static const String hideRedactedEvents = 'chat.fluffy.hideRedactedEvents'; - static const String hideUnknownEvents = 'chat.fluffy.hideUnknownEvents'; - static const String hideUnimportantStateEvents = - 'chat.fluffy.hideUnimportantStateEvents'; - static const String separateChatTypes = 'chat.fluffy.separateChatTypes'; - static const String sentry = 'sentry'; - static const String theme = 'theme'; - static const String amoledEnabled = 'amoled_enabled'; - static const String codeLanguage = 'code_language'; - static const String showNoGoogle = 'chat.fluffy.show_no_google'; - static const String fontSizeFactor = 'chat.fluffy.font_size_factor'; - static const String showNoPid = 'chat.fluffy.show_no_pid'; - static const String databasePassword = 'database-password'; - static const String appLockKey = 'chat.fluffy.app_lock'; - static const String unifiedPushRegistered = - 'chat.fluffy.unifiedpush.registered'; - static const String unifiedPushEndpoint = 'chat.fluffy.unifiedpush.endpoint'; - static const String ownStatusMessage = 'chat.fluffy.status_msg'; - static const String dontAskForBootstrapKey = - 'chat.fluffychat.dont_ask_bootstrap'; - static const String autoplayImages = 'chat.fluffy.autoplay_images'; - static const String sendTypingNotifications = - 'chat.fluffy.send_typing_notifications'; - static const String sendPublicReadReceipts = - 'chat.fluffy.send_public_read_receipts'; - static const String sendOnEnter = 'chat.fluffy.send_on_enter'; - static const String swipeRightToLeftToReply = - 'chat.fluffy.swipeRightToLeftToReply'; - static const String experimentalVoip = 'chat.fluffy.experimental_voip'; - static const String showPresences = 'chat.fluffy.show_presences'; - static const String displayChatDetailsColumn = - 'chat.fluffy.display_chat_details_column'; - static const String noEncryptionWarningShown = - 'chat.fluffy.no_encryption_warning_shown'; +import 'dart:convert'; + +import 'package:flutter/foundation.dart'; + +import 'package:async/async.dart'; +import 'package:http/http.dart' as http; +import 'package:matrix/matrix_api_lite/utils/logs.dart'; +import 'package:shared_preferences/shared_preferences.dart'; + +import 'package:fluffychat/utils/platform_infos.dart'; + +enum AppSettings { + textMessageMaxLength('textMessageMaxLength', 16384), + audioRecordingNumChannels('audioRecordingNumChannels', 1), + audioRecordingAutoGain('audioRecordingAutoGain', true), + audioRecordingEchoCancel('audioRecordingEchoCancel', false), + audioRecordingNoiseSuppress('audioRecordingNoiseSuppress', true), + audioRecordingBitRate('audioRecordingBitRate', 64000), + audioRecordingSamplingRate('audioRecordingSamplingRate', 44100), + showNoGoogle('chat.fluffy.show_no_google', false), + unifiedPushRegistered('chat.fluffy.unifiedpush.registered', false), + unifiedPushEndpoint('chat.fluffy.unifiedpush.endpoint', ''), + pushNotificationsGatewayUrl( + 'pushNotificationsGatewayUrl', + 'https://push.fluffychat.im/_matrix/push/v1/notify', + ), + pushNotificationsPusherFormat( + 'pushNotificationsPusherFormat', + 'event_id_only', + ), + renderHtml('chat.fluffy.renderHtml', true), + fontSizeFactor('chat.fluffy.font_size_factor', 1.0), + hideRedactedEvents('chat.fluffy.hideRedactedEvents', false), + hideUnknownEvents('chat.fluffy.hideUnknownEvents', true), + autoplayImages('chat.fluffy.autoplay_images', true), + sendTypingNotifications('chat.fluffy.send_typing_notifications', true), + sendPublicReadReceipts('chat.fluffy.send_public_read_receipts', true), + swipeRightToLeftToReply('chat.fluffy.swipeRightToLeftToReply', true), + sendOnEnter('chat.fluffy.send_on_enter', false), + showPresences('chat.fluffy.show_presences', true), + displayNavigationRail('chat.fluffy.display_navigation_rail', false), + experimentalVoip('chat.fluffy.experimental_voip', false), + shareKeysWith('chat.fluffy.share_keys_with_2', 'all'), + noEncryptionWarningShown( + 'chat.fluffy.no_encryption_warning_shown', + false, + ), + displayChatDetailsColumn('chat.fluffy.display_chat_details_column', false), + // AppConfig-mirrored settings + applicationName('chat.fluffy.application_name', 'FluffyChat'), + defaultHomeserver('chat.fluffy.default_homeserver', 'matrix.org'), + // colorSchemeSeed stored as ARGB int + colorSchemeSeedInt('chat.fluffy.color_scheme_seed', 0xFF5625BA), + emojiSuggestionLocale('emoji_suggestion_locale', ''), + enableSoftLogout('chat.fluffy.enable_soft_logout', false), + enableMatrixNativeOIDC('chat.fluffy.enable_matrix_native_oidc', false), + presetHomeserver('chat.fluffy.preset_homeserver', ''), + welcomeText('chat.fluffy.welcome_text', ''); + + final String key; + final T defaultValue; + + const AppSettings(this.key, this.defaultValue); + + static SharedPreferences get store => _store!; + static SharedPreferences? _store; + + static Future init({bool loadWebConfigFile = true}) async { + if (AppSettings._store != null) return AppSettings.store; + + final store = AppSettings._store = await SharedPreferences.getInstance(); + + // Migrate wrong datatype for fontSizeFactor + final fontSizeFactorString = Result( + () => store.getString(AppSettings.fontSizeFactor.key), + ).asValue?.value; + if (fontSizeFactorString != null) { + Logs().i('Migrate wrong datatype for fontSizeFactor!'); + await store.remove(AppSettings.fontSizeFactor.key); + final fontSizeFactor = double.tryParse(fontSizeFactorString); + if (fontSizeFactor != null) { + await store.setDouble(AppSettings.fontSizeFactor.key, fontSizeFactor); + } + } + + if (store.getBool(AppSettings.sendOnEnter.key) == null) { + await store.setBool(AppSettings.sendOnEnter.key, !PlatformInfos.isMobile); + } + if (kIsWeb && loadWebConfigFile) { + try { + final configJsonString = utf8.decode( + (await http.get(Uri.parse('config.json'))).bodyBytes, + ); + final configJson = + json.decode(configJsonString) as Map; + for (final setting in AppSettings.values) { + if (store.get(setting.key) != null) continue; + final configValue = configJson[setting.name]; + if (configValue == null) continue; + if (configValue is bool) { + await store.setBool(setting.key, configValue); + } + if (configValue is String) { + await store.setString(setting.key, configValue); + } + if (configValue is int) { + await store.setInt(setting.key, configValue); + } + if (configValue is double) { + await store.setDouble(setting.key, configValue); + } + } + } on FormatException catch (_) { + Logs().v('[ConfigLoader] config.json not found'); + } catch (e) { + Logs().v('[ConfigLoader] config.json not found', e); + } + } + + return store; + } +} + +extension AppSettingsBoolExtension on AppSettings { + bool get value { + final value = Result(() => AppSettings.store.getBool(key)); + final error = value.asError; + if (error != null) { + Logs().e( + 'Unable to fetch $key from storage. Removing entry...', + error.error, + error.stackTrace, + ); + } + return value.asValue?.value ?? defaultValue; + } + + Future setItem(bool value) => AppSettings.store.setBool(key, value); +} + +extension AppSettingsStringExtension on AppSettings { + String get value { + final value = Result(() => AppSettings.store.getString(key)); + final error = value.asError; + if (error != null) { + Logs().e( + 'Unable to fetch $key from storage. Removing entry...', + error.error, + error.stackTrace, + ); + } + return value.asValue?.value ?? defaultValue; + } + + Future setItem(String value) => AppSettings.store.setString(key, value); +} + +extension AppSettingsIntExtension on AppSettings { + int get value { + final value = Result(() => AppSettings.store.getInt(key)); + final error = value.asError; + if (error != null) { + Logs().e( + 'Unable to fetch $key from storage. Removing entry...', + error.error, + error.stackTrace, + ); + } + return value.asValue?.value ?? defaultValue; + } + + Future setItem(int value) => AppSettings.store.setInt(key, value); +} + +extension AppSettingsDoubleExtension on AppSettings { + double get value { + final value = Result(() => AppSettings.store.getDouble(key)); + final error = value.asError; + if (error != null) { + Logs().e( + 'Unable to fetch $key from storage. Removing entry...', + error.error, + error.stackTrace, + ); + } + return value.asValue?.value ?? defaultValue; + } + + Future setItem(double value) => AppSettings.store.setDouble(key, value); } diff --git a/lib/config/themes.dart b/lib/config/themes.dart index 3a3e51335..3295d0191 100644 --- a/lib/config/themes.dart +++ b/lib/config/themes.dart @@ -1,48 +1,26 @@ import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/config/setting_keys.dart'; import 'app_config.dart'; abstract class FluffyThemes { - static const double columnWidth = 360.0; + static const double columnWidth = 380.0; - static const double navRailWidth = 64.0; + static const double maxTimelineWidth = columnWidth * 2; + + static const double navRailWidth = 80.0; static bool isColumnModeByWidth(double width) => width > columnWidth * 2 + navRailWidth; static bool isColumnMode(BuildContext context) => - isColumnModeByWidth(MediaQuery.of(context).size.width); + isColumnModeByWidth(MediaQuery.sizeOf(context).width); static bool isThreeColumnMode(BuildContext context) => - MediaQuery.of(context).size.width > FluffyThemes.columnWidth * 3.5; + MediaQuery.sizeOf(context).width > FluffyThemes.columnWidth * 3.5; - static const fallbackTextStyle = TextStyle( - fontFamily: 'Roboto', - fontFamilyFallback: ['NotoEmoji'], - ); - - static var fallbackTextTheme = const TextTheme( - bodyLarge: fallbackTextStyle, - bodyMedium: fallbackTextStyle, - labelLarge: fallbackTextStyle, - bodySmall: fallbackTextStyle, - labelSmall: fallbackTextStyle, - displayLarge: fallbackTextStyle, - displayMedium: fallbackTextStyle, - displaySmall: fallbackTextStyle, - headlineMedium: fallbackTextStyle, - headlineSmall: fallbackTextStyle, - titleLarge: fallbackTextStyle, - titleMedium: fallbackTextStyle, - titleSmall: fallbackTextStyle, - ); - - static LinearGradient backgroundGradient( - BuildContext context, - int alpha, - ) { + static LinearGradient backgroundGradient(BuildContext context, int alpha) { final colorScheme = Theme.of(context).colorScheme; return LinearGradient( begin: Alignment.topCenter, @@ -65,32 +43,34 @@ abstract class FluffyThemes { ]) { final colorScheme = ColorScheme.fromSeed( brightness: brightness, - seedColor: seed ?? AppConfig.colorSchemeSeed ?? AppConfig.primaryColor, + seedColor: seed ?? Color(AppSettings.colorSchemeSeedInt.value), ); // Sets status and navigation bar style whenever buildTheme called SystemChrome.setSystemUIOverlayStyle( getOverlayStyle(brightness, colorScheme), ); + final isColumnMode = FluffyThemes.isColumnMode(context); return ThemeData( visualDensity: VisualDensity.standard, useMaterial3: true, brightness: brightness, colorScheme: colorScheme, - textTheme: PlatformInfos.isDesktop - ? brightness == Brightness.light - ? Typography.material2018().black.merge(fallbackTextTheme) - : Typography.material2018().white.merge(fallbackTextTheme) - : null, - snackBarTheme: const SnackBarThemeData( - behavior: SnackBarBehavior.floating, - ), - dividerColor: brightness == Brightness.light - ? Colors.blueGrey.shade50 - : Colors.blueGrey.shade900, + dividerColor: brightness == Brightness.dark + ? colorScheme.surfaceContainerHighest + : colorScheme.surfaceContainer, popupMenuTheme: PopupMenuThemeData( + color: colorScheme.surfaceContainerLow, + iconColor: colorScheme.onSurface, + textStyle: TextStyle(color: colorScheme.onSurface), shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(AppConfig.borderRadius), + borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), + ), + ), + segmentedButtonTheme: SegmentedButtonThemeData( + style: SegmentedButton.styleFrom( + iconColor: colorScheme.onSurface, + disabledIconColor: colorScheme.onSurface, ), ), textSelectionTheme: TextSelectionThemeData( @@ -99,21 +79,28 @@ abstract class FluffyThemes { ), inputDecorationTheme: InputDecorationTheme( border: OutlineInputBorder( - borderSide: BorderSide.none, - borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), + borderRadius: BorderRadius.circular(AppConfig.borderRadius), ), contentPadding: const EdgeInsets.all(12), - filled: true, + ), + chipTheme: ChipThemeData( + showCheckmark: false, + backgroundColor: colorScheme.surfaceContainer, + side: BorderSide.none, + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + ), ), appBarTheme: AppBarTheme( - toolbarHeight: FluffyThemes.isColumnMode(context) ? 72 : 56, - shadowColor: FluffyThemes.isColumnMode(context) - ? Colors.grey.withAlpha(64) + toolbarHeight: isColumnMode ? 72 : 56, + shadowColor: isColumnMode + ? colorScheme.surfaceContainer.withAlpha(128) + : null, + surfaceTintColor: isColumnMode ? colorScheme.surface : null, + backgroundColor: isColumnMode ? colorScheme.surface : null, + actionsPadding: isColumnMode + ? const EdgeInsets.symmetric(horizontal: 16.0) : null, - surfaceTintColor: - FluffyThemes.isColumnMode(context) ? colorScheme.surface : null, - backgroundColor: - FluffyThemes.isColumnMode(context) ? colorScheme.surface : null, systemOverlayStyle: SystemUiOverlayStyle( statusBarColor: Colors.transparent, statusBarIconBrightness: brightness.reversed, @@ -122,30 +109,27 @@ abstract class FluffyThemes { systemNavigationBarColor: colorScheme.surface, ), ), - textButtonTheme: TextButtonThemeData( - style: TextButton.styleFrom( - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), - ), - ), - ), outlinedButtonTheme: OutlinedButtonThemeData( style: OutlinedButton.styleFrom( - side: BorderSide( - width: 1, - color: colorScheme.primary, - ), + side: BorderSide(width: 1, color: colorScheme.primary), shape: RoundedRectangleBorder( side: BorderSide(color: colorScheme.primary), borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), ), ), ), - dialogTheme: DialogTheme( - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), - ), + progressIndicatorTheme: ProgressIndicatorThemeData( + strokeCap: StrokeCap.round, + color: colorScheme.primary, + refreshBackgroundColor: colorScheme.primaryContainer, ), + snackBarTheme: isColumnMode + ? const SnackBarThemeData( + showCloseIcon: true, + behavior: SnackBarBehavior.floating, + width: FluffyThemes.columnWidth * 1.5, + ) + : const SnackBarThemeData(behavior: SnackBarBehavior.floating), elevatedButtonTheme: ElevatedButtonThemeData( style: ElevatedButton.styleFrom( backgroundColor: colorScheme.secondaryContainer, @@ -153,9 +137,6 @@ abstract class FluffyThemes { elevation: 0, padding: const EdgeInsets.all(16), textStyle: const TextStyle(fontSize: 16), - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(AppConfig.borderRadius), - ), ), ), ); @@ -176,3 +157,19 @@ extension on Brightness { Brightness get reversed => this == Brightness.dark ? Brightness.light : Brightness.dark; } + +extension BubbleColorTheme on ThemeData { + Color get bubbleColor => brightness == Brightness.light + ? colorScheme.primary + : colorScheme.primaryContainer; + + Color get onBubbleColor => brightness == Brightness.light + ? colorScheme.onPrimary + : colorScheme.onPrimaryContainer; + + Color get secondaryBubbleColor => HSLColor.fromColor( + brightness == Brightness.light + ? colorScheme.tertiary + : colorScheme.tertiaryContainer, + ).withSaturation(0.5).toColor(); +} diff --git a/lib/l10n/intl_ar.arb b/lib/l10n/intl_ar.arb new file mode 100644 index 000000000..8bcfa71e5 --- /dev/null +++ b/lib/l10n/intl_ar.arb @@ -0,0 +1,3187 @@ +{ + "@@locale": "ar", + "@@last_modified": "2021-08-14 12:41:10.156221", + "about": "حول", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "أقبل", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} قبل الدعوة", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "الحساب", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 تم تنشيط {username} التشفير من طرف إلى طرف", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "المدير", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "اللقب", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} أجاب على المكالمة", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "يمكن لأي أحد الدخول", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "الأرشيف", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "هل يُسمح للزوار الدخول", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "أمتأكد؟", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "لتتمكن من التأكد من الشخص الآخر، يرجى إدخال عبارة المرور أو مفتاح الاسترداد.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "أتقبل طلب تحقق {username}؟", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banFromChat": "حظر من المحادثة", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "محظور", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} حظر {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "أُحظر الجهاز", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "cancel": "ألغِ", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "غيَّر {username} صورة المحادثة", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "غيَّر {username} وصف المحادثة الى: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "غيَّر {username} اسم المحادثة الى: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "غيَّر {username} أذون المحادثة", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} غير إسمه العلني إلى: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "غيّر {username} قواعد وصول الزوار", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "غيّر {username} قواعد وصول الزوار الى: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "غيَّر {username} مرئية التأريخ", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "غيَّر {username} مرئية التأريخ الى: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "غيَّر {username} قواعد الانضمام", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "غيَّر {username} قواعد الانضمام الى: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "غيّر {username} صورته الشخصية", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "غيّر {username} ألقاب الغرف", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "غيّر {username} رابط الدعوة", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeTheHomeserver": "غيّر الخادم", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "غيّر أسلوبك", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "غيِّر اسم المجموعة", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "فسُد التشفير", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "محادثة", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "تفاصيل المحادثة", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "اختر كلمة سر قوية", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "اغلق", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "يرجى مقارنة الرموز التعبيرية", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "الرجاء مقارنة الأرقام", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "أكّد", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "اتصل", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "دعيَ المراسل للمجموعة", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "نُسخ للحافظة", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "انسخ", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "تعذر فك تشفير الرسالة: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} منتسبا", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "أنشئ", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 أنشأ {username} المحادثة", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "نشطٌ حاليا", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "داكن", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}/{month}/{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "لا مجال للعودة، أتأكد تعطيل حسابك؟", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "delete": "احذف", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "احذف الحساب", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "حذف الرسالة", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "جهاز", + "@device": { + "type": "String", + "placeholders": {} + }, + "devices": "الأجهزة", + "@devices": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "غُيِّر الاسم العلني", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "نزِّل الملف", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "حرر الاسم العلني", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "الانفعالة موجودة مسبقا!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "رمز الانفعالة غير صالح!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "اعدادات الانفعالات", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "رمز الانفعالة", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "اختر صورة ورمزا للانفعالة!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "محادثة فارغة", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "لن يمكنك تعطيل التشفير أبدا، أمتأكد؟", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryption": "التشفير", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "التشفير معطل", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "أنهى {senderName} المكالمة", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterYourHomeserver": "أدخل الخادم", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "fileName": "اسم الملف", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "فلافي-شات", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "أعد التوجيه", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "من بعد الانضمام", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "من بعد الدعوة", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "المجموعة", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "المجموعة عامة", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "في مجموعة مع {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "يمنع الزوار", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "يمكن للزوار الانضمام", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "سحب {username} دعوة {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "المساعدة", + "@help": { + "type": "String", + "placeholders": {} + }, + "id": "المعرّف", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "المُعرّف", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "المستخدمون المتجاهلون", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "عبارة مرور أو مفتاح استرداد خطأ", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "دعوة مراسل", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "أدعو مراسلا الى {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "دُعيَ", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} دعا {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "المستخدمون المدعوون فقط", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteText": "دعاك {username} إلى FluffyChat.\n1. قم بزيارة موقع fluffychat.im وقم بتثبيت التطبيق\n2. قم بإنشاءحساب أو تسجيل الدخول\n3. افتح رابط الدعوة:\n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "يكتب…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 انضم {username} إلى المحادثة", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "انضم للمحادثة", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} ركل {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} ركل وحظر {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "طرد من المحادثة", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "آخر نشاط: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "غادر", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "غادر المحادثة", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "الرخصة", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "فاتح", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "حمِّل {count} منتسبًا إضافيًا", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "يحمّل… يرجى الانتظار.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "حمِّل المزيد…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "لِج", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "لِج ل {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "اخرج", + "@logout": { + "type": "String", + "placeholders": {} + }, + "moderator": "مشرف", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "أكتم الماحدثة", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "اعلم أننا نستخدم بانتاليمون للتشفير طرفا لطرف.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 رسالة جديدة في FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "طلب تحقق جديد!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "no": "لا", + "@no": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "لم يُعثر على انفعالة. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "يبدو أن خدمة Firebase Cloud Messaging غير متاحة على جهازك. لمواصلة تلقي الإشعارات، نوصي بتثبيت ntfy. باستخدام ntfy أو أي مزود خدمة Unified Push آخر، يمكنك تلقي إشعارات الدفع بطريقة آمنة للبيانات. يمكنك تنزيل ntfy من PlayStore أو من F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "بدون", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPermission": "بدون اذن", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "لم يُعثر على غرف…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "ok": "موافق", + "@ok": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "تم تفعيل النسخ الاحتياطي للمفاتيح عبر الإنترنت", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "عفوًا، حدث خطأ ما…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "افتح التطبيق لقراءة الرسائل", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "افتح الكميرا", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "عبارة المرور أو مفتاح الاستعادة", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "كلمة السر", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "غُيّرت كلمة السر", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "pickImage": "اختر صورة", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "ثبِّت", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "شغّل {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnterYourPassword": "أدخل كلمة السر", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "أدخل اسم المستخدم", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "privacy": "الخصوصية", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "الغرف العامة", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "recording": "يسجل", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "حذف {username} حدثًا", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "رفض", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "رفض {username} الدعوة", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "أعد الانضمام", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "أزِل", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "أزِل كل الأجهزة الأخرى", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "أزاله {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "أزل جهازا", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "فك حجبه من المحادثة", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "ردّ", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "أطلب إذنا", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "رُقيّت الغرفة", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "رآه {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "أرسل", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "أرسل رسالة", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "أرسل ملفًا صوتيًا", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "أرسل ملف", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "أرسل صورة", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "أرسل الملف الأصلي", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "أرسل فيديو", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 أرسل {username} ملفا", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 أرسل {username} ملفا صوتيا", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} أرسل صورة", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 أرسل {username} ملصقا", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 أرسل {username} مقطع فيديو", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "أرسل {senderName} معلومات مكالمة", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setInvitationLink": "عيّن رابط الدعوة", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setStatus": "عيّن الحالة", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "الإعدادات", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "شارك", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "شارك {username} موقعه", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "skip": "تخط", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "الشفرة المصدرية", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "بدأ {senderName} مكالمة", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "statusExampleMessage": "ماهو وضعك؟", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "أرسل", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "النظام", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "لا يتطبقان", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "متطبقان", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "فلافي-شات", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "حاول إعادة الارسال", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "ألغى {username} حظر {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "ألغ حظر الجهاز", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "جهز مجهول", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "خوارزمية تشفير مجهولة", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "حدث مجهول '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "ألغِ كتم المحادثة", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "ألغِ التثبيت", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 محادثة غير مقروءة} other{{unreadCount} محادثات غير مقروءة}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} و {count} أخرون يكتبون…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} و {username2} يكتبان…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} يكتب…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} غادر المحادثة", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "اسم المستخدم", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "أرسل {username} حدث {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "تحقق", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "ابدأ التحقق", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "تُحقق منك بنجاح!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "يتحقق من الحساب الآخر", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "مكالمة فيديو", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "مرئية تأريخ المحادثة", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "مرئي لكل المنتسبين", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "مرئي للجميع", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "رسالة صوتية", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "ينتظر قبول الشريك للطلب…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "ينتظر قبول الشريك لإيموجي…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "ينتظر قبول الشريك للأرقام…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "الخلفية:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "تحذير!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "من يسمح له الانضمام للمجموعة", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "اكتب رسالة…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "نعم", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "انت", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "لم تعد منتسبا لهذه المحادثة", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "حُظرت من هذه المحادثة", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "people": "أشخاص", + "@people": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "امسح رمز الاستجابة السريعة", + "@scanQrCode": {}, + "noMatrixServer": "{server1} ليس خادم ماتريكس، بدلًا منه أتريد استخدام {server2}؟", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "noConnectionToTheServer": "انقطع الاتصال بالخادم", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "next": "التالي", + "@next": { + "type": "String", + "placeholders": {} + }, + "newChat": "محادثة جديدة", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "messages": "الرسائل", + "@messages": { + "type": "String", + "placeholders": {} + }, + "mention": "اذكر", + "@mention": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "تغييرات تخص الأعضاء", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "غير مسيء", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "نقرت على الرابط", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "ignore": "تجاهل", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "ما مدى سوء هذا المحتوى؟", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "اخف الأحداث المجهولة", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "groups": "المجموعات", + "@groups": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "انتقل للغرفة الجديدة", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "fontSize": "حجم الخط", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "مسيئة للغاية", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "كل شيء جاهز!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "homeserver": "الخادم", + "@homeserver": {}, + "enterAnEmailAddress": "أدخل عنوان بريد إلكتروني", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "encrypted": "مشفر", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "فعّل التشفير", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "حزمة الوجوه التعبيرية للغرفة", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "عدّل الصورة الرمزية للغرفة", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "عدّل الخوادم المحجوبة", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "edit": "عدّل", + "@edit": { + "type": "String", + "placeholders": {} + }, + "directChats": "محادثات مباشرة", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "deviceId": "معرّف الجهاز", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "مساحة جديدة", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "انسخ الى الحافظة", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "أّرسل الابلاغ الى مدير الخادم", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "يحوي اسم المستخدم", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "يحوي الاسم العلني", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "commandMissing": "{command} ليس بأمر.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "commandInvalid": "أمر غير صالح", + "@commandInvalid": { + "type": "String" + }, + "commandHint_unban": "فك الحظر عن المستخدم المذكور في هذه الغرفة", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandHint_send": "أرسل نصًا", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_react": "أرسل ردًا كتفاعل", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_plain": "أرسل نصًا غير منسق", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_op": "عين مستوى نفوذ المستخدم في هذه الغرفة (الافتراضي: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_myroomnick": "عين اسمًا لك مخصص لهذه الغرفة", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_me": "صف نفسك", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_leave": "تغادر هذه الغرفة", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_kick": "يزيل المستخدم المذكور من الغرفة", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_join": "تنضم الى الغرفة المذكورة", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_invite": "يدعو المستخدم المذكور الى الغرفة", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_html": "أرسل نصًا بتنسيق HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_ban": "يحظر المستخدم المذكور من هذه الغرفة", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "clearArchive": "امسح الأرشيف", + "@clearArchive": {}, + "chats": "المحادثات", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "أُضيفت المحادثة الى هذا المساحة", + "@chatHasBeenAddedToThisSpace": {}, + "chatBackup": "النسخ الاحتياطي للمحادثات", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "غيّر الصورة الرمزية", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "changePassword": "غيّر كلمة السر", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "غيّر اسم الجهاز", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "تعذر فتح المسار {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "blocked": "محجوب", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "أرسل عند الدخول", + "@sendOnEnter": {}, + "autoplayImages": "شغِّل الملصقات والوجوه المتحركة تلقائيا", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "areYouSureYouWantToLogout": "أمتأكد من الخروج؟", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "appLock": "قفل التطبيق", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "allChats": "كل المحادثات", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "all": "الكل", + "@all": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "أضف إلى المساحة", + "@addToSpace": {}, + "addEmail": "أضف بريدًا إلكترونيًا", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "لم تضف أي طريقة لاستعادة كلمة السر.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "notifications": "الإشعارات", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "reason": "السبب", + "@reason": { + "type": "String", + "placeholders": {} + }, + "search": "ابحث", + "@search": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "خدمات الموقع معطلة. مكنها لتتمكن من مشاركة موقعك.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "خطأ أثناء الحصول على الموقع: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "editRoomAliases": "عدّل الاسم المميز للغرفة", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "configureChat": "ضبط المحادثة", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "يتم تأمين رسائلك القديمة باستخدام مفتاح الاسترداد. يرجى التأكد من أنك لا تضيعه.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "شارك الموقع", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "اختر رمز المرور", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "اختر رجاء", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "استعادة كلمة السر", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "نسيتَ كلمة السر", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "participant": "منتسب", + "@participant": { + "type": "String", + "placeholders": {} + }, + "or": "أو", + "@or": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "يتطلب هذا الخادم التحقق من بريدك الإلكتروني.", + "@serverRequiresEmail": {}, + "link": "رابط", + "@link": {}, + "openInMaps": "افتح في الخريطة", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "enableMultiAccounts": "(ميزة تجربية) فعّل تعدد الحسابات", + "@enableMultiAccounts": {}, + "bundleName": "اسم الحزمة", + "@bundleName": {}, + "removeFromBundle": "أزله من الحزمة", + "@removeFromBundle": {}, + "addToBundle": "أضفه الى حزمة", + "@addToBundle": {}, + "editBundlesForAccount": "عدّل حزم هذا الحساب", + "@editBundlesForAccount": {}, + "addAccount": "أضف حسابًا", + "@addAccount": {}, + "online": "متصل", + "@online": { + "type": "String", + "placeholders": {} + }, + "offline": "غير متصل", + "@offline": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} يكتبون…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "notificationsEnabledForThisAccount": "الإشعارات مفعلة لهذا الحساب", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "عام في المساحة", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "بدّل حالة التفضيل", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "علّمه كمقروء/غير مقروء", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "unavailable": "غير متوفر", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "لماذا تريد الإبلاغ عنه؟", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "يمكنك استعادة كلمة السر بهذه العناوين.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "تسجيل دخول أحادي", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "بدّل حالة الكتم", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "showPassword": "أظهر كلمة السر", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "verified": "موثّق", + "@verified": { + "type": "String", + "placeholders": {} + }, + "spaceName": "اسم المساحة", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "يُزامن… يرجى الانتظار.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "طابات كثيرة. حاول مجددًا لاحقًا!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "أرسلنا لك رسالة بالبريد الإلكتروني", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "مفتاحك العمومي", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "status": "الحالة", + "@status": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "أنقله من جهاز آخر", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "مسح نسخة المحادثة الاحتياطية لإنشاء مفتاح استرداد جديد؟", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "saveFile": "احفظ الملف", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "security": "الأمان", + "@security": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "أزل الصورة الرمزية", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "botMessages": "رسائل البوت", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "أرسل نصًا", + "@sendAsText": { + "type": "String" + }, + "sendMessages": "إرسال رسائل", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "دعوات لي", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "استبدل الغرفة باصدار أحدث", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "register": "سجّل", + "@register": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "يحصل على الموقع…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "أرسل ملصقًا", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "مستوى الأذونات الافتراضية للمستخدمين الجدد", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "تعيين مستوى الأذونات", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "عيّن وجوهًا تعبيرية مخصصة", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "أُ خرج أحد العملاء الذي تسختدمها", + "@oneClientLoggedOut": {}, + "pleaseEnter4Digits": "أدخل 4 أرقام أو أتركه فارغ لتعطيل القفل.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "احذف رسالة", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "أبلغ عن الرسالة", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "إصدار الغرفة", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "كرّر كلمة السر", + "@repeatPassword": {}, + "removeFromSpace": "أزل من المساحة", + "@removeFromSpace": {}, + "unverified": "غير مؤكد", + "@unverified": {}, + "whoCanPerformWhichAction": "من يستطيع القيام بأي عمل", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "معلومات الرسالة", + "@messageInfo": {}, + "messageType": "نوع الرسالة", + "@messageType": {}, + "sender": "المرسل", + "@sender": {}, + "openGallery": "افتخ المعرض", + "@openGallery": {}, + "time": "الوقت", + "@time": {}, + "badServerLoginTypesException": "يدعم الخادم المستخدم أنواع تسجيل الدخول التالية:\n{serverVersions}\nلكن هذا التطبيق يدعم فقط:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "commandHint_clearcache": "مسح الذاكرة المؤقتة", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "enableEmotesGlobally": "تفعيل حزمة التعبيرات بشكل عام", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "إخفاء الأحداث المنقحة", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "commandHint_discardsession": "إنهاء الجلسة", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "locationPermissionDeniedNotice": "تم رفض إذن الموقع. الرجاء منح الإذن للقدرة على مشاركة موقعك.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "يدعم الخادم الرئيسي المستخدم إصدارات المواصفات:\n{serverVersions}\nلكن هذا التطبيق يدعم فقط:\n{supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "offensive": "عدواني", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "تم إعداد النسخ الاحتياطي لمحادثاتك.", + "@yourChatBackupHasBeenSetUp": {}, + "noEncryptionForPublicRooms": "يمكنك فقط تفعيل التشفير عندما تصبح الغرفة غير متاحة للعامة.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "emojis": "إيموجي", + "@emojis": {}, + "voiceCall": "مكالمة صوتية", + "@voiceCall": {}, + "unsupportedAndroidVersion": "نسخة أندرويد غير مدعومة", + "@unsupportedAndroidVersion": {}, + "unsupportedAndroidVersionLong": "تتطلب هذه الميزة إصدار Android أحدث. يرجى التحقق من وجود تحديثات أو دعم Lineage OS.", + "@unsupportedAndroidVersionLong": {}, + "experimentalVideoCalls": "مكالمات الفيديو التجريبية", + "@experimentalVideoCalls": {}, + "commandHint_create": "أنشأ محادثة جماعية فارغة\nاستخدم --لا-تشفير لتعطيل التشفير", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_dm": "إبدأ محادثة مباشرة\nاستخدم --لا-تشفير لتعطيل التشفير", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "oopsPushError": "عذراً! للأسف، حدث خطأ أثناء إعداد الإشعارات.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "يرجى اتباع التعليمات الموجودة على الموقع والنقر على التالي.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "commandHint_myroomavatar": "حدد صورتك لهذه الغرفة (عن طريق mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "videoCallsBetaWarning": "يرجى ملاحظة أن مكالمات الفيديو حالياً في مرحلة تجريبية. قد لا تعمل كما هو متوقع أو تعمل على الإطلاق على جميع المنصات.", + "@videoCallsBetaWarning": {}, + "placeCall": "إجراء مكالمة", + "@placeCall": {}, + "videoWithSize": "فيديو ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "emailOrUsername": "البريد الإلكتروني أو اسم المستخدم", + "@emailOrUsername": {}, + "dismiss": "رفض", + "@dismiss": {}, + "setAsCanonicalAlias": "تعيين كاسم مستعار رئيسي", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "يرجى النقر على الرابط الموجود في البريد الإلكتروني ثم المتابعة.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "الرجاء إدخال رقم التعريف الشخصي الخاص بك", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pushRules": "قواعد الإشعارات", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reactedWith": "{sender} تفاعل ب {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "markAsRead": "حدد كمقروء", + "@markAsRead": {}, + "openVideoCamera": "افتح الكاميرا لمقطع فيديو", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "start": "إبدأ", + "@start": {}, + "publish": "انشر", + "@publish": {}, + "addToSpaceDescription": "إختر مساحة لإضافة هذه المحادثة إليها.", + "@addToSpaceDescription": {}, + "reportUser": "التبيلغ عن المستخدم", + "@reportUser": {}, + "openChat": "فتح المحادثة", + "@openChat": {}, + "pinMessage": "تثبيت في الغرفة", + "@pinMessage": {}, + "confirmEventUnpin": "هل أنت متأكد من إلغاء تثبيت الحدث بشكل دائم؟", + "@confirmEventUnpin": {}, + "fileHasBeenSavedAt": "تم حفظ الملف في {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "user": "مستخدم", + "@user": {}, + "custom": "مُخصّص", + "@custom": {}, + "googlyEyesContent": "{senderName} يرسل لك عيون googly", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "widgetVideo": "فيديو", + "@widgetVideo": {}, + "recoveryKeyLost": "هل فقدت مفتاح الاسترداد؟", + "@recoveryKeyLost": {}, + "pleaseEnterRecoveryKeyDescription": "لإلغاء قفل رسائلك القديمة ، يرجى إدخال مفتاح الاسترداد الذي تم إنشاؤه في جلسة سابقة. مفتاح الاسترداد ليس كلمة المرور الخاصة بك.", + "@pleaseEnterRecoveryKeyDescription": {}, + "confirmMatrixId": "يرجى تأكيد معرف Matrix الخاص بك من أجل حذف حسابك.", + "@confirmMatrixId": {}, + "supposedMxid": "يجب أن يكون هذا {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "hydrateTor": "مستخدمو تور: استيراد تصدير الجلسة", + "@hydrateTor": {}, + "commandHint_googly": "أرسل بعض عيون googly", + "@commandHint_googly": {}, + "commandHint_cuddle": "أرسل عناق", + "@commandHint_cuddle": {}, + "commandHint_hug": "إرسال حضن", + "@commandHint_hug": {}, + "cuddleContent": "{senderName} يحتضنك", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "unlockOldMessages": "إلغاء قفل الرسائل القديمة", + "@unlockOldMessages": {}, + "commandHint_markasdm": "وضع علامة على أنها غرفة رسائل مباشرة لمعرف المصفوفة", + "@commandHint_markasdm": {}, + "allRooms": "جميع الدردشات الجماعية", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "dehydrate": "تصدير الجلسة ومسح الجهاز", + "@dehydrate": {}, + "dehydrateWarning": "لا يمكن التراجع عن هذا الإجراء. تأكد من تخزين ملف النسخ الاحتياطي بأمان.", + "@dehydrateWarning": {}, + "dehydrateTorLong": "بالنسبة لمستخدمي تور ، يوصى بتصدير الجلسة قبل إغلاق النافذة.", + "@dehydrateTorLong": {}, + "dehydrateTor": "مستخدمو تور: تصدير الجلسة", + "@dehydrateTor": {}, + "hydrate": "استعادة من ملف النسخ الاحتياطي", + "@hydrate": {}, + "pleaseEnterRecoveryKey": "الرجاء إدخال مفتاح الاسترداد:", + "@pleaseEnterRecoveryKey": {}, + "recoveryKey": "مفتاح الاسترداد", + "@recoveryKey": {}, + "startFirstChat": "ابدأ محادثتك الأولى", + "@startFirstChat": {}, + "widgetCustom": "مُخصّص", + "@widgetCustom": {}, + "widgetNameError": "يرجى تقديم اسم العرض.", + "@widgetNameError": {}, + "errorAddingWidget": "خطأ في إضافة الأداة.", + "@errorAddingWidget": {}, + "youRejectedTheInvitation": "لقد رفضت الدعوة", + "@youRejectedTheInvitation": {}, + "youJoinedTheChat": "لقد انضممت إلى المحادثة", + "@youJoinedTheChat": {}, + "youAcceptedTheInvitation": "👍 لقد قبلت الدعوة", + "@youAcceptedTheInvitation": {}, + "youBannedUser": "لقد حظرت {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "لقد سحبت الدعوة لـ {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 لقد تمت دعوتك من قبل {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "storeInAndroidKeystore": "تخزين في سجل مفاتيح اندرويد", + "@storeInAndroidKeystore": {}, + "storeInAppleKeyChain": "تخزين في سلسلة مفاتيح ابل", + "@storeInAppleKeyChain": {}, + "storeSecurlyOnThisDevice": "احفظه بأمان على هذا الجهاز", + "@storeSecurlyOnThisDevice": {}, + "countFiles": "ملفات {count}", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "foregroundServiceRunning": "يظهر هذا الإشعار عند تشغيل الخدمة الأمامية.", + "@foregroundServiceRunning": {}, + "screenSharingTitle": "مشاركة الشاشة", + "@screenSharingTitle": {}, + "appearOnTop": "يظهر في الأعلى", + "@appearOnTop": {}, + "otherCallingPermissions": "الميكروفون والكاميرا وأذونات FluffyChat الأخرى", + "@otherCallingPermissions": {}, + "enterSpace": "أدخل المساحة", + "@enterSpace": {}, + "enterRoom": "أدخل الغرفة", + "@enterRoom": {}, + "deviceKeys": "مفاتيح الجهاز:", + "@deviceKeys": {}, + "whyIsThisMessageEncrypted": "لماذا هذه الرسالة غير قابلة للقراءة؟", + "@whyIsThisMessageEncrypted": {}, + "nextAccount": "الحساب التالي", + "@nextAccount": {}, + "previousAccount": "الحساب السابق", + "@previousAccount": {}, + "encryptThisChat": "تشفير هذه المحادثة", + "@encryptThisChat": {}, + "screenSharingDetail": "أنت تشارك شاشتك في FuffyChat", + "@screenSharingDetail": {}, + "hideUnimportantStateEvents": "إخفاء أحداث الحالة غير المهمة", + "@hideUnimportantStateEvents": {}, + "newGroup": "مجموعة جديدة", + "@newGroup": {}, + "youKicked": "👞 لقد ركلت {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "newSpace": "مساحة جديدة", + "@newSpace": {}, + "commandHint_markasgroup": "وضع علامة كمجموعة", + "@commandHint_markasgroup": {}, + "separateChatTypes": "الدردشات المباشرة والمجموعات المنفصلة", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "hugContent": "{senderName} يعانقك", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hydrateTorLong": "هل قمت بتصدير جلستك الأخيرة على تور؟ قم باستيرادها بسرعة واستمر في المحادثة.", + "@hydrateTorLong": {}, + "widgetUrlError": "هذا ليس عنوان URL صالحًا.", + "@widgetUrlError": {}, + "indexedDbErrorTitle": "مشاكل الوضع الخاص", + "@indexedDbErrorTitle": {}, + "indexedDbErrorLong": "للأسف ، لم يتم تمكين تخزين الرسائل في الوضع الخاص افتراضيا.\nيرجى زيارة\n - حول:التكوين\n - تعيين dom.indexedDB.privateBrowsing.enabled إلى true\nخلاف ذلك ، لا يمكن تشغيل FluffyChat.", + "@indexedDbErrorLong": {}, + "switchToAccount": "التبديل إلى الحساب {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "addWidget": "إضافة اداة", + "@addWidget": {}, + "widgetEtherpad": "ملاحظة نصية", + "@widgetEtherpad": {}, + "youKickedAndBanned": "🙅 لقد ركلت وحظرت {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "قمت بإلغاء الحظر {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "saveKeyManuallyDescription": "احفظ هذا المفتاح يدويا عن طريق تشغيل مربع حوار مشاركة النظام أو الحافظة.", + "@saveKeyManuallyDescription": {}, + "widgetJitsi": "اجتماعات جيتسي", + "@widgetJitsi": {}, + "youInvitedUser": "📩 قمت بدعوة {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "storeInSecureStorageDescription": "قم بتخزين مفتاح الاسترداد في التخزين الآمن لهذا الجهاز.", + "@storeInSecureStorageDescription": {}, + "widgetName": "الاسم", + "@widgetName": {}, + "users": "المستخدمون", + "@users": {}, + "callingPermissions": "أذونات الاتصال", + "@callingPermissions": {}, + "callingAccount": "الاتصال بالحساب", + "@callingAccount": {}, + "callingAccountDetails": "يسمح لـ FluffyChat باستخدام تطبيق android Dialer الأصلي.", + "@callingAccountDetails": {}, + "appearOnTopDetails": "يسمح للتطبيق بالظهور في الأعلى (ليست هناك حاجة إذا قمت بالفعل بإعداد Fluffychat كحساب اتصال)", + "@appearOnTopDetails": {}, + "numChats": "{number} الدردشات", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "jump": "قفز", + "@jump": {}, + "report": "الإبلاغ", + "@report": {}, + "noKeyForThisMessage": "يمكن أن يحدث هذا إذا تم إرسال الرسالة قبل تسجيل الدخول إلى حسابك على هذا الجهاز.\n\nمن الممكن أيضا أن يكون المرسل قد حظر جهازك أو حدث خطأ ما في الاتصال بالإنترنت.\n\nهل يمكنك قراءة الرسالة في جلسة أخرى؟ ثم يمكنك نقل الرسالة منه! انتقل إلى الإعدادات > الأجهزة وتأكد من أن أجهزتك قد تحققت من بعضها البعض. عندما تفتح الغرفة في المرة التالية وتكون كلتا الجلستين في المقدمة ، سيتم إرسال المفاتيح تلقائيا.\n\nألا تريد أن تفقد المفاتيح عند تسجيل الخروج أو تبديل الأجهزة؟ تأكد من تمكين النسخ الاحتياطي للدردشة في الإعدادات.", + "@noKeyForThisMessage": {}, + "allSpaces": "كل المساحات", + "@allSpaces": {}, + "doNotShowAgain": "لا تظهر مرة أخرى", + "@doNotShowAgain": {}, + "wasDirectChatDisplayName": "محادثة فارغة (كانت {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "disableEncryptionWarning": "لأسباب أمنية ، لا يمكنك تعطيل التشفير في المحادثة ، حيث تم تمكينه من قبل.", + "@disableEncryptionWarning": {}, + "reportErrorDescription": "😭 أوه لا. هناك خطأ ما. إذا كنت تريد، يمكنك الإبلاغ عن هذا الخطأ إلى المطورين.", + "@reportErrorDescription": {}, + "newSpaceDescription": "يسمح لك تطبيق المساحات بتوحيد دردشاتك وبناء مجتمعات خاصة أو عامة.", + "@newSpaceDescription": {}, + "sorryThatsNotPossible": "معذرة... هذا غير ممكن", + "@sorryThatsNotPossible": {}, + "openLinkInBrowser": "فتح الرابط في المتصفح", + "@openLinkInBrowser": {}, + "reopenChat": "إعادة فتح المحادثة", + "@reopenChat": {}, + "noBackupWarning": "تحذير! بدون تمكين النسخ الاحتياطي للدردشة ، ستفقد الوصول إلى رسائلك المشفرة. يوصى بشدة بتمكين النسخ الاحتياطي للدردشة أولاً قبل تسجيل الخروج.", + "@noBackupWarning": {}, + "noOtherDevicesFound": "لم يتم العثور على أجهزة أخرى", + "@noOtherDevicesFound": {}, + "fileIsTooBigForServer": "تعذر الإرسال! لا يدعم الخادم سوى المرفقات التي تصل إلى {max}.", + "@fileIsTooBigForServer": {}, + "jumpToLastReadMessage": "الانتقال إلى آخر رسالة مقروءة", + "@jumpToLastReadMessage": {}, + "readUpToHere": "اقرأ حتى هنا", + "@readUpToHere": {}, + "signInWithPassword": "سجل الدخول بكلمة السر", + "@signInWithPassword": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "رجاء حاول مجددا أو اختر خادما مختلفا.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "signInWith": "تسجيل الدخول باستخدام {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "importNow": "استيراد الآن", + "@importNow": {}, + "importEmojis": "استيراد الرموز التعبيرية", + "@importEmojis": {}, + "exportEmotePack": "تصدير حزمة الرموز التعبيرية بتنسيق zip", + "@exportEmotePack": {}, + "notAnImage": "ليس ملف صورة.", + "@notAnImage": {}, + "importFromZipFile": "الاستيراد من ملف .zip", + "@importFromZipFile": {}, + "replace": "استبدال", + "@replace": {}, + "sendTypingNotifications": "إرسال إشعارات الكتابة", + "@sendTypingNotifications": {}, + "createGroup": "إنشاء مجموعة", + "@createGroup": {}, + "messagesStyle": "الرسائل:", + "@messagesStyle": {}, + "shareInviteLink": "شارك رابط الدعوة", + "@shareInviteLink": {}, + "profileNotFound": "لا يمكن العثور على المستخدم على الخادم. ربما هناك مشكلة في الاتصال أو المستخدم غير موجود.", + "@profileNotFound": {}, + "setTheme": "تعيين السمة:", + "@setTheme": {}, + "setColorTheme": "تعيين لون السمة:", + "@setColorTheme": {}, + "inviteContactToGroupQuestion": "هل تريد دعوة {contact} إلى المحادثة \"{groupName}\"؟?", + "@inviteContactToGroupQuestion": {}, + "tryAgain": "أعد المحاولة", + "@tryAgain": {}, + "redactMessageDescription": "سيتم تنقيح الرسالة لجميع المشاركين في هذه المحادثة. هذا لا يمكن التراجع عنها.", + "@redactMessageDescription": {}, + "optionalRedactReason": "(اختياري) سبب تنقيح هذه الرسالة ...", + "@optionalRedactReason": {}, + "redactedBy": "منقح بواسطة {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactedByBecause": "تم حجبه بواسطة {username} بسبب: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "invite": "دعوة", + "@invite": {}, + "addChatDescription": "أضف وصفًا للدردشة...", + "@addChatDescription": {}, + "chatPermissions": "صلاحيات المحادثة", + "@chatPermissions": {}, + "chatDescription": "وصف المحادثة", + "@chatDescription": {}, + "chatDescriptionHasBeenChanged": "تغير وصف المجموعة", + "@chatDescriptionHasBeenChanged": {}, + "noChatDescriptionYet": "لم يتم إنشاء وصف للمحادثة حتى الآن.", + "@noChatDescriptionYet": {}, + "invalidServerName": "اسم الخادم غير متاح", + "@invalidServerName": {}, + "setChatDescription": "تعيين وصفًا للدردشة", + "@setChatDescription": {}, + "directChat": "محادثة مباشرة", + "@directChat": {}, + "inviteGroupChat": "📨 دعوة للمحادثة الجماعية", + "@inviteGroupChat": {}, + "invitePrivateChat": "📨 دعوة دردشة خاصة", + "@invitePrivateChat": {}, + "emoteKeyboardNoRecents": "التعبيرات المستخدمة مؤخرًا ستظهر هنا ...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "invalidInput": "مدخل غير صالح!", + "@invalidInput": {}, + "wrongPinEntered": "تم إدخال رمز خاطئ! حاول مرة أخرى خلال {seconds} ثانية...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "hasKnocked": "🚪 لقد طرق {user}", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "pleaseEnterANumber": "الرجاء إدخال رقم أكبر من 0", + "@pleaseEnterANumber": {}, + "banUserDescription": "سيتم حظر المستخدم من المحادثة ولن يتمكن من الدخول إلى المحادثة مرة أخرى حتى يتم رفع الحظر عنه.", + "@banUserDescription": {}, + "removeDevicesDescription": "سيتم تسجيل خروجك من هذا الجهاز ولن تتمكن بعد ذلك من تلقي الرسائل.", + "@removeDevicesDescription": {}, + "unbanUserDescription": "سيتمكن المستخدم من الدخول إلى المحادثة مرة أخرى إذا حاول.", + "@unbanUserDescription": {}, + "pushNotificationsNotAvailable": "دفع الإخطارات غير متوفرة", + "@pushNotificationsNotAvailable": {}, + "makeAdminDescription": "بمجرد تعيين هذا المستخدم كمسؤول، قد لا تتمكن من التراجع عن هذا لأنه سيكون لديه نفس الأذونات التي تتمتع بها.", + "@makeAdminDescription": {}, + "archiveRoomDescription": "سيتم نقل المحادثة إلى الأرشيف. سيتمكن المستخدمون الآخرون من رؤية أنك غادرت المحادثة.", + "@archiveRoomDescription": {}, + "learnMore": "تعلم المزيد", + "@learnMore": {}, + "roomUpgradeDescription": "سيتم بعد ذلك إعادة إنشاء المحادثة باستخدام إصدار الغرفة الجديد. سيتم إخطار جميع المشاركين بأنهم بحاجة إلى التبديل إلى المحادثة الجديدة. يمكنك معرفة المزيد حول إصدارات الغرف على https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "kickUserDescription": "يتم طرد المستخدم من المحادثة ولكن لا يتم حظره. في المحادثات العامة، يمكن للمستخدم الانضمام مرة أخرى في أي وقت.", + "@kickUserDescription": {}, + "createGroupAndInviteUsers": "إنشاء مجموعة ودعوة المستخدمين", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "يمكن العثور على المجموعة عبر البحث", + "@groupCanBeFoundViaSearch": {}, + "noUsersFoundWithQuery": "لسوء الحظ، لا يمكن العثور على مستخدم لديه \"{query}\". يرجى التحقق مما إذا كنت قد ارتكبت خطأ كتابي.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "yourGlobalUserIdIs": "معرف المستخدم العمومي الخاص بك هو: ", + "@yourGlobalUserIdIs": {}, + "groupName": "أسم المجموعة", + "@groupName": {}, + "searchChatsRooms": "ابحث عن #الدردشات، @المستخدمين...", + "@searchChatsRooms": {}, + "startConversation": "بدء محادثة", + "@startConversation": {}, + "commandHint_sendraw": "إرسال جيسون الخام", + "@commandHint_sendraw": {}, + "wrongRecoveryKey": "عذرًا... لا يبدو أن هذا هو مفتاح الاسترداد الصحيح.", + "@wrongRecoveryKey": {}, + "blockListDescription": "يمكنك حظر المستخدمين الذين يزعجونك. لن تتمكن من تلقي أي رسائل أو دعوات للغرفة من المستخدمين الموجودين في قائمة الحظر الشخصية الخاصة بك.", + "@blockListDescription": {}, + "blockedUsers": "المستخدمون المحظورون", + "@blockedUsers": {}, + "block": "حظر", + "@block": {}, + "blockUsername": "تجاهل اسم المستخدم", + "@blockUsername": {}, + "databaseMigrationTitle": "تم تحسين قاعدة البيانات", + "@databaseMigrationTitle": {}, + "databaseMigrationBody": "انتظر من فضلك. قد يستغرق ذلك بعض الوقت.", + "@databaseMigrationBody": {}, + "thisDevice": "هذا الجهاز:", + "@thisDevice": {}, + "publicSpaces": "مساحة عامة", + "@publicSpaces": {}, + "passwordIsWrong": "كلمة السر للدخول خاطئة", + "@passwordIsWrong": {}, + "pleaseEnterYourCurrentPassword": "من فضلك أدخل كلمة السر الحالية", + "@pleaseEnterYourCurrentPassword": {}, + "publicLink": "رابط عام", + "@publicLink": {}, + "nothingFound": "لم نجد شيئاً.", + "@nothingFound": {}, + "decline": "رفض", + "@decline": {}, + "newPassword": "كلمة المرور الجديدة", + "@newPassword": {}, + "passwordsDoNotMatch": "كلمات المرور لا تتطابق", + "@passwordsDoNotMatch": {}, + "subspace": "مساحة فرعية", + "@subspace": {}, + "select": "اختر", + "@select": {}, + "pleaseChooseAStrongPassword": "الرجاء اختيار كلمة مرور قوية", + "@pleaseChooseAStrongPassword": {}, + "addChatOrSubSpace": "إضافة دردشة أو مساحة فرعية", + "@addChatOrSubSpace": {}, + "leaveEmptyToClearStatus": "اتركه فارغًا لمسح حالتك.", + "@leaveEmptyToClearStatus": {}, + "joinSpace": "انضم إلى المساحة", + "@joinSpace": {}, + "searchForUsers": "ابحث عن @users...", + "@searchForUsers": {}, + "databaseBuildErrorBody": "غير قادر على بناء قاعدة بيانات SQlite. يحاول التطبيق استخدام قاعدة بيانات قديمة في الوقت الحالي. الرجاء الإبلاغ عن هذا الخطأ للمطورين على {url}. رسالة الخطأ هي: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "حدث خطأ بداخل التطبيق", + "@initAppError": {}, + "sessionLostBody": "جلستك مفقودة يرجى إبلاغ المطورين بهذا الخطأ في {url}. رسالة الخطأ هي: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "يحاول التطبيق الآن استعادة جلستك من النسخة الاحتياطية. الرجاء الإبلاغ عن هذا الخطأ للمطورين على {url}. رسالة الخطأ هي:{error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "completedKeyVerification": "أكمل {sender} عملية التحقق من المفتاح", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "طلب {sender} التحقق من المفتاح", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "شفّاف", + "@transparent": {}, + "youInvitedToBy": "📩 تمت دعوتك عبر الرابط إلى:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "formattedMessagesDescription": "عرض محتوى الرسالة الغنية مثل النص الغامق باستخدام الماركداون.", + "@formattedMessagesDescription": {}, + "verifyOtherUserDescription": "إذا قمت بالتحقق من مستخدم آخر، فيمكنك التأكد من أنك تعرف من تكتب إليه حقًا. 💪\n\nعند بدء عملية التحقق، سترى أنت والمستخدم الآخر نافذة منبثقة في التطبيق. هناك سترى بعد ذلك سلسلة من الرموز التعبيرية أو الأرقام التي يتعين عليك مقارنتها مع بعضها البعض.\n\nأفضل طريقة للقيام بذلك هي الالتقاء أو بدء مكالمة فيديو. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDeviceDescription": "عند التحقق من جهاز آخر، يمكن لهذه الأجهزة تبادل المفاتيح، مما يزيد من أمانك بشكل عام. 💪 عند بدء عملية التحقق، ستظهر نافذة منبثقة في التطبيق على كلا الجهازين. هناك سترى بعد ذلك سلسلة من الرموز التعبيرية أو الأرقام التي يتعين عليك مقارنتها مع بعضها البعض. من الأفضل أن يكون كلا الجهازين في متناول يديك قبل بدء عملية التحقق. 🤳", + "@verifyOtherDeviceDescription": {}, + "formattedMessages": "رسائل منسقة", + "@formattedMessages": {}, + "sendReadReceipts": "إرسال بالقراءة", + "@sendReadReceipts": {}, + "verifyOtherDevice": "🔐 التحقق من الجهاز الآخر", + "@verifyOtherDevice": {}, + "forwardMessageTo": "هل تريد إعادة توجيه الرسالة إلى {roomName}؟", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "يستطيع المشاركون الآخرون في المحادثة رؤيتك عند كتابة رسالة جديدة.", + "@sendTypingNotificationsDescription": {}, + "sendReadReceiptsDescription": "يمكن للمشاركين الآخرين في المحادثة معرفة متى قرأت الرسالة.", + "@sendReadReceiptsDescription": {}, + "verifyOtherUser": "🔐 التحقق من المستخدم الآخر", + "@verifyOtherUser": {}, + "acceptedKeyVerification": "وافق {sender} على التحقق من المفتاح", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "قام {sender} بإلغاء التحقق من المفتاح", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} جاهز للتحقق من المفتاح", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "بدأ {sender} عملية التحقق من المفتاح", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "hidePresences": "إخفاء قائمة الحالة؟", + "@hidePresences": {}, + "incomingMessages": "الرسائل الواردة", + "@incomingMessages": {}, + "presenceStyle": "الحضور:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "إظهار رسائل الحالة من المستخدمين الآخرين", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "stickers": "الملصقات", + "@stickers": {}, + "discover": "استكشف", + "@discover": {}, + "commandHint_ignore": "تجاهل معرف المصفوفة المعطى", + "@commandHint_ignore": {}, + "commandHint_unignore": "إلغاء تجاهل معرف المصفوفة المحدد", + "@commandHint_unignore": {}, + "unreadChatsInApp": "{appname}: {unread} الدردشات غير المقروءة", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "تشفير قاعدة البيانات غير مدعوم على هذا النظام الأساسي", + "@noDatabaseEncryption": {}, + "appLockDescription": "قفل التطبيق عند عدم استخدامه بالرمز السري", + "@appLockDescription": {}, + "accessAndVisibility": "الوصول والرؤية", + "@accessAndVisibility": {}, + "calls": "المكالمات", + "@calls": {}, + "customEmojisAndStickers": "الرموز التعبيرية والملصقات المخصصة", + "@customEmojisAndStickers": {}, + "hideRedactedMessagesBody": "إذا قام شخص ما بتنقيح رسالة، فلن تكون هذه الرسالة مرئية في المحادثة بعد الآن.", + "@hideRedactedMessagesBody": {}, + "hideInvalidOrUnknownMessageFormats": "إخفاء تنسيقات الرسائل غير الصالحة أو غير المعروفة", + "@hideInvalidOrUnknownMessageFormats": {}, + "overview": "نظرة عامة", + "@overview": {}, + "notifyMeFor": "أعلمني بـ", + "@notifyMeFor": {}, + "passwordRecoverySettings": "إعدادات استعادة كلمة المرور", + "@passwordRecoverySettings": {}, + "globalChatId": "معرف المحادثة العامة", + "@globalChatId": {}, + "accessAndVisibilityDescription": "من المسموح له بالانضمام إلى هذه المحادثة وكيف يمكن اكتشاف المحادثة.", + "@accessAndVisibilityDescription": {}, + "customEmojisAndStickersBody": "قم بإضافة أو مشاركة الرموز التعبيرية أو الملصقات المخصصة التي يمكن استخدامها في أي دردشة.", + "@customEmojisAndStickersBody": {}, + "hideRedactedMessages": "إخفاء الرسائل المكررة", + "@hideRedactedMessages": {}, + "hideMemberChangesInPublicChats": "إخفاء تغييرات الأعضاء في الدردشات العامة", + "@hideMemberChangesInPublicChats": {}, + "hideMemberChangesInPublicChatsBody": "لا تظهر في المخطط الزمني للدردشة إذا انضم شخص ما إلى محادثة عامة أو غادرها لتحسين إمكانية القراءة.", + "@hideMemberChangesInPublicChatsBody": {}, + "usersMustKnock": "المستخدم يجب أن يطرق الباب", + "@usersMustKnock": {}, + "chatCanBeDiscoveredViaSearchOnServer": "يمكن اكتشاف الشات عن طريق البحث في {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "noOneCanJoin": "لا أحد يستطيع الانضمام", + "@noOneCanJoin": {}, + "knocking": "طرق", + "@knocking": {}, + "userWouldLikeToChangeTheChat": "{user} يرغب في الانضمام إلى المحادثة.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "لم يتم بعد إنشاء أي رابط عام", + "@noPublicLinkHasBeenCreatedYet": {}, + "knock": "دق", + "@knock": {}, + "thereAreCountUsersBlocked": "يوجد حاليًا {count} من المستخدمين المحظورين.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "publicChatAddresses": "عناوين المحادثة العامة", + "@publicChatAddresses": {}, + "createNewAddress": "إنشاء عنوان جديد", + "@createNewAddress": {}, + "userRole": "دور المستخدم", + "@userRole": {}, + "minimumPowerLevel": "{level} هو الحد الأدنى من مستوى الطاقة.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "بحث في {chat}...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "files": "الملفات", + "@files": {}, + "restricted": "مقيد", + "@restricted": {}, + "knockRestricted": "قيود النقر", + "@knockRestricted": {}, + "searchMore": "ابحث أكثر...", + "@searchMore": {}, + "gallery": "المعرض", + "@gallery": {}, + "swipeRightToLeftToReply": "اسحب من اليمين إلى اليسار للرد", + "@swipeRightToLeftToReply": {}, + "alwaysUse24HourFormat": "علّم لعرض الوقت بنسق 24 ساعة دائما.‏", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "countChatsAndCountParticipants": "{chats} دردشات و {participants} مشاركين", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "لم يتم العثور على دردشات...", + "@noMoreChatsFound": {}, + "joinedChats": "انضم إلى الدردشة", + "@joinedChats": {}, + "unread": "غير المقروءة", + "@unread": {}, + "space": "المساحة", + "@space": {}, + "spaces": "المساحات", + "@spaces": {}, + "markAsUnread": "تحديد كغير مقروء", + "@markAsUnread": {}, + "goToSpace": "انتقل إلى المساحة: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "userLevel": "{level} - مستخدم", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - مشرف", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - مدير", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "تغيير إعدادات الدردشة العامة", + "@changeGeneralChatSettings": {}, + "inviteOtherUsers": "دعوة مستخدمين آخرين إلى هذه الدردشة", + "@inviteOtherUsers": {}, + "changeTheChatPermissions": "تغيير أذونات الدردشة", + "@changeTheChatPermissions": {}, + "changeTheVisibilityOfChatHistory": "تغيير رؤية سجل الدردشة", + "@changeTheVisibilityOfChatHistory": {}, + "changeTheCanonicalRoomAlias": "تغيير عنوان الدردشة العامة الرئيسي", + "@changeTheCanonicalRoomAlias": {}, + "sendRoomNotifications": "إرسال إشعارات @room", + "@sendRoomNotifications": {}, + "changeTheDescriptionOfTheGroup": "تغيير وصف الدردشة", + "@changeTheDescriptionOfTheGroup": {}, + "invitedBy": "📩 تمت دعوته من قبل {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "chatPermissionsDescription": "‪حدد مستوى الصلاحية الضروري لإجراءات معينة في هذه الدردشة. عادة ما تمثل مستويات الصلاحية 0 و 50 و 100 المستخدمين والمشرفين ولكن أي تدرج ممكن.", + "@chatPermissionsDescription": {}, + "changelog": "سجل التغييرات", + "@changelog": {}, + "updateInstalled": "تم تثبيت🎉 تحديث {version}!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "sendCanceled": "تم إلغاء الإرسال", + "@sendCanceled": {}, + "noChatsFoundHere": "لم يتم العثور على دردشات هنا حتى الآن. ابدأ محادثة جديدة مع شخص ما باستخدام الزر أدناه. ⤵️", + "@noChatsFoundHere": {}, + "loginWithMatrixId": "تسجيل الدخول باستخدام معرف ماتريكس", + "@loginWithMatrixId": {}, + "discoverHomeservers": "اكتشف الخوادم المنزلية", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "ما هو خادم المنزل ؟", + "@whatIsAHomeserver": {}, + "homeserverDescription": "يتم تخزين جميع بياناتك على خادم المنزل، تمامًا مثل مزود خدمة البريد الإلكتروني. يمكنك اختيار خادم البيت الذي تريد استخدامه، بينما لا يزال بإمكانك التواصل مع الجميع. اعرف المزيد على https://matrix.org.", + "@homeserverDescription": {}, + "doesNotSeemToBeAValidHomeserver": "لا يبدو أنه خادم منزلي متوافق. عنوان URL غير صحيح ؟", + "@doesNotSeemToBeAValidHomeserver": {}, + "calculatingFileSize": "جارٍ حساب حجم الملف...", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "إعداد مرفق الإرسال...", + "@prepareSendingAttachment": {}, + "sendingAttachment": "جارٍ إرسال المرفق...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "جارٍ إنشاء صورة مصغرة للفيديو...", + "@generatingVideoThumbnail": {}, + "compressVideo": "جارٍ ضغط الفيديو...", + "@compressVideo": {}, + "sendingAttachmentCountOfCount": "جارٍ إرسال المرفق {index} من {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "تم الوصول إلى حد الخادم! انتظر {seconds} ثانية...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "لم يتم التحقق من أحد أجهزتك", + "@oneOfYourDevicesIsNotVerified": {}, + "noticeChatBackupDeviceVerification": "ملاحظة: عند توصيل جميع أجهزتك بنسخة احتياطية للدردشة، يتم التحقق منها تلقائيًا.", + "@noticeChatBackupDeviceVerification": {}, + "continueText": "استمرار", + "@continueText": {}, + "welcomeText": "مرحبًا، 👋 معك FluffyChat. يمكنك تسجيل الدخول إلى أي خادم منزلي، وهو متوافق مع https://matrix.org. ثم دردش مع أي شخص. إنها شبكة مراسلة لا مركزية ضخمة!", + "@welcomeText": {}, + "blur": "الضبابية:", + "@blur": {}, + "setWallpaper": "تعيين الخلفية", + "@setWallpaper": {}, + "opacity": "التعتيم:", + "@opacity": {}, + "manageAccount": "‫إدارة الحساب‬", + "@manageAccount": {}, + "noContactInformationProvided": "لا يقدم السيرفر أي معلومات اتصال صحيحة", + "@noContactInformationProvided": {}, + "contactServerAdmin": "اتصل بمسؤول الخادم", + "@contactServerAdmin": {}, + "contactServerSecurity": "الاتصال بمسؤول أمان ااخادم", + "@contactServerSecurity": {}, + "supportPage": "صفحة الدعم", + "@supportPage": {}, + "serverInformation": "معلومات الخادم:", + "@serverInformation": {}, + "name": "الإسم", + "@name": {}, + "version": "اﻹصدار", + "@version": {}, + "website": "الموقع اﻹلكتروني", + "@website": {}, + "aboutHomeserver": "حول {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "boldText": "خط غامق", + "@boldText": {}, + "italicText": "خط مائل", + "@italicText": {}, + "strikeThrough": "يتوسطه خط", + "@strikeThrough": {}, + "invalidUrl": "رابط غير صحيح", + "@invalidUrl": {}, + "addLink": "إضافة رابط", + "@addLink": {}, + "pleaseFillOut": "من فضلك قم بتعبئته", + "@pleaseFillOut": {}, + "unableToJoinChat": "يتعذر الانضمام إلى الدردشة. ربما يكون الطرف الآخر قد أغلق المحادثة بالفعل.", + "@unableToJoinChat": {}, + "sendImages": "إرسال {count} صورة", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "ضغط", + "@compress": {}, + "previous": "السابق", + "@previous": {}, + "otherPartyNotLoggedIn": "لم يقم الطرف الآخر بتسجيل الدخول حالياً وبالتالي لا يمكنه تلقي الرسائل!", + "@otherPartyNotLoggedIn": {}, + "setCustomPermissionLevel": "حدد مستوى صلاحية مخصص", + "@setCustomPermissionLevel": {} +} diff --git a/lib/l10n/intl_be.arb b/lib/l10n/intl_be.arb new file mode 100644 index 000000000..0ae7d887f --- /dev/null +++ b/lib/l10n/intl_be.arb @@ -0,0 +1,3502 @@ +{ + "alwaysUse24HourFormat": "адключана", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "repeatPassword": "Паўтарыце пароль", + "@repeatPassword": {}, + "notAnImage": "Не файл выявы.", + "@notAnImage": {}, + "setCustomPermissionLevel": "Задаць карыстальніцкі ўзровень дазволу", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Калі ласка, выберыце ролю ніжэй ці ўвядзіце карыстальніцкі ўзровень дазволу паміж 0 і 100.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Ігнараваць карыстальніка", + "@ignoreUser": {}, + "normalUser": "Звычайны карыстальнік", + "@normalUser": {}, + "remove": "Прыбраць", + "@remove": { + "type": "String", + "placeholders": {} + }, + "importNow": "Імпартаваць зараз", + "@importNow": {}, + "importEmojis": "Імпартаваць эмодзі", + "@importEmojis": {}, + "importFromZipFile": "Імпартаваць з файла .zip", + "@importFromZipFile": {}, + "exportEmotePack": "Экспартаваць пак эмодзі як .zip", + "@exportEmotePack": {}, + "replace": "Замяніць", + "@replace": {}, + "about": "Пра праграму", + "@about": {}, + "aboutHomeserver": "Пра {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "accept": "Прыняць", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} прыняў запрашэнне", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Уліковы запіс", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} актывіраваў end to end шыфраванне", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Дадаць email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Калі ласка, спраўдзіце свой Matrix ID перад выдаленнем свайго ўліковага запісу.", + "@confirmMatrixId": {}, + "supposedMxid": "Гэта павінна быць накшталт {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "Дадайце апісанне чату...", + "@addChatDescription": {}, + "addToSpace": "Дадаць у прастору", + "@addToSpace": {}, + "admin": "Адмін", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "псеўданім", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Усё", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Усе чаты", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_roomupgrade": "Абнавіце гэты пакой да згаданай версіі", + "@commandHint_roomupgrade": {}, + "commandHint_googly": "Даслаць смешныя вочы", + "@commandHint_googly": {}, + "commandHint_cuddle": "Даслаць усмешку", + "@commandHint_cuddle": {}, + "commandHint_hug": "Даслаць абдымашкі", + "@commandHint_hug": {}, + "googlyEyesContent": "{senderName} даслаў(-ла) вам смешныя вочы", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} усміхаецца вам", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} абдымае вас", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "answeredTheCall": "{senderName} адказаў(-ла) на выклік", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Усе могуць далучыцца", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Код-пароль", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "Блакіруе праграму, пакуль вы не ўвядзіце пін-код", + "@appLockDescription": {}, + "archive": "Архіў", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Ці дазволена карыстальнікам-гасцям далучыцца", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Вы ўпэўнены?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Вы ўпэўнены, што хаціце выйсці?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Каб спраўдзіць іншага чалавека, калі ласка, увядзіце фразу-пароль ці ключ аднаўлення.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Прыняць запрос на верыфікацыю ад {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Аўтаматычна прайграваць аніміраваныя стыкеры і эмодзі", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "Хатні сервер падтрымлівае наступныя метады ўваходу:\n{serverVersions}\nАле гэта праграма падтрымлівае толькі:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendTypingNotifications": "Дасылаць паведамленне пра друк", + "@sendTypingNotifications": {}, + "swipeRightToLeftToReply": "Змахніце ўлева, каб адказаць", + "@swipeRightToLeftToReply": {}, + "sendOnEnter": "Дасылаць на enter", + "@sendOnEnter": {}, + "badServerVersionsException": "Хатні сервер падтрымлівае наступныя версіі спецыфікацыі:\n{serverVersions}\nАле гэта праграма падтрымлівае толькі:{supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "countChatsAndCountParticipants": "{chats} чатаў і {participants} удзельнікаў", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Болей чатаў не знойдзена...", + "@noMoreChatsFound": {}, + "noChatsFoundHere": "Здаецца, тут пуста. Пачніце новы чат з кімсьці праз кнопку ніжэй. ⤵️", + "@noChatsFoundHere": {}, + "joinedChats": "Чаты, да якіх вы далучыліся", + "@joinedChats": {}, + "unread": "Непрачытаные", + "@unread": {}, + "space": "Прастора", + "@space": {}, + "spaces": "Прасторы", + "@spaces": {}, + "banFromChat": "Заблакіраваць ў чаце", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Заблакіраваны", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} заблакіраваў {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Заблакіраваць прыладу", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Заблакіравана", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Паведамленні ботаў", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Скасаваць", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Немагчыма адкрыць URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Змяніць назву прылады", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} змяніў выяву чата", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} змяніў апісанне чата на :'{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} змяніў назву чата на '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} змяніў дазволы чата", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} змяніў адлюстроўваемае імя на: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} змяніў правілы гасцявога доступу", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} змяніў правілы гасцявога доступу на: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} змяніў бачнасць гісторыі", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} змяніў бачнасць гісторыі на: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} змяніў правілы падлучэння", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} змяніў правілы падлучэння на: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} змяніў свой аватар", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "noMessagesYet": "Паведамленняў пакуль што няма", + "@noMessagesYet": {}, + "changedTheRoomAliases": "{username} змяніў псеўданімы пакою", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} змяніў(-ла) запрашальную спасылку", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Змяніць пароль", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Змяніць дамашні сервер", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Змяніць ваш стыль", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Змяніць назву групы", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Змяніць вашу выяву", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Шыфраванне было сапсавана", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Чат", + "@chat": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Рэзервовае капіраванне чатаў было наладжана.", + "@yourChatBackupHasBeenSetUp": {}, + "chatBackup": "Рэзервовае капіраванне чатаў", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Вашы паведамленні абаронены ключом аднаўлення. Калі ласка, пераканайцеся ў тым, што вы яго не згубіце.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Дэталі чата", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Чат быў дададзены ў гэту прастору", + "@chatHasBeenAddedToThisSpace": {}, + "chats": "Чаты", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Стварыце надзейны пароль", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Ачысціць архіў", + "@clearArchive": {}, + "close": "Закрыць", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasdm": "Пазначыць як пакой асабоных паведамленняў для дадання Matrix ID", + "@commandHint_markasdm": {}, + "commandHint_markasgroup": "Пазначыць як групу", + "@commandHint_markasgroup": {}, + "commandHint_ban": "Заблакіраваць карыстальніка у гэтым пакое", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Ачысціць кэш", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Стварыць пусты групавы чат.\nВыкарыстоўвайце --no-encryption каб адключыць шыфраванне", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Спыніць сеанс", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Пачаць асобны чат.\nВыкарыстоўвайце --no-encryption, каб адключыць шыфраванне", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_html": "Даслаць тэкст з разметкай HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Запрасіць карыстальніка ў гэты пакой", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Далучыцца да гэтага пакою", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Выдаліць карыстальніка з гэтага пакою", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Пакінуць гэты пакой", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Апішыце сябе", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Задаць выяву гэтага пакою (ад mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Задайце адлюстроўваемае імя для гэтага пакою", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Задайце ўзровень правоў гэтага карыстальніка (па змаўчанні: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Даслаць неадфарматыраваны тэкст", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Даслаць адказ як рэакцыю", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Даслаць тэкст", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Разблакіраваць карыстальніка ў гэтым пакое", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Няслушная каманда", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} не каманда.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Калі ласка, параўнайце эмодзі", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Калі ласка, параўнайце лічбы", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Наладзіць чат", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Пацвердзіць", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Далучыцца", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Кантакт быў запрошаны ў групу", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Мае адлюстроўваемае імя", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Мае імя карыстальніка", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Пра кантэнт было паведамлена адміністратарам сервера", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Скапіравана ў буфер", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Капіраваць", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Скапіраваць у буфер", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Немагчыма расшыфраваць паведамленне: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "checkList": "Кантрольны спіс", + "@checkList": {}, + "countParticipants": "{count} удзельніка(-ў)", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "countInvited": "Запрошана {count}", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Стварыць", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} стварыў(-ла) чат", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createGroup": "Стварыць групу", + "@createGroup": {}, + "createNewSpace": "Новая прастора", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Зараз актыўны", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Цёмная", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Гэта дэактывіруе ваш уліковы запіс. Гэта дзеянне не можа быць адменена! Вы ўпэўнены?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Узровень дазволаў для новых карыстальнікаў па змаўчанні", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Выдаліць", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Выдаліць уліковы запіс", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Выдаліць паведамленне", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Прылада", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID прылады", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Прылады", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Асобныя чаты", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "allRooms": "Усе групавыя чаты", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Адлюстроўваемае імя было зменена", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Спампаваць файл", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Змяніць", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Змяніць заблакіраваныя сервера", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "Дазволы чату", + "@chatPermissions": {}, + "editDisplayname": "Змяніць адлюстроўваемае імя", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Змяніць псеўданімы пакою", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Змяніць выяву пакою", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Эмодзі ўжо існуе!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Недапушчальнае скарачэнне эмодзі!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteKeyboardNoRecents": "Нядаўна ўжытыя эмодзі паявяцца тут...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Наборы эмодзі для пакою", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Налады эмодзі", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "ID габальнага чату", + "@globalChatId": {}, + "accessAndVisibility": "Даступнасць і бачнасць", + "@accessAndVisibility": {}, + "accessAndVisibilityDescription": "Каму дазволена далучацца да гэтага чату і як ён можа быць знойдзены.", + "@accessAndVisibilityDescription": {}, + "calls": "Выклікі", + "@calls": {}, + "customEmojisAndStickers": "Карыстальніцкія эмодзі і стыкеры", + "@customEmojisAndStickers": {}, + "customEmojisAndStickersBody": "Дадаць ці падзяліцца карыстальніцкімі эмодзі ці стыкерамі, што могуць быць ужыты ў любым чаце.", + "@customEmojisAndStickersBody": {}, + "emoteShortcode": "Скарачэнне эмодзі", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Вы павінны задаць скарачэнне эмодзі і выяву!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Пусты чат", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Уключыць набор эмодзі глабальна", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Уключыць шыфраванне", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Вы больш не зможаце адключыць шыфраванне. Вы ўпэўнены?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Зашыфравана", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Шыфраванне", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Шыфраванне не ўключана", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} скончыў выклік", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enableMultiAccounts": "(БЭТА) Уключыць некалькі ўліковых запісаў на гэтай прыладзе", + "@enableMultiAccounts": {}, + "enterAnEmailAddress": "Увядзіце электроную пошту (email)", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Дамашні сервер", + "@homeserver": {}, + "enterYourHomeserver": "Увядзіце адрас дамашняга сервера", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Памылка атрымання месцазнаходжання: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Усё гатова!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Занадта абражальны", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Назва файла", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Памер шрыфту", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Пераслаць", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "З далучэння", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "З запрашэння", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Перайсці ў новы пакой", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Група", + "@group": { + "type": "String", + "placeholders": {} + }, + "chatDescription": "Апісанне чату", + "@chatDescription": {}, + "chatDescriptionHasBeenChanged": "Апісанне чату зменена", + "@chatDescriptionHasBeenChanged": {}, + "groupIsPublic": "Група публічная", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Групы", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Групы з {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Госці забаронены", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Госці могуць далучацца", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} адазваў запрашэнне для {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Дапамога", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Схаваць адрэдагаваныя падзеі", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideRedactedMessages": "Схаваць адрэдагаваныя паведамленні", + "@hideRedactedMessages": {}, + "hideRedactedMessagesBody": "Калі хтосьці рэдагуе паведамленне, яно будзе схавана ў чаце.", + "@hideRedactedMessagesBody": {}, + "hideInvalidOrUnknownMessageFormats": "Хаваць памылковыя ці невядомыя фарматы паведамленняў", + "@hideInvalidOrUnknownMessageFormats": {}, + "howOffensiveIsThisContent": "Наколькі абражальны гэты кантэнт?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Ідэнтыфікацыя", + "@identity": { + "type": "String", + "placeholders": {} + }, + "block": "Заблакіраваць", + "@block": {}, + "blockedUsers": "Заблакіраваныя карыстальнікі", + "@blockedUsers": {}, + "blockListDescription": "Вы можаце заблакіраваць карыстальнікаў, якія вам перашкаджаюць. Вы не атрымаеце ад іх ні паведамленняў, ні запрашэнняў.", + "@blockListDescription": {}, + "blockUsername": "Ігнараваць імя карыстальніка", + "@blockUsername": {}, + "iHaveClickedOnLink": "Я перайшоў па спасылцы", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Няслушныя фраза-пароль ці ключ аднаўлення", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Безабідны", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Запрасіць кантакт", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroupQuestion": "Вы хаціце запрасіць {contact} да чату \"{groupName}\"?", + "@inviteContactToGroupQuestion": {}, + "inviteContactToGroup": "Запрасіць кантакт да {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "Апісанне чату яшчэ няма.", + "@noChatDescriptionYet": {}, + "tryAgain": "Паспрабуйце зноў", + "@tryAgain": {}, + "invalidServerName": "Недапушчальная назва сервера", + "@invalidServerName": {}, + "invited": "Запрошаны", + "@invited": { + "type": "String", + "placeholders": {} + }, + "redactMessageDescription": "Гэта паведамленне будзе адрэдагавана для усіх карыстальнікаў. Вы не зможаце яго адмяніць.", + "@redactMessageDescription": {}, + "optionalRedactReason": "(Неабавязкова) Прычына рэдагавання паведамлення...", + "@optionalRedactReason": {}, + "invitedUser": "📩 {username} запрасіў(-ла) {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Толькі запрошаныя карыстальнікі", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Запрашэнне для мяне", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} запрасіў вас у FluffyChat.\n1. Перайдзіце на fluffychat.im і ўстанавіце праграму\n2. Зарэгестрыруйцесь альбо ўвайдзіце\n3. Перайдзіце па запрашальнай спасылцы:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "піша…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} далучыўся(лася) да чату", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Далучыцца да пакою", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} выгнаў(-ла) {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} выгнаў(-ла) і заблакіраваў(-ла) {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Выгнаць з чату", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Апошняя актыўнасць: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Выйсці", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Выйсці з чату", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Ліцэнзія", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Светлая", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Загрузіць яшчэ {count} удзельнікаў", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrate": "Экспарт сеансу і ачыстка прылады", + "@dehydrate": {}, + "dehydrateWarning": "Гэта дзеянне не можа быць адменена. Пераканайцеся, што вы бяспечна захавалі файл рэзервовай копіі.", + "@dehydrateWarning": {}, + "dehydrateTor": "Карыстальнікі TOR: Экспарт сесіі", + "@dehydrateTor": {}, + "dehydrateTorLong": "Для карыстальнікаў TOR прапануем экспартаваць сесію перад тым, як закрыць акно.", + "@dehydrateTorLong": {}, + "hydrateTor": "Карыстальнікі TOR: Імпарт экспарту сесіі", + "@hydrateTor": {}, + "hydrateTorLong": "Вы экспартавалі сесію ў мінулы раз праз TOR? Хутка імпартуйце яе і працягніце размовы.", + "@hydrateTorLong": {}, + "hydrate": "Аднавіць з рэзервовай копіі", + "@hydrate": {}, + "loadingPleaseWait": "Загрузка... Калі ласка, пачакайце.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Загрузіць больш…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Сервісы месцазнаходжанн, адключаны. Калі ласка, уключыце іх, каб зноў дзяліцца месцазнаходжаннем.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Дазвол атрымання месцазнаходжання скасаваны. Калі ласка, дайце яго каб дзяліцца месцазнаходжаннем.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Логін", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Увайсці ў {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Выйсці", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Змяненні ўдзельнікаў", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Згадаць", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Паведамленні", + "@messages": { + "type": "String", + "placeholders": {} + }, + "messagesStyle": "Паведамленні:", + "@messagesStyle": {}, + "moderator": "Мадэратар", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Заглушыць чат", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Пераканайцеся, калі ласка, што вы выкарыстоўваеце Pantalaimon для end-to-end шыфравання.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Новы чат", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Новае паведамленне ў FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Новы запыт на верыфікацыю!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Далей", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Не", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Няма злучэння з серверам", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Эмодзі не знойдзены. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Вы зможаце актывіраваць шыфраванне як толькі пакой перастане быць агульнадаступным.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Здаецца, на вашай прыладзе няма ці недаступны Firebase Cloud Messaging. Каб далей атрымліваць паведамленні, мы прапануем усталяваць ntfy ці іншы правайдар паведамленняў, каб атрымліваць іх бяспечна. Вы можаце спампаваць ntfy з PlayStore ці F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} не з'яўляецца серверам matrix. Выкарыстоўваць {server2} замест яго?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "shareInviteLink": "Падзяліцца запрашальнай спасылкай", + "@shareInviteLink": {}, + "scanQrCode": "Сканіраваць QR-код", + "@scanQrCode": {}, + "none": "Нічога", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Вы яшчэ не дадалі метад аднаўлення пароля.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Няма дазволу", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Пакоі не знойдзены…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Паведамленні", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "setChatDescription": "Задаць апісанне чату", + "@setChatDescription": {}, + "setInvitationLink": "Задаць запрашальную спасылку", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Задаць ўзровееь дазволаў", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Задаць статус", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Налады", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Падзяліцца", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} падзяліўся(-лася) сваім месцазнаходжаннем", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Падзяліцца месцазнаходжаннем", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Паказаць пароль", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "Прысутнасць:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Паказваць паведасленні статусаў іншых карыстальнікаў", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Адзіны ўваход", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Прапусціць", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Зыходны код", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Прастора публічна", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Назва прасторы", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} пачаў выклік", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "startFirstChat": "Пачніце ваш першы чат", + "@startFirstChat": {}, + "status": "Статус", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Як вашыя справы?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Дастасаваць", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Сінхранізацыя... Калі ласка, пачакайце.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWaitCounter": " Сінхарнізацыя… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "systemTheme": "Сістэма", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Яны не супадаюць", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Яны супадаюць", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Пераключыць Захаванае", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Пераключыць гук", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Бачна ўсім", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Галасавое паведамленне", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Чакаем, калі партнёр прыме запыт…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Чакаем, калі партнёр прыме эмодзі…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Чакаем, калі партнёр зацвердзіць лічбы…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Шпалеры:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Увага!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Мы даслалі вам ліст на email", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Хто якія дзеянні можа выконваць", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Каму дазволена далучацца да гэтай группы", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Чаму вы хаціце паскардзіцца?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Ачысціць рэзервовую копію чата, каб стварыць новы ключ аднаўлення?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "З гэтымі адрасамі, вы сожаце аднавіць свой пароль.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Напісать паведамленне…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Так", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Вы", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Вы больш не ўдзельнічаеце ў гэтым чаце", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Вы былі заблакіраваны ў гэтым чаце", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Ваш публічны ключ", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Інфармацыя пра паведамленне", + "@messageInfo": {}, + "time": "Час", + "@time": {}, + "messageType": "Тып паведамлення", + "@messageType": {}, + "sender": "Адпраўшчык", + "@sender": {}, + "openGallery": "Адкрыць галерэю", + "@openGallery": {}, + "removeFromSpace": "Выдаліць з прасторы", + "@removeFromSpace": {}, + "addToSpaceDescription": "Выберыце прастору, да якой дадаць гэты чат.", + "@addToSpaceDescription": {}, + "start": "Пачаць", + "@start": {}, + "pleaseEnterRecoveryKeyDescription": "Каб разблакіраваць вашы мінулыя паведамленні, калі ласка, увядзіце ключ аднаўлення, што быў згенерыраваны ў мінулай сесіі. Ключ аднаўлення гэта НЕ ваш пароль.", + "@pleaseEnterRecoveryKeyDescription": {}, + "publish": "Апублікаваць", + "@publish": {}, + "videoWithSize": "Відэа ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "openChat": "Адкрыць чат", + "@openChat": {}, + "markAsRead": "Адзначыць як прачытанае", + "@markAsRead": {}, + "reportUser": "Паскардзіцца на карыстальніка", + "@reportUser": {}, + "dismiss": "Адхіліць", + "@dismiss": {}, + "reactedWith": "{sender} рэагуе з {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Прымацаваць да пакою", + "@pinMessage": {}, + "confirmEventUnpin": "Вы ўпэўнены ў тым, што хаціце назаўсёды адмацаваць гэту падзею?", + "@confirmEventUnpin": {}, + "emojis": "Эмодзі", + "@emojis": {}, + "placeCall": "Здзейсніць выклік", + "@placeCall": {}, + "voiceCall": "Галасавы выклік", + "@voiceCall": {}, + "unsupportedAndroidVersion": "Непадтрымліваемая версія Android", + "@unsupportedAndroidVersion": {}, + "unsupportedAndroidVersionLong": "Гэта функцыя патрабуе навейшай версіі Android. Калі ласка, праверце наяўнасць абнаўленняў ці падтрымку Linage OS.", + "@unsupportedAndroidVersionLong": {}, + "videoCallsBetaWarning": "Звярніце ўвагу, што відэа выклікі знаходзяцца ў бэце. Яны могуць працаваць некарэктна ці не на ўсіх платформах.", + "@videoCallsBetaWarning": {}, + "experimentalVideoCalls": "Эксперыментальныя відэа выклікі", + "@experimentalVideoCalls": {}, + "emailOrUsername": "Email ці імя карыстальніка", + "@emailOrUsername": {}, + "indexedDbErrorTitle": "Праблемы з прыватным рэжымам", + "@indexedDbErrorTitle": {}, + "indexedDbErrorLong": "Сховішча паведамленняў, на жаль, не ўключана ў прыватным рэжыме па змаўчанні.\nКалі ласка, наведайце\n - about:config\n - што dom.indexedDB.privateBrowsing.enabled уключаны\nІнакш, FluffyChat будзе немагчыма запусціць.", + "@indexedDbErrorLong": {}, + "switchToAccount": "Пераключыцца на ўліковы запіс {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Наступны ўліковы запіс", + "@nextAccount": {}, + "previousAccount": "Мінулы ўліковы запіс", + "@previousAccount": {}, + "addWidget": "Дадаць віджэт", + "@addWidget": {}, + "widgetVideo": "Відэа", + "@widgetVideo": {}, + "widgetEtherpad": "Тэкставая нататка", + "@widgetEtherpad": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "widgetCustom": "Карыстальніцкі", + "@widgetCustom": {}, + "widgetName": "Імя", + "@widgetName": {}, + "widgetUrlError": "Гэта хібны URL.", + "@widgetUrlError": {}, + "widgetNameError": "Калі ласка, укажыце адлюстроўваемаем імя.", + "@widgetNameError": {}, + "errorAddingWidget": "Памылка дадання віджэту.", + "@errorAddingWidget": {}, + "youRejectedTheInvitation": "Вы скасавалі запрашэнне", + "@youRejectedTheInvitation": {}, + "youJoinedTheChat": "Вы далучыліся да чату", + "@youJoinedTheChat": {}, + "youAcceptedTheInvitation": "👍 Вы прынялі запрашэнне", + "@youAcceptedTheInvitation": {}, + "youBannedUser": "Вы заблакіравалі {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Вы адазвалі запрашэнне для {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Вы былі запрошаны па спасылцы на:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Вы былі запрошаны карыстальнікам {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "invitedBy": "📩 Запрошаны(-а) {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Вы запрасілі {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Вы выгналі {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Вы выгналі і заблакіравалі {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Вы разблакіравалі {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hasKnocked": "🚪 {user} пагрукаўся", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Карыстальнікі абавязаны пагрукацца", + "@usersMustKnock": {}, + "noOneCanJoin": "Ніхто не можа далучыцца", + "@noOneCanJoin": {}, + "userWouldLikeToChangeTheChat": "{user} хоча далучыцца да чату.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Публічны ключ яшчэ не створаны", + "@noPublicLinkHasBeenCreatedYet": {}, + "knock": "Пагрукацца", + "@knock": {}, + "users": "Карыстальнікі", + "@users": {}, + "unlockOldMessages": "Адкрыць старыя паведамленні", + "@unlockOldMessages": {}, + "storeInSecureStorageDescription": "Захаваць код аднаўлення ў бяспечным месцы на прыладзе.", + "@storeInSecureStorageDescription": {}, + "saveKeyManuallyDescription": "Захаваць гэты ключ самастойна, выклікам сістэмнага акна Падзяліцца ці праз буфер.", + "@saveKeyManuallyDescription": {}, + "storeInAndroidKeystore": "Захаваць у Android KeyStore", + "@storeInAndroidKeystore": {}, + "storeInAppleKeyChain": "Захаваць у Apple KeyChain", + "@storeInAppleKeyChain": {}, + "storeSecurlyOnThisDevice": "Захаваць на гэтай прыладзе", + "@storeSecurlyOnThisDevice": {}, + "countFiles": "{count} файлаў", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "user": "Карыстальнік", + "@user": {}, + "custom": "Карыстальніцкае", + "@custom": {}, + "foregroundServiceRunning": "Гэта паведамленне з'явіцца, калі асноўныя службы запрацуюць.", + "@foregroundServiceRunning": {}, + "screenSharingTitle": "падзяліцца экранам", + "@screenSharingTitle": {}, + "screenSharingDetail": "Вы дзеліцеся экранам у FluffyChat", + "@screenSharingDetail": {}, + "callingPermissions": "Дазволы на выклікі", + "@callingPermissions": {}, + "callingAccount": "Уліковы запіс для выклікаў", + "@callingAccount": {}, + "callingAccountDetails": "Дазваляе FluffyChat выкарыстоўваць сістэмную праграму для выклікаў.", + "@callingAccountDetails": {}, + "appearOnTop": "З'яўляцца зверху", + "@appearOnTop": {}, + "appearOnTopDetails": "Дазваляе праграму з'яўляцца наверсе (не патрэбна, калі FluffyChat наладжаны як уліковы запіс для выклікаў)", + "@appearOnTopDetails": {}, + "otherCallingPermissions": "Мікрафон, камера і іншыя дазволы FluffyChat", + "@otherCallingPermissions": {}, + "whyIsThisMessageEncrypted": "Чаму гэта паведамленне нельга прачытаць?", + "@whyIsThisMessageEncrypted": {}, + "noKeyForThisMessage": "Гэта можа здарыцца з-за таго, што паведамленне было даслана да таго, як вы увайшлі ў уліковы запіс на гэтай прыладзе.\n\nТаксама верагодна, што адпраўшчык заблакіраваў вашу прыладу ці ў вас хібы з інтэрнэтам.\n\nВы можаце чытаць гэта паведамленне з іншага сеансу? Тад дашліце паведамленне адтуль! Перайдзіце ў Налады > Прылады і пераканайцеся ў тым, што вашы прылады верыфікавалі адна адну. Калі вы адкрыеце пакой наступны раз і абодве сэсіі будуць запушчаны, ключы павінны сінхранізавацца аўтаматычна.\n\nВы не хаціце згубіць клбчы, калі будзеце выходзіць ці змяняць прылады? Пераканайцеся ў тым, што вы уключылі рэзервовае капіраванне чатаў у наладах.", + "@noKeyForThisMessage": {}, + "newGroup": "Новая група", + "@newGroup": {}, + "newSpace": "Новая прастора", + "@newSpace": {}, + "enterSpace": "Увайсці ў прастору", + "@enterSpace": {}, + "enterRoom": "Увайсці ў пакой", + "@enterRoom": {}, + "allSpaces": "Усе прасторы", + "@allSpaces": {}, + "numChats": "{number} чатаў", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Хаваць неабавязковыя падзеі статусу", + "@hideUnimportantStateEvents": {}, + "hidePresences": "Хаваць спіс статусаў?", + "@hidePresences": {}, + "doNotShowAgain": "Не паказваць зноў", + "@doNotShowAgain": {}, + "wasDirectChatDisplayName": "Пусты чат (быў {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "newSpaceDescription": "Прасторы дазваляюць аб'ядноўваць вашы чаты і ствараць агульныя ці асобныя супольнасці.", + "@newSpaceDescription": {}, + "encryptThisChat": "Шыфраваць гэты чат", + "@encryptThisChat": {}, + "disableEncryptionWarning": "У мэтах бяспекі, вы не можаце адклбчауь шыфраванне ў гэтым чаце, дзе яно было ўключана.", + "@disableEncryptionWarning": {}, + "sorryThatsNotPossible": "Прабачце... Гэта немагчыма", + "@sorryThatsNotPossible": {}, + "deviceKeys": "Ключы прылад:", + "@deviceKeys": {}, + "reopenChat": "Адкрыць чат зноў", + "@reopenChat": {}, + "noBackupWarning": "Увага! Без уключэння рэзервовага капіравання чатаў, вы страціце доступ да вашых зашыфраваных паведамленняў. Настойліва рэкамендуецца уключыць фукнцыю да таго, як выйсці.", + "@noBackupWarning": {}, + "noOtherDevicesFound": "Іншыя прылады не знойдзены", + "@noOtherDevicesFound": {}, + "fileIsTooBigForServer": "Немагчыма даслаць! Сервер падтрымлівае файлы да {max}.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "Файл быў захаваны ў {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Перайсці да апошняга паведамлення", + "@jumpToLastReadMessage": {}, + "readUpToHere": "Чытаць тут", + "@readUpToHere": {}, + "jump": "Перайсці", + "@jump": {}, + "openLinkInBrowser": "Адкрыць спасылку ў браўзеры", + "@openLinkInBrowser": {}, + "reportErrorDescription": "😭 О не, штосьці пайшло не так. Калі жадаеце, можаце падаць справаздачу аб памылке распрауоўшчыкам.", + "@reportErrorDescription": {}, + "report": "паскардзіцца", + "@report": {}, + "signInWithPassword": "Увайсці з паролем", + "@signInWithPassword": {}, + "manageAccount": "Кіраванне ўліковым запісам", + "@manageAccount": {}, + "noContactInformationProvided": "Сервер не мае ніякай вернай кантактнай інфармацыі", + "@noContactInformationProvided": {}, + "contactServerAdmin": "Звязацца з адміністратарам сервера", + "@contactServerAdmin": {}, + "contactServerSecurity": "Звязацца з сервернай бяспекай", + "@contactServerSecurity": {}, + "supportPage": "Падтрымка", + "@supportPage": {}, + "serverInformation": "Серверная інфармацыя:", + "@serverInformation": {}, + "name": "Імя", + "@name": {}, + "version": "Версія", + "@version": {}, + "website": "Сайт", + "@website": {}, + "compress": "Сцісканне", + "@compress": {}, + "boldText": "Цёмны", + "@boldText": {}, + "italicText": "Курсіў", + "@italicText": {}, + "strikeThrough": "Перакрэслены", + "@strikeThrough": {}, + "pleaseFillOut": "Калі ласка, запоўніце", + "@pleaseFillOut": {}, + "invalidUrl": "Няслушны url", + "@invalidUrl": {}, + "addLink": "Дадаць спасылку", + "@addLink": {}, + "unableToJoinChat": "Немагчыма далучыцца да чату. Магчыма, іншы бок ужо скончыў размову.", + "@unableToJoinChat": {}, + "previous": "Мінулы", + "@previous": {}, + "otherPartyNotLoggedIn": "Іншы бок зараз не увайшоў, таму не можа атрымліваць паведамленні!", + "@otherPartyNotLoggedIn": {}, + "appWantsToUseForLogin": "Выкарыстоўваць '{server}' для ўвахода", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Тым самым, вы дазваляеце праграме і сайту дзяліцца інфармацыяй пра вас.", + "@appWantsToUseForLoginDescription": {}, + "open": "Адкрыць", + "@open": {}, + "waitingForServer": "Чаканне сервера...", + "@waitingForServer": {}, + "appIntroduction": "FluffyChat дазваляе вам і вашым сябрам размаўляць скрозь розныя мэсэнджары. Даведайцеся болей на https://matrix.org ці націсніце *Працягнуць*.", + "@appIntroduction": {}, + "newChatRequest": "📩 Запыт новага чату", + "@newChatRequest": {}, + "contentNotificationSettings": "Налады паведамленняў кантэнту", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "Агульныя налады паведамленняў", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "Налады паведамленняў пакою", + "@roomNotificationSettings": {}, + "userSpecificNotificationSettings": "Налады паведамленняў карыстальніка", + "@userSpecificNotificationSettings": {}, + "otherNotificationSettings": "Іншыя налады паведамленняў", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "Змяшчае імя карыстальніка", + "@notificationRuleContainsUserName": {}, + "notificationRuleContainsUserNameDescription": "Паведамляе пра тое, што паведамленне мае імя карыстальніка.", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleMaster": "Заглушыць усе паведамленні", + "@notificationRuleMaster": {}, + "notificationRuleMasterDescription": "Перазапісвае ўсе іншыя правілы і адключае паведамленні.", + "@notificationRuleMasterDescription": {}, + "notificationRuleSuppressNotices": "Адключыць аўтаматычныя паведамленні", + "@notificationRuleSuppressNotices": {}, + "notificationRuleSuppressNoticesDescription": "Адключыць паведамленні ад аўтаматызаваных кліентаў, накшталт ботаў.", + "@notificationRuleSuppressNoticesDescription": {}, + "notificationRuleInviteForMe": "Запрашэнне мяне", + "@notificationRuleInviteForMe": {}, + "notificationRuleInviteForMeDescription": "Паведамляе карыстальніка, калі яго запрашаюць у пакой.", + "@notificationRuleInviteForMeDescription": {}, + "allDevices": "Усе прылады", + "@allDevices": {}, + "crossVerifiedDevicesIfEnabled": "З перакрыжаваным спраўджваннем прылад, калі ўключана", + "@crossVerifiedDevicesIfEnabled": {}, + "crossVerifiedDevices": "Перакрыжавана спраўджаныя прылады", + "@crossVerifiedDevices": {}, + "verifiedDevicesOnly": "Толькі спраўджаныя прылады", + "@verifiedDevicesOnly": {}, + "takeAPhoto": "Зрабіць здымак", + "@takeAPhoto": {}, + "recordAVideo": "Запісаць відэа", + "@recordAVideo": {}, + "optionalMessage": "(Апцыянальна) паведамленне...", + "@optionalMessage": {}, + "notSupportedOnThisDevice": "Не падтрымліваецца на гэтай прыладзе", + "@notSupportedOnThisDevice": {}, + "enterNewChat": "Увядзіце новы чат", + "@enterNewChat": {}, + "approve": "Пацвердзіць", + "@approve": {}, + "youHaveKnocked": "Вы былі выгнаны", + "@youHaveKnocked": {}, + "pleaseWaitUntilInvited": "Калі ласка, пачакайце, пакуль хтосьці з пакою вас не запрасіць.", + "@pleaseWaitUntilInvited": {}, + "commandHint_logout": "Выйсці з бягуяай прылады", + "@commandHint_logout": {}, + "commandHint_logoutall": "Выйсці на ўсіх актыўных прыладах", + "@commandHint_logoutall": {}, + "displayNavigationRail": "Паказваць навігацыйны след на тэлефоне", + "@displayNavigationRail": {}, + "customReaction": "Карыстальніцкая рэакцыя", + "@customReaction": {}, + "moreEvents": "Больш падзей", + "@moreEvents": {}, + "declineInvitation": "Скасаваць запрашэнне", + "@declineInvitation": {}, + "notificationsEnabledForThisAccount": "Паведамленні ўклбчаны для гжтага ўліковага запісу", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} карыстальнікаў пішуць…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Атрыманне месцазнаходжання…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Абражальна", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Не ў сетцы", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ок", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "У сетцы", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Рэзервовае капіраванне ключэй уключана", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Упс! На жаль, пры наладжванні пуш-паведамленняў, адбылася памылка.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Упс, штосьці пайшло не так…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Адкройце праграму, каб прачытаць паведамленні", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Адкрыць камеру", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Адкрыць камеру для відэа", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "Адзін з вашых кліентаў выйшаў", + "@oneClientLoggedOut": {}, + "addAccount": "Дадаць уліковы запіс", + "@addAccount": {}, + "editBundlesForAccount": "Змяніць пакеты для гэтага ўліковага запісу", + "@editBundlesForAccount": {}, + "addToBundle": "Дадаць у пакет", + "@addToBundle": {}, + "removeFromBundle": "Выдаліць з пакета", + "@removeFromBundle": {}, + "bundleName": "Назва пакета", + "@bundleName": {}, + "openInMaps": "Адкрыць на картах", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "link": "Спасылка", + "@link": {}, + "serverRequiresEmail": "Гэты сервер павінен спраўдзіць ваш email для рэгістрацыі.", + "@serverRequiresEmail": {}, + "or": "Ці", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Удзельнік", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "фраза-пароль ці ключ аднаўлення", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Пароль", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Не памятаю пароль", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Пароль быў зменены", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "hideMemberChangesInPublicChats": "Хаваць змяненні ўдзельнікаў у публічных чатах", + "@hideMemberChangesInPublicChats": {}, + "hideMemberChangesInPublicChatsBody": "Не паказваць далучэнні і выхады з чату ў шкале часу для лепшай чытальнасці.", + "@hideMemberChangesInPublicChatsBody": {}, + "overview": "Агляд", + "@overview": {}, + "notifyMeFor": "Паведамляць мяне пра", + "@notifyMeFor": {}, + "passwordRecoverySettings": "Налады скіду пароля", + "@passwordRecoverySettings": {}, + "passwordRecovery": "Аднаўленне пароля", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Людзі", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Абраць выяву", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Замацаваць", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Прайграць {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Калі ласка, выберыце", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Калі ласка, выберыце код доступу", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Калі ласка, націсніце на спасылку ў лісце на email, каб працягнуць.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Калі ласка, увядзіце 4 лічбы ці пакіньце пустым, каб адключыць код-пароль.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKey": "Увядзіце ключ аднаўлення:", + "@pleaseEnterRecoveryKey": {}, + "pleaseEnterYourPassword": "Калі ласка, увядзіце ваш пароль", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Калі ласка, увядзіце пін-код", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Калі ласка, увядзіце імя карыстальніка", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Калі ласка, сачыце за інстуркцыямі ў браўзеры і націсніце \"Далей\".", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Прыватнасць", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Публічныя пакоі", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Правілы пушэй", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Прычына", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Запіс", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedBy": "Адрэдагавана {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Асобны чат", + "@directChat": {}, + "redactedByBecause": "Адрэдагавана {username}, прычына: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactedAnEvent": "{username} адрэдагаваў(-ла) падзею", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Адрэдагаваць паведамленне", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Зарэгістравацца", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Адмовіць", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} адмовіў запрашэнне", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Далучыцца зноў", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Выдаліць усе іншыя прылады", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Выдалена {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Выдаліць прыладу", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Разблакіраваць у чаце", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Выдаліць выяву ўліковага запісу", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Замяніць пакой навейшай версіяй", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Адказаць", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Паведаміць пра паведамленне", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Запрасіць дазвол", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Пакой быў абноўлены", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Версія пакою", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Захаваць файл", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Пошук", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Бяспека", + "@security": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "Ключ аднаўлення", + "@recoveryKey": {}, + "recoveryKeyLost": "Ключ абнаўлення страчаны?", + "@recoveryKeyLost": {}, + "seenByUser": "Прагледжана {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Даслаць", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Даслаць паведамленне", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Даслаць як тэкст", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Даслаць аўдыё", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Даслаць файл", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Даслаць выяву", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendImages": "Даслаць {count} выяў(-вы)", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendMessages": "Даслаць паведамленні", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Даслаць арыгінал", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Даслаць стыкер", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Даслаць відэа", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} даслаў файл", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} даслаў аўдыё", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} даслаў выяву", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} даслаў стыкер", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} даслаў відэа", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} даслаў інфрамацыю пра выклік", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "separateChatTypes": "Падзяляць асобныя чаты і групы", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Задаць як асноўны псеўданім", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Задаць карыстальніцкі эмодзі", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Пазначыць прачытаным/непрачытаным", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Занадта шмат запытаў. Паспрабуйце пазней!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Перанесці з іншай прылады", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Паспрабуйце даслаць зноў", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Недаступна", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} разблакіраваў {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Разблакіраваць прыладу", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Невядомая прылада", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Невядомы алгарытм шыфравання", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Невядомая падзея '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Уключыць павдеамленні чата", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Адмацаваць", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 непрачытаны чат} other{{unreadCount} непрачытаных чатаў}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} і {count} іншых удзельнікаў пішуць…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} і {username2} пішуць…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} піша…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} пакінуў(-ла) чат", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Імя карыстальніка", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} даслаў падзею {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "unverified": "Не спраўджана", + "@unverified": {}, + "verified": "Спраўджана", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Спраўдзіць", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Пачаць спраўджванне", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Вы паспяхова спраўджаны!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Спраўдзіць іншы ўліковы запіс", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Відэа выклік", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "verifyOtherUserDescription": "Калі вы спраўдзілі іншага карыстальніка, вы можаце быць упэўненым з кім вы сапраўды перапісваецеся.💪\n\nКалі вы пачнеце спраўджванне, вы і іншы карыстальнік, убачыце ўсплывальнае акно ў праграме. У ім вы ўбачыце некалькі эмодзі ці лічб, якія вы павінны параўнаць адзін з адным.\n\nЛепшы метад зрабіць гэта - пачаць відэа выклік. 👭", + "@verifyOtherUserDescription": {}, + "pleaseEnterANumber": "Калі ласка, увядзіце лічбу большую за 0", + "@pleaseEnterANumber": {}, + "verifyOtherDeviceDescription": "Калі вы спраўдзіце другую прыладу, яны абмяняюцца ключамі, якія ўзмоцняць вашу бяспеку. 💪 Калі вы пачнеце спраўджванне, у праграмах прылад з'явіцца ўсплывальнае паведамленне. Потым, вы ўбачыце некалькі эмодзі ці лічбаў, якія вы павінны параўнаць паміж сабой. Прасцей за ўсё гэта зрабіць, маючы дзве прылады побач. 🤳", + "@verifyOtherDeviceDescription": {}, + "verifyOtherUser": "🔐 Спраўдзіць іншага карыстальніка", + "@verifyOtherUser": {}, + "verifyOtherDevice": "🔐 Спраўдзіць іншую прыладу", + "@verifyOtherDevice": {}, + "changeTheCanonicalRoomAlias": "Змяніць публічны адрас чату", + "@changeTheCanonicalRoomAlias": {}, + "wrongRecoveryKey": "Прабачце... гэта не выглядае як ключ аднаўлення.", + "@wrongRecoveryKey": {}, + "restoreSessionBody": "Праграма спрабуе аднавіць вашу сесію з рэзервовай копіі. Калі ласка, паведаміце пра памылку распрацоўшчыкам па спасылцы {url}. Паведамленне памылкі: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "homeserverDescription": "Вашыя даныя захоўваюцца на дамашнім серверы, як у правайдара электронай пошты. Вы можаце самастойна абраць дамашні сервер, захоўвая пры тым магчымасць размаўляць. Даведайцеся болей на https://matrix.org.", + "@homeserverDescription": {}, + "longPressToRecordVoiceMessage": "Доўга цісніце, каб запісаць галасавое паведамленне.", + "@longPressToRecordVoiceMessage": {}, + "visibilityOfTheChatHistory": "Бачнасць гісторыі чату", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Бачна для ўсіх удзельнікаў", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "pleaseTryAgainLaterOrChooseDifferentServer": "Калі ласка, паспрабуйце пазней ці абярыце іншы сервер.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "signInWith": "Увайсці з {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "profileNotFound": "Карыстальнік не знойдзены на гэтым серверы. Гэта можа быць памылка сеткі ці карыстальніка не існуе.", + "@profileNotFound": {}, + "setTheme": "Тэма:", + "@setTheme": {}, + "setColorTheme": "Каляровая схема:", + "@setColorTheme": {}, + "invite": "Запрасіць", + "@invite": {}, + "inviteGroupChat": "📨 Запрашэнне ў групавы чат", + "@inviteGroupChat": {}, + "invitePrivateChat": "📨 Запрашэнне ў асобны чат", + "@invitePrivateChat": {}, + "invalidInput": "Недапушчальны ўвод!", + "@invalidInput": {}, + "wrongPinEntered": "Няверны пін-код! Паспрабуйце праз {seconds} секунд...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "archiveRoomDescription": "Чат перамясціцца ў архіў. Іншыя карыстальнікі будуць бачыць гэта так, быццам вы выйшлі з чату.", + "@archiveRoomDescription": {}, + "roomUpgradeDescription": "Чат будзе пераствораны з новай версіяй пакою. Усе ўдзельнікі будуць паведамлены пра неабходнасць перайсці ў новы чат. Вы можаце даведацца пра версіі пакояў тут: https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "removeDevicesDescription": "Вы выйдзеце з гэтай прылады і больш не будзеце атрымліваць паведамленні.", + "@removeDevicesDescription": {}, + "sendTypingNotificationsDescription": "Іншыя ўдзельнікі чату могуць бачыць, калі вы пішаце новае паведамленне.", + "@sendTypingNotificationsDescription": {}, + "continueText": "Працягнуць", + "@continueText": {}, + "banUserDescription": "Карыстальнік будзе заблакіраваны з чату і больш не зможа ўвайсці, пакуль вы яго не разблакіруеце.", + "@banUserDescription": {}, + "unbanUserDescription": "Карыстальнік зможа зноў далучыцца да чату.", + "@unbanUserDescription": {}, + "kickUserDescription": "Карыстальнік будзе выгнаны, але не заблакіраваны. У публічных чатах, ён зможа далучыцца зноў у любы час.", + "@kickUserDescription": {}, + "makeAdminDescription": "Калі вы зробіце карыстальніка адміністратарам, вы не зможаце адмяніць гэта дзеянне, бо ён будзе мець такія ж правы, як і вы.", + "@makeAdminDescription": {}, + "pushNotificationsNotAvailable": "Пуш-паведамленні недаступны", + "@pushNotificationsNotAvailable": {}, + "learnMore": "Даведацца больш", + "@learnMore": {}, + "yourGlobalUserIdIs": "Ваш глабальны ID-карыстальніка: ", + "@yourGlobalUserIdIs": {}, + "noUsersFoundWithQuery": "На жаль, мы не змаглі знайсці карыстальніка з імём \"{query}\". Калі ласка, праверце наяўнасць памылак.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "knocking": "Грукацца", + "@knocking": {}, + "knockRestricted": "Грук абмежаваны", + "@knockRestricted": {}, + "spaceMemberOfCanKnock": "Удзельнікі прасторы з {spaces} могуць грукацца", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "chatCanBeDiscoveredViaSearchOnServer": "Чат можа быць знойдзены праз пошук у {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchChatsRooms": "Пошук #чатаў, @карыстальнікаў...", + "@searchChatsRooms": {}, + "nothingFound": "Нічога не знойдзена...", + "@nothingFound": {}, + "groupName": "Назва групы", + "@groupName": {}, + "createGroupAndInviteUsers": "Стварыць групу і запрасіць карыстальнікаў", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "Група можа быць знойдзена праз пошук", + "@groupCanBeFoundViaSearch": {}, + "startConversation": "Пачаць размову", + "@startConversation": {}, + "commandHint_sendraw": "Даслаць толькі json", + "@commandHint_sendraw": {}, + "databaseMigrationTitle": "База даных аптымізавана", + "@databaseMigrationTitle": {}, + "databaseMigrationBody": "Калі ласка, пачакайце. Гэта можа заняць некаторы час.", + "@databaseMigrationBody": {}, + "leaveEmptyToClearStatus": "Пакіньце пустым, каб ачысціць свой статус.", + "@leaveEmptyToClearStatus": {}, + "select": "Выбраць", + "@select": {}, + "searchForUsers": "Пошук @карыстальнікаў...", + "@searchForUsers": {}, + "pleaseEnterYourCurrentPassword": "Калі ласка, увядзіце свой бягучы пароль", + "@pleaseEnterYourCurrentPassword": {}, + "newPassword": "Новы пароль", + "@newPassword": {}, + "pleaseChooseAStrongPassword": "Калі ласка, падбярыце больш надзейны пароль", + "@pleaseChooseAStrongPassword": {}, + "passwordsDoNotMatch": "Паролі не супадаюць", + "@passwordsDoNotMatch": {}, + "passwordIsWrong": "Вы ўвялі няверны пароль", + "@passwordIsWrong": {}, + "publicLink": "Публічная спасылка", + "@publicLink": {}, + "publicChatAddresses": "Публічныя адрасы чату", + "@publicChatAddresses": {}, + "createNewAddress": "Стварыць новы адрас", + "@createNewAddress": {}, + "joinSpace": "Далучыцца да прасторы", + "@joinSpace": {}, + "publicSpaces": "Публічныя прасторы", + "@publicSpaces": {}, + "addChatOrSubSpace": "Дадаць чат ці пад-прастору", + "@addChatOrSubSpace": {}, + "subspace": "Пад-прастора", + "@subspace": {}, + "decline": "Адхіліць", + "@decline": {}, + "thisDevice": "Гэта прылада:", + "@thisDevice": {}, + "initAppError": "Адбылася памылка пры ініцыялізацыі праграмы", + "@initAppError": {}, + "userRole": "Роль карыстальніка", + "@userRole": {}, + "minimumPowerLevel": "{level} - мінімальны ўзровень дазволаў.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "Пошук у чаце \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Шукаць яшчэ...", + "@searchMore": {}, + "gallery": "Галерэя", + "@gallery": {}, + "files": "Файлы", + "@files": {}, + "databaseBuildErrorBody": "Немагчыма стварыць базу даных SQlite. Праграма спрабуе выкарыстоўваць састарэлую базу. Калі ласка, паведаміце распрацоўшчыкам пра гэта: {url}. Паведамленне памылкі: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Ваш сеанс страчаны. Калі ласка, паведаміце пра гэта распрацоўшчыкам: {url}. Паведамленне памылкі: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Пераслаць паведамленне ў {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Дасылаць адзнаку аб чытанні", + "@sendReadReceipts": {}, + "sendReadReceiptsDescription": "Іншыя карыстальнікі чатаў будуць бачыць, калі вы прачыталі паведамленні.", + "@sendReadReceiptsDescription": {}, + "formattedMessages": "Фармаціраваныя паведамленні", + "@formattedMessages": {}, + "formattedMessagesDescription": "Адлюстроўваць пашыраныя паведамленні разметкай markdown.", + "@formattedMessagesDescription": {}, + "acceptedKeyVerification": "{sender} прыняў(-ла) спраўджванне ключэй", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} адхіліў(-ла) спраўджванне ключэй", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} скочныў(-ла) спраўджванне ключэй", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} гатовы(-а) да спраўджвання ключэй", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} запрасіў(-ла) спраўджванне ключэй", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} пачаў(-ла) спраўджванне ключэй", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Празрысты", + "@transparent": {}, + "incomingMessages": "Уваходныя паведамленні", + "@incomingMessages": {}, + "stickers": "Стыкеры", + "@stickers": {}, + "discover": "Даследаваць", + "@discover": {}, + "commandHint_ignore": "Ігнараваць дадзены matrix ID", + "@commandHint_ignore": {}, + "commandHint_unignore": "Перастаць ігнараваць дадзены matrix ID", + "@commandHint_unignore": {}, + "unreadChatsInApp": "{appname}: {unread} непрачытаных чатаў", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Шыфраванне базы даных не падтрымліваецца гэтай платформай", + "@noDatabaseEncryption": {}, + "thereAreCountUsersBlocked": "На гэты момант, {count} карыстальнікаў заблакіравана.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "Абмежавана", + "@restricted": {}, + "goToSpace": "Перайсці да прасторы: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Адзначыць як непрачытанае", + "@markAsUnread": {}, + "userLevel": "{level} - Карыстальнік", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Мадэратар", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Адміністратар", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Змяніць агульныя налады чату", + "@changeGeneralChatSettings": {}, + "inviteOtherUsers": "Запрасіць іншых карыстальнікаў у гэты чат", + "@inviteOtherUsers": {}, + "changeTheChatPermissions": "Змяніць дазволы чату", + "@changeTheChatPermissions": {}, + "changeTheVisibilityOfChatHistory": "Змяніць бачнасць гісторыі чату", + "@changeTheVisibilityOfChatHistory": {}, + "sendRoomNotifications": "Дасылаць паведамленні @room", + "@sendRoomNotifications": {}, + "changeTheDescriptionOfTheGroup": "Змяніць апісанне чату", + "@changeTheDescriptionOfTheGroup": {}, + "chatPermissionsDescription": "Задаць узровень дазволаў, які неабходны для некаторых дзеянняў у чаце. Узроўні 0, 50 і 100 звычайна адлюстроўваюць карыстальнікаў, мадэратараў і адміністратараў, але любая градацыя магчыма.", + "@chatPermissionsDescription": {}, + "updateInstalled": "🎉 Абнаўленне {version} усталявана!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Спіс змен", + "@changelog": {}, + "sendCanceled": "Адпраўка скасавана", + "@sendCanceled": {}, + "loginWithMatrixId": "Увайсці з Matrix-ID", + "@loginWithMatrixId": {}, + "discoverHomeservers": "Даследаваць дамашнія сервера", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "Што такое дамашні сервер?", + "@whatIsAHomeserver": {}, + "doesNotSeemToBeAValidHomeserver": "Гэта не выглядае як дамашні сервер. Няслушны URL?", + "@doesNotSeemToBeAValidHomeserver": {}, + "calculatingFileSize": "Вылічэнне памеру файла...", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "Падрыхтоўка адпраўкі прыкладання...", + "@prepareSendingAttachment": {}, + "sendingAttachment": "Адпраўка прыкладання...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "Стварэнне вокладкі відэа...", + "@generatingVideoThumbnail": {}, + "compressVideo": "Сцісканне відэа...", + "@compressVideo": {}, + "sendingAttachmentCountOfCount": "Адпраўляецца прыкладанне {index} з {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Дасягнуты серверны ліміт! Пачакайце {seconds} секунд...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Адна з вашых прылад не спраўджана", + "@oneOfYourDevicesIsNotVerified": {}, + "noticeChatBackupDeviceVerification": "Заўвага: Калі вы падключыце ўсе свае прылады да рэзервовага капіравання, яны аўтаматычна спраўдзяцца.", + "@noticeChatBackupDeviceVerification": {}, + "welcomeText": "Вітаначкі 👋 Гэта FluffyChat. Вы можаце ўвайсці на любы дамашні сервер, што сумяшчальны з https://matrix.org, а потым паразмаўляць з кім-небудзь. Гэта вялізная дэцэнтралізаваная сетка абмену паведамленнямі!", + "@welcomeText": {}, + "blur": "Размыццё:", + "@blur": {}, + "opacity": "Празрыстасць:", + "@opacity": {}, + "setWallpaper": "Задаць шпалеры", + "@setWallpaper": {}, + "notificationRuleMemberEvent": "Падзеі ўдзельніцтва", + "@notificationRuleMemberEvent": {}, + "notificationRuleMemberEventDescription": "Спыніць усе паведамленні пра ўдзельніцтва.", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleIsUserMention": "Згадванні карыстальніка", + "@notificationRuleIsUserMention": {}, + "notificationRuleIsUserMentionDescription": "Паведамляе, калі карыстальніка згадалі ў паведамленні.", + "@notificationRuleIsUserMentionDescription": {}, + "notificationRuleContainsDisplayName": "Мае адлюстроўваемае імя", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleContainsDisplayNameDescription": "Паведамляе, калі паведамленне мае іх адлюстроўваемае імя.", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleIsRoomMention": "Згадванні пакою", + "@notificationRuleIsRoomMention": {}, + "notificationRuleIsRoomMentionDescription": "Паведамляе карыстальніка, калі згадваюць пакой.", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleRoomnotif": "Паведамленні пакою", + "@notificationRuleRoomnotif": {}, + "notificationRuleRoomnotifDescription": "Паведамляе пра згадванні '@room'.", + "@notificationRuleRoomnotifDescription": {}, + "notificationRuleTombstone": "Помнік", + "@notificationRuleTombstone": {}, + "notificationRuleTombstoneDescription": "Паведамляе пра дэактывацыю пакою.", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleReaction": "Рэакцыя", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "Адключыць усе паведамленні пра рэакцыі.", + "@notificationRuleReactionDescription": {}, + "notificationRuleRoomServerAcl": "ACL сервера пакою", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleRoomServerAclDescription": "Адключыць паведамленні пра серверныя спісы кантролю пакою (ACL).", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleSuppressEdits": "Заглушыць змены", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "Заглушыць паведамленні пра адрэдагаваныя паведамленні.", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleCall": "Выклік", + "@notificationRuleCall": {}, + "notificationRuleCallDescription": "Паведамляе пра выклікі.", + "@notificationRuleCallDescription": {}, + "notificationRuleEncryptedRoomOneToOne": "Шыфраваны пакой One-to-One", + "@notificationRuleEncryptedRoomOneToOne": {}, + "notificationRuleEncryptedRoomOneToOneDescription": "Паведамляе пра паведамленні ў шыфраваных one-to-one пакоях.", + "@notificationRuleEncryptedRoomOneToOneDescription": {}, + "notificationRuleRoomOneToOne": "Пакой One-to-One", + "@notificationRuleRoomOneToOne": {}, + "notificationRuleRoomOneToOneDescription": "Паведамляе пра паведамленні ў пакоях one-to-one.", + "@notificationRuleRoomOneToOneDescription": {}, + "notificationRuleMessage": "Паведамленне", + "@notificationRuleMessage": {}, + "notificationRuleMessageDescription": "Паведамляе пра звычайныя паведамленні.", + "@notificationRuleMessageDescription": {}, + "notificationRuleEncrypted": "Зашыфравана", + "@notificationRuleEncrypted": {}, + "notificationRuleEncryptedDescription": "Паведамляе пра паведамленні ў зашыфраваных пакоях.", + "@notificationRuleEncryptedDescription": {}, + "notificationRuleJitsi": "Jitsi", + "@notificationRuleJitsi": {}, + "notificationRuleJitsiDescription": "Паведамляе пра падзеі віджэту Jitsi.", + "@notificationRuleJitsiDescription": {}, + "notificationRuleServerAcl": "Заглушыць серверныя падзеі ACL", + "@notificationRuleServerAcl": {}, + "notificationRuleServerAclDescription": "Заглушыць паведамленні пра серверныя падзеі ACL.", + "@notificationRuleServerAclDescription": {}, + "unknownPushRule": "Невядомае правіла пуша '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "🎙️{duration} - Галасавое паведамленне ад {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Калі вы выдаліце гэтыя налады паведамленняў, гэта не можа быць адменена.", + "@deletePushRuleCanNotBeUndone": {}, + "more": "Больш", + "@more": {}, + "shareKeysWith": "Падзяліцца ключамі з...", + "@shareKeysWith": {}, + "shareKeysWithDescription": "Якім прыладам вы давяраеце настолькі, каб яны маглі чытаць вашыя зашыфраваныя паведамленні?", + "@shareKeysWithDescription": {}, + "pause": "Паўза", + "@pause": {}, + "resume": "Працягнуць", + "@resume": {}, + "newSubSpace": "Новая пад-прастора", + "@newSubSpace": {}, + "moveToDifferentSpace": "Перамясціцца ў іншую прастору", + "@moveToDifferentSpace": {}, + "moveUp": "Перамясціць вышэй", + "@moveUp": {}, + "moveDown": "Перамясціць ніжэй", + "@moveDown": {}, + "removeFromSpaceDescription": "Гэты чат будзе выдалены з прасторы, але з'явіцца ў вашым спісе чатаў.", + "@removeFromSpaceDescription": {}, + "countChats": "{chats} чатаў", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Удзельнік прасторы {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Даць грошы", + "@donate": {}, + "startedAPoll": "{username} пачаў апытанне.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Апытанне", + "@poll": {}, + "startPoll": "Пачаць апытанне", + "@startPoll": {}, + "endPoll": "Скончыць апытанне", + "@endPoll": {}, + "answersVisible": "Адказы бачны", + "@answersVisible": {}, + "answersHidden": "Адказы схаваны", + "@answersHidden": {}, + "pollQuestion": "Пытанне апытання", + "@pollQuestion": {}, + "answerOption": "Варыянт адказу", + "@answerOption": {}, + "addAnswerOption": "Дадаць варыянт адказу", + "@addAnswerOption": {}, + "allowMultipleAnswers": "Дазволіць некалькі адказаў", + "@allowMultipleAnswers": {}, + "pollHasBeenEnded": "Апытанне было скончана", + "@pollHasBeenEnded": {}, + "countVotes": "{count, plural, =1{Адзін голас} other{{count} галасы(-оў)}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Вынікі будуць бачны, калі апытанне скончыцца", + "@answersWillBeVisibleWhenPollHasEnded": {}, + "replyInThread": "Адказаць у гутарку", + "@replyInThread": {}, + "countReplies": "{count, plural, =1{Адзін адказ} other{{count} адказа(-ў)}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Гутарка", + "@thread": {}, + "backToMainChat": "Вярнуцца ў галоўны чат", + "@backToMainChat": {}, + "saveChanges": "Захаваць змены", + "@saveChanges": {}, + "createSticker": "Стварыць стыкер ці эмадзі", + "@createSticker": {}, + "useAsSticker": "Ужыць як стыкер", + "@useAsSticker": {}, + "useAsEmoji": "Ужыць як эмадзі", + "@useAsEmoji": {}, + "stickerPackNameAlreadyExists": "Назва набору стыкераў ужо існуе", + "@stickerPackNameAlreadyExists": {}, + "newStickerPack": "Новы набор стыкераў", + "@newStickerPack": {}, + "stickerPackName": "Назва набору стыкераў", + "@stickerPackName": {}, + "attribution": "Атрыбуцыя", + "@attribution": {}, + "skipChatBackup": "Прапусціць рэзервовае капіраванне чатаў", + "@skipChatBackup": {}, + "skipChatBackupWarning": "Вы ўпэўнены? Без наладжвання рэзервовага капіравання чатаў, вы можаце згубіць доступ да ўсіх вашых чатаў, калі вы зменіце прыладу.", + "@skipChatBackupWarning": {}, + "loadingMessages": "Загрузка паведамленняў", + "@loadingMessages": {}, + "setupChatBackup": "Наладзіць рэзервовае капіраванне чатаў", + "@setupChatBackup": {} +} diff --git a/lib/l10n/intl_bn.arb b/lib/l10n/intl_bn.arb new file mode 100644 index 000000000..fa010fdf3 --- /dev/null +++ b/lib/l10n/intl_bn.arb @@ -0,0 +1,194 @@ +{ + "@@last_modified": "2021-08-14 12:41:10.154280", + "about": "সম্পর্কে", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "স্বীকার করি", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "{username} আমন্ত্রণ গ্রহণ করেছে", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "অ্যাকাউন্ট", + "@account": { + "type": "String", + "placeholders": {} + }, + "alwaysUse24HourFormat": "না", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "repeatPassword": "পাসওয়ার্ড আবার লিখো", + "@repeatPassword": {}, + "notAnImage": "ইমেজ ফাইল না।", + "@notAnImage": {}, + "setCustomPermissionLevel": "কাস্টম অনুমতি লেভেল ঠিক করো", + "@setCustomPermissionLevel": {}, + "admin": "অ্যাডমিস", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "অ্যালিয়াস", + "@alias": { + "type": "String", + "placeholders": {} + }, + "archive": "আর্কাইভ", + "@archive": { + "type": "String", + "placeholders": {} + }, + "banned": "ব্যানড", + "@banned": { + "type": "String", + "placeholders": {} + }, + "cancel": "বাতিল", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "chat": "চ্যাট", + "@chat": { + "type": "String", + "placeholders": {} + }, + "close": "বন্ধ", + "@close": { + "type": "String", + "placeholders": {} + }, + "confirm": "নিশ্চিত করো", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "কানেক্ট", + "@connect": { + "type": "String", + "placeholders": {} + }, + "copy": "অনুলিপি", + "@copy": { + "type": "String", + "placeholders": {} + }, + "create": "তৈরি", + "@create": { + "type": "String", + "placeholders": {} + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "delete": "অপসারণ", + "@delete": { + "type": "String", + "placeholders": {} + }, + "device": "ডিভাইস", + "@device": { + "type": "String", + "placeholders": {} + }, + "devices": "ডিভাইস", + "@devices": { + "type": "String", + "placeholders": {} + }, + "notifications": "বিজ্ঞপ্তি", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "edit": "সম্পাদন", + "@edit": { + "type": "String", + "placeholders": {} + }, + "encryption": "এনক্রিপশন", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encrypted": "এনক্রিপ্টকৃত", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "ফ্লাফিচ্যাট", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "ফরওয়ার্ড", + "@forward": { + "type": "String", + "placeholders": {} + }, + "group": "গ্রুপ", + "@group": { + "type": "String", + "placeholders": {} + }, + "help": "সাহায্য", + "@help": { + "type": "String", + "placeholders": {} + }, + "id": "আইডি", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "পরিচয়", + "@identity": { + "type": "String", + "placeholders": {} + }, + "invited": "আমন্ত্রিত", + "@invited": { + "type": "String", + "placeholders": {} + }, + "leave": "ছেড়ে যাও", + "@leave": { + "type": "String", + "placeholders": {} + }, + "logout": "প্রস্থান", + "@logout": { + "type": "String", + "placeholders": {} + }, + "license": "অনুমতিপত্র (লাইসেন্স)", + "@license": { + "type": "String", + "placeholders": {} + }, + "login": "প্রবেশ", + "@login": { + "type": "String", + "placeholders": {} + } +} diff --git a/assets/l10n/intl_el.arb b/lib/l10n/intl_bo.arb similarity index 63% rename from assets/l10n/intl_el.arb rename to lib/l10n/intl_bo.arb index 327d2bdc7..f6b086662 100644 --- a/assets/l10n/intl_el.arb +++ b/lib/l10n/intl_bo.arb @@ -1,397 +1,439 @@ { "@showPassword": { - "type": "text", + "type": "String", "placeholders": {} }, - "hugContent": "{senderName} σε αγκαλιάζει", "@hugContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "@theyMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "@jumpToLastReadMessage": {}, "@allRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, - "commandHint_cuddle": "Στείλτε μια αγκαλιά", "@commandHint_cuddle": {}, "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "@widgetVideo": {}, "@dismiss": {}, "@unknownDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, - "admin": "Διαχειριστής", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "@reportErrorDescription": {}, "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "@setPermissionsLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "@addAccount": {}, "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@chatHasBeenAddedToThisSpace": {}, "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "@removeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "@unsupportedAndroidVersion": {}, "@device": { - "type": "text", + "type": "String", "placeholders": {} }, - "blockDevice": "Συσκευή μπλοκ", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "@widgetJitsi": {}, "@youAreNoLongerParticipatingInThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "@messageType": {}, "@indexedDbErrorLong": {}, "@oneClientLoggedOut": {}, "@toggleMuted": { - "type": "text", + "type": "String", "placeholders": {} }, "@unsupportedAndroidVersionLong": {}, "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@verifySuccess": { - "type": "text", + "type": "String", "placeholders": {} }, "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "@startFirstChat": {}, "@callingAccount": {}, "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "@setColorTheme": {}, "@nextAccount": {}, "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, "@warning": { - "type": "text", + "type": "String", "placeholders": {} }, "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "@allSpaces": {}, - "supposedMxid": "Αυτό θα πρέπει να είναι {mxid}", "@supposedMxid": { - "type": "text", + "type": "String", "placeholders": { - "mxid": {} + "mxid": { + "type": "String" + } } }, "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "@user": {}, "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@videoCall": { - "type": "text", + "type": "String", "placeholders": {} }, "@youAcceptedTheInvitation": {}, - "banFromChat": "Απαγόρευση από τη συνομιλία", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "@userAndOthersAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "count": {} + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "@youInvitedBy": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@userIsTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@banUserDescription": {}, "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, - "askSSSSSign": "Για να μπορέσετε να υπογράψετε το άλλο άτομο, πληκτρολογήστε τη συνθηματική φράση ασφαλούς αποθήκευσης ή το κλειδί ανάκτησης.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "@widgetEtherpad": {}, "@waitingPartnerAcceptRequest": { - "type": "text", + "type": "String", "placeholders": {} }, - "remove": "Αφαιρέστε το", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "@writeAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "@removeDevicesDescription": {}, "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "@separateChatTypes": { - "type": "text", + "type": "String", "placeholders": {} }, "@tryAgain": {}, - "areGuestsAllowedToJoin": "Επιτρέπεται στους φιλοξενούμενους χρήστες να συμμετάσχουν", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, - "blocked": "Αποκλεισμένο", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "@youKickedAndBanned": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "@unbanUserDescription": {}, "@userAndUserAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "username2": {} + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } } }, "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "@saveFile": { - "type": "text", + "type": "String", "placeholders": {} }, - "sendOnEnter": "Αποστολή με enter", "@sendOnEnter": {}, "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, - "answeredTheCall": "{senderName} απάντησε στην κλήση", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "@youRejectedTheInvitation": {}, "@otherCallingPermissions": {}, "@messagesStyle": {}, "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "@link": {}, @@ -401,915 +443,1006 @@ "@chatDescription": {}, "@callingAccountDetails": {}, "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "@enterSpace": {}, "@encryptThisChat": {}, "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "@unavailable": { - "type": "text", + "type": "String", "placeholders": {} }, "@previousAccount": {}, "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "@reopenChat": {}, "@pleaseEnterRecoveryKey": {}, "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "@toggleFavorite": { - "type": "text", + "type": "String", "placeholders": {} }, "@no": { - "type": "text", + "type": "String", "placeholders": {} }, - "alias": "ψευδώνυμο", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "@widgetNameError": {}, "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "@unpin": { - "type": "text", + "type": "String", "placeholders": {} }, "@addToBundle": {}, "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "@spaceIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "@addWidget": {}, - "all": "Όλα", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "@unblockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "@countFiles": { "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "@noKeyForThisMessage": {}, "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "@shareLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_markasgroup": {}, "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "@hydrateTor": {}, "@pushNotificationsNotAvailable": {}, "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "@storeInAppleKeyChain": {}, "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "@hydrate": {}, "@invalidServerName": {}, "@chatPermissions": {}, "@voiceMessage": { - "type": "text", + "type": "String", "placeholders": {} }, - "badServerLoginTypesException": "Ο homeserver υποστηρίζει τους τύπους σύνδεσης:\n{serverVersions}\nΑλλά αυτή η εφαρμογή υποστηρίζει μόνο:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, - "cantOpenUri": "Δεν μπορεί να ανοίξει το URI {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "@sender": {}, "@storeInAndroidKeystore": {}, "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "@signInWithPassword": {}, "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "@weSentYouAnEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "@makeAdminDescription": {}, "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "@synchronizingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "@transferFromAnotherDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "@saveKeyManuallyDescription": {}, "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "@editBundlesForAccount": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "@whyIsThisMessageEncrypted": {}, "@unreadChats": { - "type": "text", + "type": "String", "placeholders": { - "unreadCount": {} + "unreadCount": { + "type": "int" + } } }, "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@setChatDescription": {}, "@userLeftTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@spaceName": { - "type": "text", + "type": "String", "placeholders": {} }, - "importFromZipFile": "Εισαγωγή από αρχείο .zip", "@importFromZipFile": {}, "@toggleUnread": { - "type": "text", + "type": "String", "placeholders": {} }, "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "@dehydrateWarning": {}, "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "@noOtherDevicesFound": {}, "@whoIsAllowedToJoinThisGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@storeSecurlyOnThisDevice": {}, "@yourChatBackupHasBeenSetUp": {}, "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "@redactedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@submit": { - "type": "text", + "type": "String", "placeholders": {} }, "@videoCallsBetaWarning": {}, "@unmuteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, - "autoplayImages": "Αυτόματη αναπαραγωγή κινούμενων αυτοκόλλητων και emotes", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "@yes": { - "type": "text", + "type": "String", "placeholders": {} }, "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "@signInWith": { - "type": "text", + "type": "String", "placeholders": { - "provider": {} + "provider": { + "type": "String" + } } }, "@username": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@fileIsTooBigForServer": {}, "@homeserver": {}, "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@verified": { - "type": "text", + "type": "String", "placeholders": {} }, - "repeatPassword": "Επανάληψη κωδικού πρόσβασης", "@repeatPassword": {}, "@setStatus": { - "type": "text", + "type": "String", "placeholders": {} }, "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "@callingPermissions": {}, "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@readUpToHere": {}, "@start": {}, "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "@unlockOldMessages": {}, "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "@numChats": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "@optionalRedactReason": {}, - "acceptedTheInvitation": "👍 {username} αποδέχτηκε την πρόσκληση", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@waitingPartnerEmoji": { - "type": "text", + "type": "String", "placeholders": {} }, "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "@tryToSendAgain": { - "type": "text", + "type": "String", "placeholders": {} }, "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "@dehydrate": {}, "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "@visibleForAllParticipants": { - "type": "text", + "type": "String", "placeholders": {} }, "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, - "banned": "Απαγορευμένο", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "@sendAsText": { - "type": "text" + "type": "String" }, "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, "@archiveRoomDescription": {}, - "exportEmotePack": "Εξαγωγή πακέτου Emote ως .zip", "@exportEmotePack": {}, "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "@sendSticker": { - "type": "text", + "type": "String", "placeholders": {} }, - "account": "Λογαριασμός", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "@switchToAccount": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "@commandInvalid": { - "type": "text" + "type": "String" }, "@setAsCanonicalAlias": { - "type": "text", + "type": "String", "placeholders": {} }, "@whyDoYouWantToReportThis": { - "type": "text", + "type": "String", "placeholders": {} }, "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "@placeCall": {}, "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "@experimentalVideoCalls": {}, "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "@pleaseEnterRecoveryKeyDescription": {}, "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "@openInMaps": { - "type": "text", + "type": "String", "placeholders": {} }, "@withTheseAddressesRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "@inviteContactToGroupQuestion": {}, "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "@redactedByBecause": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "reason": {} + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } } }, "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "@youHaveWithdrawnTheInvitationFor": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "@skip": { - "type": "text", + "type": "String", "placeholders": {} }, "@appearOnTopDetails": {}, "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "@enterRoom": {}, "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, - "areYouSure": "Είσαι σίγουρος;", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, - "allChats": "Όλες οι συνομιλίες", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "@reportUser": {}, "@sharedTheLocation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "@unbannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "@confirmEventUnpin": {}, - "badServerVersionsException": "Ο homeserver υποστηρίζει τις εκδόσεις Spec:\n{serverVersions}\nΑλλά αυτή η εφαρμογή υποστηρίζει μόνο τις {supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "@youInvitedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "@fileHasBeenSavedAt": { - "type": "text", + "type": "String", "placeholders": { - "path": {} + "path": { + "type": "String" + } } }, "@license": { - "type": "text", + "type": "String", "placeholders": {} }, - "addToSpace": "Προσθήκη στο χώρο", "@addToSpace": {}, "@unbanFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "@redactMessageDescription": {}, "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "@recoveryKey": {}, "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "@invalidInput": {}, - "about": "Σχετικά με το", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "@dehydrateTorLong": {}, "@yourPublicKey": { - "type": "text", + "type": "String", "placeholders": {} }, "@tooManyRequestsWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "@doNotShowAgain": {}, - "activatedEndToEndEncryption": "🔐 {username} ενεργοποίησε κρυπτογράφηση από άκρη σε άκρη", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@report": {}, "@status": { - "type": "text", + "type": "String", "placeholders": {} }, "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "@verifyStart": { - "type": "text", + "type": "String", "placeholders": {} }, "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "@unverified": {}, "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "@serverRequiresEmail": {}, @@ -1317,202 +1450,212 @@ "@screenSharingTitle": {}, "@widgetCustom": {}, "@sentCallInformations": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "@addToSpaceDescription": {}, - "googlyEyesContent": "{senderName} σας στέλνει googly eyes", "@googlyEyesContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "@youBannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@theyDontMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "@youHaveBeenBannedFromThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, - "addChatDescription": "Προσθέστε μια περιγραφή συνομιλίας...", "@addChatDescription": {}, "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, - "cancel": "Ακύρωση", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "@hasKnocked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@publish": {}, "@openLinkInBrowser": {}, "@clearArchive": {}, - "appLock": "Κλείδωμα εφαρμογών", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "@messageInfo": {}, "@disableEncryptionWarning": {}, "@directChat": {}, "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "@wrongPinEntered": { - "type": "text", + "type": "String", "placeholders": { - "seconds": {} + "seconds": { + "type": "int" + } } }, - "sendTypingNotifications": "Αποστολή ειδοποιήσεων δακτυλογράφησης", "@sendTypingNotifications": {}, "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "@inviteGroupChat": {}, "@appearOnTop": {}, "@invitePrivateChat": {}, "@verifyTitle": { - "type": "text", + "type": "String", "placeholders": {} }, "@foregroundServiceRunning": {}, "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "@voiceCall": {}, "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "@unknownEncryptionAlgorithm": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, - "importEmojis": "Εισαγωγή Emojis", "@importEmojis": {}, "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "@wasDirectChatDisplayName": { - "type": "text", + "type": "String", "placeholders": { - "oldDisplayName": {} + "oldDisplayName": { + "type": "String" + } } }, "@noChatDescriptionYet": {}, "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "@removeFromBundle": {}, "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "@whoCanPerformWhichAction": { - "type": "text", + "type": "String", "placeholders": {} }, - "confirmMatrixId": "Παρακαλούμε επιβεβαιώστε το Matrix ID σας για να διαγράψετε τον λογαριασμό σας.", "@confirmMatrixId": {}, "@learnMore": {}, "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "@you": { - "type": "text", + "type": "String", "placeholders": {} }, - "notAnImage": "Δεν είναι αρχείο εικόνας.", "@notAnImage": {}, "@users": {}, "@openGallery": {}, "@chatDescriptionHasBeenChanged": {}, "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "@newGroup": {}, @@ -1520,411 +1663,440 @@ "@dehydrateTor": {}, "@removeFromSpace": {}, "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "@sourceCode": { - "type": "text", + "type": "String", "placeholders": {} }, "@roomUpgradeDescription": {}, "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "@userSentUnknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "type": {} + "username": { + "type": "String" + }, + "type": { + "type": "String" + } } }, "@scanQrCode": {}, "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "@pleaseEnterANumber": {}, "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "@youKicked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, - "areYouSureYouWantToLogout": "Σίγουρα θέλετε να αποσυνδεθείτε;", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@profileNotFound": {}, "@jump": {}, "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "@reactedWith": { - "type": "text", + "type": "String", "placeholders": { - "sender": {}, - "reaction": {} + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } } }, - "bannedUser": "{username} banned {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "@sorryThatsNotPossible": {}, "@videoWithSize": { - "type": "text", + "type": "String", "placeholders": { - "size": {} + "size": { + "type": "String" + } } }, "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "@shareInviteLink": {}, "@commandHint_markasdm": {}, "@recoveryKeyLost": {}, - "cuddleContent": "{senderName} σε αγκαλιάζει", "@cuddleContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, - "askVerificationRequest": "Αποδοχή αυτού του αιτήματος επαλήθευσης από {username};", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "@deviceKeys": {}, "@waitingPartnerNumbers": { - "type": "text", + "type": "String", "placeholders": {} }, "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, - "addEmail": "Προσθήκη email", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "@emoteKeyboardNoRecents": { - "type": "text", + "type": "String", "placeholders": {} }, "@setCustomEmotes": { - "type": "text", + "type": "String", "placeholders": {} }, "@startedACall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "@visibilityOfTheChatHistory": { - "type": "text", + "type": "String", "placeholders": {} }, "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, "@setTheme": {}, "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "@youJoinedTheChat": {}, "@wallpaper": { - "type": "text", + "type": "String", "placeholders": {} }, "@openVideoCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "@statusExampleMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "@markAsRead": {}, "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "@widgetName": {}, "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@errorAddingWidget": {}, "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, - "commandHint_hug": "Στείλτε μια αγκαλιά", "@commandHint_hug": {}, - "replace": "Αντικαταστήστε το", "@replace": {}, "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "@youUnbannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, - "archive": "Αρχείο", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@visibleForEveryone": { - "type": "text", + "type": "String", "placeholders": {} }, "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "@newSpace": {}, "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, - "accept": "Αποδοχή", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "@unknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "type": {} + "type": { + "type": "String" + } } }, "@emojis": {}, "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "@share": { - "type": "text", + "type": "String", "placeholders": {} }, - "commandHint_googly": "Στείλτε μερικά μάτια", "@commandHint_googly": {}, "@pleaseTryAgainLaterOrChooseDifferentServer": {}, "@createGroup": {}, "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "@hydrateTorLong": {}, "@time": {}, "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, - "botMessages": "Μηνύματα bot", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "@custom": {}, "@noBackupWarning": {}, "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "@verify": { - "type": "text", + "type": "String", "placeholders": {} }, "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "@storeInSecureStorageDescription": {}, "@openChat": {}, "@kickUserDescription": {}, "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, - "importNow": "Εισαγωγή τώρα", "@importNow": {}, "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "@setInvitationLink": { - "type": "text", + "type": "String", "placeholders": {} }, "@pinMessage": {}, "@screenSharingDetail": {}, "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "@invite": {}, "@enableMultiAccounts": {}, - "anyoneCanJoin": "Οποιοσδήποτε μπορεί να συμμετάσχει", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "@indexedDbErrorTitle": {}, "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } } } diff --git a/lib/l10n/intl_ca.arb b/lib/l10n/intl_ca.arb new file mode 100644 index 000000000..051487539 --- /dev/null +++ b/lib/l10n/intl_ca.arb @@ -0,0 +1,3146 @@ +{ + "@@last_modified": "2021-08-14 12:41:10.145728", + "about": "Quant a", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Accepta", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} ha acceptat la invitació", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Compte", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} ha activat el xifratge d’extrem a extrem", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Administració", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "àlies", + "@alias": { + "type": "String", + "placeholders": {} + }, + "allChats": "Tots els xats", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} ha respost a la trucada", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Qualsevol pot unir-se", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Blocatge de l’aplicació", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arxiu", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Es pot entrar al xat com a convidadi", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "N’esteu seguri?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Per a poder donar accés a l’altra persona, introduïu la frase de seguretat o clau de recuperació.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Voleu acceptar aquesta sol·licitud de verificació de: {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banFromChat": "Veta del xat", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Vetadi", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} ha vetat a {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Bloca el dispositiu", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Missatges del bot", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Cancel·la", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "No es pot obrir l’URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Canvia el nom del dispositiu", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} ha canviat la imatge del xat", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} ha canviat la descripció del xat a: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} ha canviat el nom del xat a: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} ha canviat els permisos del xat", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} ha canviat les normes d’accés dels convidats", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} ha canviat les normes d’accés dels convidats a: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} ha canviat la visibilitat de l’historial", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} ha canviat la visibilitat de l’historial a: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} ha canviat les normes d’unió", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} ha canviat les normes d’unió a: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} ha canviat la seva imatge de perfil", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} ha canviat l’àlies de la sala", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} ha canviat l’enllaç per a convidar", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Canvia la contrasenya", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Canvia el servidor", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Canvia l’estil", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Canvia el nom del grup", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "El xifratge s’ha corromput", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Xat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Detalls del xat", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Xats", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Trieu una contrasenya forta", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Tanca", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_html": "Envia text en format HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_leave": "Abandona aquesta sala", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_op": "Estableix el nivell d'autoritat d'uni usuàriï (per defecte: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Envia text sense format", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_send": "Envia text", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "compareEmojiMatch": "Compareu aquests emojis", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Compareu aquests números", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Confirma", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Connecta", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "El contacte ha estat convidat al grup", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Conté l'àlies", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Inclou nom d'usuàriï", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "S’ha copiat al porta-retalls", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Copia", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "No s'ha pogut desxifrar el missatge: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} participants", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Crea", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} ha creat el xat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Actiu actualment", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Fosc", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Es desactivarà el vostre compte d’usuàriï. És irreversible! Voleu fer-ho igualment?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "delete": "Suprimeix", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Suprimeix el compte", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Suprimeix el missatge", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Dispositiu", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Id. de dispositiu", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Dispositius", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Xats directes", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Ha canviat l'àlies", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Baixa el fitxer", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Edita", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Edita l'àlies", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "L'emoticona ja existeix!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Codi d'emoticona invàlid!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Paquet d'emoticones de la sala", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Paràmetres de les emoticones", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Codi d'emoticona", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Has de seleccionar un codi d'emoticona i una imatge!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Xat buit", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Activa el paquet d'emoticones global", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "No podreu desactivar el xifratge mai més. N’esteu segur?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Xifrat", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Xifratge", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "El xifratge no s’ha activat", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} ha finalitzat la trucada", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Introduïu una adreça electrònica", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Introdueix el teu servidor", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "fileName": "Nom del fitxer", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Reenvia", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Des de la unió", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Des de la invitació", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Grup", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "El grup és públic", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grup amb {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Els convidats no poden unir-se", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Els convidats es poden unir", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} ha retirat la invitació de {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Ajuda", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Amaga els esdeveniments estripats", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Amaga els esdeveniments desconeguts", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "id": "Id.", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identitat", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Usuaris ignorats", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "He fet clic a l'enllaç", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Frase de seguretat o clau de recuperació incorrecta", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Convida contacte", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Convida contacte a {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Convidat", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} ha convidat a {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Només usuàriïs convidadis", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Invitació per a mi", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} t'ha convidat a FluffyChat.\n1. Visita fluffychat.im i instaŀla l'app\n2. Registra't o inicia sessió\n3. Obre l'enllaç d'invitació:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "escrivint…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} s'ha unit al xat", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Uneix-te a la sala", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} ha expulsat a {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} ha expulsat i vetat a {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Expulsa del xat", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Actiu per última vegada: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Abandona", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Ha marxat del xat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Llicència", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Clar", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Carrega {count} participants més", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "S’està carregant… Espereu.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Carrega’n més…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "S’han desactivat els serveis d’ubicació. Activeu-los per a compartir la vostra ubicació.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "S’ha rebutjat el permís d’ubicació. Atorgueu-lo per a poder compartir la vostra ubicació.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Inicia la sessió", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Inicia sessió a {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Finalitza la sessió", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Canvis de participants", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Menciona", + "@mention": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderador", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Silencia el xat", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Tingueu en compte que, ara per ara, us cal el Pantalaimon per a poder utilitzar el xifratge d’extrem a extrem.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Missatge nou al FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nova sol·licitud de verificació!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "no": "No", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Sense connexió al servidor", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "No s’ha trobat cap emoticona. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Sembla que no teniu els Serveis de Google al telèfon. Això és una bona decisió respecte a la vostra privadesa! Per a rebre notificacions automàtiques del FluffyChat, us recomanem instaŀlar ntfy. Amb ntfy o qualsevol altre proveïdor de Unified Push, pots rebre notificacions de forma segura i lliure. Pots instaŀlar ntfy des de la PlayStore o des de F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Cap", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Encara no heu afegit cap mètode per a poder recuperar la contrasenya.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Sense permís", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "No s’ha trobat cap sala…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notificacions", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Notificacions activades per a aquest compte", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} usuàriïs escrivint…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offline": "Fora de línia", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "D'acord", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "En línia", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "La còpia de seguretat de claus en línia està activada", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Alguna cosa ha anat malament…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Obre l'aplicació per llegir els missatges", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Obre la càmera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "or": "O", + "@or": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "contrasenya o clau de recuperació", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Contrasenya", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Contrasenya oblidada", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "La contrasenya ha canviat", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Recuperació de contrassenya", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Selecciona una imatge", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Fixa", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Reproduir {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChooseAPasscode": "Tria un codi d'accés", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Fes clic a l'enllaç del correu i, després, segueix.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Introdueix 4 dígits o deixa-ho buit per desactivar el bloqueig.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Introdueix la teva contrasenya", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Introdueix el teu nom d'usuàriï", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privadesa", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Sales públiques", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Regles push", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "recording": "Enregistrant", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} ha estripat un esdeveniment", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Rebutja", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} ha rebutjat la invitació", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Torna-t'hi a unir", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Elimina", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Elimina tots els altres dispositius", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Eliminat per {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Elimina dispositiu", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Aixeca el veto", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "Respon", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Sol·licita permís", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "La sala s'ha actualitzat", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "security": "Seguretat", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Vist per {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Envia", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Envia un missatge", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Envia com a text", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Envia un àudio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Envia un fitxer", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Envia una imatge", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Envia l’original", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Envia adhesiu", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Envia un vídeo", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} ha enviat un fitxer", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} ha enviat un àudio", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} ha enviat una imatge", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} ha enviat un adhesiu", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} ha enviat un vídeo", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} ha enviat informació de trucada", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setInvitationLink": "Defineix l’enllaç per a convidar", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Defineix el nivell de permisos", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Defineix l’estat", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Paràmetres", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Comparteix", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} n’ha compartit la ubicació", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "singlesignon": "Autenticació única", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Omet", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Codi font", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} ha iniciat una trucada", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "statusExampleMessage": "Com us sentiu avui?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Envia", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistema", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "No coincideixen", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Coincideixen", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Marca com a llegit/sense llegir", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Massa sol·licituds. Torna-ho a provar més tard!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Intenta tornar a enviar", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "No disponible", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} ha aixecat el veto a {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Desbloqueja dispositiu", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Dispositiu desconegut", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "L’algorisme de xifratge és desconegut", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Esdeveniment desconegut '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Deixa de silenciar el xat", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Deixa de fixar", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 xat no llegit} other{{unreadCount} xats no llegits}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} i {count} més estan escrivint…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} i {username2} estan escrivint…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} està escrivint…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} ha marxat del xat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Nom d’usuàriï", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} ha enviat un esdeveniment {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "Verifica", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Inicia la verificació", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "T'has verificat correctament!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verificant un altre compte", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videotrucada", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Visibilitat de l’historial del xat", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Visible per a tots els participants", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Visible per a tothom", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Missatge de veu", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "S’està esperant que l’altre accepti l’emoji…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "S’està esperant que l’altre accepti els nombres…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Fons:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Atenció!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Us hem enviat un missatge de correu electrònic", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Qui pot unir-se a aquest grup", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Amb aquestes adreces, si ho necessiteu, podeu recuperar la vostra contrasenya.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Escriviu un missatge…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Sí", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Vós", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Ja no participeu en aquest xat", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "T'han vetat en aquest xat", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "La vostra clau pública", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "all": "Tot", + "@all": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Afegeix a un espai", + "areYouSureYouWantToLogout": "Segur que voleu finalitzar la sessió?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "addEmail": "Afegeix una adreça electrònica", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "commandInvalid": "L’ordre no és vàlida", + "@commandInvalid": { + "type": "String" + }, + "fontSize": "Mida de la lletra", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Ves a la sala nova", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "next": "Següent", + "@next": { + "type": "String", + "placeholders": {} + }, + "link": "Enllaç", + "people": "Gent", + "@people": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "Estripa el missatge", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Envia en prémer Retorn", + "clearArchive": "Neteja l’arxiu", + "chatBackupDescription": "Els teus xats estan protegits amb una clau de recuperació. Assegura't de no perdre-la.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "El xat s’ha afegit a aquest espai", + "autoplayImages": "Reprodueix automàticament enganxines i emoticones animades", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "chatBackup": "Còpia de seguretat del xat", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "blocked": "Blocat", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Tot és a punt!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Nom de l’espai", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "search": "Cerca", + "@search": { + "type": "String", + "placeholders": {} + }, + "verified": "Verificat", + "@verified": { + "type": "String", + "placeholders": {} + }, + "newChat": "Xat nou", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Canvia l’avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignora", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "commandHint_react": "Envia una resposta com a reacció", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "defaultPermissionLevel": "Nivell de permisos per defecte per nous membres", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extremadament ofensiu", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "S’ha configurat la còpia de seguretat del xat.", + "contentHasBeenReported": "El contingut s’ha denunciat als administradors del servidor", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Activa el xifratge", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "addAccount": "Afegeix un compte", + "noEncryptionForPublicRooms": "Només podreu activar el xifratge quan la sala ja no sigui accessible públicament.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Versió de la sala", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Envia missatges", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Desa el fitxer", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Seguiu les instruccions al lloc web i toqueu «Següent».", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Denuncia el missatge", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Defineix com a àlies principal", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "status": "Estat", + "@status": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Commuta l’estat «preferit»", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Commuta l’estat «silenci»", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Transfereix des d’un altre dispositiu", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Defineix emoticones personalitzades", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Qui pot efectuar quina acció", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Per què voleu denunciar això?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Voleu suprimir la còpia de seguretat dels xats per a crear una clau de recuperació nova?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "S’està esperant que l’altre accepti la sol·licitud…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "unverified": "No verificat", + "commandHint_me": "Descriviu-vos", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandMissing": "{command} no és una ordre.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "configureChat": "Configura el xat", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Copia al porta-retalls", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Espai nou", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "S’ha produït un error en obtenir la ubicació: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "groups": "Grups", + "@groups": { + "type": "String", + "placeholders": {} + }, + "messages": "Missatges", + "@messages": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Mostra la contrasenya", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "L’espai és públic", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "Escaneja un codi QR", + "obtainingLocation": "S’està obtenint la ubicació…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Comparteix la ubicació", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "S’està sincronitzant… Espereu.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "reason": "Raó", + "@reason": { + "type": "String", + "placeholders": {} + }, + "changedTheDisplaynameTo": "{username} ha canviat el seu àlies a: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "howOffensiveIsThisContent": "Com d’ofensiu és aquest contingut?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "commandHint_clearcache": "Neteja la memòria cau", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_join": "Uneix-te a la sala", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Expulsa uni usuàriï d'aquesta sala", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_myroomavatar": "Establiu la imatge per a aquesta sala (per mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_dm": "Inicia un xat directe\nUsa --no-encryption per desactivar l'encriptatge", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_invite": "Convida uni usuàriï a aquesta sala", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_ban": "Veta uni usuàriï d'aquesta sala", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_create": "Crea un xat de grup buit\nUsa --no-encryption per desactivar l'encriptatge", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Descarta la sessió", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "repeatPassword": "Repetiu la contrasenya", + "commandHint_myroomnick": "Estableix el teu àlies per a aquesta sala", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "editBlockedServers": "Edita els servidors bloquejats", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "El servidor admet els inicis de sessió:\n{serverVersions}\nPerò l'aplicació només admet:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "hugContent": "{senderName} t'abraça", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Salta a l'últim missatge llegit", + "allRooms": "Tots els xats de grup", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "commandHint_cuddle": "Envia una carícia", + "widgetVideo": "Vídeo", + "dismiss": "Ignora-ho", + "reportErrorDescription": "😭 Oh no. Hi ha hagut algun error. Si vols, pots informar d'aquest bug a l'equip de desenvolupament.", + "removeYourAvatar": "Esborra el teu avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "unsupportedAndroidVersion": "Aquesta versió d'Android és incompatible", + "widgetJitsi": "Jitsi Meet", + "messageType": "Tipus de missatge", + "indexedDbErrorLong": "L'emmagatzematge de missatges no està disponible per defecte en el mode privat.\nVisita\n - about:config\n - posa a true l'opció dom.indexedDB.privateBrowsing.enabled\nSi no ho fas, no podràs fer servir FluffyChat en mode privat.", + "oneClientLoggedOut": "Una de les teves aplicacions ha tancat la sessió", + "startFirstChat": "Comença el teu primer xat", + "callingAccount": "Compte de la trucada", + "setColorTheme": "Tria el color del tema:", + "nextAccount": "Compte següent", + "allSpaces": "Tots els espais", + "supposedMxid": "Això hauria de ser {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "user": "Usuàrïi", + "youAcceptedTheInvitation": "👍 Has acceptat la invitació", + "noMatrixServer": "{server1} no és un servidor de matrix, vols fer servir {server2} ?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 {user} t'ha convidat", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "banUserDescription": "Es vetarà li usuàriï al xat i no podrà tornar-hi a entrar fins que se li aixequi el veto.", + "widgetEtherpad": "Nota de text", + "removeDevicesDescription": "Tancaràs la sessió d'aquest dispositiu i no hi podràs rebre més missatges.", + "separateChatTypes": "Separa xats directes i grups", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "tryAgain": "Torna-ho a provar", + "youKickedAndBanned": "🙅 Has expulsat i vetat a {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unbanUserDescription": "L'usuàrïi ja pot tornar a entrar al xat.", + "youRejectedTheInvitation": "Has rebutjat la invitació", + "otherCallingPermissions": "Micròfon, càmera i altres permisos del FluffyChat", + "messagesStyle": "Missatges:", + "widgetUrlError": "La URL no és vàlida.", + "emailOrUsername": "Email o nom d'usuàrïi", + "newSpaceDescription": "Els espais et permeten consolidar els teus xats i construir comunitats públiques o privades.", + "chatDescription": "Descripció del xat", + "callingAccountDetails": "Permet al FluffyChat de fer servir l'app de trucades nativa de l'Android.", + "editRoomAliases": "Canvia els àlies de la sala", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "enterSpace": "Obre l'espai", + "encryptThisChat": "Xifra aquest xat", + "previousAccount": "Compte anterior", + "reopenChat": "Reobre el xat", + "pleaseEnterRecoveryKey": "Introdueix la teva clau de recuperació:", + "widgetNameError": "Posa el nom públic.", + "inoffensive": "Inofensiu", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "addToBundle": "Afegeix al pquet", + "addWidget": "Afegeix un giny", + "countFiles": "{count} arxius", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noKeyForThisMessage": "Això pot passar si el missatge es va enviar abans que haguessis iniciat sessió al teu compte des d'aquest dispositiu.\n\nTambé pot ser que l'emissor hagi bloquejat el teu dispositiu o que la connexió a internet anés malament.\n\nQue pots llegir el missatge des d'una altra sessió? Si és així, llavors pots transferir-lo! Ves a Paràmetres → Dispositius i assegura't que els teus dispositius s'ha verificat mútuament. Quan obris la sala la propera vegada i totes dues sessions estiguin executant-se, en primer pla, llavors les claus es trasnsmetran automàticament.\n\nVols evitar perdre les claus en tancar la sessió o en canviar de dispositiu? Llavors assegura't que has activat la còpia de seguretat del xat als paràmetres.", + "commandHint_markasgroup": "Marca com un grup", + "hydrateTor": "Usuàrïis de Tor: Importa una sessió anterior", + "pushNotificationsNotAvailable": "Les notificacions push no estan disponibles", + "storeInAppleKeyChain": "Desa en la Apple KeyChain", + "replaceRoomWithNewerVersion": "Substitueix la sala amb la versió més recent", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "hydrate": "Restaura un arxiu de recuperació", + "invalidServerName": "El nom del servidor és invàlid", + "chatPermissions": "Permisos del xat", + "sender": "Remitent", + "storeInAndroidKeystore": "Desa en la Android KeyStore", + "signInWithPassword": "Inicia sessió amb contrasenya", + "offensive": "Ofensiu", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "makeAdminDescription": "Un cop hagis fet admin aquesta persona ja no podràs desfer-ho, ja que llavors tindrà els mateixos permisos que tu.", + "saveKeyManuallyDescription": "Per desar aquesta clau manualment, pica l'eina de compartir o copia-la al porta-retalls.", + "editBundlesForAccount": "Edita paquets per aquest compte", + "whyIsThisMessageEncrypted": "Per què no es pot llegir aquest missatge?", + "setChatDescription": "Posa una descripció de xat", + "importFromZipFile": "Importa des d'un arxiu zip", + "dehydrateWarning": "Aquesta acció és irreversible. Assegura't que deses l'arxiu de recuperació en un lloc segur.", + "noOtherDevicesFound": "No s'han trobat més dispositius", + "redactedBy": "Estripat per {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "videoCallsBetaWarning": "Tingues en compte que les trucades de vídeo estan encara en beta. Pot ser que no funcioni bé o que falli en alguna plataforma.", + "participant": "Participant", + "@participant": { + "type": "String", + "placeholders": {} + }, + "signInWith": "Inicia sessió amb {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "No s'ha pogut enviar! El servidor només accepta adjunts de fins a {max}.", + "homeserver": "Servidor", + "callingPermissions": "Permisos de trucada", + "readUpToHere": "Llegit fins aquí", + "start": "Comença", + "register": "Registra't", + "@register": { + "type": "String", + "placeholders": {} + }, + "unlockOldMessages": "Desbloqueja els missatges antics", + "numChats": "{number} xats", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Opcional) El motiu per estripar el missatge...", + "dehydrate": "Exporta la sessió i neteja el dispositiu", + "archiveRoomDescription": "Aquest xat serà arxivat. Els altres contactes del grup ho veuran com si haguessis abandonat el xat.", + "exportEmotePack": "Exporta com un pack Emote en .zip", + "switchToAccount": "Canvia al compte {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "experimentalVideoCalls": "Trucades de vídeo experimentals", + "pleaseEnterRecoveryKeyDescription": "Per desbloquejar els missatges antics, introdueix la clau de recuperació que vas generar en una sessió anterior. La clau de recuperació NO és la teva contrasenya.", + "openInMaps": "Obre als mapes", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroupQuestion": "Vols convidar {contact} al xat \"{groupName}\"?", + "redactedByBecause": "Estripat per {username} per: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Has rebutjat la invitació de {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "appearOnTopDetails": "Permet a l'app que aparegui sobre d'altres apps. No cal si ja has afegit FluffyChat com a compte de trucades", + "enterRoom": "Entra a la sala", + "reportUser": "Denuncia l'usuàrïi", + "confirmEventUnpin": "Vols desfixar l'esdeveniment permanentment?", + "badServerVersionsException": "Aquest servidor suporta aquestes versions de Matrix:\n{serverVersions}\nPerò aquesta aplicación només és compatible amb {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Has convidat a {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "S'ha desat l'arxiu a {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "redactMessageDescription": "S'estriparà el missatge per a totser d'aquesta conversa. Aquesta acció és irreversible.", + "recoveryKey": "Clau de recuperació", + "invalidInput": "L'entrada no és vàlida!", + "dehydrateTorLong": "Per a lis usuàrïis de Tor, es recomana exportar la sessió abans de tancar la finestra.", + "doNotShowAgain": "No ho tornis a mostrar", + "report": "informa", + "serverRequiresEmail": "Aquest servidor necessita validar la teva adreça per registrar-t'hi.", + "hideUnimportantStateEvents": "Amaga canvis d'estat poc importants", + "screenSharingTitle": "compartició de pantalla", + "widgetCustom": "Personalització", + "addToSpaceDescription": "Tria un espai per afegir-hi el xat.", + "googlyEyesContent": "{senderName} t'ha enviat un parell d'ulls", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "youBannedUser": "Has vetat a {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "addChatDescription": "Afegeix una descripció al xat...", + "editRoomAvatar": "Canvia la imatge de la sala", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "hasKnocked": "🚪 {user} pica a la porta", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "publish": "Publica", + "openLinkInBrowser": "Obre l'enllaç en un navegador", + "messageInfo": "Informació del missatge", + "disableEncryptionWarning": "Per motius de seguretat, un cop activat, no es pot desactivar el xifratge.", + "directChat": "Xat directe", + "wrongPinEntered": "Pin incorrecte! Torna-ho a provar en {seconds} segons...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "Envia notificacions d'escriptura", + "inviteGroupChat": "📨 Invitació de grup", + "appearOnTop": "Mostra per sobre", + "invitePrivateChat": "📨 Invitació a un xat privat", + "foregroundServiceRunning": "Aquesta notificació apareix quan el servei de primer pla està corrent.", + "voiceCall": "Videotrucada", + "commandHint_unban": "Aixeca el veto a aquesti usuàriï per aquesta sala", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "importEmojis": "Importa emojis", + "wasDirectChatDisplayName": "Xat buit ( era {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "No s'ha afegit una descripció de xat.", + "removeFromBundle": "Esborra del paquet", + "confirmMatrixId": "Confirma la teva ID de Matrix per poder esborrar el compte.", + "learnMore": "Llegeix-ne més", + "notAnImage": "No és un arxiu d'image.", + "users": "Usuàrïis", + "openGallery": "Obre la galeria", + "chatDescriptionHasBeenChanged": "Ha canviat la descripció del xat", + "newGroup": "Grup nou", + "bundleName": "Nom del paquet", + "dehydrateTor": "Usuàrïis de Tor: Exporta la sessió", + "removeFromSpace": "Esborra de l'espai", + "roomUpgradeDescription": "El xat serà recreat amb una versió de sala nova. Totis lis participants seran notificadis que han de canviar al nou xat. Pots llegir més sobre les versions de sala a https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Introdueix un número major que 0", + "youKicked": "👞 Has expulsat a {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "profileNotFound": "No s'ha trobat el compte en aquest servidor. Pot ser un error de connexió, o que realment no existeixi.", + "jump": "Salta", + "reactedWith": "{sender} ha reaccionat amb {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "sorryThatsNotPossible": "Aquesta acció no és possible", + "videoWithSize": "Vídeo {size}", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "shareInviteLink": "Comparteix un enllaç d'invitació", + "commandHint_markasdm": "Marca com a conversa directa la sala amb aquesta ID de Matrix", + "recoveryKeyLost": "Que has perdut la clau de recuperació?", + "cuddleContent": "{senderName} et fa una carícia", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "deviceKeys": "Claus del dispositiu:", + "emoteKeyboardNoRecents": "Els últims emotes usats apareixeran aquí...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Tria el tema:", + "youJoinedTheChat": "T'has afegit al xat", + "openVideoCamera": "Obre la càmera per a fer un vídeo", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "markAsRead": "Marca com a llegit", + "widgetName": "Nom", + "errorAddingWidget": "S'ha produït un error en afegir el giny.", + "commandHint_hug": "Envia una abraçada", + "replace": "Reemplaça", + "oopsPushError": "Ep! Sembla que s'ha produït un error en configurar les notificacions.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "youUnbannedUser": "Has aixecat el veto a {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "newSpace": "Espai nou", + "emojis": "Emojis", + "pleaseEnterYourPin": "Introdueix el teu pin", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Escull", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "commandHint_googly": "Envia uns ulls curiosos", + "pleaseTryAgainLaterOrChooseDifferentServer": "Torna-ho a provar més tard o tria un servidor diferent.", + "createGroup": "Crea un grup", + "hydrateTorLong": "Que vas exportar la teva última sessió a Tor? La pots importar ara i continuar xatejant.", + "time": "Temps", + "custom": "Personalitzat", + "noBackupWarning": "Compte! Si no actives la còpia de seguretat dels xats, perdràs accés als teus missatges xifrats. És molt recomanable activar-ho abans de tancar la sessió.", + "storeInSecureStorageDescription": "Desa la clau de recuperació en l'emmagatzematge segur d'aquest dispositiu.", + "openChat": "Obre el xat", + "kickUserDescription": "Li usuàrïi ha estat expulsadi però no vetadi. Als xats públics, pot tornar-hi a entrar en qualsevol moment.", + "importNow": "Importa-ho ara", + "pinMessage": "Fixa a la sala", + "invite": "Convida", + "enableMultiAccounts": "(Beta) Activa multi-compte en aquest dispositiu", + "indexedDbErrorTitle": "Problemes amb el mode privat", + "unsupportedAndroidVersionLong": "Aquesta funcionalitat només funciona amb versions d'Android més noves.", + "storeSecurlyOnThisDevice": "Desa de forma segura en aquest dispositiu", + "screenSharingDetail": "Estàs compartint la teva pantalla a FluffyChat", + "placeCall": "Truca", + "block": "Bloca", + "blockUsername": "Ignora aquesti usuàrïi", + "blockedUsers": "Usuàrïis blocadis", + "blockListDescription": "Pots bloquejar usuàrïis que et molestin. No rebràs missatges seus ni invitacions de part seva a cap sala.", + "pleaseChooseAStrongPassword": "Tria una contrasenya forta", + "youInvitedToBy": "📩 T'han enviat un enllaç d'invitació per:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "groupName": "Nom del grup", + "createGroupAndInviteUsers": "Crea un grup i convida-hi usuàrïis", + "wrongRecoveryKey": "Malauradament, aquesta clau de recuperació no és la correcta.", + "publicLink": "Enllaç públic", + "transparent": "Transparent", + "sendReadReceiptsDescription": "Lis altris participants d'un xat poden veure quan has llegit un missatge.", + "yourGlobalUserIdIs": "La teva ID global és: ", + "startConversation": "Comença una conversa", + "commandHint_sendraw": "Envia un json pelat", + "databaseMigrationTitle": "La base de dades ha estat optimitzada", + "pleaseEnterYourCurrentPassword": "Fica la teva contrasenya actual", + "newPassword": "Contrasenya nova", + "restoreSessionBody": "L'aplicació provarà de restaurar la teva sessió des de la còpia de seguretat. Si us plau, comunica aquest error a l'equi pde desenvolupament a {url}. El missatge d'error és {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "formattedMessages": "Missatges amb format", + "formattedMessagesDescription": "Mostra contingut amb format enriquit com text en cursiva, fent servir markdown.", + "verifyOtherUser": "🔐 Verifica uni altri usuàrïi", + "verifyOtherDevice": "🔐 Verifica un altre dispositiu", + "databaseBuildErrorBody": "No s'ha pogut construir la base de dades SQLite. L'aplicació provarà de fer servir un format de base de dades antiquat. Si us plau, comunica aquesta situació a la comunitat de desenvolupament a {url}. El missatge d'error és: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "S'ha produït un error mentre s'inicialitzava l'aplicació", + "hidePresences": "Amagar la llista de Status?", + "noUsersFoundWithQuery": "No s'ha trobat cap usuàrïi amb \"{query}\". Revisa si ho has escrit malament.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "leaveEmptyToClearStatus": "Per esborrar el teu estat, deixa-ho en blanc.", + "select": "Tria", + "searchForUsers": "Cerca @usuariïs...", + "subspace": "Subespai", + "addChatOrSubSpace": "Afegeix un xat o un subespai", + "decline": "Denega", + "sendReadReceipts": "Envia informes de tecleig", + "sendTypingNotificationsDescription": "Lis altris participants d'un xat poden veure quan estàs teclejant un missatge nou.", + "incomingMessages": "Missatge d'entrada", + "presenceStyle": "Presència:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "acceptedKeyVerification": "{sender} ha acceptat la verificació de claus", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} ha canceŀlat la verificació de claus", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} ha comletat la verificació de claus", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} està a punt per verificar les claus", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "nothingFound": "No s'ha trobat res...", + "searchChatsRooms": "Cerca #sales, @usuariïs...", + "groupCanBeFoundViaSearch": "El grup es pot trobar per la cerca general", + "databaseMigrationBody": "Espereu un moment, si us plau.", + "passwordsDoNotMatch": "Les contrasenyes no coincideixen", + "passwordIsWrong": "La contrasenya introduïda és incorrecta", + "joinSpace": "Fica't a l'espai", + "publicSpaces": "Espais públics", + "thisDevice": "Aquest dispositiu:", + "sessionLostBody": "S'ha perdut la teva sessió. Si us plau, comunica aquest error a l'equip de desenvolupament a {url}. El missatge d'error és: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Vols reenviar el missatge a {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "verifyOtherUserDescription": "Si verifiques aquesti usuàrïi, podràs estar seguri de a qui estàs escrivint. . 💪\n\nQuan inicies una verificació, l'altra persona i tu veureu un missatge emergent a l'app. Us sortiran un seguit d'emojis o números a cada pantalla, que haureu de comparar.\n\nLa millor manera de fer-ho és quedar en persona o fer una vídeo-trucada. 👭", + "verifyOtherDeviceDescription": "Quan verifiques un altre dispositiu, aquests poden intercanviar claus, així que es millora la seguretat total. 💪 Quan comences una verificació, apareixerà un missatge emergent a tots dos dispositius. A cadascun hi apareixerà un seguit d'emojis o de números que hauràs de comparar. El millor és tenir tots dos dispositius a mà abans d'iniciar la verificació. 🤳", + "requestedKeyVerification": "{sender} ha soŀlicitat verificar claus", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} ha iniciat la verificació de claus", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "presencesToggle": "Mostra els missatges d'estat d'altres usuàrïis", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "stickers": "Enganxines", + "discover": "Descobreix", + "commandHint_ignore": "Ignora el compte de matrix especificat", + "commandHint_unignore": "Deixa d'ignorar el compt de matrix especificat", + "sendCanceled": "S'ha canceŀlat l'enviament", + "noChatsFoundHere": "Encara no hi ha xats. Obre una conversa amb algú picant al botó de sota. ⤵️", + "hideMemberChangesInPublicChatsBody": "No mostres a l'històric de conversa de les sales públiques quan algú hi entra o surt. Això facilita la lectura.", + "invitedBy": "📩 Convidadi per {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "knock": "Pica", + "knocking": "S'està picant", + "restricted": "Restringit", + "knockRestricted": "No es pot picar a la porta", + "goToSpace": "Ves a l'espai {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "adminLevel": "{level} - Admin", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Canvia les opcions generals de xat", + "sendRoomNotifications": "Envia notificacions @room", + "changeTheDescriptionOfTheGroup": "Canvia la descripció del xat", + "changelog": "Registre de canvis", + "userLevel": "{level} - Usuàriï", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderadori", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "inviteOtherUsers": "Convida més gent a la conversa", + "changeTheChatPermissions": "Canvia els permisos del xat", + "changeTheVisibilityOfChatHistory": "Canvia la visibilitat de l'historial de conversa", + "changeTheCanonicalRoomAlias": "Canvia l'adreça principal del xat", + "accessAndVisibilityDescription": "Qui pot entrar a aquesta conversa i com pot ser descoberta.", + "customEmojisAndStickers": "Emojis i stickers propis", + "accessAndVisibility": "Accés i visibilitat", + "calls": "Trucades", + "hideRedactedMessages": "Amaga els missatges estripats", + "hideInvalidOrUnknownMessageFormats": "Amaga els missatges que tinguin un format desconegut", + "hideMemberChangesInPublicChats": "Amaga els canvis d'estat de lis membres a les sales públiques", + "notifyMeFor": "Nofica'm que", + "overview": "Resum", + "passwordRecoverySettings": "Recuperació de contrasenya", + "userRole": "Rol d'usuàriï", + "minimumPowerLevel": "El nivell mínim de permisos és {level}.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "gallery": "Galeria", + "noDatabaseEncryption": "No es pot xifrar la base de dades en aquesta plataforma", + "usersMustKnock": "Lis membres han de picar a la porta", + "noOneCanJoin": "Ningú s'hi pot ficar", + "userWouldLikeToChangeTheChat": "{user} vol entrar al xat.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "customEmojisAndStickersBody": "Afegeix o comparteix emojis o stickers. Els podràs fer servir en qualsevol conversa.", + "hideRedactedMessagesBody": "Si algú estripa un missatge, ja no apareixerà a l'historial de la conversa.", + "searchIn": "Cerca al xat \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "markAsUnread": "Marca com a no llegit", + "chatPermissionsDescription": "Defineix quin nivell de permisos cal per cada acció en aquest xat. Els nivells 0, 50 i 100 normalment representen usuàriïs, mods i admins, però es pot canviar.", + "updateInstalled": "🎉 S'ha actualitzat a la versió {version}!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "appLockDescription": "Bloca l'app amb un pin quan no la facis servir", + "swipeRightToLeftToReply": "Llisca de dreta esquerra per respondre", + "globalChatId": "Identificador global de xat", + "createNewAddress": "Crea una adreça nova", + "searchMore": "Cerca més...", + "files": "Arxius", + "publicChatAddresses": "Adreces públiques del xat", + "unreadChatsInApp": "{appname}: {unread} converses pendents", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "Ara mateix hi ha {count} usuàriïs bloquejadis.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "loginWithMatrixId": "Entra amb l'id de Matrix", + "discoverHomeservers": "Descobreix servidors", + "whatIsAHomeserver": "Què és un servidor de Matrix?", + "homeserverDescription": "Totes les teves dades s'emmagatzemen al servidor, com passa amb el e-mail. Pots triar quin servidor vols fer servir sense témer a no poder comunicar gent d'altres servidors. Llegeix-ne més a https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "No sembla un servidor compatible. Pot ser que la URL estigui malament?", + "countChatsAndCountParticipants": "{chats} xats i {participants} participants", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "No hi ha més xats...", + "space": "Espai", + "joinedChats": "Xats on has entrat", + "unread": "Sense llegir", + "spaces": "Espais", + "noPublicLinkHasBeenCreatedYet": "No s'ha creat cap enllaç públic", + "chatCanBeDiscoveredViaSearchOnServer": "El xat es pot descobrir amb la cerca de {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "calculatingFileSize": "S'està calculant la mida de l'arxiu...", + "prepareSendingAttachment": "S'està preparant per enviar l'adjunt...", + "generatingVideoThumbnail": "S'està generant la miniatura del vídeo...", + "noticeChatBackupDeviceVerification": "Nota: quan connectes tots els dispositius al backup del xat, es verifiquen automàticament.", + "continueText": "Continua", + "strikeThrough": "Text ratllat", + "addLink": "Afegeix un enllaç", + "noContactInformationProvided": "El servidor no ofereix cap informació de contacte vàlida", + "setWallpaper": "Tria imatge de fons", + "sendImages": "Envia {count} imatge", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendingAttachment": "S'està enviant l'adjunt...", + "compressVideo": "S'està comprimint el vídeo...", + "sendingAttachmentCountOfCount": "S'està enviant l'adjunt {index} de {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "S'ha arribat al límit del servidor! Esperant {seconds} segons...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Un dels teus dispositius no està verificat", + "welcomeText": "Hola hola! 👋 Això és FluffyChat. Pots iniciar sessió en qualsevol servidor compatible amb https://matrix.org. I llavors xatejar amb qualsevol. És una xarxa enorme de missatgeria descentralitzada !", + "blur": "Difumina:", + "opacity": "Opacitat:", + "manageAccount": "Gestiona el compte", + "contactServerAdmin": "Contacta l'admin del servidor", + "contactServerSecurity": "Contacta l'equip de seguretat del servidor", + "version": "Versió", + "website": "Lloc web", + "compress": "Comprimeix", + "pleaseFillOut": "Emplena", + "invalidUrl": "URL invàlida", + "unableToJoinChat": "No s'ha pogut entrar al xat. Pot ser que l'altri participant hagi tancat la conversa.", + "aboutHomeserver": "Quant a {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "supportPage": "Pàgina de suport", + "serverInformation": "Informació del servidor:", + "name": "Nom", + "boldText": "Text en negreta", + "italicText": "Text en cursiva", + "contentNotificationSettings": "Opcions de notificació de continguts", + "roomNotificationSettings": "Opcions de notificacions de sales", + "notificationRuleContainsUserName": "Conté el nom d'usuàriï", + "notificationRuleContainsUserNameDescription": "Notifica l'usuàriï quan un missatge contingui el seu nom.", + "notificationRuleMaster": "Silencia totes les notificacions", + "notificationRuleSuppressNotices": "Elimina els missatges automàtics", + "notificationRuleInviteForMe": "Invitació per a mi", + "notificationRuleInviteForMeDescription": "Notifica l'usuàriï quan és convidadi a una sala.", + "notificationRuleMemberEventDescription": "Ignora les notificacions quan entra o surt algú d'una sala.", + "notificationRuleIsUserMention": "Mencions", + "notificationRuleContainsDisplayName": "Conté el nom visible", + "notificationRuleIsRoomMention": "Menció de sala", + "notificationRuleIsRoomMentionDescription": "Notifica l'usuàriï quan es s'esmenti la sala.", + "notificationRuleRoomnotifDescription": "Notifica l'usuàriï quan un missatge contingui '@room'.", + "notificationRuleTombstone": "Làpida", + "notificationRuleTombstoneDescription": "Notifica l'usuàriï dels missatges de desactivació de sales.", + "notificationRuleReaction": "Reacció", + "notificationRuleReactionDescription": "Ignora les notificacions sobre reaccions.", + "notificationRuleRoomServerAcl": "Regles ACL del servidor d'una sala", + "notificationRuleRoomServerAclDescription": "Ignora les notificacions sobre les regles d'accés (ACL) del servidor d'una sala.", + "notificationRuleSuppressEdits": "Elimina les edicions", + "notificationRuleSuppressEditsDescription": "Ignora les notificacions per missatges editats.", + "notificationRuleCall": "Trucada", + "notificationRuleCallDescription": "Notifica l'usuàriï de trucades.", + "notificationRuleEncryptedRoomOneToOneDescription": "Notifica l'usuàriï de missatges en sales xifrades un a un, converses de dues persones.", + "notificationRuleEncryptedRoomOneToOne": "Converses xifrades", + "notificationRuleRoomOneToOne": "Converses", + "notificationRuleMessageDescription": "Notifica l'usuàriï sobre missatges generals.", + "notificationRuleEncrypted": "Xifrat", + "notificationRuleEncryptedDescription": "Notifica l'usuàriï de missatges en sales xifrades.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleServerAcl": "Ignora canvis en ACL de servidor", + "unknownPushRule": "No es coneix la regla push '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "more": "Més", + "notificationRuleSuppressNoticesDescription": "No envia notificacions relacionades amb usuàriïs automàtics com els bots.", + "otherNotificationSettings": "Altres opcions de notificacions", + "notificationRuleIsUserMentionDescription": "Notifica quan mencionin l'usuàriï en un missatge.", + "notificationRuleContainsDisplayNameDescription": "Notifica l'usuàriï quan un missatge contingui el seu nom per mostrar.", + "notificationRuleJitsiDescription": "Notifica l'usuàriï sobre activitat del giny de Jitsi.", + "notificationRuleRoomnotif": "Notificació de sala", + "deletePushRuleCanNotBeUndone": "Si esborres aquesta opció de notificació no ho podràs tornar a canviar.", + "notificationRuleRoomOneToOneDescription": "Notifica l'usuàriï de missatges en converses de dues persones, sales un a un.", + "notificationRuleMemberEvent": "Canvis de membres", + "otherPartyNotLoggedIn": "L'altra persona no està en línia ara mateix i per tant no pot rebre missatges!", + "userSpecificNotificationSettings": "Opcions de notificacions d'usuàriï", + "generalNotificationSettings": "Opcions de notificacions generals", + "notificationRuleMessage": "Missatge", + "notificationRuleServerAclDescription": "Ignora les notificacions per canvis en les regles d'accés (ACL) de servidor.", + "shareKeysWithDescription": "Quins dispositius vols que puguin llegir els teus missatges xifrats?", + "previous": "Anterior", + "notificationRuleMasterDescription": "Ignora totes les altres regles i deshabilita totes les notificacions.", + "newChatRequest": "📩 Soŀlicitud de missatge", + "allDevices": "Tots els dispositius", + "crossVerifiedDevices": "Els dispositius verificats mútuament", + "verifiedDevicesOnly": "Només els dispositius verificats", + "synchronizingPleaseWaitCounter": " S'està sincronitzant... ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "appWantsToUseForLogin": "Fes servir '{server}' per iniciar sessió", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Consenteixes que l'app i la web comparteixen informació sobre tu.", + "open": "Obre", + "appIntroduction": "El FluffyChat et permet xatejar amb amiguis entre diverses aplicacions. Llegeix-ne més a https://matrix.org o pica \"Continua\".", + "waitingForServer": "S'està esperant el servidor...", + "shareKeysWith": "Comparteix les claus amb...", + "crossVerifiedDevicesIfEnabled": "Els dispositius verificats mútuament, si està activat", + "commandHint_roomupgrade": "Actualitza aquesta sala a la versió indicada", + "takeAPhoto": "Fes una foto", + "recordAVideo": "Grava un vídeo", + "optionalMessage": "(Opcional) missatge...", + "enterNewChat": "Entra al nou xat", + "notSupportedOnThisDevice": "No suportat en aquest dispositiu", + "setCustomPermissionLevel": "Afegeix un nivell de permisos personalitzat", + "setPermissionsLevelDescription": "Tria un role predefinit o bé introdueix un nivell de permís personalitzat d'entre 0 i 100.", + "ignoreUser": "Ignora l'usuàriï", + "normalUser": "Usuàriï normal", + "changedTheChatDescription": "{username} ha canviat la descripció del xat", + "changedTheChatName": "{username} ha canviat el nom del xat", + "checkList": "Llista de tasques", + "countInvited": "{count} convidadis", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Missatge de veu de {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "approve": "Aprova", + "youHaveKnocked": "T'han picat a la porta", + "pleaseWaitUntilInvited": "Ara espera fins que algú de la sala t'hi deixi entrar.", + "commandHint_logout": "Tanca la sessió per aquest dispositiu", + "commandHint_logoutall": "Tanca totes les sessions actives", + "displayNavigationRail": "Mostra la barra de navegació al mòbil", + "customReaction": "Reacció personalitzada", + "moreEvents": "Altres esdeveniments", + "declineInvitation": "Rebutja la invitació", + "noMessagesYet": "No hi ha cap missatge", + "longPressToRecordVoiceMessage": "Deixa picat per gravar un missatge de veu.", + "pause": "Pausa", + "resume": "Continua", + "newSubSpace": "Crea un sub-espai", + "moveToDifferentSpace": "Mou-lo a un altre espai", + "moveUp": "Mou-lo amunt", + "moveDown": "Mou-lo avall", + "removeFromSpaceDescription": "S'esborrarà de l'espai el xat, però encara apareixerà a la llista de xats.", + "countChats": "{chats} xats", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Membre dels espais {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Membre dels espais {spaces} poden picar a porta", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Dona", + "startedAPoll": "{username} ha creat una enquesta.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Enquesta", + "startPoll": "Comença una enquesta", + "endPoll": "Acaba l'enquesta", + "answersVisible": "Respostes visibles", + "answersHidden": "Respostes amagades", + "pollQuestion": "Pregunta de l'enquesta", + "answerOption": "Opció de resposta", + "addAnswerOption": "Afegeix una opció", + "allowMultipleAnswers": "Permet múltiples respostes", + "pollHasBeenEnded": "Ha acabat l'enquesta", + "countVotes": "{count, plural, =1{Un vot} other{{count} vots}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Les respostes seran visibles quan s'acabi l'enquesta", + "replyInThread": "Respon en un fil", + "countReplies": "{count, plural, =1{Una resposta} other{{count} respostes}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Fil", + "backToMainChat": "Torna al xat principal", + "saveChanges": "Desa els canvis", + "createSticker": "Crea un sticker o un emoji", + "useAsSticker": "Agafa com a sticker", + "useAsEmoji": "Agafa com a emoji", + "stickerPackNameAlreadyExists": "Ja existeix aquest nom per un pack de stickers", + "newStickerPack": "Nou pack de stickers", + "stickerPackName": "Nom del pack de stickers", + "attribution": "Atribució", + "skipChatBackup": "Omet la còpia de seguretat del xat", + "skipChatBackupWarning": "N'estàs seguri? Si no actives la còpia de seguretat pots perdre accés als teus missatges si canvies de dispositiu.", + "loadingMessages": "S'estan carregant més missatges", + "setupChatBackup": "Activa la còpia de seguretat del xat", + "noMoreResultsFound": "No s'han trobat més resultats", + "chatSearchedUntil": "S'ha cercat fins a {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "URL base de federació", + "clientWellKnownInformation": "Informació de", + "baseUrl": "URL base", + "identityServer": "Servidor d'identitats:", + "versionWithNumber": "Versió: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Registres", + "advancedConfigs": "Avançat", + "advancedConfigurations": "Configuracions avançades", + "signIn": "Obre sessió", + "createNewAccount": "Crea un compte nou", + "signUpGreeting": "El FluffyChat és descentralitzat! Tria un servidor on vulguis crear-t'hi un compte, i som-hi!", + "signInGreeting": "Si ja tens un compte a Matrix, benvingudi! Tria el teu servidor i inicia-hi sessió.", + "appIntro": "Pots xatejar amb lis tevis amiguis amb Fluffychat. És una app de missatgeria [matrix] descentralitzada! Llegeix-ne més a https://matrix.org si vols, o inicia sessió.", + "theProcessWasCanceled": "S'ha canceŀlat el procés." +} diff --git a/lib/l10n/intl_cs.arb b/lib/l10n/intl_cs.arb new file mode 100644 index 000000000..4b4660a1b --- /dev/null +++ b/lib/l10n/intl_cs.arb @@ -0,0 +1,2997 @@ +{ + "@@locale": "cs", + "@@last_modified": "2021-08-14 12:41:10.131133", + "about": "O aplikaci", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Přijmout", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} přijal/a pozvání", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Účet", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} aktivoval/a koncové šifrování", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Přidat e-mail", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Správce", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Vše", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Všechny chaty", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} odpověděl na hovor", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Kdokoliv se může připojit", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Zámek aplikace", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Archivovat", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Mohou se připojit hosté", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Jste si jistý?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Opravdu se chcete odhlásit?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Pro ověření této osoby zadejte prosím přístupovou frázi k „bezpečnému úložišti“ anebo „klíč pro obnovu“.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Přijmout žádost o ověření od {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Automaticky přehrajte animované nálepky a emoce", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "Homeserver podporuje přihlášení typu:\n{serverVersions}\nAle tato aplikace podporuje pouze:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "Homeserver podporuje specifikaci verzí:\n{serverVersions}\nAle tato aplikace podporuje pouze verze {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Zakázat chat", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Zakázán", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} zakázal {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blokovat zařízení", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Zakázán", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Zprávy od bota", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Zrušit", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Nelze otevřít URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Změnit název zařízení", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} změnil avatar chatu", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} změnil/a popis konverzace na: „{description}“", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} změnil/a název konverzace na: „{chatname}“", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} změnili nastavení oprávnění v chatu", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} změnil/a svoji přezdívku na: „{displayname}“", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} změnili přístupová práva pro hosty", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} změnili přístupová práva pro hosty na: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} změnili nastavení viditelnosti historie diskuze", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} změnili nastavení viditelnosti historie diskuze na: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} změnili nastavení pravidel připojení", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} změnili nastavení pravidel připojení na: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} změnili svůj avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} změnili nastavení aliasů místnosti", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} změnili odkaz k pozvání do místnosti", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Změnit heslo", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Změnit domovský server", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Změňte svůj styl", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Změnit název skupiny", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Změňte svůj avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Šifrování bylo poškozeno", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Záloha chatu", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Vaše zprávy jsou zabezpečeny bezpečnostním klíčem. Ujistěte se, prosím, že klíč neztratíte.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Bližší údaje o chatu", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Chaty", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Vyberte silné heslo", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Vymazat archiv", + "close": "Zavřít", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Zakázat danému uživateli přístup do této místnosti", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Odeslat text ve formátu HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Pozvěte daného uživatele do této místnosti", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Připojte se k dané místnosti", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Odeberte daného uživatele z této místnosti", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Opusťte tuto místnost", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Představ se", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Nastavte si obrázek pro tuto místnost (autor mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Nastavte si váš zobrazovaný název pro tuto místnost", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Nastavit úroveň práv daného uživatele (výchozí: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Odeslat neformátovaný text", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Odeslat odpověď jako reakci", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Poslat zprávu", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Zrušte zákaz přístupu daného uživatele do této místnosti", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Příkaz je neplatný", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} není příkaz.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Porovnejte a přesvědčete se, že následující emotikony se shodují na obou zařízeních", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Porovnejte a přesvědčete se, že následující čísla se shodují na obou zařízeních", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Nastavení chatu", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Potvrdit", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Připojit", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt byl pozván do skupiny", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Obsahuje zobrazovaný název", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Obsahuje uživatelské jméno", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Obsah byl nahlášen správcům serveru", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Zkopírováno do schránky", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopírovat", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Zkopírovat do schránky", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Nebylo možné dešifrovat zprávu: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} účastníků", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Vytvořit", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} založil/a chat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Nový prostor", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Aktuálně aktivní", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Tmavé", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}.{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}. {month}. {year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Tímto krokem se deaktivuje váš uživatelský účet. Akci nelze vrátit zpět! Jste si jistí?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Výchozí úroveň oprávnění nových uživatelů", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Smazat", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Smazat účet", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Smazat zprávu", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Zařízení", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID zařízení", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Zařízení", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Přímé chatování", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Přezdívka byla změněna", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Stáhnout soubor", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Upravit", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Upravit zakázané servery", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Změnit přezdívku", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Upravit aliasy místností", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Upravit avatara místnosti", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emotikona již existuje!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Neplatný kód emotikony!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Balíček emotikonů pro místnost", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Nastavení emotikonů", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Klávesová zkratka emotikonu", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Musíte si vybrat klávesovou zkratku emotikonu a obrázek!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Prázdný chat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Povolit balíček emotikon všude", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Povolit šifrování", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Šifrování již nebude možné vypnout. Jste si tím jisti?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Šifrováno", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Šifrování", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Šifrování není aktivní", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} ukončil hovor", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Zadejte e-mailovou adresu", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Zadejte svůj domovský server", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Chyba při získávání polohy: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Vše připraveno!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extrémně urážlivé", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Název souboru", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Velikost písma", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Přeposlat", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Od vstupu", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Od pozvání", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Přejít do nové místnost", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Skupina", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Skupina je veřejná", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Skupiny", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Skupina s {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Hosté jsou zakázáni", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Hosté se mohou připojit", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} stáhl pozvánku pro {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Pomoc", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Skrýt redigované události", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Skrýt neznámé události", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Jak urážlivý je tento obsah?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identita", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorovat", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Ignorovaní uživatelé", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Klikl jsem na odkaz", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Nesprávné přístupové heslo anebo klíč pro obnovu", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Neškodný", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Pozvat kontakt", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Pozvat kontakt do {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Pozvaný", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} pozval/a {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Pouze pozvaní uživatelé", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Pozvěte mě", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} vás pozval/a na FluffyChat.\n1. Navštivte fluffychat.im a nainstalujte si aplikaci.\n2. Zaregistrujte se nebo se přihlaste.\n3. Otevřte pozvánku: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "píše…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} se připojil/a do konverzace", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Připojte se k místnosti", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} vyhodil/a {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "{username} vyhodil/a a zabanoval/a {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Vyhodit z chatu", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Naposledy aktivní: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Opustit", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Opustil chat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licence", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Světlé", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Načíst dalších {count} účastníků", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Načítání… Prosíme vyčkejte.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Načíst další…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Služby určování polohy jsou deaktivovány. Povolte jim, aby mohli sdílet vaši polohu.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Oprávnění k poloze odepřeno. Udělte jim prosím možnost sdílet vaši polohu.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Přihlásit se", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Přihlášení k {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Odhlásit", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Změny členů", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Zmínit se", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Zprávy", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderátor", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Ztlumit chat", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Prosím vezměte na vědomí, že pro použití koncového šifrování je prozatím potřeba použít Pantalaimon.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Nový chat", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nová zpráva ve FluffyChatu", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nová žádost o ověření!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Další", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Ne", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Žádné připojení k serveru", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Nebyly nalezeny žádné emotikony. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Můžete aktivovat šifrování jakmile místnost přestane být veřejně dostupná.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Zdá se, že služba Firebase Cloud Messaging není ve vašem zařízení k dispozici. Chcete-li i nadále přijímat push oznámení, doporučujeme nainstalovat ntfy. Pomocí ntfy nebo jiného poskytovatele Unified Push můžete přijímat oznámení push zabezpečeným způsobem přenosu dat. Aplikaci ntfy si můžete stáhnout z obchodu PlayStore nebo z webu F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} není matrixový server, použít místo toho server {server2}?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "none": "Žádný", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Dosud jste nepřidali způsob, jak obnovit své heslo.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Chybí oprávnění", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Nebyly nalezeny žádné místnosti…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Oznámení", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Oznámení povolena pro tento účet", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} uživatelé píší…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Získávání polohy…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Urážlivé", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Odpojeni", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Připojeni", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Online záloha kíčů je zapnuta", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Jejda! Při nastavování oznámení push došlo bohužel k chybě.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Jejda, něco se pokazilo…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Otevřete aplikaci pro přečtení zpráv", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Otevřít fotoaparát", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Otevřít v mapách", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Nebo", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Účastník", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "heslo nebo klíč pro obnovení", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Heslo", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Zapomenuté heslo", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Heslo bylo změněno", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Obnova hesla", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Lidé", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Zvolit obrázek", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Připnout zprávu", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Přehrát {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Prosím vyberte si", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Vyberte přístupový kód", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Klikněte na odkaz v e-mailu a pokračujte.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Chcete-li deaktivovat zámek aplikace, zadejte 4 číslice nebo nechte prázdné.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Zadejte prosím své heslo", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Zadejte svůj PIN", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Zadejte prosím své uživatelské jméno", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Postupujte podle pokynů na webu a klepněte na další.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Soukromí", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Veřejné místnosti", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Pravidla push", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Důvod", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Nahrávání", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} opravili událost", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Redigovat zprávu", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Registrovat", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Zamítnout", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} odmítli pozvání", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Znovu se připojte", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Odstranit", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Odstranit všechna další zařízení", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Odstraněno {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Odstraňit zařízení", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Zrušit zákaz chatu", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Odstraňte svého avatara", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Nahradit místnost novou verzí", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Odpovědět", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Nahlásit zprávu", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Vyžádat oprávnění", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Místnost byla upgradována", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Verze místnosti", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Uložit soubor", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Hledat", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Bezpečnostní", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Viděno uživatelem {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Odeslat", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Odeslat zprávu", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Odeslat jako text", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Odeslat audio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Odeslat soubor", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Odeslat obrázek", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Odeslat zprávy", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Odeslat originál", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Odeslat nálepku", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Odeslat video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "{username} poslali soubor", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "{username} poslali zvukovou nahrávku", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "{username} poslali obrázek", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "{username} poslali samolepku", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "{username} poslali video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} odeslal informace o hovoru", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Nastavit jako hlavní alias", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Nastavit vlastní emotikony", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Nastavit zvací odkaz", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Nastavit úroveň oprávnění", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Nastavit stav", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Nastavení", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Sdílet", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} sdílel jejich polohu", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Sdílet polohu", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Zobrazit heslo", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Jedinečné přihlášení", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Přeskočit", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Zdrojové kódy", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Prostor je veřejný", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Název prostoru", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} zahájil hovor", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Stav", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Jak se dneska máš?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Odeslat", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synchronizace ... Čekejte prosím.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Téma systému", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Neshodují se", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Shodují se", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Přepnout Oblíbené", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Přepnout ztlumené", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Označit jako přečtené/nepřečtené", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Příliš mnoho požadavků. Prosím zkuste to znovu později!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Přenos z jiného zařízení", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Zkuste odeslat znovu", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Nedostupní", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} zrušili zákaz pro {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Odblokovat zařízení", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Neznámé zařízení", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Neznámý šifrovací algoritmus", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Neznámá událost „{type}“", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Zrušit ztlumení chatu", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Odepnout zprávu", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 nepřečtený chat} other{{unreadCount} nepřečtené chaty}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} a {count} dalších píší…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} a {username2} píší…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} píše…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "{username} opustili chat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Uživatelské jméno", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} poslali událost {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Ověřeno", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Ověřit", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Zahájit ověření", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Ověření proběhlo úspěšně!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Ověřuji druhý účet", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Video hovor", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Viditelnost historie chatu", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Viditelné pro všechny účastnící se", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Viditelné pro všechny", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Hlasová zpráva", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Čeká se na potvrzení žádosti partnerem…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Čeká se na potvrzení emoji partnerem…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Čekání na partnera až přijme čísla…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Pozadí:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Varování!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Zaslali jsme vám e-mail", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Kdo může provést jakou akci", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Kdo se může připojit do této skupiny", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Proč to chcete nahlásit?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Chcete vymazat zálohu chatu a vytvořit nový bezpečnostní klíč?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "S těmito adresami můžete obnovit své heslo.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Napište zprávu…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Ano", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Vy", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Tohoto chatu se nadále neúčastníte", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Byl vám zablokován přístup k tomuto chatu", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Váš veřejný klíč", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Do tohoto prostoru byl přidán chat", + "addToSpace": "Přidat do prostoru", + "scanQrCode": "Naskenujte QR kód", + "sendOnEnter": "Odeslat při vstupu", + "homeserver": "Domácí server", + "serverRequiresEmail": "Tento server potřebuje k registraci ověřit vaši e -mailovou adresu.", + "addToBundle": "Přidat do balíčku", + "addAccount": "Přidat účet", + "bundleName": "Název balíčku", + "link": "Odkaz", + "yourChatBackupHasBeenSetUp": "Vaše záloha chatu byla nastavena.", + "editBundlesForAccount": "Upravit balíčky pro tento účet", + "enableMultiAccounts": "(BETA) Na tomto zařízení povolte více účtů", + "oneClientLoggedOut": "Jeden z vašich klientů byl odhlášen", + "removeFromBundle": "Odstranit z tohoto balíčku", + "unverified": "Neověřeno", + "messageInfo": "Informace o zprávě", + "time": "Čas", + "messageType": "Typ zprávy", + "sender": "Odesílatel", + "repeatPassword": "Zopakujte heslo", + "openGallery": "Otevřít galerii", + "addToSpaceDescription": "Vyberte umístění, do kterého chcete tento chat přidat.", + "start": "Start", + "removeFromSpace": "Odstranit z tohoto místa", + "commandHint_clearcache": "Vymazat mezipamět", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_discardsession": "Zahodit relaci", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Zahajte přímý chat\nK deaktivaci šifrování použijte --no-encryption", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_create": "Vytvořte prázdný skupinový chat\n K deaktivaci šifrování použijte --no-encryption", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "openVideoCamera": "Otevřete fotoaparát pro video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "publish": "Uveřejnit", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "markAsRead": "Označit jako přečtené", + "reportUser": "Nahlásit uživatele", + "openChat": "Otevřete chat", + "dismiss": "Zavrhnout", + "reactedWith": "{sender} reagoval s {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "emojis": "Emojis", + "voiceCall": "Hlasový hovor", + "unsupportedAndroidVersion": "Nepodporovaná verze Androidu", + "videoCallsBetaWarning": "Upozorňujeme, že videohovory jsou aktuálně ve verzi beta. Nemusí fungovat podle očekávání nebo fungovat vůbec na všech platformách.", + "placeCall": "Zavolejte", + "emailOrUsername": "E-mail nebo uživatelské jméno", + "experimentalVideoCalls": "Experimentální videohovory", + "unsupportedAndroidVersionLong": "Tato funkce vyžaduje novější verzi Android. Zkontrolujte prosím aktualizace nebo podporu Lineage OS.", + "pinMessage": "Připnout zprávu do místnosti", + "confirmEventUnpin": "Opravdu chcete událost trvale odepnout?", + "separateChatTypes": "Odděĺlit přímé chaty, skupiny a prostory", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youKicked": "Vykopli jste uživatele {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "switchToAccount": "Přepnout na účet {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "previousAccount": "Předchozí účet", + "widgetJitsi": "Jitsi Meet", + "youAcceptedTheInvitation": "Přijal jsi pozvání", + "youJoinedTheChat": "Připojili jste se k chatu", + "youInvitedBy": "Byli jste pozváni uživatelem {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "nextAccount": "Další účet", + "addWidget": "Přidat widget", + "widgetVideo": "Video", + "widgetEtherpad": "Textová poznámka", + "widgetName": "Jméno", + "youBannedUser": "Zakázali jste uživatele {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "Pozvali jste uživatele {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "Vykopli jste a zakázali jste uživatele {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Zrušili jste zákaz uživateli {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "widgetCustom": "Vlastní", + "youRejectedTheInvitation": "Odmítli jste pozvání", + "youHaveWithdrawnTheInvitationFor": "Stáhli jste pozvánku pro uživatele {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "widgetUrlError": "Toto není platná adresa URL.", + "widgetNameError": "Zadejte jméno pro zobrazení.", + "errorAddingWidget": "Chyba při přidávání widgetu.", + "disableEncryptionWarning": "Z bezpečnostních důvodů nemůžete vypnout šifrování v chatu, kde již bylo dříve zapnuto.", + "confirmMatrixId": "Pro smazání svého účtu potvrďte, prosím, své Matrix ID.", + "commandHint_googly": "Poslat kroutící se očička", + "commandHint_cuddle": "Poslat mazlení", + "commandHint_hug": "Poslat obejmutí", + "hugContent": "{senderName} vás objímá", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "googlyEyesContent": "{senderName} vám posílá kroutící se očička", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} se s vámi mazlí", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "notAnImage": "Není obrázek.", + "importNow": "Importovat nyní", + "redactedByBecause": "Smazáno uživatelem {username} s důvodem: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "storeInAndroidKeystore": "Uložit v Android KeyStore", + "dehydrateTorLong": "Uživatelům TOR se doporučuje exportovat relaci před zavřením okna.", + "numChats": "{number} konverzací", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "dehydrate": "Exportovat relaci a promazat zařízení", + "newGroup": "Nová skupina", + "hydrateTor": "TOR uživatelé: Import exportovanou relaci", + "doNotShowAgain": "Nezobrazovat znovu", + "commandHint_markasdm": "Označit jako místnost přímé konverzace s daným Matrix ID", + "recoveryKey": "Klíč k obnovení", + "hydrateTorLong": "Exportovali jste vaši poslední relaci na TOR? Rychle ji importujte a pokračujte v konverzaci.", + "hydrate": "Obnovit ze souboru zálohy", + "pleaseEnterRecoveryKey": "Prosím vložte váš klíč pro obnovení:", + "createGroup": "Vytvořit skupinu", + "shareInviteLink": "Sdílet pozvánku", + "pleaseEnterRecoveryKeyDescription": "K odemknutí vašich starých zpráv prosím vložte váš klíč k obnovení vygenerovaný v předchozím sezení. Váš klíč k obnovení NENÍ vaše heslo.", + "setColorTheme": "Nastavit barvy:", + "importEmojis": "Importovat emodži", + "importFromZipFile": "Importovat ze .zip souboru", + "exportEmotePack": "Exportovat emodži jako .zip", + "replace": "Nahradit", + "users": "Uživatelé", + "storeInAppleKeyChain": "Uložit v Apple KeyChain", + "jumpToLastReadMessage": "Skočit na naposledy přečtenou zprávu", + "signInWithPassword": "Přihlásit se pomocí hesla", + "redactedBy": "Smazáno uživatelem {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "inviteContactToGroupQuestion": "Chcete pozvat {contact} do konverzace \"{groupName}\"?", + "dehydrateTor": "TOR uživatelé: Export relace", + "tryAgain": "Zkuste to znovu", + "redactMessageDescription": "Tato zpráva bude smazána pro všechny účastníky konverzace. Tuto akci nelze vzít zpět.", + "optionalRedactReason": "(Nepovinné) Důvod smazání této zprávy…", + "messagesStyle": "Zprávy:", + "allSpaces": "Všechny prostory", + "noOtherDevicesFound": "Žádná ostatní zařízení nebyla nalezena", + "addChatDescription": "Přidat popis konverzace...", + "chatDescription": "Popis konverzace", + "chatDescriptionHasBeenChanged": "Popis konverzace byl změněn", + "noChatDescriptionYet": "Zatím nebyl vytvořen žádný popis konverzace.", + "invalidServerName": "Neplatné jméno serveru", + "chatPermissions": "Oprávnění konverzace", + "directChat": "Přímá konverzace", + "setChatDescription": "Nastavit popis konverzace", + "startFirstChat": "Začněte svou první konverzaci", + "callingPermissions": "Oprávnění volání", + "whyIsThisMessageEncrypted": "Proč nelze přečíst tuto zprávu?", + "wasDirectChatDisplayName": "Prázdná konverzace (dříve {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "newSpaceDescription": "Prostory umožňují organizovat Vaše konverzace a vytvářet soukromé nebo veřejné komunity.", + "profileNotFound": "Uživatel nebyl na serveru nalezen. Možná je problém s připojením nebo uživatel neexistuje.", + "setTheme": "Nastavit vzhled:", + "sendTypingNotifications": "Posílat oznámení o psaní", + "commandHint_markasgroup": "Označit jako skupinu", + "allRooms": "Všechny skupinové konverzace", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "recoveryKeyLost": "Ztracený klíč k obnovení?", + "unlockOldMessages": "Odemknout staré zprávy", + "foregroundServiceRunning": "Toto oznámení se zobrazuje když běží služba na pozadí.", + "screenSharingDetail": "Sdílíte svou obrazovku přes FluffyChat", + "callingAccountDetails": "Opravňuje FluffyChat používat Android systémovou aplikaci pro vytáčení.", + "appearOnTop": "Zobrazovat nahoře", + "otherCallingPermissions": "Mikrofon, kamera a ostatní oprávnění FluffyChat", + "encryptThisChat": "Zašifrovat tuto konverzaci", + "sorryThatsNotPossible": "Omlouváme se… to není možné", + "deviceKeys": "Klíče zařízení:", + "reopenChat": "Znovu otevřít konverzaci", + "fileIsTooBigForServer": "Neodesláno! Server povoluje maximálně {max} příloh.", + "jump": "Skočit", + "openLinkInBrowser": "Otevřít odkaz v prohlížeči", + "pleaseTryAgainLaterOrChooseDifferentServer": "Prosím zkuste to znovu nebo si vyberte jiný server.", + "signInWith": "Přihlásit se pomocí {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "supposedMxid": "Tady by mělo být {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "newSpace": "Nový prostor", + "screenSharingTitle": "sdílení obrazovky", + "user": "Uživatel", + "fileHasBeenSavedAt": "Soubor uložen do {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "custom": "Vlastní", + "dehydrateWarning": "Tuto akci nelze vzít zpět. Ujistěte se, že máte bezpečně uložený soubor zálohy.", + "storeInSecureStorageDescription": "Klíč k obnovení uložte v zabezpečeném úložišti tohoto zařízení.", + "saveKeyManuallyDescription": "Uložte tento klíč manuálně pomocí systémového dialogu sdílení nebo zkopírováním do schránky.", + "storeSecurlyOnThisDevice": "Uložit bezpečně na tomto zařízení", + "countFiles": "{count} souborů", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "emoteKeyboardNoRecents": "Naposledy použité emodži se zobrazí zde...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "Zamknout aplikaci pomocí PIN kódu když není používána", + "globalChatId": "Globální ID chatu", + "accessAndVisibility": "Přístup a viditelnost", + "calls": "Volání", + "customEmojisAndStickers": "Vlastní emodži a nálepky", + "accessAndVisibilityDescription": "Kdo se může připojit a najít tuto konverzaci.", + "customEmojisAndStickersBody": "Přidat nebo sdílet vlastní emodži či nálepky, které lze použít v konverzaci.", + "swipeRightToLeftToReply": "Potáhnutím zprava doleva odpovědět na zprávu", + "countChatsAndCountParticipants": "{chats} konverzaci a {participants} účastníci", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Žádné další konverzace nalezeny...", + "hideRedactedMessages": "Skrýt upravené zprávy", + "hideRedactedMessagesBody": "Pokud někdo zprávu zrediguje, nebude tato zpráva v chatu již viditelná.", + "hideInvalidOrUnknownMessageFormats": "Skrýt nesprávné nebo neznámé formáty zpráv", + "blockUsername": "Ignorovat uživatelské jméno", + "hideMemberChangesInPublicChats": "Skrýt změny členů ve veřejných chatech", + "hideMemberChangesInPublicChatsBody": "Nezobrazovat na časové ose chatu, pokud se někdo připojí nebo opustí veřejný chat, aby se zlepšila čitelnost.", + "overview": "Přehled", + "notifyMeFor": "Upozorněte mě na", + "passwordRecoverySettings": "Nastavení obnovení hesla", + "presenceStyle": "Dostupnost:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "block": "Zablokovat", + "indexedDbErrorLong": "Ukládání zpráv bohužel není ve výchozím nastavení v soukromém režimu povoleno.\nNavštivte prosím\n - about:config\n - nastavte dom.indexedDB.privateBrowsing.enabled na true\nV opačném případě nebude možné FluffyChat spustit.", + "youInvitedToBy": "📩 Prostřednictvím odkazu jste byli pozváni na:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "indexedDbErrorTitle": "Problémy privátního prostředí", + "blockListDescription": "Můžete blokovat uživatele, kteří vás obtěžují. Od uživatelů na vašem osobním seznamu blokovaných uživatelů nebudete moci přijímat žádné zprávy ani pozvánky do místnosti.", + "blockedUsers": "Zablokování uživatelé", + "alwaysUse24HourFormat": "Vypnuto", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "noChatsFoundHere": "Nejsou zde žádné konverzace. Začněte novou konverzaci s někým pomocí tlačítka níže. ⤵️", + "joinedChats": "Připojené chaty", + "unread": "Nepřečtené", + "space": "Prostor", + "spaces": "Prostory", + "presencesToggle": "Zobrazení stavových zpráv od jiných uživatelů", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "aboutHomeserver": "O {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "ignoreUser": "Ignorovat uživatele", + "normalUser": "Normalní uživatel", + "countInvited": "{count} pozváno", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "invitedBy": "📩 Pozván {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hasKnocked": "🚪 {user} zaklepal", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Uživatelé musí zaklepat", + "setCustomPermissionLevel": "Nastavit vlastní úroveň oprávnění", + "changedTheChatDescription": "{username} změnil/a popis konverzace", + "changedTheChatName": "{username} změnil/a název konverzace", + "checkList": "Kontrolní seznam", + "knock": "Zaklepat", + "userWouldLikeToChangeTheChat": "{user} požádal/a o přidání do konverzace.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "enterSpace": "Vstoupit do prostoru", + "enterRoom": "Vstoupit do místnosti", + "hideUnimportantStateEvents": "Skrýt nedůležité stavové události", + "hidePresences": "Skrýt seznam událostí?", + "noBackupWarning": "Pozor! Bez povolení zálohování konverzací ztratíte přístup k zašifrovaným zprávám. Důrazně doporučujeme zálohování konverzací před odhlášením povolit.", + "readUpToHere": "Čtěte až sem", + "reportErrorDescription": "😭 Ale ne, něco se porouchalo. Pokud chcete, můžete tento bug nahlásit vývojářům.", + "report": "hlášení", + "invite": "Pozvánka", + "inviteGroupChat": "📨 Skupinová pozvánka", + "invitePrivateChat": "📨 Soukromá pozvánka", + "appearOnTopDetails": "Umožňuje zobrazit aplikaci nahoře (není nutné, pokud již máte Fluffychat nastaven jako účet volajícího)", + "noKeyForThisMessage": "K tomuto může dojít, pokud byla zpráva odeslána před přihlášením k účtu v tomto zařízení.\n\nJe také možné, že odesílatel zablokoval vaše zařízení nebo se něco pokazilo s internetovým připojením.\n\nJste schopni si zprávu přečíst v jiné relaci? Pak můžete zprávu přenést z něj! Přejděte do Nastavení > Zařízení a zkontrolujte, zda se Vaše zařízení vzájemně ověřila. Při příštím otevření místnosti, kdy budou obě relace v popředí, se klíče přenesou automaticky.\n\nNechcete klíče ztratit při odhlašování nebo přepínání zařízení? Ujistěte se, že jste v nastaveních povolili zálohování konverzací.", + "invalidInput": "Nevhodný vstup!", + "wrongPinEntered": "Nespravný PIN! Zkuste to znovu za {seconds} vteřin...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pleaseEnterANumber": "Prosím, zadejte číslo větší než 0", + "archiveRoomDescription": "Konverzace bude přesunuta do archivu. Ostatní uživatelé uvidí, že jste konverzaci opustil/a.", + "roomUpgradeDescription": "Konverzace bude vytvořena znovu s novou verzí místnosti. Všem účastníkům bude oznámeno, že se musí přesunout do nové konverzace. Více o verzích místností se dočtete na https://spec.matrix.org/latest/", + "removeDevicesDescription": "Budete odhlášen/a z tohoto zařízení a nebudete nadále moci přijímat zprávy.", + "banUserDescription": "Uživatel bude vyhozen z konverzace a nebude se moci znovu připojit dokud nebude odblokován.", + "unbanUserDescription": "Uživatel se bude moci vrátit do konverzace pokud se o to pokusí.", + "makeAdminDescription": "Jestliže tohoto uživatele povýšíte na administrátora, nebude tak moci odčinit, protože bude mít stejná oprávnění jako Vy.", + "pushNotificationsNotAvailable": "Notifikace nejsou dostupné", + "learnMore": "Dozvědět se více", + "yourGlobalUserIdIs": "Vaše globální uživatelské ID (user-ID) je: ", + "knocking": "Klepání", + "chatCanBeDiscoveredViaSearchOnServer": "Konverzaci naleznete vyhledáváním na {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchChatsRooms": "Vyhledat #konverzace, @uživatele...", + "nothingFound": "Nic nenalezeno...", + "groupName": "Název skupiny", + "createGroupAndInviteUsers": "Vytvořit skupinu a pozvat uživatele", + "groupCanBeFoundViaSearch": "Skupinu naleznete vyhledávním", + "startConversation": "Začít konverzaci", + "commandHint_sendraw": "Odeslat soubor json", + "databaseMigrationTitle": "Databáze je optimalizována", + "databaseMigrationBody": "Vydržte prosím. Bude to chvilku trvat.", + "leaveEmptyToClearStatus": "Zanechte prázdné pro smazání statusu.", + "select": "Vybrat", + "searchForUsers": "Vyhledat @uživatele...", + "pleaseEnterYourCurrentPassword": "Prosím, zadejte Vaše současné heslo", + "newPassword": "Nové heslo", + "pleaseChooseAStrongPassword": "Prosím, zvolte si silné heslo", + "passwordsDoNotMatch": "Hesla se neshodují", + "passwordIsWrong": "Zadané heslo je nesprávné", + "publicLink": "Veřejný odkaz", + "publicChatAddresses": "Adresy veřejných konverzací", + "createNewAddress": "Vytvořit novou adresu", + "thisDevice": "Toto zařzení:", + "setPermissionsLevelDescription": "Zvolte, prosím, níže roli, nebo zadejte vlastní úroveň oprávnění mezi 0 a 100.", + "synchronizingPleaseWaitCounter": " Synchronizuji… ({percentage} %)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "noOneCanJoin": "Nikdo se nemůže připojit", + "noPublicLinkHasBeenCreatedYet": "Zatím nebyl vytvořen žádný veřejný odkaz", + "kickUserDescription": "Uživatel bude vyhozen z chatu, ale nikoliv zabanován. V případě veřejných chatů to znamená, že se kdykoliv může znovu připojit.", + "noUsersFoundWithQuery": "Nepodařilo se najít uživatele \"{query}\". Zkontrolujte, prosím, že jste se nepřepsali.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "wrongRecoveryKey": "Jejda... toto nejspíš není správný obnovovací klíč.", + "joinSpace": "Připojit se do prostoru", + "publicSpaces": "Veřejné prostory", + "decline": "Odmítnout", + "initAppError": "Při načítání nastala chyba", + "minimumPowerLevel": "Minimální úroveň oprávnění je {level}.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "gallery": "Galerie", + "files": "Soubory", + "databaseBuildErrorBody": "Nepodařilo se sestavit SQlite databázi. Aplikace se pokusí použít starší verzi databáze. Nahlaste, prosím, tuto chybu vývojářům na adrese {url}. Chybová hláška je: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Vaše relace byla ztracena. Nahlaste, prosím, tuto chybu vývojářům na adrese {url}. Chybová hláška je: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Aplikace se pokusí obnovit vaši relaci ze zálohy. Nahlaste, prosím, tuto chybu vývojářům na adrese {url}. Chybová hláška je: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Přeposlat zprávu do {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Posílat potvrzení o přečtení", + "sendTypingNotificationsDescription": "Ostatní účastníci konverzace uvidí, že píšete novou zprávu.", + "sendReadReceiptsDescription": "Ostatní účastníci konverzace uvidí, že jste si přečetl/a jejich zprávu.", + "formattedMessages": "Formátované zprávy", + "formattedMessagesDescription": "Zobrazovat formátovaný obsah zpráv, jako například tučný text pomocí markdownu.", + "verifyOtherUser": "🔐 Ověřit jiného uživatele", + "verifyOtherUserDescription": "Když ověříte jiného uživatele, můžete si být jistí, že víte, s kým si píšete. 💪\n\nJakmile začnete s ověřením, vy a druhý uživatel uvidíte v aplikaci vyskakovací okno. V něm uvidíte sérii emodži nebo čísel, které musíte společně porovnat.\n\nNejjednodušší je setkat se osobně nebo si udělat videohovor. 👭", + "verifyOtherDevice": "🔐 Ověřit jiné zařízení", + "verifyOtherDeviceDescription": "Když ověříte jiné zařízení, tato zařízení si mohou vyměnit klíče, čímž zvýšíte vaše zabezpečení. 💪 Jakmile začnete s ověřením, v aplikaci na obou zařízeních se objeví vyskakovací okno. V něm uvidíte sérii emodži nebo čísel, které musíte na zařízeních porovnat mezi sebou. Než začnete s ověřováním, je fajn mít obě zařízení po ruce. 🤳", + "acceptedKeyVerification": "{sender} přijal/a ověření klíče", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} zrušil ověření klíče", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} dokončil ověření klíče", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} je připraven/a na ověření klíče", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} požádal/a o ověření klíče", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} začal/a s ověřením klíče", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "prepareSendingAttachment": "Připravuji odeslání přílohy...", + "sendingAttachment": "Posílám přílohu...", + "generatingVideoThumbnail": "Vytvářím náhledový obrázek videa...", + "compressVideo": "Komprimuji video...", + "sendingAttachmentCountOfCount": "Odesílám přílohu {index} z {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Dosažen limit serveru! Čekám {seconds} sekund...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Jedno z vašich zařízení není ověřeno", + "continueText": "Pokračovat", + "welcomeText": "Ahoj, ahoj 👋 Tohle je FluffyChat. Můžete se přihlásit k jakémukoliv domácímu serveru, který je kompatibilní s https://matrix.org, a začít s kýmkoliv chatovat. Je to obří decentralizovaná chatovací síť!", + "setWallpaper": "Nastavit tapetu", + "manageAccount": "Spravovat účet", + "noContactInformationProvided": "Server neposkytl žádné platné kontaktní informace", + "contactServerAdmin": "Kontaktovat administrátora serveru", + "supportPage": "Podpora", + "serverInformation": "Informace o serveru:", + "name": "Název", + "version": "Verze", + "website": "Webová stránka", + "compress": "Komprimovat", + "boldText": "Tučný text", + "italicText": "Kurzíva", + "strikeThrough": "Přeškrtnutý text", + "pleaseFillOut": "Prosím vyplňte", + "invalidUrl": "Neplatná URL adresa", + "addLink": "Přidat odkaz", + "unableToJoinChat": "Nepodařilo se připojit ke konverzaci. Je možné, že druhá strana ji už uzavřela.", + "previous": "Předchozí", + "otherPartyNotLoggedIn": "Druhá strana aktuálně není přihlášená, takže nemůže přijímat zprávy!", + "appWantsToUseForLogin": "Použít '{server}' k přihlášení", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Pokračováním povolíte aplikaci a webové stránce sdílet mezi sebou informace o vás.", + "open": "Otevřít", + "waitingForServer": "Čekám na server...", + "appIntroduction": "FluffyChat vám umožňuje chatovat s přáteli napříč různými aplikacemi. Zjistěte více na https://matrix.org nebo prostě klepněte na *Pokračovat*.", + "newChatRequest": "📩 Nová žádost o konverzaci", + "generalNotificationSettings": "Obecné nastavení oznámení", + "roomNotificationSettings": "Nastavení oznámení pro místnost", + "userSpecificNotificationSettings": "Nastavení oznámení pro uživatele", + "otherNotificationSettings": "Ostatní nastavení oznámení", + "notificationRuleContainsUserName": "Obsahuje uživatelské jméno", + "notificationRuleContainsUserNameDescription": "Pošle uživateli oznámení, když zpráva obsahuje jeho uživatelské jméno.", + "notificationRuleMaster": "Ztlumit veškerá oznámení", + "notificationRuleMasterDescription": "Přepíše veškerá ostatní pravidla a zakáže všechna oznámení.", + "notificationRuleSuppressNotices": "Ztlumit automatizované zprávy", + "notificationRuleSuppressNoticesDescription": "Ztlumí oznámení od automatizovaných klientů, jako jsou např. roboti.", + "notificationRuleInviteForMe": "Pozvánka adresovaná mně", + "notificationRuleInviteForMeDescription": "Pošle uživateli oznámení, když je pozván do místnosti.", + "notificationRuleMemberEvent": "Události týkající se členství", + "notificationRuleMemberEventDescription": "Ztlumí oznámení týkající se veškerých událostí souvisejících s členstvím.", + "notificationRuleIsUserMention": "Zmínka uživatele", + "notificationRuleIsUserMentionDescription": "Pošle uživateli oznámení, když je někdo přímo zmíní ve zprávě.", + "notificationRuleContainsDisplayName": "Obsahuje přezdívku", + "notificationRuleContainsDisplayNameDescription": "Pošle uživateli oznámení, když zpráva obsahuje jejich přezdívku.", + "notificationRuleIsRoomMention": "Označení místnosti", + "notificationRuleIsRoomMentionDescription": "Pošle uživateli oznámení, když je označena celá místnost.", + "notificationRuleRoomnotif": "Označení místnosti", + "notificationRuleRoomnotifDescription": "Pošle uživateli oznámení, když zpráva obsahuje '@room'.", + "notificationRuleTombstone": "Náhrobek", + "notificationRuleTombstoneDescription": "Pošle uživateli oznámení ohledně zpráv o deaktivaci místnosti.", + "notificationRuleReaction": "Reakce", + "notificationRuleReactionDescription": "Ztlumí oznámení o reakcích.", + "notificationRuleSuppressEdits": "Ztlumit úpravy", + "notificationRuleSuppressEditsDescription": "Ztlumí notifikace týkající se upravených zpráv.", + "notificationRuleCall": "Hovor", + "notificationRuleCallDescription": "Pošle uživateli oznámení ohledně hovorů.", + "sentVoiceMessage": "🎙️ {duration} - Hlasová zpráva od {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Odstranění tohoto nastavení oznámení nelze vzít zpět.", + "more": "Více", + "shareKeysWith": "Sdílet klíče s...", + "shareKeysWithDescription": "Která zařízení mají být označena jako důvěryhodná, aby mohla současně číst vaše zprávy v šifrovaných konverzacích?", + "allDevices": "Všechna zařízení", + "crossVerifiedDevicesIfEnabled": "Křížově ověřená zařízení, pokud je povoleno", + "crossVerifiedDevices": "Křížově ověřená zařízení", + "verifiedDevicesOnly": "Pouze ověřená zařízení", + "recordAVideo": "Nahrát video", + "optionalMessage": "(Volitelné) zpráva...", + "notSupportedOnThisDevice": "Není na tomto zařízení podporováno", + "approve": "Schválit", + "youHaveKnocked": "Zaklepali jste", + "pleaseWaitUntilInvited": "Nyní musíte počkat, až vás nějaký člen této místnosti pozve dovnitř.", + "commandHint_logout": "Odhlásit se z aktuálního zařízení", + "commandHint_logoutall": "Odhlásit se ze všech aktivních zařízení", + "displayNavigationRail": "Zobrazit navigační lištu na mobilu", + "customReaction": "Vlastní reakce", + "moreEvents": "Více událostí", + "declineInvitation": "Odmítnout pozvánku", + "noMessagesYet": "Zatím tu nejsou žádné zprávy", + "longPressToRecordVoiceMessage": "Podržte pro nahrání hlasové zprávy.", + "pause": "Pozastavit", + "resume": "Pokračovat", + "newSubSpace": "Nový podprostor", + "moveToDifferentSpace": "Přesunout do jiného prostoru", + "removeFromSpaceDescription": "Tato konverzace bude odstraněna z tohoto prostoru, stále však bude dostupná ve vašem seznamu konverzací.", + "countChats": "{chats} konverzací", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Členové prostoru {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Členové prostoru {spaces} mohou zaklepat", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Přispět", + "startedAPoll": "{username} spustil/a hlasování.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Hlasování", + "startPoll": "Spustit hlasování", + "endPoll": "Ukončit hlasování", + "answersVisible": "Odpovědi budou viditelné", + "answersHidden": "Odpovědi budou skryté", + "pollQuestion": "Předmět hlasování", + "answerOption": "Možnost", + "addAnswerOption": "Přidat možnost", + "allowMultipleAnswers": "Povolit více odpovědí", + "pollHasBeenEnded": "Hlasování skončilo", + "answersWillBeVisibleWhenPollHasEnded": "Odpovědi budou viditelné jakmile hlasování skončí", + "replyInThread": "Odpovědět ve vlákně", + "thread": "Vlákno", + "backToMainChat": "Zpátky do hlavního chatu", + "saveChanges": "Uložit změny", + "createSticker": "Vytvořit nálepku nebo emodži", + "useAsSticker": "Použít jako nálepku", + "useAsEmoji": "Použít jako emodži", + "stickerPackNameAlreadyExists": "Balíček nálepek s tímto názvem již existuje", + "newStickerPack": "Nový balíček nálepek", + "stickerPackName": "Název balíčku nálepek", + "attribution": "Zdroj", + "skipChatBackup": "Přeskočit zálohu konverzací", + "skipChatBackupWarning": "Jste si jistí? Pokud nepovolíte zálohu konverzací, můžete ztratit přístup ke svým zprávám v případě změny zařízení.", + "loadingMessages": "Načítám zprávy", + "setupChatBackup": "Nastavit zálohování konverzací", + "noMoreResultsFound": "Žádné další výsledky nenalezeny", + "chatSearchedUntil": "Konverzace prohledána do {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "Základní URL pro federování", + "baseUrl": "Základní URL", + "versionWithNumber": "Verze: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Záznamy", + "advancedConfigs": "Pokročilá nastavení", + "signIn": "Přihlásit se", + "createNewAccount": "Vytvořit nový účet", + "signUpGreeting": "FluffyChat je decentralizovaný! Vyberte server, kde si chcete vytvořit účet, a jdeme na věc!", + "signInGreeting": "Již máte účet na Matrixu? Vítejte zpět! Vyberte svůj domácí server a přihlaste se.", + "appIntro": "S FluffyChatem můžeme chatovat s přáteli. Je to decentralizovaná chatovací aplikace pro [matrix]! Zjistěte více na https://matrix.org nebo se zaregistrujte.", + "theProcessWasCanceled": "Proces byl zrušen.", + "sendImages": "Poslat {count} obrazků", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "commandHint_roomupgrade": "Aktualizovat místnost na danou verzi", + "subspace": "Podprostor" +} diff --git a/lib/l10n/intl_da.arb b/lib/l10n/intl_da.arb new file mode 100644 index 000000000..5f9f53f59 --- /dev/null +++ b/lib/l10n/intl_da.arb @@ -0,0 +1,137 @@ +{ + "repeatPassword": "Gentag password", + "notAnImage": "Ikke en billedfil.", + "setCustomPermissionLevel": "Indstil særligt tilladelsesniveau", + "setPermissionsLevelDescription": "Vælg en prædefineret rolle herunder eller indtaste et særligt tilladelsesniveau mellem 0 og 100.", + "ignoreUser": "Ignorér bruger", + "remove": "Fjern", + "@remove": { + "type": "String", + "placeholders": {} + }, + "importNow": "Importer nu", + "importEmojis": "Importer emojis", + "normalUser": "Normal bruger", + "importFromZipFile": "Importer fra .zip fil", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "exportEmotePack": "Eksportér Emote-pakke som .zip-fil", + "replace": "Erstat", + "about": "Om", + "aboutHomeserver": "Om {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "accept": "Acceptér", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} accepterede invitationen", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Konto", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} aktiverede end-to-end kryptering", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Tilføj e-mail", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Bekræft din Matrix-ID for at slette din konto.", + "supposedMxid": "Den burde være {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "Tilføj en beskrivelse af chatten...", + "addToSpace": "Tilføj til gruppe", + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "allChats": "Alle samtaler", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_roomupgrade": "Opgrader dette rum til den givne rumversion", + "commandHint_googly": "Send googly-eyes", + "commandHint_cuddle": "Send et varmt smil", + "commandHint_hug": "Send et kram", + "googlyEyesContent": "{senderName} sender dig googly-eyes", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} sender dig et varmt smil", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} krammer dig", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "answeredTheCall": "{senderName} svarer på dit opkald", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Enhver kan deltage", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + } +} diff --git a/lib/l10n/intl_de.arb b/lib/l10n/intl_de.arb new file mode 100644 index 000000000..2af7eb0ea --- /dev/null +++ b/lib/l10n/intl_de.arb @@ -0,0 +1,3150 @@ +{ + "@@locale": "de", + "@@last_modified": "2021-08-14 12:41:10.119255", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "about": "Über", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Annehmen", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} hat die Einladung angenommen", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Konto", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} hat Ende-zu-Ende Verschlüsselung aktiviert", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "E-Mail hinzufügen", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "Alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Alle", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Alle Chats", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} hat den Anruf angenommen", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Jeder darf beitreten", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Anwendungssperre", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Archiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Dürfen Gäste teilnehmen?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Bist du sicher?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Willst du dich wirklich abmelden?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Bitte gib, um die andere Person signieren zu können, dein Sicherheitsschlüssel oder Wiederherstellungsschlüssel ein.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Diese Bestätigungsanfrage von {username} annehmen?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "Der Homeserver unterstützt diese Anmelde-Typen:\n{serverVersions}\nAber diese App unterstützt nur:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "Der Homeserver unterstützt die Spec-Versionen:\n{serverVersions}\nAber diese App unterstützt nur:\n{supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Aus dem Chat verbannen", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Verbannt", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} hat {targetName} verbannt", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blockiere Gerät", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Blockiert", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot-Nachrichten", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Abbrechen", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Die URI {uri} kann nicht geöffnet werden", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Gerätenamen ändern", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} hat den Chat-Avatar geändert", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} hat die Chatbeschreibung geändert in: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} hat den Chatnamen geändert in: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} hat die Chat-Berechtigungen geändert", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} hat den Spitznamen geändert in: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} hat die Zugangsregeln für Gäste geändert", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} hat die Zugangsregeln für Gäste geändert zu: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} hat die Sichtbarkeit des Chat-Verlaufs geändert", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} hat die Sichtbarkeit des Chat-Verlaufs geändert zu: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} hat die Zugangsregeln geändert", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} hat die Zugangsregeln geändert zu: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} hat das Profilbild geändert", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} hat die Raum-Aliasse geändert", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} hat den Einladungslink geändert", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Passwort ändern", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Anderen Homeserver verwenden", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Ändere Deinen Style", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Gruppenname ändern", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Deinen Avatar ändern", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Die Verschlüsselung wurde korrumpiert", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Chat-Backup", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Deine Nachrichten sind mit einem Wiederherstellungsschlüssel gesichert. Bitte stelle sicher, dass du ihn nicht verlierst.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Chatdetails", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Chats", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Wähle ein sicheres Passwort", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Archiv leeren", + "close": "Schließen", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Banne ausgewählten Benutzer aus diesen Raum", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Sende HTML-formatierten Text", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Lade den Benutzer in diesen Raum ein", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Betritt den ausgewählten Raum", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Entferne den übergebenen Benutzer aus diesem Raum", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Diesen Raum verlassen", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Beschreibe dich selbst", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Setze dein Profilbild nur für diesen Raum (MXC-Uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Setze deinen Anzeigenamen nur für diesen Raum", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Setze den übergeben Powerlevel des Benutzers (Standard: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Sende unformatierten Text", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Sende die Antwort als Reaktion", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Text senden", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Hebe die Verbannung dieses Benutzers in diesem Raum auf", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Befehl ungültig", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} ist kein Befehl.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Bitte vergleiche die Emojis", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Bitte vergleiche die Zahlen", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Chat konfigurieren", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Bestätigen", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Verbinden", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt wurde in die Gruppe eingeladen", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Enthält Anzeigenamen", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Enthält Benutzernamen", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Der Inhalt wurde den Serveradministratoren gemeldet", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Wurde in die Zwischenablage kopiert", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopieren", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "In Zwischenablage kopieren", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Nachricht konnte nicht entschlüsselt werden: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} Mitglieder", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Erstellen", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} hat den Chat erstellt", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Neuer Space", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Jetzt gerade online", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Dunkel", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}.{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}.{month}.{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Dies deaktiviert dein Konto. Es kann nicht rückgängig gemacht werden! Bist du sicher?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Standardberechtigungsstufe für neue Benutzer", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Löschen", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Konto löschen", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Nachricht löschen", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Gerät", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Geräte-ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Geräte", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Direkte Chats", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Anzeigename wurde geändert", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Datei herunterladen", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Bearbeiten", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Blockierte Server einstellen", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Anzeigename ändern", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Raum-Aliase bearbeiten", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Raumavatar bearbeiten", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emoticon existiert bereits!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Ungültiges Emoticon-Kürzel!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Emoticon-Bündel für Raum", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emoticon-Einstellungen", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Emoticon-Kürzel", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Wähle ein Emoticon-Kürzel und ein Bild!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Leerer Chat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Aktiviere Emoticon-Bündel global", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Verschlüsselung anschalten", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Du wirst die Verschlüsselung nicht mehr ausstellen können. Bist Du sicher?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Verschlüsselt", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Verschlüsselung", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Verschlüsselung ist nicht aktiviert", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} hat den Anruf beendet", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Gib eine E-Mail-Adresse ein", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Gib Deinen Homeserver ein", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Fehler beim Suchen des Standortes: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Alles fertig!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extrem beleidigend", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Dateiname", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Schriftgröße", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Weiterleiten", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Ab dem Beitritt", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Ab der Einladung", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Zum neuen Raum wechseln", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Gruppe", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Öffentliche Gruppe", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Gruppen", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Gruppe mit {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Gäste sind verboten", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Gäste dürfen beitreten", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} hat die Einladung für {targetName} zurückgezogen", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Hilfe", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Gelöschte Nachrichten ausblenden", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Unbekannte Ereignisse ausblenden", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Wie beleidigend ist dieser Inhalt?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identität", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorieren", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Ignorierte Personen", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Ich habe den Link angeklickt", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Falsches Passwort oder Wiederherstellungsschlüssel", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Harmlos", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Kontakt einladen", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Kontakt in die Gruppe {groupName} einladen", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Eingeladen", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} hat {targetName} eingeladen", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Nur eingeladene Mitglieder", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Einladung für mich", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} hat Dich zu FluffyChat eingeladen. \n1. Gehe auf fluffychat.im und installiere die App \n2. Melde Dich in der App an \n3. Öffne den Einladungslink: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "schreibt …", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} ist dem Chat beigetreten", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Raum beitreten", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} hat {targetName} hinausgeworfen", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} hat {targetName} hinausgeworfen und verbannt", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Aus dem Chat hinauswerfen", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Zuletzt aktiv: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Verlassen", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Hat den Chat verlassen", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Lizenz", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Hell", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "{count} weitere Mitglieder laden", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Lade … Bitte warten.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Mehr laden …", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Standort ist deaktiviert. Bitte aktivieren, um den Standort teilen zu können.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Standort-Berechtigung wurde abgelehnt. Bitte akzeptieren, um den Standort teilen zu können.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Anmelden", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Bei {homeserver} anmelden", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Abmelden", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Änderungen der Mitglieder", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Erwähnen", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Nachrichten", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Stummschalten", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Bitte beachte, dass du Pantalaimon brauchst, um Ende-zu-Ende-Verschlüsselung benutzen zu können.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Neuer Chat", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Neue Nachricht in FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Neue Verifikationsanfrage!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Weiter", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Nein", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Keine Verbindung zum Server", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Keine Emoticons gefunden. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Du kannst die Verschlüsselung erst aktivieren, sobald dieser Raum nicht mehr öffentlich zugänglich ist.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Firebase Cloud Messaging scheint auf deinem Gerät nicht verfügbar zu sein. Um trotzdem Push-Benachrichtigungen zu erhalten, empfehlen wir die Installation von ntfy. Mit ntfy oder einem anderen Unified-Push-Anbieter kannst du Push-Benachrichtigungen datensicher empfangen. Du kannst ntfy im PlayStore oder bei F-Droid herunterladen.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Keiner", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Du hast bisher keine Möglichkeit hinzugefügt, um dein Passwort zurückzusetzen.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Keine Berechtigung", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Keine Räume gefunden …", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Benachrichtigungen", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Benachrichtigungen für dieses Konto aktiviert", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} Mitglieder schreiben …", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Standort wird ermittelt …", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Beleidigend", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Offline", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Online", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Online-Schlüsselsicherung ist aktiviert", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Hoppla! Leider ist beim Einrichten der Push-Benachrichtigungen ein Fehler aufgetreten.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Hoppla, da ist etwas schiefgelaufen…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "App öffnen, um Nachrichten zu lesen", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Kamera öffnen", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "In Maps öffnen", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Oder", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Mitglied", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "Passwort oder Wiederherstellungsschlüssel", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Passwort", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Passwort vergessen", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Passwort wurde geändert", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Passwort wiederherstellen", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Personen", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Bild wählen", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Anpinnen", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "{fileName} abspielen", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Bitte wählen", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Bitte einen Code festlegen", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Bitte auf den Link in der E-Mail klicken und dann fortfahren.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Bitte 4 Ziffern eingeben oder leer lassen, um die Anwendungssperre zu deaktivieren.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Bitte dein Passwort eingeben", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Bitte gib deine Pin ein", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Bitte deinen Benutzernamen eingeben", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Bitte folge den Anweisungen auf der Website und tippe auf Weiter.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privatsphäre", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Öffentliche Räume", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Push-Regeln", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Grund", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Aufnahme", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} hat ein Ereignis gelöscht", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Nachricht löschen", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Registrieren", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Ablehnen", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} hat die Einladung abgelehnt", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Wieder beitreten", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Entfernen", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Alle anderen Geräte entfernen", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Entfernt von {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Gerät entfernen", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Verbannung aufheben", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Deinen Avatar löschen", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Raum mit neuer Version ersetzen", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Antworten", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Nachricht melden", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Berechtigung anfragen", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Der Raum wurde ge-upgraded", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Raumversion", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Datei speichern", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Suchen", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Sicherheit", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Gelesen von {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Senden", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Nachricht schreiben", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Sende als Text", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Sende Audiodatei", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Datei senden", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Bild senden", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Nachrichten senden", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Sende Original", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Sticker senden", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Sende Video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} hat eine Datei gesendet", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} hat eine Audio-Datei gesendet", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} hat ein Bild gesendet", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} hat einen Sticker gesendet", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} hat ein Video gesendet", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} hat Anrufinformationen geschickt", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Als Haupt-Alias festlegen", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Eigene Emoticons einstellen", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Einladungslink festlegen", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Berechtigungsstufe einstellen", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Status ändern", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Einstellungen", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Teilen", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} hat den Standort geteilt", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Standort teilen", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Passwort anzeigen", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Einmalige Anmeldung", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Überspringe", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Quellcode", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Space ist öffentlich", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Space-Name", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} hat einen Anruf getätigt", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Status", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Wie geht es dir heute?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Absenden", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synchronisiere... Bitte warten.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "System", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Stimmen nicht überein", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Stimmen überein", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Favorite umschalten", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Stummgeschaltete umschalten", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Markieren als gelesen/ungelesen", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Zu viele Anfragen. Bitte versuche es später noch einmal!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Von anderem Gerät übertragen", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Noch mal versuchen zu senden", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Nicht verfügbar", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} hat die Verbannung von {targetName} aufgehoben", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Geräteblockierung aufheben", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Unbekanntes Gerät", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Unbekannter Verschlüsselungsalgorithmus", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Unbekanntes Ereignis '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Stumm aus", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Nicht mehr anpinnen", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 ungelesene Unterhaltung} other{{unreadCount} ungelesene Unterhaltungen}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} und {count} andere schreiben …", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} und {username2} schreiben …", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} schreibt …", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} hat den Chat verlassen", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Benutzername", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} hat ein {type}-Ereignis gesendet", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Verifiziert", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verifizieren", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Starte Verifikation", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Erfolgreich verifiziert!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Anderes Konto wird verifiziert", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videoanruf", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Sichtbarkeit des Chat-Verlaufs", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Sichtbar für alle Mitglieder", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Für jeden sichtbar", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Sprachnachricht", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Warte darauf, dass der Partner die Anfrage annimmt …", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Warte darauf, dass der Partner die Emoji annimmt …", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Warten, dass der Partner die Zahlen annimmt …", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Hintergrund:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Achtung!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Wir haben dir eine E-Mail gesendet", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Wer kann welche Aktion ausführen", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Wer darf der Gruppe beitreten", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Warum willst du dies melden?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Den Chat-Backup löschen, um einen neuen Wiederherstellungsschlüssel zu erstellen?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Mit diesen Adressen kannst du dein Passwort wiederherstellen, wenn du es vergessen hast.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Schreibe eine Nachricht …", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Ja", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Du", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Du bist kein Mitglied mehr in diesem Chat", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Du wurdest aus dem Chat verbannt", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Dein öffentlicher Schlüssel", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} ist kein Matrix-Server, stattdessen {server2} benutzen?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "scanQrCode": "QR-Code scannen", + "chatHasBeenAddedToThisSpace": "Chat wurde zum Space hinzugefügt", + "autoplayImages": "Animierte Sticker und Emotes automatisch abspielen", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "addToSpace": "Zum Space hinzufügen", + "serverRequiresEmail": "Dieser Server muss deine E-Mail-Adresse für die Registrierung überprüfen.", + "enableMultiAccounts": "(BETA) Aktiviere Multi-Accounts für dieses Gerät", + "bundleName": "Name des Bundles", + "removeFromBundle": "Von diesem Bundle entfernen", + "addToBundle": "Zu einem Bundle hinzufügen", + "editBundlesForAccount": "Bundles für dieses Konto bearbeiten", + "addAccount": "Konto hinzufügen", + "oneClientLoggedOut": "Einer deiner Clients wurde abgemeldet", + "homeserver": "Homeserver", + "sendOnEnter": "Senden mit Enter", + "link": "Link", + "yourChatBackupHasBeenSetUp": "Dein Chat-Backup wurde eingerichtet.", + "unverified": "Unverifiziert", + "messageInfo": "Nachrichten-Info", + "time": "Zeit", + "messageType": "Nachrichtentyp", + "sender": "Absender:in", + "openGallery": "Galerie öffnen", + "removeFromSpace": "Aus dem Space entfernen", + "addToSpaceDescription": "Wähle einen Space aus, um diesen Chat hinzuzufügen.", + "start": "Start", + "repeatPassword": "Passwort wiederholen", + "commandHint_dm": "Starte einen direkten Chat\nBenutze --no-encryption, um die Verschlüsselung auszuschalten", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_discardsession": "Sitzung verwerfen", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_clearcache": "Zwischenspeicher löschen", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Erstelle ein leeren Gruppenchat\nBenutze --no-encryption, um die Verschlüsselung auszuschalten", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "openVideoCamera": "Video aufnehmen", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "publish": "Veröffentlichen", + "pinMessage": "An Raum anheften", + "emojis": "Emojis", + "placeCall": "Anruf tätigen", + "voiceCall": "Sprachanruf", + "unsupportedAndroidVersion": "Nicht unterstützte Android-Version", + "videoCallsBetaWarning": "Bitte beachte, dass sich Videoanrufe derzeit in der Beta-Phase befinden. Sie funktionieren möglicherweise nicht wie erwartet oder überhaupt nicht auf allen Plattformen.", + "emailOrUsername": "E-Mail oder Benutzername", + "unsupportedAndroidVersionLong": "Diese Funktion erfordert eine neuere Android-Version. Bitte suche nach Updates oder prüfe die Lineage-OS-Unterstützung.", + "experimentalVideoCalls": "Experimentelle Videoanrufe", + "reactedWith": "{sender} reagierte mit {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "markAsRead": "Als gelesen markiert", + "reportUser": "Benutzer melden", + "openChat": "Chat öffnen", + "confirmEventUnpin": "Möchtest du das Ereignis wirklich dauerhaft lösen?", + "dismiss": "Verwerfen", + "switchToAccount": "Zu Konto {number} wechseln", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Nächstes Konto", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "Angepasst", + "widgetEtherpad": "Textnotiz", + "addWidget": "Widget hinzufügen", + "widgetVideo": "Video", + "widgetName": "Name", + "widgetUrlError": "Das ist keine gültige URL.", + "errorAddingWidget": "Fehler beim Hinzufügen des Widgets.", + "previousAccount": "Vorheriges Konto", + "separateChatTypes": "Separate Direktchats und Gruppen", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "widgetNameError": "Bitte gib einen Anzeigenamen an.", + "youKicked": "👞 Du hast {user} rausgeworfen", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Du hast {user} rausgeworfen und verbannt", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Du hast die Verbannung von {user} rückgängig gemacht", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youRejectedTheInvitation": "Du hast die Einladung abgelehnt", + "youJoinedTheChat": "Du bist dem Chat beigetreten", + "youAcceptedTheInvitation": "👍 Du hast die Einladung angenommen", + "youBannedUser": "Du hast den {user} verbannt", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Du hast die Einladung für {user} zurückgezogen", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Du wurdest von {user} eingeladen", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Du hast {user} eingeladen", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "recoveryKey": "Wiederherstellungs-Schlüssel", + "recoveryKeyLost": "Wiederherstellungsschlüssel verloren?", + "user": "Benutzer", + "custom": "Benutzerdefiniert", + "storeInAndroidKeystore": "Im Android KeyStore speichern", + "storeSecurlyOnThisDevice": "Auf diesem Gerät sicher speichern", + "dehydrate": "Sitzung exportieren und Gerät löschen", + "dehydrateWarning": "Diese Aktion kann nicht rückgängig gemacht werden. Stelle sicher, dass du die Sicherungsdatei sicher aufbewahrst.", + "dehydrateTor": "TOR-Benutzer: Sitzung exportieren", + "dehydrateTorLong": "Für TOR-Benutzer wird empfohlen, die Sitzung zu exportieren, bevor das Fenster geschlossen wird.", + "hydrateTor": "TOR-Benutzer: Session-Export importieren", + "hydrate": "Aus Sicherungsdatei wiederherstellen", + "indexedDbErrorTitle": "Probleme im Privatmodus", + "unlockOldMessages": "Entsperre alte Nachrichten", + "pleaseEnterRecoveryKeyDescription": "Um deine alten Nachrichten zu entsperren, gib bitte den Wiederherstellungsschlüssel ein, der in einer früheren Sitzung generiert wurde. Dein Wiederherstellungsschlüssel ist NICHT dein Passwort.", + "saveKeyManuallyDescription": "Speicher diesen Schlüssel manuell, indem du den Systemfreigabedialog oder die Zwischenablage auslöst.", + "hydrateTorLong": "Hast du deine Sitzung das letzte Mal auf TOR exportiert? Importiere sie schnell und chatte weiter.", + "pleaseEnterRecoveryKey": "Bitte gib deinen Wiederherstellungsschlüssel ein:", + "countFiles": "{count} Dateien", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "users": "Benutzer", + "storeInSecureStorageDescription": "Speicher den Wiederherstellungsschlüssel im sicheren Speicher dieses Geräts.", + "storeInAppleKeyChain": "Im Apple KeyChain speichern", + "indexedDbErrorLong": "Die Nachrichtenspeicherung ist im privaten Modus standardmäßig leider nicht aktiviert.\nBitte besuche\n- about:config\n- Setze dom.indexedDB.privateBrowsing.enabled auf true\nAndernfalls ist es nicht möglich, FluffyChat auszuführen.", + "confirmMatrixId": "Bitte bestätigen deine Matrix-ID, um dein Konto zu löschen.", + "supposedMxid": "das sollte sein {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasdm": "Als Direktnachrichtenraum für die angegebene Matrix-ID markieren", + "commandHint_markasgroup": "Als Gruppe markieren", + "hideUnimportantStateEvents": "Blende unwichtige Zustandsereignisse aus", + "doNotShowAgain": "Nicht mehr anzeigen", + "appearOnTopDetails": "Ermöglicht, dass die App oben angezeigt wird (nicht erforderlich, wenn du Fluffychat bereits als Anrufkonto eingerichtet haben)", + "noKeyForThisMessage": "Dies kann passieren, wenn die Nachricht gesendet wurde, bevor du dich auf diesem Gerät bei deinem Konto angemeldet hast.\n\nEs ist auch möglich, dass der Absender dein Gerät blockiert hat oder etwas mit der Internetverbindung schief gelaufen ist.\n\nKannst du die Nachricht in einer anderen Sitzung lesen? Dann kannst du die Nachricht davon übertragen! Gehe zu den Einstellungen > Geräte und vergewissere dich, dass sich deine Geräte gegenseitig verifiziert haben. Wenn du den Raum das nächste Mal öffnest und beide Sitzungen im Vordergrund sind, werden die Schlüssel automatisch übertragen.\n\nDu möchtest die Schlüssel beim Abmelden oder Gerätewechsel nicht verlieren? Stelle sicher, dass du das Chat-Backup in den Einstellungen aktiviert hast.", + "foregroundServiceRunning": "Diese Benachrichtigung wird angezeigt, wenn der Vordergrunddienst ausgeführt wird.", + "screenSharingTitle": "Bildschirm teilen", + "callingPermissions": "Anrufberechtigungen", + "callingAccount": "Anrufkonto", + "callingAccountDetails": "Ermöglicht FluffyChat, die native Android-Dialer-App zu verwenden.", + "appearOnTop": "Oben erscheinen", + "otherCallingPermissions": "Mikrofon, Kamera und andere FluffyChat-Berechtigungen", + "whyIsThisMessageEncrypted": "Warum ist diese Nachricht nicht lesbar?", + "newGroup": "Neue Gruppe", + "newSpace": "Neuer Space", + "enterSpace": "Raum betreten", + "enterRoom": "Raum betreten", + "allSpaces": "Alle Spaces", + "screenSharingDetail": "Du teilst deinen Bildschirm in FuffyChat", + "numChats": "{number} Chats", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "newSpaceDescription": "Mit Spaces kannst du deine Chats zusammenfassen und private oder öffentliche Communities aufbauen.", + "wasDirectChatDisplayName": "Leerer Chat (war {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "encryptThisChat": "Diesen Chat verschlüsseln", + "googlyEyesContent": "{senderName} hat dir Googly Eyes gesendet", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "startFirstChat": "Starte deinen ersten Chat", + "deviceKeys": "Geräteschlüssel:", + "commandHint_cuddle": "Umarmung senden", + "commandHint_hug": "Umarmung senden", + "cuddleContent": "{senderName} knuddelt dich", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "sorryThatsNotPossible": "Sorry ... das ist nicht möglich", + "hugContent": "{senderName} umarmt dich", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_googly": "Glupschaugen senden", + "disableEncryptionWarning": "Aus Sicherheitsgründen kannst du die Verschlüsselung in einem Chat nicht deaktivieren, wo sie zuvor aktiviert wurde.", + "reopenChat": "Chat wieder eröffnen", + "noBackupWarning": "Achtung! Ohne Aktivierung des Chat-Backups verlierst du den Zugriff auf deine verschlüsselten Nachrichten. Vor dem Ausloggen wird dringend empfohlen, das Chat-Backup zu aktivieren.", + "noOtherDevicesFound": "Keine anderen Geräte anwesend", + "allRooms": "Alle Gruppenchats", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "fileHasBeenSavedAt": "Datei wurde gespeichert unter {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Zur letzten ungelesenen Nachricht", + "readUpToHere": "Bis hier gelesen", + "pleaseTryAgainLaterOrChooseDifferentServer": "Bitte versuche es später noch einmal oder wähle einen anderen Server.", + "jump": "Springen", + "openLinkInBrowser": "Link im Browser öffnen", + "reportErrorDescription": "😭 Oh nein. Etwas ist schief gelaufen. Wenn du möchtest, kannst du den Bug bei den Entwicklern melden.", + "report": "Melden", + "signInWithPassword": "Anmelden mit Passwort", + "signInWithLabel": "Anmelden mit:", + "importNow": "Jetzt importieren", + "importEmojis": "Emojis importieren", + "importFromZipFile": "Aus ZIP-Datei importieren", + "exportEmotePack": "Emote-Paket als ZIP-Datei exportieren", + "notAnImage": "Keine Bilddatei.", + "replace": "Ersetzen", + "sendTypingNotifications": "Tippbenachrichtigungen senden", + "profileNotFound": "Der Benutzer konnte auf dem Server nicht gefunden werden. Vielleicht gibt es ein Verbindungsproblem oder der Benutzer existiert nicht.", + "createGroup": "Gruppe erstellen", + "shareInviteLink": "Einladungslink teilen", + "inviteContactToGroupQuestion": "Willst du {contact} zum Chat {groupName} einladen?", + "tryAgain": "Neuer Versuch", + "redactMessageDescription": "Die Nachricht wird für alle Teilnehmer dieses Gesprächs gelöscht. Dies kann nicht rückgängig gemacht werden.", + "redactedBy": "Gelöscht von {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactedByBecause": "Gelöscht von {username} weil: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "setTheme": "Design festlegen:", + "setColorTheme": "Farbdesign einstellen:", + "invite": "Einladen", + "optionalRedactReason": "(Optional) Grund für die Löschung dieser Nachricht...", + "messagesStyle": "Nachrichten:", + "chatPermissions": "Chatberechtigungen", + "chatDescription": "Chatbeschreibung", + "chatDescriptionHasBeenChanged": "Chatbeschreibung geändert", + "noChatDescriptionYet": "Noch keine Chatbeschreibung vorhanden.", + "invalidServerName": "Ungültiger Servername", + "directChat": "Privater Chat", + "addChatDescription": "Chatbeschreibung hinzufügen ...", + "setChatDescription": "Chatbeschreibung festlegen", + "inviteGroupChat": "📨 Einladungen zum Gruppenchat", + "invitePrivateChat": "📨 Einladungen zum privaten Chat", + "invalidInput": "Ungültige Eingabe!", + "hasKnocked": "🚪 {user} hat angeklopft", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "wrongPinEntered": "Falsche PIN eingegeben! Bitte in {seconds} Sekunden erneut versuchen ...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pleaseEnterANumber": "Bitte eine Zahl größer 0 eingeben", + "emoteKeyboardNoRecents": "Kürzlich verwendete Emotes werden hier angezeigt ...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "banUserDescription": "Der Benutzer wird aus dem Chat gebannt und kann den Chat erst wieder betreten, wenn die Verbannung aufgehoben wird.", + "removeDevicesDescription": "Du wirst von diesem Gerät abgemeldet und kannst dann dort keine Nachrichten mehr empfangen.", + "unbanUserDescription": "Der Benutzer kann den Chat dann wieder betreten, wenn er es versucht.", + "pushNotificationsNotAvailable": "Push-Benachrichtigungen nicht verfügbar", + "makeAdminDescription": "Sobald du diesen Benutzer zum Administrator gemacht hast, kannst du das möglicherweise nicht mehr rückgängig machen, da er dann über dieselben Berechtigungen wie du verfügt.", + "archiveRoomDescription": "Der Chat wird in das Archiv verschoben. Andere Benutzer können sehen, dass du den Chat verlassen hast.", + "learnMore": "Erfahre mehr", + "roomUpgradeDescription": "Der Chat wird dann mit der neuen Raumversion neu erstellt. Alle Teilnehmer werden benachrichtigt, dass sie zum neuen Chat wechseln müssen. Mehr über Raumversionen erfährst du unter https://spec.matrix.org/latest/rooms/", + "kickUserDescription": "Der Benutzer wird aus dem Chat geworfen, aber nicht gebannt. In öffentlichen Chats kann der Benutzer jederzeit wieder beitreten.", + "blockListDescription": "Du kannst Benutzer blockieren, die dich stören. Von Benutzern auf deiner persönlichen Blocklierliste kannst du keine Nachrichten oder Raumeinladungen mehr erhalten.", + "createGroupAndInviteUsers": "Gruppe erstellen und Nutzer einladen", + "startConversation": "Unterhaltung starten", + "blockedUsers": "Blockierte Benutzer", + "groupCanBeFoundViaSearch": "Gruppe kann über die Suche gefunden werden", + "noUsersFoundWithQuery": "Leider konnte mit \"{query}\" kein Benutzer gefunden werden. Bitte schau nach, ob dir ein Tippfehler unterlaufen ist.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "block": "Blockieren", + "yourGlobalUserIdIs": "Deine globale Benutzer-ID ist: ", + "commandHint_sendraw": "Rohes JSON senden", + "wrongRecoveryKey": "Entschuldigung ... das scheint nicht der richtige Wiederherstellungsschlüssel zu sein.", + "blockUsername": "Blockiere Benutzername", + "groupName": "Gruppenname", + "searchChatsRooms": "Suche nach #Chats, @Nutzer ...", + "databaseMigrationTitle": "Datenbank wird optimiert", + "databaseMigrationBody": "Bitte warten. Dies kann einen Moment dauern.", + "thisDevice": "Dieses Gerät:", + "publicSpaces": "Öffentliche Spaces", + "passwordIsWrong": "Dein eingegebenes Passwort ist falsch", + "pleaseEnterYourCurrentPassword": "Bitte dein aktuelles Passwort eingeben", + "publicLink": "Öffentlicher Link", + "nothingFound": "Nichts gefunden ...", + "decline": "Ablehnen", + "newPassword": "Neues Passwort", + "passwordsDoNotMatch": "Passwörter stimmen nicht überein", + "subspace": "Sub-Space", + "select": "Auswählen", + "pleaseChooseAStrongPassword": "Bitte wähle ein starkes Passwort", + "addChatOrSubSpace": "Chat oder Sub-Space hinzufügen", + "leaveEmptyToClearStatus": "Leer lassen, um den Status zu löschen.", + "joinSpace": "Space beitreten", + "searchForUsers": "Suche nach @benutzer ...", + "initAppError": "Beim Starten der App ist ein Fehler aufgetreten", + "databaseBuildErrorBody": "Die SQlite-Datenbank kann nicht erstellt werden. Die App versucht vorerst, die Legacy-Datenbank zu verwenden. Bitte melde diesen Fehler an die Entwickler unter {url}. Die Fehlermeldung lautet: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Die App versucht nun, deine Sitzung aus der Sicherung wiederherzustellen. Bitte melde diesen Fehler an die Entwickler unter {url}. Die Fehlermeldung lautet: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Die App versucht nun, deine Sitzung aus der Sicherung wiederherzustellen. Bitte melde diesen Fehler an die Entwickler unter {url}. Die Fehlermeldung lautet: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Du wurdest per Link eingeladen zu:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "sendReadReceipts": "Lesebestätigungen senden", + "formattedMessages": "Formatierte Nachrichten", + "forwardMessageTo": "Nachricht weiterleiten an {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Andere Teilnehmer in einem Chat können sehen, wenn du eine neue Nachricht tippst.", + "formattedMessagesDescription": "Formatierte Nachrichteninhalte wie fettgedruckten Text mit Markdown anzeigen.", + "verifyOtherUser": "🔐 Anderen Benutzer verifizieren", + "sendReadReceiptsDescription": "Andere Teilnehmer in einem Chat können sehen, ob du eine Nachricht gelesen hast.", + "transparent": "Transparent", + "verifyOtherDevice": "🔐 Anderes Gerät verifizieren", + "verifyOtherUserDescription": "Wenn du einen anderen Benutzer verifizierst, kannst du sicher sein, dass du weißt, an wen du wirklich schreibst. 💪\n\nWenn du eine Verifizierung startest, wird dir und dem anderen Nutzer ein Popup in der App angezeigt. Dort siehst du dann eine Reihe von Emojis oder Zahlen, die ihr miteinander vergleichen müsst.\n\nDas geht am besten, wenn man sich trifft oder einen Videoanruf startet. 👭", + "acceptedKeyVerification": "{sender} hat die Schlüsselverifikation akzeptiert", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} hat die Schlüsselverifikation abgebrochen", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} hat die Schlüsselverifikation abgeschlossen", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} ist bereit für die Schlüsselverifikation", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} hat eine Schlüsselverifikation angefragt", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} hat die Schlüsselverifikation gestartet", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "verifyOtherDeviceDescription": "Wenn du ein anderes Gerät verifizierst, können diese Geräte Schlüssel austauschen, was die Sicherheit insgesamt erhöht. 💪Sobald du eine Verifizierung startest, erscheint ein Pop-up in der App auf beiden Geräten. Dort siehst du dann eine Reihe von Emojis oder Zahlen, die du miteinander vergleichen musst. Am besten hältst du beide Geräte bereit, bevor du die Verifizierung startest. 🤳", + "presenceStyle": "Statusmeldungen:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Status-Nachrichten anderer Benutzer anzeigen", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "incomingMessages": "Eingehende Nachrichten", + "commandHint_unignore": "Angegebene Matrix-ID nicht mehr ignorieren", + "commandHint_ignore": "Angegebene Matrix-ID ignorieren", + "noDatabaseEncryption": "Datenbankverschlüsselung wird auf dieser Plattform nicht unterstützt", + "hidePresences": "Status-Liste verbergen?", + "stickers": "Sticker", + "discover": "Entdecken", + "unreadChatsInApp": "{appname}: {unread} ungelesene Chats", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "customEmojisAndStickersBody": "Eigene Emojis oder Sticker zur Nutzung im Chat hinzufügen oder teilen.", + "globalChatId": "Globale Chat-ID", + "accessAndVisibility": "Zugang und Sichtbarkeit", + "hideMemberChangesInPublicChats": "Mitglieder-Änderungen in öffentlichen Chats ausblenden", + "accessAndVisibilityDescription": "Wer darf dem Chat beitreten und wie kann der Chat gefunden werden.", + "hideMemberChangesInPublicChatsBody": "Zeige keine Beitritt- oder Verlassen-Ereignisse von Mitgliedern in der Timeline an, um die Lesbarkeit in öffentlichen Chats zu verbessern.", + "userWouldLikeToChangeTheChat": "{user} würde dem Chat gerne beitreten.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Es wurde noch kein öffentlicher Link erstellt", + "chatCanBeDiscoveredViaSearchOnServer": "Chat kann über die Suche auf {server} gefunden werden", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appLockDescription": "App mit einer PIN sperren, wenn sie nicht verwendet wird", + "calls": "Anrufe", + "customEmojisAndStickers": "Eigene Emojis und Sticker", + "hideRedactedMessages": "Geschwärzte Nachrichten verstecken", + "hideRedactedMessagesBody": "Wenn jemand eine Nachricht schwärzt/löscht, dann wird diese Nachricht im Chat nicht mehr sichtbar sein.", + "hideInvalidOrUnknownMessageFormats": "Ungültige und unbekannte Nachrichten-Formate ausblenden", + "overview": "Übersicht", + "notifyMeFor": "Benachrichtige mich für", + "passwordRecoverySettings": "Passwort-Wiederherstellungs-Einstellungen", + "knock": "Anklopfen", + "knocking": "Klopft", + "thereAreCountUsersBlocked": "Im Augenblick werden {count} Benutzer blockiert.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "usersMustKnock": "Benutzer müssen anklopfen", + "noOneCanJoin": "Niemand kann beitreten", + "createNewAddress": "Neue Adresse erstellen", + "userRole": "Benutzerrolle", + "minimumPowerLevel": "{level} is das minimale Power-Level.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "publicChatAddresses": "Öffentliche Chat-Adressen", + "gallery": "Galerie", + "files": "Dateien", + "restricted": "Beschränkt", + "knockRestricted": "Anklopfen beschränkt", + "searchIn": "In Chat \"{chat}\" suchen ...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Weiter suchen ...", + "unread": "Ungelesen", + "noMoreChatsFound": "Keine weiteren Chats gefunden ...", + "joinedChats": "Beigetretene Chats", + "space": "Space", + "spaces": "Spaces", + "goToSpace": "Geh zum Space: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Als ungelesen markieren", + "swipeRightToLeftToReply": "Wische von rechts nach links zum Antworten", + "countChatsAndCountParticipants": "{chats} Chats und {participants} Teilnehmer", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Allgemeine Chat-Einstellungen ändern", + "userLevel": "{level} - Benutzer", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheChatPermissions": "Ändere die Chat-Berechtigungen", + "changeTheVisibilityOfChatHistory": "Wechsele die Sichtbarkeit der Chat-Historie", + "chatPermissionsDescription": "Einstellen, welches Level für bestimmte Aktionen in diesem Chat erforderlich ist. Die Level 0, 50 und 100 stehen üblicherweise für Benutzer, Moderatoren und Admins, aber jede Abstufung ist möglich.", + "invitedBy": "📩 Eingeladen von {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "adminLevel": "{level} - Administrator", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "inviteOtherUsers": "Lade andere Benutzer in diesen Chat ein", + "changeTheCanonicalRoomAlias": "Ändern der Hauptadresse für den öffentlichen Chat", + "sendRoomNotifications": "Sende eine @room-Benachrichtigung", + "changeTheDescriptionOfTheGroup": "Chat-Beschreibung ändern", + "updateInstalled": "🎉 Update {version} installiert!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Änderungsprotokoll", + "sendCanceled": "Senden abgebrochen", + "noChatsFoundHere": "Hier wurden noch keine Chats gefunden. Starte einen neuen Chat mit jemandem, indem du die Schaltfläche unten verwenden. ⤵️", + "whatIsAHomeserver": "Was ist ein Homeserver?", + "doesNotSeemToBeAValidHomeserver": "Scheint kein kompatibler Homeserver zu sein. Falsche URL?", + "loginWithMatrixId": "Mit Matrix-ID anmelden", + "discoverHomeservers": "Homeserver suchen", + "homeserverDescription": "Alle deine Daten werden auf einem Homeserver gespeichert, so wie bei einem E-Mail Anbieter. Du kannst aussuchen, welchen Homeserver du benutzen willst und kannst trotzdem mit allen kommunizieren. Erfahre mehr auf https://matrix.org.", + "sendingAttachment": "Anhang wird gesendet ...", + "generatingVideoThumbnail": "Generiere Video-Vorschaubild ...", + "serverLimitReached": "Server-Limit erreicht! Warte {seconds} Sekunden ...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "calculatingFileSize": "Dateigröße wird berechnet ...", + "prepareSendingAttachment": "Anhang zum Senden vorbereiten ...", + "compressVideo": "Video wird komprimiert ...", + "sendingAttachmentCountOfCount": "Sende Anhang {index} von {length} ...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "fileIsTooBigForServer": "Kann nicht gesendet werden! Der Server unterstützt nur Anhänge bis höchstens {max}.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Eines deiner Geräte ist nicht verifiziert", + "noticeChatBackupDeviceVerification": "Hinweis: Wenn du alle deine Geräte mit dem Chat-Backup verbindest, sind sie automatisch verifiziert.", + "setWallpaper": "Hintergrund ändern", + "opacity": "Deckkraft:", + "welcomeText": "Hey Hey 👋 Das ist FluffyChat. Du kannst sich bei jedem Homeserver anmelden, der mit https://matrix.org kompatibel ist. Und dann mit jedem chatten. Das hier ist ein riesiges dezentrales Nachrichtennetzwerk!", + "blur": "Verwischen:", + "manageAccount": "Konto verwalten", + "continueText": "Fortfahren", + "noContactInformationProvided": "Der Server stellt keine gültigen Kontaktinformationen bereit", + "contactServerAdmin": "Serveradministrator kontaktieren", + "name": "Name", + "version": "Version", + "website": "Website", + "aboutHomeserver": "Über {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "boldText": "Fetter Text", + "invalidUrl": "Ungültige URL", + "addLink": "Link hinzufügen", + "unableToJoinChat": "Chat kann nicht beigetreten werden. Möglicherweise hat die Gegenseite das Gespräch bereits beendet.", + "italicText": "Kursiver Text", + "strikeThrough": "Durchgestrichen", + "pleaseFillOut": "Bitte ausfüllen", + "sendImages": "Sende {count} Bilder", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "contactServerSecurity": "Server-Sicherheit kontaktieren", + "compress": "Komprimieren", + "supportPage": "Support-Seite", + "serverInformation": "Server-Informationen:", + "appIntroduction": "Mit FluffyChat kannst du über verschiedene Messenger hinweg mit deinen Freunden chatten. Erfahre mehr dazu auf https://matrix.org oder tippe einfach auf *Fortfahren*.", + "newChatRequest": "📩 Neue Chat-Anfrage", + "synchronizingPleaseWaitCounter": " Synchronisierung… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "waitingForServer": "Auf Server warten...", + "previous": "Vorige", + "otherPartyNotLoggedIn": "Der User ist aktuell nicht eingeloggt und kann daher keine Nachrichten empfangen!", + "appWantsToUseForLogin": "Nutze '{server}' um dich einzuloggen", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Hiermit erlaubst du der App und der Website, Informationen über dich weiterzugeben.", + "open": "Offen", + "notificationRuleContainsUserName": "Enthält Benutzernamen", + "notificationRuleContainsUserNameDescription": "Benachrichtigt den Benutzer, wenn eine Nachricht seinen Benutzernamen enthält.", + "notificationRuleMaster": "Alle Benachrichtigungen stummschalten", + "notificationRuleSuppressNotices": "Automatisierte Nachrichten unterdrücken", + "notificationRuleMasterDescription": "Setzt alle anderen Regeln außer Kraft und deaktiviert alle Benachrichtigungen.", + "generalNotificationSettings": "Allgemeine Benachrichtigungseinstellungen", + "otherNotificationSettings": "Andere Benachrichtigungseinstellungen", + "contentNotificationSettings": "Einstellungen für Inhaltsbenachrichtigungen", + "userSpecificNotificationSettings": "Benutzerspezifische Benachrichtigungseinstellungen", + "roomNotificationSettings": "Einstellungen für Raumbenachrichtigungen", + "notificationRuleSuppressNoticesDescription": "Unterdrückt Benachrichtigungen von automatisierten Clients wie Bots.", + "notificationRuleInviteForMe": "Einladung für mich", + "notificationRuleReaction": "Reaktion", + "notificationRuleReactionDescription": "Unterdrückt Benachrichtigungen für Reaktionen.", + "notificationRuleSuppressEditsDescription": "Unterdrückt Benachrichtigungen für bearbeitete Nachrichten.", + "notificationRuleCall": "Anruf", + "notificationRuleCallDescription": "Benachrichtigt den Benutzer über Anrufe.", + "notificationRuleEncrypted": "Verschlüsselt", + "more": "Mehr", + "notificationRuleSuppressEdits": "Unterdrückt Bearbeitungen", + "notificationRuleRoomServerAclDescription": "Unterdrückt Benachrichtigungen für Raumserver-Zugriffskontrolllisten (ACL).", + "notificationRuleMessage": "Nachricht", + "notificationRuleMessageDescription": "Informiert den Benutzer über allgemeine Nachrichten.", + "notificationRuleJitsi": "Jitsi", + "allDevices": "Alle Geräte", + "enterNewChat": "Neuen Chat betreten", + "shareKeysWith": "Schlüssel teilen mit...", + "shareKeysWithDescription": "Welchen Geräten sollte vertraut werden, damit sie deine Nachrichten in verschlüsselten Chats mitlesen können?", + "verifiedDevicesOnly": "Nur verifizierte Geräte", + "takeAPhoto": "Foto aufnehmen", + "recordAVideo": "Video aufnehmen", + "optionalMessage": "(Optionale) Nachricht...", + "notSupportedOnThisDevice": "Nicht unterstützt auf diesem Gerät", + "ignoreUser": "Nutzer ignorieren", + "notificationRuleEncryptedRoomOneToOneDescription": "Benachrichtigt den Benutzer über Nachrichten in verschlüsselten Eins-zu-Eins-Chats.", + "commandHint_roomupgrade": "Aktualisieren Sie diesen Raum auf die angegebene Raumversion", + "notificationRuleMemberEvent": "Mitgliederveranstaltung", + "notificationRuleInviteForMeDescription": "Benachrichtigt den Benutzer, wenn er in einen Raum eingeladen wird.", + "notificationRuleIsUserMentionDescription": "Benachrichtigt den Benutzer, wenn er in einer Nachricht direkt erwähnt wird.", + "notificationRuleRoomnotifDescription": "Benachrichtigt den Benutzer, wenn eine Nachricht „@room“ enthält.", + "notificationRuleRoomOneToOneDescription": "Benachrichtigt den Benutzer über Nachrichten in Einzelchats.", + "notificationRuleEncryptedDescription": "Benachrichtigt den Benutzer über Nachrichten in verschlüsselten Räumen.", + "notificationRuleJitsiDescription": "Benachrichtigt den Benutzer über Jitsi-Widget-Ereignisse.", + "checkList": "Checkliste", + "countInvited": "{count} invited", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "notificationRuleIsUserMention": "Benutzererwähnung", + "notificationRuleContainsDisplayName": "Enthält den Anzeigenamen", + "notificationRuleContainsDisplayNameDescription": "Benachrichtigt den Benutzer, wenn eine Nachricht seinen Anzeigenamen enthält.", + "notificationRuleIsRoomMention": "Chat-Erwähnung", + "notificationRuleRoomnotif": "Chat-Benachritigung", + "notificationRuleTombstoneDescription": "Benachrichtigt den Benutzer über Nachrichten zur Raumdeaktivierung.", + "notificationRuleEncryptedRoomOneToOne": "Verschlüsselter Einzelchat", + "notificationRuleRoomOneToOne": "Einzelchat", + "notificationRuleServerAclDescription": "Unterdrückt Benachrichtigungen für Server-ACL-Ereignisse.", + "unknownPushRule": "Unbekannte Push-Regel '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Wenn Sie diese Benachrichtigungseinstellung löschen, kann dies nicht rückgängig gemacht werden.", + "crossVerifiedDevices": "Cross-verifizierte Geräte", + "notificationRuleIsRoomMentionDescription": "Benachrichtigt den Benutzer, wenn ein Raum erwähnt wird.", + "notificationRuleRoomServerAcl": "Raumserver-ACL", + "crossVerifiedDevicesIfEnabled": "Cross-verifizierte Geräte, falls aktiviert", + "notificationRuleServerAcl": "Unterdrücken von Server-ACL-Ereignissen", + "notificationRuleMemberEventDescription": "Unterdrückt Benachrichtigungen zu Mitgliedschaftsereignissen.", + "sentVoiceMessage": "🎙️ {duration} - Sprachnachricht von {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "normalUser": "Normaler Benutzer", + "setCustomPermissionLevel": "Benutzerdefinierte Berechtigungsstufe festlegen", + "setPermissionsLevelDescription": "Bitte wählen Sie unten eine vordefinierte Rolle aus oder geben Sie eine benutzerdefinierte Berechtigungsstufe zwischen 0 und 100 ein.", + "approve": "Genehmigen", + "youHaveKnocked": "Du hast geklopft", + "pleaseWaitUntilInvited": "Bitte warte nun, bis dich jemand aus dem Raum auffordert.", + "notificationRuleTombstone": "Tombstone", + "commandHint_logout": "Aktuelles Gerät abmelden", + "commandHint_logoutall": "Alle aktiven Geräte abmelden", + "displayNavigationRail": "Navigationsleiste auf dem Smartphone anzeigen", + "customReaction": "Benutzerdefinierte Reaktion", + "moreEvents": "Weitere Ereignisse", + "declineInvitation": "Einladung ablehnen", + "noMessagesYet": "Noch keine Nachrichten", + "longPressToRecordVoiceMessage": "Lange drücken, um eine Sprachnachricht aufzunehmen.", + "pause": "Pause", + "newSubSpace": "Neuer Sub-Space", + "moveToDifferentSpace": "In einen anderen space wechseln", + "moveUp": "Nach oben", + "moveDown": "Nach unten", + "removeFromSpaceDescription": "Der Chat wird aus dem Space entfernt, erscheint aber weiterhin in Ihrer Chatliste.", + "countChats": "{chats} Chats", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Space-Mitglieder von {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Space-Mitglieder von {spaces} kann klopfen", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Spenden", + "resume": "Fortsetzen", + "startedAPoll": "{username} hat eine Umfrage gestartet.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Umfrage", + "startPoll": "Umfrage starten", + "endPoll": "Umfrage beenden", + "answersVisible": "Antworten sichtbar", + "answersHidden": "Antworten sind verborgen", + "pollQuestion": "Frage", + "answerOption": "Antwortmöglichkeit", + "addAnswerOption": "Antwortoption hinzufügen", + "allowMultipleAnswers": "Mehrere Antworten zulassen", + "pollHasBeenEnded": "Umfrage ist beendet", + "countVotes": "{count, plural, =1{Eine Stimme} other{{count} Stimmen}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Die Antworten werden nach Ende der Umfrage sichtbar sein", + "replyInThread": "Im Thread antworten", + "countReplies": "{count, plural, =1{Eine Antwort} other{{count} Antworten}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Thread", + "backToMainChat": "Zurück zum Hauptchat", + "changedTheChatDescription": "{username} hat die Chatbeschreibung geändert", + "changedTheChatName": "{username} den Chatnamen geändert", + "saveChanges": "Änderungen speichern", + "skipChatBackup": "Chatsicherung überspringen", + "skipChatBackupWarning": "Bist du sicher? Ohne die Chatsicherung zu aktivieren, kannst du den Zugriff auf deine Nachrichten verlieren, wenn du dein Gerät wechselst.", + "loadingMessages": "Nachrichten werden geladen", + "setupChatBackup": "Chatsicherung einrichten", + "createSticker": "Sticker oder Emoji erstellen", + "useAsSticker": "Als Sticker verwenden", + "useAsEmoji": "Als Emoji verwenden", + "stickerPackNameAlreadyExists": "Name des Sticker-Pakets existiert bereits", + "newStickerPack": "Neues Sticker-Paket", + "stickerPackName": "Name des Sticker-Pakets", + "noMoreResultsFound": "Keine weiteren Ergebnisse gefunden", + "chatSearchedUntil": "Chat durchsucht bis {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "attribution": "Attribuierung", + "identityServer": "Identitätsserver:", + "versionWithNumber": "Version: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Protokolle", + "baseUrl": "Basis-URL", + "advancedConfigs": "Erweiterte Konfigurationen", + "advancedConfigurations": "Erweiterte Konfigurationen", + "signIn": "Anmelden", + "createNewAccount": "Neues Konto erstellen", + "signUpGreeting": "FluffyChat ist dezentral! Wähle einen Server, auf dem du dein Konto erstellen möchtest, und los geht's!", + "signInGreeting": "Du hast bereits ein Konto bei Matrix? Willkommen zurück! Wähle deinen Homeserver aus und melde dich an.", + "appIntro": "Mit FluffyChat kannst du mit deinen Freunden chatten. Es ist ein sicherer, dezentralisierter [Matrix]-Messenger! Erfahre mehr auf https://matrix.org, wenn du möchtest, oder melde dich einfach an.", + "theProcessWasCanceled": "Der Vorgang wurde abgebrochen.", + "federationBaseUrl": "Basis-URL der Föderation", + "clientWellKnownInformation": "Bekannte Informationen zum Client:", + "join": "Beitreten", + "searchOrEnterHomeserverAddress": "Homeserver-Adresse suchen oder eingeben", + "matrixId": "Matrix ID" +} diff --git a/lib/l10n/intl_el.arb b/lib/l10n/intl_el.arb new file mode 100644 index 000000000..24b1e2ea3 --- /dev/null +++ b/lib/l10n/intl_el.arb @@ -0,0 +1,503 @@ +{ + "hugContent": "{senderName} σε αγκαλιάζει", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_cuddle": "Στείλε μια αγκαλιά", + "@commandHint_cuddle": {}, + "admin": "Διαχειριστής", + "@admin": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "Αποκλεισμός Συσκευής", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "supposedMxid": "Αυτό θα πρέπει να είναι {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "banFromChat": "Αποκλεισμός από τη συνομιλία", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Για να μπορέσεις να υπογράψεις το άλλο άτομο, πληκτρολόγησε τη συνθηματική φράση ασφαλούς αποθήκευσης ή το κλειδί ανάκτησης.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "remove": "Αφαίρεση", + "@remove": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Επιτρέπεται στους επισκέπτες χρήστες να συμμετάσχουν", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "blocked": "Αποκλείστηκε", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Αποστολή με enter", + "@sendOnEnter": {}, + "answeredTheCall": "{senderName} απάντησε στην κλήση", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "alias": "ψευδώνυμο", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Όλα", + "@all": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "Ο οικιακός διακομιστής υποστηρίζει τους τύπους σύνδεσης:\n{serverVersions}\nΑλλά αυτή η εφαρμογή υποστηρίζει μόνο:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "cantOpenUri": "Δεν μπορεί να ανοίξει το URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "importFromZipFile": "Εισαγωγή από αρχείο .zip", + "@importFromZipFile": {}, + "autoplayImages": "Αυτόματη αναπαραγωγή κινούμενων αυτοκόλλητων και emotes", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "repeatPassword": "Επανάληψη κωδικού πρόσβασης", + "@repeatPassword": {}, + "acceptedTheInvitation": "👍 {username} αποδέχτηκε την πρόσκληση", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banned": "Αποκλείστηκε", + "@banned": { + "type": "String", + "placeholders": {} + }, + "exportEmotePack": "Εξαγωγή πακέτου Emote ως .zip", + "@exportEmotePack": {}, + "account": "Λογαριασμός", + "@account": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Σίγουρα;", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "allChats": "Όλες οι συνομιλίες", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "Ο οικιακός διακομιστής υποστηρίζει τις εκδόσεις Spec:\n{serverVersions}\nΑλλά αυτή η εφαρμογή υποστηρίζει μόνο {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "addToSpace": "Προσθήκη στο χώρο", + "@addToSpace": {}, + "about": "Σχετικά", + "@about": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} ενεργοποίησε την κρυπτογράφηση από άκρο σε άκρο", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "googlyEyesContent": "{senderName} σού στέλνει αστεία μάτια", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "addChatDescription": "Πρόσθεσε μια περιγραφή συνομιλίας...", + "@addChatDescription": {}, + "cancel": "Ακύρωση", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "appLock": "Κλείδωμα εφαρμογής", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "sendTypingNotifications": "Αποστολή ειδοποιήσεων πληκτρολόγησης", + "@sendTypingNotifications": {}, + "importEmojis": "Εισαγωγή Emojis", + "@importEmojis": {}, + "confirmMatrixId": "Παρακαλούμε επιβεβαίωσε το Matrix ID σου για να διαγράψεις τον λογαριασμό σου.", + "@confirmMatrixId": {}, + "notAnImage": "Δεν είναι αρχείο εικόνας.", + "@notAnImage": {}, + "areYouSureYouWantToLogout": "Σίγουρα θες να αποσυνδεθείς;", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} απέκλεισε {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} σέ αγκαλιάζει", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "askVerificationRequest": "Αποδοχή αυτού του αιτήματος επαλήθευσης από {username};", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Προσθήκη email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "commandHint_hug": "Στείλτε μια αγκαλιά", + "@commandHint_hug": {}, + "replace": "Αντικατάσταση", + "@replace": {}, + "archive": "Αρχείο", + "@archive": { + "type": "String", + "placeholders": {} + }, + "accept": "Αποδοχή", + "@accept": { + "type": "String", + "placeholders": {} + }, + "commandHint_googly": "Στείλε αστεία μάτια", + "@commandHint_googly": {}, + "botMessages": "Μηνύματα bot", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "importNow": "Εισαγωγή τώρα", + "@importNow": {}, + "anyoneCanJoin": "Οποιοσδήποτε μπορεί να συμμετάσχει", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "alwaysUse24HourFormat": "Ψευδής", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "setCustomPermissionLevel": "Όρισε προσαρμοσμένο επίπεδο άδειας", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Επέλεξε έναν προκαθορισμένο ρόλο παρακάτω ή εισήγαγε ένα προσαρμοσμένο επίπεδο άδειας μεταξύ 0 και 100.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Αγνόηση χρήστη", + "@ignoreUser": {}, + "normalUser": "Κανονικός χρήστης", + "@normalUser": {}, + "aboutHomeserver": "Σχετικά με {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "commandHint_roomupgrade": "Αναβάθμιση αυτού του δωματίου στην δεδομένη έκδοση δωματίου", + "@commandHint_roomupgrade": {}, + "appLockDescription": "Κλείδωμα εφαρμογής όταν δεν χρησιμοποιείται με κωδικό PIN", + "@appLockDescription": {}, + "swipeRightToLeftToReply": "Σύρσιμο δεξιά προς αριστερά για απάντηση", + "@swipeRightToLeftToReply": {}, + "countChatsAndCountParticipants": "{chats} συνομιλίες και {participants} συμμετέχοντες", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Δεν βρέθηκαν άλλες συνομιλίες...", + "@noMoreChatsFound": {}, + "noChatsFoundHere": "Δεν υπάρχουν συνομιλίες ακόμα. Ξεκίνα μια νέα συνομιλία με κάποιον χρησιμοποιώντας το κουμπί παρακάτω. ⤵️", + "@noChatsFoundHere": {}, + "unread": "Μη αναγνωσμένα", + "@unread": {}, + "space": "Χώρος", + "@space": {}, + "spaces": "Χώροι", + "@spaces": {}, + "changeDeviceName": "Αλλαγή ονόματος συσκευής", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} άλλαξε το άβαταρ συνομιλίας", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} άλλαξε την περιγραφή συνομιλίας σε: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} άλλαξε το όνομα συνομιλίας σε: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} άλλαξε τα δικαιώματα συνομιλίας", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} άλλαξε το εμφανιζόμενο όνομά του σε: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} άλλαξε τους κανόνες πρόσβασης των επισκεπτών", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} άλλαξε τους κανόνες πρόσβασης των επισκεπτών σε: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} άλλαξε την ορατότητα ιστορικού", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} άλλαξε την ορατότητα ιστορικού σε: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} άλλαξε τους κανόνες συμμετοχής", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} άλλαξε τους κανόνες συμμετοχής σε: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "Ο χρήστης {username} άλλαξε την εικόνα προφίλ του", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Αλλαγή κωδικού πρόσβασης", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Άλλαξε το στυλ σου", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Αλλαγή εικόνας προφιλ", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "joinedChats": "Συνδεδεμένες συνομιλίες", + "@joinedChats": {}, + "chatBackup": "Αντίγραφο ασφαλείας συνομιλίας", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Λεπτομέρειες συνομιλίας", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Η συνομιλία προστέθηκε στο δωμάτιο", + "@chatHasBeenAddedToThisSpace": {}, + "chats": "Συνομιλίες", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Εισάγετε ένα δυνατό κωδικό πρόσβασης", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Κλείσιμο", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Αποκλεισμός χρήστη από το δωμάτιο", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Εκκαθάριση προσωρινής μνήμης", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_invite": "Πρόσκληση αυτού του χρήστη στο δωμάτιο", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + } +} diff --git a/lib/l10n/intl_en.arb b/lib/l10n/intl_en.arb new file mode 100644 index 000000000..da89e973f --- /dev/null +++ b/lib/l10n/intl_en.arb @@ -0,0 +1,3138 @@ +{ + "@@locale": "en", + "@@last_modified": "2021-08-14 12:38:37.885451", + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "repeatPassword": "Repeat password", + "notAnImage": "Not an image file.", + "setCustomPermissionLevel": "Set custom permission level", + "setPermissionsLevelDescription": "Please choose a predefined role below or enter a custom permission level between 0 and 100.", + "ignoreUser": "Ignore user", + "normalUser": "Normal user", + "remove": "Remove", + "@remove": { + "type": "String", + "placeholders": {} + }, + "importNow": "Import now", + "importEmojis": "Import Emojis", + "importFromZipFile": "Import from .zip file", + "exportEmotePack": "Export Emote pack as .zip", + "replace": "Replace", + "about": "About", + "aboutHomeserver": "About {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "accept": "Accept", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} accepted the invitation", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Account", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} activated end to end encryption", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Add email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Please confirm your Matrix ID in order to delete your account.", + "supposedMxid": "This should be {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "Add a chat description...", + "addToSpace": "Add to space", + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "All", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "All chats", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_roomupgrade": "Upgrade this room to the given room version", + "commandHint_googly": "Send some googly eyes", + "commandHint_cuddle": "Send a cuddle", + "commandHint_hug": "Send a hug", + "googlyEyesContent": "{senderName} sends you googly eyes", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} cuddles you", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} hugs you", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "answeredTheCall": "{senderName} answered the call", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Anyone can join", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "App lock", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "Lock the app when not using with a pin code", + "archive": "Archive", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Are guest users allowed to join?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Are you sure?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Are you sure you want to log out?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "To be able to sign the other person, please enter your secure store passphrase or recovery key.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Accept this verification request from {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Automatically play animated stickers and emotes", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "The homeserver supports the login types:\n{serverVersions}\nBut this app supports only:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendTypingNotifications": "Send typing notifications", + "swipeRightToLeftToReply": "Swipe right to left to reply", + "sendOnEnter": "Send on enter", + "badServerVersionsException": "The homeserver supports the Spec versions:\n{serverVersions}\nBut this app supports only {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "countChatsAndCountParticipants": "{chats} chats and {participants} participants", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "No more chats found...", + "noChatsFoundHere": "No chats found here yet. Start a new chat with someone by using the button below. ⤵️", + "joinedChats": "Joined chats", + "unread": "Unread", + "space": "Space", + "spaces": "Spaces", + "banFromChat": "Ban from chat", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Banned", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} banned {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Block Device", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Blocked", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot messages", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Cancel", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Can't open the URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Change device name", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} changed the chat avatar", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescription": "{username} changed the chat description", + "changedTheChatDescriptionTo": "{username} changed the chat description to: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatName": "{username} changed the chat name", + "changedTheChatNameTo": "{username} changed the chat name to: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} changed the chat permissions", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} changed their displayname to: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} changed the guest access rules", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} changed the guest access rules to: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} changed the history visibility", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} changed the history visibility to: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} changed the join rules", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} changed the join rules to: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} changed their avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} changed the room aliases", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} changed the invitation link", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Change password", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Change the homeserver", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Change your style", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Change the name of the group", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Change your avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "The encryption has been corrupted", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Your chat backup has been set up.", + "chatBackup": "Chat backup", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Your messages are secured with a recovery key. Please make sure you don't lose it.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Chat details", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Chat has been added to this space", + "chats": "Chats", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Choose a strong password", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Clear archive", + "close": "Close", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasdm": "Mark as direct message room for the giving Matrix ID", + "commandHint_markasgroup": "Mark as group", + "commandHint_ban": "Ban the given user from this room", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Clear cache", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Create an empty group chat\nUse --no-encryption to disable encryption", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Discard session", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Start a direct chat\nUse --no-encryption to disable encryption", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_html": "Send HTML-formatted text", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Invite the given user to this room", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Join the given room", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Remove the given user from this room", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Leave this room", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Describe yourself", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Set your picture for this room (by mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Set your display name for this room", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Set the given user's power level (default: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Send unformatted text", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Send reply as a reaction", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Send text", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Unban the given user from this room", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Command invalid", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} is not a command.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Please compare the emojis", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Please compare the numbers", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Configure chat", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Confirm", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Connect", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Contact has been invited to the group", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Contains display name", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Contains username", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "The content has been reported to the server admins", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Copied to clipboard", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Copy", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Copy to clipboard", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Could not decrypt message: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "checkList": "Check list", + "countParticipants": "{count} participants", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "countInvited": "{count} invited", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Create", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} created the chat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createGroup": "Create group", + "createNewSpace": "New space", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Currently active", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Dark", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "This will deactivate your user account. This can not be undone! Are you sure?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Default permission level for new users", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Delete", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Delete account", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Delete message", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Device", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Device ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Devices", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Direct Chats", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "allRooms": "All Group Chats", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Displayname has been changed", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Download file", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Edit", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Edit blocked servers", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "Chat permissions", + "editDisplayname": "Edit displayname", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Edit room aliases", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Edit room avatar", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emote already exists!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Invalid emote shortcode!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteKeyboardNoRecents": "Recently-used emotes will appear here...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Emote packs for room", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emote Settings", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "Global chat ID", + "accessAndVisibility": "Access and visibility", + "accessAndVisibilityDescription": "Who is allowed to join this chat and how the chat can be discovered.", + "calls": "Calls", + "customEmojisAndStickers": "Custom emojis and stickers", + "customEmojisAndStickersBody": "Add or share custom emojis or stickers which can be used in any chat.", + "emoteShortcode": "Emote shortcode", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "You need to pick an emote shortcode and an image!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Empty chat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Enable emote pack globally", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Enable encryption", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "You won't be able to disable the encryption anymore. Are you sure?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Encrypted", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Encryption", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Encryption is not enabled", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} ended the call", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Enter an email address", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Homeserver", + "enterYourHomeserver": "Enter your homeserver", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Error obtaining location: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Everything ready!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extremely offensive", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "File name", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Font size", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Forward", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "From joining", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "From the invitation", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Go to the new room", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Group", + "@group": { + "type": "String", + "placeholders": {} + }, + "chatDescription": "Chat description", + "chatDescriptionHasBeenChanged": "Chat description changed", + "groupIsPublic": "Group is public", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Groups", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Group with {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Guests are forbidden", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Guests can join", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} has withdrawn the invitation for {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Help", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Hide redacted events", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideRedactedMessages": "Hide redacted messages", + "hideRedactedMessagesBody": "If someone redacts a message, this message won't be visible in the chat anymore.", + "hideInvalidOrUnknownMessageFormats": "Hide invalid or unknown message formats", + "howOffensiveIsThisContent": "How offensive is this content?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identity", + "@identity": { + "type": "String", + "placeholders": {} + }, + "block": "Block", + "blockedUsers": "Blocked users", + "blockListDescription": "You can block users who are disturbing you. You won't be able to receive any messages or room invites from the users on your personal block list.", + "blockUsername": "Ignore username", + "iHaveClickedOnLink": "I have clicked on the link", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Incorrect passphrase or recovery key", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Inoffensive", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Invite contact", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroupQuestion": "Do you want to invite {contact} to the chat \"{groupName}\"?", + "inviteContactToGroup": "Invite contact to {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "No chat description created yet.", + "tryAgain": "Try again", + "invalidServerName": "Invalid server name", + "invited": "Invited", + "@invited": { + "type": "String", + "placeholders": {} + }, + "redactMessageDescription": "The message will be redacted for all participants in this conversation. This cannot be undone.", + "optionalRedactReason": "(Optional) Reason for redacting this message...", + "invitedUser": "📩 {username} invited {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Invited users only", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Invite for me", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} invited you to FluffyChat.\n1. Visit fluffychat.im and install the app \n2. Sign up or sign in \n3. Open the invite link: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "is typing…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} joined the chat", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Join room", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} kicked {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} kicked and banned {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Kick from chat", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Last active: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Leave", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Left the chat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "License", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Light", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Load {count} more participants", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrate": "Export session and wipe device", + "dehydrateWarning": "This action cannot be undone. Ensure you safely store the backup file.", + "dehydrateTor": "TOR Users: Export session", + "dehydrateTorLong": "For TOR users, it is recommended to export the session before closing the window.", + "hydrateTor": "TOR Users: Import session export", + "hydrateTorLong": "Did you export your session last time on TOR? Quickly import it and continue chatting.", + "hydrate": "Restore from backup file", + "loadingPleaseWait": "Loading… Please wait.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Load more…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Location services are disabled. Please enable them to be able to share your location.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Location permission denied. Please grant them to be able to share your location.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Login", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Log in to {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Logout", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Member changes", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Mention", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Messages", + "@messages": { + "type": "String", + "placeholders": {} + }, + "messagesStyle": "Messages:", + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Mute chat", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Please be aware that you need Pantalaimon to use end-to-end encryption for now.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "New chat", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 New message in FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "New verification request!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Next", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "No", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "No connection to the server", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "No emotes found. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "You can only activate encryption as soon as the room is no longer publicly accessible.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Firebase Cloud Messaging doesn't appear to be available on your device. To still receive push notifications, we recommend installing ntfy. With ntfy or another Unified Push provider you can receive push notifications in a data secure way. You can download ntfy from the PlayStore or from F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} is no matrix server, use {server2} instead?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "shareInviteLink": "Share invite link", + "scanQrCode": "Scan QR code", + "none": "None", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "You have not added a way to recover your password yet.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "No permission", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "No rooms found…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notifications", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Notifications enabled for this account", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} users are typing…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Obtaining location…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Offensive", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Offline", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Online", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Online Key Backup is enabled", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Oops! Unfortunately, an error occurred when setting up the push notifications.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Oops, something went wrong…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Open app to read messages", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Open camera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Open camera for a video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "One of your clients has been logged out", + "addAccount": "Add account", + "editBundlesForAccount": "Edit bundles for this account", + "addToBundle": "Add to bundle", + "removeFromBundle": "Remove from this bundle", + "bundleName": "Bundle name", + "enableMultiAccounts": "(BETA) Enable multi accounts on this device", + "openInMaps": "Open in maps", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "link": "Link", + "serverRequiresEmail": "This server needs to validate your email address for registration.", + "or": "Or", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Participant", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "passphrase or recovery key", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Password", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Password forgotten", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Password has been changed", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "hideMemberChangesInPublicChats": "Hide member changes in public chats", + "hideMemberChangesInPublicChatsBody": "Do not show in the chat timeline if someone joins or leaves a public chat to improve readability.", + "overview": "Overview", + "notifyMeFor": "Notify me for", + "passwordRecoverySettings": "Password recovery settings", + "passwordRecovery": "Password recovery", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "People", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Pick an image", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Pin", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Play {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Please choose", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Please choose a pass code", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Please click on the link in the email and then proceed.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Please enter 4 digits or leave empty to disable app lock.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKey": "Please enter your recovery key:", + "pleaseEnterYourPassword": "Please enter your password", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Please enter your pin", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Please enter your username", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Please follow the instructions on the website and tap on next.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privacy", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Public Rooms", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Push rules", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Reason", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Recording", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedBy": "Redacted by {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Direct chat", + "redactedByBecause": "Redacted by {username} because: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactedAnEvent": "{username} redacted an event", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Redact message", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Register", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Reject", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} rejected the invitation", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Rejoin", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Remove all other devices", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Removed by {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Remove device", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Unban from chat", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Remove your avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Replace room with newer version", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Reply", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Report message", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Request permission", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Room has been upgraded", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Room version", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Save file", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Search", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Security", + "@security": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "Recovery key", + "recoveryKeyLost": "Recovery key lost?", + "seenByUser": "Seen by {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Send", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Send a message", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Send as text", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Send audio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Send file", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Send image", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendImages": "Send {count} image", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendMessages": "Send messages", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Send original", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Send sticker", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Send video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} sent a file", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} sent an audio", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} sent a picture", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} sent a sticker", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} sent a video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} sent call information", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "separateChatTypes": "Separate Direct Chats and Groups", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Set as main alias", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Set custom emotes", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setChatDescription": "Set chat description", + "setInvitationLink": "Set invitation link", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Set permissions level", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Set status", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Settings", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Share", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} shared their location", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Share location", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Show password", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "Presence:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Show status messages from other users", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Single Sign on", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Skip", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Source code", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Space is public", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Space name", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} started a call", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "startFirstChat": "Start your first chat", + "status": "Status", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "How are you today?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Submit", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synchronizing… Please wait.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWaitCounter": " Synchronizing… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "systemTheme": "System", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "They Don't Match", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "They Match", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Toggle Favorite", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Toggle Muted", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Mark Read/Unread", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Too many requests. Please try again later!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Transfer from another device", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Try to send again", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Unavailable", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} unbanned {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Unblock Device", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Unknown device", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Unknown encryption algorithm", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Unknown event '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Unmute chat", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Unpin", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 unread chat} other{{unreadCount} unread chats}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} and {count} others are typing…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} and {username2} are typing…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} is typing…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} left the chat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Username", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} sent a {type} event", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "unverified": "Unverified", + "verified": "Verified", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verify", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Start Verification", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "You successfully verified!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verifying other account", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Video call", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Visibility of the chat history", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Visible for all participants", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Visible for everyone", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Voice message", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Waiting for partner to accept the request…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Waiting for partner to accept the emoji…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Waiting for partner to accept the numbers…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Wallpaper:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Warning!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "We sent you an email", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Who can perform which action", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Who is allowed to join this group", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Why do you want to report this?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Wipe your chat backup to create a new recovery key?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "With these addresses you can recover your password.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Write a message…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Yes", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "You", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "You are no longer participating in this chat", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "You have been banned from this chat", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Your public key", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Message info", + "time": "Time", + "messageType": "Message Type", + "sender": "Sender", + "openGallery": "Open gallery", + "removeFromSpace": "Remove from space", + "addToSpaceDescription": "Select a space to add this chat to it.", + "start": "Start", + "pleaseEnterRecoveryKeyDescription": "To unlock your old messages, please enter your recovery key that has been generated in a previous session. Your recovery key is NOT your password.", + "publish": "Publish", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "openChat": "Open Chat", + "markAsRead": "Mark as read", + "reportUser": "Report user", + "dismiss": "Dismiss", + "reactedWith": "{sender} reacted with {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Pin to room", + "confirmEventUnpin": "Are you sure to permanently unpin the event?", + "emojis": "Emojis", + "placeCall": "Place call", + "voiceCall": "Voice call", + "unsupportedAndroidVersion": "Unsupported Android version", + "unsupportedAndroidVersionLong": "This feature requires a newer Android version. Please check for updates or Lineage OS support.", + "videoCallsBetaWarning": "Please note that video calls are currently in beta. They might not work as expected or work at all on all platforms.", + "experimentalVideoCalls": "Experimental video calls", + "emailOrUsername": "Email or username", + "indexedDbErrorTitle": "Private mode issues", + "indexedDbErrorLong": "The message storage is unfortunately not enabled in private mode by default.\nPlease visit\n - about:config\n - set dom.indexedDB.privateBrowsing.enabled to true\nOtherwise, it is not possible to run FluffyChat.", + "switchToAccount": "Switch to account {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Next account", + "previousAccount": "Previous account", + "addWidget": "Add widget", + "widgetVideo": "Video", + "widgetEtherpad": "Text note", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "Custom", + "widgetName": "Name", + "widgetUrlError": "This is not a valid URL.", + "widgetNameError": "Please provide a display name.", + "errorAddingWidget": "Error adding the widget.", + "youRejectedTheInvitation": "You rejected the invitation", + "youJoinedTheChat": "You joined the chat", + "youAcceptedTheInvitation": "👍 You accepted the invitation", + "youBannedUser": "You banned {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "You have withdrawn the invitation for {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 You have been invited via link to:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 You have been invited by {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "invitedBy": "📩 Invited by {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 You invited {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 You kicked {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 You kicked and banned {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "You unbanned {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hasKnocked": "🚪 {user} has knocked", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Users must knock", + "noOneCanJoin": "No one can join", + "userWouldLikeToChangeTheChat": "{user} would like to join the chat.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "No public link has been created yet", + "knock": "Knock", + "users": "Users", + "unlockOldMessages": "Unlock old messages", + "storeInSecureStorageDescription": "Store the recovery key in the secure storage of this device.", + "saveKeyManuallyDescription": "Save this key manually by triggering the system share dialog or clipboard.", + "storeInAndroidKeystore": "Store in Android KeyStore", + "storeInAppleKeyChain": "Store in Apple KeyChain", + "storeSecurlyOnThisDevice": "Store securely on this device", + "countFiles": "{count} files", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "user": "User", + "custom": "Custom", + "foregroundServiceRunning": "This notification appears when the foreground service is running.", + "screenSharingTitle": "screen sharing", + "screenSharingDetail": "You are sharing your screen in FuffyChat", + "callingPermissions": "Calling permissions", + "callingAccount": "Calling account", + "callingAccountDetails": "Allows FluffyChat to use the native android dialer app.", + "appearOnTop": "Appear on top", + "appearOnTopDetails": "Allows the app to appear on top (not needed if you already have Fluffychat setup as a calling account)", + "otherCallingPermissions": "Microphone, camera and other FluffyChat permissions", + "whyIsThisMessageEncrypted": "Why is this message unreadable?", + "noKeyForThisMessage": "This can happen if the message was sent before you have signed in to your account at this device.\n\nIt is also possible that the sender has blocked your device or something went wrong with the internet connection.\n\nAre you able to read the message on another session? Then you can transfer the message from it! Go to Settings > Devices and make sure that your devices have verified each other. When you open the room the next time and both sessions are in the foreground, the keys will be transmitted automatically.\n\nDo you not want to lose the keys when logging out or switching devices? Make sure that you have enabled the chat backup in the settings.", + "newGroup": "New group", + "newSpace": "New space", + "enterSpace": "Enter space", + "enterRoom": "Enter room", + "allSpaces": "All spaces", + "numChats": "{number} chats", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Hide unimportant state events", + "hidePresences": "Hide Status List?", + "doNotShowAgain": "Do not show again", + "wasDirectChatDisplayName": "Empty chat (was {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "newSpaceDescription": "Spaces allows you to consolidate your chats and build private or public communities.", + "encryptThisChat": "Encrypt this chat", + "disableEncryptionWarning": "For security reasons you can not disable encryption in a chat, where it has been enabled before.", + "sorryThatsNotPossible": "Sorry... that is not possible", + "deviceKeys": "Device keys:", + "reopenChat": "Reopen chat", + "noBackupWarning": "Warning! Without enabling chat backup, you will lose access to your encrypted messages. It is highly recommended to enable the chat backup first before logging out.", + "noOtherDevicesFound": "No other devices found", + "fileIsTooBigForServer": "Unable to send! The server only supports attachments up to {max}.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "File has been saved at {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Jump to last read message", + "readUpToHere": "Read up to here", + "jump": "Jump", + "openLinkInBrowser": "Open link in browser", + "reportErrorDescription": "😭 Oh no. Something went wrong. If you want, you can report this bug to the developers.", + "report": "report", + "signInWithPassword": "Sign in with password", + "pleaseTryAgainLaterOrChooseDifferentServer": "Please try again later or choose a different server.", + "profileNotFound": "The user could not be found on the server. Maybe there is a connection problem or the user doesn't exist.", + "setTheme": "Set theme:", + "setColorTheme": "Set color theme:", + "invite": "Invite", + "inviteGroupChat": "📨 Group chat invite", + "invitePrivateChat": "📨 Private chat invite", + "invalidInput": "Invalid input!", + "wrongPinEntered": "Wrong pin entered! Try again in {seconds} seconds...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pleaseEnterANumber": "Please enter a number greater than 0", + "archiveRoomDescription": "The chat will be moved to the archive. Other users will be able to see that you have left the chat.", + "roomUpgradeDescription": "The chat will then be recreated with the new room version. All participants will be notified that they need to switch to the new chat. You can find out more about room versions at https://spec.matrix.org/latest/rooms/", + "removeDevicesDescription": "You will be logged out of this device and will no longer be able to receive messages.", + "banUserDescription": "The user will be banned from the chat and will not be able to enter the chat again until they are unbanned.", + "unbanUserDescription": "The user will be able to enter the chat again if they try.", + "kickUserDescription": "The user is kicked out of the chat but not banned. In public chats, the user can rejoin at any time.", + "makeAdminDescription": "Once you make this user admin, you may not be able to undo this as they will then have the same permissions as you.", + "pushNotificationsNotAvailable": "Push notifications not available", + "learnMore": "Learn more", + "yourGlobalUserIdIs": "Your global user-ID is: ", + "noUsersFoundWithQuery": "Unfortunately no user could be found with \"{query}\". Please check whether you made a typo.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "knocking": "Knocking", + "chatCanBeDiscoveredViaSearchOnServer": "Chat can be discovered via the search on {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchChatsRooms": "Search for #chats, @users...", + "nothingFound": "Nothing found...", + "groupName": "Group name", + "createGroupAndInviteUsers": "Create a group and invite users", + "groupCanBeFoundViaSearch": "Group can be found via search", + "wrongRecoveryKey": "Sorry... this does not seem to be the correct recovery key.", + "startConversation": "Start conversation", + "commandHint_sendraw": "Send raw json", + "databaseMigrationTitle": "Database is optimized", + "databaseMigrationBody": "Please wait. This may take a moment.", + "leaveEmptyToClearStatus": "Leave empty to clear your status.", + "select": "Select", + "searchForUsers": "Search for @users...", + "pleaseEnterYourCurrentPassword": "Please enter your current password", + "newPassword": "New password", + "pleaseChooseAStrongPassword": "Please choose a strong password", + "passwordsDoNotMatch": "Passwords do not match", + "passwordIsWrong": "Your entered password is wrong", + "publicLink": "Public link", + "publicChatAddresses": "Public chat addresses", + "createNewAddress": "Create new address", + "joinSpace": "Join space", + "publicSpaces": "Public spaces", + "addChatOrSubSpace": "Add chat or sub space", + "subspace": "Subspace", + "decline": "Decline", + "thisDevice": "This device:", + "initAppError": "An error occured while init the app", + "userRole": "User role", + "minimumPowerLevel": "{level} is the minimum power level.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "Search in chat \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Search more...", + "gallery": "Gallery", + "files": "Files", + "databaseBuildErrorBody": "Unable to build the SQlite database. The app tries to use the legacy database for now. Please report this error to the developers at {url}. The error message is: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Your session is lost. Please report this error to the developers at {url}. The error message is: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "The app now tries to restore your session from the backup. Please report this error to the developers at {url}. The error message is: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Forward message to {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Send read receipts", + "sendTypingNotificationsDescription": "Other participants in a chat can see when you are typing a new message.", + "sendReadReceiptsDescription": "Other participants in a chat can see when you have read a message.", + "formattedMessages": "Formatted messages", + "formattedMessagesDescription": "Display rich message content like bold text using markdown.", + "verifyOtherUser": "🔐 Verify other user", + "verifyOtherUserDescription": "If you verify another user, you can be sure that you know who you are really writing to. 💪\n\nWhen you start a verification, you and the other user will see a popup in the app. There you will then see a series of emojis or numbers that you have to compare with each other.\n\nThe best way to do this is to meet up or start a video call. 👭", + "verifyOtherDevice": "🔐 Verify other device", + "verifyOtherDeviceDescription": "When you verify another device, those devices can exchange keys, increasing your overall security. 💪 When you start a verification, a popup will appear in the app on both devices. There you will then see a series of emojis or numbers that you have to compare with each other. It's best to have both devices handy before you start the verification. 🤳", + "acceptedKeyVerification": "{sender} accepted key verification", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} canceled key verification", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} completed key verification", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} is ready for key verification", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} requested key verification", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} started key verification", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Transparent", + "incomingMessages": "Incoming messages", + "stickers": "Stickers", + "discover": "Discover", + "commandHint_ignore": "Ignore the given matrix ID", + "commandHint_unignore": "Unignore the given matrix ID", + "unreadChatsInApp": "{appname}: {unread} unread chats", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Database encryption is not supported on this platform", + "thereAreCountUsersBlocked": "Right now there are {count} users blocked.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "Restricted", + "knockRestricted": "Knock restricted", + "goToSpace": "Go to space: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Mark as unread", + "userLevel": "{level} - User", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Admin", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Change general chat settings", + "inviteOtherUsers": "Invite other users to this chat", + "changeTheChatPermissions": "Change the chat permissions", + "changeTheVisibilityOfChatHistory": "Change the visibility of the chat history", + "changeTheCanonicalRoomAlias": "Change the main public chat address", + "sendRoomNotifications": "Send a @room notifications", + "changeTheDescriptionOfTheGroup": "Change the description of the chat", + "chatPermissionsDescription": "Define which power level is necessary for certain actions in this chat. The power levels 0, 50 and 100 are usually representing users, moderators and admins, but any gradation is possible.", + "updateInstalled": "🎉 Update {version} installed!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Changelog", + "sendCanceled": "Sending canceled", + "loginWithMatrixId": "Login with Matrix-ID", + "discoverHomeservers": "Discover homeservers", + "whatIsAHomeserver": "What is a homeserver?", + "homeserverDescription": "All your data is stored on the homeserver, just like an email provider. You can choose which homeserver you want to use, while you can still communicate with everyone. Learn more at at https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Doesn't seem to be a compatible homeserver. Wrong URL?", + "calculatingFileSize": "Calculating file size...", + "prepareSendingAttachment": "Prepare sending attachment...", + "sendingAttachment": "Sending attachment...", + "generatingVideoThumbnail": "Generating video thumbnail...", + "compressVideo": "Compressing video...", + "sendingAttachmentCountOfCount": "Sending attachment {index} of {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Server limit reached! Waiting {seconds} seconds...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "One of your devices is not verified", + "noticeChatBackupDeviceVerification": "Note: When you connect all your devices to the chat backup, they are automatically verified.", + "continueText": "Continue", + "welcomeText": "Hey Hey 👋 This is FluffyChat. You can sign in to any homeserver, which is compatible with https://matrix.org. And then chat with anyone. It's a huge decentralized messaging network!", + "blur": "Blur:", + "opacity": "Opacity:", + "setWallpaper": "Set wallpaper", + "manageAccount": "Manage account", + "noContactInformationProvided": "Server does not provide any valid contact information", + "contactServerAdmin": "Contact server admin", + "contactServerSecurity": "Contact server security", + "supportPage": "Support page", + "serverInformation": "Server information:", + "name": "Name", + "version": "Version", + "website": "Website", + "compress": "Compress", + "boldText": "Bold text", + "italicText": "Italic text", + "strikeThrough": "Strikethrough", + "pleaseFillOut": "Please fill out", + "invalidUrl": "Invalid url", + "addLink": "Add link", + "unableToJoinChat": "Unable to join chat. Maybe the other party has already closed the conversation.", + "previous": "Previous", + "otherPartyNotLoggedIn": "The other party is currently not logged in and therefore cannot receive messages!", + "appWantsToUseForLogin": "Use '{server}' to log in", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "You hereby allow the app and website to share information about you.", + "open": "Open", + "waitingForServer": "Waiting for server...", + "appIntroduction": "FluffyChat lets you chat with your friends across different messengers. Learn more at https://matrix.org or just tap *Continue*.", + "newChatRequest": "📩 New chat request", + "contentNotificationSettings": "Content notification settings", + "generalNotificationSettings": "General notification settings", + "roomNotificationSettings": "Room notification settings", + "userSpecificNotificationSettings": "User specific notification settings", + "otherNotificationSettings": "Other notification settings", + "notificationRuleContainsUserName": "Contains User Name", + "notificationRuleContainsUserNameDescription": "Notifies the user when a message contains their username.", + "notificationRuleMaster": "Mute all notifications", + "notificationRuleMasterDescription": "Overrides all other rules and disables all notifications.", + "notificationRuleSuppressNotices": "Suppress Automated Messages", + "notificationRuleSuppressNoticesDescription": "Suppresses notifications from automated clients like bots.", + "notificationRuleInviteForMe": "Invite for Me", + "notificationRuleInviteForMeDescription": "Notifies the user when they are invited to a room.", + "notificationRuleMemberEvent": "Member Event", + "notificationRuleMemberEventDescription": "Suppresses notifications for membership events.", + "notificationRuleIsUserMention": "User Mention", + "notificationRuleIsUserMentionDescription": "Notifies the user when they are directly mentioned in a message.", + "notificationRuleContainsDisplayName": "Contains Display Name", + "notificationRuleContainsDisplayNameDescription": "Notifies the user when a message contains their display name.", + "notificationRuleIsRoomMention": "Room Mention", + "notificationRuleIsRoomMentionDescription": "Notifies the user when there is a room mention.", + "notificationRuleRoomnotif": "Room Notification", + "notificationRuleRoomnotifDescription": "Notifies the user when a message contains '@room'.", + "notificationRuleTombstone": "Tombstone", + "notificationRuleTombstoneDescription": "Notifies the user about room deactivation messages.", + "notificationRuleReaction": "Reaction", + "notificationRuleReactionDescription": "Suppresses notifications for reactions.", + "notificationRuleRoomServerAcl": "Room Server ACL", + "notificationRuleRoomServerAclDescription": "Suppresses notifications for room server access control lists (ACL).", + "notificationRuleSuppressEdits": "Suppress Edits", + "notificationRuleSuppressEditsDescription": "Suppresses notifications for edited messages.", + "notificationRuleCall": "Call", + "notificationRuleCallDescription": "Notifies the user about calls.", + "notificationRuleEncryptedRoomOneToOne": "Encrypted Room One-to-One", + "notificationRuleEncryptedRoomOneToOneDescription": "Notifies the user about messages in encrypted one-to-one rooms.", + "notificationRuleRoomOneToOne": "Room One-to-One", + "notificationRuleRoomOneToOneDescription": "Notifies the user about messages in one-to-one rooms.", + "notificationRuleMessage": "Message", + "notificationRuleMessageDescription": "Notifies the user about general messages.", + "notificationRuleEncrypted": "Encrypted", + "notificationRuleEncryptedDescription": "Notifies the user about messages in encrypted rooms.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Notifies the user about Jitsi widget events.", + "notificationRuleServerAcl": "Suppress Server ACL Events", + "notificationRuleServerAclDescription": "Suppresses notifications for Server ACL events.", + "unknownPushRule": "Unknown push rule '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Voice message from {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "If you delete this notification setting, this can not be undone.", + "more": "More", + "shareKeysWith": "Share keys with...", + "shareKeysWithDescription": "Which devices should be trusted so that they can read along your messages in encrypted chats?", + "allDevices": "All devices", + "crossVerifiedDevicesIfEnabled": "Cross verified devices if enabled", + "crossVerifiedDevices": "Cross verified devices", + "verifiedDevicesOnly": "Verified devices only", + "takeAPhoto": "Take a photo", + "recordAVideo": "Record a video", + "optionalMessage": "(Optional) message...", + "notSupportedOnThisDevice": "Not supported on this device", + "enterNewChat": "Enter new chat", + "approve": "Approve", + "youHaveKnocked": "You have knocked", + "pleaseWaitUntilInvited": "Please wait now, until someone from the room invites you.", + "commandHint_logout": "Logout your current device", + "commandHint_logoutall": "Logout all active devices", + "displayNavigationRail": "Show navigation rail on mobile", + "customReaction": "Custom reaction", + "moreEvents": "More events", + "declineInvitation": "Decline invitation", + "noMessagesYet": "No messages yet", + "longPressToRecordVoiceMessage": "Long press to record voice message.", + "pause": "Pause", + "resume": "Resume", + "newSubSpace": "New sub space", + "moveToDifferentSpace": "Move to different space", + "moveUp": "Move up", + "moveDown": "Move down", + "removeFromSpaceDescription": "The chat will be removed from the space but still appear in your chat list.", + "countChats": "{chats} chats", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Space member of {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Space member of {spaces} can knock", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Donate", + "startedAPoll": "{username} started a poll.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Poll", + "startPoll": "Start poll", + "endPoll": "End poll", + "answersVisible": "Answers visible", + "answersHidden": "Answers hidden", + "pollQuestion": "Poll question", + "answerOption": "Answer option", + "addAnswerOption": "Add answer option", + "allowMultipleAnswers": "Allow multiple answers", + "pollHasBeenEnded": "Poll has been ended", + "countVotes": "{count, plural, =1{One vote} other{{count} votes}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Answers will be visible when poll has ended", + "replyInThread": "Reply in thread", + "countReplies": "{count, plural, =1{One reply} other{{count} replies}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Thread", + "backToMainChat": "Back to main chat", + "saveChanges": "Save changes", + "createSticker": "Create sticker or emoji", + "useAsSticker": "Use as sticker", + "useAsEmoji": "Use as emoji", + "stickerPackNameAlreadyExists": "Sticker pack name already exists", + "newStickerPack": "New sticker pack", + "stickerPackName": "Sticker pack name", + "attribution": "Attribution", + "skipChatBackup": "Skip chat backup", + "skipChatBackupWarning": "Are you sure? Without enabling the chat backup you may lose access to your messages if you switch your device.", + "loadingMessages": "Loading messages", + "setupChatBackup": "Set up chat backup", + "noMoreResultsFound": "No more results found", + "chatSearchedUntil": "Chat searched until {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "Federation Base URL", + "clientWellKnownInformation": "Client-Well-Known Information:", + "baseUrl": "Base URL", + "identityServer": "Identity Server:", + "versionWithNumber": "Version: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Logs", + "advancedConfigs": "Advanced Configs", + "advancedConfigurations": "Advanced configurations", + "signIn": "Sign in", + "createNewAccount": "Create new account", + "signUpGreeting": "FluffyChat is decentralized! Select a server where you want to create your account and let's go!", + "signInGreeting": "You already have an account in Matrix? Welcome back! Select your homeserver and sign in.", + "appIntro": "With FluffyChat you can chat with your friends. It's a secure decentralized [matrix] messenger! Learn more on https://matrix.org if you like or just sign up.", + "theProcessWasCanceled": "The process was canceled.", + "join": "Join", + "searchOrEnterHomeserverAddress": "Search or enter homeserver address", + "matrixId": "Matrix ID", + "setPowerLevel": "Set power level", + "makeModerator": "Make moderator", + "makeAdmin": "Make admin", + "removeModeratorRights": "Remove moderator rights", + "removeAdminRights": "Remove admin rights", + "powerLevel": "Power level", + "setPowerLevelDescription": "Power levels define what a member is allowed to do in this room and usually range between 0 and 100.", + "owner": "Owner" +} diff --git a/assets/l10n/intl_eo.arb b/lib/l10n/intl_eo.arb similarity index 67% rename from assets/l10n/intl_eo.arb rename to lib/l10n/intl_eo.arb index 2cda9beb9..44b04049f 100644 --- a/assets/l10n/intl_eo.arb +++ b/lib/l10n/intl_eo.arb @@ -2,1899 +2,2070 @@ "@@last_modified": "2021-08-14 12:41:10.107750", "about": "Prio", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "Akcepti", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "{username} akceptis la inviton", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "Konto", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "activatedEndToEndEncryption": "{username} aktivigis tutvojan ĉifradon", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "addEmail": "Aldoni retpoŝtadreson", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "admin": "Administranto", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "kromnomo", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "Ĉio", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "allChats": "Ĉiuj babiloj", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "answeredTheCall": "{senderName} respondis la vokon", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "Ĉiu ajn povas aliĝi", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "appLock": "Ŝlosado", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "Arĥivo", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "Ĉu gastoj rajtas aliĝi", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "Ĉu vi certas?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSureYouWantToLogout": "Ĉu vi certe volas adiaŭi?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "Por ke vi povu kontroli (subskribi) la alian personon, bonvolu enigi pasfrazon de via sekreta deponejo aŭ vian rehavan ŝlosilon.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "Ĉu akcepti ĉi tiun kontrolpeton de {username}?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "badServerLoginTypesException": "La hejmservilo subtenas la jenajn specojn de salutoj:\n{serverVersions}\nSed ĉi tiu aplikaĵo subtenas nur:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "badServerVersionsException": "La hejmservilo subtenas la jenajn version de la specifaĵo:\n{serverVersions}\nSed ĉi tiu aplikaĵo subtenas nur {supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "banFromChat": "Forbari de babilo", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "Forbarita", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "{username} forbaris uzanton {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "blockDevice": "Bloki aparaton", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "Blokita", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "Mesaĝoj de robotoj", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "Nuligi", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "cantOpenUri": "Ne povis malfermi URI {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "changeDeviceName": "Ŝanĝi nomon de aparato", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "{username} ŝanĝis bildon de la babilo", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "{username} ŝanĝis priskribon de la babilo al: «{description}»", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheChatNameTo": "{username} ŝanĝis nomon de la babilo al: «{chatname}»", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheChatPermissions": "{username} ŝanĝis permesojn pri la babilo", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheDisplaynameTo": "{username} ŝanĝis sian prezentan nomon al: {username}", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username} ŝanĝis regulojn pri aliro de gastoj", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username} ŝanĝis regulojn pri aliro de gastoj al: {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheHistoryVisibility": "{username} ŝanĝis videblecon de la historio", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "{username} ŝanĝis videblecon de la historio al: {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRules": "{username} ŝanĝis regulojn pri aliĝado", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username} ŝanĝis regulojn pri aliĝado al: {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username} ŝanĝis sian profilbildon", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomAliases": "{username} ŝanĝis la kromnomojn de la ĉambro", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "{username} ŝanĝis la invitan ligilon", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changePassword": "Ŝanĝi pasvorton", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheHomeserver": "Ŝanĝi hejmservilon", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "Ŝanĝu la haŭton", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheNameOfTheGroup": "Ŝanĝi nomon de la grupo", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "changeYourAvatar": "Ŝanĝi vian profilbildon", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "La ĉifrado estas difektita", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "Babilo", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackup": "Savkopiado de babilo", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackupDescription": "Via savkopio de babilo estas sekurigita per sekureca ŝlosilo. Bonvolu certigi, ke vi ne perdos ĝin.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "Detaloj pri babilo", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chats": "Babiloj", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "Elektu fortan pasvorton", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "Vakigi arĥivon", "@clearArchive": {}, "close": "Fermi", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_ban": "Forbari la donitan uzanton de ĉi tiu ĉambro", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_html": "Sendi tekston formatan je HTML", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "Inviti la donitan uzanton al ĉi tiu ĉambro", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandHint_join": "Aliĝi al la donita ĉambro", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_kick": "Forigi la donitan uzanton de ĉi tiu ĉambro", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_leave": "Foriri de ĉi tiu ĉambro", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_me": "Priskribu vian agon", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "commandHint_myroomavatar": "Agordi vian profilbildon por ĉi tiu ĉambro (laŭ mxc-uri)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_myroomnick": "Agordi vian prezentan nomon en ĉi tiu ĉambro", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_op": "Agordi povnivelon de la donita uzanto (implicite: 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_plain": "Sendi senformatan tekston", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_react": "Sendi respondon kiel reagon", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "commandHint_unban": "Malforbari la donitan uzanton de ĉi tiu ĉambro", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "commandInvalid": "Nevalida ordono", "@commandInvalid": { - "type": "text" + "type": "String" }, "commandMissing": "{command} ne estas ordono.", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "compareEmojiMatch": "Komparu kaj certigu, ke la jenaj bildosignoj samas en ambaŭ aparatoj:", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "Komparu kaj certigu, ke la jenaj numeroj samas en ambaŭ aparatoj:", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "configureChat": "Agordi babilon", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "Konfirmi", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "Konektiĝi", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "contactHasBeenInvitedToTheGroup": "Kontakto invitiĝis al la grupo", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "Enhavas prezentan nomon", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "Enhavas uzantonomon", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "La enhavo raportiĝis al la administrantoj de la servilo", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "Kopiite al tondujo", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "Kopii", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "Kopii al tondujo", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "Ne povis malĉifri mesaĝon: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "countParticipants": "{count} partoprenantoj", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "create": "Krei", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "createdTheChat": "{username} kreis la babilon", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "createNewSpace": "Nova aro", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "currentlyActive": "Nun aktiva", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "Malhela", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{day}a de la {month}a", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "dateWithYear": "{day}a de la {month}a de {year}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "deactivateAccountWarning": "Ĉi tio malaktivigos vian konton de uzanto. Ne eblas tion malfari! Ĉu certe vi certas?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "defaultPermissionLevel": "Norma nivelo de permesoj", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "Forigi", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "Forigi konton", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "Forigi mesaĝon", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "Aparato", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "Identigilo de aparato", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "Aparatoj", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "Rektaj babiloj", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "Prezenta nomo ŝanĝiĝis", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "Elŝuti dosieron", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "Redakti", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "Redakti blokitajn servilojn", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "Redakti prezentan nomon", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "Ŝanĝi kromnomojn de ĉambro", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "Redakti bildon de ĉambro", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Mieneto jam ekzistas!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "Nevalida mallongigo de mieneto!", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "Mienetaroj por la ĉambro", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Agordoj pri mienetoj", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteShortcode": "Mallongigo de mieneto", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Vi devas elekti mallongigon de mieneto kaj bildon!", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "Malplena babilo", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "Ŝalti mienetaron ĉie", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "Ŝalti ĉifradon", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryptionWarning": "Vi ne povos malŝalti la ĉifradon. Ĉu vi certas?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "Ĉifrite", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "Ĉifrado", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "Ĉifrado ne estas ŝaltita", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName} finis la vokon", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "enterAnEmailAddress": "Enigu retpoŝtadreson", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "enterYourHomeserver": "Enigu vian hejmservilon", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "errorObtainingLocation": "Eraris akirado de loko: {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "everythingReady": "Ĉio pretas!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "Tre ofenda", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "Dosiernomo", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "Grandeco de tiparo", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "Plusendi", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "fromJoining": "Ekde aliĝo", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "fromTheInvitation": "Ekde la invito", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "Iri al la nova ĉambro", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "Grupo", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "Grupo estas publika", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "groups": "Grupoj", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "groupWith": "Grupo kun {displayname}", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "guestsAreForbidden": "Gastoj estas malpermesitaj", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "Gastoj povas aliĝi", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "hasWithdrawnTheInvitationFor": "{username} nuligis la inviton por {targetName}", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "help": "Helpo", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "hideRedactedEvents": "Kaŝi obskurigitajn eventojn", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "Kaŝi nekonatajn eventojn", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "howOffensiveIsThisContent": "Kiel ofenda estas ĉi tiu enhavo?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "Identigilo", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "Identeco", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignore": "Malatenti", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "Malatentitaj uzantoj", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "Mi klakis la ligilon", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "Neĝusta pasfrazo aŭ rehava ŝlosilo", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "Neofenda", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "Inviti kontakton", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "Inviti kontakton al {groupName}", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "invited": "Invitita", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUser": "{username} invitis uzanton {targetName}", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "invitedUsersOnly": "Nur invititoj", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteForMe": "Invito por mi", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteText": "{username} invitis vin al FluffyChat. \n1. Instalu la aplikaĵon FluffyChat: https://fluffychat.im \n2. Registriĝu aŭ salutu \n3. Malfermu la invitan ligilon: {link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "isTyping": "tajpas…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "joinedTheChat": "{username} aliĝis al la babilo", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "joinRoom": "Aliĝi al ĉambro", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "kicked": "{username} forpelis uzanton {targetName}", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickedAndBanned": "{username} forpelis kaj forbaris uzanton {targetName}", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickFromChat": "Forpeli de babilo", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "lastActiveAgo": "Lastafoje aktiva: {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "leave": "Foriri", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "leftTheChat": "Foriris de la ĉambro", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "Permesilo", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "Hela", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "loadCountMoreParticipants": "Enlegi {count} pliajn partoprenantojn", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "loadingPleaseWait": "Enlegante… bonvolu atendi.", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "loadMore": "Enlegi pli…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "Saluti", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "logInTo": "Saluti servilon {homeserver}", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "logout": "Adiaŭi", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "memberChanges": "Ŝanĝoj de anoj", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "Mencii", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "Mesaĝoj", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "Reguligisto", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "muteChat": "Silentigi babilon", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "Bonvolu scii, ke vi ankoraŭ bezonas la programon Pantalaimon por uzi tutvojan ĉifradon.", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "Nova babilo", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "Nova mesaĝo en FluffyChat", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newVerificationRequest": "Nova kontrolpeto!", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "Sekva", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "Ne", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "Neniu konekto al la servilo", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "noEmotesFound": "Neniuj mienetoj troviĝis. 😕", "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "Vi nur povas aktivigi ĉifradon kiam la ĉambro ne plu estas publike alirebla.", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "noGoogleServicesWarning": "Ŝajnas, ke via telefono ne havas servojn de Google. Tio estas bona decido por via privateco! Por ricevadi pasivajn sciigojn en FluffyChat, ni rekomendas, ke vi uzu la https://microg.org/ aŭ https://unifiedpush.org/.", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "none": "Neniu", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "Vi ankoraŭ ne aldonis manieron rehavi vian pasvorton.", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "noPermission": "Neniu permeso", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "Neniuj ĉambroj troviĝis…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "Sciigoj", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "Sciigoj ŝaltiĝis por ĉi tiu konto", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "numUsersTyping": "{count} uzantoj tajpas…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "obtainingLocation": "Akirante lokon…", "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "offensive": "Ofenda", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "offline": "Eksterrete", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "ok": "bone", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "Enrete", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "onlineKeyBackupEnabled": "Enreta savkopiado de ŝlosiloj estas ŝaltita", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsPushError": "Oj! Bedaŭrinde eraris la agordado de pasivaj sciigoj.", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "Oj! Io misokazis…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "Malfermu la aplikaĵon por legi mesaĝojn", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "Malfermi fotilon", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "or": "Aŭ", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "participant": "Partoprenanto", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "passphraseOrKey": "pasfrazo aŭ rehava ŝlosilo", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "Pasvorto", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "Forgesita pasvorto", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "Pasvorto ŝanĝiĝis", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "Rehavo de pasvorto", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "Personoj", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "Elekti bildon", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "Fiksi", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "play": "Ludi {fileName}", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "pleaseChoose": "Bonvolu elekti", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChooseAPasscode": "Bonvolu elekti paskodon", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseClickOnLink": "Bonvolu klaki la ligilon en la retletero kaj pluiĝi.", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "Bonvolu enigi 4 ciferojn, aŭ nenion por malŝalti ŝlosadon de la aplikaĵo.", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "Bonvolu enigi vian pasvorton", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "Bonvolu enigi vian personan identigan numeron", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "Bonvolu enigi vian uzantonomon", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseFollowInstructionsOnWeb": "Bonvolu sekvi la instrukciojn de la retejo kaj tuŝetu al «Sekva».", "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "privacy": "Privateco", "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "publicRooms": "Publikaj ĉambroj", "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "pushRules": "Reguloj de pasivaj sciigoj", "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, "reason": "Kialo", "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "recording": "Registrante", "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "redactedAnEvent": "{username} obskurigis eventon", "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "redactMessage": "Obskurigi mesaĝon", "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "register": "Registriĝi", "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "reject": "Rifuzi", "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "rejectedTheInvitation": "{username} rifuzis la inviton", "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "rejoin": "Ree aliĝi", "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "remove": "Forigi", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "removeAllOtherDevices": "Forigi ĉiujn aliajn aparatojn", "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "removedBy": "Forigita de {username}", "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removeDevice": "Forigi aparaton", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unbanFromChat": "Malforbari", "@unbanFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "removeYourAvatar": "Forigi vian profilbildon", "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Bildigi riĉforman enhavon de mesaĝoj", - "@renderRichContent": { - "type": "text", + "type": "String", "placeholders": {} }, "replaceRoomWithNewerVersion": "Anstataŭigi ĉambron per nova versio", "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "reply": "Respondi", "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "reportMessage": "Raporti mesaĝon", "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "requestPermission": "Peti permeson", "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "roomHasBeenUpgraded": "Ĉambro gradaltiĝis", "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "roomVersion": "Versio de ĉambro", "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "saveFile": "Konservi dosieron", "@saveFile": { - "type": "text", + "type": "String", "placeholders": {} }, "search": "Serĉi", "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "security": "Sekureco", "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "seenByUser": "Vidita de {username}", "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "send": "Sendi", "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAMessage": "Sendi mesaĝon", "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAudio": "Sendi sondosieron", "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "sendFile": "Sendi dosieron", "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "sendImage": "Sendi bildon", "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendMessages": "Sendi mesaĝojn", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOriginal": "Sendi originalon", "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "sendSticker": "Sendi glumarkon", "@sendSticker": { - "type": "text", + "type": "String", "placeholders": {} }, "sendVideo": "Sendi filmon", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAFile": "{username} sendis dosieron", "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAnAudio": "{username} sendis sondosieron", "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAPicture": "{username} sendis bildon", "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentASticker": "{username} sendis glumarkon", "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAVideo": "{username} sendis filmon", "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentCallInformations": "{senderName} sendis informojn pri voko", "@sentCallInformations": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "setAsCanonicalAlias": "Agordi kiel ĉefan kromnomon", "@setAsCanonicalAlias": { - "type": "text", + "type": "String", "placeholders": {} }, "setCustomEmotes": "Agordi proprajn mienetojn", "@setCustomEmotes": { - "type": "text", + "type": "String", "placeholders": {} }, "setInvitationLink": "Agordi invitan ligilon", "@setInvitationLink": { - "type": "text", + "type": "String", "placeholders": {} }, "setPermissionsLevel": "Agordi nivelon de permesoj", "@setPermissionsLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "setStatus": "Agordi staton", "@setStatus": { - "type": "text", + "type": "String", "placeholders": {} }, "settings": "Agordoj", "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, "share": "Konigi", "@share": { - "type": "text", + "type": "String", "placeholders": {} }, "sharedTheLocation": "{username} konigis sian lokon", "@sharedTheLocation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "shareLocation": "Konigi lokon", "@shareLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "showPassword": "Montri pasvorton", "@showPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "singlesignon": "Ununura saluto", "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, "skip": "Preterpasi", "@skip": { - "type": "text", + "type": "String", "placeholders": {} }, "sourceCode": "Fontkodo", "@sourceCode": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceIsPublic": "Aro estas publika", "@spaceIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceName": "Nomo de aro", "@spaceName": { - "type": "text", + "type": "String", "placeholders": {} }, "startedACall": "{senderName} komencis vokon", "@startedACall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "status": "Stato", "@status": { - "type": "text", + "type": "String", "placeholders": {} }, "statusExampleMessage": "Kiel vi fartas?", "@statusExampleMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "submit": "Sendi", "@submit": { - "type": "text", + "type": "String", "placeholders": {} }, "synchronizingPleaseWait": "Spegulante… Bonvolu atendi.", "@synchronizingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "systemTheme": "Sistema", "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "theyDontMatch": "Ili ne akordas", "@theyDontMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "theyMatch": "Ili akordas", "@theyMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "title": "FluffyChat", "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, "toggleFavorite": "Baskuli elstarigon", "@toggleFavorite": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleMuted": "Basklui silentigon", "@toggleMuted": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleUnread": "Baskuli legitecon", "@toggleUnread": { - "type": "text", + "type": "String", "placeholders": {} }, "tooManyRequestsWarning": "Tro multaj petoj. Bonvolu reprovi poste!", "@tooManyRequestsWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "transferFromAnotherDevice": "Transporti de alia aparato", "@transferFromAnotherDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "tryToSendAgain": "Reprovi sendi", "@tryToSendAgain": { - "type": "text", + "type": "String", "placeholders": {} }, "unavailable": "Nedisponeble", "@unavailable": { - "type": "text", + "type": "String", "placeholders": {} }, "unbannedUser": "{username} malforbaris uzanton {targetName}", "@unbannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "unblockDevice": "Malbloki aparaton", "@unblockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownDevice": "Nekonata aparato", "@unknownDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEncryptionAlgorithm": "Nekonata ĉifra algoritmo", "@unknownEncryptionAlgorithm": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEvent": "Nekonata evento «{type}»", "@unknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "type": {} + "type": { + "type": "String" + } } }, "unmuteChat": "Malsilentigi babilon", "@unmuteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "unpin": "Malfiksi", "@unpin": { - "type": "text", + "type": "String", "placeholders": {} }, "unreadChats": "{unreadCount, plural, =1{1 nelegita babilo} other{{unreadCount} nelegitaj babiloj}}", "@unreadChats": { - "type": "text", + "type": "String", "placeholders": { - "unreadCount": {} + "unreadCount": { + "type": "int" + } } }, "userAndOthersAreTyping": "{username} kaj {count} aliaj tajpas…", "@userAndOthersAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "count": {} + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "userAndUserAreTyping": "{username} kaj {username2} tajpas…", "@userAndUserAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "username2": {} + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } } }, "userIsTyping": "{username} tajpas…", "@userIsTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "userLeftTheChat": "{username} foriris de la babilo", "@userLeftTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "username": "Uzantonomo", "@username": { - "type": "text", + "type": "String", "placeholders": {} }, "userSentUnknownEvent": "{username} sendis eventon de speco {type}", "@userSentUnknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "type": {} + "username": { + "type": "String" + }, + "type": { + "type": "String" + } } }, "verified": "Kontrolita", "@verified": { - "type": "text", + "type": "String", "placeholders": {} }, "verify": "Kontroli", "@verify": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyStart": "Komenci kontrolon", "@verifyStart": { - "type": "text", + "type": "String", "placeholders": {} }, "verifySuccess": "Vi sukcese kontrolis!", "@verifySuccess": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyTitle": "Kontrolante alian konton", "@verifyTitle": { - "type": "text", + "type": "String", "placeholders": {} }, "videoCall": "Vidvoko", "@videoCall": { - "type": "text", + "type": "String", "placeholders": {} }, "visibilityOfTheChatHistory": "Videbleco de historio de la babilo", "@visibilityOfTheChatHistory": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForAllParticipants": "Videbla al ĉiuj partoprenantoj", "@visibleForAllParticipants": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForEveryone": "Videbla al ĉiuj", "@visibleForEveryone": { - "type": "text", + "type": "String", "placeholders": {} }, "voiceMessage": "Voĉmesaĝo", "@voiceMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerAcceptRequest": "Atendante konfirmon de peto de la kunulo…", "@waitingPartnerAcceptRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerEmoji": "Atendante akcepton de la bildosignoj de la kunulo…", "@waitingPartnerEmoji": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerNumbers": "Atendante akcepton de la numeroj, de la kunulo…", "@waitingPartnerNumbers": { - "type": "text", + "type": "String", "placeholders": {} }, "wallpaper": "Fonbildo", "@wallpaper": { - "type": "text", + "type": "String", "placeholders": {} }, "warning": "Averto!", "@warning": { - "type": "text", + "type": "String", "placeholders": {} }, "weSentYouAnEmail": "Ni sendis retleteron al vi", "@weSentYouAnEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "whoCanPerformWhichAction": "Kiu povas kion", "@whoCanPerformWhichAction": { - "type": "text", + "type": "String", "placeholders": {} }, "whoIsAllowedToJoinThisGroup": "Kiu rajtas aliĝi al ĉi tiu grupo", "@whoIsAllowedToJoinThisGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "whyDoYouWantToReportThis": "Kial vi volas tion ĉi raporti?", "@whyDoYouWantToReportThis": { - "type": "text", + "type": "String", "placeholders": {} }, "wipeChatBackup": "Ĉu forviŝi la savkopion de via babilo por krei novan sekurecan ŝlosilon?", "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "withTheseAddressesRecoveryDescription": "Per tiuj ĉi adresoj vi povas rehavi vian pasvorton.", "@withTheseAddressesRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "writeAMessage": "Skribi mesaĝon…", "@writeAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "yes": "Jes", "@yes": { - "type": "text", + "type": "String", "placeholders": {} }, "you": "Vi", "@you": { - "type": "text", + "type": "String", "placeholders": {} }, "youAreNoLongerParticipatingInThisChat": "Vi ne plu partoprenas ĉi tiun babilon", "@youAreNoLongerParticipatingInThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "youHaveBeenBannedFromThisChat": "Vi estas forbarita de ĉi tiu babilo", "@youHaveBeenBannedFromThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "yourPublicKey": "Via publika ŝlosilo", "@yourPublicKey": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAsText": "Sendi kiel tekston", "@sendAsText": { - "type": "text" + "type": "String" }, "noMatrixServer": "{server1} ne estas matriksa servilo, eble provu anstataŭe servilon {server2}?", "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "commandHint_send": "Sendi tekston", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "chatHasBeenAddedToThisSpace": "Babilo aldoniĝis al ĉi tiu aro", "@chatHasBeenAddedToThisSpace": {}, "autoplayImages": "Memage ludi movbildajn glumarkojn kaj mienetojn", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "addToSpace": "Aldoni al aro", @@ -1902,333 +2073,5 @@ "homeserver": "Hejmservilo", "@homeserver": {}, "sendOnEnter": "Sendi per eniga klavo", - "@sendOnEnter": {}, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@reportErrorDescription": {}, - "@addAccount": {}, - "@unsupportedAndroidVersion": {}, - "@widgetJitsi": {}, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@startFirstChat": {}, - "@callingAccount": {}, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@user": {}, - "@youAcceptedTheInvitation": {}, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@previousAccount": {}, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@widgetNameError": {}, - "@addToBundle": {}, - "@addWidget": {}, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@commandHint_markasgroup": {}, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@storeInAppleKeyChain": {}, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@signInWithPassword": {}, - "@makeAdminDescription": {}, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@saveKeyManuallyDescription": {}, - "@editBundlesForAccount": {}, - "@whyIsThisMessageEncrypted": {}, - "@setChatDescription": {}, - "@importFromZipFile": {}, - "@dehydrateWarning": {}, - "@noOtherDevicesFound": {}, - "@yourChatBackupHasBeenSetUp": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCallsBetaWarning": {}, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@fileIsTooBigForServer": {}, - "@repeatPassword": {}, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@optionalRedactReason": {}, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@reportUser": {}, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@redactMessageDescription": {}, - "@recoveryKey": {}, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@dehydrateTorLong": {}, - "@doNotShowAgain": {}, - "@report": {}, - "@unverified": {}, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@foregroundServiceRunning": {}, - "@voiceCall": {}, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@removeFromBundle": {}, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@roomUpgradeDescription": {}, - "@scanQrCode": {}, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@widgetName": {}, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@newSpace": {}, - "@emojis": {}, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@hydrateTorLong": {}, - "@time": {}, - "@custom": {}, - "@noBackupWarning": {}, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@pinMessage": {}, - "@invite": {}, - "@enableMultiAccounts": {}, - "@indexedDbErrorTitle": {}, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@placeCall": {} -} \ No newline at end of file + "@sendOnEnter": {} +} diff --git a/lib/l10n/intl_es.arb b/lib/l10n/intl_es.arb new file mode 100644 index 000000000..0275ef30d --- /dev/null +++ b/lib/l10n/intl_es.arb @@ -0,0 +1,3158 @@ +{ + "@@locale": "es", + "@@last_modified": "2021-08-14 12:41:10.097243", + "about": "Acerca de", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Aceptar", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} aceptó la invitación", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Cuenta", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} activó el cifrado de extremo a extremo", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Añadir dirección de correo", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Administrador", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} respondió a la llamada", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Cualquiera puede unirse", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "Archivo", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "¿Pueden los usuarios invitados unirse?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "¿Estás seguro?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "¿Confirma que quiere cerrar sesión?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Para poder confirmar a la otra persona, ingrese su contraseña de almacenamiento segura o la clave de recuperación.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "¿Aceptar esta solicitud de verificación de {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "El servidor soporta los siguientes mecanismos para autenticación:\n{serverVersions}\npero esta aplicación sólo soporta:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "El servidor soporta las siguientes versiones de la especificación:\n{serverVersions}\npero esta aplicación sólo soporta las versiones {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Vetar del chat", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Vetado", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} vetó a {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Bloquear dispositivo", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Bloqueado", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "cancel": "Cancelar", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Cambiar el nombre del dispositivo", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} cambió el icono del chat", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} cambió la descripción del chat a: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} cambió el nombre del chat a: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} cambió los permisos del chat", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} cambió su nombre visible a: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} cambió las reglas de acceso de visitantes", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} cambió las reglas de acceso de visitantes a: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} cambió la visibilidad del historial", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} cambió la visibilidad del historial a: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} cambió las reglas de ingreso", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} cambió las reglas de ingreso a {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} cambió su imagen de perfil", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} cambió el alias de la sala", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} cambió el enlace de invitación", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Cambiar la contraseña", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Cambiar el servidor", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Cambia tu estilo", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Cambiar el nombre del grupo", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "El cifrado se ha corrompido", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Copia de respaldo del chat", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Tus mensajes están protegidos por una llave de seguridad. Procura no perderla.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Detalles del chat", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Conversaciones", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Elija una contraseña segura", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Borrar archivo", + "close": "Cerrar", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Por favor compare los emojis", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Por favor compare los números", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Confirmar", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Conectar", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "El contacto ha sido invitado al grupo", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Copiado al portapapeles", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Copiar", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Copiar al portapapeles", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "No se pudo descifrar el mensaje: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} participantes", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Crear", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬{username} creó el chat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Actualmente activo", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Oscuro", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Se desactivará su cuenta de usuario. ¡La operación no se puede cancelar! ¿Está seguro?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "delete": "Eliminar", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Cancelar cuenta", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Eliminar mensaje", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Dispositivo", + "@device": { + "type": "String", + "placeholders": {} + }, + "devices": "Dispositivos", + "@devices": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "El nombre visible ha cambiado", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Descargar archivo", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Editar nombre visible", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Editar alias de la sala", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "¡El emote ya existe!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "¡El atajo del emote es inválido!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Paquetes de emoticonos para la habitación", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Configuración de emotes", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Atajo de emote", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "¡Debes elegir un atajo de emote y una imagen!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Chat vacío", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Habilitar paquete de emoticonos a nivel general", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Ya no podrá deshabilitar el cifrado. ¿Estás seguro?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryption": "Cifrado", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "El cifrado no está habilitado", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} terminó la llamada", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Introducir una dirección de correo electrónico", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Ingrese su servidor", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "¡Todo listo!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "fileName": "Nombre del archivo", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Reenviar", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Desde que se unió", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Desde la invitación", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Grupo", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "El grupo es público", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grupo con {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Los visitantes están prohibidos", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Los visitantes pueden unirse", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} ha retirado la invitación para {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Ayuda", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Ocultar sucesos censurados", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Ocultar sucesos desconocidos", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "id": "Identificación", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identidad", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Usuarios ignorados", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Frase de contraseña o clave de recuperación incorrecta", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Invitar contacto", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Invitar contacto a {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Invitado", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩{username} invitó a {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Sólo usuarios invitados", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} te invitó a FluffyChat.\n1.Visita fluffychat.im e instala la app\n2. Regístrate o inicia sesión\n3. Abre el enlace de invitación:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "está escribiendo…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋{username} se unió al chat", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Unirse a la sala", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞{username} echó a {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅{username} echó y vetó a {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Echar del chat", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Última vez activo: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Abandonar", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Abandonó el chat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licencia", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Claro", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Mostrar {count} participantes más", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Cargando… Por favor espere.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Mostrar más…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Acceso", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Iniciar sesión en {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Cerrar sesión", + "@logout": { + "type": "String", + "placeholders": {} + }, + "mention": "Mencionar", + "@mention": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderador", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Silenciar chat", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Tenga en cuenta que necesita Pantalaimon para utilizar el cifrado de extremo a extremo por ahora.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "Nuevo mensaje en FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "¡Nueva solicitud de verificación!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Siguiente", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "No", + "@no": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Ningún emote encontrado. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Sólo se puede activar el cifrado en cuanto la sala deja de ser de acceso público.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Parece que no tienes servicios de Firebase Cloud Messaging en tu dispositivo. Para recibir de todas formas notificaciones, recomendamos instalar ntfy. Con ntfy o cualquier proveedor Unified Push, puedes recibir notificaciones manteniendo seguridad de datos. Puedes descargar ntfy de la PlayStore o de F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Ninguno", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Sin autorización", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Ninguna sala encontrada…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "offline": "Desconectado", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Conectado", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "La copia de seguridad de la clave en línea está habilitada", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ups, algo salió mal…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Abrir la aplicación para leer los mensajes", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Abrir cámara", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "contraseña o clave de recuperación", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Contraseña", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "La contraseña ha sido cambiada", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "people": "Personas", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Elegir imagen", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Pin", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Reproducir {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseClickOnLink": "Haga clic en el enlace del correo electrónico y luego continúe.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Por favor ingrese su contraseña", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Por favor ingrese su nombre de usuario", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Por favor, siga las instrucciones del sitio web y presione \"siguiente\".", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privacidad", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Salas públicas", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "recording": "Grabando", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} censuró un suceso", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Rechazar", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} rechazó la invitación", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Volver a unirse", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Eliminar", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Eliminar todos los otros dispositivos", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Eliminado por {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Eliminar dispositivo", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Eliminar la expulsión", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "Responder", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Solicitar permiso", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "La sala ha subido de categoría", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Versión de sala", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Visto por {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Enviar", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Enviar un mensaje", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Enviar audio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Enviar un archivo", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Enviar una imagen", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Enviar el original", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Enviar video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "{username} envió un archivo", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "{username} envió un audio", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "{username} envió una imagen", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "{username} envió un sticker", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "{username} envió un video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} envió información de la llamada", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Fijar alias principal", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Establecer enlace de invitación", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Establecer estado", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Ajustes", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Compartir", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} compartió la ubicación", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "showPassword": "Mostrar contraseña", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "skip": "Omitir", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Código fuente", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} comenzó una llamada", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "statusExampleMessage": "¿Cómo estás hoy?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Enviar", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistema", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "No coinciden", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Coinciden", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Transferir desde otro dispositivo", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Intentar enviar nuevamente", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Indisponible", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} admitió a {targetName} nuevamente", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Desbloquear dispositivo", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Dispositivo desconocido", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Algoritmo de cifrado desconocido", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Evento desconocido '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Dejar de silenciar el chat", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Despinchar", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 chat no leído} other{{unreadCount} chats no leídos}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} y {count} más están escribiendo…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} y {username2} están escribiendo…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} está escribiendo…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "{username} abandonó el chat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Nombre de usuario", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} envió un evento {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Verificado", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verificar", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Comenzar verificación", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "¡Has verificado exitosamente!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verificando la otra cuenta", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Video llamada", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Visibilidad del historial del chat", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Visible para todos los participantes", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Visible para todo el mundo", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Mensaje de voz", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Esperando a que el socio acepte la solicitud…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Esperando a que el socio acepte los emojis…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Esperando a que el socio acepte los números…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Fondo de pantalla:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "¡Advertencia!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Te enviamos un correo electrónico", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Quién tiene permitido unirse al grupo", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Escribe un mensaje…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Sí", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Tú", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Ya no estás participando en este chat", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Has sido vetado de este chat", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "Reproducir emoticonos y stickers animados automáticamente", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "allChats": "Todos los chats", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Agregar al espacio", + "cantOpenUri": "No puedo abrir el URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "all": "Todo", + "@all": { + "type": "String", + "placeholders": {} + }, + "appLock": "Bloqueo de aplicación", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Mensajes de bot", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "Se ha cerrado en la sesión de uno de sus clientes", + "addAccount": "Añadir cuenta", + "editBundlesForAccount": "Editar paquetes para esta cuenta", + "addToBundle": "Agregar al paquete", + "bundleName": "Nombre del paquete", + "saveFile": "Guardar el archivo", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Enviar stickers", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Establecer nivel de permisos", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Compartir ubicación", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Inicio de sesión único", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "status": "Estado", + "@status": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sincronizando... por favor espere.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "He hecho clic en el enlace", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "directChats": "Chat directo", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Error al obtener la ubicación: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "howOffensiveIsThisContent": "¿Cuán ofensivo es este contenido?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Invitar por mí", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Aún no ha agregado una forma de recuperar su contraseña.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} usuarios están escribiendo…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "or": "O", + "@or": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "El espacio es público", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "El chat se ha agregado a este espacio", + "commandInvalid": "Comando inválido", + "@commandInvalid": { + "type": "String" + }, + "passwordRecovery": "Recuperación de contraseña", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "security": "Seguridad", + "@security": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extremadamente ofensivo", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Editar servidores bloqueado", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Configurar chat", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Sin conexión al servidor", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Tu clave pública", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Contraseña olvidada", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Inofensivo", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "reason": "Razón", + "@reason": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Cambios de miembros", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Nuevo espacio", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "edit": "Editar", + "@edit": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Establecer emoticonos personalizados", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorar", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notificaciones", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Notificaciones habilitadas para esta cuenta", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "offensive": "Ofensiva", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "Este servidor necesita validar su dirección de correo electrónico para registrarse.", + "pleaseChoose": "Por favor elija", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Reemplazar habitación con una versión más nueva", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "El contenido ha sido reportado a los administradores del servidor", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "groups": "Grupos", + "@groups": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Mensaje de informe", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "search": "Buscar", + "@search": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Permiso de ubicación denegado. Concédeles que puedan compartir tu ubicación.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Nivel de permiso predeterminado para nuevo usuarios", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Obteniendo ubicación…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "participant": "Participante", + "@participant": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Regla de Push", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "register": "Registrarse", + "@register": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Enviar como texto", + "@sendAsText": { + "type": "String" + }, + "toggleMuted": "Alternar silenciado", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Demasiadas solicitudes. ¡Por favor inténtelo más tarde!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Con esta dirección puede recuperar su contraseña.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "commandHint_send": "Enviar texto", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "deviceId": "ID del dispositivo", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Contiene nombre de usuario", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "¡UPS¡ Desafortunadamente, se produjo un error al configurar las notificaciones push.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Quitar tu avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Habilitar la encriptación", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "messages": "Mensajes", + "@messages": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Tamaño de fuente", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Prohibir al usuario dado en esta sala", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_unban": "Des banear al usuario dado en esta sala", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandMissing": "{command} no es un comando.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "scanQrCode": "Escanear código QR", + "homeserver": "Servidor inicial", + "newChat": "Nuevo chat", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "commandHint_join": "Únete a la sala indicada", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "sendOnEnter": "Enviar con enter", + "changeYourAvatar": "Cambiar tu avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "commandHint_me": "Descríbete", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_html": "Enviar texto con formato HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Invitar al usuario indicado a esta sala", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_kick": "Eliminar el usuario indicado de esta sala", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Deja esta sala", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_myroomavatar": "Selecciona tu foto para esta sala (by mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Establece tu nombre para mostrar para esta sala", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Establece el nivel de potencia del usuario dado (default: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Enviar texto sin formato", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Enviar respuesta como reacción", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "containsDisplayName": "Contiene nombre para mostrar", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Editar avatar de sala", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Los servicios de ubicación están deshabilitado. Habilite para poder compartir su ubicación.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Encriptado", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Ir a la nueva sala", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} no es un servidor matrix, usar {server2} en su lugar?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "openInMaps": "Abrir en maps", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "removeFromBundle": "Quitar de este paquete", + "link": "Link", + "enableMultiAccounts": "(BETA) habilite varias cuenta en este dispositivo", + "pleaseEnter4Digits": "Ingrese 4 dígitos o déjelo en blanco para deshabilitar el bloqueo de la aplicación.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Elija un código de acceso", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Por favor ingrese su PIN", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "Censurar mensaje", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Enviar mensajes", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Nombre del espacio", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Alternar favorito", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Marcar como: leído / no leído", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Quién puede realizar qué acción", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "¿Por qué quieres denunciar esto?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "¿Limpiar la copia de seguridad de tu chat para crear una nueva clave de recuperación?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Se ha configurado la copia de respaldo del chat.", + "unverified": "No verificado", + "commandHint_clearcache": "Limpiar cache", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "messageInfo": "Información del mensaje", + "time": "Tiempo", + "openVideoCamera": "Abrir la cámara para un video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Repite la contraseña", + "removeFromSpace": "Eliminar del espacio", + "addToSpaceDescription": "Elige un espacio para añadirle este chat.", + "openGallery": "Abrir galería", + "start": "Iniciar", + "commandHint_discardsession": "Descartar sesión", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "messageType": "Tipo de Mensaje", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "publish": "Publicar", + "newSpace": "Nuevo espacio", + "allSpaces": "Todos los espacios", + "widgetUrlError": "Esta no es una URL válida.", + "commandHint_markasgroup": "Marcar como grupo", + "nextAccount": "Siguiente cuenta", + "youRejectedTheInvitation": "Rechazaste la invitación", + "newGroup": "Nuevo grupo", + "widgetJitsi": "Jitsi Meet", + "previousAccount": "Cuenta anterior", + "users": "Usuarios", + "youInvitedBy": "📩 Has sido invitado por {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youAcceptedTheInvitation": "👍 Aceptaste la invitación", + "widgetEtherpad": "Nota de texto", + "commandHint_cuddle": "Enviar un abrazo", + "supposedMxid": "Esto debería ser {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "importFromZipFile": "Importar de un archivo .zip", + "exportEmotePack": "Exportar paquete de emotes a .zip", + "addChatDescription": "Añadir una descripción del chat...", + "sendTypingNotifications": "Enviar notificaciones \"está escribiendo\"", + "importEmojis": "Importar emojis", + "confirmMatrixId": "Por favor confirma tu Matrix ID para borrar tu cuenta.", + "notAnImage": "El archivo no es una imagen.", + "commandHint_hug": "Mandar un abrazo", + "importNow": "Importar ahora", + "hugContent": "{senderName} te abraza", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "otherCallingPermissions": "Micrófono, cámara y otros permisos de FluffyChat", + "emailOrUsername": "Correo electrónico o nombre de usuario", + "countFiles": "{count} archivos", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "reportUser": "Reportar usuario", + "voiceCall": "Llamada de voz", + "reactedWith": "{sender} reaccionó con {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "markAsRead": "Marcar como leído", + "widgetName": "Nombre", + "replace": "Reemplazar", + "unsupportedAndroidVersionLong": "Esta característica requiere una versión más reciente de Android. Por favor, compruebe las actualizaciones o la compatibilidad de LineageOS.", + "storeSecurlyOnThisDevice": "Almacenar de forma segura en este dispositivo", + "openChat": "Abrir chat", + "screenSharingDetail": "Usted está compartiendo su pantalla en FluffyChat", + "allRooms": "Todos los chats grupales", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "widgetVideo": "Vídeo", + "dismiss": "Descartar", + "unsupportedAndroidVersion": "Versión de Android no compatible", + "indexedDbErrorLong": "El almacenamiento de mensajes, por desgracia, no está habilitado en el modo privado por defecto.\nPor favor, visite\n - about:config\n - Establezca dom.indexedDB.privateBrowsing.enabled a true\nDe otra forma, no es posible usar FluffyChat.", + "startFirstChat": "Comience su primer chat", + "commandHint_create": "Crear un chat grupal vacío\nUse --no-encryption para deshabilitar el cifrado", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "user": "Usuario", + "separateChatTypes": "Separar chats directos de grupos", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "tryAgain": "Inténtelo de nuevo", + "youKickedAndBanned": "🙅 Usted expulsó y prohibió el acceso a {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "messagesStyle": "Mensajes:", + "chatDescription": "Descripción del chat", + "callingAccountDetails": "Permite a FluffyChat utilizar la aplicación de llamadas nativa de Android.", + "enterSpace": "Unirse al espacio", + "pleaseEnterRecoveryKey": "Por favor, introduzca su clave de recuperación:", + "widgetNameError": "Por favor, proporciona un nombre para mostrar.", + "addWidget": "Añadir widget", + "hydrateTor": "TOR: Importar sesión exportada", + "storeInAppleKeyChain": "Almacenar en la KeyChain de Apple", + "hydrate": "Restaurar desde fichero de copia de seguridad", + "invalidServerName": "Nombre del servidor no válido", + "chatPermissions": "Permisos del chat", + "sender": "Remitente", + "storeInAndroidKeystore": "Almacenar en la KeyStore de Android", + "saveKeyManuallyDescription": "Compartir esta clave manualmente usando el diálogo de compartir del sistema o el portapapeles.", + "whyIsThisMessageEncrypted": "¿Por qué no se puede leer este mensaje?", + "setChatDescription": "Establecer descripción del chat", + "dehydrateWarning": "Esta acción no se puede deshacer. Asegúrese de que ha almacenado de forma segura el fichero de copia de seguridad.", + "redactedBy": "Censurado por {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "videoCallsBetaWarning": "Tenga en cuenta que las videollamadas están actualmente en fase beta. Es posible que no funcionen como se espera o que no funcionen de ninguna manera en algunas plataformas.", + "callingPermissions": "Permisos de llamadas", + "unlockOldMessages": "Desbloquear mensajes viejos", + "numChats": "{number} chats", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Opcional) Motivo para censurar este mensaje...", + "dehydrate": "Exportar sesión y limpiar dispositivo", + "switchToAccount": "Cambiar a la cuenta {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "experimentalVideoCalls": "Videollamadas experimentales", + "pleaseEnterRecoveryKeyDescription": "Para desbloquear sus viejos mensajes, introduzca su clave de recuperación que se generó en una sesión anterior. Su clave de recuperación NO es su contraseña.", + "inviteContactToGroupQuestion": "¿Quieres invitar a {contact} al chat {groupName}?", + "redactedByBecause": "Censurado por {username} porque: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Usted retiró la invitación a {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "enterRoom": "Unirse a la sala", + "confirmEventUnpin": "¿Seguro que quiere desfijar permanentemente el evento?", + "youInvitedUser": "📩 Usted invitó a {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "redactMessageDescription": "El mensaje será censurado para todas las personas participantes en la conversación. Esto no se puede deshacer.", + "recoveryKey": "Clave de recuperación", + "dehydrateTorLong": "Si está usando TOR, es recomendable exportar la sesión antes de cerrar la ventana.", + "doNotShowAgain": "No mostrar de nuevo", + "hideUnimportantStateEvents": "Ocultar eventos de estado no importantes", + "screenSharingTitle": "Compartir la pantalla", + "widgetCustom": "Personalizado", + "youBannedUser": "Usted prohibió el acceso a {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "directChat": "Chat directo", + "appearOnTop": "Aparecer en la cima", + "foregroundServiceRunning": "Esta notificación aparece cuando el servicio en segundo plano se está ejecutando.", + "wasDirectChatDisplayName": "Chat vacío (era {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "No se ha creado una descripción del chat aún.", + "chatDescriptionHasBeenChanged": "Se ha cambiado la descripción del chat", + "dehydrateTor": "TOR: Exportar sesión", + "youKicked": "👞 Usted expulsó a {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "shareInviteLink": "Compartir enlace de invitación", + "commandHint_markasdm": "Marcar como sala de mensajes directos para el ID de Matrix", + "recoveryKeyLost": "¿Perdió su clave de recuperación?", + "emoteKeyboardNoRecents": "Los emotes usados recientemente aparecerán aquí...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "youJoinedTheChat": "Usted se ha unido al chat", + "errorAddingWidget": "Fallo al añadir el widget.", + "commandHint_dm": "Iniciar un chat directo\nUse --no-encryption para deshabilitar el cifrado", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "youUnbannedUser": "Usted volvió a permitir el acceso a {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "emojis": "Emojis", + "createGroup": "Crear grupo", + "hydrateTorLong": "¿Exportó su sesión la última vez que estuvo en TOR? Impórtela rápidamente y continúe chateando.", + "custom": "Personalizado", + "storeInSecureStorageDescription": "Almacenar la clave de recuperación en el almacenamiento seguro de este dispositivo.", + "pinMessage": "Anclar a la sala", + "indexedDbErrorTitle": "Problemas con el modo privado", + "googlyEyesContent": "{senderName} te manda ojos saltones", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} se acurruca contigo", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_googly": "Enviar unos ojos saltones", + "noChatsFoundHere": "No se han encontrado chats. Inicia un nuevo chat usando el botón de abajo. ⤵️", + "joinedChats": "Chats Unidos", + "space": "Espacio", + "spaces": "Espacios", + "block": "Bloquear", + "blockListDescription": "Puedes bloquear usuarios que te estén molestando. No podrás recibir mensajes ni invitaciones de chat de los usuarios de tu lista de bloqueo.", + "aboutHomeserver": "Acerca de {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "unread": "No leídos", + "swipeRightToLeftToReply": "Desliza a la izquierda para responder", + "hideRedactedMessagesBody": "Si alguien elimina un mensaje, este mensaje ya no será visible en el chat.", + "hideInvalidOrUnknownMessageFormats": "Esconde formatos de mensajes inválidos o desconocidos", + "hideRedactedMessages": "Esconde mensajes eliminados", + "appLockDescription": "Bloquear la aplicación cuando no se use con código pin", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "accessAndVisibility": "Acceso y visibilidad", + "globalChatId": "ID de chat Global", + "accessAndVisibilityDescription": "A quién se le permite unirse a este chat y cómo se puede descubrir el chat.", + "calls": "Llamadas", + "customEmojisAndStickers": "Emojis y stickers personalizados", + "customEmojisAndStickersBody": "Agrega o comparte emojis y stickers personalizados que se pueden utilizar en cualquier chat.", + "blockedUsers": "Usuarios bloqueados", + "blockUsername": "Ignorar nombre de usuario", + "noMoreChatsFound": "No se encontraron más chats...", + "countChatsAndCountParticipants": "{chats} chats y {participants} participantes", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "notifyMeFor": "Notificarme", + "presencesToggle": "Mostrar mensajes de estado de otros usuarios", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "placeCall": "Llamar", + "callingAccount": "Llamando a cuenta", + "appearOnTopDetails": "Permite que la app aparezca delante (no hace falta si ya tienes Fluffychat configurado como cuenta llamante)", + "disableEncryptionWarning": "Por motivos de seguridad no es posible deshabilitar el cifrado en un chat si ha sido habilitado previamente.", + "setColorTheme": "Poner tema de color:", + "inviteGroupChat": "📨 Invitar a grupo", + "invalidInput": "¡Entrada no válida!", + "wrongPinEntered": "¡Pin erróneo! Vuelve a intenrarlo en {seconds} segundos...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "decline": "Declinar", + "thisDevice": "Este dispositivo:", + "minimumPowerLevel": "{level} es el nivel mínimo.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "verifyOtherDevice": "🔐 Verificar otro dispositivo", + "chatPermissionsDescription": "Definir el nivel necesario para ciertas acciones en este chat. Los niveles 0, 50 y 100 habitualmente representan usuarios, moderadores y administradores, pero se puede establecer cualquier escala.", + "updateInstalled": "¡🎉 Actualización {version} instalada!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Cambios", + "sendCanceled": "Envío cancelado", + "invite": "Invitar", + "searchIn": "Buscar en chat \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "appWantsToUseForLogin": "Usar '{server}' para entrar", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Por la presente permites a la app y web compartir información sobre ti.", + "encryptThisChat": "Cifrar este chat", + "publicLink": "Enlace público", + "transparent": "Transparente", + "select": "Elegir", + "newPassword": "Nueva clave", + "nothingFound": "No se encontró nada...", + "subspace": "Sub espacio", + "openLinkInBrowser": "Abrir enlace en navegador", + "presenceStyle": "Presencia:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "youInvitedToBy": "📩 Te han invitado con un enlace a:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "signInWith": "Entrar con {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "setTheme": "Poner tema:", + "learnMore": "Aprender más", + "incomingMessages": "Mensajes entrantes", + "noOtherDevicesFound": "No se han encontrado otros dispositivos", + "generalNotificationSettings": "Ajustes de notificación generales", + "roomNotificationSettings": "Ajustes de notificación de salas", + "userSpecificNotificationSettings": "Ajustes de notificación por usuario", + "contentNotificationSettings": "Ajustes de notificación de contenido", + "otherNotificationSettings": "Otros ajustes de notificación", + "notificationRuleContainsUserName": "Contiene nombre de usuario", + "notificationRuleContainsUserNameDescription": "Notifica al usuario cuando un mensaje contiene su nombre de usuario.", + "notificationRuleMaster": "Silenciar todas las notificaciones", + "notificationRuleMasterDescription": "Anula todas las demás reglas y desactiva todas las notificaciones.", + "notificationRuleSuppressNotices": "Suprimir los mensajes automáticos", + "notificationRuleSuppressNoticesDescription": "Suprimir notificaciones de clientes automáticos, como bots.", + "notificationRuleInviteForMe": "Invitación para mí", + "notificationRuleInviteForMeDescription": "Notifica al usuario cuando se les invita a una sala.", + "notificationRuleMemberEvent": "Evento para miembros", + "notificationRuleMemberEventDescription": "Suprimir notificaciones de eventos para miembros.", + "notificationRuleIsUserMention": "Mención al usuario", + "notificationRuleIsUserMentionDescription": "Notifica al usuario cuando son mencionados directamente en un mensaje.", + "notificationRuleContainsDisplayName": "Contiene el nombre visible", + "notificationRuleContainsDisplayNameDescription": "Notifica al usuario cuando un mensaje contiene su nombre visible.", + "notificationRuleIsRoomMention": "Mención de sala", + "notificationRuleIsRoomMentionDescription": "Notifica al usuario cuando hay una mención de sala.", + "notificationRuleRoomnotif": "Notificación de sala", + "notificationRuleRoomnotifDescription": "Notifica al usuario cuando un mensaje contiene '@sala'.", + "notificationRuleTombstone": "Lápida", + "notificationRuleTombstoneDescription": "Notifica al usuario sobre mensajes de desactivación de sala.", + "notificationRuleReaction": "Reacción", + "notificationRuleReactionDescription": "Suprime notificaciones por reacciones.", + "notificationRuleRoomServerAcl": "ACL de servidor de sala", + "notificationRuleRoomServerAclDescription": "Suprime notificaciones de listas de control de acceso de servidores de sala.", + "notificationRuleSuppressEdits": "Suprimir ediciones", + "notificationRuleSuppressEditsDescription": "Suprime las notificaciones de mensajes editados.", + "notificationRuleCall": "Llamar", + "notificationRuleCallDescription": "Notifica al usuario de llamadas.", + "notificationRuleEncryptedRoomOneToOne": "Sala cifrada uno a uno", + "notificationRuleEncryptedRoomOneToOneDescription": "Notifica al usuario sobre mensajes en salas cifradas uno a uno.", + "notificationRuleRoomOneToOne": "Sala uno a uno", + "notificationRuleRoomOneToOneDescription": "Notifica al usuario sobre mensajes en salas uno a uno.", + "notificationRuleMessage": "Mensaje", + "notificationRuleMessageDescription": "Notifica al usuario sobre mensajes generales.", + "notificationRuleEncrypted": "Cifrado", + "notificationRuleEncryptedDescription": "Notifica al usuario sobre mensajes en salas cifradas.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Notifica al usuario sobre eventos del componente de Jitsi.", + "notificationRuleServerAcl": "Suprimir eventos de ACL del servidor", + "notificationRuleServerAclDescription": "Suprime notificaciones de eventos de ACL del servidor.", + "unknownPushRule": "Regla de notificación desconocida '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Si eliminas este ajuste de notificación, esto no se puede deshacer.", + "more": "Más", + "serverLimitReached": "¡Alcanzado límite del servidor! Esperando {seconds} segundos...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "groupCanBeFoundViaSearch": "Los grupos se pueden encontrar buscando", + "addChatOrSubSpace": "Añadir chat o sub espacio", + "sendRoomNotifications": "Mandar notificación @sala", + "changeTheChatPermissions": "Cambiar los permisos de chat", + "setWallpaper": "Poner fondo", + "sendImages": "Envío de la imagen {count}", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "invitedBy": "📩 Invitado por {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Los usuarios han de avisar", + "noOneCanJoin": "Nadie puede unirse", + "reopenChat": "Reabrir chat", + "hidePresences": "¿Esconder la lista de estado?", + "fileIsTooBigForServer": "¡No se pudo mandar! El servidor solamente permite adjuntos de hasta {max}.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Saltar al último mensaje leído", + "report": "informe", + "readUpToHere": "Leer hasta aquí", + "signInWithPassword": "Entrar con clave", + "formattedMessages": "Mensajes con formato", + "publicSpaces": "Espacios públicos", + "formattedMessagesDescription": "Mostrar contenido de mensaje enriquecido, como texto en negrita, usando markdown.", + "userLevel": "{level} - Usuario", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "completedKeyVerification": "{sender} completó la verificación de clave", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sendingAttachment": "Enviando adjunto...", + "compress": "Comprimir", + "pleaseFillOut": "Por favor, rellenar", + "newChatRequest": "📩 Nueva petición de chat", + "unbanUserDescription": "El usuario podrá entrar al chat de nuevo si lo intenta.", + "roomUpgradeDescription": "El chat se volverá a crear con la nueva versión de sala. Todos los participantes serán notificados de que tienen que cambiarse al nuevo chat. Puedes encontrar más información sobre versiones de salas en https://spec.matrix.org/latest/rooms/", + "makeAdminDescription": "Una vez hagas que este usuario sea admin, puede que no puedas deshacerlo porque tendrá los mismos permisos que tú.", + "knocking": "Avisando", + "chatCanBeDiscoveredViaSearchOnServer": "El chat se puede descubrir buscando en {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchChatsRooms": "Buscar #chats, @usuarios...", + "groupName": "Nombre de grupo", + "createGroupAndInviteUsers": "Crear un grupo e invitar usuarios", + "databaseMigrationTitle": "La base de datos está optimizada", + "searchForUsers": "Buscar @usuarios...", + "startConversation": "Iniciar conversación", + "gallery": "Galería", + "files": "Archivos", + "initAppError": "Hubo un error al arrancar la app", + "sessionLostBody": "Se perdió tu sesión. Por favor, informa de este error a los desarrolladores en {url}. El mensaje de error es: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "unreadChatsInApp": "{appname}: {unread} chats no leídos", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "restricted": "Restringido", + "requestedKeyVerification": "{sender} ha pedido verificación de clave", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "adminLevel": "{level} - Administrador", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Cambiar los ajustes generales de chat", + "inviteOtherUsers": "Invitar a otros usuarios a este chat", + "calculatingFileSize": "Calculando tamaño de archivo...", + "prepareSendingAttachment": "Prepara envío del adjunto...", + "generatingVideoThumbnail": "Generando miniatura de vídeo...", + "sendingAttachmentCountOfCount": "Enviando adjunto {index} de {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "compressVideo": "Comprimiendo vídeo...", + "blur": "Difuminar:", + "continueText": "Continuar", + "welcomeText": "Eh, eh, 👋 Esto es FluffyChat. Puedes acceder a cualquier homeserver, que sea compatible con https://matrix.org. Y luego chatear con cualquiera. ¡Es una red de mensajería descentralizada enorme!", + "opacity": "Opacidad:", + "version": "Versión", + "serverInformation": "Información del servidor:", + "website": "Web", + "name": "Nombre", + "knockRestricted": "Aviso restringido", + "hideMemberChangesInPublicChats": "Ocultar cambios de miembros en salas públicas", + "hideMemberChangesInPublicChatsBody": "No mostrar en el chat que alguien entra o sale de una sala pública para mejorar la inteligibilidad.", + "passwordRecoverySettings": "Ajustes de recuperación de clave", + "acceptedKeyVerification": "{sender} aceptó la verificación de clave", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "stickers": "Pegatinas", + "shareKeysWith": "Compartir claves con...", + "shareKeysWithDescription": "¿Qué dispositivos deben ser de confianza para que puedan leer tus mensajes en chats cifrados?", + "crossVerifiedDevicesIfEnabled": "Dispositivos verificados si están habilitados", + "allDevices": "Todos los dispositivos", + "crossVerifiedDevices": "Dispositivos verificados", + "verifiedDevicesOnly": "Solo dispositivos verificados", + "deviceKeys": "Claves de dispositivo:", + "overview": "Vista general", + "removeDevicesDescription": "Vas a salir en este dispositivo y ya no podrás recibir mensajes.", + "databaseMigrationBody": "Por favor espera. Esto llevará un momento.", + "pleaseEnterYourCurrentPassword": "Por favor, pon tu clave actual", + "pleaseChooseAStrongPassword": "Por favor, pon una clave fuerte", + "joinSpace": "Unirse al espacio", + "wrongRecoveryKey": "Lo siento... esta no parece ser la clave de recuperación correcta.", + "leaveEmptyToClearStatus": "Deja vacío para limpiar tu estado.", + "databaseBuildErrorBody": "No pude crear la base de datos SQlite. La app intenta usar la base de datos heredada por ahora. Por favor, informa de este error a los desarrolladores en {url}. El mensaje de error es: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "La app ahora trata de recuperar tu sesión de la copia de seguridad. Por favor, informa de este error a los desarrolladores en {url}. El mensaje de error es: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceipts": "Mandar recibos de lectura", + "sendTypingNotificationsDescription": "Otros participantes en un chat pueden ver cuándo estás escribiendo un mensaje.", + "sendReadReceiptsDescription": "Otros participantes en un chat pueden ver cuándo has leído un mensaje.", + "verifyOtherUserDescription": "Si verificas a otro usuario, puedes estar seguro de a quién estás escribiendo realmente. 💪\n\nCuando empiezas una verificación, tú y el otro usuario veréis una ventana emergente en la app. En ella veréis una serie de emojiso números que tenéis que comparar.\n\nLa mejor forma de hacer esto es quedar o una videollamada. 👭", + "verifyOtherDeviceDescription": "Cuando verificas otro dispositivo, esos dispositivos pueden intercambiar claves, incrementando tu seguridad global. 💪 Cuando inicias una verificación, aparece una ventana en la app en ambos dispositivos. En ella, verás una serie de emojis o números que tienes que comparar. Es mejor tener ambos dispositivos a mano antes de empezar la verificación. 🤳", + "canceledKeyVerification": "{sender} canceló la verificación de clave", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "commandHint_unignore": "No ignorar la ID de matrix dada", + "noDatabaseEncryption": "En esta plataforma no hay cifrado de base de datos", + "startedKeyVerification": "{sender} ha comenzado verificación de clave", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "discover": "Descubrir", + "thereAreCountUsersBlocked": "Ahora mismo, hay {count} usuarios bloqueados.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "commandHint_ignore": "Ignorar la ID de matrix dada", + "jump": "Saltar", + "commandHint_sendraw": "Mandar json pelado", + "kickUserDescription": "Se expulsa al usuario del chat, pero no se le prohíbe volver a entrar. En chats públicos, el usuario podrá volver a entrar en cualquier momento.", + "fileHasBeenSavedAt": "Archivo guardado en {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "markAsUnread": "Marcar no leído", + "changeTheDescriptionOfTheGroup": "Cambiar la descripción del chat", + "sorryThatsNotPossible": "Lo siento... eso no es posible", + "publicChatAddresses": "Dirección de chat pública", + "createNewAddress": "Crear nueva dirección", + "userRole": "Rol de usuario", + "boldText": "Texto en negrita", + "italicText": "Texto en cursiva", + "strikeThrough": "Tachado", + "searchMore": "Buscar más...", + "noPublicLinkHasBeenCreatedYet": "No se ha creado un enlace público aún", + "knock": "Aviso", + "newSpaceDescription": "Los espacios permiten consolidar los chats y montar comunidades privadas o públicas.", + "pleaseTryAgainLaterOrChooseDifferentServer": "Por favor, intente luego o elija un servidor distinto.", + "pleaseEnterANumber": "Por favor pon un número mayor que 0", + "archiveRoomDescription": "El chat se moverá al archivo. Otros usuarios podrán ver que has abandonado el chat.", + "pushNotificationsNotAvailable": "No están disponibles las notificaciones emergentes", + "passwordsDoNotMatch": "Las claves no coinciden", + "passwordIsWrong": "La clave que has puesto es incorrecta", + "verifyOtherUser": "🔐 Verificar a otro usuario", + "isReadyForKeyVerification": "{sender} está preparado para verificación de clave", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "goToSpace": "Ir al espacio: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "oneOfYourDevicesIsNotVerified": "Uno de tus dispositivos no está verificado", + "noticeChatBackupDeviceVerification": "Nota: Cuando conectas todos tus dispositivos a la copia de seguridad del chat, son verificados automáticamente.", + "manageAccount": "Gestionar cuenta", + "contactServerAdmin": "Contactar con el administrador del servidor", + "contactServerSecurity": "Contactar con seguridad del servidor", + "supportPage": "Página de atención", + "invalidUrl": "URL incorrecta", + "addLink": "Añadir enlace", + "unableToJoinChat": "No se puede entrar al chat. Puede que la otra parte ya haya cerrado la conversación.", + "waitingForServer": "Esperando al servidor...", + "discoverHomeservers": "Descubrir homeservers", + "profileNotFound": "El usuario no se encontró en el servidor. Puede que haya un problema de conexión o el usuario no exista.", + "synchronizingPleaseWaitCounter": " Sincronizando… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "reportErrorDescription": "😭 Oh, no. Algo ha salido mal. Si quieres, puedes informar de este fallo a los desarrolladores.", + "hasKnocked": "🚪 {user} ha avisado", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noBackupWarning": "¡Cuidado! Si no se habilita la copia de seguridad del chat, perderás acceso a tus mensajes cifrados. Se recomienda encarecidamente habilitar la copia de seguridad del chat antes de salir.", + "userWouldLikeToChangeTheChat": "{user} quiere unirse al chat.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "yourGlobalUserIdIs": "Tu id de usuario global es: ", + "noKeyForThisMessage": "Esto puede ocurrir si el mensaje se envió antes de que entraras en tu cuenta en este dispositivo.\n\nTambién puede que el remitente haya bloqueado tu dispositivo o haya fallado algo en la conexión a Internet.\n\n¿Puedes leer el mensaje en otra sesión? Entonces, ¡puedes transferir el mensaje desde allí! Ve a Ajustes > Dispositivos y asegúrate de que tus dispositivos se han verificado mutuamente. Cuando abras la sala la próxima vez y ambas sesiones estén en primer plano, las claves se transmitirán automáticamente.\n\n¿No quieres perder las claves al salir o al cambiar de dispositivo? Asegúrate de que has habilitado la copia de seguridad del chat en los ajustes.", + "invitePrivateChat": "📨 Invitar a grupo privado", + "banUserDescription": "Se expulsará al usuario del chat y no podrá volver a entrar hasta que se le permita.", + "loginWithMatrixId": "Entrar con un ID de Matrix", + "changeTheCanonicalRoomAlias": "Cambiar la dirección pública principal de chat", + "noContactInformationProvided": "El servidor no suministra ninguna información de contacto válida", + "noUsersFoundWithQuery": "Desgraciadamente, no se encontró ningún usuario con \"{query}\". Por favor, revisa si cometiste un error.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "changeTheVisibilityOfChatHistory": "Cambiar la visibilidad de la historia de chat", + "doesNotSeemToBeAValidHomeserver": "No parece ser un homeserver compatible. ¿URL equivocada?", + "moderatorLevel": "{level} - Moderador", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "homeserverDescription": "Todos tus datos se guardan en el homeserver, como en un proveedor de correo electrónico. Puedes elegir el homeserver que quieres usar, a la par que te puedes comunicar con todos. Más en https://matrix.org.", + "whatIsAHomeserver": "¿Qué es un homeserver?", + "open": "Abrir", + "appIntroduction": "FluffyChat te permite chatear con tus amigos con diferentes mensajerías. Aprende más en https://matrix.org o simplemente pincha *Continuar*.", + "forwardMessageTo": "¿Reenviar mensaje a {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "previous": "Anterior", + "otherPartyNotLoggedIn": "La otra parte ahora mismo no está conectada y por tanto ¡no puede recibir mensajes!", + "takeAPhoto": "Tomar foto", + "recordAVideo": "Grabar video", + "optionalMessage": "(Opcional) mensaje...", + "notSupportedOnThisDevice": "No es compatible con este dispositivo", + "enterNewChat": "Ingresar a nuevo chat", + "pleaseWaitUntilInvited": "Por favor espera, hasta que alguien del chat te invite.", + "commandHint_roomupgrade": "Actualizar este chat a la versión de chat asignada", + "checkList": "Lista de tareas", + "countInvited": "{count} invitado", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Mensaje de voz de {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "setCustomPermissionLevel": "Agregar nivel personalizado de permiso", + "setPermissionsLevelDescription": "Por favor elige un rol predeterminado o un nivel de permiso personalizado entre 0 a 100.", + "ignoreUser": "Ignorar usuario", + "normalUser": "Usuario normal", + "commandHint_logout": "Salir del dispositivo actual", + "commandHint_logoutall": "Salir de todos los dispositivos activos", + "displayNavigationRail": "Mostrar carril de navegación en móvil", + "approve": "Aprobar", + "youHaveKnocked": "Has sido expulsado", + "customReaction": "Reacción personalizada", + "moreEvents": "Más eventos", + "declineInvitation": "Rechazar invitación", + "changedTheChatDescription": "{username} ha cambiado la descripción del chat", + "changedTheChatName": "{username} ha cambiado el nombre del chat", + "noMessagesYet": "Sin mensajes", + "longPressToRecordVoiceMessage": "Deja presionado para grabar un mensaje.", + "pause": "Pausa", + "resume": "Continuar", + "newSubSpace": "Nuevo sub espacio", + "moveToDifferentSpace": "Mover a otro espacio", + "moveUp": "Mover arriba", + "moveDown": "Mover abajo", + "removeFromSpaceDescription": "El chat sera removido del espacio pero continuara apareciendo en tu lista de chats.", + "countChats": "{chats} chats", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "startedAPoll": "{username} inició una encuesta.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Encuesta", + "startPoll": "Iniciar encuesta", + "endPoll": "Finalizar encuesta", + "answersVisible": "Respuestas visibles", + "spaceMemberOf": "Espacio miembro de {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Miembros del espacio de {spaces} pueden llamar", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Donar", + "answersHidden": "Respuestas ocultas", + "pollQuestion": "Pregunta de encuesta", + "answerOption": "Respuesta", + "addAnswerOption": "Añadir respuesta", + "allowMultipleAnswers": "Permitir varias respuestas", + "pollHasBeenEnded": "La encuesta ha terminado", + "countVotes": "{count, plural, =1{One vote} other{{count} votes}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Las respuestas serán visibles cuando termine la encuesta", + "replyInThread": "Contestar en el hilo", + "countReplies": "{count, plural, =1{One reply} other{{count} replies}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Hilo", + "backToMainChat": "Volver al chat pricipal", + "saveChanges": "Guardar cambios", + "createSticker": "Crear sticker o emoticono", + "useAsSticker": "Usar como sticker", + "useAsEmoji": "Usar como emoticono", + "stickerPackNameAlreadyExists": "El nombre del paquete de stickers ya existe", + "newStickerPack": "Nuevo paquete de stickers", + "stickerPackName": "Nombre del paquete de stickers", + "attribution": "Atribución", + "skipChatBackup": "Omitir copia de seguridad del chat", + "skipChatBackupWarning": "¿Estás seguro? Sin habilitar la copia de seguridad del chat puedes perder el acceso a tus mensajes si cambias de dispositivo.", + "loadingMessages": "Cargando mensajes", + "setupChatBackup": "Configurar la copia de seguridad del chat", + "noMoreResultsFound": "No se han encontrado más resultados", + "chatSearchedUntil": "Chat buscado hasta {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "URL de la Federación Base", + "clientWellKnownInformation": "Información conocida del cliente:", + "baseUrl": "URL Base", + "identityServer": "Identidad del Servidor:", + "versionWithNumber": "Versión: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Registros", + "advancedConfigs": "Configuración avanzada", + "advancedConfigurations": "Configuraciones Avanzadas", + "signIn": "Iniciar sesión", + "createNewAccount": "Crear nueva cuenta", + "signUpGreeting": "¡FluffyChat está descentralizado! ¡Selecciona un servidor donde quieres crear tu cuenta y sigamos!", + "signInGreeting": "¿Ya tienes una cuenta en Matrix? ¡Bienvenido de nuevo! Selecciona tu servidor e inicia sesión.", + "appIntro": "Con FluffyChat puedes hablar con tus amigos ¡Es un sistema de mensajería de [matrix] seguro y descentralizado! Aprende más en https://matrix.org si quieres o simplemente inicia sesión.", + "theProcessWasCanceled": "El proceso se ha cancelado.", + "join": "Unirse", + "searchOrEnterHomeserverAddress": "Buscar o pon la dirección de tu servidor local", + "matrixId": "Matrix ID" +} diff --git a/lib/l10n/intl_et.arb b/lib/l10n/intl_et.arb new file mode 100644 index 000000000..50dfc1458 --- /dev/null +++ b/lib/l10n/intl_et.arb @@ -0,0 +1,3159 @@ +{ + "@@locale": "et", + "@@last_modified": "2021-08-14 12:41:10.079944", + "about": "Rakenduse teave", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Nõustu", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} võttis kutse vastu", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Kasutajakonto", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐{username} võttis kasutusele läbiva krüptimise", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Lisa e-posti aadress", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Peakasutaja", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Kõik", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Kõik vestlused", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} vastas kõnele", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Kõik võivad liituda", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Rakenduse lukustus", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arhiiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Kas külalised võivad liituda?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Kas sa oled kindel?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Kas sa oled kindel, et soovid välja logida?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Selleks, et teist osapoolt identifitseerivat allkirja anda, palun sisesta oma turvahoidla paroolifraas või taastevõti.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Kas võtad vastu selle verifitseerimispalve kasutajalt {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Esita liikuvad kleepse ja emotikone automaatselt", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "See koduserver toetab Matrixi võrku sisselogimiseks:\n{serverVersions}\nAga see rakendus toetab vaid järgmisi võimalusi:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "See koduserver toetab Matrixi spetsifikatsioonist järgmisi versioone:\n{serverVersions}\nAga see rakendus toetab vaid järgmisi versioone: {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Keela ligipääs vestlusele", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Ligipääs vestlusele on keelatud", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} keelas ligipääsu kasutajale {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blokeeri seade", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Blokeeritud", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Robotite sõnumid", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Katkesta", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "{uri} aadressi avamine ei õnnestu", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Muuda seadme nime", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} muutis vestluse tunnuspilti", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} muutis vestluse uueks kirjelduseks '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} muutis vestluse uueks nimeks '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} muutis vestlusega seotud õigusi", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} muutis oma uueks kuvatavaks nimeks: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} muutis külaliste ligipääsureegleid", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} muutis külaliste ligipääsureegleid järgnevalt: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} muutis sõnumite ajaloo nähtavust", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} muutis sõnumite ajaloo nähtavust järgnevalt: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} muutis liitumise reegleid", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} muutis liitumise reegleid järgnevalt: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} muutis oma tunnuspilti", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} muutis jututoa aliast", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} muutis kutse linki", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Muuda salasõna", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Muuda koduserverit", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Muuda oma stiili", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Muuda vestlusrühma nime", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Muuda oma tunnuspilti", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Kasutatud krüptimine on vigane", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Vestlus", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Varunda vestlus", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Sinu vestluste varukoopia on krüptitud taastamiseks mõeldud turvavõtmega. Palun vaata, et sa seda ei kaota.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Vestluse teave", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Vestlused", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Vali korralik salasõna", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Kustuta arhiiv", + "close": "Sulge", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Sea sellele kasutajale antud jututoas suhtluskeeld", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Saada HTML-vormingus tekst", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Kutsu see kasutaja antud jututuppa", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Liitu selle jututoaga", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Eemalda antud kasutaja sellest jututoast", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Lahku sellest jututoast", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Kirjelda ennast", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Määra selles jututoas oma tunnuspilt (mxc-uri vahendusel)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Määra selles jututoas oma kuvatav nimi", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Seadista selle kasutaja õigusi (vaikimisi: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Saada vormindamata tekst", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Saada vastus reaktsioonina", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Saada sõnum", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Eemalda sellelt kasutajalt antud jututoas suhtluskeeld", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Vigane käsk", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} ei ole käsk.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Palun võrdle emotikone", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Palun võrdle numbreid", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Seadista vestlust", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Kinnita", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Ühenda", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Sinu kontakt on kutsutud liituma vestlusrühma", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Sisaldab kuvatavat nime", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Sisaldab kasutajanime", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Saatsime selle sisu kohta teate koduserveri haldajate", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Kopeerisin lõikelauale", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopeeri", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopeeri lõikelauale", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Sõnumi dekrüptimine ei õnnestunud: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} osalejat", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Loo", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} algatas vestluse", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Uus kogukond", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Hetkel aktiivne", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Tume", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}.{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}.{month}.{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Järgnevaga eemaldatakse sinu konto kasutusest. Seda tegevust ei saa tagasi pöörata! Kas sa ikka oled kindel?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Vaikimisi õigused uutele kasutajatele", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Kustuta", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Kustuta kasutajakonto", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Kustuta sõnum", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Seade", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Seadme tunnus", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Seadmed", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Otsevestlused", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Kuvatav nimi on muudetud", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Laadi fail alla", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Muuda", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Muuda blokeeritud serverite loendit", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Muuda kuvatavat nime", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Muuda jututoa aliast", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Muuda jututoa tunnuspilti", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Selline emotsioonitegevus on juba olemas!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Vigane emotsioonitegevuse lühikood!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Emotsioonitegevuste pakid jututoa jaoks", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emotsioonitegevuste seadistused", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Emotsioonitegevuse lühikood", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Sa pead valima emotsioonitegevuse lühikoodi ja pildi!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Vestlust pole olnud", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Võta emotsioonitegevuste pakid läbivalt kasutusele", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Kasuta krüptimist", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Sa ei saa hiljem enam krüptimist välja lülitada. Kas oled kindel?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Krüptitud", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Krüptimine", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Krüptimine ei ole kasutusel", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} lõpetas kõne", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Sisesta e-posti aadress", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Sisesta oma koduserveri aadress", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Viga asukoha tuvastamisel: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Kõik on valmis!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Äärmiselt solvav", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Faili nimi", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Fondi suurus", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Edasta", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Alates liitumise hetkest", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Kutse saamisest", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Hakka kasutama uut jututuba", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Vestlusrühm", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Vestlusrühm on avalik", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Vestlusrühmad", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Vestlusrühm {displayname} kasutajanimega", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Külalised ei ole lubatud", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Külalised võivad liituda", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} on võtnud tagasi {targetName} kutse", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Abiteave", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Peida muudetud sündmused", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Peida tundmatud sündmused", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Kui solvav see sisu on?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identiteet", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Eira", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Eiratud kasutajad", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Ma olen klõpsinud saadetud linki", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Vigane paroolifraas või taastevõti", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Kahjutu", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Kutsu sõpru ja tuttavaid", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Kutsu sõpru ja tuttavaid {groupName} liikmeks", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Kutsutud", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} saatis kutse kasutajale {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Ainult kutsutud kasutajatele", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Kutse minu jaoks", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} kutsus sind kasutama Matrix'i-põhist suhtlusrakendust FluffyChat. \n1. Ava fluffychat.im ja paigalda FluffyChat'i rakendus \n2. Liitu kasutajaks või logi sisse olemasoleva Matrix'i kasutajakontoga\n3. Ava kutse link: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "kirjutab…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} liitus vestlusega", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Liitu jututoaga", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} müksas kasutaja {targetName} välja", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅{username} müksas kasutaja {targetName} välja ning seadis talle suhtluskeelu", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Müksa vestlusest välja", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Viimati nähtud: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Lahku", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Lahkus vestlusest", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Litsents", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Hele", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Lisa veel {count} osalejat", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Laadin andmeid… Palun oota.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Laadi veel…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Asukohateenused on seadmes väljalülitatud. Asukoha jagamiseks palun lülita nad sisse.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Puudub luba asukohateenuste kasutamiseks. Asukoha jagamiseks palun anna rakendusele vastavad õigused.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Logi sisse", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Logi sisse {homeserver} serverisse", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Logi välja", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Muudatused liikmeskonnas", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Märgi ära", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Sõnumid", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderaator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Summuta vestlus", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Palun arvesta, et sa saad hetkel kasutada läbivat krüptimist vaid siis, kui koduserver kasutab Pantalaimon'it.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Uus vestlus", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Uus sõnum FluffyChat'i vahendusel", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Uus verifitseerimispäring!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Edasi", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Ei", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Puudub ühendus koduserveriga", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Ühtegi emotsioonitegevust ei leidunud. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Sa võid krüptimise kasutusele võtta niipea, kui jututuba pole enam avalik.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Tundub, et sinu nutiseadmes pole Firebase Cloud Messaging teenuseid. Sinu privaatsuse mõttes on see kindlasti hea otsus! Kui sa soovid FluffyChatis näha tõuketeavitusi, siis soovitame, et selle jaoks kasutad ntfy liidestust. Kasutades ntfyd või mõnda muud Unified Push standardil põhinevat liidestust saad tõuketeavitusi turvalisel moel. Ntfy rakendus on saadaval nii PlayStore kui F-Droidi rakendusepoodides.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} pole Matrix'i server, kas kasutame selle asemel {server2} serverit?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "none": "Mitte midagi", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Sa pole veel lisanud võimalust salasõna taastamiseks.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Õigused puuduvad", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Jututubasid ei leidunud…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Teavitused", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Teavitused on sellel kontol kasutusel", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} kasutajat kirjutavad…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Tuvastan asukohta…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Solvav", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Väljas", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Sobib", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Saadaval", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Krüptovõtmete veebipõhine varundus on kasutusel", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Hopsti! Kahjuks tekkis tõuketeavituste seadistamisel viga.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Hopsti! Midagi läks nüüd viltu…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Sõnumite lugemiseks ava rakendus", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Ava kaamera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Ava kaardirakendusega", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "või", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Osaleja", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "paroolifraas või taastevõti", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Salasõna", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Salasõna on ununenud", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Salasõna on muudetud", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Salasõna taastamine", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Inimesed", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Vali pilt", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Tõsta esile", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Esita {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Palun vali", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Palun vali rakenduse PIN-kood", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Jätkamiseks palun klõpsi sulle saadetud e-kirjas leiduvat linki.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Rakenduse luku jaoks sisesta 4 numbrit või kui sa sellist võimalust ei soovi kasutada, siis jäta nad tühjaks.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Palun sisesta oma salasõna", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Palun sisesta oma PIN-kood", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Palun sisesta oma kasutajanimi", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Palun järgi veebilehel olevaid juhiseid ja klõpsi nuppu Edasi.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privaatsus", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Avalikud jututoad", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Tõukereeglid", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Põhjus", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Salvestan", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} muutis sündmust", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Eemalda sõnum", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Registreeru", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Lükka tagasi", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} lükkas kutse tagasi", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Liitu uuesti", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Eemalda", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Eemalda kõik muud seadmed", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "{username} eemaldas sündmuse", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Eemalda seade", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Eemalda suhtluskeeld", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Kustuta oma tunnuspilt", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Asenda jututoa senine versioon uuega", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Vasta", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Teata sõnumist", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Palu õigusi", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Jututoa vesrioon on uuendatud", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Jututoa versioon", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Salvesta fail", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Otsi", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Turvalisus", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Sõnumit nägi {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Saada", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Saada sõnum", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Saada tekstisõnumina", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Saada helifail", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Saada fail", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Saada pilt", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Saada sõnumeid", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Saada fail muutmata kujul", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Saada kleeps", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Saada videofail", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} saatis faili", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} saatis helifaili", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} saatis pildi", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} saatis kleepsu", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} saatis video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} saatis teavet kõne kohta", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Määra põhinimeks", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Kohanda emotsioonitegevusi", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Tee kutselink", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Seadista õigusi", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Määra olek", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Seadistused", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Jaga", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} jagas oma asukohta", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Jaga asukohta", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Näita salasõna", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Ühekordne sisselogimine", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Jäta vahele", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Lähtekood", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Kogukond on avalik", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Kogukonna nimi", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} alustas kõnet", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Olek", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Kuidas sul täna läheb?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Saada", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sünkroniseerin andmeid… Palun oota.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Süsteem", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Nad ei klapi omavahel", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Nad klapivad omavahel", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Muuda olekut lemmikuna", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Lülita summutamine sisse või välja", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Märgi loetuks / lugemata", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Liiga palju päringuid. Palun proovi hiljem uuesti!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Tõsta teisest seadmest", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Proovi uuesti saata", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Eemal", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} eemaldas ligipääsukeelu kasutajalt {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Eemalda seadmelt blokeering", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Tundmatu seade", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Tundmatu krüptoalgoritm", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Tundmatu sündmuse tüüp '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Lõpeta vestluse vaigistamine", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Eemalda esiletõstmine", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 lugemata vestlus} other{{unreadCount} lugemata vestlust}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} ja {count} muud kirjutavad…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} ja {username2} kirjutavad…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} kirjutab…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪{username} lahkus vestlusest", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Kasutajanimi", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} saatis {type} sündmuse", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Verifitseeritud", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verifitseeri", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Alusta verifitseerimist", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Sinu verifitseerimine õnnestus!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verifitseerin teist kasutajakontot", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videokõne", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Vestluse ajaloo nähtavus", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Nähtav kõikidele osalejatele", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Nähtav kõikidele", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Häälsõnum", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Ootan, et teine osapool nõustuks päringuga…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Ootan teise osapoole kinnitust, et tegemist on samade emojidega…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Ootan teise osapoole kinnitust, et tegemist on samade numbritega…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Taustapilt:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Hoiatus!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Me saatsime sulle e-kirja", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Erinevatele kasutajatele lubatud toimingud", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Kes võivad selle vestlusrühmaga liituda", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Miks sa soovid sellest teatada?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Kas kustutame sinu vestluste varukoopia ja loome uue taastamiseks mõeldud krüptovõtme?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Nende e-posti aadresside abil saad taastada oma salasõna.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Koosta sõnum…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Jah", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Sina", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Sa enam ei osale selles vestluses", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Sinule on selles vestluses seatud suhtluskeeld", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Sinu avalik võti", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Lisasime vestluse kogukonda", + "addToSpace": "Lisa kogukonda", + "scanQrCode": "Skaneeri QR-koodi", + "sendOnEnter": "Saada sõnum sisestusklahvi vajutusel", + "homeserver": "Koduserver", + "serverRequiresEmail": "See koduserver eeldab registreerimisel kasutatava e-postiaadressi kinnitamist.", + "enableMultiAccounts": "(KATSELINE) Pruugi selles seadmes mitut Matrix'i kasutajakontot", + "bundleName": "Köite nimi", + "removeFromBundle": "Eemalda sellest köitest", + "addToBundle": "Lisa köitesse", + "editBundlesForAccount": "Muuda selle kasutajakonto köiteid", + "addAccount": "Lisa kasutajakonto", + "oneClientLoggedOut": "Üks sinu klientrakendustest on Matrix'i võrgust välja loginud", + "link": "Link", + "yourChatBackupHasBeenSetUp": "Sinu vestluste varundus on seadistatud.", + "unverified": "Verifitseerimata", + "repeatPassword": "Korda salasõna", + "messageInfo": "Sõnumi teave", + "time": "Kellaaeg", + "messageType": "Sõnumi tüüp", + "sender": "Saatja", + "openGallery": "Ava galerii", + "addToSpaceDescription": "Vali kogukond, kuhu soovid seda vestlust lisada.", + "removeFromSpace": "Eemalda kogukonnast", + "start": "Alusta", + "commandHint_discardsession": "Loobu sessioonist", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_clearcache": "Tühjenda vahemälu", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_dm": "Alusta otsevestlust\nKrüptimise keelamiseks kasuta --no-encryption võtit", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_create": "Loo tühi vestlusrühm\nKrüptimise keelamiseks kasuta --no-encryption võtit", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "openVideoCamera": "Tee video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "markAsRead": "Märgi loetuks", + "reportUser": "Teata kasutajast", + "openChat": "Ava vestlus", + "dismiss": "Loobu", + "reactedWith": "{sender} reageeris nii {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "emojis": "Emotikonid", + "placeCall": "Helista", + "unsupportedAndroidVersion": "See Androidi versioon ei ole toetatud", + "voiceCall": "Häälkõne", + "confirmEventUnpin": "Kas sa oled kindel, et tahad esiletõstetud sündmuse jäädavalt eemaldada?", + "pinMessage": "Tõsta sõnum jututoas esile", + "videoCallsBetaWarning": "Palun arvesta, et videokõned on veel beetajärgus. Nad ei pruugi veel toimida kõikidel platvormidel korrektselt.", + "emailOrUsername": "E-posti aadress või kasutajanimi", + "experimentalVideoCalls": "Katselised videokõned", + "unsupportedAndroidVersionLong": "See funktsionaalsus eeldab uuemat Androidi versiooni. Palun kontrolli, kas sinu nutiseadmele leidub süsteemiuuendusi või saaks seal Lineage OSi kasutada.", + "nextAccount": "Järgmine kasutajakonto", + "separateChatTypes": "Eraldi vestlused ja jututoad", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "errorAddingWidget": "Vidina lisamisel tekkis viga.", + "widgetNameError": "Palun sisesta kuvatav nimi.", + "addWidget": "Lisa vidin", + "previousAccount": "Eelmine kasutajakonto", + "widgetUrlError": "See pole korrektne URL.", + "widgetName": "Nimi", + "widgetCustom": "Kohandatud", + "widgetJitsi": "Jitsi Meet", + "widgetEtherpad": "Märkmed ja tekstid", + "widgetVideo": "Video", + "switchToAccount": "Pruugi kasutajakontot # {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "youAcceptedTheInvitation": "👍 Sa võtsid kutse vastu", + "youUnbannedUser": "Sa eemaldasid suhtluskeelu kasutajalt {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Sa oled tühistanud kutse kasutajale {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youBannedUser": "Sa seadsid suhtluskeelu kasutajale {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youJoinedTheChat": "Sa liitusid vestlusega", + "youKickedAndBanned": "🙅Sa müksasid kasutaja {user} välja ning seadsid talle suhtluskeelu", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "youRejectedTheInvitation": "Sa lükkasid kutse tagasi", + "youKicked": "👞 Sa müksasid kasutaja {user} välja", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Sa saatsid kutse kasutajale {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 {user} saatis sulle kutse", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "publish": "Avalda", + "pleaseEnterRecoveryKey": "Palun sisesta oma taastevõti:", + "recoveryKey": "Taastevõti", + "users": "Kasutajad", + "storeInSecureStorageDescription": "Salvesta taastevõti selle seadme turvahoidlas.", + "saveKeyManuallyDescription": "Salvesta see krüptovõti kasutades selle süsteemi jagamisvalikuid või lõikelauda.", + "storeInAndroidKeystore": "Vali salvestuskohaks Android KeyStore", + "storeInAppleKeyChain": "Vali salvestuskohaks Apple KeyChain", + "recoveryKeyLost": "Kas taasetvõti on kadunud?", + "pleaseEnterRecoveryKeyDescription": "Vanade sõnumite lugemiseks palun siseta oma varasemas sessioonis loodud taastevõti. Taastamiseks mõeldud krüptovõti EI OLE sinu salasõna.", + "storeSecurlyOnThisDevice": "Salvesta turvaliselt selles seadmes", + "unlockOldMessages": "Muuda vanad sõnumid loetavaks", + "countFiles": "{count} faili", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrate": "Ekspordi sessiooni teave ja kustuta nutiseadmest rakenduse andmed", + "dehydrateTor": "TOR'i kasutajad: Ekspordi sessioon", + "hydrateTor": "TOR'i kasutajatele: impordi viimati eksporditud sessiooni andmed", + "hydrateTorLong": "Kui viimati TOR'i võrku kasutasid, siis kas sa eksportisid oma sessiooni andmed? Kui jah, siis impordi nad mugavasti ja jätka suhtlemist.", + "indexedDbErrorTitle": "Brauseri privaatse akna kasutamisega seotud asjaolud", + "dehydrateWarning": "Seda tegevust ei saa tagasi pöörata. Palun kontrolli, et sa oled varukoopia turvaliselt salvestanud.", + "dehydrateTorLong": "Kui oled TOR'i võrgu kasutaja, siis enne akna sulgemist palun ekspordi viimase sessiooni andmed.", + "indexedDbErrorLong": "Privaatse akna puhul andmete salvestamine vaikimisi pole kasutusel.\nPalun toimi alljärgnevalt:\n- ava about:config\n- määra dom.indexedDB.privateBrowsing.enabled väärtuseks true\nVastasel juhul sa ei saa FluffyChat'i kasutada.", + "hydrate": "Taasta varundatud failist", + "user": "Kasutaja", + "custom": "Kohandatud", + "confirmMatrixId": "Konto kustutamiseks palun kinnita oma Matrix'i kasutajatunnus (Matrix ID).", + "supposedMxid": "See peaks olema {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "Märgi vestlusrühmaks", + "commandHint_markasdm": "Märgi otsevestusluseks antud Matrixi ID jaoks", + "whyIsThisMessageEncrypted": "Miks see sõnum pole loetav?", + "noKeyForThisMessage": "See võib juhtuda, kui sõnum oli saadetud enne, kui siin seadmes oma kontoga sisse logisid.\n\nSamuti võib juhtuda siis, kui saatja on lugemises selles seadmes blokeerinud või on tekkinud tõrkeid veebiühenduses.\n\nAga mõnes teises seadmes saad seda sõnumit lugeda? Siis sa võid sõnumi sealt üle tõsta. Ava Seadistused -> Seadmed ning kontrolli, et kõik sinu seadmed on omavahel verifitseeritud. Kui avad selle vestluse või jututoa ning mõlemad sessioonid on avatud, siis vajalikud krüptovõtmed saadetakse automaatset.\n\nKas sa soovid vältida krüptovõtmete kadumist väljalogimisel ja seadmete vahetusel? Siis palun kontrolli, et seadistuses on krüptovõtmete varundus sisse lülitatud.", + "callingPermissions": "Helistamise õigused", + "callingAccountDetails": "Võimaldab FluffyChat'il kasutada Androidi helistamisrakendust.", + "appearOnTop": "Luba pealmise rakendusena", + "otherCallingPermissions": "Mikrofoni, kaamera ja muud FluffyChat'i õigused", + "newGroup": "Uus jututuba", + "newSpace": "Uus kogukond", + "enterSpace": "Sisene kogukonda", + "enterRoom": "Ava jututuba", + "appearOnTopDetails": "Sellega lubad rakendust avada kõige pealmisena (pole vajalik, kui Fluffychat on juba seadistatud toimima helistamiskontoga)", + "callingAccount": "Helistamiskonto", + "screenSharingTitle": "ekraani jagamine", + "foregroundServiceRunning": "See teavitus toimib siis, kui esiplaaniteenus töötab.", + "allSpaces": "Kõik kogukonnad", + "screenSharingDetail": "Sa jagad oma ekraani FuffyChati vahendusel", + "numChats": "{number} vestlust", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Peida väheolulised olekuteated", + "doNotShowAgain": "Ära näita uuesti", + "commandHint_cuddle": "Saada üks kaisutus", + "commandHint_hug": "Saada üks kallistus", + "googlyEyesContent": "{senderName} saatis sulle otsivad silmad", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} kaisutab sind", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} kallistab sind", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_googly": "Saada ühed otsivad silmad", + "wasDirectChatDisplayName": "Sõnumiteta vestlus (vana nimega {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "startFirstChat": "Alusta oma esimest vestlust", + "encryptThisChat": "Krüpti see vestlus", + "disableEncryptionWarning": "Kui vestluses on krüptimine kasutusele võetud, siis turvalisuse huvides ei saa seda hiljem välja lülitada.", + "sorryThatsNotPossible": "Vabandust... see ei ole võimalik", + "deviceKeys": "Seadme võtmed:", + "newSpaceDescription": "Kogukonnad võimaldavad sul koondada erinevaid vestlusi ning korraldada avalikku või privaatset ühistegevust.", + "reopenChat": "Alusta vestlust uuesti", + "noOtherDevicesFound": "Muid seadmeid ei leidu", + "noBackupWarning": "Hoiatus! Kui sa ei lülita sisse vestluse varundust, siis sul puudub hiljem ligipääs krüptitud sõnumitele. Me tungivalt soovitame, et palun lülita vestluse varundamine sisse enne väljalogimist.", + "fileIsTooBigForServer": "Saatmine ei õnnestu! Serveri vaid kuni {max} suurusega manuseid.", + "fileHasBeenSavedAt": "Fail on salvestatud kausta: {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Liigu viimase loetud sõnumini", + "readUpToHere": "Siiamaani on loetud", + "jump": "Hüppa", + "openLinkInBrowser": "Ava link veebibrauseris", + "report": "teata", + "allRooms": "Kõik vestlusrühmad", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "😭 Oh appike! Midagi läks valesti. Kui soovid, võid sellest veast arendajatele teatada.", + "signInWithPassword": "Logi sisse salasõnaga", + "pleaseTryAgainLaterOrChooseDifferentServer": "Palun proovi hiljem uuesti või muuda serveri nime.", + "signInWith": "Logi sisse kasutades teenusepakkujat:", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "importFromZipFile": "Impordi zip-failist", + "exportEmotePack": "Ekspordi emotikonide pakk zip-failina", + "replace": "Asenda", + "notAnImage": "See pole pildifail.", + "importNow": "Impordi kohe", + "importEmojis": "Impordi emojid", + "sendTypingNotifications": "Saada kirjutamise teavitusi", + "createGroup": "Loo vestlusrühm", + "setTheme": "Vali teema:", + "inviteContactToGroupQuestion": "Kas sa soovid kutsuda kasutajat {contact} „{groupName}“ jututuppa?", + "tryAgain": "Proovi uuesti", + "chatPermissions": "Vestluse õigused", + "chatDescription": "Vestluse kirjeldus", + "noChatDescriptionYet": "Vestluse kirjeldus on puudu.", + "optionalRedactReason": "(Kui soovid lisada) Sõnumi muutmise põhjus...", + "messagesStyle": "Sõnumid:", + "shareInviteLink": "Jaga kutse linki", + "directChat": "Otsevestlus", + "setChatDescription": "Lisa vestluse kirjeldus", + "profileNotFound": "Sellist kasutajat serveris ei leidu. Tegemist võib olla kas võrguühenduse probleemiga või sellist kasutajat tõesti pole olemas.", + "setColorTheme": "Vali värviteema:", + "invite": "Kutsu", + "invalidServerName": "Vigane serveri nimi", + "addChatDescription": "Lisa vestluse kirjeldus...", + "chatDescriptionHasBeenChanged": "Vestluse kirjeldus on muutunud", + "redactMessageDescription": "Sõnumi muudatus kehtib kõikidele vestluses osalejatele. Seda muudatust ei saa tagasi pöörata.", + "redactedBy": "Muutja: {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactedByBecause": "Muutja {username} märkis põhjuseks: „{reason}“", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "inviteGroupChat": "📨 Kutse vestlusrühma", + "invitePrivateChat": "📨 Kutsu omavahelisele vestlusele", + "emoteKeyboardNoRecents": "Hiljuti kasutatud emotikonid kuvame siin...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "invalidInput": "Vigane sisend!", + "wrongPinEntered": "Sisestasid vale PIN-koodi! Proovi uuesti {seconds} sekundi pärast...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "banUserDescription": "Sellele kasutajale on nüüd selles jututoas seatud suhtluskeeld ning ta ei saa vestluses osaleda seni, kuni suhtluskeeld pole eemaldatud.", + "removeDevicesDescription": "Sind logitakse sellest seadmest välja ja sa enam ei saa sõnumeid.", + "unbanUserDescription": "Uuesti proovimisel saab see kasutaja nüüd vestlusega liituda.", + "pushNotificationsNotAvailable": "Tõuketeavitused pole saadaval", + "makeAdminDescription": "Kui annad sellele kasutajale peakasutaja õigused, siis kuna tal on sinuga samad õigused, sa ei saa seda toimingut enam tagasi pöörata.", + "archiveRoomDescription": "Selle vestluse tõstame nüüd arhiivi. Muud osalejad näevad, et sa oled vestlusest lahkunud.", + "hasKnocked": "🚪{user} on jututoa uksele koputanud", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "learnMore": "Loe lisaks", + "roomUpgradeDescription": "See vestlus luuakse nüüd uuesti jututoa uue versioonina. Kõik senised osalejad saavad teate, et nad peavad liituma uue vestlusega. Jututubade versioonide kohta leiad teavet https://spec.matrix.org/latest/rooms/ lehelt", + "pleaseEnterANumber": "Palun sisesta 0'st suurem number", + "kickUserDescription": "See kasutaja on nüüd jutuoast välja müksatud, kuid talle pole seatud suhtluskeeldu. Avaliku jututoa puhul saab ta alati uuesti liituda.", + "blockListDescription": "Sul on võimalik blokeerida neid kasutajaid, kes sind segavad. Oma isiklikku blokerimisloendisse lisatud kasutajad ei saa sulle saata sõnumeid ega kutseid.", + "createGroupAndInviteUsers": "Lisavestlusrühm ja kutsu sinna kasutajaid", + "startConversation": "Alusta vestlust", + "blockedUsers": "Blokeeritud kasutajad", + "groupCanBeFoundViaSearch": "Vestlusrühm on leitav otsinguga", + "noUsersFoundWithQuery": "Päringuga „{query}“ ei leidunud kahkus ühtegi kasutajat. Palun kontrolli, et päringus poleks vigu.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "block": "Blokeeri", + "yourGlobalUserIdIs": "Sinu üldine kasutajatunnus on: ", + "commandHint_sendraw": "Saada json oma algupärasel kujul", + "wrongRecoveryKey": "Vabandust..., see ei tundu olema korrektne taastevõti.", + "blockUsername": "Eira kasutajanime", + "groupName": "Vestlusrühma nimi", + "databaseMigrationTitle": "Andmebaas on optimeeritud", + "searchChatsRooms": "Otsi #vestlusi, @kasutajaid...", + "databaseMigrationBody": "Palun oota üks hetk. Natuke võib kuluda aega.", + "thisDevice": "See seade:", + "publicSpaces": "Avalikud kogukonnad", + "passwordIsWrong": "Sinu sisestatud salasõna on vale", + "pleaseEnterYourCurrentPassword": "Palun sisesta oma praegune salasõna", + "publicLink": "Avalik link", + "nothingFound": "Ei leidnud mitte midagi...", + "decline": "Keeldu", + "newPassword": "Uus salasõna", + "passwordsDoNotMatch": "Salasõnad ei klapi omavahel", + "subspace": "Jututuba või alamkogukond", + "select": "Vali", + "pleaseChooseAStrongPassword": "Palun sisesta korralik salasõna", + "addChatOrSubSpace": "Lisa vestlus või jututuba", + "leaveEmptyToClearStatus": "Senise oleku eemaldamiseks jäta väärtus tühjaks.", + "joinSpace": "Liitu kogukonnaga", + "searchForUsers": "Otsi kasutajat @kasutajanimi ...", + "databaseBuildErrorBody": "SQlite andmebaasi loomine ei õnnestu. Seetõttu üritab rakendus kasutada senist andmehoidlat. Palun teata sellest veast arendajatele siin: {url} märkides veateate: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "Rakenduse käivitamisel tekkis viga", + "sessionLostBody": "Sinu sessioon on kadunud. Palun teata sellest veast arendajatele siin: {url} märkides veateate: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Nüüd üritab rakendus taastada sinu sessiooni varukoopiast. Palun teata sellest veast arendajatele siin: {url} märkides veateate: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "transparent": "Läbipaistev", + "youInvitedToBy": "📩 Sa oled lingiga saanud kutse jututuppa:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "sendReadReceipts": "Saada lugemisteatisi", + "verifyOtherUserDescription": "Kui sa oled vestluse teise osapoole verifitseerinud, siis saad kindel olla, et tead, kellega suhtled. 💪\n\nKui alustad verifitseerimist, siis sinul ja teisel osapoolel tekib rakenduses hüpikaken. Seal kuvatakse emotikonide või numbrite jada, mida peate omavahel võrdlema.\n\nKõige lihtsam on seda teha kas omavahelise kohtumise ajal või videokõne kestel. 👭", + "forwardMessageTo": "Kas edastame sõnumi jututuppa {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Muud vestluses osalejad saavad näha, kui sa oled uut sõnumit kirjutamas.", + "sendReadReceiptsDescription": "Muud vestluses osalejad näevad, kas oled sõnumit lugenud.", + "formattedMessages": "Vormindatud sõnumid", + "verifyOtherUser": "🔐 Verifitseeri teine kasutaja", + "verifyOtherDevice": "🔐 Verifitseeri oma muu seade", + "canceledKeyVerification": "{sender} katkestas krüptovõtmete verifitseerimise", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} sai valmis krüptovõtmete verifitseerimise", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "formattedMessagesDescription": "Kasutades markdown-süntaksit kuva vormindust, nagu rasvases kirjas tekst.", + "verifyOtherDeviceDescription": "Kui sa oled oma muu seadme verifitseerinud, siis need seadmed võivad vahetada krüptovõtmeid ning see parandab üldist turvalisust. 💪 Kui alustad verifitseerimist, siis sinu mõlemas seadmes tekib rakenduses hüpikaken. Seal kuvatakse emotikonide või numbrite jada, mida pead omavahel võrdlema. On oluline, et mõlemad seadmed on verifitseerimise alustamisel sinu kõrval. 🤳", + "acceptedKeyVerification": "{sender} nõustus krüptovõtmete verifitseerimisega", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} on valmis krüptovõtmete verifitseerimiseks", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} palus krüptovõtmete verifitseerimist", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} alustas krüptovõtmete verifitseerimist", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "presenceStyle": "Olekuteated:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Näita teiste kasutajate olekuteateid", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "incomingMessages": "Saabuvad sõnumid", + "hidePresences": "Peida olekute loend?", + "stickers": "Kleepsud", + "discover": "Otsi ja leia", + "commandHint_ignore": "Eira seda Matrixi kasutajatunnust", + "commandHint_unignore": "Lõpeta selle Matrixi kasutajatunnuse eiramine", + "unreadChatsInApp": "{appname}: {unread} lugemata vestlust", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "globalChatId": "Üldine vestluse tunnus", + "accessAndVisibilityDescription": "Kes võib selle vestlusega liituda ja kuidas on võimalik seda vestlust leida.", + "hideRedactedMessagesBody": "Kui keegi muudab sõnumit, siis teda enam ei kuvataks vestluses.", + "userWouldLikeToChangeTheChat": "{user} soovib liituda vestlusega.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hideMemberChangesInPublicChats": "Peida avalike vestluste liikmelisuse muutused", + "notifyMeFor": "Teavita mind kui", + "usersMustKnock": "Kasutajad peavad uksele koputama", + "noOneCanJoin": "Mitte keegi ei saa liituda", + "knocking": "Koputus uksele", + "chatCanBeDiscoveredViaSearchOnServer": "Vestluse või jututoa saad leida otsingust serveris {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "publicChatAddresses": "Vestluse avalik aadress", + "minimumPowerLevel": "{level} on väikseim võimalik õiguste tase.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Andmebaasi krüptimine pole sellel platvormil toetatud", + "noPublicLinkHasBeenCreatedYet": "Avalikult kasutatavat linki pole veel olemas", + "knock": "Koputa uksele", + "appLockDescription": "Kui sa rakendust parasjagu ei kasuta, siis lukusta ta PIN-koodiga", + "accessAndVisibility": "Ligipääsetavus ja nähtavus", + "calls": "Kõned", + "customEmojisAndStickers": "Kohandatud emotikonid ja kleepsud", + "customEmojisAndStickersBody": "Lisa või jaga kohandatud emotikone või kleepsupakke, mida võiks kasutada igas vestluses.", + "hideRedactedMessages": "Peida muudetud sõnumid", + "hideInvalidOrUnknownMessageFormats": "Peida vigase või tundmatu vorminguga sõnumid", + "hideMemberChangesInPublicChatsBody": "Parema loetavuse nimel ära näita vestluse ajajoonel avaliku jututoaga liitumisi ja sealt lahkumisi.", + "overview": "Ülevaade", + "passwordRecoverySettings": "Salasõna taastamise seadistused", + "createNewAddress": "Loo uus aadress", + "userRole": "Kasutaja roll", + "thereAreCountUsersBlocked": "Hetkel on {count} blokeeritud kasutajat.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "searchIn": "Otsi vestlusest „{chat}“...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Otsi veel...", + "knockRestricted": "Koputa piiratud ligipääsuga jututoa uksele", + "restricted": "Piiratud", + "gallery": "Galerii", + "files": "Failid", + "swipeRightToLeftToReply": "Vastamiseks viipa paremalt vasakule", + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "noMoreChatsFound": "Rohkem vestlusi ei leidu...", + "joinedChats": "Vestlusi, millega oled liitunud", + "unread": "Lugemata", + "space": "Kogukond", + "spaces": "Kogukonnad", + "goToSpace": "Ava kogukond: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Märgi mitteloetuks", + "countChatsAndCountParticipants": "{chats} vestlust ja {participants} osalejat", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "userLevel": "{level} - kasutaja", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - moderaator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - peakasutaja", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheVisibilityOfChatHistory": "Muuda vestluse ajaloo nähtavust", + "sendRoomNotifications": "Saada @jututuba teavitusi", + "changeTheCanonicalRoomAlias": "Muuda vestluse põhilist avalikult nähtavat aadressi", + "changeGeneralChatSettings": "Muuda vestluse üldiseid seadistusi", + "inviteOtherUsers": "Kutsu teisi osalejaid sellesse vestlusesse", + "changeTheChatPermissions": "Muuda vestluse õigusi", + "changeTheDescriptionOfTheGroup": "Muuda vestluse kirjeldust", + "chatPermissionsDescription": "Määra erinevatele kasutajatele selles vestluses vajalikud õigused. Tüüpiliselt on need 0, 50 ja 100 (vastavalt kasutajad, moderaatorid ja peakasutajad), kuid igasugused vahepealsed variatsioonid on ka võimalikud.", + "invitedBy": "📩 Kutsujaks {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "updateInstalled": "🎉 Versiooniuuendus {version} on paigaldatud!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Muudatuste logi", + "sendCanceled": "Saatmine on katkestatud", + "noChatsFoundHere": "Siin ei leidu veel ühtegi vestlust. Alusta uut vestlust klõpsides allpool asuvat nuppu. ⤵️", + "loginWithMatrixId": "Logi sisse Matrix-ID alusel", + "discoverHomeservers": "Leia koduservereid", + "whatIsAHomeserver": "Mis on koduserver?", + "homeserverDescription": "Sarnaselt e-postiteenuse pakkujale on kõik sinu sõnumid salvestatud koduserveris. Sa võid valida sellise koduserveri, nagu sulle meeldib ja nad kõik suudavad teiste koduserveritega suhelda. Lisateavet leiad veebisaidist https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Ei tundu olema ühilduv koduserver. Kas võrguaadress on ikka õige?", + "prepareSendingAttachment": "Valmistume manuse saatmiseks...", + "generatingVideoThumbnail": "Loome video pisipilti...", + "compressVideo": "Pakime videot väiksemaks...", + "sendingAttachmentCountOfCount": "Saadame manust: {index} pikkusega {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Serveri poolt lubatud ülempiir on käes. Ootame {seconds} sekundit...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendingAttachment": "Saadame manust...", + "calculatingFileSize": "Arvutame faili suurust...", + "oneOfYourDevicesIsNotVerified": "Üks sinu seadmetest pole verifitseeritud", + "noticeChatBackupDeviceVerification": "Märkus: kui liidad kõik oma seadmed vestluste varundamisega, siis on nad sellega ka automaatselt verifitseeritud.", + "continueText": "Jätka", + "welcomeText": "Tere, tere 👋 See on FluffyChat. Sa võid sisse logida igasse koduserverisse, mis ühildub https://matrix.org serveriga. Ja seejärel saad suhelda kõigiga. Tegemist on ikka väga suure detsentraliseeritud sõnumivõrguga!", + "setWallpaper": "Määra taustapildiks", + "manageAccount": "Halda kasutajakontot", + "blur": "Hägusus:", + "opacity": "Läbipaistmatus:", + "contactServerSecurity": "Võta ühendust serveri andmeturbe eest vastutajaga", + "supportPage": "Kasutajatugi", + "serverInformation": "Serveri teave:", + "name": "Nimi", + "version": "Versioon", + "noContactInformationProvided": "Server ei jaga asjakohast kontaktteavet", + "contactServerAdmin": "Võta ühendust serveri haldajaga", + "website": "Veebisait", + "aboutHomeserver": "Koduserveri teave: {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "pleaseFillOut": "Palun täida", + "invalidUrl": "Vigane võrguaadress", + "addLink": "Lisa link", + "strikeThrough": "Läbikriipsutatud kiri", + "boldText": "Paks kiri", + "italicText": "Kaldkiri", + "unableToJoinChat": "Vestlusega liitumine ei õnnestu. Võib-olla on teine osapool juba vestluse sulgenud.", + "sendImages": "Saada {count} pilti", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Paki kokku", + "previous": "Eelmine", + "otherPartyNotLoggedIn": "Vestluse teine osapool pole hetkel võrku loginud ega seega saa neid sõnumeid kohe kätte!", + "open": "Ava", + "appWantsToUseForLoginDescription": "Järgnevaga lubad sa, et rakendus ja veebisait jagavad teavet sinu kohta.", + "appWantsToUseForLogin": "Sisselogimiseks kasuta serverit '{server}'", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "waitingForServer": "Ootame serveri vastust...", + "appIntroduction": "FluffyChat võimaldab sul suhelda sõprade ja tuttavatega, kes kasutavad erinevaid sõnumikliente. Lisateavet leiad https://matrix.org saidist või lihtsalt klõpsi „Jätka“.", + "synchronizingPleaseWaitCounter": " Sünkroniseerime… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "newChatRequest": "📩 Uus vestluskutse", + "notificationRuleCallDescription": "Teavita kasutajat saabuvast video- või häälkõnest.", + "notificationRuleEncryptedRoomOneToOneDescription": "Teavita kasutajat kahepoolse krüptitud vestluse sõnumitest.", + "notificationRuleMasterDescription": "Ära järgi muid reegleid ja lülita kõik teavitused välja.", + "notificationRuleSuppressNoticesDescription": "Ära teavita sõnumite puhul, mis on genereeritud masinate, nt jututubade robotite poolt.", + "notificationRuleSuppressEdits": "Peida muutmised", + "notificationRuleInviteForMeDescription": "Teavita kasutajat jututoa kutse saamisel.", + "notificationRuleIsUserMentionDescription": "Teavita kasutajat, kui ta on sõnumis otseselt mainitud.", + "notificationRuleContainsDisplayNameDescription": "Teavita kasutajat, kui sõnumis leidub ta kuvatav nimi.", + "notificationRuleJitsi": "Jitsi videokõned", + "notificationRuleRoomnotif": "Jututoa üldteavitus", + "notificationRuleRoomnotifDescription": "Teavita kasutajat, kui jututuba on sõnumis otseselt mainitud viisil „@toanimi“.", + "generalNotificationSettings": "Üldised teavituste seadistused", + "roomNotificationSettings": "Jututoa teavituste seadistused", + "userSpecificNotificationSettings": "Kasutajakohaste teavituste seadistused", + "notificationRuleContainsUserName": "Kasutajanime olemasolul", + "notificationRuleSuppressNotices": "Ära teavita automaatsete sõnumite korral", + "notificationRuleMemberEventDescription": "Ära teavita sõnumite puhul, mis seotud jututubade liikmelisusega.", + "notificationRuleIsUserMention": "Kasutaja mainimised", + "notificationRuleContainsDisplayName": "Kuvatava nime sisaldumisel", + "notificationRuleIsRoomMention": "Jututoa mainimine", + "notificationRuleIsRoomMentionDescription": "Teavita kasutajat, kui jututuba on sõnumis otseselt mainitud.", + "notificationRuleTombstone": "Jututoa tegevuse lõpetamine", + "notificationRuleTombstoneDescription": "Teavita kasutajat jututoa väljalülitamisega seotud sõnumite korral.", + "notificationRuleReaction": "Reageerimised", + "notificationRuleRoomServerAcl": "Jututoa ligipääsuõigused serveris", + "notificationRuleSuppressEditsDescription": "Peida teavitused sõnumite muutmise kohta.", + "notificationRuleCall": "Kõned", + "notificationRuleEncryptedRoomOneToOne": "Kahepoolne vestlus krüptitud jututoas", + "notificationRuleRoomOneToOne": "Kahepoolne vestlus krüptimata jututoas", + "notificationRuleMessageDescription": "Teavita kasutajat üldistest sõnumitest.", + "notificationRuleEncrypted": "Krüptitud sõnumid", + "notificationRuleEncryptedDescription": "Teavita kasutajat sõnumitest krüptitud jututubades.", + "notificationRuleJitsiDescription": "Teavita kasutajat sündmustest Jitsi vidinas.", + "notificationRuleMessage": "Üldised sõnumid", + "notificationRuleServerAclDescription": "Peida teavitused ligipääsuõiguste muutuste korral serveris.", + "unknownPushRule": "Tõuketeavituse tundmatu reegel '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "more": "Lisateave", + "notificationRuleInviteForMe": "Kutsed mulle", + "notificationRuleContainsUserNameDescription": "Teavita kasutajat, kui sõnumis on tema kasutajanimi.", + "contentNotificationSettings": "Sisuteavituste seadistused", + "notificationRuleRoomServerAclDescription": "Peida teavitused jututoa ligipääsuõiguste muutuste korral serveris.", + "notificationRuleRoomOneToOneDescription": "Teavita kasutajat kahepoolse krüptimata vestluse sõnumitest.", + "notificationRuleServerAcl": "Ligipääsuõigused serveris", + "notificationRuleMemberEvent": "Jututoa liikmelisusega seotud sündmus", + "notificationRuleMaster": "Summuta kõik teavitused", + "notificationRuleReactionDescription": "Teavita kasutajat sõnumitele reageerimise korral.", + "otherNotificationSettings": "Muud teavituste seadistused", + "deletePushRuleCanNotBeUndone": "Kui sa kustutad selle teavituse seadistuse, siis seda tegevust tagasi võtta ei saa.", + "shareKeysWith": "Jaga võtmeid seadmega...", + "shareKeysWithDescription": "Missuguseid seadmeid sa usaldad, et neist võiks lugeda krüptitud vestluste sõnumeid?", + "allDevices": "Kõiki seadmeid", + "crossVerifiedDevicesIfEnabled": "Risttunnustatud seadmeid, kui see võimalus on kasutusel", + "crossVerifiedDevices": "Risttunnustatud seadmeid", + "verifiedDevicesOnly": "Vaid verifitseeritud seadmeid", + "recordAVideo": "Salvesta video", + "takeAPhoto": "Pildista", + "optionalMessage": "Sõnum (kui soovid lisada)...", + "notSupportedOnThisDevice": "See pole antud seadmes toetatud", + "enterNewChat": "Liitu uue vestlusega", + "commandHint_roomupgrade": "Uuenda see jututuba antud jututoa versioonini", + "setCustomPermissionLevel": "Seadista kohandatud õiguste tase", + "setPermissionsLevelDescription": "Palun vali eelseadistatud rollide seast või lisa õiguste tase vahemikus 0 kuni 100.", + "ignoreUser": "Eira kasutajat", + "normalUser": "Tavakasutaja", + "approve": "Kiida heaks", + "pleaseWaitUntilInvited": "Palun oota seni, kuni keegi jututoast saadab sulle kutse.", + "youHaveKnocked": "Sa oled koputanud", + "countInvited": "{count} kutsutut", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Häälsõnum kasutajalt {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "checkList": "Kontrollnimekiri", + "commandHint_logoutall": "Logi kõikidest aktiivsetest seadmetest välja", + "commandHint_logout": "Logi oma praegusest seadmest välja", + "displayNavigationRail": "Näita mobiilis külgmist tööriistariba", + "customReaction": "Kohandatud reaktsioon", + "moreEvents": "Veel sündmusi", + "declineInvitation": "Keeldu kutsest", + "noMessagesYet": "Pole veel ühtegi sõnumit", + "longPressToRecordVoiceMessage": "Pika vajutusega saad salvestada häälsõnumi.", + "pause": "Peata", + "resume": "Jätka", + "newSubSpace": "Uus alamkogukond", + "moveToDifferentSpace": "Tõsta teise kogukonda", + "moveUp": "Liiguta ülespoole", + "moveDown": "Liiguta allapoole", + "removeFromSpaceDescription": "See vestlus eemaldatakse nüüd kogukonnast, kuid on jätkuvalt nähtav sinu vestluste loendis.", + "countChats": "{chats} vestlust", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Kogukonna liige: {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "{spaces} kogukonna liige võib uksele koputada", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Toeta meid rahaliselt", + "startedAPoll": "{username} koostas küsitluse.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Küsitlus", + "startPoll": "Koosta küsitlus", + "endPoll": "Lõpeta küsitlus", + "answersVisible": "Vastused on näha", + "answersHidden": "Vastused on peidetud", + "pollQuestion": "Küsitluse küsimus", + "answerOption": "Valikvastus", + "addAnswerOption": "Lisa valikvastus", + "allowMultipleAnswers": "Luba mitu vastusevalikut", + "pollHasBeenEnded": "Küsitlus on lõppenud", + "countVotes": "{count, plural, =1{Üks hääl} other{{count} häält}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Vastused on näha küsitluse lõppedes", + "replyInThread": "Vasta jutulõngas", + "countReplies": "{count, plural, =1{Üks vastus} other{{count} vastust}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Jutulõng", + "backToMainChat": "Tagasi põhivestlusesse", + "saveChanges": "Salvesta muudatused", + "createSticker": "Loo kleeps või emoji", + "useAsSticker": "Kasuta kleepsuna", + "useAsEmoji": "Kasuta emojina", + "stickerPackNameAlreadyExists": "Selline kleepsupaki nimi on juba olemas", + "newStickerPack": "Uus kleepsupakk", + "stickerPackName": "Kleepsupaki nimi", + "attribution": "Autoriõigused", + "skipChatBackup": "Jäta vestluse varundamine vahele", + "skipChatBackupWarning": "Kas oled kindel? Kui sa pole lülitanud sisse vestluste krüptovõtmete varundust, siis võid oma seadme vahetamisel kaotada ligipääsu oma senistele sõnumitele.", + "loadingMessages": "Laadin sõnumeid", + "setupChatBackup": "Võta kasutusele vestluste varundus", + "changedTheChatDescription": "{username} muutis vestluse kirjeldust", + "changedTheChatName": "{username} muutis vestluse nime", + "noMoreResultsFound": "Rohkem tulemusi ei leidu", + "chatSearchedUntil": "Otsing vestlusest kuni {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "Födereerimise alusaadress", + "clientWellKnownInformation": "Kliendi „.well-known“ teave:", + "baseUrl": "Alusaadress", + "identityServer": "Isikutuvastusserver:", + "versionWithNumber": "Versioon: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Logid", + "advancedConfigs": "Täiendav seadistus", + "advancedConfigurations": "Täiendavad seadistused", + "signInWithLabel": "Logi sisse kasutades:", + "signIn": "Logi sisse", + "createNewAccount": "Loo uus kasutajakonto", + "signUpGreeting": "FluffyChat kasutab hajutatud võrku! Vali server, kuhu tahad oma kasutajakonto lisada ning alustame!", + "signInGreeting": "Sul juba on Matrixi kasutajakonto olemas? Tere tulemast tagasi! Vali oma koduserver ja logi sisse.", + "appIntro": "FluffyChati abil saad suhelda oma sõpradega. See on turvaline ja hajutatud sõnumiklient [matrix]-i võrgus! Lisateavet leiad https://matrix.org saidist või lihtsalt liitu.", + "theProcessWasCanceled": "Protsess on katkestatud.", + "join": "Liitu", + "searchOrEnterHomeserverAddress": "Otsi koduserveri aadressi või sisesta see", + "matrixId": "Matrixi kasutajatunnus", + "setPowerLevel": "Seadista õigusi", + "makeModerator": "Määra moderaatoriks", + "makeAdmin": "Määra peakasutajaks", + "removeModeratorRights": "Eemalda moderaatori õigused", + "removeAdminRights": "Eemalda peakasutaja õigused", + "powerLevel": "Õiguste tase", + "setPowerLevelDescription": "Õiguste tase on üks võimalusi kirjeldamaks seda, mida kasutaja saab jututoas teha ning see tavaliselt väljendub numbriga vahemikust 0 kuni 100.", + "owner": "Omanik" +} diff --git a/lib/l10n/intl_eu.arb b/lib/l10n/intl_eu.arb new file mode 100644 index 000000000..fc913cb75 --- /dev/null +++ b/lib/l10n/intl_eu.arb @@ -0,0 +1,3151 @@ +{ + "@@locale": "eu", + "@@last_modified": "2021-08-14 12:41:10.062383", + "about": "Honi buruz", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Onartu", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username}(e)k gonbidapena onartu du", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Kontua", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username}(e)k ertzetik ertzerako zifratzea gaitu du", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Administratzailea", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "ezizena", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName}(e)k deia erantzun du", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Edonor batu daiteke", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "Fitxategia", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Batu al daitezke bisitan dauden erabiltzaileak", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Ziur zaude?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Beste pertsona egiaztatzeko, sartu zure biltegiratze segururako pasaesaldia edo berreskuratze-gakoa.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "{username}(r)en egiaztaketa-eskaera onartu?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banFromChat": "Txatera batzeko debekua ezarri", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Kanporatuta", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username}(e)k {targetName}(r)i debekua ezarri dio", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blokeatu gailua", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "cancel": "Utzi", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username}(e)k txataren abatarra aldatu du", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username}(e)k txataren deskribapena aldatu du: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username}(e)k txataren izena '{chatname}'(e)ra aldatu du", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username}(e)k txataren baimenak aldatu ditu", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username}(e)k bere ezizena aldatu du. Aurrerantzean '{displayname}' izango da", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username}(e)k bisitarien sarbide-arauak aldatu ditu", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username}(e)k bisitarien arauak aldatu ditu: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username}(e)k historiaren ikusgaitasuna aldatu du", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username}(e)k historiaren ikusgaitasuna {rules}-(e)ra aldatu du", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username}(e)k batzeko arauak aldatu ditu", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username}(e)k batzeko arauak aldatu ditu: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username}(e)k profileko abatarra aldatu du", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username}(e)k gelaren ezizena aldatu du", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username}(e)k gonbidapen-esteka aldatu du", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeTheHomeserver": "Aldatu zerbitzaria", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Aldatu itxura", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Taldearen izena aldatu", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Zifratzea hondatu egin da", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Txata", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Txataren xehetasunak", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Aukeratu pasahitz sendo bat", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Itxi", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Konparatu emojiak", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Konparatu zenbakiak", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Baieztatu", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Konektatu", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontaktua taldera gonbidatu da", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Arbelera kopiatu da", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopiatu", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Ezin izan da mezua deszifratu: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} partaide", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Sortu", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username}(e)k txata sortu du", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Une honetan aktibo", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Iluna", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}/{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}/{month}/{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "delete": "Ezabatu", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Mezuak ezabatu", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Gailua", + "@device": { + "type": "String", + "placeholders": {} + }, + "devices": "Gailuak", + "@devices": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Ezizena aldatu da", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Deskargatu fitxategia", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Editatu ezizena", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emotea badago lehendik ere!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Emotearen laburdura ez da baliozkoa!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emote-ezarpenak", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Laburdura", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Emote-laburdura eta irudi bat aukeratu behar dituzu!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Txata hutsik dago", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Ezingo duzu zifratzea ezgaitu. Ziur zaude?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryption": "Zifratzea", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Zifratzea ez dago gaituta", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName}(e)k deia amaitu du", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterYourHomeserver": "Sartu zure zerbitzaria", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "fileName": "Fitxategiaren izena", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Birbidali", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Batzeaz geroztik", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Gonbidapenaz geroztik", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Taldea", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Taldea publikoa da", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "{displayname} duen taldea", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Ez, bisitariak ez daude baimenduta", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Bai, bisitariak batu daitezke", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username}(e)k {targetName}(r)en gonbidapena atzera bota du", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Laguntza", + "@help": { + "type": "String", + "placeholders": {} + }, + "id": "IDa", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identitatea", + "@identity": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Pasaesaldi edo berreskuratze-gakoa ez da zuzena", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Kontaktuak gonbidatu", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Gonbidatu kontaktua {groupName}(e)ra", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Gonbidatuta", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username}(e)k {targetName} gonbidatu du", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Gonbidatutako erabiltzaileak solik", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username}(e)k FluffyChatera gonbidatu zaitu.\n1. Bisitatu https://fluffychat.im eta instalatu aplikazioa\n2. Eman izena edo hasi saioa\n3. Ireki gonbidapen-esteka:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "idazten ari da…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} txatera batu da", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Batu gelara", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username}(e)k {targetName} kanporatu du", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username}(e)k {targetName} kanporatu eta debekua ezarri dio", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Txatetik kanporatu", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Azkenekoz aktibo: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Irten", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Txatetik irten da", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Lizentzia", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Argia", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Kargatu {count} partaide gehiago", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Kargatzen… itxaron.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Kargatu gehiago…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Hasi saioa", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Hasi saioa {homeserver}(e)n", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Amaitu saioa", + "@logout": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderatzailea", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Mututu txata", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Kontuan izan oraingoz Pantalaimon behar duzula ertzetik ertzerako zifratzerako.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Mezu berria FluffyChaten", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Egiaztaketa-eskaera berria!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "no": "Ez", + "@no": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Ez da emoterik aurkitu. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Ez dirudi Firebase Cloud Messaging zure mugikorrean erabilgarri dagoenik. Jakinarazpenak jasotzeko ntfy instalatzea gomendatzen dugu. ntfy edo beste Unified Push hornitzaileren batekin, push jakinarazpenak jaso ditzazkezu datuentzako segurua den modu batean. ntfy PlayStore edo F-Droid dendetatik deskarga dezakezu.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Bat ere ez", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Baimenik gabe", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Ez da gelarik aurkitu…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "ok": "Ados", + "@ok": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Gakoen online babeskopia gaituta dago", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Hara, zerbaitek huts egin du…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Ireki aplikazioa mezuak irakurtzeko", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Ireki kamera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "pasaesaldia edo berreskuratze-gakoa", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Pasahitza", + "@password": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Aukeratu irudi bat", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Finkatu", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Abiarazi {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnterYourPassword": "Sartu zure pasahitza", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Sartu zure erabiltzaile-izena", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Gela publikoak", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "recording": "Grabatzen", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username}(e)k gertaera bat atzera bota du", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Baztertu", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username}(e)k gonbidapena baztertu du", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Batu berriro", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Kendu", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Kendu gainerako gailu guztiak", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "{username}(e)k kendu du", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Kendu gailua", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Kendu txatean duen debekua", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "Erantzun", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Eskatu baimena", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Gela bertsio-berritu da", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "{username}(e)k ikusi du", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Bidali", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Bidali mezua", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Bidali audioa", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Bidali fitxategia", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Bidali irudia", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Bidali jatorrizkoa", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Bidali bideoa", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username}(e)k fitxategia bidali du", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username}(e)k audioa bidali du", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username}(e)k irudia bidali du", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username}(e)k pegatina bidali du", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username}(e)k bideoa bidali du", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName}(e)k deiaren informazioa bidali du", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setInvitationLink": "Gonbidapen-esteka ezarri", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Ezarri egoera", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Ezarpenak", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Partekatu", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username}(e)k kokapena partekatu du", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "skip": "Saltatu", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Iturburu kodea", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName}(e)k deia hasi du", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "statusExampleMessage": "Zer moduz zaude gaur?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Bidali", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistemak darabilena", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Ez datoz bat", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Bat datoz", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Saiatu berriro bidaltzen", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username}(e)k {targetName}(r)i debekua kendu dio", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Desblokeatu gailua", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Gailu ezezaguna", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Zifratze-algoritmo ezezaguna", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "'{type}' gertaera ezezaguna", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Utzi txata mututzeari", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Utzi finkatzeari", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "userAndOthersAreTyping": "{username} eta beste {count} idazten ari dira…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} eta {username2} idazten ari dira…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} idazten ari da…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username}(e)k txata utzi du", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Erabiltzaile-izena", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username}(e)k {type} gertaera bat bidali du", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "Egiaztatu", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Abiarazi egiaztaketa", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Ondo egiaztatu duzu!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Beste kontua egiaztatzen", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Bideo-deia", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Txat-historiaren ikusgaitasuna", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Partaide guztientzat ikusgai", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Edonorentzat ikusgai", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Ahozko mezua", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Kideak eskaera onartuko zain…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Kideak emojia onartuko zain…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Kideak zenbakiak onartuko zain…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Horma-irudia:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Nor batu daiteke talde honetara", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Idatzi mezua…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Bai", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Zeu", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Ez duzu txat honetan parte hartzen honezkero", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Txat honetan debekua ezarri dizute", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Editatu gelaren aliasak", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "chats": "Txatak", + "@chats": { + "type": "String", + "placeholders": {} + }, + "emojis": "Emojiak", + "placeCall": "Egin deia", + "voiceCall": "Ahozko deia", + "unsupportedAndroidVersion": "Android bertsioa ez da bateragarria", + "unsupportedAndroidVersionLong": "Funtzio honek Android bertsio berriago bat behar du. Egiaztatu eguneraketak ote dauden edo begiratu Lineage OS-ek zure gailuarentzat aukerarik eskaintzen duen.", + "commandHint_ban": "Debekatu erabiltzailea gela honetan", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Ezabatu katxea", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Sortu taldeko-txat huts bat\nErabili --no-encyption zifratzea desgaitzeko", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_op": "Zehaztu erabiltzaile honen botere-maila (defektuz: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Bidali formaturik gabeko testua", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Bidali erantzuna erreakzio gisa", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Bidali testua", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "createNewSpace": "Gune berria", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Editatu blokeatutako zerbitzariak", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Gelaren abatarra editatu", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Zifratuta", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "enterAnEmailAddress": "Sartu helbide elektroniko bat", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Zerbitzaria", + "errorObtainingLocation": "Errorea kokapena lortzerakoan: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Dena prest!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Izugarri iraingarria", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Joan gela berrira", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "groups": "Taldeak", + "@groups": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Ezkutatu atzera botatako gertaerak", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Ezkutatu gertaera ezezagunak", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Niretzako gonbidapenak", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Gaitu kontu honentzako jakinarazpenak", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} erabiltzaile idazten ari dira…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "notifications": "Jakinarazpenak", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "Zure gailuetako batek saioa amaitu du", + "addAccount": "Gehitu kontua", + "editBundlesForAccount": "Editatu kontu honetarako sortak", + "oopsPushError": "Hara! Zoritxarrez, errore bat gertatu da push jakinarazpenak ezartzerakoan.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Aukeratu", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Gorde fitxategia", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Single Sign on", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{irakurri gabeko txat 1} other {irakurri gabeko {unreadCount} txat}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "videoCallsBetaWarning": "Kontuan izan bideo-deiak beta fasean daudela. Litekeena da behar bezala erabili ezin izatea —erabili ahal badira—.", + "toggleMuted": "Ikusi / Ezkutatu mutututakoak", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "all": "Guztia", + "@all": { + "type": "String", + "placeholders": {} + }, + "next": "Hurrengoa", + "@next": { + "type": "String", + "placeholders": {} + }, + "experimentalVideoCalls": "Bideo-dei esperimentalak", + "emailOrUsername": "ePosta edo erabiltzaile-izena", + "enableMultiAccounts": "(BETA) Gaitu kontu bat baino gehiago gailu honetan", + "openVideoCamera": "Ireki kamera bideorako", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "removeFromBundle": "Kendu sorta honetatik", + "serverRequiresEmail": "Zerbitzari honek zure posta elektronikoa egiaztatu behar du izena eman dezazun.", + "or": "Edo", + "@or": { + "type": "String", + "placeholders": {} + }, + "link": "Esteka", + "privacy": "Pribatutasuna", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "Bota mezua atzera", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Eman izena", + "@register": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Jarraitu webguneko argibideak eta sakatu 'Hurrengoa'.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "reason": "Arrazoia", + "@reason": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Salatu mezua", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "status": "Egoera", + "@status": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Zure gako publikoa", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "messageType": "Mezu mota", + "time": "Ordua", + "dismiss": "Baztertu", + "switchToAccount": "Aldatu {number} kontura", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "previousAccount": "Aurreko kontua", + "edit": "Editatu", + "@edit": { + "type": "String", + "placeholders": {} + }, + "mention": "Aipatu", + "@mention": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Idatzi berriro pasahitza", + "addEmail": "Gehitu ePosta", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Ziur zaude saioa amaitu nahi duzula?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopiatu arbelera", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Ez ikusia egindako erabiltzaileak", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "security": "Segurtasuna", + "@security": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "Automatikoki abiarazi pegatina eta emote animatuak", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendOnEnter": "Bidali enter sakatuz", + "badServerVersionsException": "Zerbitzariak ondorengo ezaugarriak onartzen ditu:\n{serverVersions}\nBaina aplikazioak hauek onartzen ditu bakarrik: {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "botMessages": "Boten mezuak", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Ezin da {uri} URIa ireki", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Aldatu gailuaren izena", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changePassword": "Aldatu pasahitza", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Aldatu abatarra", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Txataren babeskopia", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Txat zaharrak berreskuratze-gako batekin daude babestuta. Ez galdu gako hori.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Txata gune honetara gehitu da", + "configureChat": "Txata konfiguratu", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Edukia zerbitzariko administratzaileei jakinarazi zaie", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Kideen aldaketak", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Ezarri alias nagusi bezala", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Ezarri zure emoteak", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "appLock": "Aplikazioa blokeatzea", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Gehitu gunera", + "allChats": "Txat guztiak", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "Zerbitzariak ondorengo aukerak onartzen ditu saioa hasteko:\n{serverVersions}\nBaina aplikazioak hauek onartzen ditu bakarrik:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "commandHint_dm": "Hasi banakako txat bat\nErabili --no-encyption zifratzea desgaitzeko", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_leave": "Utzi gela hau", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "blocked": "Blokeatuta", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "commandInvalid": "Komandoa ez da baliozkoa", + "@commandInvalid": { + "type": "String" + }, + "commandHint_myroomnick": "Ezarri zure ezizena gela honetarako", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "ignore": "Ezikusi", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Erabiltzaile-izena dauka", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Ezizena dauka", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Kokapen zerbitzuak ezgaituta daude. Gaitu zure kokapena partekatu ahal izateko.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "directChats": "Banakako txatak", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Gaitu zifratzea", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Estekan sakatu dut", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Oraindik ez duzu pasahitza berreskuratzeko modurik gehitu.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "online": "Linean", + "@online": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Push arauak", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Sartu lau zenbaki edo utzi hutsik aplikazioa babestu nahi ez baduzu.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Ordezkatu gela bertsio berriago batekin", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "search": "Bilatu", + "@search": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Helbide hauekin pasahitza berreskuratu dezakezu.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Zergatik salatu nahi duzu?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Bideoa ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "openGallery": "Ireki bilduma", + "pinMessage": "Finkatu gelan", + "reactedWith": "{sender}(e)k {reaction}(r)ekin erreakzionatu du", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "confirmEventUnpin": "Ziur zaude gertaera finaktzeari utzi nahi diozula?", + "nextAccount": "Hurrengo kontua", + "markAsRead": "Markatu irakurritzat", + "yourChatBackupHasBeenSetUp": "Txaten babeskopiak ezarri dira.", + "clearArchive": "Ezabatu artxiboa", + "commandHint_html": "Bidali testua HTML formatuan", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Gonbidatu erabiltzailea gela honetara", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Batu adierazitako gelara", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Kendu erabiltzaile hori gela honetatik", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_me": "Deskribatu zure burua", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Ezarri zure irudia gela honetarako (mxc-uri bidez)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_unban": "Kendu erabiltzaileak gela honetan duen debekua", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandMissing": "{command} ez da komandoa.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "commandHint_discardsession": "Baztertu saioa", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "deactivateAccountWarning": "Honek zure kontua desaktibatuko du. Ezin da desegin! Ziur zaude?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Erabiltzaile berrien defektuzko botere-maila", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Ezabatu kontua", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Gailuaren IDa", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Gelarako emote-sortak", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Gaitu emote-sorta txat guztietarako", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Letraren tamaina", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Zenbaterainoko iraingarria da eduki hau?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Ez da iraingarria", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Kokapen baimena ukatu da. Eman zure kokapena partekatzeko baimena.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "messages": "Mezuak", + "@messages": { + "type": "String", + "placeholders": {} + }, + "newChat": "Txat berria", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Ez dago konexiorik zerbitzariarekin", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Zifratzea aktiba dezakezu soilik gelak publikoa izateari utzi badio.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} ez da matrix zerbitzari bat, {server2} erabili nahi duzu haren ordez?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "scanQrCode": "Eskaneatu QR kodea", + "obtainingLocation": "Kokapena atzitzen…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Iraingarria", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Lineaz kanpo", + "@offline": { + "type": "String", + "placeholders": {} + }, + "addToBundle": "Gehitu sortara", + "bundleName": "Sortaren izena", + "openInMaps": "Ireki mapen aplikazioan", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "participant": "Partaide", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Pasahitza ahaztu dut", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Pasahitza aldatu da", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Pasahitzaren berreskurapena", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Jendea", + "@people": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Aukeratu sartzeko kode bat", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Sakatu ePostako estekan eta ondoren jarraitu.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Sartu zure PINa", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Kendu zure abatarra", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Gelaren bertsioa", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Bidali testu bezala", + "@sendAsText": { + "type": "String" + }, + "sendMessages": "Mezuak bidali", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Bidali pegatina", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Ezarri baimen-maila", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Partekatu kokapena", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Erakutsi pasahitza", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Gunea publikoa da", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Gunearen izena", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sinkronizatzen… itxaron.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Ikusi / Ezkutatu gogokoak", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Markatu irakurrita / irakurri gabe", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Eskaera gehiegi. Saiatu berriro geroago!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Beste gailu batetik transferitu", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Ez dago eskuragai", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unverified": "Egiaztatu gabe(a)", + "verified": "Egiaztatuta", + "@verified": { + "type": "String", + "placeholders": {} + }, + "warning": "Kontuz!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "ePosta bat bidali dizugu", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Nork zer egin dezakeen", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Ezabatu txataren babeskopia berreskuratze-gako berria sortzeko?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Mezuaren xehetasunak", + "sender": "Igorlea", + "removeFromSpace": "Kendu gunetik", + "addToSpaceDescription": "Hautatu gune bat txat hau bertara gehitzeko.", + "start": "Hasi", + "publish": "Argitaratu", + "reportUser": "Salatu erabiltzailea", + "openChat": "Ireki txata", + "addWidget": "Gehitu widgeta", + "widgetVideo": "Bideoa", + "widgetEtherpad": "Testu-oharra", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "Norberak ezarritakoa", + "widgetName": "Izena", + "youJoinedTheChat": "Txatera batu zara", + "youAcceptedTheInvitation": "👍 Gonbidapena onartu duzu", + "youBannedUser": "{user}(r)i debekua ezarri diozu", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "{user}(r)i luzatutako gonbidapena baliogabetu duzu", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 {user}(e)k gonbidatu zaitu", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 {user} gonbidatu duzu", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 {user} kanporatu duzu", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 {user} kanporatu eta debekua ezarri diozu", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "{user}(r)i debekua kendu diozu", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youRejectedTheInvitation": "Gonbidapena baztertu duzu", + "separateChatTypes": "Bereizi banakako mezuak eta taldeak", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "widgetUrlError": "Ez da baliozko URLa.", + "widgetNameError": "Zehaztu ezizen bat.", + "errorAddingWidget": "Errorea widgeta gehitzerakoan.", + "pleaseEnterRecoveryKey": "Sartu berreskuratze-gakoa:", + "recoveryKey": "Berreskuratze-gakoa", + "recoveryKeyLost": "Berreskuratze-gakoa galdu duzu?", + "users": "Erabiltzaileak", + "storeInAndroidKeystore": "Gorde Android KeyStore-n", + "dehydrate": "Esportatu saioa eta ezabatu gailua", + "dehydrateWarning": "Ekintza hau ezin da desegin. Egiaztatu babeskopia toki seguruan gorde duzula.", + "hydrate": "Lehengoratu babeskopia bat erabiliz", + "pleaseEnterRecoveryKeyDescription": "Mezu zaharrak ikusi ahal izateko, sartu aurreko saioan sortu zen berreskuratze-gakoa. Berreskuratze-gakoa EZ da zure pasahitza.", + "indexedDbErrorLong": "Mezuen artxibatzea ez dago defektuz gaituta modu pribatua erabiltzean.\nGaitzeko:\n - about:config\n - dom.indexedDB.privateBrowsing.enabled aukerak true erakutsi dezala\nBestela ezin da FluffyChat erabili.", + "storeSecurlyOnThisDevice": "Gorde gailu honetan modu seguruan", + "countFiles": "{count} fitxategi", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "user": "Erabiltzailea", + "custom": "Neurrira egindakoa", + "storeInSecureStorageDescription": "Gorde berreskuratze-gakoa gailu honetako biltegiratze seguruan.", + "storeInAppleKeyChain": "Gorde Apple KeyChain-en", + "unlockOldMessages": "Desblokeatu mezu zaharrak", + "dehydrateTorLong": "TOR erabiltzaileentzat gomendioa leihoa itxi baino lehen saioa esportatzea da.", + "hydrateTorLong": "Esportatu al zenuen zure saioa TOR erabili zenuen azken aldian? Inportatu segidan eta jarraitu txateatzen.", + "dehydrateTor": "TOR Erabiltzaileak: Esportatu saioa", + "hydrateTor": "TOR Erabiltzaileak: Inportatu esportatutako saioa", + "saveKeyManuallyDescription": "Gorde eskuz gako hau gailuko partekatze-menua edo arbela erabiliz.", + "indexedDbErrorTitle": "Arazoak modu pribatuarekin", + "confirmMatrixId": "Baieztatu zure Matrix IDa kontua ezabatu ahal izateko.", + "newSpace": "Gune berria", + "enterRoom": "Sartu gelara", + "whyIsThisMessageEncrypted": "Zergatik ezin da mezu hau irakurri?", + "allSpaces": "Gune guztiak", + "newGroup": "Talde berria", + "enterSpace": "Sartu gunera", + "appearOnTopDetails": "Aplikazioa goikaldean agertzea baimentzen du (ez da beharrezkoa FluffyChat deitzeko kontutzat ezarri baduzu)", + "screenSharingTitle": "pantaila-partekatzea", + "screenSharingDetail": "Pantaila FluffyChaten partekatzen ari zara", + "callingPermissions": "Deitzeko baimenak", + "callingAccount": "Deitzen ari den kontua", + "callingAccountDetails": "Baimendu FluffyChat Android gailuko telefono-markagailua erabiltzea.", + "appearOnTop": "Gainean erakutsi", + "otherCallingPermissions": "Mikrofono, kamera eta FluffyChaten beste baimen batzuk", + "numChats": "{number} txat", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Ezkutatu garrantzirik gabeko gertaerak", + "noKeyForThisMessage": "Mezua gailu honetan saioa hasi baino lehen bidali bazen gertatu daiteke.\n\nBeste aukera bat igorleak zure gailua blokeatu izana da, edo zerbaitek huts egin izana interneteko konexioan.\n\nMezua beste saio batean irakur dezakezu? Hala bada, mezua transferitu dezakezu! Zoaz Ezrpenetara > Gailuak eta baieztatu zure gailuek bata bestea egiaztatu dutela. Gela irekiko duzun hurrengo aldian eta bi saioak aurreko planoan irekita daudenean, gakoak automatikoki partekatuko dira.\n\nEz duzu gakorik galdu nahi saioa amaitu edo gailuak aldatzen dituzunean? Baieztatu ezarpenetan txaten babeskopiak gaituta dituzula.", + "supposedMxid": "Hau {mxid} izan behar da", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "Markatu talde bezala", + "foregroundServiceRunning": "Jakinarazpen hau zerbitzua martxan dagoenean agertzen da.", + "commandHint_markasdm": "Markatu mezu-zuzen gela bezala Matrix ID jakin honentzat", + "wasDirectChatDisplayName": "Txata hutsik dago ({oldDisplayName} zen lehen)", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "deviceKeys": "Gailuaren gakoak:", + "noBackupWarning": "Adi! Txataren babeskopia gaitzen ez baduzu, ezingo dituzu zifratutako txatak atzitu. Oso gomendagarria da txaten babeskopia gaitzea saioa amaitu baino lehen.", + "doNotShowAgain": "Ez erakutsi berriro", + "fileIsTooBigForServer": "Ezin da bidali! Zerbitzariak gehienez {max}-ko eranskinak onartzen ditu.", + "noOtherDevicesFound": "Ez da beste gailurik aurkitu", + "startFirstChat": "Hasi zure lehen txata", + "newSpaceDescription": "Guneek txatak taldekatzea ahalbidetzen dute eta komunitate pribatu edo publikoak osatzea.", + "disableEncryptionWarning": "Segurtasun arrazoiak direla-eta, ezin duzu lehendik zifratuta zegoen txat bateko zifratzea ezgaitu.", + "encryptThisChat": "Zifratu txata", + "commandHint_hug": "Bidali besarkada", + "hugContent": "{senderName}(e)k besarkatu zaitu", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "sorryThatsNotPossible": "Barka… hori ez da posible", + "reopenChat": "Ireki txata berriro", + "commandHint_googly": "Bidali begi dibertigarri batzuk", + "commandHint_cuddle": "Bidali besarkada samurra", + "googlyEyesContent": "{senderName}(e)k begi dibertigarri batzuk bidali dizkizu", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "allRooms": "Talde-txat guztiak", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "jumpToLastReadMessage": "Joan irakurritako azken mezura", + "reportErrorDescription": "😭 O ez! Zerbaitek huts egin du. Nahi izanez gero, eman garatzaileei errorearen berri.", + "cuddleContent": "{senderName}(e)k samurki besarkatu zaitu", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "readUpToHere": "Honaino irakurrita", + "fileHasBeenSavedAt": "Fitxategia {path}(e)n gorde da", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jump": "Joan", + "openLinkInBrowser": "Ireki esteka nabigatzailean", + "report": "salatu", + "signInWithPassword": "Hasi saioa pasahitzarekin", + "pleaseTryAgainLaterOrChooseDifferentServer": "Saiatu geroago edo aukeratu beste zerbitzari bat.", + "signInWith": "Hasi saioa {provider}(r)ekin", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Ez da irudi-fitxategia.", + "importNow": "Inportatu orain", + "importEmojis": "Inportatu emojiak", + "importFromZipFile": "Inportatu .zip fitxategi batetik", + "exportEmotePack": "Esportatu emote-sorta .zip gisa", + "replace": "Ordezkatu", + "sendTypingNotifications": "Jakinarazi idazten nagoela", + "setColorTheme": "Ezarri kolore-gaia:", + "tryAgain": "Saiatu berriro", + "messagesStyle": "Mezuak:", + "chatDescription": "Txataren deskribapena", + "invalidServerName": "Zerbitzari-izenak ez du balio", + "chatPermissions": "Txataren baimenak", + "setChatDescription": "Ezarri txataren deskribapena", + "redactedBy": "{username}(e)k atzera bota du", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Aukerakoa) Mezua atzera botatzearen arrazoia…", + "inviteContactToGroupQuestion": "{contact} \"{groupName}\" txatera gonbidatu nahi duzu?", + "redactedByBecause": "{username}(e)k atzera bota du \"{reason}\" dela-eta", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactMessageDescription": "Mezua elkarrizketa honetako partaide guztientzat botako da atzera. Ezin da desegin.", + "addChatDescription": "Gehitu txataren deskribapena…", + "directChat": "Banakako txata", + "wrongPinEntered": "PIN okerra! Saiatu berriro {seconds} segundu barru…", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "noChatDescriptionYet": "Ez da txaterako deskribapenik sortu oraindik.", + "chatDescriptionHasBeenChanged": "Txataren deskribapena aldatu da", + "profileNotFound": "Ezin izan da erabiltzailea zerbitzarian aurkitu. Agian arazo bat dago konexioarekin edo erabiltzailea ez da existitzen.", + "shareInviteLink": "Partekatu gonbidapen-esteka", + "emoteKeyboardNoRecents": "Oraintsu erabilitako emoteak hemen ageriko dira…", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Ezarri gaia:", + "createGroup": "Sortu taldea", + "invite": "Gonbidatu", + "invalidInput": "Sartu duzunak ez du balio!", + "inviteGroupChat": "📨 Taldeko txatera gonbidapena", + "invitePrivateChat": "📨 Txat pribatura gonbidapena", + "banUserDescription": "Erabiltzailea txatetik kanporatu eta berriro sartzeko debekua ezarriko zaio; ezingo da berriro sartu debekua kendu arte.", + "removeDevicesDescription": "Gailu honetako saioa amaituko da eta ezingo duzu mezurik jaso aurrerantzean.", + "unbanUserDescription": "Erabiltzailea txatera berriro sartu ahal izango da berak nahi izanez gero.", + "pushNotificationsNotAvailable": "Push jakinarazpenak ez daude erabilgarri", + "makeAdminDescription": "Behin erabiltzaile hau administratzaile eginda, litekeena da desegin ezin izatea zuk dituzun baimenak izango dituelako.", + "archiveRoomDescription": "Txata artxibategira mugituko da. Beste erabiltzaileek txatetik alde egin duzula ikusi ahal izango dute.", + "hasKnocked": "🚪 {user}(e)k baimena eskatu du", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "learnMore": "Gehiago irakurri", + "roomUpgradeDescription": "Gela bertsio berri gisa birsortuko da txata. Partaide guztiei jakinaraziko zaie txat berrira aldatu behar direla. Gehiago irakur dezakezu gela bertsioei buruz ondorengo estekan: https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Sartu 0 baino zenbaki handiago bat", + "kickUserDescription": "Erabiltzailea txatetik kanporatu da baina ez zaio debekua ezarri. Txat publikoen kasuan, edozein momentutan batu daiteke berriro.", + "createGroupAndInviteUsers": "Sortu talde bat eta gonbidatu partaideak", + "startConversation": "Hasi elkarrizketa", + "groupCanBeFoundViaSearch": "Bilaketa erabiliz aurkitu daiteke taldea", + "noUsersFoundWithQuery": "Zoritxarrez ez da \"{query}\" duen erabiltzailerik aurkitu. Egiaztatu zuzen idatzi duzula.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "yourGlobalUserIdIs": "Zure erabiltzaile-ID orokorra: ", + "commandHint_sendraw": "Bidali json gordina", + "wrongRecoveryKey": "Barka baina ez dirudi berreskuratze-gako zuzena denik.", + "groupName": "Taldearen izena", + "searchChatsRooms": "Bilatu #txatak, @erabiltzaileak…", + "blockListDescription": "Gogaitzen zaituzten erabiltzaileak blokeatu ditzakezu. Ez duzu blokeatutakoen zerrendan dituzun erabiltzaileen mezurik edo gelara batzeko gonbidapenik jasoko.", + "blockedUsers": "Blokeatutako erabiltzaileak", + "block": "Blokeatu", + "blockUsername": "Ezikusi erabiltzaile-izena", + "databaseMigrationTitle": "Datu-basea optimizatu da", + "databaseMigrationBody": "Itxaron, litekeena da tarte bat behar izatea.", + "publicSpaces": "Gune publikoak", + "passwordIsWrong": "Sartu duzun pasahitza okerra da", + "pleaseEnterYourCurrentPassword": "Sartu oraingo pasahitza", + "publicLink": "Esteka publikoa", + "nothingFound": "Ez da ezer aurkitu…", + "newPassword": "Pasahitz berria", + "passwordsDoNotMatch": "Pasahitzak ez datoz bat", + "subspace": "Azpi-gunea", + "select": "Hautatu", + "pleaseChooseAStrongPassword": "Aukeratu pasahitz sendo bat", + "addChatOrSubSpace": "Gehitu txata edo azpi-gunea", + "leaveEmptyToClearStatus": "Utzi hutsik zure egoera garbitzeko.", + "joinSpace": "Batu gunera", + "searchForUsers": "Bilatu @erabiltzaileak…", + "thisDevice": "Gailu hau:", + "decline": "Baztertu", + "databaseBuildErrorBody": "Ezin da SQlite datu-basea eraiki. Aplikazioa aurreko datu-basea erabiltzen saiatuko da oraingoz. Jakinarazi errorea garatzaileei {url} helbidean. Errorearen mezua ondorengoa da: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "Errorea aplikazioa abiaraztean", + "sessionLostBody": "Zure saioa galdu da. Jakinarazi errorea garatzaileei {url} helbidean. Errorearen mezua ondorengoa da: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Aplikazioa babeskopia erabiliz saioa leheneratzen saiatuko da. Jakinarazi errorea garatzaileei {url} helbidean. Errorearen mezua ondorengoa da: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Esteka baten bidez gonbidatu zaituzte:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "transparent": "Gardena", + "sendReadReceipts": "Bidali irakurri izanaren agiria", + "formattedMessages": "Formatua duten mezuak", + "verifyOtherDevice": "🔐 Egiaztatu beste gailu bat", + "acceptedKeyVerification": "{sender}(e)k gakoaren egiaztapena onartu du", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender}(e)k gakoen egiaztapena ezeztatu du", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender}(e)k gakoen egiaztapena galdegin du", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "Txateko beste partaideek mezu bat irakurri duzula ikus dezakete.", + "forwardMessageTo": "Birbidali mezua {roomName}(e)ra?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender}(e)k gakoen egiaztapena osatu du", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} gakoak egiaztatzeko prest dago", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "verifyOtherDeviceDescription": "Beste gailu bat egiaztatzean, gailu horiek gakoak truka ditzakete, eta segurtasun orokorra handitu. 💪 Egiaztapena hasten duzunean, laster-leiho bat agertuko da bi gailuetan. Bertan, elkarrekin alderatu behar diren emoji edo zenbaki batzuk ikusiko dituzu. Hobe da bi gailuak eskura izatea egiaztapena hasi aurretik. 🤳", + "verifyOtherUserDescription": "Beste erabiltzaile bat egiaztatzen baduzu, ziur egon zaitezke nori idazten ari zaren. 💪\n\nEgiaztapena hasten duzunean, zuk eta beste erabiltzaileak laster-leiho bat ikusiko duzue aplikazioan. Bertan, elkarrekin alderatu behar diren emoji edo zenbaki batzuk erakutsiko dira.\n\nBideo-dei bat hastea edo aurrez-aurre batzea da horretarako modurik onena. 👭", + "formattedMessagesDescription": "Erakutsi mezu aberatsen edukia markdown erabiliz, testu lodia esaterako.", + "sendTypingNotificationsDescription": "Txateko beste partaideek mezu berri bat idazten ari zarela ikus dezakete.", + "verifyOtherUser": "🔐 Egiaztatu beste erabiltzaile bat", + "startedKeyVerification": "{sender}(e)k gakoen egiaztapena hasi du", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "presencesToggle": "Erakutsi beste erabiltzaileen egoera-mezuak", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "Presentzia:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "incomingMessages": "Jasotako mezuak", + "hidePresences": "Ezkutatu Egoeren Zerrenda?", + "discover": "Arakatu", + "stickers": "Pegatinak", + "commandHint_unignore": "Utzi Matrix ID honi muzin egiteari", + "commandHint_ignore": "Muzin egin Matrix ID honi", + "unreadChatsInApp": "{appname}: {unread} mezu irakurri gabe", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Plataforma honetan ezin da datu-basea zifratu", + "usersMustKnock": "Erabiltzaileek baimena eskatu behar dute", + "userWouldLikeToChangeTheChat": "{user}(e)k txatera batu nahiko luke.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "knock": "Eskatu baimena", + "knocking": "Baimena eskatzen", + "chatCanBeDiscoveredViaSearchOnServer": "Txata {server}(e)n bilaketa eginez aurkitu daiteke", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "Une honetan {count} erabiltzaile daude blokeatuta.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "appLockDescription": "Blokeatu aplikazioa pin kode batekin erabiltzen ari ez zarenean", + "accessAndVisibility": "Sarbidea eta ikusgaitasuna", + "accessAndVisibilityDescription": "Nork du txat honetara batzeko baimena eta nola aurkitu daiteke txata.", + "customEmojisAndStickers": "Emoji eta pegatina propioak", + "customEmojisAndStickersBody": "Gehitu edo partekatu edozein txatetan erabil daitezkeen emoji edo pegatina propioak.", + "hideRedactedMessages": "Ezkutatu atzera botatako mezuak", + "hideRedactedMessagesBody": "Norbaitek mezuren bat atzera botaz gero, mezua txatetik kenduko da, abisurik gabe.", + "hideInvalidOrUnknownMessageFormats": "Ezkutatu mezuen formatu ezezagun edo baliogabea", + "overview": "Ikuspegi orokorra", + "notifyMeFor": "Jakinarazi…", + "passwordRecoverySettings": "Pasahitza berreskuratzeko ezarpenak", + "hideMemberChangesInPublicChats": "Ezkutatu kideen egoera aldaketak txat publikoetan", + "globalChatId": "Txat ID orokorra", + "calls": "Deiak", + "hideMemberChangesInPublicChatsBody": "Ez erakutsi txataren denbora-lerroan norbait txat publikora batu edo txatetik irteten dela, irakurgaitasuna hobetzeko.", + "noOneCanJoin": "Ezin da inor batu", + "noPublicLinkHasBeenCreatedYet": "Oraindik ez da esteka publikorik sortu", + "userRole": "Erabiltzailearen rola", + "minimumPowerLevel": "{level} da gutxieneko botere-maila.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "publicChatAddresses": "Txataren helbide publikoak", + "createNewAddress": "Sortu helbide berria", + "files": "Fitxategiak", + "gallery": "Galeria", + "searchIn": "Bilatu {chat} txatean...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Bilatu gehiago...", + "restricted": "Mugatuta", + "knockRestricted": "Eskatu baimena sarrera mugatua duen txatean", + "swipeRightToLeftToReply": "Herrestatu eskuin-ezker erantzuteko", + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "noMoreChatsFound": "Ez da beste txatik aurkitu...", + "unread": "Irakurtzeke", + "space": "Gunea", + "joinedChats": "Batu zaren txatak", + "goToSpace": "Joan {space} gunera", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Markatu irakurri gabetzat", + "countChatsAndCountParticipants": "{chats} txat eta {participants} partaide", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "spaces": "Guneak", + "adminLevel": "{level} - Administratzailea", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheChatPermissions": "Aldatu txataren baimenak", + "inviteOtherUsers": "Gonbidatu beste erabiltzaileak txat honetara", + "userLevel": "{level} - Erabiltzailea", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderatzailea", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "sendRoomNotifications": "Bidali @gela jakinarazpena", + "changeTheDescriptionOfTheGroup": "Aldatu txataren deskribapena", + "changeGeneralChatSettings": "Aldatu txataren ezarpen orokorrak", + "changeTheVisibilityOfChatHistory": "Aldatu txataren historiaren ikusgaitasuna", + "changeTheCanonicalRoomAlias": "Aldatu txataren helbide publiko nagusia", + "invitedBy": "📩 {user}(e)k gonbidatua", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "updateInstalled": "🎉 {version} bertsioa instalatu da!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Aldaketak", + "chatPermissionsDescription": "Definitu zer botere-maila behar den txat honetako ekintza jakinetarako. 0, 50 eta 100 botere-mailek erabiltzaileak, moderatzaileak eta administratzaileak ordezkatzen dituzte, baina edozein graduazio posible da.", + "sendCanceled": "Bidalketa bertan behera utzi da", + "noChatsFoundHere": "Ez da txatik aurkitu. Hasi norbaitekin txateatzen beheko botoia erabiliz. ⤵️", + "homeserverDescription": "Zerbitzariak datuak gordetzen ditu, ePosta hornitzaileek mezuak gordetzen dituzten bezala. Nahi duzun zerbitzaria aukeratu dezakezu eta, hala ere, besteetako edonorekin hitz egin. Ikasi gehiago https://matrix.org webgunean.", + "loginWithMatrixId": "Hasi saioa Matrix IDarekin", + "discoverHomeservers": "Arakatu zerbitzariak", + "whatIsAHomeserver": "Zer da zerbitzari bat?", + "doesNotSeemToBeAValidHomeserver": "Ez dirudi zerbitzaria bateragarria denik. Zuzena da URLa?", + "calculatingFileSize": "Fitxategiaren tamaina kalkulatzen…", + "prepareSendingAttachment": "Eranskinaren bidalketa prestatzen…", + "sendingAttachment": "Eranskina bidaltzen…", + "compressVideo": "Bideoa konprimatzen…", + "generatingVideoThumbnail": "Bideoaren iruditxoa sortzen…", + "serverLimitReached": "Zerbitzariaren muga gainditu da! Itxaron {seconds} segundo…", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendingAttachmentCountOfCount": "{index}. eranskina bidaltzen ({length} guztira)…", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Zure gailuetako bat ez dago egiaztatuta", + "noticeChatBackupDeviceVerification": "Oharra: gailu guztiak txat-babeskopiarekin konektatzen dituzunean, automatikoki egiaztatzen dira.", + "opacity": "Opakutasuna:", + "manageAccount": "Kudeatu kontua", + "setWallpaper": "Ezarri horma-irudia", + "blur": "Lausotu:", + "continueText": "Jarraitu", + "welcomeText": "Ieup 👋 Ongi etorri FluffyChat-era. https://matrix.org-rekin bateragarria den edozein zerbitzaritan hasi dezakezu saioa eta edonorekin txateatu. Mezularitza-sare deszentralizatu eraraldoia da!", + "contactServerAdmin": "Jarri harremanetan zerbitzariaren administratzailearekin", + "aboutHomeserver": "{homeserver}(e)ri buruz", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "supportPage": "Laguntza orria", + "serverInformation": "Zerbitzariaren informazioa:", + "name": "Izena", + "version": "Bertsioa", + "website": "Webgunea", + "contactServerSecurity": "Jakinarazi segurtasun arazo bat", + "noContactInformationProvided": "Zerbitzariak ez du harremanetarako informaziorik zehaztu", + "boldText": "Testu lodia", + "italicText": "Testu etzana", + "invalidUrl": "URL baliogabea", + "addLink": "Gehitu esteka", + "strikeThrough": "Zirrimarra", + "pleaseFillOut": "Bete ezazu", + "unableToJoinChat": "Ezin da txatera batu. Agian besteak elkarrizketa itxiko zuen honezkero.", + "sendImages": "Bidali {count} irudi", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Konprimatu", + "previous": "Aurrekoa", + "otherPartyNotLoggedIn": "Besteak ez du saiorik hasita eta, beraz, ezin du mezurik jaso!", + "appWantsToUseForLogin": "Erabili '{server}' saioa hasteko", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Honenbestez, aplikazioak eta webguneak zuri buruzko informazioa partekatzea baimentzen duzu.", + "open": "Ireki", + "generalNotificationSettings": "Jakinarazpen orokorren ezarpenak", + "notificationRuleContainsUserName": "Erabiltzaile-izena dauka", + "notificationRuleMaster": "Isilarazi jakinarazpen guztiak", + "userSpecificNotificationSettings": "Erabiltzaile zehatzen jakinarazpenen ezarpenak", + "more": "Gehiago", + "newChatRequest": "📩 Txat-eskaera berria", + "contentNotificationSettings": "Edukiaren jakinarazpenen ezarpenak", + "notificationRuleContainsUserNameDescription": "Mezuan erabiltzaile-izena aipatzen denean jakinarazten du.", + "notificationRuleMasterDescription": "Gainerako arauak gainidatzi eta jakinarazpenak ezgaitzen ditu.", + "roomNotificationSettings": "Gelen jakinarazpenen ezarpenak", + "otherNotificationSettings": "Beste jakinarazpenen ezarpenak", + "waitingForServer": "Zerbitzariaren zain…", + "appIntroduction": "FluffyChatek mezularitza-programa desberdinak erabiltzen dituzten lagunekin txateatzea ahalbidetzen dizu. Ikasi gehiago https://matrix.org estekan edo sakatu *Jarraitu*.", + "synchronizingPleaseWaitCounter": " Sinkronizatzen… (%{percentage})", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "notificationRuleInviteForMe": "Gonbidapena niretzat", + "notificationRuleInviteForMeDescription": "Erabiltzailea gela batera gonbidatzen dutenean jakinarazten du.", + "notificationRuleSuppressNotices": "Ezkutatu mezu automatikoak", + "notificationRuleSuppressNoticesDescription": "BOTen eta bestelako bezero automatikoen jakinarazpenak ezkutatzen ditu.", + "notificationRuleMemberEvent": "Kideen gertaera", + "notificationRuleMemberEventDescription": "Kideen gertaeren jakinarazpenak ezkutatzen ditu.", + "notificationRuleIsUserMention": "Erabiltzailea aipatzea", + "notificationRuleContainsDisplayName": "Pantaila-izena dauka", + "notificationRuleIsUserMentionDescription": "Erabiltzailea mezu zuzen batean aipatzen dutenean jakinarazten du.", + "notificationRuleContainsDisplayNameDescription": "Mezu batek erabiltzailearen pantaila-izena duenean jakinarazten du.", + "notificationRuleIsRoomMention": "Gelaren aipamena", + "notificationRuleIsRoomMentionDescription": "Gela aipatzen denean erabiltzailea jakinarazten du.", + "notificationRuleRoomnotif": "Gelaren jakinarazpena", + "notificationRuleRoomnotifDescription": "Mezu batek '@room' duenean erabiltzaileari jakinarazten dio.", + "notificationRuleTombstone": "Hilarria", + "notificationRuleReaction": "Erreakzioa", + "notificationRuleReactionDescription": "Erreakzioen jakinarazpenak ezkutatzen ditu.", + "notificationRuleTombstoneDescription": "Gela desaktibatzeko mezuei buruz jakinarazten dio erabiltzaileari.", + "notificationRuleRoomServerAcl": "Gelaren zerbitzariaren ACLa", + "notificationRuleSuppressEdits": "Ezkutatu edizioak", + "notificationRuleCall": "Deia", + "notificationRuleEncryptedRoomOneToOne": "Zifratutako bien arteko gela", + "notificationRuleSuppressEditsDescription": "Editatutako mezuen jakinarazpenak ezkutatzen ditu.", + "notificationRuleCallDescription": "Erabiltzaileari deiei buruz jakinarazten dio.", + "notificationRuleEncryptedRoomOneToOneDescription": "Erabiltzailea jakinarazten du zifratutako bien arteko geletako mezuei buruz.", + "notificationRuleRoomOneToOne": "Bien arteko gela", + "notificationRuleRoomOneToOneDescription": "Erabiltzailea jakinarazten du bien arteko geletako mezuei buruz.", + "notificationRuleMessage": "Mezua", + "notificationRuleMessageDescription": "Erabiltzailea jakinarazten du mezu orokorrei buruz.", + "notificationRuleEncrypted": "Zifratuak", + "notificationRuleEncryptedDescription": "Erabiltzailea jakinarazten du zifratutako geletako mezuei buruz.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Erabiltzailea jakinarazten du Jitsi widgetaren gertaerei buruz.", + "notificationRuleServerAcl": "Ezkutatu zerbitzariaren ACL gertaerak", + "notificationRuleServerAclDescription": "Zerbitzariaren ACL gertaerak ezkutatzen ditu.", + "unknownPushRule": "Push arau ezezaguna '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Jakinarazpen ezarpen hau ezabatzen baduzu, ezin da desegin.", + "shareKeysWith": "Partekatu gakoak…", + "allDevices": "Gailu guztiekin", + "shareKeysWithDescription": "Zein gailu hartu beharko litzateke fidagarritzat zifratutako txaten mezuak irakur ditzaten?", + "crossVerifiedDevicesIfEnabled": "Egiaztapen gurutzatuko gailuekin, gaituta badaude", + "verifiedDevicesOnly": "Egiaztatutako gailuekin soilik", + "crossVerifiedDevices": "Egiaztapen gurutzatuko gailuekin", + "takeAPhoto": "Egin argazkia", + "recordAVideo": "Grabatu bideoa", + "optionalMessage": "Mezua (aukerakoa)…", + "notSupportedOnThisDevice": "Ez da gailu honekin bateragarria", + "commandHint_roomupgrade": "Bertsio-berritu gela adierazitako gela-bertsiora", + "enterNewChat": "Sartu txat berrira", + "normalUser": "Erabiltzaile arrunta", + "notificationRuleRoomServerAclDescription": "Gela-zerbitzarirako sarbide-kontroleko zerrenden (ACL) jakinarazpenak ezkutatzen ditu.", + "ignoreUser": "Egin muzin erabiltzaileari", + "setCustomPermissionLevel": "Ezarri baimen-maila propioak", + "setPermissionsLevelDescription": "Aukeratu defektuzko rola edo sartu baimen-maila pertsonalizatu bat 0 eta 100 artean.", + "approve": "Onetsi", + "youHaveKnocked": "Sartzeko baimena eskatu duzu", + "pleaseWaitUntilInvited": "Orain itxaron gelako norbaitek gonbidatzen zaituen arte.", + "checkList": "Kontrol-zerrenda", + "countInvited": "{count} gonbidatu", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - {sender}(r)en ahots-mezua", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "commandHint_logout": "Amaitu saioa gailu honetan", + "commandHint_logoutall": "Amaitu saioa aktibo dauden gailu guztietan", + "moreEvents": "Gertaera gehiago", + "displayNavigationRail": "Erakutsi nabigazio-barra mugikorrean", + "customReaction": "Erreakzio pertsonalizatua", + "declineInvitation": "Uko egin gonbidapenari", + "noMessagesYet": "Mezurik ez oraingoz", + "longPressToRecordVoiceMessage": "Sakatuta mantendu ahots-mezua grabatzeko.", + "pause": "Gelditu", + "resume": "Jarraitu", + "moveToDifferentSpace": "Beste gune batera mugitu", + "moveUp": "Eraman gora", + "moveDown": "Eraman behera", + "removeFromSpaceDescription": "Txata gunetik kenduko da, baina txaten zerrendan mantenduko da.", + "countChats": "{chats} txat", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "donate": "Egin dohaintza", + "newSubSpace": "Azpi-gune berria", + "spaceMemberOf": "{spaces} guneko kidea", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "{spaces} guneko kideak sartzeko baimena eska dezake", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "startedAPoll": "{username}(e)k bozketa hasi du.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Bozketa", + "startPoll": "Hasi bozketa", + "endPoll": "Amaitu bozketa", + "answersVisible": "Erakutsi emaitzak", + "answersHidden": "Ezkutatu emaitzak", + "pollQuestion": "Bozketako galdera", + "answerOption": "Erantzun-aukera", + "addAnswerOption": "Gehitu erantzun-aukera", + "allowMultipleAnswers": "Baimendu erantzun bat baino gehiago", + "pollHasBeenEnded": "Bozketa amaitu da", + "countVotes": "{count, plural, =1{Bozka bat} other{{count} bozka}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Emaitzak bozketak amaitu duenean egongo dira ikusgai", + "replyInThread": "Erantzun harian", + "countReplies": "{count, plural, =1{Erantzun bat} other{{count} erantzun}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Haria", + "backToMainChat": "Joan txat nagusira", + "changedTheChatDescription": "{username}(e)k txataren deskribapena aldatu du", + "changedTheChatName": "{username}(e)k txataren izena aldatu du", + "saveChanges": "Gorde aldaketak", + "createSticker": "Sortu pegatina edo emojia", + "attribution": "Sortzailea", + "skipChatBackup": "Ez egin txataren babeskopia", + "skipChatBackupWarning": "Ziur? Txataren babeskopia gaitzen ez baduzu, gailuz aldatuz gero mezuen sarbidea gal zenezake.", + "loadingMessages": "Mezuak kargatzen", + "setupChatBackup": "Ezarri txataren babeskopia", + "useAsSticker": "Erabili pegatina gisa", + "stickerPackNameAlreadyExists": "Pegatina-sortaren izena badago lehendik ere", + "newStickerPack": "Pegatina-sorta berria", + "stickerPackName": "Pegatina-sortaren izena", + "useAsEmoji": "Erabili emoji gisa", + "noMoreResultsFound": "Ez da beste emaitzarik aurkitu", + "chatSearchedUntil": "Txatean bilatu da {time} arte", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "clientWellKnownInformation": "Bezeroaren Well-Known informazioa:", + "versionWithNumber": "Bertsioa: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Erregistroak", + "advancedConfigs": "Konfigurazio aurreratua", + "advancedConfigurations": "Konfigurazio aurreratua", + "signInWithLabel": "Hasi saioa honakoarekin:", + "federationBaseUrl": "Federatzeko URL oinarria", + "baseUrl": "URL oinarria", + "identityServer": "Identitate-zerbitzaria:", + "signIn": "Hasi saioa", + "createNewAccount": "Sortu kontu berria", + "signUpGreeting": "FluffyChat deszentralizatua da! Hautatu zure kontua zein zerbitzaritan sortu nahi duzun, eta hasi erabiltzen!", + "signInGreeting": "Baduzu dagoeneko Matrix kontu bat? Ongi etorri berriro ere! Hautatu zure zerbitzaria eta hasi saioa.", + "appIntro": "FluffyChat-i esker lagunekin txateatu dezakezu. [matrix]-erako mezularitza programa seguru eta deszentralizatua da! Nahi baduzu, irakurri gehiago https://matrix.org gunean, edo hasi saioa.", + "theProcessWasCanceled": "Eragiketa bertan behera utzi da.", + "join": "Batu", + "searchOrEnterHomeserverAddress": "Bilatu edo sartu zerbitzariaren helbidea", + "matrixId": "Matrix IDa" +} diff --git a/lib/l10n/intl_fa.arb b/lib/l10n/intl_fa.arb new file mode 100644 index 000000000..6c2937e0b --- /dev/null +++ b/lib/l10n/intl_fa.arb @@ -0,0 +1,3026 @@ +{ + "@@last_modified": "2021-08-14 12:41:10.061080", + "repeatPassword": "تکرار گذرواژه", + "about": "درباره", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "پذیرش", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} دعوت را پذیرفت", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "حساب", + "@account": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "به فضا افزودن", + "appLock": "قفل برنامه", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "all": "همه", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "همه گپ‌ها", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "addEmail": "افزودن رایانامه", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} به تماس پاسخ داد", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "هرکسی می‌تواند بپیوندد", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "بایگانی", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "مطمئن هستید؟", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "مطمئن هستید می‌خواهید خارج شوید؟", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} رمزنگاری سراسری را فعال کرد", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "مدیر", + "@admin": { + "type": "String", + "placeholders": {} + }, + "supposedMxid": "گمان میرود {mxid} باشد", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "botMessages": "پیام‌های ربات", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "changedTheDisplaynameTo": "{username} نام نمایشی را به '{displayname}' تغییر داد", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "confirmMatrixId": "برای پاک کردن حساب، لطفاً هویت ماتریکس خود را بپذیرید.", + "changeDeviceName": "تغییر نام دستگاه", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "alias": "نام مستعار", + "@alias": { + "type": "String", + "placeholders": {} + }, + "banFromChat": "محروم کردن از گپ", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "آیا درخواست بازبینی {username} را می‌پذیرید؟", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "areGuestsAllowedToJoin": "آیا مهمانان اجازه پیوستن دارند", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "پخش خودکار شکلک‌ها و برچسب‌های متحرک", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendOnEnter": "فرستادن با کلید Enter", + "cancel": "رد کردن", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changedTheChatDescriptionTo": "{username} توضیح گپ را به '{description}' تغییر داد", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} دسترسی‌های گپ را تغییر داد", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} نام گپ را به '{chatname}' تغییر داد", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "cantOpenUri": "نمی‌توان پیوند {uri} را باز کرد", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "banned": "محروم‌شده", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} کاربر {targetName} را محروم کرد", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "مسدود کردن دستگاه", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "مسدود‌شده", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "سرور از این نوع ورود پشتیبانی می‌کند:\n{serverVersions}\nاما برنامه تنها از این‌ها پشتیبانی می‌کند:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "سرور از این نسخه‌های مشخصات پشتیبانی می‌کند:\n{serverVersions}\nاما برنامه تنها از این‌ها پشتیبانی می‌کند:\n{supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "changedTheChatAvatar": "{username} نماد گپ را تغییر داد", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} قوانین دسترسی مهمان را تغییر داد", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} نماد نمایه را تغییر داد", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "chats": "گپ‌ها", + "@chats": { + "type": "String", + "placeholders": {} + }, + "messages": "پیام‌ها", + "@messages": { + "type": "String", + "placeholders": {} + }, + "send": "فرستادن", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "فرستادن صدا", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "فرستادن نسخه اصلی", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "changedTheRoomAliases": "{username} نام‌های مستعار اتاق را تغییر داد", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} پیوند دعوت را تغییر داد", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "close": "بستن", + "@close": { + "type": "String", + "placeholders": {} + }, + "sendImage": "فرستادن تصویر", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "فرستادن پیام‌ها", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "changedTheHistoryVisibility": "{username} ویژگی دیدن تاریخچه را تغییر داد", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} قوانین دسترسی مهمان را به {rules} تغییر داد", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} قوانین پیوستن را به {joinRules} تغییر داد", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} ویژگی دیدن تاریخچه را به {rules} تغییر داد", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "chooseAStrongPassword": "یک گذرواژه قوی انتخاب کنید", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "پشتیبان گپ شما تنظیم شد.", + "changeTheme": "تغییر پوسته", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "تغییر نام گروه", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "تغییر نماد نمایه", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "رمزنگاری مخدوش شده است", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "پاک کردن بایگانی", + "commandHint_create": "ساختن یک گپ گروهی خالی\nاز «--no-encryption» برای غیرفعال کردن رمزنگاری استفاده کنید", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_dm": "شروع یک گپ مستقیم\nاز «--no-encryption» برای غیرفعال کردن رمزنگاری استفاده کنید", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "sendSticker": "فرستادن برچسب", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "فرستادن ویدئو", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sender": "فرستنده", + "changedTheJoinRules": "{username} قوانین پیوستن را تغییر داد", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "chatDetails": "جزئیات گپ", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasdm": "علامت‌گذاری به‌عنوان اتاق پیام مستقیم با شناسه ماتریکس", + "commandHint_markasgroup": "علامت‌گذاری به‌عنوان گروه", + "commandHint_clearcache": "پاک کردن حافظه نهان", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_discardsession": "رد کردن نشست", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "groups": "گروه‌ها", + "@groups": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "برای خواندن پیام‌ها، برنامه را باز کنید", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "فرستادن پیام", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sentCallInformations": "{senderName} اطلاعات تماس را فرستاد", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "sendAsText": "فرستادن به‌عنوان متن", + "@sendAsText": { + "type": "String" + }, + "sendFile": "فرستادن پرونده", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} تماس را آغاز کرد", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "tryToSendAgain": "تلاش دوباره برای فرستادن", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "reactedWith": "{sender} با {reaction} واکنش نشان داد", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "askSSSSSign": "لطفاً عبارت عبور یا کلید بازیابی حافظه امن را وارد کنید تا شخص دیگری را امضا کنید.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "گپ به این فضا افزوده شد", + "chat": "گپ", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "پشتیبان گپ", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "changePassword": "تغییر گذرواژه", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "تغییر سرور خانگی", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "separateChatTypes": "جداسازی گپ‌های مستقیم از گروه‌ها", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "sentAPicture": "🖼️ {username} یک تصویر فرستاد", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} یک ویدئو فرستاد", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "commandInvalid": "دستور نامعتبر", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} یک دستور نیست.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "contactHasBeenInvitedToTheGroup": "مخاطب به گروه دعوت شد", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} یک پرونده فرستاد", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} یک صدا فرستاد", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userSentUnknownEvent": "{username} یک رویداد {type} فرستاد", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "weSentYouAnEmail": "یک رایانامه برای شما فرستادیم", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "بارگیری {count} شرکت‌کننده دیگر", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentASticker": "😊 {username} یک برچسب فرستاد", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "connect": "اتصال", + "@connect": { + "type": "String", + "placeholders": {} + }, + "confirm": "پذیرفتن", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "allSpaces": "همه فضاها", + "commandHint_ban": "محروم کردن کاربر مشخص‌شده از این اتاق", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_kick": "بیرون کردن کاربر مشخص‌شده از این اتاق", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_plain": "فرستادن متن بدون قالب", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_unban": "رد محرومیت کاربر مشخص‌شده از این اتاق", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "containsDisplayName": "دارای نام نمایشی", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "دارای نام کاربری", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "device": "دستگاه", + "@device": { + "type": "String", + "placeholders": {} + }, + "copy": "رونوشت", + "@copy": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "سطح دسترسی پیش‌فرض", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "پاک کردن", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "پاک کردن حساب", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "پاک کردن پیام", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "commandHint_html": "فرستادن متن با قالب HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_join": "پیوستن به اتاق مشخص‌شده", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_leave": "ترک این اتاق", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_myroomnick": "تنظیم نام نمایشی برای این اتاق", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_myroomavatar": "تنظیم نماد نمایه برای این اتاق (با mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_op": "تنظیم سطح دسترسی کاربر مشخص‌شده (پیش‌فرض: ۵۰)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_react": "فرستادن پاسخ به‌عنوان واکنش", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "compareEmojiMatch": "لطفاً شکلک‌ها را مقایسه کنید", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "رونوشت به بریده‌دان", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "countParticipants": "{count} شرکت‌کننده", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "ساختن", + "@create": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "فضای جدید", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deviceId": "شناسه دستگاه", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "دستگاه‌ها", + "@devices": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "نام نمایشی تغییر کرد", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "بارگیری پرونده", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "ویرایش", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "ویرایش سرورهای مسدود", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "ویرایش نام‌های مستعار اتاق", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "ویرایش نماد اتاق", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "شکلک از پیش وجود دارد!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "باید یک کد کوتاه شکلک و یک تصویر انتخاب کنید!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "کد کوتاه شکلک نامعتبر است!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "گپ خالی", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "به بریده‌دان رونوشت شد", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} گپ را ساخت", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "darkTheme": "تیره", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "directChats": "گپ‌های مستقیم", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "بسته‌های شکلک برای اتاق", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "تنظیمات شکلک", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "کد کوتاه شکلک", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "commandHint_me": "توصیف خود", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_send": "فرستادن متن", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "couldNotDecryptMessage": "نمی‌توان پیام را رمزگشایی کرد: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "chatBackupDescription": "پیام‌های شما با کلید بازیابی محافظت می‌شوند. حتماً آن را نزد خود نگه دارید.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "deactivateAccountWarning": "این کار حساب شما را غیرفعال می‌کند. این کنش برگشت‌ناپذیر است! آیا مطمئن هستید؟", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "commandHint_invite": "دعوت از کاربر مشخص‌شده به این اتاق", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "compareNumbersMatch": "لطفاً اعداد را مقایسه کنید", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "پیکربندی گپ", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "currentlyActive": "اکنون فعال", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}، {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "editDisplayname": "ویرایش نام نمایشی", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "id": "شناسه", + "@id": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} دعوت {targetName} را پس گرفت", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "guestsAreForbidden": "مهمان‌ها ممنوع هستند", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "پنهان کردن رویدادهای ویرایش‌شده", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "پنهان کردن رویدادهای ناشناخته", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "محتوا به مدیران سرور گزارش شد", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "از پیوستن", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "از دعوت", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "رفتن به اتاق جدید", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "گروه", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "گروه عمومی است", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "گروه با {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "howOffensiveIsThisContent": "این محتوا چقدر توهین‌آمیز است؟", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "فعال کردن بسته شکلک به‌صورت سراسری", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "فعال کردن رمزنگاری", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "نمی‌توانید رمزنگاری را غیرفعال کنید. آیا مطمئن هستید؟", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "رمزنگاری‌شده", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "رمزنگاری", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "رمزنگاری فعال نیست", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "enterAnEmailAddress": "یک نشانی رایانامه وارد کنید", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} به تماس پایان داد", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "homeserver": "سرور خانگی", + "enterYourHomeserver": "سرور خانگی خود را وارد کنید", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "خطا در به‌دست آوردن مکان: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "همه‌چیز آماده است!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "بسیار توهین‌آمیز", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "نام پرونده", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "فلافی‌چت", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "اندازه قلم", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "هدایت", + "@forward": { + "type": "String", + "placeholders": {} + }, + "help": "کمک", + "@help": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "مهمان‌ها می‌توانند بپیوندند", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "کاربران نادیده‌گرفته شده", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "commandHint_googly": "فرستادن چند چشم گوگولی", + "googlyEyesContent": "{senderName} برای شما چشم‌های گوگولی می‌فرستد", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "ignore": "نادیده‌گرفتن", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "cuddleContent": "{senderName} شما را در آغوش می‌گیرد", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "identity": "هویت", + "@identity": { + "type": "String", + "placeholders": {} + }, + "hugContent": "{senderName} شما را بغل می‌کند", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_cuddle": "فرستادن آغوش", + "commandHint_hug": "فرستادن بغل", + "editBundlesForAccount": "ویرایش بسته‌های این حساب", + "logout": "خروج", + "@logout": { + "type": "String", + "placeholders": {} + }, + "mention": "نام‌بردن", + "@mention": { + "type": "String", + "placeholders": {} + }, + "muteChat": "بی‌صدا کردن گپ", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "newChat": "گپ جدید", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 پیام جدید در فلافی‌چت", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "بدون اتصال به سرور", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "no": "خیر", + "@no": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "هنوز روشی برای بازیابی گذرواژه خود اضافه نکرده‌اید.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "آگاه‌سازها برای این حساب فعال شدند", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "or": "یا", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "شرکت‌کننده", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "عبارت عبور یا کلید بازیابی", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "گذرواژه", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "گذرواژه تغییر کرد", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "بازیابی گذرواژه", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "pin": "سنجاق کردن", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "پخش {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnter4Digits": "لطفاً ۴ رقم وارد کنید یا خالی بگذارید تا قفل برنامه غیرفعال شود.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "لطفاً رمز کوتاه خود را وارد کنید", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "لطفاً گذرواژه خود را وارد کنید", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "لطفاً دستورالعمل‌های وبگاه را دنبال کنید و روی بعدی بزنید.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "اتاق‌های عمومی", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "در حال به‌دست آوردن مکان…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "اوه، مشکلی پیش آمد…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "addToBundle": "افزودن به بسته", + "passwordForgotten": "فراموشی گذرواژه", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKey": "لطفاً کلید بازیابی خود را وارد کنید:", + "link": "پیوند", + "iHaveClickedOnLink": "روی پیوند کلیک کردم", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "عبارت عبور یا کلید بازیابی نادرست است", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "بی‌ضرر", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "دعوت مخاطب به {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "فقط کاربران دعوت‌شده", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "دعوت برای من", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "isTyping": "در حال نوشتن…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "پیوستن به اتاق", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} کاربر {targetName} را بیرون کرد", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "بیرون کردن از گپ", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "گپ را ترک کرد", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "dehydrate": "صدور نشست و پاک کردن دستگاه", + "hydrateTorLong": "آیا آخرین بار نشست خود را با تور صادر کردید؟ آن را وارد کنید و گپ را ادامه دهید.", + "loadingPleaseWait": "در حال بارگذاری… لطفاً صبر کنید.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "بارگذاری بیشتر…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "دسترسی به مکان رد شد. برای هم‌رسانی مکان، لطفاً دسترسی بدهید.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "logInTo": "ورود به {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "memberChanges": "تغییرات اعضا", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "moderator": "ناظر", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "درخواست بازبینی جدید!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "noPermission": "بدون دسترسی", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "اتاقی پیدا نشد…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "offline": "آفلاین", + "@offline": { + "type": "String", + "placeholders": {} + }, + "online": "آنلاین", + "@online": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "اوه! خطایی در تنظیم آگاه‌سازها رخ داد.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "openCamera": "باز کردن دوربین", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "addAccount": "افزودن حساب", + "people": "افراد", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "انتخاب تصویر", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "لطفاً انتخاب کنید", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "لطفاً یک رمز کوتاه انتخاب کنید", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "لطفاً نام کاربری خود را وارد کنید", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "privacy": "حریم خصوصی", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "license": "گواهینامه", + "@license": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} کاربر در حال نوشتن…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "invited": "دعوت‌شده", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} از {targetName} دعوت کرد", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "joinedTheChat": "👋 {username} به گپ پیوست", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} کاربر {targetName} را بیرون و محروم کرد", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "dehydrateWarning": "این کنش برگشت‌ناپذیر است. مطمئن شوید پرونده پشتیبان را به‌صورت امن ذخیره می‌کنید.", + "locationDisabledNotice": "مکان‌یاب غیرفعال است. لطفاً آن را فعال کنید تا بتوانید مکان خود را هم‌رسانی کنید.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "dehydrateTorLong": "برای کاربران تور، پیشنهاد می‌شود پیش از بستن پنجره، نشست را صادر کنند.", + "needPantalaimonWarning": "لطفاً توجه کنید که برای رمزنگاری سرتاسر به Pantalaimon نیاز دارید.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "next": "بعدی", + "@next": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "شکلکی پیدا نشد. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "به نظر می‌رسد دستگاه شما سرویس‌های گوگل ندارد. این انتخاب خوبی برای حریم خصوصی است! برای دریافت آگاه‌سازها در فلافی‌چت، پیشنهاد می‌کنیم از https://ntfy.sh استفاده کنید. با ntfy یا یک فراهم‌کننده UnifiedPush می‌توانید آگاه‌سازهای امن دریافت کنید. می‌توانید ntfy را از Play Store یا F-Droid بارگیری کنید.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "رمزنگاری را تنها زمانی می‌توانید فعال کنید که اتاق عمومی نباشد.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "پشتیبان‌گیری آنلاین کلید فعال است", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "enableMultiAccounts": "(آزمایشی) فعال کردن چند حساب در این دستگاه", + "pleaseClickOnLink": "لطفاً روی پیوند در رایانامه کلیک کنید و ادامه دهید.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "hydrateTor": "کاربران تور: وارد کردن نشست صادر شده", + "hydrate": "بازیابی از پرونده پشتیبان", + "inviteContact": "دعوت از مخاطب", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} سرور ماتریکس نیست، از {server2} استفاده شود؟", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "openVideoCamera": "باز کردن دوربین برای فیلم‌برداری", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "یکی از برنامه‌های شما از سیستم خارج شد", + "removeFromBundle": "برداشتن از بسته", + "bundleName": "نام بسته", + "openInMaps": "باز کردن در نقشه", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "برای ثبت‌نام، این سرور باید نشانی رایانامه شما را تأیید کند.", + "inviteText": "{username} شما را به فلافی‌چت دعوت کرد.\n۱. به fluffychat.im بروید و برنامه را نصب کنید\n۲. ثبت‌نام کنید یا وارد شوید\n۳. پیوند دعوت را باز کنید:\n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "leave": "ترک کردن", + "@leave": { + "type": "String", + "placeholders": {} + }, + "none": "هیچ", + "@none": { + "type": "String", + "placeholders": {} + }, + "offensive": "توهین‌آمیز", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "پویش کد QR", + "lastActiveAgo": "آخرین فعالیت: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "lightTheme": "روشن", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "dehydrateTor": "کاربران تور: صدور نشست", + "login": "ورود", + "@login": { + "type": "String", + "placeholders": {} + }, + "notifications": "آگاه‌سازها", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "ok": "خوب", + "@ok": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "اتاق ارتقا یافت", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "register": "ثبت‌نام", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "رد کردن", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} دعوت را رد کرد", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "پیوستن دوباره", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "لغو محرومیت از گپ", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "پاسخ", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "درخواست دسترسی", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "نگارش اتاق", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "search": "جستجو", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "امنیت", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "دیده‌شده توسط {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "تنظیم به‌عنوان نام مستعار اصلی", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "برداشتن نماد نمایه", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "recording": "در حال ضبط", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} یک رویداد را ویرایش کرد", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "remove": "برداشتن", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "پاک کردن همه دستگاه‌های دیگر", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "پاک‌شده توسط {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "پاک کردن دستگاه", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "گزارش پیام", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "saveFile": "ذخیره پرونده", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "کلید بازیابی", + "setInvitationLink": "تنظیم پیوند دعوت", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "pushRules": "قوانین آگاه‌ساز", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "دلیل", + "@reason": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "تنظیم شکلک‌های سفارشی", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "ویرایش پیام", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "جایگزینی اتاق با نگارش جدیدتر", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "recoveryKeyLost": "کلید بازیابی گم شد؟", + "fileHasBeenSavedAt": "پرونده در {path} ذخیره شد", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "enterSpace": "ورود به فضا", + "wasDirectChatDisplayName": "گپ خالی (پیش‌تر {oldDisplayName} بود)", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "newSpaceDescription": "فضاها امکان یکپارچه‌سازی گپ‌ها و ساخت جوامع خصوصی یا عمومی را فراهم می‌کنند.", + "encryptThisChat": "رمزنگاری این گپ", + "sorryThatsNotPossible": "متأسفیم... این ممکن نیست", + "deviceKeys": "کلیدهای دستگاه:", + "fileIsTooBigForServer": "نمیتوان فرستاد! سرور تنها از پیوست های تا {max} پشتیبانی میکند.", + "jumpToLastReadMessage": "پرش به آخرین پیام خوانده‌شده", + "hideUnimportantStateEvents": "پنهان کردن رویدادهای غیرمهم وضعیت", + "doNotShowAgain": "دوباره نمایش نده", + "readUpToHere": "خوانده‌شده تا اینجا", + "noBackupWarning": "هشدار! بدون فعال کردن پشتیبان گپ، دسترسی به پیام‌های رمزنگاری‌شده خود را از دست خواهید داد. پیشنهاد می‌شود پیش از خروج، پشتیبان گپ را فعال کنید.", + "noOtherDevicesFound": "دستگاه دیگری پیدا نشد", + "countFiles": "{count} پرونده", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "callingAccountDetails": "اجازه به فلافی‌چت برای استفاده از شماره‌گیر بومی اندروید.", + "noKeyForThisMessage": "اگر پیام پیش از ورود به حساب در این دستگاه فرستاده شده باشد، این مشکل ممکن است رخ دهد.\n\nهمچنین ممکن است فرستنده دستگاه شما را مسدود کرده باشد یا مشکلی در اتصال اینترنت وجود داشته باشد.\n\nآیا می‌توانید پیام را در نشست دیگری بخوانید؟ در این صورت، می‌توانید آن را منتقل کنید! به تنظیمات > دستگاه‌ها بروید و مطمئن شوید دستگاه‌هایتان یکدیگر را بازبینی کرده‌اند. هنگام باز کردن دوباره اتاق و فعال بودن هر دو نشست، کلیدها به‌صورت خودکار منتقل می‌شوند.\n\nآیا نمی‌خواهید هنگام خروج یا تغییر دستگاه کلیدها را گم کنید؟ مطمئن شوید پشتیبان گپ را در تنظیمات فعال کرده‌اید.", + "numChats": "{number} گپ", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "disableEncryptionWarning": "به دلایل امنیتی نمی‌توانید رمزنگاری را در گپی که فعال شده غیرفعال کنید.", + "enterRoom": "ورود به اتاق", + "newGroup": "گروه جدید", + "foregroundServiceRunning": "این آگاه‌ساز زمانی ظاهر می‌شود که خدمت پیش‌زمینه فعال است.", + "appearOnTopDetails": "اجازه به برنامه برای نمایش در بالا (اگر فلافی‌چت را به‌عنوان حساب تماس تنظیم کرده‌اید، لازم نیست)", + "storeSecurlyOnThisDevice": "ذخیره امن در این دستگاه", + "screenSharingDetail": "شما در حال هم‌رسانی صفحه‌نمایش خود در فلافی‌چت هستید", + "newSpace": "فضای جدید", + "saveKeyManuallyDescription": "این کلید را با استفاده از هم‌رسانی یا بریده‌دان به‌طور دستی ذخیره کنید.", + "storeInAndroidKeystore": "ذخیره در Android KeyStore", + "storeInAppleKeyChain": "ذخیره در Apple KeyChain", + "user": "کاربر", + "custom": "سفارشی", + "screenSharingTitle": "هم‌رسانی صفحه‌نمایش", + "callingPermissions": "دسترسی‌های تماس", + "callingAccount": "حساب تماس", + "appearOnTop": "نمایش در بالا", + "otherCallingPermissions": "میکروفون، دوربین و دیگر دسترسی‌های فلافی‌چت", + "whyIsThisMessageEncrypted": "چرا این پیام خوانا نیست؟", + "reopenChat": "باز کردن دوباره گپ", + "unmuteChat": "فعال کردن صدای گپ", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "nextAccount": "حساب بعدی", + "unlockOldMessages": "گشودن پیام‌های قدیمی", + "share": "هم‌رسانی", + "@share": { + "type": "String", + "placeholders": {} + }, + "skip": "رد کردن", + "@skip": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "سامانه", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "هم‌خوانی ندارند", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "تغییر وضعیت برگزیده", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "تغییر وضعیت بی‌صدا", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "تغییر وضعیت خوانده‌شده/خوانده‌نشده", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "unavailable": "در دسترس نیست", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unblockDevice": "باز کردن دستگاه", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "آغاز بازبینی", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "بازبینی با موفقیت انجام شد!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "در انتظار پذیرش شکلک توسط دیگری…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "کاغذدیواری:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "چه کسی می‌تواند چه کاری انجام دهد", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "نوشتن پیام…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "widgetVideo": "ویدئو", + "youHaveBeenBannedFromThisChat": "شما از این گپ محروم شده‌اید", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "تنظیم سطح دسترسی", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "تنظیم وضعیت", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "تنظیمات", + "@settings": { + "type": "String", + "placeholders": {} + }, + "showPassword": "نمایش گذرواژه", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "ورود یکپارچه", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "spaceName": "نام فضا", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startFirstChat": "شروع اولین گپ", + "theyMatch": "هم‌خوانی دارند", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "فلافی‌چت", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "درخواست‌های بیش از حد. لطفاً بعداً دوباره تلاش کنید!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} محرومیت {targetName} را برداشت", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unknownEncryptionAlgorithm": "الگوریتم رمزنگاری ناشناخته", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unpin": "برداشتن سنجاق", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "userAndUserAreTyping": "{username} و {username2} در حال نوشتن…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "videoCall": "تماس تصویری", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "قابل‌دید برای همه شرکت‌کنندگان", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "قابل‌دید برای همه", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "پیام صوتی", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "در انتظار پذیرش درخواست توسط دیگری…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "warning": "هشدار!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "شما دیگر در این گپ شرکت نمی‌کنید", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "اطلاعات پیام", + "time": "زمان", + "messageType": "نوع پیام", + "addToSpaceDescription": "فضایی را برای افزودن این گپ انتخاب کنید.", + "start": "آغاز", + "videoWithSize": "ویدئو ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "userIsTyping": "{username} در حال نوشتن…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "نام کاربری", + "@username": { + "type": "String", + "placeholders": {} + }, + "yes": "بله", + "@yes": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "کلید عمومی شما", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "publish": "انتشار", + "shareLocation": "هم‌رسانی مکان", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "youInvitedUser": "📩 شما {user} را دعوت کردید", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unverified": "تأییدنشده", + "verify": "بازبینی", + "@verify": { + "type": "String", + "placeholders": {} + }, + "openChat": "باز کردن گپ", + "dismiss": "رد کردن", + "unsupportedAndroidVersion": "نسخه اندروید پشتیبانی‌نشده", + "youUnbannedUser": "شما محرومیت {user} را برداشتید", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "verified": "تاییدشده", + "@verified": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "چرا می‌خواهید گزارش دهید؟", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "you": "شما", + "@you": { + "type": "String", + "placeholders": {} + }, + "widgetJitsi": "جیتسی‌میت(Jitsi Meet)", + "sourceCode": "کد منبع", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "فضا عمومی است", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "در حال همگام‌سازی... لطفا صبر کنید.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "رویداد ناشناخته '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "userAndOthersAreTyping": "{username} و {count} نفر دیگر در حال تایپ کردن…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userLeftTheChat": "👋 {username} گپ را ترک کرد", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "verifyTitle": "در حال تایید حساب دیگر", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "قابلیت دیدن تاریخچه گپ", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "چه کسی اجازه پیوستن به این گروه را دارد", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "در انتظار پذیرش اعداد توسط دیگری…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "برای ایجاد کلید بازیابی جدید، پشتیبان گپ خود را پاک می‌کنید؟", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "با این آدرس‌ها می‌توانید رمز خود را بازیابی کنید.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "openGallery": "بازکردن گالری", + "removeFromSpace": "حذف از فضا", + "pleaseEnterRecoveryKeyDescription": "برای گشودن قفل پیام‌های قدیمیتان، لطفا کلید بازیابی‌ای که در یک نشست پیشین تولید شده را وارد کنید. کلید بازیابی شما، رمز عبور شما نیست.", + "confirmEventUnpin": "آیا از برداشتن سنجاق رویداد به صورت دائمی مطمئن هستید؟", + "indexedDbErrorLong": "متاسفانه فضای ذخیره‌سازی پیام‌ها، به صورت پیش‌فرض در حالت خصوصی فعال نیست.\nلطفا آدرس زیر را باز کنید:\nabout:config\nمقدار «dom.indexedDB.privateBrowsing.enabled» را به «true» تغییر دهید\nدر غیر این صورت، امکان اجرای فلافی‌چت وجود ندارد.", + "widgetEtherpad": "یادداشت متنی", + "youKickedAndBanned": "🙅 شما {user} را بیرون و محروم کردید", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "statusExampleMessage": "امروز حالتان چطور است؟", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "ارسال", + "@submit": { + "type": "String", + "placeholders": {} + }, + "youRejectedTheInvitation": "شما دعوت را رد کردید", + "youAcceptedTheInvitation": "👍 شما دعوت را پذیرفتید", + "emailOrUsername": "رایانامه(ایمیل) یا نام کاربری", + "transferFromAnotherDevice": "انتقال از دستگاهی دیگر", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "videoCallsBetaWarning": "لطفا توجه داشته باشید که تماس‌های تصویری در حال حاضر آزمایشی هستند. ممکن است طبق انتظار کار نکنند یا روی همه پلتفرم‌ها اصلا کار نکنند.", + "experimentalVideoCalls": "تماس‌های تصویری آزمایشی", + "placeCall": "برقراری تماس", + "unsupportedAndroidVersionLong": "این ویژگی به نسخه تازه‌تری از اندروید نیاز دارد. لطفا به‌روزرسانی یا پشتیبانی لینیج‌اواس(LineageOS) را بررسی کنید.", + "sharedTheLocation": "{username} وضعیت مکانی خود را به اشتراک گذاشت", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "unreadChats": "{unreadCount, plural, other{{unreadCount} گپ خوانده نشده}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "status": "وضعیت", + "@status": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "دستگاه ناشناس", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "markAsRead": "علامت‌گذاشتن به عنوان خوانده شده", + "reportUser": "گزارش دادن کاربر", + "pinMessage": "سنجاق کردن به اتاق", + "emojis": "شکلک‌ها", + "voiceCall": "تماس صوتی", + "indexedDbErrorTitle": "اشکالات حالت خصوصی", + "switchToAccount": "تغییر به حساب {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "previousAccount": "حساب قبلی", + "addWidget": "افزودن ویجت", + "widgetCustom": "سفارشی", + "widgetName": "نام", + "widgetUrlError": "این آدرس وب معتبر نیست.", + "widgetNameError": "لطفا یک نام نمایشی مشخص کنید.", + "errorAddingWidget": "بروز خطا هنگام افزودن ویجت.", + "youJoinedTheChat": "شما به گپ پیوستید", + "youBannedUser": "شما {user} را محروم کردید", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "شما دعوت {user} را پس‌گرفتید", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 شما توسط {user} دعوت شده‌اید", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 شما {user} را بیرون کردید", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "users": "کاربرها", + "storeInSecureStorageDescription": "کلید بازیابی را در محل ذخیره‌سازی امن این دستگاه ذخیره کنید.", + "jump": "پرش", + "allRooms": "تمام چت‌های گروهی", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "report": "گزارش", + "openLinkInBrowser": "بازکردن پیوند در مرورگر", + "reportErrorDescription": "اوه نه. اشتباهی رخ داد. اگر تمایل دارید، می‌توانید این اشکال را با توسعه‌دهندگان گزارش دهید.", + "signInWithPassword": "ورود با رمزعبور", + "pleaseTryAgainLaterOrChooseDifferentServer": "لطفا بعدا تلاش کنید یا سرور دیگری انتخاب کنید.", + "notAnImage": "یک فایل تصویری نیست.", + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "setCustomPermissionLevel": "تنظیم سطح دسترسی سفارشی", + "setPermissionsLevelDescription": "لطفاً نقش از پیش تعریف‌شده‌ای را انتخاب کنید یا سطح دسترسی سفارشی بین ۰ تا ۱۰۰ وارد کنید.", + "ignoreUser": "چشم‌پوشی از کاربر", + "normalUser": "کاربر عادی", + "importNow": "اکنون وارد کنید", + "importEmojis": "وارد کردن شکلک‌ها", + "importFromZipFile": "وارد کردن از پرونده زیپ", + "exportEmotePack": "صادر کردن بسته شکلک به‌صورت زیپ", + "replace": "جایگزین کردن", + "aboutHomeserver": "درباره {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "addChatDescription": "افزودن توضیح گپ...", + "commandHint_roomupgrade": "ارتقای این اتاق به نگارش مشخص‌شده", + "appLockDescription": "قفل کردن برنامه با رمز کوتاه هنگام عدم استفاده", + "sendTypingNotifications": "فرستادن آگاه‌سازهای نوشتن", + "swipeRightToLeftToReply": "کشیدن از راست به چپ برای پاسخ", + "countChatsAndCountParticipants": "{chats} گپ و {participants} شرکت‌کننده", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "گپ دیگری پیدا نشد...", + "noChatsFoundHere": "اینجا هنوز گپی پیدا نشد. با استفاده از دکمه زیر گپ جدیدی با کسی شروع کنید. ⤵️", + "joinedChats": "گپ‌های پیوسته", + "unread": "خوانده‌نشده", + "space": "فضا", + "spaces": "فضاها", + "checkList": "فهرست بررسی", + "countInvited": "{count} دعوت‌شده", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "createGroup": "ساختن گروه", + "chatPermissions": "دسترسی‌های گپ", + "emoteKeyboardNoRecents": "شکلک‌هایی که به تازگی استفاده‌شده اینجا نمایش داده میشوند...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "شناسه گپ سراسری", + "accessAndVisibility": "دسترسی و قابلیت دید", + "accessAndVisibilityDescription": "چه کسی اجازه پیوستن به این گپ را دارد و گپ چگونه قابل کشف است.", + "calls": "تماس‌ها", + "customEmojisAndStickers": "شکلک‌ها و برچسب‌های سفارشی", + "customEmojisAndStickersBody": "افزودن یا هم‌رسانی شکلک‌ها یا برچسب‌های سفارشی که در هر گپ قابل استفاده‌اند.", + "chatDescription": "توضیح گپ", + "chatDescriptionHasBeenChanged": "توضیح گپ تغییر کرد", + "hideRedactedMessages": "پنهان کردن پیام‌های ویرایش‌شده", + "hideRedactedMessagesBody": "اگر کسی پیامی را ویرایش کند، دیگر نمیتوان آن پیام را در گپ دید.", + "hideInvalidOrUnknownMessageFormats": "پنهان کردن قالب‌های پیام نامعتبر یا ناشناخته", + "block": "مسدود کردن", + "blockedUsers": "کاربران مسدود‌شده", + "blockListDescription": "میتوانید کاربرانی که مزاحم شما هستند را مسدود کنید. از کاربران موجود در فهرست مسدود شخصی، پیام یا دعوت به اتاق دریافت نخواهید کرد.", + "blockUsername": "چشم‌پوشی از نام کاربری", + "inviteContactToGroupQuestion": "آیا میخواهید {contact} را به گپ «{groupName}» دعوت کنید؟", + "noChatDescriptionYet": "هنوز توضیح گپی ساخته نشده است.", + "tryAgain": "تلاش دوباره", + "invalidServerName": "نام سرور نامعتبر", + "redactMessageDescription": "پیام برای همه شرکت‌کنندگان در این گفتگو ویرایش خواهد شد. این کار برگشت‌ناپذیر است.", + "optionalRedactReason": "(اختیاری) دلیل ویرایش این پیام...", + "messagesStyle": "پیام‌ها:", + "shareInviteLink": "هم‌رسانی پیوند دعوت", + "hideMemberChangesInPublicChats": "پنهان کردن تغییرات اعضا در گپ‌های عمومی", + "hideMemberChangesInPublicChatsBody": "برای بهبود خوانایی، اینکه کسی به گپ عمومی پیوست یا آن را ترک کرد در خط زمانی گپ نمایش داده نشود.", + "overview": "دید کلی", + "notifyMeFor": "برایم آگاه‌ساز بفرست برای", + "passwordRecoverySettings": "تنظیمات بازیابی گذرواژه", + "redactedBy": "ویرایش‌شده به‌دست {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "گپ مستقیم", + "redactedByBecause": "ویرایش‌شده به‌دست {username} زیرا: «{reason}»", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "sendImages": "فرستادن {count} تصویر", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "setChatDescription": "تنظیم توضیح گپ", + "presenceStyle": "حضور:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "نمایش پیام‌های وضعیت از دیگر کاربران", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWaitCounter": " در حال همگام‌سازی... ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 شما با پیوند دعوت شده‌اید به:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "invitedBy": "📩 دعوت‌شده توسط {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hasKnocked": "🚪 {user} در زده است", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "کاربران باید در بزنند", + "noOneCanJoin": "هیچ‌کس نمیتواند بپیوندد", + "userWouldLikeToChangeTheChat": "{user} مایل به پیوستن به گپ است.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "هنوز پیوند عمومی ساخته نشده است", + "knock": "در زدن", + "hidePresences": "پنهان کردن فهرست وضعیت؟", + "signInWith": "ورود با {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "profileNotFound": "کاربر در سرور پیدا نشد. شاید مشکل اتصال وجود دارد یا کاربر وجود ندارد.", + "setTheme": "تنظیم پوسته:", + "setColorTheme": "تنظیم پوسته رنگی:", + "invite": "دعوت", + "inviteGroupChat": "📨 دعوت به گپ گروهی", + "invitePrivateChat": "📨 دعوت به گپ خصوصی", + "invalidInput": "ورودی نامعتبر!", + "wrongPinEntered": "رمز کوتاه نادرست وارد شد! {seconds} ثانیه دیگر دوباره تلاش کنید...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pleaseEnterANumber": "لطفاً عددی بزرگ‌تر از ۰ وارد کنید", + "archiveRoomDescription": "گپ به بایگانی خواهد رفت. کاربران دیگر میتوانند ببینند که شما گپ را ترک کرده‌اید.", + "roomUpgradeDescription": "گپ با نگارش جدید اتاق بازسازی خواهد شد. به همه شرکت‌کنندگان آگاهی‌رسانی میشود که باید به گپ جدید بروند. داده‌های بیشتر درباره نگارش‌های اتاق در https://spec.matrix.org/latest/rooms/", + "removeDevicesDescription": "از این دستگاه خارج خواهید شد و دیگر نمیتوانید پیام دریافت کنید.", + "banUserDescription": "کاربر از گپ محروم خواهد شد و تا زمانی که محرومیت برداشته نشود، نمیتواند دوباره وارد گپ شود.", + "unbanUserDescription": "کاربر در صورت تلاش دوباره میتواند وارد گپ شود.", + "kickUserDescription": "کاربر از گپ بیرون میشود اما محروم نمیشود. در گپ‌های عمومی، کاربر میتواند هر زمان دوباره بپیوندد.", + "makeAdminDescription": "پس از مدیر کردن این کاربر، ممکن است نتوانید این کار را لغو کنید، زیرا آن‌ها همان دسترسی‌های شما را خواهند داشت.", + "pushNotificationsNotAvailable": "آگاه‌سازهای فشاری در دسترس نیستند", + "learnMore": "بیشتر بدانید", + "yourGlobalUserIdIs": "شناسه کاربری سراسری شما: ", + "noUsersFoundWithQuery": "متأسفانه کاربری با «{query}» پیدا نشد. لطفاً بررسی کنید که آیا اشتباه نوشتاری دارید.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "knocking": "در زدن", + "chatCanBeDiscoveredViaSearchOnServer": "گپ با جستجو در {server} قابل کشف است", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchChatsRooms": "جستجو برای #گپ‌ها، @کاربران...", + "nothingFound": "چیزی پیدا نشد...", + "groupName": "نام گروه", + "createGroupAndInviteUsers": "ساختن گروه و دعوت کاربران", + "groupCanBeFoundViaSearch": "گروه با جستجو قابل یافتن است", + "wrongRecoveryKey": "متأسفیم... به نظر میرسد این کلید بازیابی درست نباشد.", + "startConversation": "آغاز گفتگو", + "commandHint_sendraw": "فرستادن JSON خام", + "databaseMigrationTitle": "پایگاه داده بهینه‌سازی شد", + "databaseMigrationBody": "لطفاً صبر کنید. این ممکن است لحظه‌ای طول بکشد.", + "leaveEmptyToClearStatus": "برای پاک کردن وضعیت، خالی بگذارید.", + "select": "انتخاب", + "searchForUsers": "جستجو برای @کاربران...", + "pleaseEnterYourCurrentPassword": "لطفاً گذرواژه کنونی خود را وارد کنید", + "newPassword": "گذرواژه جدید", + "pleaseChooseAStrongPassword": "لطفاً یک گذرواژه قوی انتخاب کنید", + "passwordsDoNotMatch": "گذرواژه‌ها هم‌خوانی ندارند", + "passwordIsWrong": "گذرواژه واردشده نادرست است", + "publicLink": "پیوند عمومی", + "publicChatAddresses": "نشانی‌های گپ عمومی", + "createNewAddress": "ساختن نشانی جدید", + "joinSpace": "پیوستن به فضا", + "publicSpaces": "فضاهای عمومی", + "addChatOrSubSpace": "افزودن گپ یا زیرفضا", + "subspace": "زیرفضا", + "decline": "نپذیرفتن", + "thisDevice": "این دستگاه:", + "userRole": "نقش کاربر", + "minimumPowerLevel": "{level} کمینه سطح دسترسی است.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "جستجو در گپ «{chat}»...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "جستجوی بیشتر...", + "gallery": "نگارخانه", + "files": "پرونده‌ها", + "databaseBuildErrorBody": "ناتوانی در ساخت پایگاه داده SQLite. برنامه اکنون سعی میکند از پایگاه داده قدیمی استفاده کند. لطفاً این خطا را به توسعه‌دهندگان در {url} گزارش دهید. پیام خطا: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "نشست شما گم شده است. لطفاً این خطا را به توسعه‌دهندگان در {url} گزارش دهید. پیام خطا: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "برنامه اکنون سعی میکند نشست شما را از پشتیبان بازیابی کند. لطفاً این خطا را به توسعه‌دهندگان در {url} گزارش دهید. پیام خطا: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "هدایت پیام به {roomName}؟", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "فرستادن رسیدهای خواندن", + "sendTypingNotificationsDescription": "دیگر شرکت‌کنندگان در گپ میتوانند ببینند که شما در حال تایپ پیام جدید هستید.", + "sendReadReceiptsDescription": "دیگر شرکت‌کنندگان در گپ میتوانند ببینند که شما پیام را خوانده‌اید.", + "formattedMessages": "پیام‌های قالب‌بندی‌شده", + "formattedMessagesDescription": "نمایش محتوای پیام غنی مانند متن پررنگ با استفاده از مارک‌داون.", + "verifyOtherUser": "🔐 بازبینی کاربر دیگر", + "verifyOtherUserDescription": "اگر کاربر دیگری را بازبینی کنید، میتوانید مطمئن شوید که واقعاً با چه کسی در حال نوشتن هستید. 💪\n\nهنگام شروع بازبینی، شما و کاربر دیگر پنجره‌ای در برنامه خواهید دید. در آنجا مجموعه‌ای از شکلک‌ها یا اعداد را مشاهده میکنید که باید با یکدیگر مقایسه کنید.\n\nبهترین راه برای این کار دیدار حضوری یا شروع تماس تصویری است. 👭", + "verifyOtherDevice": "🔐 بازبینی دستگاه دیگر", + "verifyOtherDeviceDescription": "هنگام بازبینی دستگاه دیگر، آن دستگاه‌ها میتوانند کلیدها را تبادل کنند و امنیت کلی شما را افزایش دهند. 💪 هنگام شروع بازبینی، پنجره‌ای در برنامه روی هر دو دستگاه ظاهر میشود. در آنجا مجموعه‌ای از شکلک‌ها یا اعداد را مشاهده میکنید که باید با یکدیگر مقایسه کنید. بهتر است پیش از شروع بازبینی، هر دو دستگاه در دسترس باشند. 🤳", + "acceptedKeyVerification": "{sender} بازبینی کلید را پذیرفت", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} بازبینی کلید را رد کرد", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} بازبینی کلید را کامل کرد", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} برای بازبینی کلید آماده است", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} درخواست بازبینی کلید کرد", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} بازبینی کلید را آغاز کرد", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "شفاف", + "incomingMessages": "پیام‌های دریافتی", + "stickers": "برچسب‌ها", + "discover": "کشف", + "commandHint_ignore": "چشم‌پوشی از شناسه ماتریکس داده‌شده", + "commandHint_unignore": "لغو چشم‌پوشی از شناسه ماتریکس داده‌شده", + "unreadChatsInApp": "{appname}: {unread} گپ خوانده‌نشده", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "رمزنگاری پایگاه داده در این سکو پشتیبانی نمیشود", + "thereAreCountUsersBlocked": "اکنون {count} کاربر مسدود شده‌اند.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "محدودشده", + "knockRestricted": "در زدن محدود", + "goToSpace": "رفتن به فضا: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "علامت‌گذاری به‌عنوان خوانده‌نشده", + "userLevel": "{level} - کاربر", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - ناظر", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - مدیر", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "تغییر تنظیمات عمومی گپ", + "inviteOtherUsers": "دعوت کاربران دیگر به این گپ", + "changeTheChatPermissions": "تغییر دسترسی‌های گپ", + "changeTheVisibilityOfChatHistory": "تغییر قابلیت دید تاریخچه گپ", + "changeTheCanonicalRoomAlias": "تغییر نشانی اصلی گپ عمومی", + "sendRoomNotifications": "فرستادن آگاه‌سازهای @room", + "changeTheDescriptionOfTheGroup": "تغییر توضیح گپ", + "chatPermissionsDescription": "مشخص کنید کدام سطح دسترسی برای اقدامات خاصی در این گپ لازم است. سطح‌های دسترسی ۰، ۵۰ و ۱۰۰ معمولاً نشان‌دهنده کاربران، ناظران و مدیران هستند، اما هر درجه‌بندی ممکن است.", + "updateInstalled": "🎉 به‌روزرسانی {version} نصب شد!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "فهرست تغییرات", + "sendCanceled": "فرستادن رد شد", + "loginWithMatrixId": "ورود با شناسه ماتریکس", + "discoverHomeservers": "کشف سرورهای خانگی", + "whatIsAHomeserver": "سرور خانگی چیست؟", + "homeserverDescription": "همه داده‌های شما روی سرور خانگی نگه‌داری میشوند، مانند یک فراهم‌کننده رایانامه. میتوانید سرور خانگی مورد نظر خود را انتخاب کنید، در حالی که همچنان میتوانید با هر کسی گفتگو کنید. اطلاعات بیشتر در https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "به نظر نمیرسد سرور خانگی سازگاری داشته باشد. نشانی اشتباه است؟", + "calculatingFileSize": "در حال محاسبه اندازه پرونده...", + "prepareSendingAttachment": "آماده‌سازی برای فرستادن پیوست...", + "sendingAttachment": "در حال فرستادن پیوست...", + "generatingVideoThumbnail": "در حال تولید تصویر کوچک ویدئو...", + "compressVideo": "در حال فشرده‌سازی ویدئو...", + "sendingAttachmentCountOfCount": "در حال فرستادن پیوست {index} از {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "محدودیت سرور رسیده است! {seconds} ثانیه صبر کنید...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "یکی از دستگاه‌های شما بازبینی نشده است", + "noticeChatBackupDeviceVerification": "توجه: وقتی همه دستگاه‌های خود را به پشتیبان گپ متصل کنید، به‌صورت خودکار بازبینی میشوند.", + "continueText": "ادامه", + "welcomeText": "درود درود 👋 این فلافی‌چت است. میتوانید به هر سرور خانگی سازگار با https://matrix.org وارد شوید و با هر کسی گپ بزنید. این یک شبکه پیام‌رسانی غیرمتمرکز بزرگ است!", + "blur": "محو کردن:", + "opacity": "شفافیت:", + "setWallpaper": "تنظیم کاغذدیواری", + "manageAccount": "مدیریت حساب", + "noContactInformationProvided": "سرور هیچ اطلاعات تماس معتبری نمیدهد", + "contactServerAdmin": "تماس با مدیر سرور", + "contactServerSecurity": "تماس با امنیت سرور", + "supportPage": "صفحه پشتیبانی", + "serverInformation": "درباره سرور:", + "name": "نام", + "version": "نگارش", + "website": "وبگاه", + "compress": "فشرده‌سازی", + "boldText": "متن درشت", + "italicText": "متن کج", + "strikeThrough": "خط‌خورده", + "pleaseFillOut": "لطفاً پر کنید", + "invalidUrl": "نشانی نامعتبر", + "addLink": "افزودن پیوند", + "unableToJoinChat": "ناتوانی در پیوستن به گپ. شاید طرف مقابل گفتگو را بسته است.", + "previous": "پیشین", + "otherPartyNotLoggedIn": "طرف مقابل اکنون وارد نشده است و بنابراین نمیتواند پیام دریافت کند!", + "appWantsToUseForLogin": "برای ورود از '{server}' استفاده کنید", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "شما بدین‌وسیله به برنامه و وبگاه اجازه میدهید اطلاعات شما را هم‌رسانی کنند.", + "open": "باز کردن", + "waitingForServer": "در انتظار سرور...", + "appIntroduction": "فلافی‌چت به شما امکان گپ با دوستانتان در پیام‌رسان‌های مختلف را میدهد. اطلاعات بیشتر در https://matrix.org یا فقط روی *ادامه* بزنید.", + "newChatRequest": "📩 درخواست گپ جدید", + "contentNotificationSettings": "تنظیمات آگاه‌ساز محتوا", + "generalNotificationSettings": "تنظیمات آگاه‌ساز عمومی", + "roomNotificationSettings": "تنظیمات آگاه‌ساز اتاق", + "userSpecificNotificationSettings": "تنظیمات آگاه‌ساز خاص کاربر", + "otherNotificationSettings": "سایر تنظیمات آگاه‌ساز", + "notificationRuleContainsUserName": "دارای نام کاربری", + "notificationRuleContainsUserNameDescription": "وقتی پیامی حاوی نام کاربری باشد، کاربر را آگاه میکند.", + "notificationRuleMaster": "بی‌صدا کردن همه آگاه‌سازها", + "notificationRuleMasterDescription": "از قوانین دیگر چشم‌پوشی میکند و همه آگاه‌سازها را غیرفعال میکند.", + "notificationRuleSuppressNotices": "سرکوب پیام‌های خودکار", + "notificationRuleSuppressNoticesDescription": "آگاه‌سازهای کارخواه‌های خودکار مانند ربات‌ها را سرکوب میکند.", + "notificationRuleInviteForMe": "دعوت برای من", + "notificationRuleInviteForMeDescription": "وقتی کاربر به اتاقی دعوت میشود، او را آگاه میکند.", + "notificationRuleMemberEvent": "رویداد عضویت", + "notificationRuleMemberEventDescription": "آگاه‌سازهای رویدادهای عضویت را سرکوب میکند.", + "notificationRuleIsUserMention": "نام‌بردن از کاربر", + "notificationRuleIsUserMentionDescription": "وقتی در پیامی مستقیماً از کاربر نام برده میشود، او را آگاه میکند.", + "notificationRuleContainsDisplayName": "دارای نام نمایشی", + "notificationRuleContainsDisplayNameDescription": "وقتی پیامی حاوی نام نمایشی کاربر باشد، کاربر را آگاه میکند.", + "notificationRuleIsRoomMention": "نام‌بردن از اتاق", + "notificationRuleIsRoomMentionDescription": "وقتی نام اتاق ذکر میشود، کاربر را آگاه میکند.", + "notificationRuleRoomnotif": "آگاه‌ساز اتاق", + "notificationRuleRoomnotifDescription": "وقتی پیامی حاوی '@room' باشد، کاربر را آگاه میکند.", + "notificationRuleTombstone": "سنگ قبر", + "notificationRuleTombstoneDescription": "کاربر را از پیام‌های غیرفعال‌سازی اتاق آگاه میکند.", + "notificationRuleReaction": "واکنش", + "notificationRuleReactionDescription": "آگاه‌سازهای واکنش‌ها را سرکوب میکند.", + "notificationRuleRoomServerAcl": "ACL سرور اتاق", + "notificationRuleRoomServerAclDescription": "آگاه‌سازهای فهرست‌های کنترل دسترسی سرور اتاق (ACL) را سرکوب میکند.", + "notificationRuleSuppressEdits": "سرکوب ویرایش‌ها", + "notificationRuleSuppressEditsDescription": "آگاه‌سازهای پیام‌های ویرایش‌شده را سرکوب میکند.", + "notificationRuleCall": "تماس", + "notificationRuleCallDescription": "درباره تماس‌ها کاربر را آگاه میکند.", + "notificationRuleEncryptedRoomOneToOne": "اتاق رمزنگاری‌شده یک‌به‌یک", + "notificationRuleEncryptedRoomOneToOneDescription": "کاربر را از پیام‌ها در اتاق‌های رمزنگاری‌شده یک‌به‌یک آگاه میکند.", + "notificationRuleRoomOneToOne": "اتاق یک‌به‌یک", + "notificationRuleRoomOneToOneDescription": "کاربر را از پیام‌ها در اتاق‌های یک‌به‌یک آگاه میکند.", + "notificationRuleMessage": "پیام", + "notificationRuleMessageDescription": "کاربر را از پیام‌های عمومی آگاه میکند.", + "notificationRuleEncrypted": "رمزنگاری‌شده", + "notificationRuleEncryptedDescription": "کاربر را از پیام‌ها در اتاق‌های رمزنگاری‌شده آگاه میکند.", + "notificationRuleJitsi": "جیتسی", + "notificationRuleJitsiDescription": "کاربر را از رویدادهای ابزارک جیتسی آگاه میکند.", + "notificationRuleServerAcl": "سرکوب رویدادهای ACL سرور", + "notificationRuleServerAclDescription": "آگاه‌سازهای رویدادهای ACL سرور را سرکوب میکند.", + "unknownPushRule": "قانون ناشناخته آگاه‌ساز '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - پیام صوتی از {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "اگر این تنظیم آگاه‌ساز را پاک کنید، این کار برگشت‌ناپذیر است.", + "more": "بیشتر", + "shareKeysWith": "هم‌رسانی کلیدها با...", + "shareKeysWithDescription": "کدام دستگاه‌ها باید مورد اعتماد باشند تا بتوانند پیام‌های شما را در گپ‌های رمزنگاری‌شده بخوانند؟", + "allDevices": "همه دستگاه‌ها", + "crossVerifiedDevicesIfEnabled": "دستگاه‌های بازبینی‌شده متقابل اگر فعال باشد", + "crossVerifiedDevices": "دستگاه‌های بازبینی‌شده متقابل", + "verifiedDevicesOnly": "فقط دستگاه‌های بازبینی‌شده", + "takeAPhoto": "گرفتن عکس", + "recordAVideo": "ضبط ویدئو", + "optionalMessage": "(اختیاری) پیام...", + "notSupportedOnThisDevice": "در این دستگاه پشتیبانی نمیشود", + "enterNewChat": "ورود به گپ جدید", + "approve": "پذیرفتن", + "youHaveKnocked": "شما در زده‌اید", + "pleaseWaitUntilInvited": "لطفاً اکنون صبر کنید تا کسی از اتاق شما را دعوت کند.", + "commandHint_logout": "خروج از دستگاه کنونی", + "commandHint_logoutall": "خروج از همه دستگاه‌های فعال", + "displayNavigationRail": "نمایش نوار ناوبری در تلفن همراه", + "customReaction": "واکنش سفارشی", + "moreEvents": "رویدادهای بیشتر", + "initAppError": "خطایی هنگام آغاز برنامه رخ داد", + "changedTheChatDescription": "‮‭‭‮‭‬‫{username} توضیحات گپ را تغییر داد", + "changedTheChatName": "{username} نام گپ را تغییر داد", + "declineInvitation": "رد کردن دعوت", + "noMessagesYet": "پیامی وجود ندارد", + "longPressToRecordVoiceMessage": "برای ضبط پیام صوتی، انگشت خود را نگه دارید." +} diff --git a/lib/l10n/intl_fi.arb b/lib/l10n/intl_fi.arb new file mode 100644 index 000000000..9f33e4c5b --- /dev/null +++ b/lib/l10n/intl_fi.arb @@ -0,0 +1,3487 @@ +{ + "repeatPassword": "Salasana uudelleen", + "@repeatPassword": {}, + "about": "Tietoa FluffyChatista", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Hyväksy", + "@accept": { + "type": "String", + "placeholders": {} + }, + "account": "Tili", + "@account": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "{username} hyväksyi kutsun", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "activatedEndToEndEncryption": "🔐 {username} otti käyttöön päästä-päähän salauksen", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "archive": "Arkisto", + "@archive": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Voidaksesi allekirjoittaa toisen henkilön, syötä turvavaraston salalause tai palautusavain.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "addEmail": "Lisää sähköpostiosoite", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Lisää tilaan", + "@addToSpace": {}, + "admin": "Ylläpitäjä", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Kaikki", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Kaikki keskustelut", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} vastasi puheluun", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Kuka tahansa voi liittyä", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Sovelluksen lukitus", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Sallitaanko vieraiden liittyminen", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Haluatko varmasti kirjautua ulos?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Oletko varma?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "Toista animoidut tarrat ja emojit automaattisesti", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "askVerificationRequest": "Hyväksytäänkö tämä varmennuspyyntö käyttäjältä {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sendOnEnter": "Lähetä painamalla rivinvaihtonäppäintä", + "@sendOnEnter": {}, + "badServerVersionsException": "Kotipalvelin tukee Matrix Spec versio(it)a:\n{serverVersions}, mutta tämä sovellus tukee vain versio(it)a {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "Tämä kotipalvelin tukee sisäänkirjautumistapoja: \n{serverVersions},\nmutta tämä sovellus tukee vain -tapoja: \n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Anna porttikielto keskusteluun", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Porttikiellossa", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} antoi porttikiellon käyttäjälle {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Estä laite", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Estetty", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bottien lähettämät viestit", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Peruuta", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Vaihda laitteen nimeä", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} muutti keskustelun kuvaa", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} asetti keskustelun nimeksi: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} asetti näyttönimekseen: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} muutti vieraspääsyn sääntöjä", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} asetti vieraspääsyn säännö(i)ksi: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} muutti historian näkyvyyttä", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} asetti historian näkymissäännöksi: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} muutti liittymissääntöjä", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} asetti liittymissäännöiksi: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} vaihtoi profiilikuvaansa", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} muutti kutsulinkkiä", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Vaihda salasana", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changedTheRoomAliases": "{username} muutti huoneen aliaksia", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "cantOpenUri": "URI-osoitetta {uri} ei voida avata", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} asetti keskustelun kuvaukseksi: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} muutti keskustelun oikeuksia", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeTheme": "Vaihda tyyliäsi", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Keskustelujesi varmuuskopiointi on asetettu.", + "@yourChatBackupHasBeenSetUp": {}, + "chatBackup": "Keskustelun varmuuskopiointi", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Vanhat viestisi on suojattu palautusavaimella. Varmistathan ettet hävitä sitä.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Keskustelun tiedot", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Keskustelu on lisätty tähän tilaan", + "@chatHasBeenAddedToThisSpace": {}, + "chats": "Keskustelut", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Valitse vahva salasana", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Sulje", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_html": "Lähetä HTML-muotoiltua tekstiä", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_ban": "Anna syötetylle käyttäjälle porttikielto tähän huoneeseen", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_invite": "Kutsu syötetty käyttäjä tähän huoneeseen", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_leave": "Poistu tästä huoneesta", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_myroomavatar": "Aseta profiilikuvasi tähän huoneeseen (syöttämällä mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Aseta näyttönimesi vain tässä huoneessa", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Aseta käyttäjän voimataso (oletus: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Lähetä muotoilematonta tekstiä", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Lähetä vastaus reaktiona", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "create": "Luo", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "{username} loi keskustelun", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Uusi tila", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Aktiivinen nyt", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "dateWithoutYear": "{day}.{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithYear": "{day}.{month}.{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Tämä poistaa tunnuksesi käytöstä. Tätä ei voi kumota! Oletko varma?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Uusien käyttäjien oikeuksien oletustaso", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Poista", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Poista tunnus", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Poista viesti", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Laite", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Laite-ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Laitteet", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Suorat keskustelut", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Näyttönimi on vaihdettu", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Lataa tiedosto", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Muokkaa", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Muokkaa estettyjä palvelimia", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Muokkaa näyttönimeä", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Muokkaa huoneen aliaksia", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Muokkaa huoneen profiilikuvaa", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emote on jo olemassa!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Epäkelpo emote-lyhytkoodi!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Huoneen emote-paketit", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emote-asetukset", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Emote-lyhytkoodi", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Emote-lyhytkoodi ja kuva on valittava!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Tyhjä keskustelu", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Et voi poistaa salausta myöhemmin. Oletko varma?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Salaus ei ole käytössä", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} päätti puhelun", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Syötä sähköposti-osoite", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Kotipalvelin", + "@homeserver": {}, + "enterYourHomeserver": "Syötä kotipalvelimesi", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Virhe paikannuksessa: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Kaikki on valmista!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Erittäin loukkaavaa", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Tiedostonimi", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Alkaen liittymisestä", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Alkaen kutsumisesta", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Mene uuteen huoneeseen", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Ryhmä", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Ryhmä on julkinen", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Ryhmät", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Ryhmä seuralaisina {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Vieraat on kielletty", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Vieraat voivat liittyä", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} on perunnut käyttäjän {targetName} kutsun", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Apua", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Piilota poistetut tapahtumat", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Piilota tuntemattomat tapahtumat", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Kuinka loukkaavaa tämä sisältö on?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identiteetti", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Jätä huomioitta", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Huomiotta jätetyt käyttäjät", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Kutsu yhteystieto", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "invited": "Kutsuttu", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} kutsui käyttäjän {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Vain kutsutut käyttäjät", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Kutsu minua varten", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} kutsui sinut FluffyChattiin.\n1. Viereaile sivulla: https://fluffychat.im ja asenna sovellus\n2. Rekisteröidy tai kirjaudu sisään\n3. Avaa kutsulinkki:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "kicked": "👞 {username} potki käyttäjän {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} potki ja antoi porttikiellon käyttäjälle {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Potki keskustelusta", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Aktiivinen viimeksi: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Poistu", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Poistui keskustelusta", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Lisenssi", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Vaalea", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadingPleaseWait": "Ladataan... Hetkinen.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Lataa vielä {count} osallistujaa", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadMore": "Lataa lisää…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Sijaintipalvelut ovat poissa käytöstä. Otathan ne käyttöön jakaaksesi sijaintisi.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "SIjaintioikeus on estetty. Myönnäthän sen jakaaksesi sijaintisi.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Kirjaudu sisään", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Kirjaudu sisään palvelimelle {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Kirjaudu ulos", + "@logout": { + "type": "String", + "placeholders": {} + }, + "mention": "Mainitse", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Viestit", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Valvoja", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Vaienna keskustelu", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "newChat": "Uusi keskustelu", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Uusi viesti FluffyChätissä", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Uusi varmennuspyyntö!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Seuraava", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Ei", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Ei yhteyttä palvelimeen", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Voit ottaa salauksen käyttöön vasta kun huone ei ole julkisesti liityttävissä.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} ei ole Matrix-palvelin, käytetäänkö {server2} sen sijaan?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "scanQrCode": "Skannaa QR-koodi", + "@scanQrCode": {}, + "none": "Ei yhtään", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Et ole vielä lisännyt tapaa salasanasi palauttamiseksi.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Huoneita ei löytynyt…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Ilmoitukset", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} käyttäjää kirjoittavat…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Paikannetaan sijantia…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Loukkaava", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Poissa verkosta", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Linjoilla", + "@online": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Kopioitu leikepöydälle", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopioi", + "@copy": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Vaihda profiilikuvasi", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "chat": "Keskustelu", + "@chat": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Tyhjennä arkisto", + "@clearArchive": {}, + "forward": "Edelleenlähetä", + "@forward": { + "type": "String", + "placeholders": {} + }, + "commandHint_join": "Liity syötettyyn huoneeseen", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_me": "Kuvaile itseäsi", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "compareEmojiMatch": "Vertaa hymiöitä", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Vahvista", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Sisältää käyttäjätunnuksen", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "countParticipants": "{count} osallistujaa", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "changeTheHomeserver": "Vaihda kotipalvelinta", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Vaihda ryhmän nimeä", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Salaus on korruptoitunut", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "commandHint_kick": "Poista syötetty käyttäjä huoneesta", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_unban": "Poista syötetyn käyttäjän porttikielto tästä huoneesta", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandMissing": "{command} ei ole komento.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "commandHint_send": "Lähetä tekstiä", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandInvalid": "Epäkelvollinen komento", + "@commandInvalid": { + "type": "String" + }, + "compareNumbersMatch": "Vertaa numeroita", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Määritä keskustelu", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "connect": "Yhdistä", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Yhteystieto on kutsuttu ryhmään", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Sisältää näyttönimen", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Sisältö on ilmoitettu palvelimen ylläpitäjille", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopioi leikepöydälle", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Viestin salausta ei voitu purkaa: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "encrypted": "Salattu", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Salaus", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Loukkaamatonta", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Kutsu yhteystieto ryhmään {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "isTyping": "kirjoittaa…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Ota emote-paketti käyttöön kaikkialla", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Tumma", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Ota salaus käyttöön", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Fonttikoko", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Olen klikannut linkkiä", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Virheellinen salasana tai palautusavain", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} liittyi keskusteluun", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "notificationsEnabledForThisAccount": "Tämän tunnuksen ilmoitukset ovat käytössä", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "Liity huoneeseen", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Jäsenmuutoksia", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Tiedäthän tarvitsevasi toistaiseksi Pantalaimonin käyttääksesi päästä-päähän-salausta.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Emoteja ei löytynyt. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Firebase Cloud Messaging -palvelu ei vaikuta olevan saatavilla laitteellasi. Saadaksesi push-ilmoituksia silti, suosittelemme Ntfy-sovelluksen asentamista. Käyttämällä Ntfy-sovellusta tai muuta Unified Push -tarjoajaa, saat push-ilmoitukset tietoturvallisella tavalla. Voit ladata Ntfy-sovelluksen Play Kaupasta tai F-Droidista.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Ei lupaa", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "enableMultiAccounts": "(BETA) Ota käyttöön tuki usealle tilille tällä laitteella", + "@enableMultiAccounts": {}, + "onlineKeyBackupEnabled": "Verkkkoavainvarmuuskopio on käytössä", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Hups! Valitettavasti push-ilmoituksia käyttöönotettaessa tapahtui virhe.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Hups, jotakin meni pieleen…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Avaa sovellus lukeaksesi viestit", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Avaa kamera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "Yksi tunnuksistasi on kirjattu ulos", + "@oneClientLoggedOut": {}, + "addAccount": "Lisää tili", + "@addAccount": {}, + "editBundlesForAccount": "Muokkaa tämän tilin kääröjä", + "@editBundlesForAccount": {}, + "addToBundle": "Lisää kääreeseen", + "@addToBundle": {}, + "removeFromBundle": "Poista tästä kääreestä", + "@removeFromBundle": {}, + "bundleName": "Kääreen nimi", + "@bundleName": {}, + "openInMaps": "Avaa kartoissa", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Tai", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Osallistuja", + "@participant": { + "type": "String", + "placeholders": {} + }, + "password": "Salasana", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Salasana on vaihdettu", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Salasanan palautus", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Ihmiset", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Valitse kuva", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Kiinnitä", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Toista {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Valitse", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Valitse pääsykoodi", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Klikkaa linkkiä sähköpostissa ja sitten jatka.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Syötä 4 numeroa tai jätä tyhjäksi poistaaksesi sovelluksen lukituksen.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Syötä PIN-koodisi", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Syötä käyttäjätunnuksesi", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Seuraa ohjeita verkkosivulla ja paina seuraava.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Yksityisyys", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "recording": "Tallenne", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} poisti tapahtuman", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Poista viesti", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Rekisteröidy", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Hylkää", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} hylkäsi kutsun", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Liity uudelleen", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Poista", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Poista kaikki muut laitteet", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Poistanut {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Poista laite", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Poista porttikielto keskusteluun", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Nähnyt {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sendAMessage": "Lähetä viesti", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "send": "Lähetä", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Lähetä tekstinä", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Lähetä ääniviesti", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Lähetä tiedosto", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Lähetä kuva", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Lähetä viestejä", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Lähetä alkuperäinen", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Aseta pääalias", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Aseta mukautetut emotet", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Aseta kutsulinkki", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Aseta oikeustasot", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Aseta tila", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Asetukset", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Jaa", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} jakoi sijaintinsa", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "singlesignon": "Kertakirjautuminen", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Ohita", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Lähdekoodi", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Tila on julkinen", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Tilan nimi", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "status": "Tila", + "@status": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synkronoidaan... Hetkinen.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Järjestelmä", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Ne eivät täsmää", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Ne täsmäävät", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Mykistetty-kytkin", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Liikaa pyyntöjä. Yritä myöhemmin uudelleen!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Merkitse lukemattomaksi/luetuksi", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Siirrä toiselta laitteelta", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Yritä uudelleenlähettämistä", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} poisti käyttäjän {targetName} porttikiellon", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Poista laitteen esto", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Tuntematon laite", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Tuntematon salausalgoritmi", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Tuntematon tapahtuma '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "userAndOthersAreTyping": "{username} ja {count} muuta kirjoittavat…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} ja {username2} kirjoittavat…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} kirjoittaa…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} poistui keskustelusta", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userSentUnknownEvent": "{username} lähetti {type}-tapahtuman", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "unverified": "Varmistamaton", + "@unverified": {}, + "verified": "Varmistettu", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Aloita varmennus", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Varmensit onnistuneesti!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Varmistetaan toista tunnusta", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Keskusteluhistorian näkyvyys", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Näkyy kaikille osallistujille", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Näkyy kaikille", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Ääniviesti", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Odotetaan kumppanin varmistavan pyynnön…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Odotetaan kumppanin hyväksyvän emojit…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Odotetaan kumppanin hyväksyvän numerot…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Taustakuva:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Varoitus!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Lähetimme sinulle sähköpostia", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Kuka voi suorittaa minkä toimenpiteen", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Kenen on sallittua liittyä ryhmään", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Miksi haluat ilmoittaa tämän?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Pyyhi keskusteluvarmuuskopio luodaksesi uuden palautusavaimen?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Näillä osoitteilla voit palauttaa salasanasi.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Et enää osallistu tähän keskusteluun", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Sinulle on annettu porttikielto tähän keskusteluun", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "removeFromSpace": "Poista tilasta", + "@removeFromSpace": {}, + "addToSpaceDescription": "Valitse tila, johon tämä keskustelu lisätään.", + "@addToSpaceDescription": {}, + "start": "Aloita", + "@start": {}, + "serverRequiresEmail": "Tämän palvelimen täytyy tarkistaa sähköposti-osoitteesi rekisteröitymistä varten.", + "@serverRequiresEmail": {}, + "roomVersion": "Huoneen versio", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "sentCallInformations": "{senderName} lähetti puhelutiedot", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "unavailable": "Ei saatavilla", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "verify": "Varmista", + "@verify": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "salalause tai palautusavain", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Syötä salasanasi", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Huone on päivitetty", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "search": "Hae", + "@search": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} lähetti tiedoston", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} lähetti ääniviestin", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "link": "Linkki", + "@link": {}, + "passwordForgotten": "Salasana unohtunut", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Poista profiilikuvasi", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "reply": "Vastaa", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Ilmoita viesti", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Pyydä lupaa", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Tallenna tiedosto", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "security": "Turvallisuus", + "@security": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Lähetä tarra", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Julkiset huoneet", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Push-säännöt", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Syy", + "@reason": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Korvaa huone uudemmalla versiolla", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Lähetä video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAPicture": "🖼️ {username} lähetti kuvan", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} lähetti tarran", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} lähetti videon", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Jaa sijainti", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Näytä salasana", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Millainen on vointisi?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 lukematon keskustelu} other{{unreadCount} lukematonta keskustelua}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "videoCall": "Videopuhelu", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "sender": "Lähettäjä", + "@sender": {}, + "startedACall": "{senderName} aloitti puhelun", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "submit": "Lähetä", + "@submit": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Suosikki-kytkin", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "unmuteChat": "Poista keskustelun mykistys", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Poista kiinnitys", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "time": "Aika", + "@time": {}, + "messageType": "Viestin tyyppi", + "@messageType": {}, + "username": "Käyttäjätunnus", + "@username": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Kirjoita viesti…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Kyllä", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Sinä", + "@you": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Julkinen avaimesi", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Viestin tiedot", + "@messageInfo": {}, + "openGallery": "Avaa galleria", + "@openGallery": {}, + "commandHint_clearcache": "Tyhjennä välimuisti", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Luo tyhjä ryhmäkeskustelu\nKäytä parametria --no-encryption poistaaksesi salauksen käytöstä", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_dm": "Aloita yksityiskeskustelu\nKäytä parametria --no-encryption poistaaksesi salauksen käytöstä", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_discardsession": "Hylkää istunto", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "openVideoCamera": "Avaa kamera videokuvausta varten", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "publish": "Julkaise", + "@publish": {}, + "markAsRead": "Merkitse luetuksi", + "@markAsRead": {}, + "dismiss": "Hylkää", + "@dismiss": {}, + "emojis": "Hymiöt", + "@emojis": {}, + "unsupportedAndroidVersionLong": "Tämä ominaisuus vaatii uudemman Android-version. Tarkistathan päivitykset tai Lineage OS :n tuki.", + "@unsupportedAndroidVersionLong": {}, + "unsupportedAndroidVersion": "Ei tuettu Android-versio", + "@unsupportedAndroidVersion": {}, + "reportUser": "Ilmianna käyttäjä", + "@reportUser": {}, + "voiceCall": "Äänipuhelu", + "@voiceCall": {}, + "videoCallsBetaWarning": "Huomaathan videopuheluiden ovan beta-asteella. Ne eivät ehkä toimi odotetusti tai toimi ollenkaan kaikilla alustoilla.", + "@videoCallsBetaWarning": {}, + "placeCall": "Soita", + "@placeCall": {}, + "reactedWith": "{sender} reagoi {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "openChat": "Avaa Keskustelu", + "@openChat": {}, + "pinMessage": "Kiinnitä huoneeseen", + "@pinMessage": {}, + "confirmEventUnpin": "Haluatko varmasti irrottaa tapahtuman pysyvästi?", + "@confirmEventUnpin": {}, + "widgetVideo": "Video", + "@widgetVideo": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "widgetCustom": "Mukautettu", + "@widgetCustom": {}, + "widgetName": "Nimi", + "@widgetName": {}, + "widgetUrlError": "Epäkelvollinen URL.", + "@widgetUrlError": {}, + "errorAddingWidget": "Virhe lisättäessä pienoissovellusta.", + "@errorAddingWidget": {}, + "nextAccount": "Seuraava tili", + "@nextAccount": {}, + "switchToAccount": "Siirry tilille {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "experimentalVideoCalls": "Kokeelliset videopuhelut", + "@experimentalVideoCalls": {}, + "emailOrUsername": "Sähköposti-osoite tai käyttäjätunnus", + "@emailOrUsername": {}, + "previousAccount": "Edellinen tili", + "@previousAccount": {}, + "widgetEtherpad": "Tekstimuotoinen muistiinpano", + "@widgetEtherpad": {}, + "widgetNameError": "Syötä näyttönimi.", + "@widgetNameError": {}, + "addWidget": "Lisää pienoissovellus", + "@addWidget": {}, + "youRejectedTheInvitation": "Kieltäydyit kutsusta", + "@youRejectedTheInvitation": {}, + "youJoinedTheChat": "Liityit keskusteluun", + "@youJoinedTheChat": {}, + "youAcceptedTheInvitation": "👍 Hyväksyit kutsun", + "@youAcceptedTheInvitation": {}, + "youBannedUser": "Annoit porttikiellon käyttäjälle {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Olet perunut kutsun käyttäjälle {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 {user} kutsui sinut", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Potkit käyttäjän {user} keskustelusta", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Kutsuit käyttäjän {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Potkit ja annoit porttikiellon käyttäjälle {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Poistit käyttäjän {user} porttikiellon", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "separateChatTypes": "Erota yksityiskeskustelut ryhmistä", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "dehydrateTor": "TOR-käyttäjät: vie istunto", + "@dehydrateTor": {}, + "hydrateTor": "TOR-käyttäjät: tuo viety istunto", + "@hydrateTor": {}, + "hydrateTorLong": "Veitkö edellisen istuntosi käyttäessäsi TORia? Tuo se nopeasti ja jatka jutustelua.", + "@hydrateTorLong": {}, + "pleaseEnterRecoveryKey": "Syötä palautusavaimesi:", + "@pleaseEnterRecoveryKey": {}, + "recoveryKey": "Palautusavain", + "@recoveryKey": {}, + "recoveryKeyLost": "Kadonnut palautusavain?", + "@recoveryKeyLost": {}, + "dehydrateTorLong": "Tor-käyttäjille suositellaan istunnon vientiä ennen ikkunan sulkemista.", + "@dehydrateTorLong": {}, + "hydrate": "Palauta varmuuskopiotiedostosta", + "@hydrate": {}, + "dehydrate": "Vie istunto ja tyhjennä laite", + "@dehydrate": {}, + "dehydrateWarning": "Tätä toimenpidettä ei voi kumota. Varmista varmuuskopiotiedoston turvallinen tallennus.", + "@dehydrateWarning": {}, + "users": "Käyttäjät", + "@users": {}, + "storeSecurlyOnThisDevice": "Tallenna turvallisesti tälle laitteelle", + "@storeSecurlyOnThisDevice": {}, + "pleaseEnterRecoveryKeyDescription": "Avataksesi vanhojen viestiesi salauksen, syötä palautusavaimesi, joka luotiin edellisessä istunnossa. Palautusavaimesi EI OLE salasanasi.", + "@pleaseEnterRecoveryKeyDescription": {}, + "unlockOldMessages": "Pura vanhojen viestien salaus", + "@unlockOldMessages": {}, + "indexedDbErrorLong": "Viestivarasto ei ole käytössä yksityisselauksessa oletuksena.\nKäythän osoitteessa\n - about:config\n - Aseta dom.indexedDB.privateBrowsing.enabled arvoon true\nMuuten FluffyChatin käyttäminen ei ole mahdollista.", + "@indexedDbErrorLong": {}, + "saveKeyManuallyDescription": "Tallenna tämä avain manuaalisesti käyttäen järjestelmän jakodialogia tai leikepöytää.", + "@saveKeyManuallyDescription": {}, + "storeInAndroidKeystore": "Tallenna Android KeyStoreen", + "@storeInAndroidKeystore": {}, + "storeInAppleKeyChain": "Tallenna Applen avainnippuun", + "@storeInAppleKeyChain": {}, + "countFiles": "{count} tiedostoa", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "storeInSecureStorageDescription": "Tallenna palautusavain tämän laitteen turvavarastoon.", + "@storeInSecureStorageDescription": {}, + "indexedDbErrorTitle": "Yksityisen selauksen ongelmat", + "@indexedDbErrorTitle": {}, + "user": "Käyttäjä", + "@user": {}, + "custom": "Mukautettu", + "@custom": {}, + "confirmMatrixId": "Kirjoita Matrix IDsi uudelleen poistaaksesi tunnuksesi.", + "@confirmMatrixId": {}, + "supposedMxid": "Tämän pitäisi olla {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "Merkitse ryhmäksi", + "@commandHint_markasgroup": {}, + "whyIsThisMessageEncrypted": "Miksei tätä viestiä voida lukea?", + "@whyIsThisMessageEncrypted": {}, + "noKeyForThisMessage": "Tämä voi tapahtua mikäli viesti lähetettiin ennen sisäänkirjautumistasi tälle laitteelle.\n\nOn myös mahdollista, että lähettäjä on estänyt tämän laitteen tai jokin meni pieleen verkkoyhteyden kanssa.\n\nPystytkö lukemaan viestin toisella istunnolla? Siinä tapauksessa voit siirtää viestin siltä! Mene Asetukset > Laitteet ja varmista, että laitteesi ovat varmistaneet toisensa. Seuraavankerran avatessasi huoneen ja molempien istuntojen ollessa etualalla, avaimet siirretään automaattisesti.\n\nHaluatko varmistaa ettet menetä avaimia uloskirjautuessa tai laitteita vaihtaessa? Varmista avainvarmuuskopion käytössäolo asetuksista.", + "@noKeyForThisMessage": {}, + "commandHint_markasdm": "Merkitse yksityiskeskusteluksi syötetyn Matrix IDn kanssa", + "@commandHint_markasdm": {}, + "foregroundServiceRunning": "Tämä ilmoitus näkyy etualapalvelun ollessa käynnissä.", + "@foregroundServiceRunning": {}, + "callingPermissions": "Puheluoikeudet", + "@callingPermissions": {}, + "callingAccount": "Soittamistunnus", + "@callingAccount": {}, + "callingAccountDetails": "Sallii FluffyChatin käyttää Androidin omaa Puhelut-sovellusta.", + "@callingAccountDetails": {}, + "appearOnTop": "Näy päällä", + "@appearOnTop": {}, + "appearOnTopDetails": "Sallii sovelluksen näkyä muiden sovellusten päällä (tätä ei tarvita, mikäli olet jo määrittänyt FluffyChatin puhelin-tunnukseksi)", + "@appearOnTopDetails": {}, + "newSpace": "Uusi tila", + "@newSpace": {}, + "enterSpace": "Siirry tilaan", + "@enterSpace": {}, + "enterRoom": "Siirry huoneeseen", + "@enterRoom": {}, + "allSpaces": "Kaikki tilat", + "@allSpaces": {}, + "screenSharingTitle": "ruudunjako", + "@screenSharingTitle": {}, + "otherCallingPermissions": "Mikrofoni, kamera ja muut FluffyChatin oikeudet", + "@otherCallingPermissions": {}, + "newGroup": "Uusi ryhmä", + "@newGroup": {}, + "screenSharingDetail": "Jaat ruutuasi FluffyChatissä", + "@screenSharingDetail": {}, + "hugContent": "{senderName} halaa sinua", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} kokovartalohalaa sinua", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_hug": "Lähetä halaus", + "@commandHint_hug": {}, + "googlyEyesContent": "{senderName} lähettää askartelusilmiä", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "numChats": "{number} keskustelua", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "commandHint_googly": "Lähetä askartelusilmiä", + "@commandHint_googly": {}, + "commandHint_cuddle": "Lähetä kokovartaluhalaus", + "@commandHint_cuddle": {}, + "hideUnimportantStateEvents": "Piilota ei-niin-tärkeät tilatapahtumat", + "@hideUnimportantStateEvents": {}, + "doNotShowAgain": "Älä näytä uudelleen", + "@doNotShowAgain": {}, + "fileHasBeenSavedAt": "Tiedosto on tallennettu sijaintiin {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "disableEncryptionWarning": "Turvallisuuden vuoksi et voi poistaa salausta käytöstä huoneista, joissa se on aiemmin otettu käyttöön.", + "@disableEncryptionWarning": {}, + "allRooms": "Kaikki ryhmäkeskustelut", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "startFirstChat": "Aloita ensimmäinen keskustelusi", + "@startFirstChat": {}, + "newSpaceDescription": "Tilat mahdollistavat keskusteluidesi keräämisen ja yksityisten tai julkisten yhteisöjen rakentamisen.", + "@newSpaceDescription": {}, + "deviceKeys": "Laite-avaimet:", + "@deviceKeys": {}, + "reopenChat": "Avaa keskustelu uudelleen", + "@reopenChat": {}, + "noOtherDevicesFound": "Muita laitteita ei löytynyt", + "@noOtherDevicesFound": {}, + "jumpToLastReadMessage": "Hyppää viimeiseen luettuun viestiin", + "@jumpToLastReadMessage": {}, + "readUpToHere": "Luettu tähän asti", + "@readUpToHere": {}, + "jump": "Hyppää", + "@jump": {}, + "openLinkInBrowser": "Avaa linkki selaimessa", + "@openLinkInBrowser": {}, + "report": "ilmoita", + "@report": {}, + "encryptThisChat": "Salaa tämä keskustelu", + "@encryptThisChat": {}, + "noBackupWarning": "Varoitus! Ilman avainvarmuuskopion käyttöönottoa menetät pääsyn salattuihin viesteihisi. Suosittelemme ehdottomasti avainvarmuuskopion käyttöönottoa ennen uloskirjautumista.", + "@noBackupWarning": {}, + "fileIsTooBigForServer": "Ei voi lähettää! Palvelin tukee liitetiedostoja vain enintään {max}.", + "@fileIsTooBigForServer": {}, + "reportErrorDescription": "😭 Voi ei. Jokin meni pieleen. Halutessasi voit ilmoittaa ongelman kehittäjille.", + "@reportErrorDescription": {}, + "wasDirectChatDisplayName": "Tyhjä keskustelu (oli {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "sorryThatsNotPossible": "Anteeksi... se ei ole mahdollista", + "@sorryThatsNotPossible": {}, + "signInWithPassword": "Kirjaudu sisään salasanalla", + "@signInWithPassword": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "Yritä myöhemmin uudelleen tai valitse toinen palvelin.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "setColorTheme": "Aseta väriteema:", + "@setColorTheme": {}, + "tryAgain": "Yritä uudelleen", + "@tryAgain": {}, + "messagesStyle": "Viestit:", + "@messagesStyle": {}, + "chatDescription": "Keskustelun kuvaus", + "@chatDescription": {}, + "invalidServerName": "Virheellinen palvelimen nimi", + "@invalidServerName": {}, + "chatPermissions": "Keskustelun oikeudet", + "@chatPermissions": {}, + "setChatDescription": "Asetti keskustelun kuvauksen", + "@setChatDescription": {}, + "importFromZipFile": "Tuo .zip -tiedostosta", + "@importFromZipFile": {}, + "redactedBy": "Poistanut {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "signInWith": "Kirjaudu sisään palvelulla {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Vapaaehtoinen) Syy tämän viestin poistamiselle...", + "@optionalRedactReason": {}, + "archiveRoomDescription": "Keskustelu siirretään arkistoon. Muut käyttäjät näkevät sinun poistuneen keskustelusta.", + "@archiveRoomDescription": {}, + "exportEmotePack": "Vie emotepaketti .zip-tiedostona", + "@exportEmotePack": {}, + "inviteContactToGroupQuestion": "Tahdotko kutsua yhteystiedon {contact} keskusteluun \"{groupName}\"?", + "@inviteContactToGroupQuestion": {}, + "redactedByBecause": "Poistanut {username} syystä: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactMessageDescription": "Viesti poistetaan kaikilta keskustelun osallistujilta. Tätä ei voida kumota.", + "@redactMessageDescription": {}, + "invalidInput": "Virheellinen syöte!", + "@invalidInput": {}, + "addChatDescription": "Lisää keskustelulle kuvaus...", + "@addChatDescription": {}, + "hasKnocked": "🚪 {user} on koputtanut", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "directChat": "Yksityiskeskustelu", + "@directChat": {}, + "wrongPinEntered": "Väärä pin-koodi! Yritä uudelleen {seconds} sekuntin kuluttua...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "Lähetä kirjoitusilmoituksia", + "@sendTypingNotifications": {}, + "inviteGroupChat": "📨 Kutsu ryhmäkeskusteluun", + "@inviteGroupChat": {}, + "invitePrivateChat": "📨 Kutsu yksityiskeskusteluun", + "@invitePrivateChat": {}, + "importEmojis": "Tuo emojit", + "@importEmojis": {}, + "noChatDescriptionYet": "Keskustelun kuvausta ei ole vielä luotu.", + "@noChatDescriptionYet": {}, + "notAnImage": "Tämä ei ole kuvatiedosto.", + "@notAnImage": {}, + "chatDescriptionHasBeenChanged": "Keskustelun kuvaus muutettu", + "@chatDescriptionHasBeenChanged": {}, + "roomUpgradeDescription": "Keskustelu luodaan uudelleen uudella huoneversiolla. Kaikille osallistujille ilmoitetaan, että heidän tulee siirtyä uuteen keskusteluun. Voit lukea lisää huoneversioista osoitteesta https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "pleaseEnterANumber": "Syötä suurempi luku kuin 0", + "@pleaseEnterANumber": {}, + "profileNotFound": "Käyttäjää ei löydy palvelimelta. Tämä voi olla yhteysongelma tai käyttäjä ei ole olemassa.", + "@profileNotFound": {}, + "shareInviteLink": "Jaa kutsulinkki", + "@shareInviteLink": {}, + "emoteKeyboardNoRecents": "Viimeaikoina käytetyt emotet tulevat näkymään täällä...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Aseta teema:", + "@setTheme": {}, + "replace": "Korvaa", + "@replace": {}, + "createGroup": "Luo ryhmä", + "@createGroup": {}, + "importNow": "Tuo nyt", + "@importNow": {}, + "invite": "Kutsu", + "@invite": {}, + "swipeRightToLeftToReply": "Vastaa pyyhkäisemällä oikealta vasemmalle", + "@swipeRightToLeftToReply": {}, + "accessAndVisibility": "Pääsy ja näkyvyys", + "@accessAndVisibility": {}, + "unread": "Lukemattomat", + "@unread": {}, + "noMoreChatsFound": "Lisää keskusteluja ei löytynyt...", + "@noMoreChatsFound": {}, + "alwaysUse24HourFormat": "väärä", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "select": "Valitse", + "@select": {}, + "searchForUsers": "Etsi @users...", + "@searchForUsers": {}, + "pleaseEnterYourCurrentPassword": "Anna nykyinen salasanasi", + "@pleaseEnterYourCurrentPassword": {}, + "newPassword": "Uusi salasana", + "@newPassword": {}, + "pleaseChooseAStrongPassword": "Valitse vahva salasana", + "@pleaseChooseAStrongPassword": {}, + "passwordsDoNotMatch": "Salasanat eivät täsmää", + "@passwordsDoNotMatch": {}, + "passwordIsWrong": "Salasanasi on väärä", + "@passwordIsWrong": {}, + "thisDevice": "Tämä laite:", + "@thisDevice": {}, + "gallery": "Galleria", + "@gallery": {}, + "files": "Tiedostot", + "@files": {}, + "changelog": "Muutosloki", + "@changelog": {}, + "continueText": "Jatka", + "@continueText": {}, + "welcomeText": "Hei 👋, Tämä on FluffyChat. Voit kirjautua sisään mihin tahansa kotipalvelimeen, joka on yhteensopiva https:/matrix.org:in kanssa. Sitten jutellaan kenen kanssa tahansa. Se on hajautettu viestiverkosto!", + "@welcomeText": {}, + "serverInformation": "Palvelimen tiedot:", + "@serverInformation": {}, + "name": "Nimi", + "@name": {}, + "version": "Versio", + "@version": {}, + "website": "Verkkosivu", + "@website": {}, + "previous": "Edellinen", + "@previous": {}, + "open": "Avaa", + "@open": {}, + "more": "Lisää", + "@more": {}, + "allDevices": "Kaikki laitteet", + "@allDevices": {}, + "recordAVideo": "Nauhoita video", + "@recordAVideo": {}, + "approve": "Hyväksy", + "@approve": {}, + "pause": "Keskeytä", + "@pause": {}, + "resume": "Jatka", + "@resume": {}, + "moveUp": "Siirrä ylös", + "@moveUp": {}, + "moveDown": "Siirrä alas", + "@moveDown": {}, + "poll": "Kysely", + "@poll": {}, + "setCustomPermissionLevel": "Aseta mukautettu lupataso", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Valitse alla oleva ennalta määritetty rooli tai anna mukautettu lupataso väliltä 0–100.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Jätä huomiotta", + "@ignoreUser": {}, + "normalUser": "Peruskäyttäjä", + "@normalUser": {}, + "aboutHomeserver": "Tietoja {homeserver}:sta", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "commandHint_roomupgrade": "Päivitä tämä huone annettuun huoneversioon", + "@commandHint_roomupgrade": {}, + "appLockDescription": "Lukitse sovellus kun sitä ei käytetä PIN-koodin kanssa", + "@appLockDescription": {}, + "countChatsAndCountParticipants": "{chats} pikakeskustelut ja {participants} osallistujat", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noChatsFoundHere": "Täältä ei löytynyt vielä pikakeskusteluja. Aloita uusi pikakeskustelu jonkun kanssa alla olevalla painikkeella. ⤵️", + "@noChatsFoundHere": {}, + "joinedChats": "Liittyneet pikakeskustelut", + "@joinedChats": {}, + "space": "Tila", + "@space": {}, + "spaces": "Tilat", + "@spaces": {}, + "checkList": "Tarkistuslista", + "@checkList": {}, + "countInvited": "{count} kutsuttu", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "globalChatId": "Yleisesti pätevä keskustelutunnus", + "@globalChatId": {}, + "accessAndVisibilityDescription": "Kuka voi liittyä tähän pikakeskusteluun ja miten pikakeskustelun voi löytää.", + "@accessAndVisibilityDescription": {}, + "calls": "Puhelut", + "@calls": {}, + "customEmojisAndStickers": "Mukautetut emojit ja tarrat", + "@customEmojisAndStickers": {}, + "customEmojisAndStickersBody": "Lisää tai jaa mukautettuja emojeja tai tarroja, joita voidaan käyttää missä tahansa pikakeskustelussa.", + "@customEmojisAndStickersBody": {}, + "hideInvalidOrUnknownMessageFormats": "Piilota virheelliset tai tuntemattomat viestimuodot", + "@hideInvalidOrUnknownMessageFormats": {}, + "block": "Estä", + "@block": {}, + "blockedUsers": "Estetyt käyttäjät", + "@blockedUsers": {}, + "blockListDescription": "Voit estää sinua häiritsevät käyttäjät. Et voi vastaanottaa viestejä tai huonekutsuja henkilökohtaisella estolistallasi olevilta käyttäjiltä.", + "@blockListDescription": {}, + "hideMemberChangesInPublicChats": "Piilota jäsenten muutokset julkisissa pikakeskusteluissa", + "@hideMemberChangesInPublicChats": {}, + "hideMemberChangesInPublicChatsBody": "Älä näytä pikakeskustelun aikajanalla, jos joku liittyy julkiseen pikakeskusteluun tai poistuu siitä luettavuuden parantamiseksi.", + "@hideMemberChangesInPublicChatsBody": {}, + "blockUsername": "Jätä käyttäjänimi huomiotta", + "@blockUsername": {}, + "overview": "Yleiskatsaus", + "@overview": {}, + "notifyMeFor": "Ilmoita minulle", + "@notifyMeFor": {}, + "passwordRecoverySettings": "Salasanan palautusasetukset", + "@passwordRecoverySettings": {}, + "sendImages": "Lähetä {count} kuva", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "presenceStyle": "Läsnäolo:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Näytä muiden käyttäjien tilaviestit", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWaitCounter": " Synkronoidaan… ({percentage} %)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Sinut on kutsuttu linkin kautta kohteeseen:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "invitedBy": "📩 Kutsujana {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Käyttäjien on koputettava", + "@usersMustKnock": {}, + "noOneCanJoin": "Kukaan ei voi liittyä", + "@noOneCanJoin": {}, + "userWouldLikeToChangeTheChat": "{user} haluaa liittyä pikakeskusteluun.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Julkista linkkiä ei ole vielä luotu", + "@noPublicLinkHasBeenCreatedYet": {}, + "knock": "Koputa", + "@knock": {}, + "hidePresences": "Piilotetaanko tilaluettelo?", + "@hidePresences": {}, + "removeDevicesDescription": "Sinut kirjataan ulos tästä laitteesta, etkä voi enää vastaanottaa viestejä.", + "@removeDevicesDescription": {}, + "banUserDescription": "Käyttäjä kielletään pikakeskustelusta, eikä hän voi liittyä pikakeskusteluun uudelleen ennen kuin kielto kumotetaan.", + "@banUserDescription": {}, + "unbanUserDescription": "Käyttäjä voi liittyä pikakeskusteluun uudelleen, jos hän yrittää.", + "@unbanUserDescription": {}, + "kickUserDescription": "Käyttäjä potkitaan ulos pikakeskustelusta, mutta häntä ei porttikieltoa saada. Julkisissa pikakeskusteluissa käyttäjä voi liittyä takaisin milloin tahansa.", + "@kickUserDescription": {}, + "makeAdminDescription": "Kun olet tehnyt tästä käyttäjästä järjestelmänvalvojan, et ehkä voi perua tätä, koska hänellä on siitä hetkestä lähtien samat oikeudet kuin sinulla.", + "@makeAdminDescription": {}, + "pushNotificationsNotAvailable": "Työntöilmoitukset ei saatavilla", + "@pushNotificationsNotAvailable": {}, + "learnMore": "Opi lisää", + "@learnMore": {}, + "yourGlobalUserIdIs": "Yleisesti pätevä käyttäjätunnuksesi on: ", + "@yourGlobalUserIdIs": {}, + "noUsersFoundWithQuery": "Valitettavasti käyttäjää ei löytynyt haulla \"{query}\". Tarkistathan, onko kirjoitusvirhe.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "knocking": "Koputetaan", + "@knocking": {}, + "chatCanBeDiscoveredViaSearchOnServer": "Pikakeskustelu löytyy haulla {server}:lta", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchChatsRooms": "Hae #pikakeskustelut, @käyttäjät...", + "@searchChatsRooms": {}, + "nothingFound": "Mitään ei löytynyt...", + "@nothingFound": {}, + "groupName": "Ryhmän nimi", + "@groupName": {}, + "createGroupAndInviteUsers": "Luo ryhmä ja kutsu käyttäjiä", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "Ryhmä löytyy haun kautta", + "@groupCanBeFoundViaSearch": {}, + "wrongRecoveryKey": "Pahoittelut... tämä ei vaikuta olevan oikea palautusavain.", + "@wrongRecoveryKey": {}, + "startConversation": "Aloita keskustelu", + "@startConversation": {}, + "commandHint_sendraw": "Lähetä raaka JSON", + "@commandHint_sendraw": {}, + "databaseMigrationTitle": "Tietokanta on optimoitu", + "@databaseMigrationTitle": {}, + "databaseMigrationBody": "Odotathan hetki. Tämä voi kestää hetken.", + "@databaseMigrationBody": {}, + "leaveEmptyToClearStatus": "Jätä tyhjäksi tyhjentääksesi tilasi.", + "@leaveEmptyToClearStatus": {}, + "publicLink": "Julkinen linkki", + "@publicLink": {}, + "publicChatAddresses": "Julkiset keskusteluosoitteet", + "@publicChatAddresses": {}, + "createNewAddress": "Luo uusi osoite", + "@createNewAddress": {}, + "joinSpace": "Liity tilaan", + "@joinSpace": {}, + "publicSpaces": "Julkiset tilat", + "@publicSpaces": {}, + "addChatOrSubSpace": "Lisää pikakeskustelu tai alitila", + "@addChatOrSubSpace": {}, + "subspace": "Alitila", + "@subspace": {}, + "decline": "Hylkää", + "@decline": {}, + "initAppError": "Sovelluksen alustamisessa tapahtui virhe", + "@initAppError": {}, + "userRole": "Käyttäjärooli", + "@userRole": {}, + "minimumPowerLevel": "{level} on pienin tehotaso.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "Hae keskustelusta \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Hae lisää...", + "@searchMore": {}, + "databaseBuildErrorBody": "SQlite-tietokantaa ei voida rakentaa. Sovellus yrittää toistaiseksi käyttää vanhaa tietokantaa. Ilmoita tästä virheestä kehittäjille osoitteessa {url}. Virheviesti on: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Istuntosi on menetetty. Ilmoita tästä virheestä kehittäjille osoitteessa {url}. Virheviesti on: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Sovellus yrittää nyt palauttaa istuntosi varmuuskopiosta. Ilmoita tästä virheestä kehittäjille osoitteessa {url}. Virheviesti on: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Lähetätkö viestin edelleen kohteeseen {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Lähetä lukukuittaukset", + "@sendReadReceipts": {}, + "sendTypingNotificationsDescription": "Muut keskustelun osallistujat näkevät, milloin olet kirjoittamassa uutta viestiä.", + "@sendTypingNotificationsDescription": {}, + "sendReadReceiptsDescription": "Muut keskustelun osallistujat näkevät, milloin olet lukenut viestin.", + "@sendReadReceiptsDescription": {}, + "formattedMessages": "Muotoillut viestit", + "@formattedMessages": {}, + "formattedMessagesDescription": "Näytä rikasta viestisisältöä, kuten lihavoitua tekstiä, käyttämällä Markdownia.", + "@formattedMessagesDescription": {}, + "verifyOtherUser": "🔐 Vahvista toinen käyttäjä", + "@verifyOtherUser": {}, + "verifyOtherUserDescription": "Jos vahvistat toisen käyttäjän, voit olla varma, että tiedät kenelle todella kirjoitat. 💪\n\nKun aloitat vahvistuksen, sinä ja toinen käyttäjä näette sovelluksessa ponnahdusikkunan. Siellä näette sitten sarjan emojeja tai numeroita, joita teidän on verrattava toisiinsa.\n\nParas tapa tehdä tämä on tavata heidät tai aloittaa videopuhelu. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDevice": "🔐 Vahvista toinen laite", + "@verifyOtherDevice": {}, + "verifyOtherDeviceDescription": "Kun vahvistat toisen laitteen, kyseiset laitteet voivat vaihtaa avaimia, mikä lisää yleistä turvallisuuttasi. 💪 Kun aloitat vahvistuksen, molempien laitteiden sovellukseen ilmestyy ponnahdusikkuna. Siellä näet sitten sarjan emojeja tai numeroita, joita sinun on verrattava toisiinsa. On parasta pitää molemmat laitteet käsillä ennen vahvistuksen aloittamista. 🤳", + "@verifyOtherDeviceDescription": {}, + "acceptedKeyVerification": "{sender} hyväksyi avaimen vahvistuksen", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} peruutti avaimen vahvistuksen", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} suoritti avaimen vahvistuksen", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} on valmis avaimen vahvistukseen", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} pyysi avaimen vahvistusta", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} aloitti avaimen vahvistuksen", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Läpinäkyvä", + "@transparent": {}, + "incomingMessages": "Saapuvat viestit", + "@incomingMessages": {}, + "stickers": "Tarrat", + "@stickers": {}, + "discover": "Tutustu", + "@discover": {}, + "commandHint_ignore": "Jätä huomiotta annettu matrix-tunnus", + "@commandHint_ignore": {}, + "commandHint_unignore": "Kumoa annetun matrix-tunnuksen huomiottajätäminen", + "@commandHint_unignore": {}, + "unreadChatsInApp": "{appname}: {unread} lukematonta keskustelua", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Tietokannan salausta ei tueta tällä alustalla", + "@noDatabaseEncryption": {}, + "thereAreCountUsersBlocked": "Tällä hetkellä {count} käyttäjää on estetty.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "Rajoitettu", + "@restricted": {}, + "knockRestricted": "Koputus rajoitettu", + "@knockRestricted": {}, + "goToSpace": "Siirry tilaan: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Merkitse lukemattomaksi", + "@markAsUnread": {}, + "userLevel": "{level} - Käyttäjä", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Valvoja", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Järjestelmänvalvoja", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Muuta yleisiä keskusteluasetuksia", + "@changeGeneralChatSettings": {}, + "inviteOtherUsers": "Kutsu muita käyttäjiä tähän pikakeskusteluun", + "@inviteOtherUsers": {}, + "changeTheChatPermissions": "Muuta keskustelulupia", + "@changeTheChatPermissions": {}, + "changeTheVisibilityOfChatHistory": "Muuta pikakeskusteluhistorian näkyvyyttä", + "@changeTheVisibilityOfChatHistory": {}, + "changeTheCanonicalRoomAlias": "Vaihda julkisen pikakeskustelun pääosoite", + "@changeTheCanonicalRoomAlias": {}, + "sendRoomNotifications": "Lähetä @room-ilmoituksia", + "@sendRoomNotifications": {}, + "changeTheDescriptionOfTheGroup": "Muuta keskustelun kuvausta", + "@changeTheDescriptionOfTheGroup": {}, + "chatPermissionsDescription": "Määritä tarvittava tehotaso tietyille toiminnoille tässä pikakeskustelussa. Tehotasot 0, 50 ja 100 edustavat yleensä käyttäjiä, valvoja ja ylläpitäjiä, mutta mikä tahansa porrastus on mahdollinen.", + "@chatPermissionsDescription": {}, + "updateInstalled": "🎉 Päivitys {version} asennettu!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "sendCanceled": "Lähetys peruttu", + "@sendCanceled": {}, + "loginWithMatrixId": "Kirjaudu sisään Matrix-tunnuksella", + "@loginWithMatrixId": {}, + "discoverHomeservers": "Tutustu kotipalvelimiin", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "Mikä on kotipalvelin?", + "@whatIsAHomeserver": {}, + "homeserverDescription": "Kaikki tietosi tallennetaan kotipalvelimelle, aivan kuten sähköpostipalveluntarjoaja. Voit valita, mitä kotipalvelinta haluat käyttää, ja silti kommunikoida kaikkien kanssa. Lisätietoja osoitteessa https://matrix.org.", + "@homeserverDescription": {}, + "doesNotSeemToBeAValidHomeserver": "Ei näytä olevan yhteensopiva kotipalvelin. Väärä URL-osoite?", + "@doesNotSeemToBeAValidHomeserver": {}, + "calculatingFileSize": "Lasketaan tiedoston kokoa...", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "Valmistele lähetettävä liite...", + "@prepareSendingAttachment": {}, + "sendingAttachment": "Lähetetään liitettä...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "Videon pikkukuvan luominen...", + "@generatingVideoThumbnail": {}, + "compressVideo": "Pakataan videota...", + "@compressVideo": {}, + "sendingAttachmentCountOfCount": "Lähetetään {length} pituista liitettä {index}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Palvelinraja saavutettu! Odotetaan {seconds} sekuntia...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Yhtä laitteistasi ei ole vahvistettu", + "@oneOfYourDevicesIsNotVerified": {}, + "noticeChatBackupDeviceVerification": "Huomautus: Kun yhdistät kaikki laitteesi keskustelun varmuuskopiointiin, ne vahvistetaan automaattisesti.", + "@noticeChatBackupDeviceVerification": {}, + "blur": "Sumeus:", + "@blur": {}, + "opacity": "Läpinäkymättömyys:", + "@opacity": {}, + "setWallpaper": "Aseta taustakuva", + "@setWallpaper": {}, + "manageAccount": "Hallinnoi tiliä", + "@manageAccount": {}, + "noContactInformationProvided": "Palvelin ei ilmoittaa mitään kelvollisia yhteystietoja", + "@noContactInformationProvided": {}, + "contactServerAdmin": "Ota yhteyttä palvelimen ylläpitäjään", + "@contactServerAdmin": {}, + "contactServerSecurity": "Ota yhteyttä palvelimen tietoturvaosastoon", + "@contactServerSecurity": {}, + "supportPage": "Tukisivu", + "@supportPage": {}, + "compress": "Pakkaa", + "@compress": {}, + "boldText": "Lihavoitu teksti", + "@boldText": {}, + "italicText": "Kursivoitu teksti", + "@italicText": {}, + "strikeThrough": "Yliviivaus", + "@strikeThrough": {}, + "pleaseFillOut": "Ole hyvä ja täytä", + "@pleaseFillOut": {}, + "invalidUrl": "Virheellinen URL-osoite", + "@invalidUrl": {}, + "addLink": "Lisää linkki", + "@addLink": {}, + "unableToJoinChat": "Pikakeskusteluun liittyminen ei onnistu. Toinen osapuoli on ehkä jo sulkenut keskustelun.", + "@unableToJoinChat": {}, + "otherPartyNotLoggedIn": "Toinen osapuoli ei ole tällä hetkellä kirjautuneena sisään, joten ei voi vastaanottaa viestejä!", + "@otherPartyNotLoggedIn": {}, + "appWantsToUseForLogin": "Kirjaudu sisään käyttämällä '{server}':ta", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Annat täten sovellukselle ja verkkosivustolle luvan jakaa tietoja sinusta.", + "@appWantsToUseForLoginDescription": {}, + "waitingForServer": "Odotetaan palvelinta...", + "@waitingForServer": {}, + "appIntroduction": "FluffyChatin avulla voit keskustella ystäviesi kanssa eri pikaviestimien kautta. Lue lisää osoitteesta https://matrix.org tai napauta *Jatka*.", + "@appIntroduction": {}, + "newChatRequest": "📩 Uusi pikakeskustelupyyntö", + "@newChatRequest": {}, + "contentNotificationSettings": "Sisältöilmoitusten asetukset", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "Yleiset ilmoitusasetukset", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "Huoneen ilmoitusten asetukset", + "@roomNotificationSettings": {}, + "userSpecificNotificationSettings": "Käyttäjäkohtaiset ilmoitusten asetukset", + "@userSpecificNotificationSettings": {}, + "otherNotificationSettings": "Muut ilmoitusten asetukset", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "Sisältää käyttäjän nimen", + "@notificationRuleContainsUserName": {}, + "notificationRuleContainsUserNameDescription": "Ilmoittaa käyttäjälle, kun viesti sisältää hänen käyttäjän nimensä.", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleMaster": "Mykistä kaikki ilmoitukset", + "@notificationRuleMaster": {}, + "notificationRuleMasterDescription": "Ohittaa kaikki muut säännöt ja poistaa kaikki ilmoitukset käytöstä.", + "@notificationRuleMasterDescription": {}, + "notificationRuleSuppressNotices": "Poista kaikki automatisoidut viestit", + "@notificationRuleSuppressNotices": {}, + "notificationRuleSuppressNoticesDescription": "Poistaa ilmoitukset automatisoiduilta asiakkailta, kuten boteilta.", + "@notificationRuleSuppressNoticesDescription": {}, + "notificationRuleInviteForMe": "Kutsu minulle", + "@notificationRuleInviteForMe": {}, + "notificationRuleInviteForMeDescription": "Ilmoittaa käyttäjälle, kun hänet on kutsuttu huoneeseen.", + "@notificationRuleInviteForMeDescription": {}, + "notificationRuleMemberEvent": "Jäsentapahtuma", + "@notificationRuleMemberEvent": {}, + "notificationRuleMemberEventDescription": "Poistaa jäsenyystapahtumien ilmoitukset.", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleIsUserMention": "Käyttäjän maininta", + "@notificationRuleIsUserMention": {}, + "notificationRuleIsUserMentionDescription": "Ilmoittaa käyttäjälle, kun hänet mainitaan suoraan viestissä.", + "@notificationRuleIsUserMentionDescription": {}, + "notificationRuleContainsDisplayName": "Sisältää näyttönimen", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleContainsDisplayNameDescription": "Ilmoittaa käyttäjälle, kun viesti sisältää hänen näyttönimensä.", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleIsRoomMention": "Huoneen maininta", + "@notificationRuleIsRoomMention": {}, + "notificationRuleIsRoomMentionDescription": "Ilmoittaa käyttäjälle, kun huoneesta on maininta.", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleRoomnotif": "Huoneilmoitus", + "@notificationRuleRoomnotif": {}, + "notificationRuleRoomnotifDescription": "Ilmoittaa käyttäjälle, kun viesti sisältää '@room'.", + "@notificationRuleRoomnotifDescription": {}, + "notificationRuleTombstone": "Hautakivi", + "@notificationRuleTombstone": {}, + "notificationRuleTombstoneDescription": "Ilmoittaa käyttäjälle huoneen deaktivointiviesteistä.", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleReaction": "Reagointi", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "Poistaa ilmoitukset reaktioista.", + "@notificationRuleReactionDescription": {}, + "notificationRuleRoomServerAcl": "Huonepalvelimen pääsyluettelo", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleRoomServerAclDescription": "Poistaa huonepalvelimen pääsyluetteloiden (ACL) ilmoitukset.", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleSuppressEdits": "Poista muokkaukset", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "Poistaa ilmoitukset muokatuista viesteistä.", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleCall": "Soita", + "@notificationRuleCall": {}, + "notificationRuleCallDescription": "Ilmoittaa käyttäjälle soitoista.", + "@notificationRuleCallDescription": {}, + "notificationRuleEncryptedRoomOneToOne": "Kahdenkeskinen salattu huone", + "@notificationRuleEncryptedRoomOneToOne": {}, + "notificationRuleEncryptedRoomOneToOneDescription": "Ilmoittaa käyttäjälle kahdenkeskisissä salatuissa huoneissa olevista viesteistä.", + "@notificationRuleEncryptedRoomOneToOneDescription": {}, + "notificationRuleRoomOneToOne": "Kahdenkeskinen huone", + "@notificationRuleRoomOneToOne": {}, + "notificationRuleRoomOneToOneDescription": "Ilmoittaa käyttäjälle kahdenkeskisissä huoneissa olevista viesteistä.", + "@notificationRuleRoomOneToOneDescription": {}, + "notificationRuleMessage": "Viesti", + "@notificationRuleMessage": {}, + "notificationRuleMessageDescription": "Ilmoittaa käyttäjälle yleisistä viesteistä.", + "@notificationRuleMessageDescription": {}, + "notificationRuleEncrypted": "Salattu", + "@notificationRuleEncrypted": {}, + "notificationRuleEncryptedDescription": "Ilmoittaa käyttäjälle salatuissa huoneissa olevista viesteistä.", + "@notificationRuleEncryptedDescription": {}, + "notificationRuleJitsiDescription": "Ilmoittaa käyttäjälle tapahtumista Jitsi-vimpaimesta.", + "@notificationRuleJitsiDescription": {}, + "notificationRuleServerAcl": "Poista tapahtumat palvelimen pääsyluettelosta", + "@notificationRuleServerAcl": {}, + "notificationRuleServerAclDescription": "Poistaa ilmoitukset palvelimen pääsyluettelosta.", + "@notificationRuleServerAclDescription": {}, + "unknownPushRule": "Tuntematon työntösääntö '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Ääniviesti {sender}:lta", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Jos poistat tämän ilmoitusasetuksen, sitä ei voi kumota.", + "@deletePushRuleCanNotBeUndone": {}, + "shareKeysWith": "Jaa avaimet...", + "@shareKeysWith": {}, + "shareKeysWithDescription": "Mihin laitteisiin tulisi luottaa, jotta ne voivat lukea viestejäsi salatuissa keskusteluissa?", + "@shareKeysWithDescription": {}, + "crossVerifiedDevicesIfEnabled": "Ristiinvahvistetut laitteet, jos otettu käyttöön", + "@crossVerifiedDevicesIfEnabled": {}, + "crossVerifiedDevices": "Ristiinvahvistetut laitteet", + "@crossVerifiedDevices": {}, + "verifiedDevicesOnly": "Vain vahvistetut laitteet", + "@verifiedDevicesOnly": {}, + "takeAPhoto": "Ota valokuva", + "@takeAPhoto": {}, + "optionalMessage": "(Valinnainen) viesti...", + "@optionalMessage": {}, + "notSupportedOnThisDevice": "Ei tuettu tällä laitteella", + "@notSupportedOnThisDevice": {}, + "hideRedactedMessages": "Piilota valvojan toimesta poistetut viestit", + "@hideRedactedMessages": {}, + "hideRedactedMessagesBody": "Jos viesti jonkun toimesta poistetaan, se ei enää näy pikakeskustelussa.", + "@hideRedactedMessagesBody": {}, + "enterNewChat": "Aloita uusi pikakeskustelu", + "@enterNewChat": {}, + "youHaveKnocked": "Olet koputtanut", + "@youHaveKnocked": {}, + "pleaseWaitUntilInvited": "Odotathan nyt, kunnes joku huoneesta kutsuu sinut.", + "@pleaseWaitUntilInvited": {}, + "commandHint_logout": "Kirjaudu ulos nykyinen laitteesi", + "@commandHint_logout": {}, + "commandHint_logoutall": "Kirjaudu ulos kaikki aktiiviset laitteet", + "@commandHint_logoutall": {}, + "displayNavigationRail": "Näytä navigointipalkki mobiililaitteella", + "@displayNavigationRail": {}, + "customReaction": "Mukautettu reagointi", + "@customReaction": {}, + "moreEvents": "Lisää tapahtumia", + "@moreEvents": {}, + "declineInvitation": "Hylkää kutsu", + "@declineInvitation": {}, + "noMessagesYet": "Ei vielä viestejä", + "@noMessagesYet": {}, + "longPressToRecordVoiceMessage": "Pitkä painallus ääniviestin tallentamiseksi.", + "@longPressToRecordVoiceMessage": {}, + "newSubSpace": "Uusi alitila", + "@newSubSpace": {}, + "moveToDifferentSpace": "Siirry eri tilaan", + "@moveToDifferentSpace": {}, + "removeFromSpaceDescription": "Pikakeskustelu poistetaan tilasta, mutta se näkyy edelleen pikakeskusteluluettelossasi.", + "@removeFromSpaceDescription": {}, + "countChats": "{chats} pikakeskustelua", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "{spaces}:jen tilanjäsen", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "{spaces}:jen tilanjäsen saa koputtaa", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Lahjoita", + "@donate": {}, + "startedAPoll": "{username} aloitti kyselyn.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "startPoll": "Aloita kysely", + "@startPoll": {}, + "endPoll": "Lopeta kysely", + "@endPoll": {}, + "answersVisible": "Vastaukset näkyvissä", + "@answersVisible": {}, + "answersHidden": "Vastaukset piilotettu", + "@answersHidden": {}, + "pollQuestion": "Kyselykysymys", + "@pollQuestion": {}, + "answerOption": "Vastausvaihtoehto", + "@answerOption": {}, + "addAnswerOption": "Lisää vastausvaihtoehto", + "@addAnswerOption": {}, + "allowMultipleAnswers": "Salli useita vastauksia", + "@allowMultipleAnswers": {}, + "pollHasBeenEnded": "Kysely on päättynyt", + "@pollHasBeenEnded": {}, + "answersWillBeVisibleWhenPollHasEnded": "Vastaukset näkyvät, kun kysely on päättynyt", + "@answersWillBeVisibleWhenPollHasEnded": {}, + "replyInThread": "Vastaa ketjussa", + "@replyInThread": {}, + "countVotes": "{count, plural, =1{One vote} other{{count} ääntä}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "countReplies": "{count, plural, =1{One reply} other{{count} vastausta}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Ketju", + "@thread": {}, + "backToMainChat": "Takaisin pääpikakeskusteluun", + "@backToMainChat": {} +} diff --git a/assets/l10n/intl_fil.arb b/lib/l10n/intl_fil.arb similarity index 69% rename from assets/l10n/intl_fil.arb rename to lib/l10n/intl_fil.arb index 07ef65218..414c52d44 100644 --- a/assets/l10n/intl_fil.arb +++ b/lib/l10n/intl_fil.arb @@ -1,7 +1,7 @@ { "remove": "Tanggalin", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "importNow": "I-import ngayon", @@ -14,17 +14,17 @@ "@exportEmotePack": {}, "accept": "Tanggapin", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "account": "Account", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "addEmail": "Magdagdag ng email", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "confirmMatrixId": "Paki-kumpirma ang iyong Matrix ID para burahin ang iyong account.", @@ -33,22 +33,22 @@ "@addChatDescription": {}, "admin": "Admin", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "alyas", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "Lahat", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "allChats": "Lahat ng mga chat", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_googly": "Magpadala ng mga googly eye", @@ -57,162 +57,180 @@ "@commandHint_cuddle": {}, "cuddleContent": "Niyakap ka ni {senderName}", "@cuddleContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "hugContent": "Niyakap ka ni {senderName}", "@hugContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "Pwede sumali ang anumang tao", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "appLock": "Lock ng app", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "Archive", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "Pwede ba sumali ang mga bisita", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "Sigurado ka?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "Tanggapin ang hiling ng verification mula sa {username}?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "autoplayImages": "Awtomatikong i-play ang mga gumagalaw na sticker at emote", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "sendTypingNotifications": "Ipadala ang mga typing notification", "@sendTypingNotifications": {}, "blockDevice": "I-block ang Device", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "Na-block", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "changeDeviceName": "Palitan ang pangalan ng device", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "Pinalitan ni {username} ang avatar ng chat", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheGuestAccessRules": "Pinalitan ni {username} ang mga tuntunin sa pag-access ng bisita", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibility": "Pinalitan ni {username} ang kakayahan ng pagkikita ng history", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "Pinalitan ni {username} ang kakayahan ng pagkikita ng history sa: {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheRoomAliases": "Pinalitan ni {username} ang mga alias ng room", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changePassword": "Palitan ang password", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "changeYourAvatar": "Palitan ang iyong avatar", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "Nasira ang encryption", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "Chat", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackup": "Pag-backup ng chat", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "Mga detalye ng chat", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chatHasBeenAddedToThisSpace": "Nadagdag ang chat sa space na ito", "@chatHasBeenAddedToThisSpace": {}, "chats": "Mga Chat", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "Pumili ng malakas na password", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "I-clear ang archive", "@clearArchive": {}, "close": "Isara", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_markasgroup": "Markahan bilang grupo", "@commandHint_markasgroup": {}, "commandHint_ban": "Pagbawalan ang ibinigay na user sa room na ito", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "repeatPassword": "Ulitin ang password", @@ -223,28 +241,34 @@ "@replace": {}, "about": "Tungkol sa", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "👍 Tinanggap ni {username} ang imbitasyon", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "activatedEndToEndEncryption": "🔐 Na-activate ni {username} ang end to end encryption", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "supposedMxid": "Dapat ito ay {mxid}", "@supposedMxid": { - "type": "text", + "type": "String", "placeholders": { - "mxid": {} + "mxid": { + "type": "String" + } } }, "addToSpace": "Idagdag sa space", @@ -253,485 +277,549 @@ "@commandHint_hug": {}, "googlyEyesContent": "Nagpadala si {senderName} ng googly eyes", "@googlyEyesContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "answeredTheCall": "Sinagot ni {senderName} ang tawag", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "areYouSureYouWantToLogout": "Sigurado kang gusto mong mag-log out?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "Para i-sign ang isa pang tao, pakilagay ang iyong secure store passphrase o recovery key.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "badServerLoginTypesException": "Ang homeserver ay sinusuportahan ang sumusunod na uri ng login:\n{serverVersions}\nNgunit sinusuportahan lang ng app ang:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "sendOnEnter": "Ipadala sa pagpindot ng enter", "@sendOnEnter": {}, "badServerVersionsException": "Ang homeserver ay sinusuportahan ang mga Spec bersyon:\n{serverVersions}\nNgunit sinusuportahan lang ng app ang {supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "banFromChat": "Pagbawalan sa chat", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "Pinagbawalan", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "Mga mensahe ng bot", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "Kanselahin", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "Pinagbawalan ni {username} si {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "cantOpenUri": "Hindi mabuksan ang URI na {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "changedTheJoinRules": "Pinalitan ni {username} ang mga tuntunin sa pagsali", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheJoinRulesTo": "Pinalitan ni {username} ang mga tuntunin sa pagsali sa: {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "Pinalitan ni {username} ang deskripsyon ng chat sa: '{description}'", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheProfileAvatar": "Pinalitan ni {username} ang kanilang avatar", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatNameTo": "Pinalitan ni {username} ang pangalan ng chat sa: '{chatname}'", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "Pinalitan ni {username} ang link ng imbitasyon", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changeTheHomeserver": "Palitan ang homeserver", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "Palitan ang iyong istilio", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatPermissions": "Pinalitan ni {username} ang mga pahintulot ng chat", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changeTheNameOfTheGroup": "Palitan ng pangalan ng grupo", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheDisplaynameTo": "Pinalitan ni {username} ang kanilang displayname sa: '{displayname}'", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "yourChatBackupHasBeenSetUp": "Na-set up na ang iyong chat backup.", "@yourChatBackupHasBeenSetUp": {}, "chatBackupDescription": "Naka-secure ang iyong mga lumang mensahe gamit ng recovery key. Siguraduhing hindi mo ito mawalan.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_markasdm": "Markahan bilang direktang mensahe na room para sa ibinigay na Matrix ID", "@commandHint_markasdm": {}, "changedTheGuestAccessRulesTo": "Pinalitan ni {username} ang mga tuntunin sa pag-access ng bisita sa: {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "commandHint_clearcache": "I-clear ang cache", "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "commandHint_discardsession": "Iwaksi ang sesyon", "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "commandHint_create": "Gumawa ng walang lamang group chat\nGumamit ng --no-encryption para i-disable ang encryption", "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "configureChat": "I-configure ang chat", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "Kumpirmahin", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "Paki-kumpara ang mga numero", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "Kinopya sa clipboard", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "Kopyahin", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "Kopyahin sa clipboard", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "countParticipants": "{count} mga kasali", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "createdTheChat": "💬 Ginawa ni {username} ang chat", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "createGroup": "Gumawa ng grupo", "@createGroup": {}, "createNewSpace": "Bagong space", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "currentlyActive": "Kasalukuyang aktibo", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "Madilim", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "Pinalitan na ang display name", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "Mga Direktang Chat", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "allRooms": "Lahat ng Mga Group Chat", "@allRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "I-download ang file", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "I-edit ang mga naka-block na server", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "chatPermissions": "Mga pahintulot ng chat", "@chatPermissions": {}, "editDisplayname": "I-edit ang display name", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "I-edit ang mga alyas ng room", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "I-edit", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "I-edit ang avatar ng room", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Umiiral na ang emote!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "Walang lamang chat", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "I-enable ang encryption", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "Pag-encrypt", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "Naka-encrypt", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "Hindi naka-enable ang encryption", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "everythingReady": "Handa na ang lahat!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "appLockDescription": "I-lock ang app kapag hindi ginagamit sa pamamagitan ng pin code", "@appLockDescription": {}, "commandHint_dm": "Magsimula ng direktong chat\nGumamit ng --no-encryptiom para i-disable ang encryption", "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "commandHint_html": "Magpadala ng HTML-formatted na text", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "Imbitahan ang ibinigay na user sa room na ito", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandHint_join": "Sumali sa ibinigay na room", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_kick": "Tanggalin ang ibinigay na user sa room na ito", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_leave": "Umalis sa room na ito", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_me": "Ilarawan ang iyong sarili", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "commandHint_myroomavatar": "Ilapat ang iyong larawan para sa room na ito (bilang mxc-uri)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_myroomnick": "Ilapat ang iyong display name para sa room na ito", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_op": "Ilapat ang level ng lakas sa ibinigay na user (default: 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_react": "Magpadala ng reply bilang reaksyon", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "commandHint_send": "Magpadala ng text", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "commandHint_unban": "I-unban ang ibinigay na user sa room na ito", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "commandInvalid": "Hindi wastong command", "@commandInvalid": { - "type": "text" + "type": "String" }, "compareEmojiMatch": "Paki-kumpara ang mga emoji", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "Kumonekta", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "Naglalaman ng display name", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "create": "Gumawa", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{month}/{day}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "dateWithYear": "{month}/{day}/{year}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "deactivateAccountWarning": "Ide-deactivate nito ang iyong user account. Hindi na ito maaaring bawiin! Sigurado ka?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "Burahin", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "Burahin ang mensahe", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "Device", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "ID ng Device", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "Mga Device", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "Hindi wastong shortcode ng emote!", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteKeyboardNoRecents": "Ang mga kamakailang ginamit na emote ay lalabas dito...", "@emoteKeyboardNoRecents": { - "type": "text", + "type": "String", "placeholders": {} }, "calls": "Mga Tawag", @@ -742,96 +830,102 @@ "@customEmojisAndStickersBody": {}, "emoteShortcode": "Shortcode ng emoji", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Kailangan mong pumili ng emote shortcode at isang larawan!", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "I-enable ang emote pack globally", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "Tinapos ni {senderName} ang tawag", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "enterAnEmailAddress": "Maglagay ng email address", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "homeserver": "Homeserver", "@homeserver": {}, "enterYourHomeserver": "Ilagay ang iyong homeserver", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "Lubhang nakakasakit", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_plain": "Magpadala ng hindi na-format na text", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandMissing": "Hindi isang command ang {command}.", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "contactHasBeenInvitedToTheGroup": "Inimbita ang contact sa group", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "Naglalaman ng username", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "Inulat ang nilalaman sa mga pangangasiwa ng server", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "Hindi ma-decrypt ang mensahe: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, - "defaultPermissionLevel": "Default na antas ng pahintulot", + "defaultPermissionLevel": "Default na antas ng pahintulot para sa mga bagong user", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "Burahin ang account", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "Mga emote pack para sa room", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Mga Setting ng Emote", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "globalChatId": "Global chat ID", @@ -842,29 +936,128 @@ "@accessAndVisibilityDescription": {}, "enableEncryptionWarning": "Hindi mo madi-disable ang encryption. Sigurado ka ba?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "errorObtainingLocation": "Hindi makuha ang lokasyon: {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "fileName": "Pangalan ng file", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "Laki ng font", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} + }, + "noChatsFoundHere": "Walang pang mga chat na nahanap dito. Magsimula ng bagong chat kasama ang isang tao sa pamamagitan ng paggamit ng button sa ibaba. ⤵️", + "@noChatsFoundHere": {}, + "aboutHomeserver": "Tungkol sa {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "space": "Espasyo", + "@space": {}, + "countChatsAndCountParticipants": "{chats} mga chat at {participants} mga kasali", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "guestsAreForbidden": "Pinagbabawal ang mga bisita", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Maaring sumali ang mga bisita", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "forward": "I-forward", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Mula sa pagsali", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Mula sa imbitasyon", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Pumunta sa bagong room", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Grupo", + "@group": { + "type": "String", + "placeholders": {} + }, + "swipeRightToLeftToReply": "Mag-swipe pakaliwa o kanan para tumugon", + "@swipeRightToLeftToReply": {}, + "noMoreChatsFound": "Wala nang mga chat na nahanap…", + "@noMoreChatsFound": {}, + "joinedChats": "Mga nasaling chat", + "@joinedChats": {}, + "unread": "Hindi nabasa", + "@unread": {}, + "spaces": "Mga Espasyo", + "@spaces": {}, + "groupIsPublic": "Pampubliko ang grupo", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Mga grupo", + "@groups": { + "type": "String", + "placeholders": {} + }, + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "chatDescription": "Paglalarawan ng chat", + "@chatDescription": {}, + "chatDescriptionHasBeenChanged": "Nabago ang paglalarawan ng chat", + "@chatDescriptionHasBeenChanged": {}, + "groupWith": "Grupo kasama kay/sa {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } } } diff --git a/assets/l10n/intl_fr.arb b/lib/l10n/intl_fr.arb similarity index 56% rename from assets/l10n/intl_fr.arb rename to lib/l10n/intl_fr.arb index ba0a82634..74e993c81 100644 --- a/assets/l10n/intl_fr.arb +++ b/lib/l10n/intl_fr.arb @@ -3,1916 +3,2087 @@ "@@last_modified": "2021-08-14 12:41:10.051787", "about": "À propos", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "Accepter", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "👍 {username} a accepté l'invitation", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "Compte", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "activatedEndToEndEncryption": "🔐 {username} a activé le chiffrement de bout en bout", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "addEmail": "Ajouter un courriel", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "addToSpace": "Ajouter à l'espace", "@addToSpace": {}, "admin": "Administrateur", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "adresse", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "Tout", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "allChats": "Toutes les discussions", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "answeredTheCall": "{senderName} a répondu à l'appel", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "Tout le monde peut rejoindre", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "appLock": "Verrouillage de l’application", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "Archiver", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "Les invités peuvent-i·e·ls rejoindre", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "Êtes-vous sûr·e ?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSureYouWantToLogout": "Voulez-vous vraiment vous déconnecter ?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "Pour pouvoir faire signer l'autre personne, veuillez entrer la phrase de passe de votre trousseau sécurisé ou votre clé de récupération.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "Accepter cette demande de vérification de la part de {username} ?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "autoplayImages": "Lire automatiquement les autocollants et les émojis animés", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "badServerLoginTypesException": "Le serveur d'accueil prend en charge les types de connexion :\n{serverVersions}\nMais cette application ne prend en charge que :\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "badServerVersionsException": "Le serveur d'accueil prend en charge les versions des spécifications :\n{serverVersions}\nMais cette application ne prend en charge que {supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "banFromChat": "Bannir de la discussion", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "Banni", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "{username} a banni {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "blockDevice": "Bloquer l'appareil", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "Bloqué", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "Messages de bot", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "Annuler", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "cantOpenUri": "Impossible d'ouvrir l'URI {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "changeDeviceName": "Modifier le nom de l'appareil", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "{username} a changé l'image de la discussion", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "{username} a changé la description de la discussion en : '{description}'", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheChatNameTo": "{username} a renommé la discussion en : '{chatname}'", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheChatPermissions": "{username} a changé les permissions de la discussion", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheDisplaynameTo": "{username} a changé son nom en : '{displayname}'", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username} a changé les règles d'accès à la discussion pour les invités", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username} a changé les règles d'accès à la discussion pour les invités en : {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheHistoryVisibility": "{username} a changé la visibilité de l'historique de la discussion", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "{username} a changé la visibilité de l'historique de la discussion en : {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRules": "{username} a changé les règles d'accès à la discussion", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username} a changé les règles d'accès à la discussion en : {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username} a changé son avatar", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomAliases": "{username} a changé les adresses du salon", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "{username} a changé le lien d'invitation", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changePassword": "Changer de mot de passe", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheHomeserver": "Changer le serveur d'accueil", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "Changez votre style", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheNameOfTheGroup": "Changer le nom du groupe", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "changeYourAvatar": "Changer votre avatar", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "Le chiffrement a été corrompu", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "Discussion", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackup": "Sauvegarde des discussions", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackupDescription": "Vos anciens messages sont sécurisés par une clé de récupération. Veillez à ne pas la perdre.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "Détails de la discussion", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chatHasBeenAddedToThisSpace": "La discussion a été ajoutée à cet espace", "@chatHasBeenAddedToThisSpace": {}, "chats": "Discussions", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "Choisissez un mot de passe fort", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "Effacer les archives", "@clearArchive": {}, "close": "Fermer", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_ban": "Bannir l'utilisateur/trice donné(e) de ce salon", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_html": "Envoyer du texte au format HTML", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "Inviter l'utilisateur/trice donné(e) dans ce salon", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandHint_join": "Rejoindre le salon donné", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_kick": "Supprime l'utilisateur/trice donné(e) de ce salon", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_leave": "Quitter ce salon", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_me": "Décrivez-vous", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "commandHint_myroomavatar": "Définir votre image pour ce salon (par mxc-uri)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_myroomnick": "Définir votre nom d'affichage pour ce salon", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_op": "Définir le niveau de puissance de l'utilisateur/trice donné(e) (par défaut : 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_plain": "Envoyer du texte non formaté", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_react": "Envoyer une réponse en tant que réaction", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "commandHint_send": "Envoyer du texte", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "commandHint_unban": "Débannir l'utilisateur/trice donné(e) de ce salon", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "commandInvalid": "Commande invalide", "@commandInvalid": { - "type": "text" + "type": "String" }, "commandMissing": "{command} n'est pas une commande.", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "compareEmojiMatch": "Veuillez comparer les émojis", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "Veuillez comparer les chiffres", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "configureChat": "Configurer la discussion", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "Confirmer", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "Se connecter", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "contactHasBeenInvitedToTheGroup": "Le contact a été invité au groupe", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "Contient un nom d'affichage", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "Contient un nom d'utilisateur·ice", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "Le contenu a été signalé aux administrateurs du serveur", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "Copié dans le presse-papier", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "Copier", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "Copier dans le presse-papiers", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "Impossible de déchiffrer le message : {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "countParticipants": "{count} participant(s)", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "create": "Créer", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "createdTheChat": "💬 {username} a créé la discussion", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "createNewSpace": "Nouvel espace", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "currentlyActive": "Actif en ce moment", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "Sombre", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{day}/{month}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "dateWithYear": "{day}/{month}/{year}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "deactivateAccountWarning": "Cette opération va désactiver votre compte. Une fois cette action effectuée, aucun retour en arrière n'est possible ! Êtes-vous sûr·e ?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, - "defaultPermissionLevel": "Niveau d'autorisation par défaut", + "defaultPermissionLevel": "Niveau d'autorisation par défaut pour les arrivants", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "Supprimer", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "Supprimer le compte", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "Supprimer le message", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "Appareil", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "Identifiant de l'appareil", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "Appareils", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "Discussions directes", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "Renommage effectué", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "Télécharger le fichier", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "Modifier", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "Modifier les serveurs bloqués", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "Changer de nom d'affichage", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "Modifier les adresses du salon", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "Modifier l'avatar du salon", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Cette émoticône existe déjà !", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "Raccourci d'émoticône invalide !", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "Packs d'émoticônes pour le salon", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Paramètre des émoticônes", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteShortcode": "Raccourci de l'émoticône", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Vous devez sélectionner un raccourci d'émoticône et une image !", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "Discussion vide", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "Activer globalement le pack d'émoticônes", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "Activer le chiffrement", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryptionWarning": "Vous ne pourrez plus désactiver le chiffrement. Êtes-vous sûr(e) ?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "Chiffré", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "Chiffrement", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "Le chiffrement n'est pas activé", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName} a mis fin à l'appel", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "enterAnEmailAddress": "Saisissez une adresse de courriel", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "enterYourHomeserver": "Renseignez votre serveur d'accueil", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "errorObtainingLocation": "Erreur lors de l'obtention de la localisation : {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "everythingReady": "Tout est prêt !", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "Extrêmement offensant", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "Nom du ficher", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "Taille de la police", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "Transférer", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "fromJoining": "À partir de l'entrée dans le salon", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "fromTheInvitation": "À partir de l'invitation", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "Aller dans le nouveau salon", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "Groupe", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "Le groupe est public", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "groups": "Groupes", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "groupWith": "Groupe avec {displayname}", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "guestsAreForbidden": "Les invités ne peuvent pas rejoindre", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "Les invités peuvent rejoindre", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "hasWithdrawnTheInvitationFor": "{username} a annulé l'invitation de {targetName}", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "help": "Aide", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "hideRedactedEvents": "Cacher les évènements supprimés", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "Cacher les évènements inconnus", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "howOffensiveIsThisContent": "À quel point ce contenu est-il offensant ?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "Identifiant", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "Identité", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignore": "Ignorer", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "Utilisateur·ices ignoré·es", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "J'ai cliqué sur le lien", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "Phrase de passe ou clé de récupération incorrecte", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "Non offensant", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "Inviter un contact", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "Inviter un contact dans {groupName}", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "invited": "Invité·e", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUser": "📩 {username} a invité {targetName}", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "invitedUsersOnly": "Uniquement les utilisateur·ices invité·es", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteForMe": "Inviter pour moi", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, - "inviteText": "{username} vous a invité·e sur FluffyChat. \n1. Installez FluffyChat : https://fluffychat.im \n2. Inscrivez-vous ou connectez-vous \n3. Ouvrez le lien d'invitation : {link}", + "inviteText": "{username} vous a invité·e sur FluffyChat.\n1. Visiter fluffychat.im et installer l'application\n2. Inscrivez-vous ou connectez-vous\n3. Ouvrez le lien d'invitation :\n{link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "isTyping": "est en train d'écrire…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "joinedTheChat": "👋 {username} a rejoint la discussion", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "joinRoom": "Rejoindre le salon", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "kicked": "👞 {username} a expulsé {targetName}", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickedAndBanned": "🙅 {username} a expulsé et banni {targetName}", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickFromChat": "Expulser de la discussion", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "lastActiveAgo": "Vu·e pour la dernière fois : {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "leave": "Partir", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "leftTheChat": "A quitté la discussion", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "Licence", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "Clair", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "loadCountMoreParticipants": "Charger {count} participant·es de plus", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "loadingPleaseWait": "Chargement… Veuillez patienter.", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "loadMore": "Charger plus…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "locationDisabledNotice": "Les services de localisation sont désactivés. Il est nécessaire de les activer avant de pouvoir partager votre localisation.", "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "locationPermissionDeniedNotice": "L'application n'a pas la permission d'accéder à votre localisation. Merci de l'accorder afin de pouvoir partager votre localisation.", "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "Se connecter", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "logInTo": "Se connecter à {homeserver}", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "logout": "Se déconnecter", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "memberChanges": "Changements de membres", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "Mentionner", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "Messages", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "Modérateur·rice", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "muteChat": "Mettre la discussion en sourdine", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "Pour l'instant, vous avez besoin de Pantalaimon pour utiliser le chiffrement de bout en bout.", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "Nouvelle discussion", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "💬 Nouveau message dans FluffyChat", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newVerificationRequest": "Nouvelle demande de vérification !", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "Suivant", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "Non", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "Aucune connexion au serveur", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "noEmotesFound": "Aucune émoticône trouvée. 😕", "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "Vous pouvez activer le chiffrement seulement quand le salon n'est plus accessible au public.", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, - "noGoogleServicesWarning": "Il semble que vous n'ayez aucun service Google sur votre téléphone. C'est une bonne décision pour votre vie privée ! Pour recevoir des notifications dans FluffyChat, nous vous recommandons d'utiliser https://microg.org/ ou https://unifiedpush.org/.", + "noGoogleServicesWarning": "Firebase Cloud Messaging ne semble pas être disponible sur votre appareil. Pour continuer à recevoir des notifications poussées, nous vous recommandons d'installer ntfy. Avec ntfy ou un autre fournisseur Unified Push, vous pouvez recevoir des notifications poussées de manière sécurisée. Vous pouvez télécharger ntfy sur le PlayStore ou sur F-Droid.", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "noMatrixServer": "{server1} n'est pas un serveur Matrix, souhaitez-vous utiliser {server2} à la place ?", "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "none": "Aucun", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "Vous n'avez pas encore ajouté de moyen pour récupérer votre mot de passe.", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "noPermission": "Aucune permission", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "Aucun salon trouvé…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "Notifications", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "Notifications activées pour ce compte", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "numUsersTyping": "{count} utilisateur·ices écrivent…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "obtainingLocation": "Obtention de la localisation…", "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "offensive": "Offensant", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "offline": "Hors ligne", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "ok": "Valider", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "En ligne", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "onlineKeyBackupEnabled": "La sauvegarde en ligne des clés est activée", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsPushError": "Oups ! Une erreur s'est malheureusement produite lors du réglage des notifications.", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "Oups, un problème est survenu…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "Ouvrez l'application pour lire le message", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "Ouvrir l'appareil photo", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "openInMaps": "Ouvrir dans maps", "@openInMaps": { - "type": "text", + "type": "String", "placeholders": {} }, "or": "Ou", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "participant": "Participant(e)", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "passphraseOrKey": "Phrase de passe ou clé de récupération", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "Mot de passe", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "Mot de passe oublié", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "Le mot de passe a été modifié", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "Récupération du mot de passe", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "Personnes", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "Choisir une image", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "Épingler", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "play": "Lire {fileName}", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "pleaseChoose": "Veuillez choisir", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChooseAPasscode": "Veuillez choisir un code d’accès", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseClickOnLink": "Veuillez cliquer sur le lien contenu dans le courriel puis continuez.", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "Veuillez saisir 4 chiffres ou laisser vide pour désactiver le verrouillage de l’application.", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "Renseignez votre mot de passe", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "Veuillez saisir votre code PIN", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "Renseignez votre nom d'utilisateur·ice", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseFollowInstructionsOnWeb": "Veuillez suivre les instructions sur le site et appuyer sur Suivant.", "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "privacy": "Vie privée", "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "publicRooms": "Salons publics", "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "pushRules": "Règles de notifications", "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, "reason": "Motif", "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "recording": "Enregistrement", "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "redactedAnEvent": "{username} a supprimé un évènement", "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "redactMessage": "Supprimer un message", "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "register": "S'inscrire", "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "reject": "Refuser", "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "rejectedTheInvitation": "{username} a refusé l'invitation", "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "rejoin": "Rejoindre de nouveau", "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "remove": "Supprimer", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "removeAllOtherDevices": "Supprimer tous les autres appareils", "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "removedBy": "Supprimé par {username}", "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removeDevice": "Supprimer l'appareil", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unbanFromChat": "Débannissement de la discussion", "@unbanFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "removeYourAvatar": "Supprimer votre avatar", "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Afficher les contenus riches des messages", - "@renderRichContent": { - "type": "text", + "type": "String", "placeholders": {} }, "replaceRoomWithNewerVersion": "Remplacer le salon par une nouvelle version", "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "reply": "Répondre", "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "reportMessage": "Signaler un message", "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "requestPermission": "Demander la permission", "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "roomHasBeenUpgraded": "Le salon a été mis à niveau", "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "roomVersion": "Version du salon", "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "saveFile": "Enregistrer le fichier", "@saveFile": { - "type": "text", + "type": "String", "placeholders": {} }, "search": "Rechercher", "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "security": "Sécurité", "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "seenByUser": "Vu par {username}", "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "send": "Envoyer", "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAMessage": "Envoyer un message", "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAsText": "Envoyer un texte", "@sendAsText": { - "type": "text" + "type": "String" }, "sendAudio": "Envoyer un fichier audio", "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "sendFile": "Envoyer un fichier", "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "sendImage": "Envoyer une image", "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendMessages": "Envoyer des messages", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOriginal": "Envoyer le fichier original", "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "sendSticker": "Envoyer un autocollant", "@sendSticker": { - "type": "text", + "type": "String", "placeholders": {} }, "sendVideo": "Envoyer une vidéo", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAFile": "📁 {username} a envoyé un fichier", "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAnAudio": "🎤 {username} a envoyé un fichier audio", "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAPicture": "🖼️ {username} a envoyé une image", "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentASticker": "😊 {username} a envoyé un autocollant", "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAVideo": "🎥 {username} a envoyé une vidéo", "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentCallInformations": "{senderName} a envoyé des informations sur l'appel", "@sentCallInformations": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "setAsCanonicalAlias": "Définir comme adresse principale", "@setAsCanonicalAlias": { - "type": "text", + "type": "String", "placeholders": {} }, "setCustomEmotes": "Définir des émoticônes personnalisées", "@setCustomEmotes": { - "type": "text", + "type": "String", "placeholders": {} }, "setInvitationLink": "Créer un lien d'invitation", "@setInvitationLink": { - "type": "text", + "type": "String", "placeholders": {} }, "setPermissionsLevel": "Définir le niveau de permissions", "@setPermissionsLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "setStatus": "Définir le statut", "@setStatus": { - "type": "text", + "type": "String", "placeholders": {} }, "settings": "Paramètres", "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, "share": "Partager", "@share": { - "type": "text", + "type": "String", "placeholders": {} }, "sharedTheLocation": "{username} a partagé sa position", "@sharedTheLocation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "shareLocation": "Partager la localisation", "@shareLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "showPassword": "Afficher le mot de passe", "@showPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "singlesignon": "Authentification unique", "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, "skip": "Ignorer", "@skip": { - "type": "text", + "type": "String", "placeholders": {} }, "sourceCode": "Code source", "@sourceCode": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceIsPublic": "L'espace est public", "@spaceIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceName": "Nom de l'espace", "@spaceName": { - "type": "text", + "type": "String", "placeholders": {} }, "startedACall": "{senderName} a démarré un appel", "@startedACall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "status": "Statut", "@status": { - "type": "text", + "type": "String", "placeholders": {} }, "statusExampleMessage": "Comment allez-vous aujourd'hui ?", "@statusExampleMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "submit": "Soumettre", "@submit": { - "type": "text", + "type": "String", "placeholders": {} }, "synchronizingPleaseWait": "Synchronisation... Veuillez patienter.", "@synchronizingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "systemTheme": "Système", "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "theyDontMatch": "Elles ne correspondent pas", "@theyDontMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "theyMatch": "Elles correspondent", "@theyMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "title": "FluffyChat", "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, "toggleFavorite": "Activer/désactiver en favori", "@toggleFavorite": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleMuted": "Activer/désactiver la sourdine", "@toggleMuted": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleUnread": "Marquer comme lu / non lu", "@toggleUnread": { - "type": "text", + "type": "String", "placeholders": {} }, "tooManyRequestsWarning": "Trop de requêtes. Veuillez réessayer plus tard !", "@tooManyRequestsWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "transferFromAnotherDevice": "Transfert à partir d'un autre appareil", "@transferFromAnotherDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "tryToSendAgain": "Retenter l'envoi", "@tryToSendAgain": { - "type": "text", + "type": "String", "placeholders": {} }, "unavailable": "Indisponible", "@unavailable": { - "type": "text", + "type": "String", "placeholders": {} }, "unbannedUser": "{username} a annulé le bannissement de {targetName}", "@unbannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "unblockDevice": "Retirer le blocage sur l'appareil", "@unblockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownDevice": "Appareil inconnu", "@unknownDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEncryptionAlgorithm": "Algorithme de chiffrement inconnu", "@unknownEncryptionAlgorithm": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEvent": "Événement de type inconnu : '{type}'", "@unknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "type": {} + "type": { + "type": "String" + } } }, "unmuteChat": "Retirer la sourdine de la discussion", "@unmuteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "unpin": "Désépingler", "@unpin": { - "type": "text", + "type": "String", "placeholders": {} }, "unreadChats": "{unreadCount, plural, =1{1 discussion non lue} other{{unreadCount} discussions non lues}}", "@unreadChats": { - "type": "text", + "type": "String", "placeholders": { - "unreadCount": {} + "unreadCount": { + "type": "int" + } } }, "userAndOthersAreTyping": "{username} et {count} autres sont en train d'écrire…", "@userAndOthersAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "count": {} + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "userAndUserAreTyping": "{username} et {username2} sont en train d'écrire…", "@userAndUserAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "username2": {} + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } } }, "userIsTyping": "{username} est en train d'écrire…", "@userIsTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "userLeftTheChat": "🚪 {username} a quitté la discussion", "@userLeftTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "username": "Nom d'utilisateur·ice", "@username": { - "type": "text", + "type": "String", "placeholders": {} }, "userSentUnknownEvent": "{username} a envoyé un évènement de type {type}", "@userSentUnknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "type": {} + "username": { + "type": "String" + }, + "type": { + "type": "String" + } } }, "verified": "Vérifié", "@verified": { - "type": "text", + "type": "String", "placeholders": {} }, "verify": "Vérifier", "@verify": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyStart": "Commencer la vérification", "@verifyStart": { - "type": "text", + "type": "String", "placeholders": {} }, "verifySuccess": "La vérification a été effectuée avec succès !", "@verifySuccess": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyTitle": "Vérification de l'autre compte", "@verifyTitle": { - "type": "text", + "type": "String", "placeholders": {} }, "videoCall": "Appel vidéo", "@videoCall": { - "type": "text", + "type": "String", "placeholders": {} }, "visibilityOfTheChatHistory": "Visibilité de l'historique de la discussion", "@visibilityOfTheChatHistory": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForAllParticipants": "Visible pour tous les participant·es", "@visibleForAllParticipants": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForEveryone": "Visible pour tout le monde", "@visibleForEveryone": { - "type": "text", + "type": "String", "placeholders": {} }, "voiceMessage": "Message vocal", "@voiceMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerAcceptRequest": "En attente de l'acceptation de la demande par le partenaire…", "@waitingPartnerAcceptRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerEmoji": "En attente de l'acceptation de l'émoji par le partenaire…", "@waitingPartnerEmoji": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerNumbers": "En attente de l'acceptation des nombres par le partenaire…", "@waitingPartnerNumbers": { - "type": "text", + "type": "String", "placeholders": {} }, - "wallpaper": "Image de fond", + "wallpaper": "Image de fond :", "@wallpaper": { - "type": "text", + "type": "String", "placeholders": {} }, "warning": "Attention !", "@warning": { - "type": "text", + "type": "String", "placeholders": {} }, "weSentYouAnEmail": "Nous vous avons envoyé un courriel", "@weSentYouAnEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "whoCanPerformWhichAction": "Qui peut faire quelle action", "@whoCanPerformWhichAction": { - "type": "text", + "type": "String", "placeholders": {} }, "whoIsAllowedToJoinThisGroup": "Qui est autorisé·e à rejoindre ce groupe", "@whoIsAllowedToJoinThisGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "whyDoYouWantToReportThis": "Pourquoi voulez-vous le signaler ?", "@whyDoYouWantToReportThis": { - "type": "text", + "type": "String", "placeholders": {} }, "wipeChatBackup": "Effacer la sauvegarde de votre discussion pour créer une nouvelle clé de récupération ?", "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "withTheseAddressesRecoveryDescription": "Grâce à ces adresses, vous pouvez récupérer votre mot de passe si vous en avez besoin.", "@withTheseAddressesRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "writeAMessage": "Écrivez un message…", "@writeAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "yes": "Oui", "@yes": { - "type": "text", + "type": "String", "placeholders": {} }, "you": "Vous", "@you": { - "type": "text", + "type": "String", "placeholders": {} }, "youAreNoLongerParticipatingInThisChat": "Vous ne participez plus à cette discussion", "@youAreNoLongerParticipatingInThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "youHaveBeenBannedFromThisChat": "Vous avez été banni·e de cette discussion", "@youHaveBeenBannedFromThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "yourPublicKey": "Votre clé publique", "@yourPublicKey": { - "type": "text", + "type": "String", "placeholders": {} }, "scanQrCode": "Scanner un code QR", @@ -1963,36 +2134,38 @@ "@start": {}, "commandHint_create": "Créer un groupe de discussion vide\nUtilisez --no-encryption pour désactiver le chiffrement", "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "commandHint_discardsession": "Abandonner la session", "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "commandHint_clearcache": "Vider le cache", "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "commandHint_dm": "Commencer une discussion directe\nUtilisez --no-encryption pour désactiver le chiffrement", "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "openVideoCamera": "Ouvrir la caméra pour une vidéo", "@openVideoCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "publish": "Publier", "@publish": {}, "videoWithSize": "Vidéo ({size})", "@videoWithSize": { - "type": "text", + "type": "String", "placeholders": { - "size": {} + "size": { + "type": "String" + } } }, "dismiss": "Rejeter", @@ -2005,10 +2178,14 @@ "@openChat": {}, "reactedWith": "{sender} a réagi avec {reaction}", "@reactedWith": { - "type": "text", + "type": "String", "placeholders": { - "sender": {}, - "reaction": {} + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } } }, "emojis": "Émojis", @@ -2035,7 +2212,9 @@ "@switchToAccount": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "nextAccount": "Compte suivant", @@ -2067,7 +2246,9 @@ "youHaveWithdrawnTheInvitationFor": "Vous avez retiré l'invitation pour {user}", "@youHaveWithdrawnTheInvitationFor": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youAcceptedTheInvitation": "👍 Vous avez accepté l'invitation", @@ -2075,42 +2256,54 @@ "youBannedUser": "Vous avez banni {user}", "@youBannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youInvitedBy": "📩 Vous avez été invité par {user}", "@youInvitedBy": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youInvitedUser": "📩 Vous avez invité {user}", "@youInvitedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youKicked": "👞 Vous avez dégagé {user}", "@youKicked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youKickedAndBanned": "🙅 Vous avez dégagé et banni {user}", "@youKickedAndBanned": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youUnbannedUser": "Vous avez débanni {user}", "@youUnbannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "separateChatTypes": "Séparer les discussions directes et les groupes", "@separateChatTypes": { - "type": "text", + "type": "String", "placeholders": {} }, "users": "Utilisateurs/trices", @@ -2160,7 +2353,9 @@ "countFiles": "{count} fichiers", "@countFiles": { "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "noKeyForThisMessage": "Cela peut se produire si le message a été envoyé avant que vous ne vous soyez connecté à votre compte sur cet appareil.\n\nIl est également possible que l'expéditeur ait bloqué votre appareil ou qu'un problème de connexion Internet se soit produit.\n\nÊtes-vous capable de lire le message sur une autre session ? Vous pouvez alors transférer le message à partir de celle-ci ! Allez dans Paramètres > Appareils et assurez-vous que vos appareils se sont vérifiés mutuellement. Lorsque vous ouvrirez le salon la fois suivante et que les deux sessions seront au premier plan, les clés seront transmises automatiquement.\n\nVous ne voulez pas perdre les clés en vous déconnectant ou en changeant d'appareil ? Assurez-vous que vous avez activé la sauvegarde de la discussion dans les paramètres.", @@ -2169,7 +2364,7 @@ "@enterRoom": {}, "allSpaces": "Tous les espaces", "@allSpaces": {}, - "commandHint_markasdm": "Marquer comme salon de messagerie directe", + "commandHint_markasdm": "Marquer comme salon de messages directs pour l'identifiant Matrix indiqué", "@commandHint_markasdm": {}, "commandHint_markasgroup": "Marquer comme groupe", "@commandHint_markasgroup": {}, @@ -2177,9 +2372,11 @@ "@confirmMatrixId": {}, "supposedMxid": "Cela devrait être {mxid}", "@supposedMxid": { - "type": "text", + "type": "String", "placeholders": { - "mxid": {} + "mxid": { + "type": "String" + } } }, "whyIsThisMessageEncrypted": "Pourquoi ce message est-il illisible ?", @@ -2212,7 +2409,9 @@ "@numChats": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "hideUnimportantStateEvents": "Masquer les événements d'état sans importance", @@ -2227,30 +2426,38 @@ "@commandHint_hug": {}, "googlyEyesContent": "{senderName} vous envoie des yeux écarquillés", "@googlyEyesContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "cuddleContent": "{senderName} vous fait un câlin", "@cuddleContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "hugContent": "{senderName} vous fait une accolade", "@hugContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "wasDirectChatDisplayName": "Discussion vide (était {oldDisplayName})", "@wasDirectChatDisplayName": { - "type": "text", + "type": "String", "placeholders": { - "oldDisplayName": {} + "oldDisplayName": { + "type": "String" + } } }, "encryptThisChat": "Chiffrer cette discussion", @@ -2273,20 +2480,22 @@ "@noBackupWarning": {}, "fileHasBeenSavedAt": "Le fichier a été enregistré dans {path}", "@fileHasBeenSavedAt": { - "type": "text", + "type": "String", "placeholders": { - "path": {} + "path": { + "type": "String" + } } }, - "fileIsTooBigForServer": "Le serveur signale que le fichier est trop volumineux pour être envoyé.", + "fileIsTooBigForServer": "Impossible d'envoyer ! Le serveur accepte uniquement les pièces jointes jusqu'à {max}.", "@fileIsTooBigForServer": {}, "jumpToLastReadMessage": "Aller au dernier message lu", "@jumpToLastReadMessage": {}, "readUpToHere": "Lisez jusqu’ici", "@readUpToHere": {}, - "allRooms": "Toutes les conversations groupées", + "allRooms": "Tous les groupes de discussion", "@allRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "chatPermissions": "Permissions du salon", @@ -2297,7 +2506,7 @@ "@inviteContactToGroupQuestion": {}, "importEmojis": "Importer des Emojis", "@importEmojis": {}, - "notAnImage": "Pas un fichier image", + "notAnImage": "Pas un fichier image.", "@notAnImage": {}, "chatDescriptionHasBeenChanged": "La description du salon a changé", "@chatDescriptionHasBeenChanged": {}, @@ -2305,75 +2514,654 @@ "@createGroup": {}, "importNow": "Importer maintenant", "@importNow": {}, - "@reportErrorDescription": {}, - "@setColorTheme": {}, - "@banUserDescription": {}, - "@removeDevicesDescription": {}, - "@tryAgain": {}, - "@unbanUserDescription": {}, - "@messagesStyle": {}, - "@chatDescription": {}, - "@pushNotificationsNotAvailable": {}, - "@invalidServerName": {}, - "@signInWithPassword": {}, - "@makeAdminDescription": {}, - "@setChatDescription": {}, - "@redactedBy": { - "type": "text", + "tryAgain": "Nouvelle tentative", + "@tryAgain": {}, + "blockedUsers": "Utilisateurs/trices bloqués", + "@blockedUsers": {}, + "redactMessageDescription": "Le message sera supprimé pour tous les participants de cette conversation. Il n'est pas possible de revenir en arrière.", + "@redactMessageDescription": {}, + "redactedBy": "Supprimé par {username}", + "@redactedBy": { + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@optionalRedactReason": {}, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@redactMessageDescription": {}, - "@invalidInput": {}, - "@report": {}, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@invitePrivateChat": {}, - "@noChatDescriptionYet": {}, - "@learnMore": {}, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "@profileNotFound": {}, - "@jump": {}, - "@shareInviteLink": {}, - "@emoteKeyboardNoRecents": { - "type": "text", + "directChat": "Discussion directe", + "@directChat": {}, + "optionalRedactReason": "(Facultatif) Raison de la suppression de ce message...", + "@optionalRedactReason": {}, + "subspace": "Sous-espace", + "@subspace": {}, + "sendTypingNotifications": "Envoyer des notifications de frappe", + "@sendTypingNotifications": {}, + "replace": "Remplacer", + "@replace": {}, + "emoteKeyboardNoRecents": "Les émoticônes récemment utilisées apparaîtront ici...", + "@emoteKeyboardNoRecents": { + "type": "String", "placeholders": {} }, - "@setTheme": {}, - "@replace": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@kickUserDescription": {}, - "@invite": {}, - "@openLinkInBrowser": {} -} \ No newline at end of file + "nothingFound": "Rien n'a été trouvé...", + "@nothingFound": {}, + "chatDescription": "Description de la discussion", + "@chatDescription": {}, + "invalidServerName": "Nom de serveur invalide", + "@invalidServerName": {}, + "addChatDescription": "Ajouter une description à la discussion...", + "@addChatDescription": {}, + "shareInviteLink": "Partager un lien d'invitation", + "@shareInviteLink": {}, + "openLinkInBrowser": "Ouvrir le lien dans le navigateur", + "@openLinkInBrowser": {}, + "setTheme": "Définir le thème :", + "@setTheme": {}, + "setColorTheme": "Définir la couleur du thème :", + "@setColorTheme": {}, + "databaseMigrationBody": "Veuillez patienter. Cela peut prendre un moment.", + "@databaseMigrationBody": {}, + "searchForUsers": "Rechercher des @utilisateurs/trices...", + "@searchForUsers": {}, + "passwordsDoNotMatch": "Les mots de passe ne correspondent pas", + "@passwordsDoNotMatch": {}, + "passwordIsWrong": "Votre mot de passe saisi est erroné", + "@passwordIsWrong": {}, + "publicLink": "Lien public", + "@publicLink": {}, + "joinSpace": "Rejoindre l'espace", + "@joinSpace": {}, + "publicSpaces": "Espaces publics", + "@publicSpaces": {}, + "addChatOrSubSpace": "Ajouter une discussion ou un sous-espace", + "@addChatOrSubSpace": {}, + "thisDevice": "Cet appareil :", + "@thisDevice": {}, + "sendReadReceipts": "Envoyer des accusés de réception", + "@sendReadReceipts": {}, + "sendTypingNotificationsDescription": "Les autres participants à une discussion peuvent voir que vous êtes en train de taper un nouveau message.", + "@sendTypingNotificationsDescription": {}, + "verifyOtherDevice": "🔐 Vérifier l'autre appareil", + "@verifyOtherDevice": {}, + "databaseBuildErrorBody": "La base de données SQlite ne peut pas être créée. L'application essaie d'utiliser la base de données existante pour le moment. Veuillez signaler cette erreur aux développeurs à {url}. Le message d'erreur est le suivant : {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "startConversation": "Démarrer la conversation", + "@startConversation": {}, + "formattedMessagesDescription": "Affichez le contenu formaté des messages comme du texte en gras à l'aide de markdown.", + "@formattedMessagesDescription": {}, + "incomingMessages": "Messages entrants", + "@incomingMessages": {}, + "acceptedKeyVerification": "{sender} a accepté la vérification de clé", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "pleaseTryAgainLaterOrChooseDifferentServer": "Veuillez réessayer plus tard ou choisir un autre serveur.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "inviteGroupChat": "📨 Inviter à une discussion de groupe", + "@inviteGroupChat": {}, + "invitePrivateChat": "📨 Inviter à une discussion privée", + "@invitePrivateChat": {}, + "jump": "Sauter", + "@jump": {}, + "signInWithPassword": "Se connecter avec mot de passe", + "@signInWithPassword": {}, + "hideMemberChangesInPublicChats": "Masquer les modifications de membres dans les discussions publiques", + "@hideMemberChangesInPublicChats": {}, + "hideMemberChangesInPublicChatsBody": "Ne pas afficher dans la chronologie de la discussion si quelqu'un rejoint ou quitte une discussion publique afin d'améliorer la lisibilité.", + "@hideMemberChangesInPublicChatsBody": {}, + "overview": "Aperçu", + "@overview": {}, + "notifyMeFor": "Me notifier pour", + "@notifyMeFor": {}, + "passwordRecoverySettings": "Paramètres de récupération de mot de passe", + "@passwordRecoverySettings": {}, + "hasKnocked": "🚪 {user} a frappé", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} a annulé la vérification de clé", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "unreadChatsInApp": "{appname} : {unread} discussions non lus", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} a demandé une vérification de clé", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} a lancé la vérification de clé", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "discover": "Découvrir", + "@discover": {}, + "usersMustKnock": "Les utilisateurs/trices doivent frapper", + "@usersMustKnock": {}, + "noOneCanJoin": "Personne ne peut rejoindre", + "@noOneCanJoin": {}, + "knock": "Frapper à la porte", + "@knock": {}, + "hidePresences": "Cacher la liste des statuts ?", + "@hidePresences": {}, + "appLockDescription": "Verrouiller l'application avec un code PIN lorsqu'elle n'est pas utilisée", + "@appLockDescription": {}, + "globalChatId": "Identifiant global de la discussion", + "@globalChatId": {}, + "accessAndVisibility": "Accès et visibilité", + "@accessAndVisibility": {}, + "accessAndVisibilityDescription": "Qui est autorisé à rejoindre cette discussion et comment la discussion peut être découverte.", + "@accessAndVisibilityDescription": {}, + "calls": "Appels", + "@calls": {}, + "customEmojisAndStickers": "Émoticônes et autocollants personnalisés", + "@customEmojisAndStickers": {}, + "hideRedactedMessages": "Cacher les messages supprimés", + "@hideRedactedMessages": {}, + "pleaseEnterYourCurrentPassword": "Veuillez saisir votre mot de passe actuel", + "@pleaseEnterYourCurrentPassword": {}, + "swipeRightToLeftToReply": "Glisser de droite à gauche pour répondre", + "@swipeRightToLeftToReply": {}, + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "hideRedactedMessagesBody": "Si quelqu'un supprime un message, celui-ci ne sera plus visible dans la discussion.", + "@hideRedactedMessagesBody": {}, + "customEmojisAndStickersBody": "Ajoutez ou partagez des émoticônes ou autocollants personnalisés qui peuvent être utilisés dans n'importe quelle discussion.", + "@customEmojisAndStickersBody": {}, + "blockListDescription": "Vous pouvez bloquer des utilisateurs/trices qui vous dérangent. Vous ne pourrez plus recevoir aucun message ou invitation à un salon d'utilisateurs/trices figurant sur votre liste de blocage personnelle.", + "@blockListDescription": {}, + "blockUsername": "Ignorer le nom d'utilisateur/trice", + "@blockUsername": {}, + "hideInvalidOrUnknownMessageFormats": "Masquer les formats de message invalides ou inconnus", + "@hideInvalidOrUnknownMessageFormats": {}, + "messagesStyle": "Messages :", + "@messagesStyle": {}, + "redactedByBecause": "Supprimé par {username} car : \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "setChatDescription": "Définir la description de la discussion", + "@setChatDescription": {}, + "presenceStyle": "Statut :", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Afficher les messages de statut des autres utilisateurs/trices", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "youInvitedToBy": "📩 Vous avez été invité par lien à :\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "userWouldLikeToChangeTheChat": "{user} souhaite rejoindre la discussion.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Aucun lien public n'a encore été crée", + "@noPublicLinkHasBeenCreatedYet": {}, + "gallery": "Galerie", + "@gallery": {}, + "files": "Fichiers", + "@files": {}, + "sessionLostBody": "Votre session est perdue. Veuillez signaler cette erreur aux développeurs à {url}. Le message d'erreur est le suivant : {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "searchIn": "Rechercher dans la discussion \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "forwardMessageTo": "Transférer le message à {roomName} ?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "Les autres participants à une discussion peuvent voir si vous avez lu un message.", + "@sendReadReceiptsDescription": {}, + "formattedMessages": "Messages formatés", + "@formattedMessages": {}, + "verifyOtherUser": "🔐 Vérifier l'autre utilisateur/trice", + "@verifyOtherUser": {}, + "searchMore": "Rechercher davantage...", + "@searchMore": {}, + "verifyOtherUserDescription": "Si vous vérifiez un autre utilisateur/trice, vous pouvez être sûr de savoir à qui vous écrivez réellement. 💪\n\nLorsque vous lancez une vérification, vous et l'autre utilisateur/trice verrez une fenêtre contextuelle dans l'application. Vous y verrez alors une série d'émoticônes ou de chiffres que vous devrez comparer.\n\nLa meilleure façon de procéder est de se rencontrer ou de lancer un appel vidéo. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDeviceDescription": "Lorsque vous vérifiez un autre appareil, ces appareils peuvent échanger des clés, ce qui augmente votre sécurité globale. 💪 Lorsque vous lancez une vérification, une fenêtre contextuelle s'affiche dans l'application sur les deux appareils. Vous y verrez alors une série d'émoticônes ou de chiffres que vous devrez comparer. Il est préférable d'avoir les deux appareils à portée de main avant de lancer la vérification. 🤳", + "@verifyOtherDeviceDescription": {}, + "completedKeyVerification": "{sender} a terminé la vérification de clé", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} est prêt pour la vérification de clé", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Transparent", + "@transparent": {}, + "stickers": "Autocollants", + "@stickers": {}, + "noDatabaseEncryption": "Le chiffrement de la base de données n'est pas supporté sur cette plateforme", + "@noDatabaseEncryption": {}, + "commandHint_ignore": "Ignorer l'identifiant Matrix indiqué", + "@commandHint_ignore": {}, + "commandHint_unignore": "Ne plus ignorer l'identifiant Matrix indiqué", + "@commandHint_unignore": {}, + "thereAreCountUsersBlocked": "Actuellement, il y a {count} utilisateurs/trices bloqués.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "Limité", + "@restricted": {}, + "knockRestricted": "Frapper à la porte limité", + "@knockRestricted": {}, + "signInWith": "Se connecter avec {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "groupCanBeFoundViaSearch": "Le groupe peut être trouvé via la recherche", + "@groupCanBeFoundViaSearch": {}, + "groupName": "Nom du groupe", + "@groupName": {}, + "invalidInput": "Entrée invalide !", + "@invalidInput": {}, + "block": "Bloquer", + "@block": {}, + "removeDevicesDescription": "Vous serez déconnecté de cet appareil et ne pourrez plus recevoir de messages.", + "@removeDevicesDescription": {}, + "userRole": "Rôle de l'utilisateur/trice", + "@userRole": {}, + "createNewAddress": "Créer une nouvelle adresse", + "@createNewAddress": {}, + "publicChatAddresses": "Addresses de discussion publiques", + "@publicChatAddresses": {}, + "countChatsAndCountParticipants": "{chats} discussions et {participants} participants", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "space": "Espace", + "@space": {}, + "spaces": "Espaces", + "@spaces": {}, + "noMoreChatsFound": "Aucune autre discussion trouvée...", + "@noMoreChatsFound": {}, + "unread": "Non lu", + "@unread": {}, + "joinedChats": "Discussions rejointes", + "@joinedChats": {}, + "commandHint_sendraw": "Envoyer du JSON brut", + "@commandHint_sendraw": {}, + "databaseMigrationTitle": "La base de données est optimisée", + "@databaseMigrationTitle": {}, + "leaveEmptyToClearStatus": "Laisser vide pour effacer votre statut.", + "@leaveEmptyToClearStatus": {}, + "select": "Sélectionner", + "@select": {}, + "reportErrorDescription": "😭 Oh non. Quelque chose s'est mal passé. Si vous le souhaitez, vous pouvez signaler ce bogue aux développeurs.", + "@reportErrorDescription": {}, + "report": "signaler", + "@report": {}, + "wrongPinEntered": "Mauvais code PIN saisi ! Veuillez réessayer dans {seconds} secondes...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pushNotificationsNotAvailable": "Notifications poussées indisponibles", + "@pushNotificationsNotAvailable": {}, + "yourGlobalUserIdIs": "Votre identifiant utilisateur global est : ", + "@yourGlobalUserIdIs": {}, + "chatCanBeDiscoveredViaSearchOnServer": "La discussion peut être découverte via la recherche sur {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "knocking": "Frapper", + "@knocking": {}, + "banUserDescription": "L'utilisateur/trice sera banni de la discussion et ne pourra plus y accéder jusqu'à ce qu'il/elle soit débanni.", + "@banUserDescription": {}, + "unbanUserDescription": "L'utilisateur/trice pourra entrer à nouveau dans la discussion si il/elle le souhaite.", + "@unbanUserDescription": {}, + "kickUserDescription": "L'utilisateur/trice est expulsé de la discussion mais n'est pas banni. Dans les discussions publiques, l'utilisateur/trice peut revenir à tout moment.", + "@kickUserDescription": {}, + "makeAdminDescription": "Une fois que vous aurez nommé cet utilisateur/trice administrateur, vous ne pourrez peut-être plus annuler cette opération, car il disposera alors des mêmes autorisations que vous.", + "@makeAdminDescription": {}, + "newPassword": "Nouveau mot de passe", + "@newPassword": {}, + "pleaseChooseAStrongPassword": "Veuillez choisir un mot de passe fort", + "@pleaseChooseAStrongPassword": {}, + "decline": "Refuser", + "@decline": {}, + "initAppError": "Une erreur est survenue pendant l'initialisation de l'application", + "@initAppError": {}, + "markAsUnread": "Marquer comme non lu", + "@markAsUnread": {}, + "wrongRecoveryKey": "Désolé... il ne semble pas s'agir de la bonne clé de récupération.", + "@wrongRecoveryKey": {}, + "searchChatsRooms": "Rechercher des #discussions, @utilisateurs/trices...", + "@searchChatsRooms": {}, + "createGroupAndInviteUsers": "Créer un groupe et inviter des utilisateurs/trices", + "@createGroupAndInviteUsers": {}, + "goToSpace": "Aller dans l'espace : {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "exportEmotePack": "Exporter le pack d'émoticônes au format .zip", + "@exportEmotePack": {}, + "noChatDescriptionYet": "Aucune description de discussion n'a encore été créée.", + "@noChatDescriptionYet": {}, + "invite": "Inviter", + "@invite": {}, + "pleaseEnterANumber": "Veuillez saisir un nombre supérieur à 0", + "@pleaseEnterANumber": {}, + "roomUpgradeDescription": "La discussion sera alors recréé avec la nouvelle version de salon. Tous les participants seront informés qu'ils doivent passer à la nouvelle discussion. Pour en savoir plus sur les versions des salons, consultez le site https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "learnMore": "En savoir plus", + "@learnMore": {}, + "minimumPowerLevel": "{level} est le niveau minimum de droits.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "restoreSessionBody": "L'application tente maintenant de restaurer votre session depuis la sauvegarde. Veuillez signaler cette erreur aux développeurs à {url}. Le message d'erreur est le suivant : {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "profileNotFound": "Cet utilisateur/trice n'a pu être trouvé sur le serveur. Peut-être est-ce un problème de connexion ou l'utilisateur/trice n'existe pas.", + "@profileNotFound": {}, + "archiveRoomDescription": "La discussion sera déplacée dans les archives. Les autres utilisateurs/trices pourront voir que vous avez quitté la discussion.", + "@archiveRoomDescription": {}, + "noUsersFoundWithQuery": "Malheureusement, aucun utilisateur/trice n'a pu être trouvé avec \"{query}\". Veuillez vérifier si vous n'avez pas fait de faute de frappe.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "noChatsFoundHere": "Aucune discussion trouvée. Utilisez le bouton ci-dessous pour commencer une nouvelle discussion. ⤵️", + "@noChatsFoundHere": {}, + "aboutHomeserver": "À propos de {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "changeTheDescriptionOfTheGroup": "Modifier la description de la discussion", + "@changeTheDescriptionOfTheGroup": {}, + "userLevel": "{level} — Membre", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "chatPermissionsDescription": "Définir quel niveau de pouvoir est nécessaires pour certaines actions dans cette discussion. Les niveaux de pouvoir 0, 50 et 100 représentent généralement les membres, la modération et l'administration, mais toute gradation est possible.", + "@chatPermissionsDescription": {}, + "changeGeneralChatSettings": "Modifier les paramètres généraux de la discussion", + "@changeGeneralChatSettings": {}, + "invitedBy": "📩 Invitation par {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "moderatorLevel": "{level} — Modération", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "sendCanceled": "Envoi annulé", + "@sendCanceled": {}, + "adminLevel": "{level} — Administration", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "inviteOtherUsers": "Inviter d'autres membres dans cette discussion", + "@inviteOtherUsers": {}, + "changeTheChatPermissions": "Modifier les autorisations de cette discussion", + "@changeTheChatPermissions": {}, + "changeTheVisibilityOfChatHistory": "Modifier la visibilité de l'historique de la discussion", + "@changeTheVisibilityOfChatHistory": {}, + "changeTheCanonicalRoomAlias": "Modifier l'adresse publique principale de la discussion", + "@changeTheCanonicalRoomAlias": {}, + "changelog": "Journal des modifications", + "@changelog": {}, + "synchronizingPleaseWaitCounter": " Synchronisation… ({percentage} %)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "updateInstalled": "🎉 La mise à niveau {version} est installée !", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "loginWithMatrixId": "Connexion avec l'identifiant Matrix", + "@loginWithMatrixId": {}, + "setCustomPermissionLevel": "Définir un niveau d’autorisation", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Veuillez choisir un rôle prédéfini ci-dessous ou saisir un niveau d’autorisation entre 0 et 100.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Ignorer l'utilisateur", + "@ignoreUser": {}, + "normalUser": "Utilisateur standard", + "@normalUser": {}, + "checkList": "Check-list", + "@checkList": {}, + "countInvited": "{count} invité(e/s)", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendImages": "Envoyer {count} image(s)", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "homeserverDescription": "Toutes vos données sont stockées sur le serveur de votre fournisseur matrix, comme chez un fournisseur d'e-mails. Vous pouvez choisir le serveur que vous souhaitez utiliser, tout en pouvant communiquer avec tout le monde. Pour en savoir plus, rendez-vous sur https://matrix.org.", + "@homeserverDescription": {}, + "calculatingFileSize": "Calcul en cours...", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "Préparation à l'envoi...", + "@prepareSendingAttachment": {}, + "sendingAttachment": "Envoi en cours...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "Génération de la vignette...", + "@generatingVideoThumbnail": {}, + "compressVideo": "Compression de la vidéo...", + "@compressVideo": {}, + "sendingAttachmentCountOfCount": "Envoi {index} sur {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Nombre de tentatives dépassé! Patientez {seconds} secondes...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Un de vos appareils n'est pas vérifié", + "@oneOfYourDevicesIsNotVerified": {}, + "customReaction": "Réaction", + "@customReaction": {}, + "declineInvitation": "Refuser l'invitation", + "@declineInvitation": {}, + "invalidUrl": "Adresse incorrecte", + "@invalidUrl": {}, + "addAnswerOption": "Ajouter une réponse", + "@addAnswerOption": {}, + "addLink": "Ajouter un lien", + "@addLink": {}, + "allowMultipleAnswers": "Autoriser plusieurs réponses", + "@allowMultipleAnswers": {} +} diff --git a/lib/l10n/intl_ga.arb b/lib/l10n/intl_ga.arb new file mode 100644 index 000000000..caae5d78e --- /dev/null +++ b/lib/l10n/intl_ga.arb @@ -0,0 +1,3165 @@ +{ + "you": "Tú", + "@you": { + "type": "String", + "placeholders": {} + }, + "yes": "Tá", + "@yes": { + "type": "String", + "placeholders": {} + }, + "warning": "Rabhadh!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Cúlbhrat:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "verify": "Deimhnigh", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verified": "Deimhnithe", + "@verified": { + "type": "String", + "placeholders": {} + }, + "username": "Ainm úsáideora", + "@username": { + "type": "String", + "placeholders": {} + }, + "unpin": "Bain biorán", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Níl ar fáil", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "systemTheme": "Córas", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "submit": "Cuir isteach", + "@submit": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Conas atá tú inniu?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "status": "Staid", + "@status": { + "type": "String", + "placeholders": {} + }, + "skip": "Léim", + "@skip": { + "type": "String", + "placeholders": {} + }, + "share": "Roinn", + "@share": { + "type": "String", + "placeholders": {} + }, + "settings": "Socruithe", + "@settings": { + "type": "String", + "placeholders": {} + }, + "send": "Seol", + "@send": { + "type": "String", + "placeholders": {} + }, + "security": "Slándáil", + "@security": { + "type": "String", + "placeholders": {} + }, + "search": "Cuardaigh", + "@search": { + "type": "String", + "placeholders": {} + }, + "reply": "Freagair", + "@reply": { + "type": "String", + "placeholders": {} + }, + "remove": "Bain", + "@remove": { + "type": "String", + "placeholders": {} + }, + "rejoin": "Téigh ar ais isteach", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "reject": "Diúltaigh", + "@reject": { + "type": "String", + "placeholders": {} + }, + "register": "Cláraigh", + "@register": { + "type": "String", + "placeholders": {} + }, + "recording": "Ag Taifeadadh", + "@recording": { + "type": "String", + "placeholders": {} + }, + "reason": "Fáth", + "@reason": { + "type": "String", + "placeholders": {} + }, + "privacy": "Príobháideacht", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "pin": "Biorán", + "@pin": { + "type": "String", + "placeholders": {} + }, + "people": "Daoine", + "@people": { + "type": "String", + "placeholders": {} + }, + "password": "Pasfhocal", + "@password": { + "type": "String", + "placeholders": {} + }, + "participant": "Rannpháirtí", + "@participant": { + "type": "String", + "placeholders": {} + }, + "directChats": "Comhráite Díreacha", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID gléis", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Scrios an teachtaireacht", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Scrios an cuntas", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Spás nua", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "countParticipants": "{count} rannpháirtithe", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "or": "Nó", + "@or": { + "type": "String", + "placeholders": {} + }, + "online": "Ar líne", + "@online": { + "type": "String", + "placeholders": {} + }, + "ok": "Ceart go leor", + "@ok": { + "type": "String", + "placeholders": {} + }, + "offline": "As líne", + "@offline": { + "type": "String", + "placeholders": {} + }, + "offensive": "Maslach", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "notifications": "Fógraí", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "none": "Aon cheann", + "@none": { + "type": "String", + "placeholders": {} + }, + "no": "Níl", + "@no": { + "type": "String", + "placeholders": {} + }, + "next": "Ar Aghaidh", + "@next": { + "type": "String", + "placeholders": {} + }, + "moderator": "Modhnóir", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "messages": "Teachtaireachtaí", + "@messages": { + "type": "String", + "placeholders": {} + }, + "mention": "Luaigh", + "@mention": { + "type": "String", + "placeholders": {} + }, + "logout": "Logáil amach", + "@logout": { + "type": "String", + "placeholders": {} + }, + "login": "Logáil isteach", + "@login": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Solas", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "license": "Ceadúnas", + "@license": { + "type": "String", + "placeholders": {} + }, + "leave": "Fág", + "@leave": { + "type": "String", + "placeholders": {} + }, + "invited": "Le cuireadh", + "@invited": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Neamhurchóideach", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "ignore": "Tabhair neamhaird ar", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "identity": "Aitheantas", + "@identity": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "help": "Cabhair", + "@help": { + "type": "String", + "placeholders": {} + }, + "groups": "Grúpaí", + "@groups": { + "type": "String", + "placeholders": {} + }, + "group": "Grúpa", + "@group": { + "type": "String", + "placeholders": {} + }, + "forward": "Seol ar aghaidh", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Freastalaí baile", + "encryption": "Criptiúchán", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Criptithe", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "edit": "Cuir in eagar", + "@edit": { + "type": "String", + "placeholders": {} + }, + "devices": "Gléasanna", + "@devices": { + "type": "String", + "placeholders": {} + }, + "device": "Gléas", + "@device": { + "type": "String", + "placeholders": {} + }, + "delete": "Scrios", + "@delete": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{day}/{month}/{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}/{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "containsUserName": "Coinníonn sé ainm úsáideora", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Cumraigh comhrá", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "commandInvalid": "Ordú neamhbhailí", + "@commandInvalid": { + "type": "String" + }, + "commandHint_send": "Seol téacs", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_me": "Déan cur síos ort féin", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "clearArchive": "Glan an cartlann", + "chatDetails": "Sonraí comhrá", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Cúltaca comhrá", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "D'athraigh {username} abhatár an chomhrá", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeDeviceName": "Athraigh ainm an ghléis", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Ní féidir an URI {uri} a oscailt", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "cancel": "Cealaigh", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Teachtaireachtaí bota", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "blocked": "Bactha", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "Bac Gléas", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "Chuir {username} cosc ar {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "banned": "Coiscthe", + "@banned": { + "type": "String", + "placeholders": {} + }, + "banFromChat": "Toirmisc ón gcomhrá", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Seol ar iontráil", + "archive": "Cartlann", + "@archive": { + "type": "String", + "placeholders": {} + }, + "appLock": "Bac aip", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "anyoneCanJoin": "Is féidir le aon duine dul isteach", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "D'fhreagair {senderName} an glao", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "allChats": "Gach comhrá", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "all": "Gach", + "@all": { + "type": "String", + "placeholders": {} + }, + "alias": "ailias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "admin": "Riarthóir", + "@admin": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Cuir go spás", + "addEmail": "Cuir ríomhphoist", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} criptithe deireadh go deireadh gníomhachtaithe", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Cuntas", + "@account": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 Ghlac {username} leis an gcuireadh", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "accept": "Glac", + "@accept": { + "type": "String", + "placeholders": {} + }, + "about": "Faoi", + "@about": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Glac leis an iarratas fíoraithe seo ó {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "areYouSureYouWantToLogout": "An bhfuil tú cinnte gur mhaith leat logáil amach?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "An bhfuil tú cinnte?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "An bhfuil cead ag úsáideoirí aoi páirt a ghlacadh?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 thug {username} cuireadh do {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "hideRedactedEvents": "Folaigh imeachtaí athdhéanta", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Is féidir le haíonna páirt a ghlacadh", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "guestsAreForbidden": "Tá cosc ar aíonna", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grúpa le {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "groupIsPublic": "Tá an grúpa poiblí", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Ón gcuireadh", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Cuir isteach do fhreastalaí baile", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Gearrchód emote neamhbhailí!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Tá iomaite ann cheana féin!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Cuir in eagar abhatár an tseomra", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Cuir ailiasanna an tseomra in eagar", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Cuir freastalaí blocáilte in eagar", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Leibhéal ceada réamhshocraithe d'úsáideoirí nua", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "unblockDevice": "Díbhlocáil Gléas", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Tugadh cuireadh don theagmháil a thar isteach sa grúpa", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Cuir na huimhreacha i gcomparáid le do thoil", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Cuir na emojis i gcomparáid le do thoil", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "commandMissing": "Ní ordú é {command}.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "commandHint_react": "Seol freagra mar fhreagairt", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_op": "Socraigh leibhéal cumhachta an úsáideora áirithe (réamhshocrú: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_myroomnick": "Socraigh d'ainm taispeána don seomra seo", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_myroomavatar": "Cuir do phictiúr don seomra seo (le mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_kick": "Bain an t-úsáideoir áirithe den seomra seo", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_join": "Téigh isteach sa seomra áirithe", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_ban": "Cuir cosc ar an úsáideoir áirithe ón seomra seo", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_invite": "Cuir cosc ar an úsáideoir áirithe ón seomra seo", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "chooseAStrongPassword": "Roghnaigh pasfhocal láidir", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Cuireadh comhrá leis an spás seo", + "chatBackupDescription": "Tá do theachtaireachtaí slán le heochair aisghabhála. Déan cinnte nach gcaillfidh tú í.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Truaillíodh an criptiú", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Athraigh ainm an ghrúpa", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changedTheRoomInvitationLink": "D'athraigh {username} nasc an chuiridh", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "D'athraigh {username} ailiasanna an tseomra", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "D'athraigh {username} a n-abhatár", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "D'athraigh {username} na rialacha ceangail go: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "D'athraigh {username} na rialacha ceangail", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "D'athraigh {username} infheictheacht na staire go: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "D'athraigh {username} infheictheacht na staire", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "D'athraigh {username} a n-ainm taispeána go: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "D'athraigh {username} na ceadanna comhrá", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "D'athraigh {username} an t-ainm comhrá go: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "D'athraigh {username} an cur síos comhrá go: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "autoplayImages": "Seinn greamáin agus straoiseog beoite go huathoibríoch", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "createdTheChat": "💬 chruthaigh {username} an comhrá", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "copyToClipboard": "Cóipeáil ar an ghearrthaisce", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Cóipeáilte ar an ghearrthaisce", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Coinníonn sé ainm taispeána", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "commandHint_plain": "Seol téacs neamhfhoirmithe", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_leave": "Fág an seomra seo", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_html": "Seol téacs HTML-formáidithe", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "changeYourAvatar": "Athraigh do abhatár", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Athraigh do stíl", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Athraigh an freastalaí baile", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Glórphost", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Físghlao", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Tosaigh Fíorú", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "unmuteChat": "Neamhciúnaigh comhrá", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Folaigh imeachtaí anaithnide", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Gléas anaithnid", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Marcáil Léite/Neamhléite", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Scoránaigh mar ciúnaithe", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Scoránaigh mar ceann is fearr leat", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Tá siad céanna", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Ainm an spáis", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Cód foinseach", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Taispeáin pasfhocal", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Roinn suíomh", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Cuir stádas", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Seol físeán", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Seol greamán", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Seol an bunchóip", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Seol teachtaireachtaí", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Seol íomhá", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Seol comhad", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Seol fuaim", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Sábháil comhad", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Leagan seomra", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Iarr cead", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Tuairiscigh teachtaireacht", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "removeDevice": "Bain gléas", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "Bain teachtaireacht amach", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Rialacha na bhfógraí", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Seomraí Poiblí", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Roghnaigh le do thoil", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "play": "Seinn {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "passwordRecovery": "Aisfháil pasfhocail", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Pasfhocal dearmadta", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Oscail ceamara", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "ag Aimsiú an suíomh…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Gan cead", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "newChat": "Comhrá nua", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Ciúnaigh comhrá", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Athruithe ball", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Lódáil níos mó…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "Téigh isteach sa seomra", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "isTyping": "ag clóscríobh…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Tabhair cuireadh do theagmháil", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Úsáideoirí a dtugann tú neamhaird orthu", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Ó tar isteach", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Méid cló", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Tosaigh criptiú", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Cuir ainm taispeána in eagar", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Gníomhach faoi láthair", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Ainm an chomhaid", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Gach rud réidh!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Comhrá folamh", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Gearrchód straoiseoige", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Socruithe straoiseoige", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Íoslódáil comhad", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "changePassword": "Athraigh an pasfhocal", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Dorcha", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "create": "Cruthaigh", + "@create": { + "type": "String", + "placeholders": {} + }, + "copy": "Cóipeáil", + "@copy": { + "type": "String", + "placeholders": {} + }, + "connect": "Ceangail", + "@connect": { + "type": "String", + "placeholders": {} + }, + "confirm": "Dearbhaigh", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "close": "Dún", + "@close": { + "type": "String", + "placeholders": {} + }, + "chats": "Comhráite", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chat": "Comhrá", + "@chat": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "Scan cód QR", + "inviteText": "Thug {username} cuireadh duit chuig FluffyChat.\n1. Tabhair cuairt ar fluffychat.im agus a shuiteáil an app\n2. Cláraigh nó sínigh isteach\n3. Oscail an nasc cuirí:\n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "noMatrixServer": "Níl {server1} freastalaí Matrix. Úsáid {server2} ina áit sin?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "noGoogleServicesWarning": "Is cosúil nach bhfuil Firebase Cloud Messaging ar fáil ar do ghléas. Chun fógraí brú a fháil fós, molaimid ntfy a shuiteáil. Le ntfy nó soláthraí Unified Push eile is féidir leat fógraí brú a fháil ar bhealach atá slán ó thaobh sonraí. Is féidir leat ntfy a íoslódáil ón PlayStore nó ó F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Ní féidir leat criptiú a ghníomhachtú ach a luaithe nach bhfuil an seomra inrochtana go poiblí a thuilleadh.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Níor aimsíodh aon straoiseoga. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Gan aon nasc leis an bhfreastalaí", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Iarratas fíoraithe nua!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Teachtaireacht nua in FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Bí ar an eolas go dteastaíonn Pantalaimon uait chun criptiú ó cheann go ceann a úsáid anois.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Logáil isteach chuig {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "locationPermissionDeniedNotice": "Diúltaíodh cead suímh. Deonaigh dóibh le do thoil go mbeidh tú in ann do shuíomh a roinnt.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Tá seirbhísí suímh díchumasaithe. Cuir ar a gcumas le do thoil a bheith in ann do shuíomh a roinnt.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "loadingPleaseWait": "Ag lódáil… Fan, le do thoil.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Lódáil {count} níos mó rannpháirtithe", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "leftTheChat": "Fágadh an comhrá", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Gníomhach deireanach: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "kickFromChat": "Caith é amach as an comhrá", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 chiceáil {username} {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 chiceáil {username} agus chuir sé cosc ar {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "joinedTheChat": "Tháinig 👋 {username} isteach sa chomhrá", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Úsáideoirí le cuireadh amháin", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Tabhair cuireadh do theagmháil chuig {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "incorrectPassphraseOrKey": "Pasfhrása nó eochair téarnaimh mícheart", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Chliceáil mé ar an nasc", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Cé chomh maslach atá an t-ábhar seo?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Fíor-maslach", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "Tharraing {username} an cuireadh do {targetName} siar", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "goToTheNewRoom": "Téigh go dtí an seomra nua", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Earráid maidir le suíomh a fháil: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Cuir isteach seoladh ríomhphoist", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "Chuir {senderName} deireadh leis an nglao", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "encryptionNotEnabled": "Ní chumasaítear criptiú", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Ní bheidh in ann an criptiú a dhíchumasú níos mó. An bhfuil tú cinnte?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Cumasaigh pacáiste straoiseoige go huilíoch", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Caithfidh tú gearrchód straoiseoige agus íomhá a roghnú!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Pacáistí straoiseoige don seomra", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Athraíodh an t-ainm taispeána", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "deactivateAccountWarning": "Díghníomhachtaeoidh sé seo do chuntas úsáideora. Ní féidir é seo a chealú! An bhfuil tú cinnte?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Níorbh fhéidir teachtaireacht a dhíchriptiú: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "contentHasBeenReported": "Tuairiscíodh an t-ábhar do lucht riaracháin an fhreastalaí", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "commandHint_unban": "Cuir deireadh an cosc den úsáideoir áirithe ón seomra seo", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "changedTheGuestAccessRulesTo": "D'athraigh {username} na rialacha maidir le rochtain aoi chuig: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "D'athraigh {username} na rialacha rochtana aoi", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerVersionsException": "Tá na leaganacha sonraíochta seo ar fáil faoin freastalaí baile:\n{serverVersions}\nAch níl ach na ceann seo ar fáil faoin aip seo {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "Tá na cineálacha logála isteach seo ar fáil faoin freastalaí baile:\n{serverVersions}\nAch níl ach na ceann seo ar fáil faoin aip seo:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "askSSSSSign": "Chun a bheith in ann an duine eile a shíniú, cuir isteach do phasfhrása stóir sábháilte nó d'eochair téarnaimh.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "D'eochair phoiblí", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Cuireadh cosc ort ón gcomhrá seo", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Níl tú ag glacadh páirte sa chomhrá seo a thuilleadh", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Scríobh teachtaireacht…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Leis na seoltaí seo is féidir leat do phasfhocal a athshlánú.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "An bhfuil fonn ort cúltaca do chomhrá a scriosadh chun eochair athshlánaithe nua a chruthú?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Cén fáth ar mhaith leat é seo a thuairisciú?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Cé a bhfuil cead aige/aici dul isteach sa ghrúpa seo", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Cé atá in ann an gníomh a dhéanamh", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "D'fhíoraigh tú go rathúil!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "userLeftTheChat": "🚪 D'fhág {username} an comhrá", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userAndUserAreTyping": "Tá {username} agus {username2} ag clóscríobh…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userAndOthersAreTyping": "tá {username} agus {count} daoine eile ag clóscríobh…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "unreadChats": "{unreadCount, plural, =1{1 comhrá neamhléite} other{{unreadCount} comhráite neamhléite}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "unknownEncryptionAlgorithm": "Algartam criptithe anaithnid", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "Chuir {username} deireadh an cosc {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "tryToSendAgain": "Déan iarracht a sheoladh arís", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Aistriú ó ghléas eile", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "An iomarca iarratas. Bain triail eile as níos déanaí!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Níl siad céanna", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "Roinn {username} a suíomh", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "setPermissionsLevel": "Socraigh leibhéal ceadanna", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Socraigh nasc cuiridh", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Socraigh straoiseoga saincheaptha", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Socraigh mar phríomh-ailias", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "sentCallInformations": "Sheol {senderName} faisnéis maidir le glaonna", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 sheol {username} físeán", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 sheol {username} greamán", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ sheol {username} pictiúr", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "replaceRoomWithNewerVersion": "Cuir leagan seomra níos nuaí in ionad an tseomra", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Bain d'abhatár", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Cuir deireadh an cosc ón gcomhrá", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Bainte de ag {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeAllOtherDevices": "Bain gach gléas eile", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "Dhiúltaigh {username} don chuireadh", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactedAnEvent": "Rinne {username} cinsire imeacht", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "pleaseFollowInstructionsOnWeb": "Lean na treoracha ar an suíomh gréasáin agus tapáil \"ar aghaidh\".", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Cuir isteach d'ainm úsáideora le do thoil", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Cuir isteach do uap le do thoil", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Iontráil do phasfhocal le do thoil", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Iontráil 4 dhigit le do thoil nó fág folamh chun glas aipe a dhíchumasú.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Cliceáil ar an nasc sa ríomhphost agus ansin lean ar aghaidh.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Roghnaigh paschód le do thoil", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Roghnaigh íomhá", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Athraíodh an pasfhocal", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "pasfhrása nó eochair téarnaimh", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "Ní mór don fhreastalaí seo do sheoladh ríomhphoist a bhailíochtú le haghaidh clárúcháin.", + "openInMaps": "Oscail i léarscáileanna", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Oscail an aip chun teachtaireachtaí a léamh", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Úps, chuaigh rud éigin mícheart …", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Hoips! Ar an drochuair, tharla earráid nuair a bhí na fógraí brú á mbunú.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Tá Cúltaca Eochair Ar Líne cumasaithe", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "Tá {count} úsáideoirí ag clóscríobh…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "notificationsEnabledForThisAccount": "Fógraí cumasaithe don chuntas seo", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Níor aimsíodh aon seomraí…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Níor chuir tú bealach leis do phasfhocal a aisghabháil fós.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Tabhair cuireadh dom", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Sheolamar ríomhphost chugat", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Ag fanacht le comhpháirtí glacadh leis na huimhreacha …", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Ag fanacht le comhpháirtí glacadh leis na straoiseoga…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Ag fanacht le comhpháirtí glacadh leis an iarratas…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Infheicthe do gach duine", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Infheicthe do na rannpháirtithe go léir", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Infheictheacht stair na comhrá", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Ag fíorú cuntas eile", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "Sheol {username} imeacht {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "userIsTyping": "Tá {username} ag clóscríobh…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "unknownEvent": "Imeacht anaithnid '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "synchronizingPleaseWait": "Ag sioncrónú... Fan, le do thoil.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "startedACall": "Thosaigh {senderName} glao", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "spaceIsPublic": "Tá an spás poiblí", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Sínigh Aonair ar", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "sentAnAudio": "🎤 sheol {username} fuaim", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAFile": "📁 sheol {username} comhad", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sendAsText": "Seol mar théacs", + "@sendAsText": { + "type": "String" + }, + "sendAMessage": "Seol teachtaireacht", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Le feiceáil ag {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "roomHasBeenUpgraded": "Uasghrádaíodh an seomra", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "addAccount": "Breisigh cuntas", + "enableMultiAccounts": "(BÉITE) Cumasaigh cuntais iomadúla ar an gléas seo", + "commandHint_create": "Cruthaigh comhrá grúpa folamh\nÚsáid --no-encryption chun criptiúchán a dhíchumasú", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "link": "Nasc", + "commandHint_clearcache": "Glan an taisce", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "videoCallsBetaWarning": "Tabhair faoi deara go bhfuil físglaonna i béite. B'fhéidir nach bhfeidhmíonn siad ar gach ardán chomh atá súil aige ná ar bith.", + "emailOrUsername": "Ríomhphost nó ainm úsáideora", + "repeatPassword": "Scríobh an pasfhocal arís", + "yourChatBackupHasBeenSetUp": "Bunaíodh do chúltaca comhrá.", + "openVideoCamera": "Oscail físcheamara", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "fileHasBeenSavedAt": "Sábháladh an comhad ag {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "editBundlesForAccount": "Cuir cuachta in eagar don chuntas seo", + "globalChatId": "Aitheantas comhrá domhanda", + "hideMemberChangesInPublicChatsBody": "Ná taispeáin san amlíne comhrá má théann duine isteach i gcomhrá poiblí nó má fhágann sé nó sí é chun inléiteacht a fheabhsú.", + "pleaseEnterRecoveryKey": "Cuir isteach d'eochair athshlánaithe le do thoil:", + "sender": "Seoltóir", + "noOneCanJoin": "Ní féidir le duine ar bith páirt a ghlacadh", + "noOtherDevicesFound": "Níor aimsíodh aon ghléas eile", + "profileNotFound": "Níorbh fhéidir an t-úsáideoir a aimsiú ar an bhfreastalaí. B'fhéidir go bhfuil fadhb nasctha ann nó nach bhfuil an t-úsáideoir ann.", + "inviteGroupChat": "📨 Cuireadh chuig comhrá grúpa", + "knocking": "Cnagadh", + "addChatOrSubSpace": "Cuir comhrá nó fo-spás leis", + "thisDevice": "An gléas seo:", + "formattedMessages": "Teachtaireachtaí formáidithe", + "verifyOtherDevice": "🔐 Fíoraigh gléas eile", + "commandHint_ignore": "Déan neamhaird d'aitheantas na maitríse sonraithe", + "completedKeyVerification": "{sender} fíorú eochair críochnaithe", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "changeTheCanonicalRoomAlias": "Athraigh an príomhsheoladh comhrá poiblí", + "importEmojis": "Iompórtáil Emoji", + "start": "Tosaigh", + "commandHint_dm": "Cuir tús le comhrá díreach\nÚsáid --no-cription chun criptiúchán a dhíchumasú", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "invalidServerName": "Ainm freastalaí neamhbhailí", + "addToBundle": "Cuir le bundle", + "redactedBy": "Arna chur in eagar ag {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addToSpaceDescription": "Roghnaigh spás chun an comhrá seo a chur leis.", + "markAsRead": "Marcáil mar léite", + "enterRoom": "Iontráil seomra", + "deviceKeys": "Eochracha gléis:", + "allSpaces": "Gach spás", + "searchForUsers": "Cuardaigh @users...", + "removeFromBundle": "Bain as an mbeart seo", + "recoveryKeyLost": "Eochair athshlánaithe caillte?", + "reactedWith": "D'fhreagair {sender} le {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Thug {user} cuireadh duit", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "doNotShowAgain": "Ná taispeáin arís", + "pleaseEnterANumber": "Iontráil uimhir níos mó ná 0", + "unbanUserDescription": "Beidh an t-úsáideoir in ann dul isteach sa chomhrá arís má dhéanann siad iarracht.", + "pleaseEnterYourCurrentPassword": "Iontráil do phasfhocal reatha le do thoil", + "newPassword": "Pasfhocal nua", + "subspace": "Fospás", + "decline": "Meath", + "forwardMessageTo": "Seol teachtaireacht ar aghaidh chuig {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Seol admhálacha léite", + "formattedMessagesDescription": "Taispeáin ábhar saibhir teachtaireachta cosúil le téacs trom ag baint úsáide as marcáil síos.", + "verifyOtherUser": "🔐 Fíoraigh úsáideoir eile", + "dehydrateTorLong": "Maidir le húsáideoirí TOR, moltar an seisiún a onnmhairiú roimh dhúnadh an fhuinneog.", + "numChats": "Comhráite {number}", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hidePresences": "Folaigh Liosta Stádais?", + "jump": "Léim", + "reportErrorDescription": "😭 Ó, a mhac go deo. Chuaigh rud éigin mícheart. Más mian leat, is féidir leat an fabht seo a thuairisciú do na forbróirí.", + "setTheme": "Socraigh téama:", + "invalidInput": "Ionchur neamhbhailí!", + "kickUserDescription": "Ciceáiltear an t-úsáideoir as an gcomhrá ach níl cosc air. I gcomhráite poiblí, is féidir leis an úsáideoir teacht ar ais ag am ar bith.", + "startConversation": "Tosaigh comhrá", + "commandHint_sendraw": "Seol json amh", + "leaveEmptyToClearStatus": "Fág folamh chun do stádas a ghlanadh.", + "pleaseChooseAStrongPassword": "Roghnaigh pasfhocal láidir", + "publicLink": "Nasc poiblí", + "joinSpace": "Glac páirt sa spás", + "initAppError": "Tharla earráid agus an feidhmchlár á thosú", + "requestedKeyVerification": "D'iarr {sender} fíorú eochrach", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "incomingMessages": "Teachtaireachtaí isteach", + "transparent": "Trédhearcach", + "voiceCall": "Glao gutha", + "widgetVideo": "Físeán", + "errorAddingWidget": "Earráid agus an ghiuirléid á cur leis.", + "emojis": "Emojis", + "reportUser": "Déan tuairisc ar úsáideoir", + "custom": "Saincheaptha", + "supposedMxid": "Ba cheart go mbeadh sé seo {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "Marcáil mar ghrúpa", + "dismiss": "Díbhe", + "newGroup": "Grúpa nua", + "newSpace": "Spás nua", + "confirmMatrixId": "Deimhnigh d’ID Maitrís chun do chuntas a scriosadh.", + "hideMemberChangesInPublicChats": "Cuir athruithe ball i gcomhráite poiblí i bhfolach", + "confirmEventUnpin": "An bhfuil tú cinnte an t-imeacht a dhíphionnáil go buan?", + "hugContent": "Tugann {senderName} barróg duit", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "unread": "Neamhléite", + "noChatsFoundHere": "Níor aimsíodh aon chomhrá anseo fós. Cuir tús le comhrá nua le duine éigin tríd an gcnaipe thíos a úsáid. ⤵️", + "separateChatTypes": "Comhráite Díreacha agus Grúpaí ar Leith", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Físeán ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "messageInfo": "Eolas teachtaireachta", + "messageType": "Cineál Teachtaireachta", + "pleaseEnterRecoveryKeyDescription": "Chun do sheanteachtaireachtaí a dhíghlasáil, cuir isteach d'eochair athshlánaithe a gineadh i seisiún eile. NÍ do phasfhocal í d'eochair athshlánaithe.", + "openChat": "Oscail Comhrá", + "unsupportedAndroidVersionLong": "Éilíonn an ghné seo leagan Android níos nuaí. Seiceáil le haghaidh nuashonruithe nó tacaíocht Lineage OS.", + "experimentalVideoCalls": "Glaonna físe turgnamhacha", + "switchToAccount": "Athraigh go cuntas {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "addWidget": "Cuir giuirléid leis", + "widgetUrlError": "Ní URL bailí é seo.", + "invitedBy": "📩 Cuireadh ó {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Chiceáil tú {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Unbanned tú {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "userWouldLikeToChangeTheChat": "Ba mhaith le {user} páirt a ghlacadh sa chomhrá.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "knock": "Cnoc Mhuire", + "storeInSecureStorageDescription": "Stóráil an eochair aisghabhála i stóráil slán an ghléis seo.", + "countFiles": "Comhaid {count}", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "foregroundServiceRunning": "Tá an fógra seo le feiceáil nuair atá an tseirbhís tulra ag rith.", + "screenSharingDetail": "Tá do scáileán á roinnt agat i FuffyChat", + "callingPermissions": "Ceadanna a ghlaoch", + "callingAccount": "Cuntas ag glaoch", + "callingAccountDetails": "Ceadaíonn FluffyChat an aip dhiailiú android dúchais a úsáid.", + "appearOnTopDetails": "Ceadaíonn sé don aip a bheith ar bharr (ní gá má tá socrú Fluffychat agat cheana féin mar chuntas glao)", + "otherCallingPermissions": "Micreafón, ceamara agus ceadanna FluffyChat eile", + "hideUnimportantStateEvents": "Folaigh imeachtaí stáit gan tábhacht", + "disableEncryptionWarning": "Ar chúiseanna slándála ní féidir leat criptiú a dhíchumasú i gcomhrá, áit ar cumasaíodh é roimhe seo.", + "sorryThatsNotPossible": "Tá brón orm... nach féidir a dhéanamh", + "reopenChat": "Comhrá a athoscailt", + "noBackupWarning": "Rabhadh! Gan cúltaca comhrá a chumasú, caillfidh tú rochtain ar do theachtaireachtaí criptithe. Moltar go mór an cúltaca comhrá a chumasú ar dtús sula logálann tú amach.", + "fileIsTooBigForServer": "Ní féidir seol! Ní thacaíonn an freastalaí ach le ceangaltáin suas le {max}.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Léim go dtí an teachtaireacht léite is déanaí", + "readUpToHere": "Léigh suas go dtí seo", + "openLinkInBrowser": "Oscail nasc sa bhrabhsálaí", + "signInWithPassword": "Sínigh isteach le pasfhocal", + "pleaseTryAgainLaterOrChooseDifferentServer": "Bain triail eile as níos déanaí nó roghnaigh freastalaí eile.", + "signInWith": "Sínigh isteach le:", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "invitePrivateChat": "📨 Cuireadh chuig comhrá príobháideach", + "wrongPinEntered": "Tháinig biorán mícheart isteach! Bain triail eile as i {seconds} soicind...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "archiveRoomDescription": "Bogfar an comhrá go dtí an chartlann. Beidh úsáideoirí eile in ann a fheiceáil gur fhág tú an comhrá.", + "removeDevicesDescription": "Beidh tú logáilte amach as an ngléas seo agus ní bheidh tú in ann teachtaireachtaí a fháil a thuilleadh.", + "roomUpgradeDescription": "Déanfar an comhrá a athchruthú ansin leis an leagan seomra nua. Cuirfear in iúl do gach rannpháirtí go gcaithfidh siad aistriú chuig an gcomhrá nua. Is féidir leat tuilleadh eolais a fháil faoi leaganacha seomra ag https://spec.matrix.org/latest/rooms/", + "banUserDescription": "Beidh cosc ar an úsáideoir ón gcomhrá agus ní bheidh sé in ann dul isteach sa chomhrá arís go dtí go mbeidh siad gan chosc.", + "makeAdminDescription": "Nuair a dhéanann tú an riarachán úsáideora seo, b'fhéidir nach mbeidh tú in ann é seo a chealú mar go mbeidh na ceadanna céanna acu agus atá agat.", + "learnMore": "Faigh tuilleadh eolais", + "yourGlobalUserIdIs": "Is é d'aitheantas úsáideora domhanda: ", + "noUsersFoundWithQuery": "Ar an drochuair ní fhéadfaí aon úsáideoir a aimsiú le \"{query}\". Seiceáil le do thoil an ndearna tú typo.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "searchChatsRooms": "Cuardaigh #chats, @users...", + "createGroupAndInviteUsers": "Cruthaigh grúpa agus tabhair cuireadh d'úsáideoirí", + "groupCanBeFoundViaSearch": "Is féidir teacht ar ghrúpa trí chuardach", + "wrongRecoveryKey": "Tá brón orm... Ní cosúil gurb é seo an eochair aisghabhála ceart.", + "databaseMigrationBody": "Fan, le do thoil. B'fhéidir go dtógfaidh sé seo nóiméad.", + "select": "Roghnaigh", + "passwordsDoNotMatch": "Ní mheaitseálann pasfhocail", + "searchIn": "Cuardaigh i gcomhrá \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "passwordIsWrong": "Tá do phasfhocal iontrála mícheart", + "files": "Comhaid", + "databaseBuildErrorBody": "Ní féidir bunachar sonraí SQlite a thógáil. Déanann an aip iarracht an bunachar sonraí oidhreachta a úsáid anois. Tuairiscigh an earráid seo do na forbróirí ag {url}. Is í an teachtaireacht earráide: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Cailltear do sheisiún. Tuairiscigh an earráid seo do na forbróirí ag {url}. Is í an teachtaireacht earráide: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Déanann an aip iarracht anois do sheisiún a chur ar ais ón gcúltaca. Tuairiscigh an earráid seo do na forbróirí ag {url}. Is í an teachtaireacht earráide: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "verifyOtherUserDescription": "Má fhíoraíonn tú úsáideoir eile, is féidir leat a bheith cinnte go bhfuil a fhios agat cé leis a bhfuil tú ag scríobh i ndáiríre. 💪\n\nNuair a thosaíonn tú fíorú, feicfidh tú féin agus an t-úsáideoir eile aníos san aip. Ansin feicfidh tú sraith emojis nó uimhreacha a chaithfidh tú a chur i gcomparáid lena chéile.\n\nIs é an bealach is fearr chun é seo a dhéanamh ná bualadh le chéile nó glao físe a thosú. 👭", + "sendTypingNotificationsDescription": "Is féidir le rannpháirtithe eile i gcomhrá a fheiceáil nuair atá teachtaireacht nua á clóscríobh agat.", + "verifyOtherDeviceDescription": "Nuair a fhíoraíonn tú gléas eile, is féidir leis na gléasanna sin eochracha a mhalartú, do shlándáil fhoriomlán a mhéadú. 💪 Nuair a thosaíonn tú fíorú, beidh preabfhuinneog le feiceáil san aip ar an dá ghléas. Ansin feicfidh tú sraith emojis nó uimhreacha a chaithfidh tú a chur i gcomparáid lena chéile. Is fearr an dá ghléas a bheith áisiúil sula dtosaíonn tú ar an bhfíorú. 🤳", + "acceptedKeyVerification": "{sender} glacadh le fíorú eochair", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} cealaithe fíorú eochrach", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "commandHint_unignore": "Unignore an ID maitrís tugtha", + "restricted": "Srianta", + "goToSpace": "Téigh go dtí an spás: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Marcáil mar gan léamh", + "moderatorLevel": "{level} - Modhnóir", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Riarachán", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "inviteOtherUsers": "Tabhair cuireadh d'úsáideoirí eile chuig an gcomhrá seo", + "changeTheChatPermissions": "Athraigh na ceadanna comhrá", + "changeTheVisibilityOfChatHistory": "Athraigh infheictheacht stair an chomhrá", + "chatPermissionsDescription": "Sainmhínigh cén leibhéal cumhachta is gá le haghaidh gníomhartha áirithe sa chomhrá seo. De ghnáth bíonn na leibhéil chumhachta 0, 50 agus 100 ag déanamh ionadaíochta d'úsáideoirí, do mhodhnóirí agus do riarthóirí, ach is féidir aon ghrádú a dhéanamh.", + "changelog": "ChangelogName", + "sendCanceled": "Cealaíodh seoladh", + "loginWithMatrixId": "Logáil isteach le Matrix-ID", + "discoverHomeservers": "Faigh amach faoi fhreastalaithe baile", + "whatIsAHomeserver": "Cad is freastalaí baile ann?", + "homeserverDescription": "Stóráiltear do chuid sonraí go léir ar an bhfreastalaí baile, díreach cosúil le soláthraí ríomhphoist. Is féidir leat an freastalaí baile is mian leat a úsáid a roghnú, agus is féidir leat cumarsáid a dhéanamh le gach duine fós. Foghlaim níos mó ag https://matrix.org.", + "calculatingFileSize": "Méid an chomhaid á ríomh...", + "sendingAttachment": "Iatán á sheoladh...", + "generatingVideoThumbnail": "Mionsamhail físe á cruthú...", + "compressVideo": "Físeán á chomhbhrú...", + "sendingAttachmentCountOfCount": "Ceangaltán {index} de {length} á sheoladh...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "prepareSendingAttachment": "Ullmhaigh an t- iatán á sheoladh...", + "serverLimitReached": "Sroicheadh teorainn an fhreastalaí! Ag fanacht {seconds} soicind...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Ní fhíoraítear ceann de do ghléasanna", + "noticeChatBackupDeviceVerification": "Nóta: Nuair a nascann tú do ghléasanna go léir leis an gcúltaca comhrá, déantar iad a fhíorú go huathoibríoch.", + "continueText": "Lean ar aghaidh", + "welcomeText": "Hey Hey 👋 Is é seo FluffyChat. Is féidir leat síniú isteach in aon fhreastalaí baile, atá comhoiriúnach leis https://matrix.org. Agus ansin comhrá a dhéanamh le duine ar bith. Is líonra teachtaireachtaí díláraithe ollmhór é!", + "blur": "Doiléirigh:", + "opacity": "Teimhneacht:", + "setWallpaper": "Socraigh cúlbhrat", + "manageAccount": "Bainistigh cuntas", + "noContactInformationProvided": "Ní sholáthraíonn an freastalaí aon fhaisnéis teagmhála bhailí", + "contactServerAdmin": "Déan teagmháil le admin an fhreastalaí", + "contactServerSecurity": "Déan teagmháil le slándáil an fhreastalaí", + "supportPage": "Leathanach tacaíochta", + "name": "Ainm", + "version": "Leagan", + "website": "Suíomh Gréasáin", + "messagesStyle": "Teachtaireachtaí:", + "setColorTheme": "Socraigh téama datha:", + "openGallery": "Oscail gailearaí", + "users": "Úsáideoirí", + "youBannedUser": "Chuir tú cosc ar {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "user": "Úsáideoir", + "databaseMigrationTitle": "Tá an bunachar sonraí optamaithe", + "hasKnocked": "🚪 Tá {user} tar éis cnagadh", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "report": "tuairisc", + "invite": "Tabhair cuireadh", + "publicSpaces": "Spásanna poiblí", + "whyIsThisMessageEncrypted": "Cén fáth nach féidir an teachtaireacht seo a léamh?", + "pinMessage": "Bioráin chuig an seomra", + "dehydrate": "Easpórtáil seisiún agus gléas wipe", + "dehydrateTor": "Úsáideoirí TOR: Seisiún easpórtála", + "commandHint_markasdm": "Marcáil mar sheomra teachtaireachta dírí don ID Maitrís tugtha", + "googlyEyesContent": "Seolann {senderName} súile googly chugat", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_cuddle": "Seol cuddle", + "commandHint_hug": "Seol barróg", + "startFirstChat": "Cuir tús le do chéad chomhrá", + "encryptThisChat": "Criptigh an comhrá seo", + "importNow": "Iompórtáil anois", + "sendTypingNotifications": "Seol fógraí clóscríofa", + "addChatDescription": "Cuir cur síos ar an gcomhrá leis...", + "chatPermissions": "Ceadanna comhrá", + "emoteKeyboardNoRecents": "Beidh mothúcháin a úsáideadh le déanaí le feiceáil anseo ...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "chatDescriptionHasBeenChanged": "Athraíodh cur síos ar an gcomhrá", + "pushNotificationsNotAvailable": "Níl fógraí brú ar fáil", + "publish": "Foilsigh", + "changeGeneralChatSettings": "Athraigh socruithe ginearálta comhrá", + "sendRoomNotifications": "Seol fógraí @room", + "changeTheDescriptionOfTheGroup": "Athraigh an cur síos ar an gcomhrá", + "aboutHomeserver": "Maidir le {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "cuddleContent": "Cuireann {senderName} do chudacht", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "countChatsAndCountParticipants": "{chats} comhrá agus {participants} rannpháirtí", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Níor aimsíodh a thuilleadh comhráite...", + "joinedChats": "Glacadh páirt i gcomhráite", + "space": "Spás", + "spaces": "Spásanna", + "directChat": "Comhrá díreach", + "redactedByBecause": "Athbhreithnithe ag {username} mar: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "recoveryKey": "Eochair athshlánaithe", + "setChatDescription": "Socraigh cur síos ar an gcomhrá", + "presenceStyle": "Láithreacht:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Taispeáin teachtaireachtaí stádais ó úsáideoirí eile", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "time": "Am", + "removeFromSpace": "Bain as spás", + "placeCall": "Cuir glaoch", + "unsupportedAndroidVersion": "Leagan Android gan tacaíocht", + "previousAccount": "Cuntas roimhe seo", + "widgetJitsi": "Jitsi le chéile", + "widgetCustom": "Saincheaptha", + "widgetName": "Ainm", + "usersMustKnock": "Ní mór d'úsáideoirí cnag a chur ar", + "noPublicLinkHasBeenCreatedYet": "Níor cruthaíodh aon nasc poiblí go fóill", + "storeSecurlyOnThisDevice": "Stóráil go daingean ar an ngléas seo", + "userLevel": "{level} - Úsáideoir", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "updateInstalled": "🎉 Nuashonraigh {version} suiteáilte!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "serverInformation": "Eolas freastalaí:", + "knockRestricted": "Cnoc Mhuire srianta", + "createGroup": "Cruthaigh grúpa", + "noChatDescriptionYet": "Níl aon chur síos ar an gcomhrá cruthaithe fós.", + "shareInviteLink": "Roinn an nasc cuireadh", + "notifyMeFor": "Cuir in iúl dom le haghaidh", + "passwordRecoverySettings": "Socruithe athshlánaithe pasfhocal", + "widgetEtherpad": "Nóta téacs", + "youKickedAndBanned": "🙅 Chiceáil tú agus chuir tú cosc ar {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "publicChatAddresses": "Seoltaí comhrá poiblí", + "createNewAddress": "Cruthaigh seoladh nua", + "groupName": "Ainm an ghrúpa", + "bundleName": "Ainm an bheartáin", + "enterSpace": "Iontráil spás", + "wasDirectChatDisplayName": "Comhrá folamh (bhí {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "oneClientLoggedOut": "Tá duine de do chliaint logáilte amach", + "overview": "Forbhreathnú", + "unverified": "Neamhfhíoraithe", + "widgetNameError": "Tabhair ainm taispeána, le do thoil.", + "youRejectedTheInvitation": "Dhiúltaigh tú don chuireadh", + "youHaveWithdrawnTheInvitationFor": "Tharraing tú siar an cuireadh do {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Tugadh cuireadh duit trí nasc chuig:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Thug tú cuireadh do {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unlockOldMessages": "Díghlasáil seanteachtaireachtaí", + "saveKeyManuallyDescription": "Sábháil an eochair seo de láimh trí dialóg nó gearrthaisce comhroinnte an chórais a spreagadh.", + "storeInAndroidKeystore": "Stóráil i Android KeyStore", + "storeInAppleKeyChain": "Stóráil i Apple KeyChain", + "appearOnTop": "Le feiceáil ar an mbarr", + "newSpaceDescription": "Ligeann spásanna duit do chomhráite a chomhdhlúthú agus pobail phríobháideacha nó phoiblí a thógáil.", + "chatCanBeDiscoveredViaSearchOnServer": "Is féidir comhrá a aimsiú tríd an gcuardach ar {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "nothingFound": "Níor aimsíodh aon rud...", + "searchMore": "Cuardaigh tuilleadh...", + "gallery": "Gailearaí", + "alwaysUse24HourFormat": "bréagach", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "importFromZipFile": "Iompórtáil ó chomhad .zip", + "exportEmotePack": "Easpórtáil Emote pacáiste mar .zip", + "replace": "Ionadaigh", + "appLockDescription": "Cuir glas ar an aip nuair nach bhfuil sé in úsáid le cód bioráin", + "swipeRightToLeftToReply": "Svaidhpeáil ar dheis ar chlé chun freagra a thabhairt", + "commandHint_discardsession": "Scrios an seisiún", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "allRooms": "Gach Comhrá Grúpa", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "block": "Bloc", + "blockListDescription": "Is féidir leat bac a chur ar úsáideoirí atá ag cur isteach ort. Ní bheidh tú in ann teachtaireachtaí nó cuireadh seomra ar bith a fháil ó na húsáideoirí ar do liosta bloc pearsanta.", + "blockUsername": "Déan neamhaird de ainm úsáideora", + "inviteContactToGroupQuestion": "Ar mhaith leat cuireadh a thabhairt do {contact} chuig an gcomhrá \"{groupName}\"?", + "tryAgain": "Bain triail eile as", + "optionalRedactReason": "(Roghnach) An chúis leis an teachtaireacht seo a chur in eagar...", + "dehydrateWarning": "Ní féidir an gníomh seo a chealú. Cinntigh go stórálann tú an comhad cúltaca go sábháilte.", + "hydrateTor": "Úsáideoirí TOR: Iompórtáil easpórtáil seisiún", + "hydrateTorLong": "An ndearna tú do sheisiún a easpórtáil an uair dheireanach ar TOR? Iompórtáil go tapa é agus leanúint ar aghaidh ag comhrá.", + "hydrate": "Athchóirigh ó chomhad cúltaca", + "commandHint_googly": "Seol roinnt súile googly", + "notAnImage": "Ní comhad íomhá é.", + "userRole": "Ról an úsáideora", + "minimumPowerLevel": "Is é {level} an t-íosleibhéal cumhachta.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "Tá {sender} réidh le haghaidh fíorú eochair", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "Thosaigh {sender} fíorú eochrach", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "stickers": "Greamáin", + "discover": "Faigh amach", + "unreadChatsInApp": "{appname}: {unread} comhráite gan léamh", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Ní thacaítear le criptiú bunachar sonraí ar an ardán seo", + "thereAreCountUsersBlocked": "Faoi láthair tá bac curtha ar úsáideoirí {count}.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "sendReadReceiptsDescription": "Is féidir le rannpháirtithe eile i gcomhrá a fheiceáil nuair a bhíonn teachtaireacht léite agat.", + "doesNotSeemToBeAValidHomeserver": "Ní cosúil gur freastalaí baile comhoiriúnach é. URL mícheart?", + "indexedDbErrorTitle": "Saincheisteanna mód príobháideach", + "indexedDbErrorLong": "Ar an drochuair níl an stóráil teachtaireachta cumasaithe sa mhód príobháideach de réir réamhshocraithe.\nTabhair cuairt le do thoil\n - faoi: config\n - socraithe dom.indexedDB.privateBrowsing.enabled go fíor\nSeachas sin, ní féidir FluffyChat a rith.", + "nextAccount": "An chéad chuntas eile", + "youJoinedTheChat": "Chuaigh tú isteach sa chomhrá", + "youAcceptedTheInvitation": "👍 Ghlac tú leis an gcuireadh", + "screenSharingTitle": "comhroinnt scáileáin", + "accessAndVisibility": "Rochtain agus infheictheacht", + "accessAndVisibilityDescription": "Cé a bhfuil cead aige páirt a ghlacadh sa chomhrá seo agus conas is féidir an comhrá a aimsiú.", + "calls": "Glaonna", + "customEmojisAndStickers": "Emojis agus greamáin saincheaptha", + "customEmojisAndStickersBody": "Cuir leis nó roinn emojis nó greamáin saincheaptha is féidir a úsáid in aon chomhrá.", + "chatDescription": "Cur síos ar an gcomhrá", + "hideRedactedMessages": "Folaigh teachtaireachtaí curtha in eagar", + "hideRedactedMessagesBody": "Má athghníomhaíonn duine éigin teachtaireacht, ní bheidh an teachtaireacht seo le feiceáil sa chomhrá a thuilleadh.", + "hideInvalidOrUnknownMessageFormats": "Folaigh formáidí teachtaireachta neamhbhailí nó anaithnid", + "blockedUsers": "Úsáideoirí bactha", + "redactMessageDescription": "Athrófar an teachtaireacht do gach rannpháirtí sa chomhrá seo. Ní féidir é seo a chealú.", + "noKeyForThisMessage": "Féadfaidh sé seo tarlú má seoladh an teachtaireacht sular shínigh tú isteach ar do chuntas ag an ngléas seo.\n\nIs féidir freisin gur chuir an seoltóir bac ar do ghléas nó go ndeachaigh rud éigin mícheart leis an nasc idirlín.\n\nAn bhfuil tú in ann an teachtaireacht a léamh ar sheisiún eile? Ansin is féidir leat an teachtaireacht a aistriú uaidh! Téigh go Socruithe > Gléasanna agus cinntigh go bhfuil do ghléasanna fíoraithe a chéile. Nuair a osclaíonn tú an seomra an chéad uair eile agus an dá sheisiún sa tulra, déanfar na heochracha a tharchur go huathoibríoch.\n\nNár mhaith leat na heochracha a chailleadh agus tú ag logáil amach nó ag aistriú gléasanna? Déan cinnte go bhfuil an cúltaca comhrá cumasaithe agat sna socruithe.", + "boldText": "Téacs trom", + "italicText": "Téacs iodálach", + "strikeThrough": "Stailc tríd", + "addLink": "Cuir nasc leis", + "pleaseFillOut": "Líon amach le do thoil", + "invalidUrl": "URL neamhbhailí", + "unableToJoinChat": "Ní féidir páirt a ghlacadh sa chomhrá. B’fhéidir go bhfuil an comhrá dúnta cheana féin ag an bpáirtí eile.", + "compress": "Comhbhrúigh", + "sendImages": "Seol {count} íomhá", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "appIntroduction": "Ligeann FluffyChat duit comhrá a dhéanamh le do chairde thar theachtairí éagsúla. Foghlaim tuilleadh ag https://matrix.org nó tapáil *Ar aghaidh*.", + "appWantsToUseForLoginDescription": "Ligeann tú leis seo don aip agus don suíomh Gréasáin faisnéis a roinnt fút.", + "synchronizingPleaseWaitCounter": " Ag sioncronú… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "appWantsToUseForLogin": "Úsáid '{server}' chun logáil isteach", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "open": "Oscail", + "waitingForServer": "Ag fanacht leis an bhfreastalaí...", + "previous": "Roimhe Seo", + "otherPartyNotLoggedIn": "Níl an páirtí eile logáilte isteach faoi láthair agus mar sin ní féidir leo teachtaireachtaí a fháil!", + "contentNotificationSettings": "Socruithe fógra inneachair", + "generalNotificationSettings": "Socruithe ginearálta fógra", + "roomNotificationSettings": "Socruithe fógra seomra", + "userSpecificNotificationSettings": "Socruithe fógra sainiúla don úsáideoir", + "otherNotificationSettings": "Socruithe fógra eile", + "notificationRuleContainsUserName": "Tá Ainm Úsáideora ann", + "notificationRuleMaster": "Balbhaigh gach fógra", + "notificationRuleMasterDescription": "Sáraíonn sé gach riail eile agus díchumasaítear gach fógra.", + "notificationRuleSuppressNotices": "Bain Teachtaireachtaí Uathoibrithe", + "notificationRuleSuppressNoticesDescription": "Sochtann sé fógraí ó chliaint uathoibrithe amhail róbónna.", + "notificationRuleInviteForMe": "Tabhair cuireadh Do Mhise", + "notificationRuleMemberEvent": "Imeacht Ball", + "notificationRuleMemberEventDescription": "Sochtann fógraí le haghaidh imeachtaí ballraíochta.", + "notificationRuleIsUserMention": "Luaigh Úsáideoir", + "notificationRuleIsUserMentionDescription": "Cuireann sé sin in iúl don úsáideoir nuair a luaitear go díreach iad i dteachtaireacht.", + "notificationRuleContainsDisplayName": "Tá Ainm Taispeána ann", + "notificationRuleIsRoomMention": "Luaigh Seomra", + "notificationRuleIsRoomMentionDescription": "Cuireann sé sin in iúl don úsáideoir nuair a luaitear seomra.", + "notificationRuleRoomnotif": "Fógra Seomra", + "notificationRuleRoomnotifDescription": "Cuireann sé seo in iúl don úsáideoir nuair a bhíonn '@room' i dteachtaireacht.", + "notificationRuleTombstone": "Leac uaighe", + "notificationRuleTombstoneDescription": "Cuireann sé seo in iúl don úsáideoir faoi theachtaireachtaí díghníomhaithe seomra.", + "notificationRuleReactionDescription": "Sochtann fógraí le haghaidh frithghníomhartha.", + "notificationRuleRoomServerAcl": "Freastalaí Seomra ACL", + "notificationRuleRoomServerAclDescription": "Sochtann sé fógraí do liostaí rialaithe rochtana freastalaí seomra (ACL).", + "notificationRuleSuppressEdits": "Cuir na hEagarthóirí ar ceal", + "notificationRuleSuppressEditsDescription": "Sochtann fógraí le haghaidh teachtaireachtaí curtha in eagar.", + "notificationRuleCall": "Glaoigh", + "notificationRuleCallDescription": "Cuireann sé an t-úsáideoir ar an eolas faoi ghlaonna.", + "notificationRuleEncryptedRoomOneToOne": "Seomra Duine le Duine Criptithe", + "notificationRuleRoomOneToOne": "Seomra duine le duine", + "notificationRuleRoomOneToOneDescription": "Cuireann sé seo in iúl don úsáideoir faoi theachtaireachtaí i seomraí duine le duine.", + "notificationRuleMessage": "Teachtaireacht", + "notificationRuleMessageDescription": "Cuireann sé seo in iúl don úsáideoir faoi theachtaireachtaí ginearálta.", + "notificationRuleEncrypted": "Criptithe", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Cuireann sé seo in iúl don úsáideoir faoi imeachtaí giuirléidí Jitsi.", + "notificationRuleServerAcl": "Seachtaigh Freastalaí ACL Imeachtaí", + "more": "Tuilleadh", + "newChatRequest": "📩 Iarratas comhrá nua", + "shareKeysWith": "Roinn na heochracha le...", + "allDevices": "Gach gléasanna", + "crossVerifiedDevicesIfEnabled": "Gléasanna trasfhíoraithe má tá siad cumasaithe", + "crossVerifiedDevices": "Feistí trasfhíoraithe", + "unknownPushRule": "Riail bhrú anaithnid '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "notificationRuleReaction": "Imoibriú", + "notificationRuleEncryptedDescription": "Cuireann sé seo in iúl don úsáideoir faoi theachtaireachtaí i seomraí criptithe.", + "notificationRuleContainsUserNameDescription": "Cuireann sé sin in iúl don úsáideoir nuair a bhíonn a ainm úsáideora i dteachtaireacht.", + "notificationRuleInviteForMeDescription": "Cuireann sé seo ar an eolas don úsáideoir nuair a thugtar cuireadh dó/di go seomra.", + "deletePushRuleCanNotBeUndone": "Má scriosann tú an socrú fógra seo, ní féidir é seo a chealú.", + "notificationRuleContainsDisplayNameDescription": "Cuireann sé sin in iúl don úsáideoir nuair a bhíonn a ainm taispeána i dteachtaireacht.", + "notificationRuleEncryptedRoomOneToOneDescription": "Cuireann sé seo in iúl don úsáideoir faoi theachtaireachtaí i seomraí duine le duine criptithe.", + "notificationRuleServerAclDescription": "Sochtann fógraí le haghaidh imeachtaí Freastalaí ACL.", + "shareKeysWithDescription": "Cad iad na gléasanna ar cheart muinín a chur iontu ionas gur féidir leo do chuid teachtaireachtaí a léamh i gcomhráite criptithe?", + "verifiedDevicesOnly": "Gléasanna fíoraithe amháin", + "takeAPhoto": "Glac grianghraf", + "recordAVideo": "Taifead físeán", + "notSupportedOnThisDevice": "Ní thacaítear leis ar an ngléas seo", + "optionalMessage": "Teachtaireacht (Roghnach)…", + "enterNewChat": "Cuir isteach comhrá nua", + "commandHint_roomupgrade": "Uasghrádaigh an seomra seo go dtí an leagan seomra a thugtar", + "setCustomPermissionLevel": "Socraigh leibhéal ceadanna saincheaptha", + "setPermissionsLevelDescription": "Roghnaigh ról réamhshainithe thíos nó cuir isteach leibhéal ceadanna saincheaptha idir 0 agus 100.", + "ignoreUser": "Déan neamhaird den úsáideoir", + "normalUser": "Gnáthúsáideoir", + "approve": "Ceadaigh", + "youHaveKnocked": "Bhuail tú", + "pleaseWaitUntilInvited": "Fan anois, le do thoil, go dtí go dtabharfaidh duine éigin ón seomra cuireadh duit.", + "checkList": "Liosta seiceála", + "countInvited": "cuireadh chuig {count}", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Teachtaireacht ghutha ó {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "displayNavigationRail": "Taispeáin ráille nascleanúna ar fhóin phóca", + "commandHint_logout": "Logáil amach as do ghléas reatha", + "commandHint_logoutall": "Logáil amach gach gléas gníomhach", + "customReaction": "Imoibriú saincheaptha", + "moreEvents": "Tuilleadh imeachtaí", + "declineInvitation": "Diúltaigh don chuireadh", + "noMessagesYet": "Gan aon teachtaireachtaí fós", + "longPressToRecordVoiceMessage": "Brúigh go fada chun teachtaireacht gutha a thaifeadadh.", + "pause": "Sos", + "resume": "Atosú", + "newSubSpace": "Fo-spás nua", + "moveToDifferentSpace": "Bog go spás difriúil", + "moveUp": "Bog suas", + "moveDown": "Bog síos", + "removeFromSpaceDescription": "Bainfear an comhrá as an spás ach beidh sé fós le feiceáil i do liosta comhrá.", + "countChats": "comhráite {chats}", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Ball spáis de {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Is féidir le ball spáis de {spaces} cnagadh", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Tabhair Síntiús", + "startedAPoll": "Chuir {username} tús le pobalbhreith.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Polaitíocht", + "startPoll": "Tosaigh pobalbhreith", + "endPoll": "Deireadh leis an pobalbhreith", + "answersVisible": "Freagraí le feiceáil", + "answersHidden": "Freagraí i bhfolach", + "pollQuestion": "Ceist pobalbhreithe", + "answerOption": "Rogha freagartha", + "addAnswerOption": "Cuir rogha freagra leis", + "allowMultipleAnswers": "Ceadaigh freagraí iolracha", + "pollHasBeenEnded": "Tá deireadh leis an pobalbhreith", + "countVotes": "{count, plural, =1{Vóta amháin} other{{count} vótaí}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Beidh freagraí le feiceáil nuair a bheidh an pobalbhreith thart", + "replyInThread": "Freagra sa snáithe", + "countReplies": "{count, plural, =1{Freagra amháin} other{{count} freagraí}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Snáithe", + "backToMainChat": "Ar ais chuig an bpríomhchomhrá", + "saveChanges": "Sábháil athruithe", + "createSticker": "Cruthaigh greamán nó emoji", + "useAsSticker": "Úsáid mar ghreamán", + "useAsEmoji": "Úsáid mar emoji", + "stickerPackNameAlreadyExists": "Tá ainm an phacáiste greamán ann cheana féin", + "newStickerPack": "Pacáiste greamán nua", + "stickerPackName": "Ainm an phacáiste greamán", + "attribution": "Atribution", + "skipChatBackup": "Seachain cúltaca comhrá", + "skipChatBackupWarning": "An bhfuil tú cinnte? Mura gcumasaíonn tú an cúltaca comhrá, d’fhéadfá rochtain ar do theachtaireachtaí a chailleadh má athraíonn tú do ghléas.", + "loadingMessages": "Ag lódáil teachtaireachtaí", + "setupChatBackup": "Socraigh cúltaca comhrá", + "changedTheChatDescription": "D'athraigh {username} cur síos an chomhrá", + "changedTheChatName": "D'athraigh {username} ainm an chomhrá", + "noMoreResultsFound": "Ní bhfuarthas aon torthaí eile", + "chatSearchedUntil": "Comhrá a cuardaíodh go dtí {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "URL Bonn Cónaidhme", + "clientWellKnownInformation": "Faisnéis atá ar eolas ag an gcliant:", + "baseUrl": "Bun-URL", + "identityServer": "Freastalaí Aitheantais:", + "versionWithNumber": "Leagan: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Logaí", + "advancedConfigs": "Cumraíochtaí Ardleibhéil", + "advancedConfigurations": "Cumraíochtaí ardleibhéil", + "signInWithLabel": "Sínigh isteach le:", + "signIn": "Sínigh isteach", + "createNewAccount": "Cruthaigh cuntas nua", + "signUpGreeting": "Tá FluffyChat díláraithe! Roghnaigh freastalaí inar mian leat do chuntas a chruthú agus déanaimis é!", + "signInGreeting": "An bhfuil cuntas agat i Matrix cheana féin? Fáilte ar ais! Roghnaigh do fhreastalaí baile agus sínigh isteach.", + "appIntro": "Le FluffyChat is féidir leat comhrá a dhéanamh le do chairde. Is teachtaire [maitrís] díláraithe slán é! Foghlaim tuilleadh ar https://matrix.org más maith leat nó cláraigh.", + "theProcessWasCanceled": "Cuireadh an próiseas ar ceal.", + "join": "Téigh i", + "searchOrEnterHomeserverAddress": "Cuardaigh nó cuir isteach seoladh an fhreastalaí baile", + "matrixId": "Aitheantas Maitrís", + "setPowerLevel": "Socraigh leibhéal cumhachta", + "makeModerator": "Déan modhnóir", + "makeAdmin": "Déan riarthóir", + "removeModeratorRights": "Bain cearta an mhodhnóra", + "removeAdminRights": "Bain cearta riarthóra", + "powerLevel": "Leibhéal cumhachta", + "setPowerLevelDescription": "Sainmhíníonn leibhéil chumhachta cad a cheadaítear do bhall a dhéanamh sa seomra seo agus is gnách go mbíonn siad idir 0 agus 100.", + "owner": "Úinéir" +} diff --git a/lib/l10n/intl_gl.arb b/lib/l10n/intl_gl.arb new file mode 100644 index 000000000..cc61db234 --- /dev/null +++ b/lib/l10n/intl_gl.arb @@ -0,0 +1,3159 @@ +{ + "@@locale": "gl", + "@@last_modified": "2021-08-14 12:41:10.040321", + "about": "Acerca de", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Aceptar", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} aceptou o convite", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Conta", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} activou a cifraxe extremo-a-extremo", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Engadir email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Todos", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Todas as conversas", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} respondeu á chamada", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Calquera pode unirse", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Bloqueo da app", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arquivo", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Poden entrar as usuarias convidadas?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Tes a certeza?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Tes a certeza de querer saír?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Para poder asinar a outra persoa, escribe a túa frase de paso ou chave de recuperación.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Aceptar a solicitude de verificación de {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Reproducir automáticamente adhesivos e emotes", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "O servidor soporta as seguintes formas de conexión:\n{serverVersions}\nPero esta app só soporta:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "O servidor soporta as seguintes características:\n{serverVersions}\nPero esta app só soporta {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Vetar na conversa", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Vetada", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} vetou a {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Bloquear dispositivo", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Bloqueado", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Mensaxes de Bot", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Cancelar", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Non se pode abrir o URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Cambiar nome do dispositivo", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} cambiou o avatar da conversa", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} mudou a descrición da conversa a: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} mudou o nome da charla a: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} mudou os permisos da conversa", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} cambiou o nome público a: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} mudou as regras de acceso para convidadas", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} mudou as regras de acceso para convidadas a: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} mudou a visibilidade do historial", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} mudou a visibilidade do historial a: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} mudou as regras de acceso", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} mudou as regras de acceso a: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} mudou o avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} mudou os alias da sala", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} mudou a ligazón de convite", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Mudar contrasinal", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Mudar de servidor de inicio", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Cambiar o estilo", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Mudar o nome do grupo", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Cambia o avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "A cifraxe está estragada", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Conversa", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Copia de apoio", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "As mensaxes están protexidas cunha clave de recuperación. Pon coidado e non a perdas.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Detalles da conversa", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Conversas", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Escolle un contrasinal forte", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Baleirar arquivo", + "close": "Pechar", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Vetar a usuaria indicada desta sala", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Enviar texto con formato HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Convidar á usuaria a esta sala", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Unirte á sala indicada", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Eliminar a usuaria indicada desta sala", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Saír desta sala", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Conta algo sobre ti", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Establece a túa imaxe para esta sala (por mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Establece o teu nome público para esta sala", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Establecer o nivel de responsabilidade da usuaria (por defecto: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Enviar texto sen formato", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Enviar resposta como reacción", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Enviar texto", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Retirar veto á usuaria para esta sala", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Comando non válido", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} non é un comando.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Compara estes emojis", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Compara estes números", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Configurar conversa", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Confirmar", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Conectar", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "O contacto foi convidado ao grupo", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Contén nome público", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Contén nome de usuaria", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "O contido foi denunciado á administración do servidor", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Copiado ao portapapeis", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Copiar", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Copiar ao portapapeis", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Non se descifrou a mensaxe: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} participantes", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Crear", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} creou a conversa", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Novo espazo", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Actualmente activo", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Escuro", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Esto desactivará a conta. Esto non ten volta atrás. Estás segura?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Nivel de permisos por defecto para novas usuarias", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Eliminar", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Eliminar conta", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Eliminar mensaxe", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Dispositivo", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID do dispositivo", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Dispositivos", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Conversas Directas", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "O nome público mudou", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Descargar ficheiro", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Editar", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Editar servidores bloqueados", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Editar nome público", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Editar alias da sala", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Editar avatar da sala", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Xa existe ese emote!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Atallo do emote non é válido!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Paquetes de Emotes para a sala", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Axustes de Emote", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Atallo de Emote", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Escribe un atallo e asocialle unha imaxe!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Conversa baleira", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Activar paquete emote globalmente", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Activar cifraxe", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Non poderás desactivar a cifraxe posteriormente, tes certeza?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Cifrado", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Cifraxe", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "A cifraxe non está activada", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} rematou a chamada", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Escribe un enderezo de email", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Escribe o teu servidor de inicio", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Erro ao obter a localización: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Todo preparado!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extremadamente ofensivo", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Nome do ficheiro", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Tamaño da letra", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Reenviar", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Desde que se una", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Desde o convite", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Ir á nova sala", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Grupo", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "O grupo é público", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Grupos", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grupo con {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Non se permiten convidadas", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Permítense convidadas", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} retirou o convite para {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Axuda", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Agochar eventos editados", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Agochar eventos descoñecidos", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "É moi ofensivo este contido?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identidade", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorar", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Usuarias ignoradas", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Premín na ligazón", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Frase de paso ou chave de recuperación incorrecta", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Inofensivo", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Convidar contacto", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Convidar contacto a {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Convidado", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} convidou a {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Só usuarias convidadas", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Convite para min", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} convidoute a FluffyChat.\n1. Visita fluffychat.im e instala a app\n2. Crea unha conta ou Accede\n3. Abre a ligazón do convite: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "está escribindo…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} uníuse á conversa", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Unirse á sala", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} expulsou a {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} expulsou e vetou a {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Expulsar da conversa", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Última actividade: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Saír", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Deixar a conversa", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licenza", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Claro", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Cargar {count} participantes máis", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Cargando... Agarda.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Cargar máis…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Os servizos de localización están desactivados. Actívaos para poder compartir a localización.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Permiso de localización denegado. Concede este permiso para poder compartir a localización.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Acceder", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Entrar en {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Pechar sesión", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Cambios de participantes", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Mención", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Mensaxes", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderadora", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Acalar conversa", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Ten en conta que polo de agora precisas Pantalaimon para a cifraxe extremo-a-extremo.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Nova conversa", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nova mensaxe en FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nova solicitude de verificación!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Seguinte", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Non", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Sen conexión co servidor", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Non hai emotes. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Só podes activar a cifraxe tan pronto como a sala non sexa públicamente accesible.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Semella que non tes Firebase Cloud Messaging dispoñible no teu dispositivo. Para recibir notificacións push recomendamos que instales ntfy. Con ntfy ou outro provedor Unified Push podes recibir notificacións push de xeito seguro. Podes descargar ntfy desde a PlayStore ou F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} non é un servidor matrix, usar {server2} no seu lugar?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "none": "Ningún", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Aínda non engaiches ningún xeito de recuperar o contrasinal.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Sen permiso", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Non se atoparon salas…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notificacións", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Notificacións activadas para a conta", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} usuarias están escribindo…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Obtendo a localización…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Ofensivo", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Desconectada", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "En liña", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Copia de Apoio en liña das Chaves activada", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Vaites! Desgraciadamente algo fallou ao configurar as notificacións push.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ooooi, algo fallou…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Abrir a app e ler mensaxes", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Abrir cámara", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Abrir en mapas", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Ou", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Participante", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "frase de paso ou chave de recuperación", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Contrasinal", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Contrasinal esquecido", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Cambiouse o contrasinal", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Recuperación do contrasinal", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Persoas", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Elixe unha imaxe", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Fixar", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Reproducir {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Por favor elixe", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Escolle un código de acceso", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Preme na ligazón do email e segue as instrucións.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Escribe 4 díxitos ou deíxao baleiro para non activar o bloqueo.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Escribe o teu contrasinal", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Escribe o teu pin", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Escribe o teu nome de usuaria", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Segue as instruccións do sitio web e toca en seguinte.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privacidade", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Salas públicas", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Regras de envío", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Razón", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Gravando", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} editou un evento", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Eliminar mensaxe", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Crear conta", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Rexeitar", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} rexeitou o convite", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Volta a unirte", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Quitar", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Quitar todos os outros dispositivos", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Eliminado por {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Quitar dispositivo", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Retirar veto na conversa", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Elimina o avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Substituír sala pola nova versión", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Responder", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Denunciar mensaxe", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Solicitar permiso", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "A sala foi actualizada", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Versión da sala", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Gardar ficheiro", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Buscar", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Seguridade", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Visto por {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Enviar", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Enviar unha mensaxe", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Enviar como texto", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Enviar audio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Enviar ficheiro", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Enviar imaxe", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Enviar mensaxes", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Enviar orixinal", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Enviar adhesivo", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Enviar vídeo", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} enviou un ficheiro", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} enviou un audio", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} enviou unha imaxe", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} enviou un adhesivo", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} enviou un vídeo", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} enviou información da chamada", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Establecer como alias principal", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Establecer emotes personalizados", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Establecer ligazón do convite", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Establecer nivel de permisos", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Establecer estado", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Axustes", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Compartir", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} compartiu a súa localización", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Compartir localización", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Amosar contrasinal", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Conexión Unificada SSO", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Saltar", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Código fonte", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "O Espazo é público", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Nome do Espazo", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} iniciou unha chamada", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Estado", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "¿Que tal estás hoxe?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Enviar", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sincronizando... Agarda.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistema", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Non concordan", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Concordan", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Marcar Favorito", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Cambia Noificacións", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Marcar como Lido/Non lido", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Demasiadas solicitudes. Inténtao máis tarde!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Transferir desde outro dispositivo", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Inténtao outra vez", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Non dispoñible", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} retirou o veto a {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Desbloquear dispositivo", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Dispositivo descoñecido", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Algoritmo de cifraxe descoñecido", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Evento descoñecido '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Reactivar notificacións", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Desafixar", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 conversa sen ler} other{{unreadCount} conversas sen ler}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} e {count} máis están escribindo…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} e {username2} están escribindo…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} está escribindo…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} deixou a conversa", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Nome de usuaria", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} enviou un evento {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Verificado", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verificar", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Comezar verificación", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Verificaches correctamente!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verificando a outra conta", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Chamada de vídeo", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Visibilidade do historial da conversa", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Visible para todas as participantes", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Visible para todas", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Mensaxe de voz", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Agardando a que a outra parte acepte a solicitude…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Agardando a que a outra parte acepte as emoticonas…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Agardando a que a outra parte acepte os números…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Imaxe de fondo:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Aviso!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Enviamosche un email", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Quen pode realizar determinada acción", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Quen se pode unir a este grupo", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Por que queres denunciar esto?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Queres eliminar a copia de apoio e crear unha nova chave de recuperación?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Con estos enderezos podes recuperar o contrasinal.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Escribe unha mensaxe…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Si", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Ti", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Xa non participas desta conversa", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Foches vetada nesta conversa", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "A túa chave pública", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Engadiuse a conversa a este espazo", + "addToSpace": "Engadir ao espazo", + "scanQrCode": "Escanear código QR", + "sendOnEnter": "Enter para enviar", + "homeserver": "Servidor de inicio", + "serverRequiresEmail": "O servidor precisa validar o teu enderezo de email para rexistrarte.", + "enableMultiAccounts": "(BETA) Activar varias contas neste dispositivo", + "addAccount": "Engadir conta", + "oneClientLoggedOut": "Un dos teus clientes foi desconectado", + "link": "Ligazón", + "yourChatBackupHasBeenSetUp": "Configurouse a copia de apoio da charla.", + "unverified": "Sen verificar", + "repeatPassword": "Repite o contrasinal", + "messageInfo": "Info da mensaxe", + "time": "Hora", + "sender": "Remitente", + "openGallery": "Galería pública", + "addToSpaceDescription": "Elixe un espazo ao que engadir esta conversa.", + "messageType": "Tipo de mensaxe", + "removeFromSpace": "Retirar do espazo", + "start": "Comezar", + "commandHint_discardsession": "Descartar sesión", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_create": "Crear un grupo de conversa baleiro\nUsa --no-encryption para desactivar a cifraxe", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_clearcache": "Baleirar caché", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_dm": "Iniciar unha charla directa\nUsa --no-encryption para desactivar a cifraxe", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "openVideoCamera": "Abrir a cámara para un vídeo", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Vídeo ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "publish": "Publicar", + "dismiss": "Desbotar", + "markAsRead": "Marcar como lido", + "reportUser": "Denunciar usuaria", + "openChat": "Abrir Conversa", + "voiceCall": "Chamada de voz", + "emojis": "Emojis", + "placeCall": "Chamar", + "unsupportedAndroidVersionLong": "Esta característica require unha vesión máis recente de Android. Mira se hai actualizacións ou soporte de LineageOS.", + "videoCallsBetaWarning": "Ten en conta que as chamadas de vídeo están en fase beta. Poderían non funcionar correctamente ou non funcionar nalgunhas plataformas.", + "unsupportedAndroidVersion": "Version de Android non soportada", + "reactedWith": "{sender} reaccionou con {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Fixar na sala", + "confirmEventUnpin": "Tes a certeza de querer desafixar o evento?", + "experimentalVideoCalls": "Chamadas de vídeo en probas", + "emailOrUsername": "Email ou nome de usuaria", + "switchToAccount": "Cambiar á conta {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "previousAccount": "Conta anterior", + "nextAccount": "Conta seguinte", + "bundleName": "Nome do feixe", + "widgetVideo": "Vídeo", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "Personalizado", + "widgetName": "Nome", + "widgetUrlError": "Non é un URL válido.", + "widgetNameError": "Escribe un nome público.", + "addWidget": "Engadir widget", + "widgetEtherpad": "Nota de texto", + "errorAddingWidget": "Erro ao engadir o widget.", + "editBundlesForAccount": "Editar os feixes desta conta", + "addToBundle": "Engadir ao feixe", + "removeFromBundle": "Eliminar deste feixe", + "separateChatTypes": "Separar Conversas directas e Grupos", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youRejectedTheInvitation": "Rexeitaches o convite", + "youBannedUser": "Vetaches a {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 {user} convidoute", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youJoinedTheChat": "Unícheste á conversa", + "youAcceptedTheInvitation": "👍 Aceptaches o convite", + "youHaveWithdrawnTheInvitationFor": "Retiraches o convite para {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Convidaches a {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Expulsaches a {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Expulsaches e vetaches a {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Retiraches o veto a {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "saveKeyManuallyDescription": "Garda esta chave manualmente usando o sistema para compartir do dispositivo ou portapapeis.", + "storeInAndroidKeystore": "Gardar en Android KeyStore", + "storeInAppleKeyChain": "Gardar en Apple KeyChain", + "recoveryKeyLost": "Perdeches a chave de recuperación?", + "pleaseEnterRecoveryKey": "Escribe a túa chave de recuperación:", + "recoveryKey": "Chave de recuperación", + "storeSecurlyOnThisDevice": "Gardar de xeito seguro no dispositivo", + "pleaseEnterRecoveryKeyDescription": "Para desbloquear as mensaxes antigas, escribe a chave de recuperación creada nunha sesión existente. A chave de recuperación NON é o teu contrasinal.", + "users": "Usuarias", + "storeInSecureStorageDescription": "Gardar a chave de recuperación na almacenaxe segura deste dispositivo.", + "countFiles": "{count} ficheiros", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "unlockOldMessages": "Desbloquear mensaxes antigas", + "dehydrateTorLong": "Para usuarias de TOR, é recomendable exportar a sesión antes de pechar a xanela.", + "hydrateTor": "Usuarias TOR: Importar a sesión exportada", + "hydrateTorLong": "Exportaches a túa sesión a última vez en TOR? Importaa rápidamente e segue conversando.", + "hydrate": "Restablecer desde copia de apoio", + "dehydrateWarning": "Esta acción non é reversible. Pon coidado en gardar o ficheiro de apoio.", + "dehydrate": "Exportar sesión e eliminar dispositivo", + "dehydrateTor": "Usuarias TOR: Exportar sesión", + "indexedDbErrorTitle": "Problemas no modo privado", + "indexedDbErrorLong": "A almacenaxe de mensaxes non está activada por defecto no modo privado.\nMira en\n- about:config\n- establece dom.indexedDB.privateBrowsing.enabled como true\nSe non, non é posible executar FluffyChat.", + "user": "Usuaria", + "custom": "Personal", + "confirmMatrixId": "Confirma o teu ID Matrix para poder eliminar a conta.", + "supposedMxid": "Debería ser {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasdm": "Marcar como sala de mensaxe directa para o ID Matrix indicado", + "commandHint_markasgroup": "Marcar como grupo", + "whyIsThisMessageEncrypted": "Por que non podo ler esta mensaxe?", + "noKeyForThisMessage": "Pode ser que a mensaxe fose enviada antes de que ti accedeses á túa conta neste dispositivo.\n\nTamén é posible que a remitente non validase o teu dispositivo ou tamén que algo fallase na conexión a internet.\n\nPodes ler a mensaxe noutro dispositivo? Entón podes transferila desde el! Vai a Axustes > Dispositivos e comproba que tes tódolos dispositivos verificados. Entón cando abras a sala a próxima vez a sincronización realizarase e as chaves transmitiranse automáticamente.\n\nNon desexas perder as chaves cando pechas sesión ou cambias de dispositivo? Comproba nos axustes que activaches a copia de apoio das conversas.", + "appearOnTop": "Aparecer arriba", + "otherCallingPermissions": "Micrófono, cámara e outros permisos para FluffyChat", + "newGroup": "Novo grupo", + "newSpace": "Novo espazo", + "foregroundServiceRunning": "Esta notificación aparece cando se está a executar o servizo en segundo plano.", + "screenSharingTitle": "compartición da pantalla", + "callingPermissions": "Permisos de chamada", + "callingAccount": "Conta que chama", + "callingAccountDetails": "Permítelle a FluffyChat usar a app de telefonía nativa de android.", + "appearOnTopDetails": "Permítelle á app aparecer por enriba (non é preciso se xa configuraches FluffyChat como unha conta para chamadas)", + "enterSpace": "Entrar no espazo", + "enterRoom": "Entrar na sala", + "allSpaces": "Todos os espazos", + "screenSharingDetail": "Estás a compartir a túa pantalla en FluffyChat", + "numChats": "{number} conversas", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Agochar os eventos de menor relevancia", + "doNotShowAgain": "Non mostrar outra vez", + "commandHint_googly": "Envía uns ollos desos grandes", + "googlyEyesContent": "{senderName} enviouche uns ollos grandes", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} mándache un achuche", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_cuddle": "Envía un agarimo", + "commandHint_hug": "Envía un abrazo", + "hugContent": "{senderName} abrázate", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "encryptThisChat": "Cifrar esta conversa", + "disableEncryptionWarning": "Por razóns de seguridade non podes desactivar a cifraxe dunha conversa onde foi activada previamente.", + "sorryThatsNotPossible": "Lamentámolo... iso non é posible", + "deviceKeys": "Chaves do dispositivo:", + "newSpaceDescription": "Os Espazos permítenche consolidar as túas conversas e construir comunidades públicas ou privadas.", + "startFirstChat": "Abre a túa primeira conversa", + "wasDirectChatDisplayName": "Conversa baleira (era {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "reopenChat": "Reabrir conversa", + "noOtherDevicesFound": "Non se atopan outros dispositivos", + "noBackupWarning": "Aviso! Se non activas a copia de apoio da conversa, perderás o acceso ás túas mensaxes cifradas. É moi recomendable activar a copia de apoio da conversa antes de pechar a sesión.", + "fileIsTooBigForServer": "Non se puido enviar! O servidor só permite anexos que non superen {max}.", + "fileHasBeenSavedAt": "Gardouse o ficheiro en {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Ir á última mensaxe lida", + "readUpToHere": "Lin ate aquí", + "openLinkInBrowser": "Abrir ligazón no navegador", + "jump": "Ir alá", + "report": "informar", + "allRooms": "Todas as Conversas en grupo", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "😭 Vaia! Algo fallou. Se queres, podes informar do problema ás persoas desenvolvedoras.", + "signInWithPassword": "Accede con contrasinal", + "pleaseTryAgainLaterOrChooseDifferentServer": "Inténtao máis tarde ou elixe un servidor diferente.", + "signInWith": "Accede con {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Non é un ficheiro de imaxe.", + "importNow": "Importar agora", + "importEmojis": "Importar Emojis", + "importFromZipFile": "Importar desde ficheiro .zip", + "exportEmotePack": "Exportar paquete Emote como .zip", + "replace": "Substituír", + "sendTypingNotifications": "Permitir ver que estás escribindo", + "createGroup": "Crear grupo", + "messagesStyle": "Mensaxes:", + "profileNotFound": "Non se atopa a usuaria no servidor. Pode que haxa un problema coa conexión ou que a usuaria non exista.", + "shareInviteLink": "Comparte ligazón de convite", + "setColorTheme": "Cor do decorado:", + "setTheme": "Establecer decorado:", + "inviteContactToGroupQuestion": "Queres convidar a {contact} para que se una á conversa \"{groupName}\"?", + "tryAgain": "Intentar outra vez", + "optionalRedactReason": "(Optativo) Razón para editar a mensaxe...", + "redactedBy": "Editada por {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactedByBecause": "Editada por {username} debido a: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactMessageDescription": "A mensaxe vai ser editada para todas as participantes na conversa. Non ten volta atrás.", + "invite": "Convidar", + "addChatDescription": "Engadir descrición da conversa...", + "chatPermissions": "Permisos da conversa", + "chatDescription": "Descrición da conversa", + "chatDescriptionHasBeenChanged": "Cambiou a descrición da conversa", + "noChatDescriptionYet": "Aínda non se escribeu a descrición da conversa.", + "invalidServerName": "Nome de servidor non válido", + "directChat": "Conversa Directa", + "setChatDescription": "Escribir descrición da conversa", + "inviteGroupChat": "📨 Convidar a conversa en grupo", + "invitePrivateChat": "📨 Convidar a conversa privada", + "emoteKeyboardNoRecents": "Os emotes usados recentemente aparecerán aquí...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "banUserDescription": "Vaise vetar a usuaria na conversa e non poderá entrar outra vez ata que se retire o veto.", + "removeDevicesDescription": "Vas pechar a sesión neste dispositivo e xa non poderás recibir mensaxes nel.", + "unbanUserDescription": "A usuaria vai poder entrar outra vez na conversa se quere.", + "pushNotificationsNotAvailable": "Non están dispoñibles as notificacións push", + "makeAdminDescription": "Cando convirtas a esta usuaria en admin non poderás desfacer a acción xa que terá os mesmos permisos ca ti.", + "archiveRoomDescription": "Vaise mover a charla ao arquivo. Outras usuarias poderán ver que saíches da conversa.", + "invalidInput": "Contido non válido!", + "hasKnocked": "🚪 {user} petou na porta", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "wrongPinEntered": "PIN incorrecto! Inténtao outra vez en {seconds} segundos...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "learnMore": "Saber máis", + "roomUpgradeDescription": "Vaise recrear a charla coa nova versión da sala. Todas as participantes recibirán unha notificación para que cambien á nova charla. Podes ler máis información acerca das versións das salas en https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Escribe un número maior de cero", + "kickUserDescription": "A usuaria foi expulsada pero non vetada. En conversas públicas a usuaria pode volver cando queira.", + "createGroupAndInviteUsers": "Crear un grupo e convidar usuarias", + "groupCanBeFoundViaSearch": "O grupo pódese atopar ao buscar", + "noUsersFoundWithQuery": "Lamentamos non atopar ningunha usuaria con \"{query}\". Comproba se está ben escrito.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "yourGlobalUserIdIs": "O teu ID-usuaria global é: ", + "groupName": "Nome do grupo", + "searchChatsRooms": "Buscar #conversas, @usuarias...", + "startConversation": "Iniciar conversa", + "commandHint_sendraw": "Enviar json sen editar", + "wrongRecoveryKey": "Desculpa... non semella ser o xeito correcto de recuperar a chave.", + "blockListDescription": "Podes bloquear usuarias que che molesten. Non recibirás mensaxes nin convites para salas procedentes das usuarias da túa lista persoal de bloqueo.", + "blockedUsers": "Usuarias bloqueadas", + "block": "Bloquear", + "blockUsername": "Ignorar identificador", + "thisDevice": "Este dispositivo:", + "publicSpaces": "Espazos públicos", + "passwordIsWrong": "O contrasinal escrito non é correcto", + "pleaseEnterYourCurrentPassword": "Escribe o contrasinal actual", + "publicLink": "Ligazón pública", + "nothingFound": "Non atopamos nada...", + "decline": "Desbotar", + "newPassword": "Novo contrasinal", + "passwordsDoNotMatch": "Os contrasinais non concordan", + "subspace": "Subespazo", + "select": "Escolle", + "pleaseChooseAStrongPassword": "Elixe un contrasinal forte", + "addChatOrSubSpace": "Engadir charla ou sub espazo", + "leaveEmptyToClearStatus": "Deixa baleiro para limpar o teu estado.", + "joinSpace": "Únete ao espazo", + "searchForUsers": "Buscar @persoas...", + "databaseMigrationTitle": "Base de datos optimizada", + "databaseMigrationBody": "Agarda, podería levarnos un pouco.", + "databaseBuildErrorBody": "Non se puido crear a base de datos SQlite. A app intentará usar a base de datos clásica. Por favor informa deste fallo ás desenvolvedoras en {url}. A mensaxe do erro é: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "Houbo un fallo ao iniciar a app", + "sessionLostBody": "Estragouse a túa sesión. Por favor informa deste fallo ás desenvolvedoras en {url}. A mensaxe do erro é: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "A app vai intentar restablecer a sesión desde a copia de apoio. Por favor informa deste erro ás desenvolvedoras en {url}. A mensaxe do erro é: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Convidáronte cunha ligazón a:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "transparent": "Transparente", + "sendReadReceipts": "Enviar confirmación de lectura", + "sendReadReceiptsDescription": "Outras participantes na conversa poden ver cando liches unha mensaxe.", + "formattedMessages": "Mensaxes con formato", + "verifyOtherDevice": "🔐 Verificar outro dispositivo", + "verifyOtherUser": "🔐 Verificar outra usuaria", + "verifyOtherDeviceDescription": "Ao verificar outro dispositivo estás compartindo as chaves, aumentando a túa seguridade 💪. Ao iniciar a verificación aparecerá unha xanela emerxente nos dous dispositivos. Nesa xanela verás varios emojis ou números que tes que comparar entre eles. O mellor xeito de facelo é ter os dous dispositivos contigo cando inicias o proceso de verificación. 🤳", + "canceledKeyVerification": "{sender} desbotou a verificación da chave", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} xa pode verificar a chave", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "forwardMessageTo": "Reenviar a mensaxe a {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "As outras participantes da conversa poden ver cando estás a escribir unha mensaxe.", + "formattedMessagesDescription": "Mostrar texto enriquecido nas mensaxes como letra grosa usando markdown.", + "verifyOtherUserDescription": "Se verificas a outra usuaria, podes ter a certeza de que sabes con quen estás a conversar. 💪\n\nAo iniciar a verificación, ti mais a outra usuaria veredes unha xanela emerxente na app onde aparecerán varios emojis ou números que teredes que comparar entre vós.\n\nO mellor xeito de facelo é en persoa o cunha chamada de vídeo. 👭", + "requestedKeyVerification": "{sender} solicitou verificar a chave", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "acceptedKeyVerification": "{sender} aceptou a verificación da chave", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} completou a verificación da chave", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} comezou coa verificación da chave", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "presenceStyle": "Presenza:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "hidePresences": "Agochar Lista de estados?", + "presencesToggle": "Mostra mensaxes de estado de outras usuarias", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "incomingMessages": "Mensaxes recibidas", + "stickers": "Adhesivos", + "discover": "Descubrir", + "commandHint_ignore": "Ignorar o ID matrix indicado", + "commandHint_unignore": "Non ignorar o ID matrix indicado", + "unreadChatsInApp": "{appname}: {unread} charlas sen ler", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Nesta plataforma non temos soporte para cifrar a base de datos", + "accessAndVisibility": "Acceso e Visibilidade", + "accessAndVisibilityDescription": "Quen pode unirse a esta charla e de que xeito e como poden atopala.", + "customEmojisAndStickers": "Emojis personais e adhesivos", + "calls": "Chamadas", + "hideRedactedMessages": "Agochar mensaxes editadas", + "hideRedactedMessagesBody": "Se alguén corrixe unha mensaxe entón esta xa non será visible na charla.", + "hideInvalidOrUnknownMessageFormats": "Agochar formatos de mensaxe non válidos ou descoñecidos", + "hideMemberChangesInPublicChats": "Agochar cambios dos membros nas charlas públicas", + "notifyMeFor": "Notificarme sobre", + "hideMemberChangesInPublicChatsBody": "Non mostrar na cronoloxía se alguén se une ou deixa unha conversa pública, para mellorar a lexibilidade.", + "usersMustKnock": "As usuarias teñen que pedir entrar", + "userWouldLikeToChangeTheChat": "{user} quere unirse á charla.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "knocking": "A solicitar", + "chatCanBeDiscoveredViaSearchOnServer": "A charla pode ser atopada ao buscar en {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "createNewAddress": "Crear novos enderezos", + "appLockDescription": "Bloquear a app cun código PIN cando non a uses", + "globalChatId": "ID Global da charla", + "customEmojisAndStickersBody": "Engade ou comparte emojis personais e adhesivos que poden usarse nas charlas.", + "overview": "Vista xeral", + "passwordRecoverySettings": "Axustes de recuperación do contrasinal", + "noPublicLinkHasBeenCreatedYet": "Aínda non se creou unha ligazón pública", + "knock": "Solicitar acceso", + "noOneCanJoin": "Ninguén pode unirse", + "thereAreCountUsersBlocked": "Agora mesmo hai {count} usuarias bloqueadas.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "publicChatAddresses": "Enderezos públicos da charla", + "userRole": "Rol da usuaria", + "minimumPowerLevel": "{level} é o nivel mínimo de responsabilidade.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "Buscar na conversa \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Buscar máis...", + "gallery": "Galería", + "files": "Ficheiros", + "knockRestricted": "Peta á porta", + "restricted": "Non accesible", + "swipeRightToLeftToReply": "Despraza hacia a esquerda para responder", + "alwaysUse24HourFormat": "falso", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "noMoreChatsFound": "Non se atopan máis charlas…", + "joinedChats": "Charlas nas que participas", + "countChatsAndCountParticipants": "{chats} charlas e {participants} participantes", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "unread": "Sen ler", + "space": "Espazo", + "spaces": "Espazos", + "goToSpace": "Ir ao espazo: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Marcar como non lido", + "userLevel": "{level} - Usuaria", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderadora", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Administradora", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Cambiar os axustes xerais da charla", + "inviteOtherUsers": "Convidar a outras usuarias a esta charla", + "changeTheChatPermissions": "Cambiar os permisos na charla", + "changeTheVisibilityOfChatHistory": "Cambiar a visibilidade do historial da charla", + "changeTheCanonicalRoomAlias": "Cambiar o enderezo público principal da charla", + "sendRoomNotifications": "Enviar notificacións a @room", + "changeTheDescriptionOfTheGroup": "Cambiar a descrición da charla", + "invitedBy": "📩 Convidada por {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "changelog": "Novidades na versión", + "chatPermissionsDescription": "Define que nivel de permisos son necesarios para realizar certas accións nesta charla. Os niveis de permiso 0, 50 e 100 normalmente representan, usuarias, moderadoras e administradoras, pero son posibles outras escalas.", + "updateInstalled": "🎉 Instalouse a actualización a {version}!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "sendCanceled": "Cancelouse o envío", + "noChatsFoundHere": "Aínda non hai conversas. Comeza a conversar con alguén premendo no botón de abaixo. ⤵️", + "discoverHomeservers": "Atopar servidores", + "whatIsAHomeserver": "Que é un servidor de inicio?", + "loginWithMatrixId": "Acceder co ID-Matrix", + "homeserverDescription": "Todos os teus datos quedan gardados no servidor de inicio, igual que co teu provedor de correo electrónico. Podes elexir o servidor que queres usar e poderás comunicarte con todos os demais. Aprende máis en https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Non semella ser un servidor de inicio compatible. É o URL correcto?", + "calculatingFileSize": "Calculando o tamaño do ficheiro…", + "prepareSendingAttachment": "Preparando o envío…", + "sendingAttachment": "Enviando o anexo…", + "generatingVideoThumbnail": "Creando miniatura do vídeo…", + "compressVideo": "Comprimindo o vídeo…", + "serverLimitReached": "Acadouse o límite do servidor! Agarda {seconds} segundos…", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendingAttachmentCountOfCount": "Enviando o anexo {index} de {length}…", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Un dos teus dispositivos non está verificado", + "noticeChatBackupDeviceVerification": "Nota: Cando conectas todos os teus dispositivos á copia de apoio da conversa quedan verificados automaticamente.", + "blur": "Néboa:", + "opacity": "Opacidade:", + "contactServerSecurity": "Contacto con Seguridade do servidor", + "aboutHomeserver": "Sobre {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "welcomeText": "Ola! 👋 Isto é FluffyChat. Podes iniciar sesión en calquera servidor compatible con https://matrix.org. Poderás conversar con calquera. Unha enorme rede de mensaxería descentralizada!", + "setWallpaper": "Establecer fondo", + "manageAccount": "Xestionar conta", + "noContactInformationProvided": "O servidor non proporciona información de contacto válida", + "contactServerAdmin": "Contacto con Admin do servidor", + "supportPage": "Páxina de axuda", + "serverInformation": "Información do servidor:", + "name": "Nome", + "version": "Versión", + "website": "Páxina web", + "continueText": "Continuar", + "italicText": "Cursiva", + "strikeThrough": "Riscar", + "pleaseFillOut": "Por favor completa", + "invalidUrl": "URL non válido", + "boldText": "Resaltar texto", + "addLink": "Engadir ligazón", + "unableToJoinChat": "Non se puido acceder. Pode que a outra parte xa pechase a conversa.", + "sendImages": "Enviar {count} imaxe", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Comprimir", + "previous": "Anterior", + "otherPartyNotLoggedIn": "A outra parte non está conectada neste momento e pode que non reciba as mensaxes!", + "open": "Abrir", + "appWantsToUseForLogin": "Usar '{server}' para acceder", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "contentNotificationSettings": "Axustes de notificación de contido", + "generalNotificationSettings": "Axustes xerais das notificacións", + "roomNotificationSettings": "Axustes de notificacións da sala", + "userSpecificNotificationSettings": "Axustes de notificación específicos da usuaria", + "otherNotificationSettings": "Outros axustes das notificacións", + "notificationRuleContainsUserName": "Contén nome de usuaria", + "notificationRuleContainsUserNameDescription": "Informa á usuaria cando unha mensaxe contén o seu identificador.", + "notificationRuleMaster": "Acalar todas as notificacións", + "notificationRuleSuppressNotices": "Suprimir mensaxes automatizadas", + "notificationRuleSuppressNoticesDescription": "Suprime as notificacións desde clientes automatizados como os robots.", + "notificationRuleInviteForMe": "Teño un convite", + "notificationRuleInviteForMeDescription": "Informa á usuaria de que recibeu o convite para unha sala.", + "notificationRuleMemberEvent": "Eventos dos participantes", + "notificationRuleIsUserMention": "Mención da usuaria", + "notificationRuleIsUserMentionDescription": "Informa cando se menciona explícitamente a usuaria nunha mensaxe.", + "notificationRuleContainsDisplayName": "Contén o nome público", + "notificationRuleContainsDisplayNameDescription": "Informa á usuaria cando unha mensaxe contén o seu nome público.", + "notificationRuleIsRoomMention": "Mención da sala", + "notificationRuleIsRoomMentionDescription": "Informa á usuaria cando hai unha mención da sala.", + "notificationRuleRoomnotif": "Notificación da sala", + "notificationRuleRoomnotifDescription": "Informa á usuaria cando unha mensaxe contén '@room'.", + "notificationRuleTombstone": "Lápida", + "notificationRuleTombstoneDescription": "Informa á usuaria sobre a desactivación de mensaxes na sala.", + "notificationRuleReaction": "Reacción", + "notificationRuleReactionDescription": "Omite as notificacións sobre reaccións.", + "notificationRuleRoomServerAcl": "ACL da servidor da sala", + "notificationRuleRoomServerAclDescription": "Omite notificacións para as listas de control de acceso (ACL) do servidor da sala.", + "notificationRuleSuppressEdits": "Omite edicións", + "notificationRuleSuppressEditsDescription": "Omite as notificacións sobre mensaxes editadas.", + "notificationRuleCall": "Chamada", + "notificationRuleCallDescription": "Informa á usuaria sobre as chamadas.", + "notificationRuleEncryptedRoomOneToOne": "Sala cifrada conversa persoal", + "notificationRuleEncryptedRoomOneToOneDescription": "Informa á usuaria sobre mensaxes cifradas en salas de conversa persoal.", + "notificationRuleRoomOneToOne": "Sala de conversa persoal", + "notificationRuleRoomOneToOneDescription": "Informa á usuaria sobre mensaxes en salas de conversa persoal.", + "notificationRuleMessage": "Mensaxe", + "notificationRuleMessageDescription": "Informa á usuaria sobre mensaxes xenéricas.", + "notificationRuleEncrypted": "Salas cifradas", + "notificationRuleEncryptedDescription": "Informa á usuaria sobre mensaxes en salas cifradas.", + "notificationRuleJitsiDescription": "Informa á usuaria sobre eventos do widget Jitsi.", + "notificationRuleServerAcl": "Omite eventos do sevidor ACL", + "notificationRuleJitsi": "Jitsi", + "notificationRuleServerAclDescription": "Omite notificación sobre eventos do servidor ACL.", + "unknownPushRule": "Regra push descoñecida '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Se omites este axuste de notificacións non poderás desfacer a acción.", + "more": "Máis", + "newChatRequest": "📩 Nova solicitude de conversa", + "shareKeysWith": "Compartir chaves con…", + "shareKeysWithDescription": "En que dispositivos se pode confiar e poden ler as túas conversas cifradas?", + "allDevices": "Todos os dispositivos", + "crossVerifiedDevicesIfEnabled": "Dispositivos verificados se está activado", + "crossVerifiedDevices": "Dispositivos verificados", + "verifiedDevicesOnly": "Só dispositivos verificados", + "waitingForServer": "Agardando polo servidor…", + "appIntroduction": "FluffyChat permíteche laretar coas túas amizades entre diferentes mensaxerías. Coñece máis en https://matrix.org ou toca en *Continuar*.", + "notificationRuleMasterDescription": "Sobrescribe todas as outras regras e desactiva todas as notificacións.", + "appWantsToUseForLoginDescription": "Por tanto permites que a app e o sitio web compartan información sobre ti.", + "notificationRuleMemberEventDescription": "Suprime as notificacións dos eventos de participación.", + "synchronizingPleaseWaitCounter": " Sincronizando…({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "optionalMessage": "(Optativo) mensaxe…", + "notSupportedOnThisDevice": "Non compatible co dispositivo", + "takeAPhoto": "Facer foto", + "recordAVideo": "Gravar vídeo", + "enterNewChat": "Entrar na nova conversa", + "commandHint_roomupgrade": "Actualizar esta sala á versión de sala indicada", + "setCustomPermissionLevel": "Establecer nivel personalizado dos permisos", + "setPermissionsLevelDescription": "Elixe un rol predefinido dos indicados ou escribe un nivel personalizado entre 0 e 100.", + "ignoreUser": "Ignorar usuaria", + "normalUser": "Usuaria corrente", + "approve": "Aprobar", + "pleaseWaitUntilInvited": "Agora agarda a que alguén da sala te convide a entrar.", + "youHaveKnocked": "Petaches á porta", + "sentVoiceMessage": "🎙️ {duration} - Mensaxe de voz de {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "countInvited": "{count} convidadas", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "commandHint_logoutall": "Fechar a sesión en todos os dispositivos activos", + "commandHint_logout": "Fechar a sesión no dispositivo actual", + "moreEvents": "Máis eventos", + "customReaction": "Reacción personalizada", + "declineInvitation": "Rexeitar o convite", + "noMessagesYet": "Aínda non hai mensaxes", + "checkList": "Comprobar lista", + "displayNavigationRail": "Mostrar carril de navegación nos móbiles", + "longPressToRecordVoiceMessage": "Pulsación longa para gravar mensaxe de voz.", + "pause": "Deter", + "resume": "Continuar", + "newSubSpace": "Novo sub espazo", + "moveToDifferentSpace": "Mover a outro espazo", + "moveUp": "Mover arriba", + "moveDown": "Mover abaixo", + "removeFromSpaceDescription": "Vaise quitar a conversa do espazo pero seguirá aparecendo na túa lista de conversas.", + "countChats": "{chats} conversas", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "donate": "Doar", + "spaceMemberOf": "Participa no espazo {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Os membros de {spaces} poden petar á porta", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "startedAPoll": "{username} publicou unha enquisa.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Enquisa", + "startPoll": "Publicar enquisa", + "endPoll": "Finalizar enquisa", + "answersVisible": "Resultados visibles", + "answersHidden": "Non se ven os resultados", + "pollQuestion": "Pregunta da enquisa", + "answerOption": "Opción de resposta", + "addAnswerOption": "Engadir opción", + "allowMultipleAnswers": "Permitir varias respostas", + "pollHasBeenEnded": "Rematou a enquisa", + "countVotes": "{count, plural, =1{Un voto} other{{count} votos}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "As respostas son visibles ao finalizar a enquisa", + "replyInThread": "Responder ao fío", + "countReplies": "{count, plural, =1{Unha resposta} other{{count} respostas}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Fío", + "backToMainChat": "Volver á conversa principal", + "attribution": "Atribución", + "saveChanges": "Gardar cambios", + "createSticker": "Crear adhesivo ou emoji", + "useAsSticker": "Usar como adhesivo", + "useAsEmoji": "Usar como emoji", + "stickerPackNameAlreadyExists": "Xa existe ese nome de paquete de adhesivos", + "newStickerPack": "Novo paquete de adhesivos", + "stickerPackName": "Nome do paquete de adhesivos", + "skipChatBackup": "Omitir copia da conversa", + "skipChatBackupWarning": "Tes certeza? A non activar a copia de apoio da conversa poderías perder o acceso ás mensaxes se cambias de dispositivo.", + "loadingMessages": "Cargando mensaxes", + "setupChatBackup": "Configurar copia de apoio", + "changedTheChatDescription": "{username} cambiou a descrición da sala", + "changedTheChatName": "{username} cambiou o nome da sala", + "noMoreResultsFound": "Non hai máis resultados", + "chatSearchedUntil": "Buscouse na conversa ata {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "URL base para federación", + "clientWellKnownInformation": "Información Client-Well-Known:", + "baseUrl": "URL base", + "identityServer": "Servidor de identidade:", + "versionWithNumber": "Versión: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Rexistros", + "advancedConfigs": "Axustes avanzados", + "advancedConfigurations": "Configuracións avanzadas", + "signInWithLabel": "Acceder con:", + "signIn": "Acceder", + "createNewAccount": "Crear nova conta", + "signUpGreeting": "FluffyChat é descentralizada! Elixe un servidor para crear a conta e xa podes utilizar a app!", + "signInGreeting": "Xa tes unha conta en Matrix? Benvida! Selecciona o teu servidor de orixe e accede.", + "appIntro": "Con FluffyChat podes conversar coas amizades. É mensaxería segura e descentralizada en [matrix]! Coñece máis en https://matrix.org ou crea unha conta.", + "theProcessWasCanceled": "Desbotouse o proceso.", + "join": "Unirse", + "searchOrEnterHomeserverAddress": "Busca ou escribe o enderezo do servidor de inicio", + "matrixId": "ID en Matrix", + "setPowerLevel": "Establecer responsabilidade", + "makeModerator": "Facer moderadora", + "makeAdmin": "Facer admin", + "removeModeratorRights": "Retirar permiso de moderación", + "removeAdminRights": "Retirar permiso de administración", + "powerLevel": "Nivel responsabilidade", + "setPowerLevelDescription": "Os niveis de responsabilidade definen o que pode facer unha usuaria na sala, normalmente varía de 0 a 100.", + "owner": "Propietaria" +} diff --git a/assets/l10n/intl_he.arb b/lib/l10n/intl_he.arb similarity index 54% rename from assets/l10n/intl_he.arb rename to lib/l10n/intl_he.arb index 87d50b339..28f27b104 100644 --- a/assets/l10n/intl_he.arb +++ b/lib/l10n/intl_he.arb @@ -2,1088 +2,1208 @@ "@@last_modified": "2021-08-14 12:41:10.036931", "about": "אודות", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "קבל", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "{username} קיבל את ההזמנה", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "חשבון", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "activatedEndToEndEncryption": "{username} הפעיל הצפנה מקצה לקצה", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "admin": "מנהל", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "כינוי", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "answeredTheCall": "{senderName} ענה לשיחה", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "כל אחד יכול להצטרף", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "ארכיון", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "האם משתמשים אורחים מורשים להצטרף", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "האם אתה בטוח?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "כדי שתוכל לחתום על משתמש אחר , הזן את הסיסמה שלך או את מפתח השחזור.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "לקבל בקשת אימות זו מ- {username}?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changePassword": "שנה סיסמא", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "appLock": "נעילת אפליקציה", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "ביטול", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "addEmail": "הוסף מייל", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "הכל", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "allChats": "כל הצ'אטים", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "חסום", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOnEnter": "שלח בכניסה", "@sendOnEnter": {}, "badServerLoginTypesException": "שרת הבית תומך בסוגי הכניסה:\n{serverVersions}\nאבל אפליקציה זו תומכת רק ב:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username} שינה את כללי הגישה לאורחים ל: {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRules": "{username} שינה את כללי ההצטרפות", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatNameTo": "{username} שינה את שם הצ'אט ל: '{chatname}'", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "{username} שינה את קישור ההזמנה", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "repeatPassword": "כתוב שוב את הסיסמה", "@repeatPassword": {}, "areYouSureYouWantToLogout": "האם אתה בטוח שברצונך לצאת?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "צ׳אט", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "autoplayImages": "הפעל אוטומטית מדבקות ואנימציות מונפשים", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "badServerVersionsException": "שרת הבית תומך בגרסאות:\n{serverVersions}\nאבל האפליקציה הזו תומכת רק ב-{supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "banFromChat": "צאט חסום", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "{username} חסם את {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "blockDevice": "חסום מכשיר", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "חסום", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "הודעות בוט", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "cantOpenUri": "לא ניתן לפתוח את ה-URI {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "changeDeviceName": "שנה את שם המכשיר", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "{username} שינה את האווטאר של הצ'אט", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "{username} שינה את תיאור הצ'אט ל: '{description}'", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheChatPermissions": "{username} שינה את הרשאות הצ'אט", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheDisplaynameTo": "{username} שינה את שם התצוגה שלו ל: '{displayname}'", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username} שינה את כללי הגישה לאורחים", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibility": "{username} שינה את נראות ההיסטוריה", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "{username} שינה את נראות ההיסטוריה ל: {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username} שינה את כללי ההצטרפות ל: {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username} שינה את האווטאר שלו", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomAliases": "{username} שינה את כינוי החדר", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changeTheHomeserver": "שנה את שרת הבית", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "שנה את הסגנון שלך", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheNameOfTheGroup": "שנה את שם הקבוצה", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "changeYourAvatar": "שינוי האווטאר שלך", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "ההצפנה נפגמה", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "yourChatBackupHasBeenSetUp": "גיבוי הצ'אט שלך הוגדר.", "@yourChatBackupHasBeenSetUp": {}, "chatBackup": "גיבוי צ'אט", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_ban": "חסום את המשתמש הנתון מהחדר הזה", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_clearcache": "נקה מטמון", "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "commandHint_create": "צור צ'אט קבוצתי ריק\nהשתמש ב--no-encryption כדי להשבית את ההצפנה", "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "commandHint_discardsession": "התעלם מהסשן", "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "commandHint_dm": "התחל צ'אט ישיר\nהשתמש ב--no-encryption כדי להשבית את ההצפנה", "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "commandHint_html": "שלח טקסט בתבנית HTML", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "הזמן את המשתמש הנתון לחדר זה", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandHint_join": "הצטרף לחדר הנתון", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_kick": "הסר את המשתמש הנתון מהחדר הזה", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_leave": "עזוב את החדר הזה", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_me": "תאר את עצמך", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "chatDetails": "פרטי צ'אט", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackupDescription": "גיבוי הצ'אט שלך מאובטח באמצעות מפתח אבטחה. אנא וודא שאתה לא מאבד אותו.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "chatHasBeenAddedToThisSpace": "צ'אט נוסף למרחב הזה", "@chatHasBeenAddedToThisSpace": {}, "chats": "צ'אטים", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "בחר סיסמה חזקה", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "נקה ארכיון", "@clearArchive": {}, "close": "סגור", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_myroomavatar": "הגדר את התמונה שלך לחדר זה (על ידי mxc-uri)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_myroomnick": "הגדר את שם התצוגה שלך עבור חדר זה", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "addToSpace": "הוסף לחלל", "@addToSpace": {}, "commandHint_unban": "בטל את החסימה של המשתמש הנתון מהחדר הזה", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "countParticipants": "{count} משתתפים", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "create": "צור", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "createdTheChat": "{username} יצר את הצ'אט", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "currentlyActive": "פעיל כעת", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "כהה", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{month}-{day}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "defaultPermissionLevel": "רמת הרשאת ברירת מחדל", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "מחק חשבון", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "מחק הודעה", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "מזהה מכשיר", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "התקנים", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "צ'אטים ישירים", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "הורד קובץ", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "ערוך", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "ערוך את שם התצוגה", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "ערוך כינויים לחדר", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "אימוט כבר קיים!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "צ'אט ריק", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "מוצפן", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "enterAnEmailAddress": "הזן כתובת דואר אלקטרוני", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "enterYourHomeserver": "הזן את שרת הבית שלך", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "everythingReady": "הכל מוכן!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "שם קובץ", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "גודל גופן", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "העבר", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "fromJoining": "מהצטרפות", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "fromTheInvitation": "מההזמנה", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "עבור לחדר החדש", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "הקבוצה ציבורית", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "groupWith": "קבוצה עם {displayname}", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "guestsAreForbidden": "אורחים אסורים", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "אורחים יכולים להצטרף", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "מזהה", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "זהות", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "משתמשים שהתעלמו מהם", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "ביטוי סיסמה או מפתח שחזור שגויים", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "הזמן איש קשר", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "invited": "הזמין", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUser": "{username} הזמין את {targetName}", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "invitedUsersOnly": "משתמשים מוזמנים בלבד", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteForMe": "הזמנה בשבילי", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteText": "{username} הזמין אותך ל-FluffyChat.\n1. התקן את FluffyChat: https://fluffychat.im\n2. הירשם או היכנס\n3. פתח את קישור ההזמנה: {link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "isTyping": "מקליד/ה…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "joinedTheChat": "{username} הצטרף לצ'אט", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "joinRoom": "הצטרף לחדר", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "kicked": "{username} בעט ב {targetName}", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickedAndBanned": "{username} בעט וחסם {targetName}", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickFromChat": "בעיטה מהצ'אט", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "lastActiveAgo": "פעילות אחרונה: {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "leftTheChat": "עזב את הצ'אט", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "loadingPleaseWait": "טוען אנא המתן.", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "loadMore": "טען עוד…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "locationDisabledNotice": "שירותי המיקום מושבתים. אנא הפעל אותם כדי לשתף את המיקום שלך.", "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "העתק", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_send": "שלח טקסט", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "commandHint_op": "הגדרת רמת צריכת החשמל של המשתמש הנתון (ברירת מחדל: 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_plain": "שלח טקסט לא מעוצב", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_react": "שלח תשובה כתגובה", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "containsUserName": "מכיל שם משתמש", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "createNewSpace": "חלל חדש", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "אפשר הצפנה", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "הזמן איש קשר אל {groupName}", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "dateWithYear": "{year}-{month}-{day}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "deactivateAccountWarning": "פעולה זו תשבית את חשבון המשתמש שלך. אי אפשר לבטל את זה! האם אתה בטוח?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "מכשיר", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "קבוצה", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "שם התצוגה השתנה", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "ערוך שרתים חסומים", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "עריכת אווטאר של חדר", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName} סיים את השיחה", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "groups": "קבוצות", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryptionWarning": "לא תוכל לבטל את ההצפנה יותר. האם אתה בטוח?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "הצפנה", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "errorObtainingLocation": "שגיאה בהשגת מיקום: {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "hasWithdrawnTheInvitationFor": "{username} ביטל את ההזמנה עבור {targetName}", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "hideRedactedEvents": "הסתר אירועים מצונזרים", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "ההצפנה אינה מופעלת", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "פוגעני ביותר", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "הסתר אירועים לא ידועים", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "loadCountMoreParticipants": "טען {count} משתתפים נוספים", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "homeserver": "שרת בית", "@homeserver": {}, "ignore": "התעלם", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "לחצתי על הקישור", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "leave": "לעזוב", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "רשיון", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "בהיר", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "מחיקה", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "לֹא פּוֹגֵעַ", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "configureChat": "קביעת תצורה של צ'אט", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "לאשר", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "התחבר", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "contactHasBeenInvitedToTheGroup": "איש הקשר הוזמן לקבוצה", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "מכיל שם תצוגה", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "התוכן דווח למנהלי השרת", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "הועתק ללוח הגזירים", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "commandInvalid": "הפקודה אינה חוקית", "@commandInvalid": { - "type": "text" + "type": "String" }, "commandMissing": "{command} אינו פקודה.", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "compareEmojiMatch": "השווה וודא שהאימוג'י הבאים תואמים לאלו של המכשיר השני:", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "השווה וודא שהמספרים הבאים תואמים לאלה של המכשיר השני:", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "העתק ללוח", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "לא ניתן לפענח הודעה: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "help": "עזרה", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "howOffensiveIsThisContent": "עד כמה התוכן הזה פוגעני?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "locationPermissionDeniedNotice": "הרשאת המיקום נדחתה. אנא אפשר את היכולת לשתף את מיקומך.", "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "כניסה", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "מנחה", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "שים לב שאתה צריך Pantalaimon כדי להשתמש בהצפנה מקצה לקצה לעת עתה.", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "צ'אט חדש", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newVerificationRequest": "בקשת אימות חדשה!", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "הבא", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "לא", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "אין חיבור לשרת", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "אתה יכול להפעיל הצפנה רק כשהחדר כבר לא נגיש לציבור.", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "לא נמצאו חדרים…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "התראות", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "numUsersTyping": "{count} משתמשים מקלידים…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "obtainingLocation": "משיג מיקום…", "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "onlineKeyBackupEnabled": "גיבוי מפתח מקוון מופעל", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsPushError": "אופס! למרבה הצער, אירעה שגיאה בעת הגדרת התראות.", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "אופס, משהו השתבש…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "פתח את האפליקציה לקריאת הודעות", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "oneClientLoggedOut": "אחד מהמכשירים שלך התנתק", @@ -1094,146 +1214,152 @@ "@editBundlesForAccount": {}, "participant": "משתתף", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "סיסמה", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseClickOnLink": "אנא לחץ על הקישור במייל ולאחר מכן המשך.", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "אנא הזן 4 ספרות או השאר ריק כדי להשבית את נעילת האפליקציה.", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "מחובר/ת", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "addToBundle": "הוסף לחבילה", "@addToBundle": {}, "passphraseOrKey": "ביטוי סיסמה או מפתח שחזור", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "שכחתי סיסמה", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "הסיסמה שונתה", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "שחזור סיסמה", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "אנשים", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "בחר תמונה", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "play": "הפעל {fileName}", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "pleaseChoose": "אנא בחר", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChooseAPasscode": "אנא בחר קוד גישה", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "נא הזן את הסיסמה שלך", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "אנא הזן את קוד הpin שלך", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "קוד pin", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "אנא הזן שם משתמש", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "הודעה חדשה ב-FluffyChat", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "noGoogleServicesWarning": "נראה שאין לך שירותי גוגל בטלפון שלך. זו החלטה טובה לפרטיות שלך! כדי לקבל התרעות ב- FluffyChat אנו ממליצים להשתמש https://microg.org/ או https://unifiedpush.org/.", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "noMatrixServer": "{server1} אינו שרת מטריקס, השתמש ב-{server2} במקום זאת?", "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "none": "ללא", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "עדיין לא הוספת דרך לשחזר את הסיסמה שלך.", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "offensive": "פוגעני", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "התראות הופעלו עבור חשבון זה", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "bundleName": "שם החבילה", "@bundleName": {}, "offline": "לא מקוון", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "openVideoCamera": "פתח את המצלמה לסרטון", "@openVideoCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "removeFromBundle": "הסר מחבילה זו", @@ -1242,7 +1368,7 @@ "@enableMultiAccounts": {}, "openInMaps": "פתיחה במפות", "@openInMaps": { - "type": "text", + "type": "String", "placeholders": {} }, "link": "קישור", @@ -1251,879 +1377,59 @@ "@serverRequiresEmail": {}, "logout": "יציאה", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "muteChat": "השתקת הצ'אט", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "scanQrCode": "סרוק קוד QR", "@scanQrCode": {}, "noPermission": "אין הרשאה", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "or": "או", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "logInTo": "היכנס אל {homeserver}", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "memberChanges": "שינויים בחבר", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "הזכיר", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "הודעות", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "פתח מצלמה", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@reply": { - "type": "text", - "placeholders": {} - }, - "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setColorTheme": {}, - "@nextAccount": {}, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@remove": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@removeDevice": { - "type": "text", - "placeholders": {} - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "@sendMessages": { - "type": "text", - "placeholders": {} - }, - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@reason": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@storeInAppleKeyChain": {}, - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@signInWithPassword": {}, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "@whyIsThisMessageEncrypted": {}, - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@dehydrateWarning": {}, - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@fileIsTooBigForServer": {}, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@recording": { - "type": "text", - "placeholders": {} - }, - "@optionalRedactReason": {}, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@dehydrate": {}, - "@send": { - "type": "text", - "placeholders": {} - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "@enterRoom": {}, - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@redactMessageDescription": {}, - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, - "@invalidInput": {}, - "@dehydrateTorLong": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@voiceCall": {}, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@you": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@search": { - "type": "text", - "placeholders": {} - }, - "@newGroup": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@security": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "@widgetName": {}, - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@errorAddingWidget": {}, - "@commandHint_hug": {}, - "@replace": {}, - "@reject": { - "type": "text", - "placeholders": {} - }, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@privacy": { - "type": "text", - "placeholders": {} - }, - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "@hydrateTorLong": {}, - "@time": {}, - "@custom": {}, - "@noBackupWarning": {}, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@sendVideo": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "@importNow": {}, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@invite": {}, - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "@indexedDbErrorTitle": {}, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@ok": { - "type": "text", - "placeholders": {} - }, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "@screenSharingDetail": {}, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@placeCall": {} -} \ No newline at end of file + "notAnImage": "הקובץ אינו תמונה.", + "@notAnImage": {}, + "alwaysUse24HourFormat": "", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + } +} diff --git a/lib/l10n/intl_hi.arb b/lib/l10n/intl_hi.arb new file mode 100644 index 000000000..b67c4d966 --- /dev/null +++ b/lib/l10n/intl_hi.arb @@ -0,0 +1,72 @@ +{ + "remove": "निकालना", + "@remove": { + "type": "String", + "placeholders": {} + }, + "importFromZipFile": ".zip फ़ाइल से आयात करें", + "repeatPassword": "पासवर्ड दोहराएं", + "exportEmotePack": "इमोट पैक को .zip के रूप में निर्यात करें", + "importEmojis": "इमोजी आयात करें", + "notAnImage": "कोई छवि फ़ाइल नहीं।", + "importNow": "अभी आयात करें", + "setCustomPermissionLevel": "अपना अनुमति स्तर निर्धारित करें", + "setPermissionsLevelDescription": "कृपया नीचे दी गई भूमिका चुनें या 0 से 100 के बीच अपनी कस्टम अनुमति स्तर दर्ज करें।", + "ignoreUser": "उपयोगकर्ता को नजरअंदाज करें", + "normalUser": "सामान्य उपयोगकर्ता", + "replace": "बदलें", + "about": "हमारे बारे में", + "aboutHomeserver": "{homeserver} की जानकारी", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "accept": "स्वीकार करें", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} ने निमंत्रण स्वीकार किया", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "अकाउंट", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} ने एंड-टू-एंड एन्क्रिप्शन चालू किया", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "ईमेल ऐड करें", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "कृपया अपना अकाउंट हटाने के लिए अपनी मैट्रिक्स आईडी की पुष्टि करें।", + "supposedMxid": "यह {mxid} होना चाहिए", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "चैट का विवरण जोड़ें..।" +} diff --git a/lib/l10n/intl_hr.arb b/lib/l10n/intl_hr.arb new file mode 100644 index 000000000..936e2fa79 --- /dev/null +++ b/lib/l10n/intl_hr.arb @@ -0,0 +1,3142 @@ +{ + "@@locale": "hr", + "@@last_modified": "2021-08-14 12:41:10.025984", + "about": "Informacije", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Prihvati", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} je prihvatio/la poziv", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Račun", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} je aktivirao/la obostrano šifriranje", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Dodaj e-mail adresu", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Administrator", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "pseudonim", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Svi", + "@all": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} je odgovorio/la na poziv", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Svatko se može pridružiti", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Zaključavanje programa", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arhiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Smiju li se gosti pridružiti", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Stvarno to želiš?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Stvarno se želiš odjaviti?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Za potpisivanje druge osobe, upiši svoju sigurnosnu lozinku ili ključ za oporavak.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Prihvatiti ovaj zahtjev za potvrđivanje od {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "Homeserver podržava vrste prijave:\n{serverVersions}\nMeđutim ovaj program podržava samo:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "Homeserver podržava verzije specifikacije:\n{serverVersions}\nMeđutim ovaj program podržava samo {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Isključi iz chata", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Isključen", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} je isključio/la {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blokiraj uređaj", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Blokirano", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Poruke bota", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Odustani", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "URI adresa {uri} se ne može otvoriti", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Promijeni ime uređaja", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} je promijenio/la avatar chata", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} je promijenio/la opis chata u: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} je promijenio/la ime chata u: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} je promijenio/la dozvole chata", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} je promijenio/la svoje prikazno ime u: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} je promijenio/la pravila pristupa za goste", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} je promijenio/la pravila pristupa za goste u: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} je promijenio/la vidljivost kronologije", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} je promijenio/la vidljivost kronologije u: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} je promijenio/la pravila pridruživanja", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} je promijenio/la pravila pridruživanja u: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} je promijenio/la svoj avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} je promijenio/la pseudonime soba", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} je promijenio/la poveznicu poziva", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Promijeni lozinku", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Promijeni domaći server", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Promijeni tvoj stil", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Promijeni ime grupe", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Promijeni svoj avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Šifriranje je oštećeno", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Sigurnosna kopija chata", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Tvoje poruke su osigurane s ključem za obnavljanje. Pazi da ga ne izgubiš.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Detalji chata", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Chatovi", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Odaberi snažnu lozinku", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Isprazni arhiv", + "close": "Zatvori", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Isključi navedenog korisnika iz ove sobe", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Pošalji HTML formatirani tekst", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Pozovi navedenog korisnika u ovu sobu", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Pridruži se navedenoj sobi", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Ukloni navedenog korisnika iz ove sobe", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Napusti ovu sobu", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Opiši se", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Postavi svoju sliku za ovu sobu (mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Postavi svoje ime za ovu sobu", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Postavi razinu prava navedenog korisnika (standardno: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Pošalji neformatirani tekst", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Pošalji odgovor kao reakciju", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Pošalji tekst", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Ponovo uključi navedenog korisnika u ovu sobu", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Naredba nevaljana", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} nije naredba.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Usporedi emoji sličice", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Usporedi brojeve", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Konfiguriraj chat", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Potvrdi", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Spoji", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt je pozvan u grupu", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Sadržava prikazano ime", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Sadrži korisničko ime", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Sadržaj je prijavljen administratorima servera", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Kopirano u međuspremnik", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopiraj", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopiraj u međuspremnik", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Neuspjelo dešifriranje poruke: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "Broj sudionika: {count}", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Stvori", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} je stvorio/la chat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Novi prostor", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Trenutačno aktivni", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Tamna", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Ovo će nepovratno deaktivirati tvoj korisnički račun. Stvarno to želiš?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Standardna razina dozvole za nove korisnike", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Izbriši", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Izbriši račun", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Izbriši poruku", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Uređaj", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID oznaka uređaja", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Uređaji", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Izravni chatovi", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Prikazno ime je promijenjeno", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Preuzmi datoteku", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Uredi", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Uredi blokirane servere", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Uredi prikazano ime", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Uredi pseudonime sobe", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Uredi avatar sobe", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emotikon već postoji!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Neispravna kratica emotikona!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Paketi emotikona za sobu", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Postavke emotikona", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Kratica emotikona", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Moraš odabrati jednu kraticu emotikona i sliku!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Prazan chat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Aktiviraj paket emotikona globalno", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Aktiviraj šifriranje", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Više nećeš moći deaktivirati šifriranje. Stvarno to želiš?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Šifrirano", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Šifriranje", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Šifriranje nije aktivirano", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} je završio/la poziv", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Upiši e-mail adresu", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Upiši svoj homeserver", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Sve je spremno!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Izrazito uvredljiv", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Ime datoteke", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Veličina fonta", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Proslijedi", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Od pridruživanja", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Od poziva", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Idi u novu sobu", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Grupiraj", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Grupa je javna", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Grupe", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grupa s {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Gosti su zabranjeni", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Gosti se mogu pridružiti", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} je povukao/la poziv za {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Pomoć", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Sakrij promijenjene događaje", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Sakrij nepoznate događaje", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Koliko je ovaj sadržaj uvredljiv?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identitet", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Zanemari", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Zanemareni korisnici", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Pritisnuo/la sam poveznicu", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Neispravna lozinka ili ključ za obnavljanje", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Neuvredljiv", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Pozovi kontakt", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Pozovi kontakt u {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Pozvan/a", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} je pozvao/la {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Samo pozvani korisnici", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Poziv za mene", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} te je pozvao/la u FluffyChat. \n1. Posjeti strnicu fluffychat.im i instaliraj aplikaciju \n2. Registriraj ili prijavi se \n3. Otvori poveznicu poziva: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "tipka …", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} se pridružio/la chatu", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Pridruži se sobi", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} je izbacio/la {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} je izbacio/la i isključio/la {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Izbaci iz chata", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Zadnja aktivnost: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Napusti", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Napustio/la je chat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licenca", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Svijetla", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Učitaj još {count} sudionika", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Učitava se … Pričekaj.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Učitaj još …", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Prijava", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Prijavi se na {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Odjava", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Promjene člana", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Spominjanje", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Poruke", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Voditelj", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Isključi zvuk chata", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Za trenutačno korištenje obostranog šifriranja trebaš Pantalaimon.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Novi chat", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nova poruka u FluffyChatu", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Novi zahtjev za potvrđivanje!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Dalje", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Ne", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Ne postoji veza sa serverom", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Nema emotikona. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Šifriranje možeš aktivirati samo nakon što soba više nije javno dostupna.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "none": "Ništa", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Još nisi dodao/la način za obnavljanje lozinke.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Bez dozvole", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Nema soba …", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Obavijesti", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Obavijesti su aktivirane za ovaj račun", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} korisnika tipkaju …", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offensive": "Uvredljiv", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Nepovezano s internetom", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "U redu", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Povezano s internetom", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Internetski ključ sigurnosnih kopija je aktiviran", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Ups! Nažalost se dogodila greška prilikom postavljanja automatskog primanja obavijesti.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ups, dogodila se greška …", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Za čitanje poruka, otvori program", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Otvori kameru", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "or": "Ili", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Sudionik", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "tajni izraz ili ključ za obnavljanje", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Lozinka", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Zaboravljena lozinka", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Lozinka je promijenjena", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Obnavljanje lozinke", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Ljudi", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Odaberi sliku", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Prikvači", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Sviraj {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Odaberi", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Odaberi lozinku", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Pritisni poveznicu u e-mailu i zatim nastavi.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Upiši 4 znamenke ili ostavi prazno, za deaktiviranje zaključavanja programa.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Upiši svoju lozinku", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Upiši svoj pin", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Upiši svoje korisničko ime", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Slijedi upute na web-stranici i dodirni „Dalje”.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privatnost", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Javne sobe", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Pravila slanja", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Razlog", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Snimanje", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} je preuredio/la događaj", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Ispravi poruku", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Registracija", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Odbij", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} je odbio/la poziv", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Ponovo se pridruži", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Ukloni", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Ukloni sve druge uređaje", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Uklonjeno od {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Ukloni uređaj", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Ponovo uključi u chat", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Ukloni svoj avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Zamijeni sobu s novom verzijom", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Odgovori", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Prijavi poruku", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Zatraži dozvolu", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Soba je nadograđena", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Verzija sobe", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Spremi datoteku", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Traži", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Sigurnost", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Viđeno od {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Pošalji", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Pošalji poruku", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Pošalji kao tekst", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Pošalji audio datoteku", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Pošalji datoteku", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Pošalji sliku", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Pošalji poruke", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Pošalji original", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Pošalji naljepnicu", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Pošalji video datoteku", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} ja poslao/la datoteku", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} ja poslao/la audio snimku", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} ja poslao/la sliku", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} je poslao/la naljepnicu", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} je poslao/la video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} je poslao/la podatke poziva", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Postavi kao glavni pseudonim", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Postavi prilagođene emotikone", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Pošalji poveznicu poziva", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Postavi razinu dozvola", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Postavi stanje", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Postavke", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Dijeli", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} je dijelio/la svoje mjesto", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "showPassword": "Pokaži lozinku", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Jednokratna prijava", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Preskoči", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Izvorni kȏd", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Prostor je javan", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Ime prostora", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} ja započeo/la poziv", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Stanje", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Kako si danas?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Pošalji", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sinkronizira se … Pričekaj.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sustav", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Ne poklapaju se", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Poklapaju se", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Uklj/Isklj favorite", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Uklj/Isklj isključene", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Označi kao pročitano/nepročitano", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Previše zahtjeva. Pokušaj ponovo kasnije!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Prenesi s jednog drugog uređaja", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Pokušaj ponovo poslati", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Nedostupno", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} je ponovo uključio/la {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Deblokiraj uređaj", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Nepoznat uređaj", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Nepoznat algoritam šifriranja", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Nepoznat događaj '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Uključi zvuk chata", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Otkvači", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 nepročitan chat} few{{unreadCount} nepročitana chata} other{{unreadCount} nepročitanih chatova}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} i još {count} korisnika tipkaju …", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} i {username2} tipkaju …", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} tipka …", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} je napustio/la chat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Korisničko ime", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} ja poslao/la {type} događaj", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Potvrđeno", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Potvrdi", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Pokreni potvrđivanje", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Uspješno si potvrdio/la!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Potvrđivanje drugog računa", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Video poziv", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Vidljivost povijesti chata", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Vidljivo za sve sudionike", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Vidljivo za sve", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Glasovna poruka", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Čeka se na sugovornika da prihvati zahtjev …", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Čeka se na sugovornika da prihvati emoji …", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Čeka se na sugovornika da prihvati brojeve …", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Pozadina:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Upozorenje!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Poslali smo ti e-mail", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Tko može izvršiti koju radnju", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Tko se smije pridružiti grupi", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Zašto želiš ovo prijaviti?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Izbrisati sigurnosnu kopiju chata za stvaranje novog sigurnosnog ključa za obnavljanje?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Lozinku možeš obnoviti pomoću ovih adresa.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Napiši poruku …", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Da", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Ti", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Više ne sudjeluješ u ovom chatu", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Isključen/a si iz ovog chata", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Tvoj javni ključ", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Dijeli lokaciju", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Lokacijske dozvole su odbijene. Za dijeljenje tvoje lokacije dozvoli ih.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Lokacijske usluge su deaktivirane. Za dijeljenje tvoje lokacije aktiviraj ih.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Dohvaćanje lokacije …", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Greška u dohvaćanju lokacije: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "openInMaps": "Otvori u kartama", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} nije matrix server. Da li umjesto njega koristiti {server2}?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "autoplayImages": "Automatski pokreni animirane naljepnice i emotikone", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "allChats": "Svi chatovi", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Chat je dodan u ovaj prostor", + "addToSpace": "Dodaj u prostor", + "serverRequiresEmail": "Za registraciju ovaj server mora potvrditi tvoju e-mail adresu.", + "scanQrCode": "Snimi QR kod", + "homeserver": "Homeserver", + "sendOnEnter": "Pošalji pritiskom tipke enter", + "link": "Poveznica", + "enableMultiAccounts": "(BETA) Omogući korištenje više računa na ovom uređaju", + "bundleName": "Ime paketa", + "removeFromBundle": "Ukloni iz ovog paketa", + "addToBundle": "Dodaj u paket", + "editBundlesForAccount": "Uredi pakete za ovaj račun", + "addAccount": "Dodaj račun", + "oneClientLoggedOut": "Jedan od tvojih klijenata je odjavljen", + "unverified": "Nepotvrđeno", + "yourChatBackupHasBeenSetUp": "Sigurnosna kopija tvog chata je postavljena.", + "repeatPassword": "Ponovi lozinku", + "messageInfo": "Informacija poruke", + "messageType": "Vrsta poruke", + "sender": "Pošiljatelj", + "openGallery": "Otvori galeriju", + "time": "Vrijeme", + "removeFromSpace": "Ukloni iz prostora", + "addToSpaceDescription": "Odaberi prostor kojem će se ovaj chat dodati.", + "start": "Početak", + "commandHint_clearcache": "Isprazni predmemoriju", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Stvori prazan grupni chat\nKoristi --no-encryption za deaktiviranje šifriranja", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Odbaci sesiju", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Započni izravni chat\nKoristi --no-encryption za deaktiviranje šifriranja", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "openVideoCamera": "Otvori kameru za video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "publish": "Objavi", + "markAsRead": "Označi kao pročitano", + "reportUser": "Prijavi korisnika", + "openChat": "Otvori chat", + "dismiss": "Odbaci", + "unsupportedAndroidVersion": "Nepodržana Android verzija", + "widgetVideo": "Video", + "widgetEtherpad": "Tekstna bilješka", + "widgetCustom": "Prilagođeno", + "widgetName": "Ime", + "widgetUrlError": "Ovo nije valjan URL.", + "switchToAccount": "Prijeđi na račun {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Sljedeći račun", + "emailOrUsername": "E-mail adresa ili korisničko ime", + "unsupportedAndroidVersionLong": "Ova funkcija zahtijeva noviju verziju Androida. Provjeri, postoje li nove verzije ili podrška za Lineage OS.", + "previousAccount": "Prethodni račun", + "recoveryKey": "Ključ za obnavljanje", + "recoveryKeyLost": "Izgubio/la si ključ za obnavljanje?", + "youKickedAndBanned": "🙅 Izbacio/la i isključio/la si korisnika {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "dehydrateWarning": "Ovo je nepovratna radnja. Spremi datoteku sigurnosne kopije na sigurno mjesto.", + "hydrateTor": "Korisnici TOR-a: Uzvezite izvoz sesije", + "dehydrateTor": "Korisnici TOR-a: izvezite sesiju", + "emojis": "Emojiji", + "indexedDbErrorLong": "Spremište poruka nažalost nije standarno uključena u privatnom modusu.\nOtvori stranicu\n - about:config\n - postavi dom.indexedDB.privateBrowsing.enabled na true\nFluffyChat se inače neće moći pokrenuti.", + "storeSecurlyOnThisDevice": "Spremi sigurno na ovom uređaju", + "countFiles": "Broj datoteka: {count}", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "reactedWith": "{sender} je reagirao/la sa {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Prikvači na sobu", + "confirmEventUnpin": "Stvarno želiš trajno otkvačiti događaj?", + "voiceCall": "Glasovni poziv", + "placeCall": "Nazovi", + "videoCallsBetaWarning": "Napominjemo da se funkcija videopoziva trenutačno nalazi u beta stanju. Možda neće raditi ispravno ili uopće neće raditi na svim platformama.", + "experimentalVideoCalls": "Eksperimentalni videopozivi", + "widgetJitsi": "Jitsi Meet", + "addWidget": "Dodaj widget", + "widgetNameError": "Zadaj prikazno ime.", + "youRejectedTheInvitation": "Odbio/la si poziv", + "errorAddingWidget": "Greška prilikom dodavanja widgeta.", + "youJoinedTheChat": "Pridružio/la si se chatu", + "youAcceptedTheInvitation": "👍 Prihvatio/la si poziv", + "youHaveWithdrawnTheInvitationFor": "Povukao/la si poziv za korisnika {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 {user} te je pozvao/la", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Pozvao/la si korisnika {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Izbacio/la si korisnika {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Ponovo si uključio/la korisnika {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "dehydrate": "Izvezi sesiju i izbriši uređaj", + "unlockOldMessages": "Otključaj stare poruke", + "storeInSecureStorageDescription": "Ključ za obnavljanje spremi u sigurno spremište na ovom uređaju.", + "saveKeyManuallyDescription": "Spremi ovaj ključ ručno pokretanjem dijaloga za dijeljenje sustava ili međuspremnika.", + "storeInAndroidKeystore": "Spremi u Android KeyStore", + "separateChatTypes": "Zasebni izravni chatovi i grupe", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "dehydrateTorLong": "Korisnicima TOR-a se preporučuje izvoz sesije prije zatvaranja prozora.", + "hydrateTorLong": "Je li zadnji izvoz sesije bio na TOR-u? Brzo ga uvezi i nastavi razgovarati.", + "hydrate": "Obnovi pomoću sigurnosne kopije", + "pleaseEnterRecoveryKey": "Upiši svoj ključ za obnavljanje:", + "users": "Korisnici", + "pleaseEnterRecoveryKeyDescription": "Za otključavanje starih poruka upiši ključ za obnavljanje koji je generiran u prethodnoj sesiji. Tvoj ključ za obnavljanje NIJE tvoja lozinka.", + "indexedDbErrorTitle": "Problemi u privatnom modusu", + "youBannedUser": "Isključio/la si korisnika {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "storeInAppleKeyChain": "Spremi u Apple KeyChain", + "user": "Korisnik", + "custom": "Prilagođeno", + "fileHasBeenSavedAt": "Datoteka je spremljena u {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "numChats": "{number} chata", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "Neuspjelo slanje! Server podržava samo priloge do {max}.", + "jumpToLastReadMessage": "Skoči na zadnju pročitanu poruku", + "commandHint_markasdm": "Označi kao sobu za izravnu razmjenu poruka za zadani Matrix ID", + "commandHint_markasgroup": "Označi kao grupu", + "hideUnimportantStateEvents": "Sakrij nevažna stanja događaja", + "doNotShowAgain": "Nemoj više prikazivati", + "readUpToHere": "Pročitaj do ovdje", + "wasDirectChatDisplayName": "Prazan chat (zvao se {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noBackupWarning": "Upozorenje! Bez aktiviranja spremanja sigurnosne kopije chata, izgubit ćeš pristup tvojim šifriranim porukama. Preporučujemo spremanje sigurnosne kopije chata prije odjave.", + "noOtherDevicesFound": "Nijedan drugi uređaj nije pronađen", + "whyIsThisMessageEncrypted": "Zašto nije moguće čitati ovu poruku?", + "jump": "Skoči", + "startFirstChat": "Započni svoj prvi chat", + "newSpaceDescription": "Prostori omogućuju konsolidiranje tvojih chatova i izgradnju privatne ili javne zajednice.", + "encryptThisChat": "Šifiraj ovaj chat", + "deviceKeys": "Ključevi uređaja:", + "foregroundServiceRunning": "Ova se obavijest pojavljuje kada se pokreće usluga u prvom planu.", + "callingPermissions": "Dozvole za pozivanje", + "callingAccountDetails": "Omogućuje FluffyChatu korištenje izvorne Android aplikacije za pozivanje.", + "callingAccount": "Račun za pozivanje", + "commandHint_hug": "Pošalji grljenje", + "commandHint_googly": "Pošalji kotrljajuće oči", + "commandHint_cuddle": "Pošalji maženje", + "confirmMatrixId": "Za brisanje tvog računa potvrdi svoj Matrix ID.", + "supposedMxid": "Trebao bi biti {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "enterRoom": "Upiši sobu", + "screenSharingDetail": "Dijeliš svoj ekran u FuffyChatu", + "appearOnTopDetails": "Omogućuje prikaz aplikacije ispred drugih (nije potrebno ako je FluffyChat već postavljen kao račun za pozivanje)", + "appearOnTop": "Prikaz ispred drugih", + "newGroup": "Nova grupa", + "allSpaces": "Svi prostori", + "screenSharingTitle": "dijeljenje ekrana", + "otherCallingPermissions": "Mikrofon, kamera i druge FluffyChat dozvole", + "enterSpace": "Upiši prostor", + "newSpace": "Novi prostor", + "sorryThatsNotPossible": "Žao nam je … to nije moguće", + "disableEncryptionWarning": "Iz sigurnosnih razloga ne možeš deaktivirati šifriranje u chatu u kojem je prije bilo aktivirano.", + "googlyEyesContent": "{senderName} ti šalje kotrljajuće oči", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} te mazi", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} te grli", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "noKeyForThisMessage": "To se može dogoditi ako je poruka poslana prije prijave na tvoj račun na ovom uređaju.\n\nTakođer je moguće da je pošiljatelj blokirao tvoj uređaj ili je došlo do greške s internetskom vezom.\n\nMožeš li pročitati poruku na jednoj drugoj sesiji? U tom slučaju možeš prenijeti poruku iz nje! Idi na Postavke > Uređaji i uvjeri se da su se tvoji uređaji međusobno potvrdili. Kada sljedeći put otvoriš sobu i obje sesije su u prednjem planu, ključevi će se automatski prenijeti.\n\nNe želiš izgubiti ključeve kada se odjaviš ili zamijeniš uređaje? Aktiviraj spremanje sigurnosne kopije chata u postavkama.", + "reopenChat": "Ponovo otvori chat", + "openLinkInBrowser": "Otvori poveznicu u pregledniku", + "report": "prijavi", + "allRooms": "Svi grupni chatovi", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "😭 Joj! Dogodila se greška. Pokušaj ponovo kasnije. Ako želiš, grešku možeš prijaviti programerima.", + "signInWithPassword": "Prijavi se s lozinkom", + "pleaseTryAgainLaterOrChooseDifferentServer": "Pokušaj ponovo kasnije ili odaberi jedan drugi server.", + "signInWith": "Prijavi se pomoću {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Nije slikovna datoteka.", + "importNow": "Uvezi sada", + "importEmojis": "Uvezi emoji slike", + "importFromZipFile": "Uvezi iz .zip datoteke", + "replace": "Zamijeni", + "exportEmotePack": "Izvezi paket emotikona kao .zip", + "sendTypingNotifications": "Šalji obavijesti o tipkanju", + "setColorTheme": "Postavi boju teme:", + "tryAgain": "Pokušaj ponovo", + "messagesStyle": "Poruke:", + "chatDescription": "Opis chata", + "invalidServerName": "Neispravno ime servera", + "chatPermissions": "Dozvole za chat", + "setChatDescription": "Postavi opis rzgovora", + "redactedBy": "Preuređeno od {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Opcionalno) Razlog za redigiranje ove poruke …", + "inviteContactToGroupQuestion": "Želiš li pozvati {contact} u chat „{groupName}”?", + "redactedByBecause": "Preuređeno od {username} zbog: „{reason}”", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactMessageDescription": "Poruka će se redigirati za sve sudionike u ovoj konverzaciji. To je nepovratna radnja.", + "addChatDescription": "Dodaj opis chata …", + "directChat": "Izravni chat", + "inviteGroupChat": "📨 Pozivnica u grupni chat", + "invitePrivateChat": "📨 Pozivnica u privatni chat", + "noChatDescriptionYet": "Opis chata još nije stvoren.", + "chatDescriptionHasBeenChanged": "Opis chata je promijenjen", + "profileNotFound": "Korisnik nije pronađen na serveru. Možda postoji problem s vezom ili korisnik ne postoji.", + "shareInviteLink": "Dijeli poveznicu za poziv", + "emoteKeyboardNoRecents": "Ovdje će se pojaviti nedavno korišteni emotikoni …", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Postavi temu:", + "createGroup": "Stvori grupu", + "invite": "Pozovi", + "invalidInput": "Neispravan unos!", + "wrongPinEntered": "Unesen je pogrešan PIN! Pokušaj ponovo za {seconds} sekunde …", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "hasKnocked": "🚪 {user} je pokucao/la", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "pleaseEnterANumber": "Upiši broj veći od 0", + "pushNotificationsNotAvailable": "Automatsko slanje obavijesti nije dostupno", + "learnMore": "Saznaj više", + "createGroupAndInviteUsers": "Stvori grupu i pozovi korisnike", + "startConversation": "Pokreni konverzaciju", + "blockedUsers": "Blokirani korisnici", + "groupCanBeFoundViaSearch": "Grupa se može pronaći putem pretrage", + "block": "Blokiraj", + "yourGlobalUserIdIs": "Tvoj globalni korisnički ID je: ", + "commandHint_sendraw": "Pošalji neobrađeni json", + "wrongRecoveryKey": "Oprosti … čini se da ovo nije ispravan ključ za obnavljanje.", + "blockUsername": "Zanemari korisničko ime", + "groupName": "Ime grupe", + "databaseMigrationTitle": "Baza podataka je optimirana", + "searchChatsRooms": "Traži #chats, @users …", + "databaseMigrationBody": "Pričekaj. Ovo može potrajati.", + "transparent": "Prozirno", + "formattedMessages": "Formatirane poruke", + "incomingMessages": "Dolazne poruke", + "passwordsDoNotMatch": "Lozinke se ne poklapaju", + "accessAndVisibility": "Pristup i vidljivost", + "calls": "Pozivi", + "customEmojisAndStickers": "Prilagođeni emojiji i naljepnice", + "customEmojisAndStickersBody": "Dodaj ili dijeli prilagođene emojije ili naljepnice koje se mogu koristiti u bilo kojem chatu.", + "accessAndVisibilityDescription": "Tko se smije pridružiti ovom chatu i kako se chat može otkriti.", + "stickers": "Naljepnice", + "discover": "Otkrij", + "formattedMessagesDescription": "Prikaži formatirani sadržaj poruke poput podebljanog teksta koristeći markdown.", + "nothingFound": "Ništa nije pronađeno...", + "select": "Odaberi", + "newPassword": "Nova lozinka", + "unbanUserDescription": "Korisnik će se ponovo moći pridružiti chatu ako pokuša.", + "publicSpaces": "Javni prostori", + "subspace": "Podprostori", + "decline": "Odbij", + "thisDevice": "Ovaj uređaj:", + "presenceStyle": "Prisutnost:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Prikaži poruke stanja od drugih korisnika", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "noPublicLinkHasBeenCreatedYet": "Još nije stvorena nijedna javna poveznica", + "hidePresences": "Sakriti popis stanja?", + "pleaseEnterYourCurrentPassword": "Upiši svoju trenutačnu lozinku", + "publicLink": "Javna poveznica", + "passwordIsWrong": "Tvoja upisana lozinka je kriva", + "initAppError": "Dogodila se greška prilikom inicijaliziranja aplikacije", + "hideRedactedMessagesBody": "Ako netko redigira poruku, ta poruka više neće biti vidljiva u chatu.", + "kickUserDescription": "Korisnik je izbačen iz chata, ali nije isključen. U javnim chatovima se korisnik može ponovo pridružiti u bilo kojem trenutku.", + "addChatOrSubSpace": "Dodaj chat ili podpodručje", + "appLockDescription": "Zaključaj aplikaciju kada je ne koristiš s PIN kodom", + "globalChatId": "Globalni ID chata", + "hideRedactedMessages": "Sakrij redigirane poruke", + "hideInvalidOrUnknownMessageFormats": "Sakrij nevažeće ili nepoznate formate poruka", + "overview": "Pregled", + "notifyMeFor": "Obavijesit me za", + "passwordRecoverySettings": "Postavke za obnavljanje lozinke", + "hideMemberChangesInPublicChats": "Sakrij promjene članova u javnim chatovima", + "youInvitedToBy": "📩 Pozvan/a si putem poveznice na:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "usersMustKnock": "Korisnici moraju pokucati", + "noOneCanJoin": "Nitko se ne može pridružiti", + "userWouldLikeToChangeTheChat": "{user} se želi pridružiti chatu.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "knock": "Pokucaj", + "knocking": "Kucanje", + "chatCanBeDiscoveredViaSearchOnServer": "Chat se može otkriti pretraživanjem servera {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchForUsers": "Traži @users...", + "pleaseChooseAStrongPassword": "Odaberi snažnu lozinku", + "joinSpace": "Pridruži se prostoru", + "publicChatAddresses": "Adrese javnih chatova", + "createNewAddress": "Stvori novu adresu", + "userRole": "Korisnička uloga", + "verifyOtherUser": "🔐 Potvrdi drugog korisnika", + "sendTypingNotificationsDescription": "Drugi sudionici u chatu mogu vidjeti kada tipkaš novu poruku.", + "sendReadReceiptsDescription": "Drugi sudionici u raygovoru mogu vidjeti kada pročitaš poruku.", + "searchIn": "Traži u chatu „{chat}”...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Traži više...", + "gallery": "Galerija", + "files": "Datoteke", + "verifyOtherDevice": "🔐 Potvrdi drugi uređaj", + "unreadChatsInApp": "{appname}: Broj nepročitanih chatova: {unread}", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "commandHint_ignore": "Zanemari navedeni matrix ID", + "blockListDescription": "Možeš blokirati korisnike koji te ometaju. Nećeš moći primati poruke ili pozivnice za sobe od korisnika koji se nalaze u tvom osobnom popisu blokiranih.", + "isReadyForKeyVerification": "{sender} je spreman/na za potvrđivanje ključa", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "banUserDescription": "Korisnik će biti isključen iz chata i moći će ponovo prisustvovati chatu kada ga se ponovo uključi.", + "sessionLostBody": "Tvoja je sesija izgubljena. Prijavi ovu grešku programerima na {url}. Poruka o grešci glasi: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} je završio/la potvrđivanje ključa", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "archiveRoomDescription": "Chat će se premjestiti u arhivu. Drugi korisnici će moći vidjeti da si napustio/la chat.", + "removeDevicesDescription": "Bit ćeš odjavljen/a s ovog uređaja i više nećeš moći primati poruke.", + "noUsersFoundWithQuery": "Nažalost nije pronađen nijedan korisnik s „{query}”. Provjeri točnost upisa.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "restoreSessionBody": "Aplikacija sada pokušava obnoviti tvoju sesiju iz sigurnosne kopije. Prijavi ovu grešku programerima na {url}. Poruka o grešci glasi: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} je zatražio/la potvrđivanje ključa", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "restricted": "Ograničeni", + "roomUpgradeDescription": "Chat će se tada ponovo stvoriti s novom verzijom sobe. Svi sudionici će biti obaviješteni da se moraju prebaciti na novi chat. Više o verzijama soba možeš saznati na https://spec.matrix.org/latest/rooms/", + "noGoogleServicesWarning": "Čini se da Firebase Cloud Messaging nije dostupan na tvom uređaju. Za daljnje primanje push obavijesti, preporučujemo da instaliraš ntfy. S ntfy ili drugim pružateljem Unified Push usluge možeš primati push obavijesti na podatkovno siguran način. Ntfy možeš preuzeti s PlayStorea ili s F-Droida.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "verifyOtherDeviceDescription": "Kada potvrdiš jedan drugi uređaj, ti uređaji mogu razmjenjivati ključeve, povećavajući tvoju ukupnu sigurnost. 💪 Kada pokreneš provjeru, pojavit će se skočni prozor u aplikaciji na oba uređaja. Tamo ćeš tada vidjeti niz emojija ili brojeve koje moraš međusobno usporediti. Najbolje je imati oba uređaja pri ruci prije nego što započneš provjeru. 🤳", + "verifyOtherUserDescription": "Ako potvrdiš jednog drugog korisnika, možeš biti siguran/na da znaš kome zapravo pišeš. 💪\n\nKada pokreneš provjeru, vi i drugi korisnik vidjet ćete skočni prozor u aplikaciji. Tamo ćeš tada vidjeti niz emojija ili brojeve koje morate međusobno usporediti.\n\nNajbolji način za to je da se nađete zajedno ili započnete videopoziv. 👭", + "knockRestricted": "Pokucaj na ograničene sobe", + "hideMemberChangesInPublicChatsBody": "Za bolju čitljivosti, na vremenskoj traci chata nemoj prikazivati kad se netko pridruži ili napusti javni chat.", + "makeAdminDescription": "Nakon postavljanja ovog korisnika kao administratora, to možda nećeš moći poništiti jer će on tada imati iste dozvole kao i ti.", + "leaveEmptyToClearStatus": "Ostavi prazno za brisanje tvog stanja.", + "forwardMessageTo": "Proslijediti poruku u sobu {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "minimumPowerLevel": "{level} je najmanja razina prava.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "databaseBuildErrorBody": "Nije moguće izgraditi SQlite bazu podataka. Aplikacija za sada pokušava koristiti staru bazu podataka. Prijavi ovu grešku programerima na {url}. Poruka o grešci glasi: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceipts": "Šalji potvrde o čitanju", + "acceptedKeyVerification": "{sender} je prihvatio/la potvrđivanje ključa", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} je prekinuo/la potvrđivanje ključa", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} je pokrenuo/la potvrđivanje ključa", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "commandHint_unignore": "Poništi zanemarivanje navedenog matrix ID-a", + "noDatabaseEncryption": "Šifriranje baze podataka nije podržano na ovoj platformi", + "thereAreCountUsersBlocked": "Broj trenutačno blokiranih korisnika: {count}.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "swipeRightToLeftToReply": "Za odgovaranje povuci prstom zdesna ulijevo", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "prepareSendingAttachment": "Pripremi slanje priloga …", + "sendingAttachment": "Slanje priloga …", + "sendingAttachmentCountOfCount": "Slanje priloga {index} od {length} …", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "setCustomPermissionLevel": "Postavi razinu dozvole", + "setPermissionsLevelDescription": "Odaberi unaprijed definiranu ulogu u nastavku ili upiši prilagođenu razinu dozvole između 0 i 100.", + "ignoreUser": "Zanemari korisnika", + "normalUser": "Normalni korisnik", + "aboutHomeserver": "Informacije o {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "commandHint_roomupgrade": "Nadogradi ovu sobu na zadanu verziju sobe", + "countChatsAndCountParticipants": "{chats} chata i {participants} sudionika", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Nema više chatova …", + "noChatsFoundHere": "Ovdje još nisu pronađeni chatovi. Započni novi chat s nekime pomoću donjeg gumba. ⤵️", + "joinedChats": "Pridruženi chatovi", + "unread": "Nepročitano", + "space": "Prostor", + "spaces": "Prostori", + "changedTheChatDescription": "{username} je promijenio/la opis chata", + "changedTheChatName": "{username} je promijenio/la ime chata", + "checkList": "Kontrolni popis", + "countInvited": "Broj pozvanih: {count}", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendImages": "Pošalji {count} sliku", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "synchronizingPleaseWaitCounter": " Sinkronizacija … ({percentage} %)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "invitedBy": "📩 Pozvan/a si od korisnika {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "goToSpace": "Idi u prostor: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Označi kao nepročitano", + "userLevel": "{level} – Korisnik", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} – Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} – Administrator", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Promijeni opće postavke chata", + "inviteOtherUsers": "Pozovi druge korisnike u ovaj chat", + "changeTheChatPermissions": "Promijeni dozvole za chat", + "changeTheVisibilityOfChatHistory": "Promijeni vidljivost povijesti chatova", + "changeTheCanonicalRoomAlias": "Promijeni glavnu adresu javnog chata", + "sendRoomNotifications": "Pošalji @room obavijesti", + "changeTheDescriptionOfTheGroup": "Promijeni opis chata", + "chatPermissionsDescription": "Definiraj razine dozvola koja su potrebna za određene radnje u ovom chatu. Razine dozvola 0, 50 i 100 obično predstavljaju korisnike, moderatore i administratore, ali je moguća svaka gradacija.", + "updateInstalled": "🎉 Aktualizirana verzija {version} je instalirana!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Dnevnik promjena", + "sendCanceled": "Slanje je prekinuto", + "loginWithMatrixId": "Prijava pomoću Matrix-ID-a", + "discoverHomeservers": "Otkrij homeservere", + "whatIsAHomeserver": "Što je homeserver?", + "homeserverDescription": "Svi se tvoji podaci spremaju na homeserver, baš kao kod pružatelja usluge e-pošte. Možeš odabrati koji homeserver želiš koristiti, te istovremeno komunicirati sa svima. Saznaj više na at https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Čini se da nije kompatibilan homeserver. Pogrešan URL?", + "calculatingFileSize": "Izračunavanje veličine datoteke …", + "generatingVideoThumbnail": "Generiranje minijatura videa …", + "compressVideo": "Komprimiranje videa …", + "serverLimitReached": "Granica servera je dosegnuta! Čeka {seconds} s …", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Jedan od tvojih uređaja nije potvrđen", + "noticeChatBackupDeviceVerification": "Napomena: Kada spojiš sve svoje uređaje na sigurnosnu kopiju chata, oni se automatski potvrđuju.", + "continueText": "Nastavi", + "welcomeText": "Hej, hej 👋, ovdje FluffyChat. Možeš se prijaviti na bilo koji homeserver koji je kompatibilan s https://matrix.org. I onda razgovaraj s bilo kim. To je ogromna decentralizirana mreža za razmjenu poruka!", + "blur": "Zamućenost:", + "opacity": "Neprozirnost:", + "setWallpaper": "Postavi sliku pozadine", + "manageAccount": "Upravljaj računom", + "noContactInformationProvided": "Server ne pruža nikoje valjane kontakt podatke", + "contactServerAdmin": "Kontaktiraj administratora servera", + "contactServerSecurity": "Kontaktiraj zadužene za sigurnost servera", + "supportPage": "Stranica podrške", + "serverInformation": "Podaci servera:", + "name": "Ime", + "version": "Verzija", + "website": "Web-stranica", + "compress": "Komprimiraj", + "boldText": "Podebljani tekst", + "italicText": "Kurzivni tekst", + "strikeThrough": "Precrtano", + "pleaseFillOut": "Ispuni", + "invalidUrl": "Neispravan URL", + "addLink": "Dodaj poveznicu", + "unableToJoinChat": "Neuspjelo pridruživanje chatu. Možda je druga strana već zatvorila konverzaciju.", + "previous": "Prethodni", + "otherPartyNotLoggedIn": "Druga strana trenutačno nije prijavljena i stoga ne može primati poruke!", + "appWantsToUseForLogin": "Koristi '{server}' za prijavu", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Ovime dopuštaš aplikaciji i web-stranici da dijele podatke o tebi.", + "open": "Otvori", + "waitingForServer": "Čekanje na server …", + "appIntroduction": "FluffyChat omogućuje da razgovaraš s prijateljima preko različitih messengera. Saznaj više na https://matrix.org ili jednostavno dodirni *Nastavi*.", + "newChatRequest": "📩 Novi zahtjev za chat", + "contentNotificationSettings": "Postavke obavijesti o sadržaju", + "generalNotificationSettings": "Opće postavke obavijesti", + "roomNotificationSettings": "Postavke obavijesti sobe", + "userSpecificNotificationSettings": "Koriničke postavke obavijesti", + "otherNotificationSettings": "Druge postavke obavijesti", + "notificationRuleContainsUserName": "Sadrži korisničko ime", + "notificationRuleContainsUserNameDescription": "Obavještava korisnika kada poruka sadrži njegovo korisničko ime.", + "notificationRuleMaster": "Isključi sve obavijesti", + "notificationRuleMasterDescription": "Nadjačava sva druga pravila i deaktivira sve obavijesti.", + "notificationRuleSuppressNotices": "Isključi automatizirane poruke", + "notificationRuleSuppressNoticesDescription": "Isključi obavijesti od automatiziranih klijenata poput botova.", + "notificationRuleInviteForMe": "Poziv za mene", + "notificationRuleInviteForMeDescription": "Obavještava korisnika kada je pozvan u sobu.", + "notificationRuleMemberEvent": "Događaj člana", + "notificationRuleMemberEventDescription": "Isključi obavijesti o događajima članstva.", + "notificationRuleIsUserMention": "Spominjanje korisnika", + "notificationRuleIsUserMentionDescription": "Obavještava korisnika kada je izravno spomenut u poruci.", + "notificationRuleContainsDisplayName": "Sadrži prikazano ime", + "notificationRuleContainsDisplayNameDescription": "Obavještava korisnika kada poruka sadrži njegovo prikazano ime.", + "notificationRuleIsRoomMention": "Spominjanje sobe", + "notificationRuleIsRoomMentionDescription": "Obavještava korisnika kad se spomene soba.", + "notificationRuleRoomnotif": "Obavijest o sobi", + "notificationRuleRoomnotifDescription": "Obavještava korisnika kada poruka sadrži „@room“.", + "notificationRuleTombstone": "Nadgrobni spomenik", + "notificationRuleTombstoneDescription": "Obavještava korisnika o porukama o deaktivaciji sobe.", + "notificationRuleReaction": "Reakcija", + "notificationRuleReactionDescription": "Isključi obavijesti za reakcije.", + "notificationRuleRoomServerAcl": "Kontrolni popis za pristup serveru sobe", + "notificationRuleRoomServerAclDescription": "Isključi obavijesti o kontrolnim popisima za pristup serveru sobe (ACL).", + "notificationRuleSuppressEdits": "Isključi uređivanja", + "notificationRuleSuppressEditsDescription": "Isključi obavijesti za uređene poruke.", + "notificationRuleCall": "Poziv", + "notificationRuleCallDescription": "Obavještava korisnika o pozivima.", + "notificationRuleEncryptedRoomOneToOne": "Šifrirana soba jedan-na-jedan", + "notificationRuleEncryptedRoomOneToOneDescription": "Obavještava korisnika o porukama u šifriranim sobama jedan-na-jedan.", + "notificationRuleRoomOneToOne": "Soba jedan-na-jedan", + "notificationRuleRoomOneToOneDescription": "Obavještava korisnika o porukama u sobama jedan-na-jedan.", + "notificationRuleMessage": "Poruka", + "notificationRuleMessageDescription": "Obavještava korisnika o općim porukama.", + "notificationRuleEncrypted": "Šifrirano", + "notificationRuleEncryptedDescription": "Obavještava korisnika o porukama u šifriranim sobama.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Obavještava korisnika o događajima Jitsi widgeta.", + "notificationRuleServerAcl": "Isključi događaje kontrole pristupa servera (ACL)", + "notificationRuleServerAclDescription": "Isključi obavijesti za kontrolne popise za pristup (ACL).", + "unknownPushRule": "Nepoznato push pravilo '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} – Glasovna poruka od {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Brisanje postavki obavijesti je nopovratna radnja.", + "more": "Više", + "shareKeysWith": "Dijeli ključeve s …", + "shareKeysWithDescription": "Kojim se uređajima treba vjerovati za čitanje tvojih poruka u šifriranim chatovima?", + "allDevices": "Svi uređaji", + "crossVerifiedDevicesIfEnabled": "Unakrsno potvrđeni uređaji, ako je uključeno", + "crossVerifiedDevices": "Unakrsno potvrđeni uređaji", + "verifiedDevicesOnly": "Samo potvrđeni uređaji", + "takeAPhoto": "Snimi sliku", + "recordAVideo": "Snimi video", + "optionalMessage": "(Opcionalna) poruka …", + "notSupportedOnThisDevice": "Nije podržano na ovom uređaju", + "enterNewChat": "Upiši novi chat", + "approve": "Odobri", + "youHaveKnocked": "Pokucao/la si", + "pleaseWaitUntilInvited": "Sad pričekaj, dok te netko iz sobe ne pozove.", + "commandHint_logout": "Odjavi tvoj trenutačni uređaj", + "commandHint_logoutall": "Odjavi sve aktivne uređaje", + "displayNavigationRail": "Prikaži navigacijsku traku na mobilnom uređaju", + "customReaction": "Prilagođena reakcija", + "moreEvents": "Više događaja", + "declineInvitation": "Odbij poziv", + "noMessagesYet": "Još nema poruka", + "longPressToRecordVoiceMessage": "Pritisni dugo za snimanje glasovne poruke.", + "pause": "Pauza", + "resume": "Nastavi", + "newSubSpace": "Novi podprostor", + "moveToDifferentSpace": "Premjesti u jedan drugi prostor", + "moveUp": "Pomakni gore", + "moveDown": "Pomakni dolje", + "removeFromSpaceDescription": "Chat će se ukloniti iz prostora, ali će se i dalje pojaviti na tvom popisu chatova.", + "countChats": "Broj chatova: {chats}", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Član {spaces} prostora", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Član {spaces} prostora smije pokucati", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Doniraj", + "startedAPoll": "{username} je pokrenuo/la anketu.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Anketa", + "startPoll": "Početak ankete", + "endPoll": "Kraj ankete", + "answersVisible": "Odgovori vidljivi", + "answersHidden": "Odgovori skriveni", + "pollQuestion": "Pitanje u anketi", + "answerOption": "Opcija za odgovor", + "addAnswerOption": "Dodaj opciju za odgovor", + "allowMultipleAnswers": "Dopusti više odgovora", + "pollHasBeenEnded": "Anketa je završena", + "countVotes": "{count, plural, =1{Jedan glas} few{{count} glasa} other{{count} glasova}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Odgovori će biti vidljivi nakon završetka ankete", + "replyInThread": "Odgovori u temi", + "countReplies": "{count, plural, =1{Jedan odgovor} few{{count} odgovora} other{{count} odgovora}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Tema", + "backToMainChat": "Natrag na glavni chat", + "saveChanges": "Spremi promjene", + "createSticker": "Stvori naljepnicu ili emoji", + "useAsSticker": "Koristi kao naljepnicu", + "useAsEmoji": "Koristi kao emoji", + "stickerPackNameAlreadyExists": "Ime paketa naljepnica već postoji", + "newStickerPack": "Novi paket naljepnica", + "stickerPackName": "Ime paketa naljepnica", + "attribution": "Atribucija", + "skipChatBackup": "Preskoči sigurnosno kopiranje chata", + "skipChatBackupWarning": "Sigurno? Bez aktiviranja sigurnosne kopije chata možeš izgubiti pristup svojim porukama ako promijeniš uređaj.", + "loadingMessages": "Učitavanje poruka", + "setupChatBackup": "Postavi sigurnosno kopiranje chata", + "noMoreResultsFound": "Nema više rezultata", + "chatSearchedUntil": "Chat je pretražen do {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "Osnovni URL federacije", + "clientWellKnownInformation": "Dobro poznate informacije o klijentu:", + "baseUrl": "Osnovni URL", + "identityServer": "Server identiteta:", + "versionWithNumber": "Verzija: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Zapisi", + "advancedConfigs": "Napredne konfiguracije", + "advancedConfigurations": "Napredne konfiguracije", + "signInWithLabel": "Prijavi se sa:" +} diff --git a/lib/l10n/intl_hu.arb b/lib/l10n/intl_hu.arb new file mode 100644 index 000000000..fb94d4e49 --- /dev/null +++ b/lib/l10n/intl_hu.arb @@ -0,0 +1,3377 @@ +{ + "@@locale": "hu", + "@@last_modified": "2021-08-14 12:41:10.016566", + "about": "Névjegy", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Elfogad", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} elfogadta a meghívást", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Fiók", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} aktiválta a végpontok közötti titkosítást", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Adminisztrátor", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "álnév", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} válaszolt a hívásra", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Bárki csatlakozhat", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "Archívum", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Csatlakozhatnak-e vendégek", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Biztos benne?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "A másik fél igazolásához meg kell adnia a biztonságos tároló jelmondatát vagy a visszaállítási kulcsotát.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Elfogadja {username} hitelesítési kérelmét?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banFromChat": "Kitiltás a csevegésből", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Kitiltva", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} kitiltva {targetName} által", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Eszköz blokkolása", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "cancel": "Mégse", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Eszköznév módosítása", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} módosította a csevegési profilképét", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} megváltoztatta a csevegés leírást a következőre: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} módosította a csevegés nevét a következőre: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} módosította a csevegési engedélyeket", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} módosította a megjelenített nevét erre: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} módosította a vendégek hozzáférési szabályokat", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} módosította a vendégek hozzáférési szabályait a következőre: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} módosította az előzmények láthatóságát", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} módosította az előzmények láthatóságát a következőre: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} módosított a csatlakozási szabályokat", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} módosította a csatlakozási szabályokat a következőre: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} módosította a profilképét", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} módosította a szoba álneveit", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} módosította a meghívó hivatkozást", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Jelszó módosítása", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Matrix-kiszolgáló váltás", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Stílusának módosítása", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Csoport nevének módosítása", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "A titkosítás megsérült", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Csevegés", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Csevegés részletei", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Válasszon egy erős jelszót", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Bezár", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Kérem, hasonlítsa össze a hangulatjeleket", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Kérem, hasonlítsa össze a számokat", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Megerősít", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Csatlakozás", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kapcsolat meghívásra került a csoportba", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Vágólapra másolva", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Másolás", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Nem sikerült visszafejteni az üzenetet: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} résztvevő", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Létrehoz", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} csevegést hozott létre", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Jelenleg aktív", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Sötét", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}. {day}.", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}. {month}. {day}.", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Ez deaktiválja a felhasználói fiókját. Ez nem vonható vissza! Biztos benne?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "delete": "Törlés", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Fiók törlése", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Üzenet törlése", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Eszköz", + "@device": { + "type": "String", + "placeholders": {} + }, + "devices": "Eszközök", + "@devices": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "A megjelenítési név megváltozott", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Fájl letöltése", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Megjelenítési név szerkesztése", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "A hangulatjel már létezik!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Érvénytelen hangulatjel rövidkód!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Hangulatjel csomagok a szobához", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Hangulatjel Beállítások", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Hangulatjel rövidkód", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Ki kell választania egy hangulatjel rövidkódot és egy képet!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Üres csevegés", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Hangulatjel csomag engedélyezése globálisan", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Többé nem fogja tudni kikapcsolni a titkosítást. Biztos benne?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryption": "Titkosítás", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Titkosítás nem engedélyezve", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} befejezte a hívást", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterYourHomeserver": "Adja meg a Matrix-kiszolgálóját", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "fileName": "Fájlnév", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Továbbítás", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Csatlakozás óta", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Meghívás óta", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Csoport", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "A csoport nyilvános", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Csoport {displayname}-al", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "A vendégek nem engedélyezettek", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Csatlakozhatnak vendégek", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} visszavonta {targetName} meghívását", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Súgó", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Szerkesztett események elrejtése", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Ismeretlen események elrejtése", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Azonosító", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Figyelmen kívül hagyott felhasználók", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Hibás jelmondat vagy visszaállítási kulcs", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Ismerős meghívása", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Ismerős meghívása a(z) {groupName} csoportba", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Meghívott", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} meghívta {targetName} felhasználót", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Csak meghívott felhasználók", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} meghívta a FluffyChat-be.\n1. Keresse fel a fluffychat.im oldalt, és telepítse az alkalmazást \n2. Regisztráljon vagy jelentkezzen be \n3. Nyissa meg a meghívó linket: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "épp gépel…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} csatlakozott a csevegéshez", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Csatlakozás a szobához", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} kirúgta {targetName}-t", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} kirúgta és kitiltotta {targetName}-t", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Kirúgás a csevegésből", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Utoljára aktív: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Elhagy", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Elhagyta a csevegést", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licenc", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Világos", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "További {count} résztvevő betöltése", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Betöltés… Kérem, várjon.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Továbbiak betöltése…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Bejelentkezés", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Bejelentkezés a(z) {homeserver} Matrix-kiszolgálóra", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Kijelentkezés", + "@logout": { + "type": "String", + "placeholders": {} + }, + "mention": "Megemlítés", + "@mention": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderátor", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Csevegés némítása", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Jelenleg a Pantalaimon szükséges a végpontok közötti titkosítás használatához.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Új FluffyChat üzenet", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Új hitelesítési kérelem!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "no": "Nem", + "@no": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Nem találhatóak hangulatjelek. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Úgy tűnik a Firebase Cloud Messaging nem elérhető a készülékén. Ha mégis push értesítéseket kíván kapni, javasoljuk a ntfy telepítését. A ntfy vagy más egyéb Egyesített Push szolgáltató esetében úgy kaphat értesítést, hogy adatai biztonságban maradnak. Letöltheti a ntfy-t a PlayStore-ból, vagy F-Droid-ról is.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Nincs", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Nincs engedély", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Nem találhatóak szobák…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "offline": "Offline", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Online", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Online kulcsmentés engedélyezve", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Hoppá, valami hiba lépett fel…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Alkalmazás megnyitása az üzenetek elolvasásához", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Kamera megnyitása", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "jelmondat vagy visszaállítási kulcs", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Jelszó", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "A jelszó módosításra került", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Kép választása", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Rögzítés", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "{fileName} lejátszása", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnterYourPassword": "Kérem, adja meg jelszavát", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Kérem, adja meg a felhasználónevét", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "privacy": "Adatvédelem", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Nyilvános szobák", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "recording": "Felvétel", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} szerkesztett egy eseményt", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Elutasít", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} elutasította a meghívást", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Újracsatlakozás", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Eltávolítás", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Minden más eszköz eltávolítása", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "{username} által eltávolítva", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Eszköz eltávolítása", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Csevegés kitiltás feloldása", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "Válasz", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Jogosultsági kérelem", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "A szoba frissítésre került", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "{username} látta", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Küldés", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Üzenet küldése", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Hangüzenet küldése", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Fájl küldése", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Kép küldése", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Eredeti küldése", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Videó küldése", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} küldött egy fájlt", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} hangüzenetet küldött", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} képet küldött", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} matricát küldött", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} videót küldött", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} hívásinformációt küldött", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setInvitationLink": "Meghívó hivatkozás beállítása", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Állapot beállítása", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Beállítások", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Megosztás", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} megosztotta a pozícióját", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "skip": "Kihagy", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Forráskód", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} hívást indított", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "statusExampleMessage": "Hogy érzi magát a mai napon?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Beküldés", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Rendszer", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Nem egyezőek", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Egyezőek", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Újraküldés megpróbálása", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Nem elérhető", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} feloldotta {targetName} kitiltását", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Eszköz blokkolás feloldása", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Ismeretlen eszköz", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Ismeretlen titkosítási algoritmus", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Ismeretlen esemény: '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Csevegés némítás feloldása", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Rögzítés megszüntetése", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 olvasatlan csevegés} other{{unreadCount} olvasatlan csevegés}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} és {count} másik résztvevő gépel…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} és {username2} gépel…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} gépel…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} elhagyta a csevegést", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Felhasználónév", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} felhasználó {type} eseményt küldött", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "Hitelesít", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Hitelesítés megkezdése", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Sikeres hitelesítés!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Másik fiók hitelesítése", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videóhívás", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Csevegési előzmény láthatósága", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Minden résztvevő számára látható", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Bárki számára látható", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Hangüzenet", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Várakozás a partnerre, hogy elfogadja a kérést…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Várakozás a partnerre, hogy elfogadja a hangulatjelet…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Várakozás a partnerre, hogy elfogadja a számokat…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Háttér:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Figyelem!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Ki csatlakozhat a csoporthoz", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Írjon egy üzenetet…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Igen", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Ön", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Immáron nem vesz részt ebben a csevegésben", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Kitiltották ebből a csevegésből", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Ezekkel a címekkel vissza tudja állítani a jelszavát.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Küldtünk Önnek egy emailt", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Jelszó visszaállítás", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Még nem adott meg semmilyen módszert a jelszava visszaállítására.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Meghívás számomra", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Rákattintottam a linkre", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "enterAnEmailAddress": "Adjon meg egy email címet", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Titkosított", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "edit": "Szerkeszt", + "@edit": { + "type": "String", + "placeholders": {} + }, + "directChats": "Privát Csevegések", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Eszköz ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot üzenetek", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Jelszó ismétlése", + "@repeatPassword": {}, + "addEmail": "E-mail-cím hozzáadása", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "all": "Összes", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Összes csevegés", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "Animált matricák és hangulatjelek automatikus lejátszása", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendOnEnter": "Küldés Enterrel", + "@sendOnEnter": {}, + "cantOpenUri": "Nem sikerült a következő URI megnyitása: {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeYourAvatar": "Profilkép módosítása", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Hozzáadás a térhez", + "@addToSpace": {}, + "areYouSureYouWantToLogout": "Biztosan kijelentkezik?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "A Matrix-kiszolgáló a következő bejelentkezéseket támogatja:\n{serverVersions}\nDe ez az alkalmazást csak ezeket támogatja:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "blocked": "Blokkolva", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "appLock": "Alkalmazás zár", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "commandHint_myroomnick": "Megjelenített nevének hozzárendelése a szobához", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_plain": "Formázatlan szöveg küldése", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_send": "Szöveg küldése", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "contentHasBeenReported": "A tartalom jelentésre került a szerver adminisztrátorok számára", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "commandHint_myroomavatar": "Profilképe hozzárendelése a szobához (mxc URI használatával)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "copyToClipboard": "Vágólapra másolás", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Szoba álnevek szerkesztése", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Szoba-profilkép szerkesztése", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Titkosítás engedélyezése", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Rendkívül sértő", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Betűméret", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Minden kész!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "groups": "Csoportok", + "@groups": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Mennyire sértő ez a tartalom?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Nem sértő", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "A helymeghatározás visszautasításra került. Kérem engedélyezze, hogy meg tudja osztani helyzetét.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "newChat": "Új csevegés", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "QR kód beolvasása", + "@scanQrCode": {}, + "notificationsEnabledForThisAccount": "Értesítések be vannak kapcsolva ebben a fiókban", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "offensive": "Sértő", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Hoppá! Sajnos hiba lépett fel a push értesítések beállításakor.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "commandHint_create": "Egy üres csevegő csoport létrehozása\nA --no-encryption paraméterrel feloldhatja a titkosítást", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_invite": "Adott felhasználó meghívása ebbe a szobába", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "locationDisabledNotice": "A helymeghatározás ki van kapcsolva. Kérem, kapcsolja be, hogy meg tudja osztani helyzetét.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Matrix-kiszolgáló", + "@homeserver": {}, + "chatBackup": "Csevegés biztonsági mentés", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "ignore": "Figyelmen kívül hagyás", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "next": "Következő", + "@next": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "A csevegés biztonsági mentés beállításra került.", + "@yourChatBackupHasBeenSetUp": {}, + "chatBackupDescription": "A régebbi beszélgetései egy biztonsági kulccsal vannak védve. Bizonyosodjon meg róla, hogy nem veszíti el.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Tartalmazza a megjelenített nevet", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Tartalmazza a felhasználónevet", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Ugrás az új szobába", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Nem elérhető a szerver", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Csak akkor kapcsolható be a titkosítás, ha a szoba nem nyilvánosan hozzáférhető.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Csevegés hozzáadva a térhez", + "@chatHasBeenAddedToThisSpace": {}, + "chats": "Csevegések", + "@chats": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Archívum ürítése", + "@clearArchive": {}, + "commandHint_ban": "Adott felhasználó kitiltása a szobából", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Gyorsítótár törlése", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_discardsession": "Munkamenet elvetése", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Közvetlen csevegés indítása\nA --no-encryption paraméterrel kikapcsolhatja a titkosítást", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_html": "HTML formázott szöveg küldése", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_join": "Csatlakozás a megadott szobához", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "A megadott felhasználó kirúgása a szobából", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Szoba elhagyása", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandInvalid": "Érvénytelen parancs", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} nem egy parancs.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "configureChat": "Csevegés konfigurálása", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Új tér", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Alapértelmezett hozzáférési szint új felhasználóknál", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Hiba a helymeghatározáskor: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "memberChanges": "Tagi változások", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "messages": "Üzenetek", + "@messages": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} nem egy Matrix szerver, akarja használja a {server2} szervert inkább?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "notifications": "Értesítések", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} felhasználó gépel…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Tartózkodási hely lekérése…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Kamera megnyitása videóhoz", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "A Matrix-kiszolgáló ezeket a specifikált verziókat támogatja:\n{serverVersions}\nAzonban ez az app csak a következőket: {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "commandHint_me": "Írja le magát", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_op": "Az adott felhasználó hozzáférési szintjének megadása (alapértelmezett: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_react": "Válasz küldése reakcióként", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_unban": "Adott felhasználó kitiltásának feloldása a szobához", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "editBlockedServers": "Blokkolt szerverek szerkesztése", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "dehydrate": "Munkamenet exportálása és az eszköz törlése", + "@dehydrate": {}, + "dehydrateWarning": "Ez nem visszavonható. Bizonyosodjon meg róla, hogy biztonságos helyre menti a fájlt.", + "@dehydrateWarning": {}, + "dehydrateTor": "TOR felhasználók: Munkamenet exportálása", + "@dehydrateTor": {}, + "dehydrateTorLong": "TOR felhasználóknak ajánlott a munkamenet exportálása az ablak bezárása előtt.", + "@dehydrateTorLong": {}, + "hydrateTor": "TOR felhasználóknak: munkamenet export importálása", + "@hydrateTor": {}, + "hydrate": "Visszaállítás mentett fájlból", + "@hydrate": {}, + "link": "Hivatkozás", + "@link": {}, + "redactMessage": "Üzenet szerkesztése", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "people": "Emberek", + "@people": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Kérem, írja be PIN kódját", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "cuddleContent": "{senderName} hozzád bújik", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "Jelölés csoportnak", + "@commandHint_markasgroup": {}, + "addAccount": "Fiók hozzáadása", + "@addAccount": {}, + "search": "Keresés", + "@search": { + "type": "String", + "placeholders": {} + }, + "commandHint_googly": "Gülüszemek küldése", + "@commandHint_googly": {}, + "commandHint_cuddle": "Összebújás küldése", + "@commandHint_cuddle": {}, + "sendMessages": "Üzenetek küldése", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Matrica küldése", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Üzenet jelentése", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "participant": "Résztvevő", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Elfelejtett jelszó", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Szoba verzió", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Kérem, igazolja vissza Matrix ID-jét a fiók törléséhez.", + "@confirmMatrixId": {}, + "or": "Vagy", + "@or": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Kérem, válasszon", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "commandHint_hug": "Ölelés küldése", + "@commandHint_hug": {}, + "reason": "Indok", + "@reason": { + "type": "String", + "placeholders": {} + }, + "register": "Regisztráció", + "@register": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Fájl mentése", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "googlyEyesContent": "{senderName} gülüszemeket küld", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "openInMaps": "Megnyitás térképen", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Írjon be 4 számjegyet, vagy hagyja üresen a zár kikapcsolásához.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "security": "Biztonság", + "@security": { + "type": "String", + "placeholders": {} + }, + "notAnImage": "Nem kép fájl.", + "@notAnImage": {}, + "showPassword": "Jelszó megjelenítése", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "hugContent": "{senderName} megölel", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Az utoljára olvasott üzenethez ugrás", + "@jumpToLastReadMessage": {}, + "allRooms": "Minden Csoport Csevegés", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "widgetVideo": "Videó", + "@widgetVideo": {}, + "dismiss": "Elvetés", + "@dismiss": {}, + "reportErrorDescription": "😭 Sajnos, valami félresiklott. Ha kívánja, jelezheti a bugot a fejlesztőknek.", + "@reportErrorDescription": {}, + "setPermissionsLevel": "Engedélyszint beállítása", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Profilképének törlése", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "unsupportedAndroidVersion": "Nem támogatott Android verzió", + "@unsupportedAndroidVersion": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "messageType": "Üzenet típus", + "@messageType": {}, + "indexedDbErrorLong": "Sajnos az üzenet mentés alapból nincs bekapcsolva privát módban.\nKeresse meg a\n - about:config\n - állítsa a dom.indexedDB.privateBrowsing.enabled \"true\"-ra\nMáskülönben nem lehetséges a FluffyChat futtatása.", + "@indexedDbErrorLong": {}, + "oneClientLoggedOut": "Az egyik kliense kijelentkezett", + "@oneClientLoggedOut": {}, + "toggleMuted": "Némítottak megjelenítése", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "startFirstChat": "Kezdje meg első csevegését", + "@startFirstChat": {}, + "callingAccount": "Hívási fiók", + "@callingAccount": {}, + "setColorTheme": "Szín séma beállítása:", + "@setColorTheme": {}, + "nextAccount": "Következő fiók", + "@nextAccount": {}, + "singlesignon": "Egyszeri Bejelentkezés", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "allSpaces": "Minden tér", + "@allSpaces": {}, + "supposedMxid": "{mxid}-nek kell lennie", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "user": "Felhasználó", + "@user": {}, + "youAcceptedTheInvitation": "👍 Elfogadta a meghívást", + "@youAcceptedTheInvitation": {}, + "youInvitedBy": "📩 {user} jóvoltából kapott meghívást", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "banUserDescription": "A felhasználó kitiltásra kerül a csevegésből, és nem fog tudni visszajönni egészen a kitiltás feloldásáig.", + "@banUserDescription": {}, + "widgetEtherpad": "Szöveges megjegyzés", + "@widgetEtherpad": {}, + "removeDevicesDescription": "Ki fog jelentkezni a készülékről, és többé nem fog tudni fogadni üzeneteket.", + "@removeDevicesDescription": {}, + "separateChatTypes": "Csoportok és privát üzenetek elkülönítése", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "tryAgain": "Próbálja újra", + "@tryAgain": {}, + "youKickedAndBanned": "🙅 Kirúgta és kitiltotta {user}-t", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unbanUserDescription": "A felhasználó vissza tud jönni a csevegésbe ha akar.", + "@unbanUserDescription": {}, + "pleaseClickOnLink": "Kérem, kattintson a linkre az emailben, és folytassa a műveletet.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "youRejectedTheInvitation": "Visszautasította a meghívást", + "@youRejectedTheInvitation": {}, + "otherCallingPermissions": "Mikrofon, kamera, és más egyéb FluffyChat engedélyek", + "@otherCallingPermissions": {}, + "messagesStyle": "Üzenetek:", + "@messagesStyle": {}, + "widgetUrlError": "Helytelen hivatkozás.", + "@widgetUrlError": {}, + "emailOrUsername": "Email vagy felhasználónév", + "@emailOrUsername": {}, + "newSpaceDescription": "A terek lehetővé teszik a csevegések konszolidációját, ezáltal létrehozva publikus vagy privát közösségeket.", + "@newSpaceDescription": {}, + "chatDescription": "Csevegés leírás", + "@chatDescription": {}, + "callingAccountDetails": "Engedélyezés a FluffyChat számára hogy használja a natív android hívás applikációt.", + "@callingAccountDetails": {}, + "pleaseFollowInstructionsOnWeb": "Kérem, kövesse az instrukciókat az oldalon, és nyomjon a tovább gombra.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "enterSpace": "Belépés a térre", + "@enterSpace": {}, + "encryptThisChat": "A csevegés titkosítása", + "@encryptThisChat": {}, + "previousAccount": "Előző fiók", + "@previousAccount": {}, + "reopenChat": "Csevegés újranyitása", + "@reopenChat": {}, + "pleaseEnterRecoveryKey": "Kérem, adja meg a visszaállító kódját:", + "@pleaseEnterRecoveryKey": {}, + "toggleFavorite": "Kedvencek megjelenítése", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "widgetNameError": "Kérem adjon meg egy megjelenítendő nevet.", + "@widgetNameError": {}, + "addToBundle": "Hozzáadás fiókcsoporthoz", + "@addToBundle": {}, + "spaceIsPublic": "A tér publikus", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "addWidget": "Widget hozzáadása", + "@addWidget": {}, + "countFiles": "{count} fájl", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noKeyForThisMessage": "Akkor fordulhat elő, ha az üzenet az eszközre való bejelentkezés előtt került küldésre.\n\nAz is elképzelhető, hogy a küldő blokkolta az eszközét, vagy valami probléma lépett fel az internet kapcsolatban.\n\nMás helyen látja az üzenetet? Akkor át tudja másolni ide is! Menjen a Beállítások > Eszközök részbe, és győződjön meg róla, hogy az eszközei megerősítették egymást. Legközelebb amikor ezt a szobát megnyitja, és mind a két kliens az előtérben van, akkor szikronizálódni fognak.\n\nNem akarja elveszíteni a kulcsokat amikor kijelentkezik, vagy eszközt cserél? Győződjön meg róla, hogy bekapcsolta a chat mentést a beállításokban.", + "@noKeyForThisMessage": {}, + "shareLocation": "Pozíció megosztása", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "pushNotificationsNotAvailable": "Push értesítések nem elérhetőek", + "@pushNotificationsNotAvailable": {}, + "storeInAppleKeyChain": "Tárolás az Apple KeyChain-be", + "@storeInAppleKeyChain": {}, + "replaceRoomWithNewerVersion": "Szoba cserélése egy újabb verzióra", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "invalidServerName": "Hibás szerver név", + "@invalidServerName": {}, + "chatPermissions": "Csevegés engedélyek", + "@chatPermissions": {}, + "wipeChatBackup": "Le kívánja törölni a chat mentését, hogy létrehozhasson egy új visszaállítási kulcsot?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "sender": "Küldő", + "@sender": {}, + "storeInAndroidKeystore": "Tárolás az Android KeyStore-ba", + "@storeInAndroidKeystore": {}, + "signInWithPassword": "Bejelentkezés jelszóval", + "@signInWithPassword": {}, + "makeAdminDescription": "Miután a felhasználót aminisztrátorrá lépteti elő, nem fogja tudni visszavonni döntését, mivel azonos jogosultsági szinttel fognak rendelkezni.", + "@makeAdminDescription": {}, + "synchronizingPleaseWait": "Szinkronizálás... Kérem, várjon.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Átvitel másik eszközről", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Push szabályok", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "saveKeyManuallyDescription": "A kulcs manuális mentése rendszer megosztás vagy vágólap másolás segítségével.", + "@saveKeyManuallyDescription": {}, + "editBundlesForAccount": "Fiókcsoportok szerkesztése ehhez a fiókhoz", + "@editBundlesForAccount": {}, + "whyIsThisMessageEncrypted": "Miért olvashatatlan ez az üzenet?", + "@whyIsThisMessageEncrypted": {}, + "setChatDescription": "Csevegés leírás beállítása", + "@setChatDescription": {}, + "spaceName": "Tér név", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "importFromZipFile": "Importálás zip fájlból", + "@importFromZipFile": {}, + "toggleUnread": "Jelölés Olvasottként/Olvasatlanként", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "noOtherDevicesFound": "Nem található más eszköz", + "@noOtherDevicesFound": {}, + "redactedBy": "{username} által szerkesztve", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "videoCallsBetaWarning": "Kérem vegye figyelembe, hogy a videó hívások jelenleg béta fázisban vannak. Nem biztos, hogy megfelelően fognak működni, vagy egyáltalán elindulnak egyes platformokon.", + "@videoCallsBetaWarning": {}, + "signInWith": "Bejelentkezés a {provider} kiszolgálóval", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "Nem küldhető el! A szerver csak {max} határig enged csatolmányokat.", + "@fileIsTooBigForServer": {}, + "verified": "Hitelesített", + "@verified": { + "type": "String", + "placeholders": {} + }, + "callingPermissions": "Hívási engedélyek", + "@callingPermissions": {}, + "readUpToHere": "Olvasás idáig", + "@readUpToHere": {}, + "start": "Kezdés", + "@start": {}, + "unlockOldMessages": "Régi üzenetek feloldása", + "@unlockOldMessages": {}, + "numChats": "{number} csevegés", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Választható) A szerkesztés oka...", + "@optionalRedactReason": {}, + "sendAsText": "Küldés szövegként", + "@sendAsText": { + "type": "String" + }, + "archiveRoomDescription": "A csevegés bekerül az archívumba. Más felhasználók látni fogják, hogy elhagyta a csevegést.", + "@archiveRoomDescription": {}, + "exportEmotePack": "Emojicsomag exportálása zip-be", + "@exportEmotePack": {}, + "switchToAccount": "A {number} számú fiókra váltás", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Beállítás alapértelmezett álnévként", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Miért kívánja ezt bejelenteni?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "experimentalVideoCalls": "Kísérleti videó hívások", + "@experimentalVideoCalls": {}, + "pleaseEnterRecoveryKeyDescription": "A régi üzenetei feloldásához adja meg a korábban generált visszaállítási jelszavát. A visszaállítási jelszó NEM EGYEZIK MEG a jelszóval.", + "@pleaseEnterRecoveryKeyDescription": {}, + "inviteContactToGroupQuestion": "Meg kívánja hívni {contact} ismerősét a \"{groupName}\" csevegő csoportba?", + "@inviteContactToGroupQuestion": {}, + "redactedByBecause": "{username} által szerkesztve, mivel: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Visszavonta {user} meghívását", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "appearOnTopDetails": "Engedélyezi az app számára, hogy mindig legfelül jelenjen meg (nem szükséges, ha a FluffyChat hívó fiókként lett beállítva)", + "@appearOnTopDetails": {}, + "enterRoom": "Belépés a szobába", + "@enterRoom": {}, + "pleaseChooseAPasscode": "Kérem, válasszon egy kódot", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "reportUser": "Felhasználó jelentése", + "@reportUser": {}, + "confirmEventUnpin": "Biztosan végleg le akarja venni a kitűzött eseményt?", + "@confirmEventUnpin": {}, + "youInvitedUser": "📩 Meghívta {user}-t", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "A fájl mentésre került a következő elérési úton {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "redactMessageDescription": "A társalgásban összes résztvevője számára módosításra kerül az üzenet. Ez nem visszavonható.", + "@redactMessageDescription": {}, + "recoveryKey": "Visszaállító kulcs", + "@recoveryKey": {}, + "invalidInput": "Hibás bevitel!", + "@invalidInput": {}, + "yourPublicKey": "A publikus kulcsa", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Túl sok egyidejű kérelem. Kérem próbálja meg később!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "doNotShowAgain": "Ne mutassa újra", + "@doNotShowAgain": {}, + "report": "jelentés", + "@report": {}, + "status": "Állapot", + "@status": { + "type": "String", + "placeholders": {} + }, + "unverified": "Hitelesítetlen", + "@unverified": {}, + "serverRequiresEmail": "Ehhez a szerverhez szükséges az email címének visszaigazolása.", + "@serverRequiresEmail": {}, + "hideUnimportantStateEvents": "Jelentéktelen esemény státuszok elrejtése", + "@hideUnimportantStateEvents": {}, + "screenSharingTitle": "képernyő megosztás", + "@screenSharingTitle": {}, + "widgetCustom": "Egyedi", + "@widgetCustom": {}, + "addToSpaceDescription": "Válassza ki melyik térhez kívánja hozzáadni a csevegést.", + "@addToSpaceDescription": {}, + "youBannedUser": "Letitotta {user} felhasználót", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "addChatDescription": "Chat leírás hozzáadása...", + "@addChatDescription": {}, + "hasKnocked": "🚪 {user} bekopogott", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "publish": "Közzététel", + "@publish": {}, + "openLinkInBrowser": "Hivatkozás megnyitása böngészőben", + "@openLinkInBrowser": {}, + "messageInfo": "Üzenet információ", + "@messageInfo": {}, + "disableEncryptionWarning": "Biztonsági okokból nem kapcsolható ki egy korábban bekapcsolt csevegés titkosítás.", + "@disableEncryptionWarning": {}, + "directChat": "Privát csevegés", + "@directChat": {}, + "wrongPinEntered": "Hibás pinkódot adott meg! Próbálja újra {seconds} mp múlva...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "Gépelési értesítés megjelenítése", + "@sendTypingNotifications": {}, + "inviteGroupChat": "📨 Meghívó a csoportba", + "@inviteGroupChat": {}, + "appearOnTop": "Megjelenés legfelül", + "@appearOnTop": {}, + "invitePrivateChat": "📨 Meghívó privát csevegéshez", + "@invitePrivateChat": {}, + "foregroundServiceRunning": "Ez az értesítés akkor jelenik meg ha az előtéri szolgáltatás fut.", + "@foregroundServiceRunning": {}, + "voiceCall": "Hang hívás", + "@voiceCall": {}, + "importEmojis": "Emojik importálása", + "@importEmojis": {}, + "wasDirectChatDisplayName": "Üres csevegés (korábban {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "Még nincs csevegő szoba leírás.", + "@noChatDescriptionYet": {}, + "removeFromBundle": "Eltávolítás a fiókcsoportból", + "@removeFromBundle": {}, + "whoCanPerformWhichAction": "Ki milyen műveletet végezhet", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "learnMore": "Tudjon meg többet", + "@learnMore": {}, + "users": "Felhasználók", + "@users": {}, + "openGallery": "Galéria megnyitása", + "@openGallery": {}, + "chatDescriptionHasBeenChanged": "A csevegés leírás megváltozott", + "@chatDescriptionHasBeenChanged": {}, + "newGroup": "Új csoport", + "@newGroup": {}, + "bundleName": "Fiókcsoport neve", + "@bundleName": {}, + "removeFromSpace": "Eltávolítás a térről", + "@removeFromSpace": {}, + "roomUpgradeDescription": "A csevegés újra elkészül az új szoba verzióval. Minden résztvevő értesítést kap, hogy át kell állniuk az új csevegésre. További információkért a szoba verziókról látogasson el a https://spec.matrix.org/latest/rooms/ címre", + "@roomUpgradeDescription": {}, + "pleaseEnterANumber": "Adjon meg egy 0-nál nagyobb számot", + "@pleaseEnterANumber": {}, + "youKicked": "👞 Kirúgta {user}-t", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "profileNotFound": "A felhasználó nem található a szerveren. Lehetséges, hogy csatlakozási problémák adódtak, vagy nem létezik a felhasználó.", + "@profileNotFound": {}, + "jump": "Ugrás", + "@jump": {}, + "reactedWith": "{sender} a következőképp reagált: {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "sorryThatsNotPossible": "Ez sajnos nem lehetséges", + "@sorryThatsNotPossible": {}, + "videoWithSize": "Videó ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "shareInviteLink": "Meghívó link megosztása", + "@shareInviteLink": {}, + "commandHint_markasdm": "Szoba megjelölése mint közvetlen csevegő szoba az adott Matrix ID-nél", + "@commandHint_markasdm": {}, + "recoveryKeyLost": "Elveszett visszaállító kulcs?", + "@recoveryKeyLost": {}, + "deviceKeys": "Eszköz kulcsok:", + "@deviceKeys": {}, + "emoteKeyboardNoRecents": "A nemrég használt hangulatjelek fognak itt megjelenni...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Egyedi hangulatjelek beállítása", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Téma beállítása:", + "@setTheme": {}, + "youJoinedTheChat": "Becsatlakozott a csevegésbe", + "@youJoinedTheChat": {}, + "markAsRead": "Olvasottként megjelölés", + "@markAsRead": {}, + "widgetName": "Név", + "@widgetName": {}, + "errorAddingWidget": "Hiba lépett fel a widget hozzáadásánál.", + "@errorAddingWidget": {}, + "replace": "Kicserél", + "@replace": {}, + "youUnbannedUser": "Levette a letiltást {user}-ről", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "newSpace": "Új tér", + "@newSpace": {}, + "emojis": "Hangulatjelek", + "@emojis": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "Próbálja meg később, vagy válasszon másik szervert.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "createGroup": "Csoport létrehozása", + "@createGroup": {}, + "hydrateTorLong": "Legutóbb TOR segítségével exportálta korábbi munkamenetét? Gyorsan importálja őket vissza, és folytassa a csevegést.", + "@hydrateTorLong": {}, + "time": "Idő", + "@time": {}, + "custom": "Egyedi", + "@custom": {}, + "noBackupWarning": "Figyelem! Ha nem kapcsolja be a csevegés mentést, elveszíti a hozzáférést a tikosított üzeneteihez. Erősen ajánlott a csevegés mentés bekapcsolása kijelentkezés előtt.", + "@noBackupWarning": {}, + "storeInSecureStorageDescription": "Tárolja a visszaállítási kulcsot az eszköz biztonsági tárjában.", + "@storeInSecureStorageDescription": {}, + "openChat": "Csevegés megnyitása", + "@openChat": {}, + "kickUserDescription": "A felhasználó kirúgásra került a csevegésből, de nincs kitiltva. Publikus csevegés esetén a felhasználó bármikor visszatérhet.", + "@kickUserDescription": {}, + "importNow": "Importálás most", + "@importNow": {}, + "pinMessage": "Kitűzés a szobában", + "@pinMessage": {}, + "invite": "Meghívás", + "@invite": {}, + "enableMultiAccounts": "(BÉTA) Több fiók bekapcsolása az eszközön", + "@enableMultiAccounts": {}, + "indexedDbErrorTitle": "Privát mód problémák", + "@indexedDbErrorTitle": {}, + "unsupportedAndroidVersionLong": "Ehhez a funkcióhoz egy újabb Android verzió kell. Kérem ellenőrizze be van e frissítve teljesen készüléke, esetlegesen van e LineageOS támogatás hozzá.", + "@unsupportedAndroidVersionLong": {}, + "storeSecurlyOnThisDevice": "Biztonságos tárolás az eszközön", + "@storeSecurlyOnThisDevice": {}, + "screenSharingDetail": "Megosztja a képernyőjét a FluffyChat-ben", + "@screenSharingDetail": {}, + "placeCall": "Tér hívás", + "@placeCall": {}, + "block": "Blokkolás", + "@block": {}, + "blockedUsers": "Blokkolt felhasználók", + "@blockedUsers": {}, + "blockListDescription": "Az Önt zavaró felhasználókat blokkolhatja. A blokkolt listán található felhasználóktól nem tud fogadni üzenetet vagy szoba meghívást.", + "@blockListDescription": {}, + "blockUsername": "Felhasználónév ignorálása", + "@blockUsername": {}, + "presenceStyle": "Állapot:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Más felhasználók állapot üzeneteinek megjelenítése", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "youInvitedToBy": "📩 Meghívást kapott linken keresztül a következőhöz:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "decline": "Elutasítás", + "@decline": {}, + "yourGlobalUserIdIs": "A globális felhasználó-ID-je: ", + "@yourGlobalUserIdIs": {}, + "noUsersFoundWithQuery": "\"{query}\"-vel nem található felhasználó. Ellenőrizze nincs e elírás.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "acceptedKeyVerification": "{sender} elfogadta a kulcs megerősítést", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "searchForUsers": "Keressen @felhasználókat...", + "@searchForUsers": {}, + "joinSpace": "Csatlakozás a térre", + "@joinSpace": {}, + "publicSpaces": "Nyilvános terek", + "@publicSpaces": {}, + "databaseMigrationTitle": "Adatbázis optimalizálva", + "@databaseMigrationTitle": {}, + "leaveEmptyToClearStatus": "Hagyja üresen a státusz kitörléséhez.", + "@leaveEmptyToClearStatus": {}, + "pleaseEnterYourCurrentPassword": "Kérem adja meg jelenlegi jelszavát", + "@pleaseEnterYourCurrentPassword": {}, + "newPassword": "Új jelszó", + "@newPassword": {}, + "addChatOrSubSpace": "Csevegés vagy al-tér hozzáadása", + "@addChatOrSubSpace": {}, + "pleaseChooseAStrongPassword": "Kérem válasszon egy erős jelszót", + "@pleaseChooseAStrongPassword": {}, + "passwordsDoNotMatch": "A jelszavak nem egyeznek", + "@passwordsDoNotMatch": {}, + "passwordIsWrong": "Hibás a beírt jelszava", + "@passwordIsWrong": {}, + "subspace": "Al-tér", + "@subspace": {}, + "thisDevice": "Ez az eszköz:", + "@thisDevice": {}, + "forwardMessageTo": "Üzenet továbbítása a {roomName} szobába?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "A csevegés többi tagja látja amikor gépel.", + "@sendTypingNotificationsDescription": {}, + "sendReadReceiptsDescription": "A csevegés többi tagja láthatja, ha olvasta az üzeneteiket.", + "@sendReadReceiptsDescription": {}, + "sendReadReceipts": "Olvasási igazolás küldése", + "@sendReadReceipts": {}, + "formattedMessages": "Formázott üzenetek", + "@formattedMessages": {}, + "formattedMessagesDescription": "Formázott szöveg - mint például félkövér - megjelenítése \"markdown\"-al.", + "@formattedMessagesDescription": {}, + "verifyOtherUser": "🔐 Más felhasználó igazolása", + "@verifyOtherUser": {}, + "verifyOtherDevice": "🔐 Más eszköz hitelesítése", + "@verifyOtherDevice": {}, + "sessionLostBody": "A munkamenete elvesződött. Kérem jelentse ezt a fejlesztőknek a {url} címen. A hiba szövege a következő: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "databaseBuildErrorBody": "Nem lehetséges az SQlite adatbázis létrehozása. Az app megpróbálja a régi típusú adatbázist használni. Kérem jelentse a hibát a fejlesztőknek a {url} hivatkozáson. A hiba szövege a következő: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Megpróbálkozunk visszaállítani a munkamenetét egy korábbi mentésből. Kérem jelezze a hibát a fejlesztőknek a {url} címen. A hiba szövege a következő: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "hidePresences": "El kívánja rejteni a státusz listát?", + "@hidePresences": {}, + "searchChatsRooms": "Keressen #csevegéseket, @felhasználókat...", + "@searchChatsRooms": {}, + "wrongRecoveryKey": "Sajnos, úgy tűnik hibásan adta meg a visszaállítási kulcsot.", + "@wrongRecoveryKey": {}, + "startConversation": "Társalgás kezdése", + "@startConversation": {}, + "commandHint_sendraw": "Tiszta json küldése", + "@commandHint_sendraw": {}, + "databaseMigrationBody": "Kérem várjon. Ez igénybe vehet valamennyi időt.", + "@databaseMigrationBody": {}, + "initAppError": "Hiba lépett fel az app indítása során", + "@initAppError": {}, + "canceledKeyVerification": "{sender} visszautasította a kulcs megerősítést", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} befejezte a kulcs megerősítést", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} készen áll a kulcs megerősítésre", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} kulcs megerősítést kér", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} elkezdte a kulcs megerősítést", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Átlátszó", + "@transparent": {}, + "incomingMessages": "Bejövő üzenetek", + "@incomingMessages": {}, + "nothingFound": "Nincs találat...", + "@nothingFound": {}, + "publicLink": "Nyilvános hivatkozás", + "@publicLink": {}, + "select": "Kiválaszt", + "@select": {}, + "stickers": "Matricák", + "@stickers": {}, + "discover": "Felfedezés", + "@discover": {}, + "groupName": "Csoport név", + "@groupName": {}, + "createGroupAndInviteUsers": "Hozzon létre egy csoportot és hívjon meg felhasználókat", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "A csoportokat kereséssel találhatja meg", + "@groupCanBeFoundViaSearch": {}, + "verifyOtherUserDescription": "Ha megerősít egy másik felhasználót, akkor teljesen biztos lehet abban kivel cseveg. 💪\n\nA megerősítési folyamat kezdetekor megjelenik egy felugró ablak mindkettőjüknél. Ekkor egy hangulatjel vagy szám sor összehasonlítási folyamat veszi kezdetét.\n\nA legpraktikusabb módja ennek, hogy találkozzanak, vagy videó hívás során beszéljék meg. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDeviceDescription": "Amikor egy másik eszközt hitelesít, az eszközök kulcsokat cserélnek egymás között, ezáltal növelve az összbiztonságot. 💪 Amikor megkezdődik a folyamat, mind a két eszközön megjelenik egy felugró üzenet. Hangulatjelek és számok sorozata fog megjelenni, amit össze tud hasonlítani a két eszközön. Érdemes tehát mind a két eszközt a közelben tartani. 🤳", + "@verifyOtherDeviceDescription": {}, + "accessAndVisibility": "Hozzáférés és láthatóság", + "@accessAndVisibility": {}, + "accessAndVisibilityDescription": "Ki számára engedélyezett a csevegéshez való csatlakozás, és hogyan találhatja azt meg.", + "@accessAndVisibilityDescription": {}, + "calls": "Hívások", + "@calls": {}, + "hideInvalidOrUnknownMessageFormats": "Érvénytelen vagy ismeretlen üzenetformátum elrejtése", + "@hideInvalidOrUnknownMessageFormats": {}, + "hideMemberChangesInPublicChatsBody": "Ne mutassa ha valaki be- vagy kilép a csevegésből az olvashatóság javítása érdekében.", + "@hideMemberChangesInPublicChatsBody": {}, + "notifyMeFor": "Értesítsen ha", + "@notifyMeFor": {}, + "passwordRecoverySettings": "Jelszó-helyreállítási beállítások", + "@passwordRecoverySettings": {}, + "noOneCanJoin": "Senki sem csatlakozhat", + "@noOneCanJoin": {}, + "userWouldLikeToChangeTheChat": "{user} szeretne csatlakozni a csevegéshez.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Nyilvános link nem került még létrehozásra", + "@noPublicLinkHasBeenCreatedYet": {}, + "chatCanBeDiscoveredViaSearchOnServer": "Csevegés felfedezhető a {server} szerveren történő kereséssel", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appLockDescription": "Applikáció zárolása PIN kóddal használaton kívül", + "@appLockDescription": {}, + "customEmojisAndStickers": "Egyedi hangulatjelek és matricák", + "@customEmojisAndStickers": {}, + "customEmojisAndStickersBody": "Egyedi hangulatjelek és matricák hozzáadása, amelyek bármely csevegésben felhasználhatóak.", + "@customEmojisAndStickersBody": {}, + "overview": "Áttekintés", + "@overview": {}, + "publicChatAddresses": "Nyilvános csevegés címek", + "@publicChatAddresses": {}, + "userRole": "Felhasználói szerep", + "@userRole": {}, + "createNewAddress": "Új cím létrehozása", + "@createNewAddress": {}, + "noDatabaseEncryption": "Adatbázis titkosítás nem támogatott ezen a platformon", + "@noDatabaseEncryption": {}, + "thereAreCountUsersBlocked": "Jelenleg {count} felhasználó van letiltva.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "unreadChatsInApp": "{appname}: {unread} olvasatlan csevegések", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "searchIn": "Keresés a \"{chat}\" csevegésben...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "files": "Fájlok", + "@files": {}, + "commandHint_unignore": "Adott matrix ID figyelembe vétele", + "@commandHint_unignore": {}, + "restricted": "Korlátozott", + "@restricted": {}, + "knockRestricted": "Kopogás korlátozva", + "@knockRestricted": {}, + "globalChatId": "Átfogó csevegő ID", + "@globalChatId": {}, + "hideRedactedMessages": "Szerkesztett üzenetek elrejtése", + "@hideRedactedMessages": {}, + "hideRedactedMessagesBody": "Ha valaki szerkeszti az üzenetét, ez az üzenet nem jelenik meg a csevegés során.", + "@hideRedactedMessagesBody": {}, + "hideMemberChangesInPublicChats": "Tag változások elrejtése a publikus csevegésben", + "@hideMemberChangesInPublicChats": {}, + "knocking": "Bekopogás", + "@knocking": {}, + "usersMustKnock": "A felhasználóknak be kell kopogniuk", + "@usersMustKnock": {}, + "knock": "Kopogás", + "@knock": {}, + "minimumPowerLevel": "{level} a minimum szint.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchMore": "További keresés...", + "@searchMore": {}, + "gallery": "Galéria", + "@gallery": {}, + "commandHint_ignore": "Adott matrix ID figyelmen kívül hagyása", + "@commandHint_ignore": {}, + "unread": "Olvasatlan", + "@unread": {}, + "space": "Tér", + "@space": {}, + "spaces": "Terek", + "@spaces": {}, + "invitedBy": "📩 {user} jóvoltából meghívva", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "markAsUnread": "Olvasatlannak jelölés", + "@markAsUnread": {}, + "moderatorLevel": "{level} - Moderátor", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Általános csevegés beállítások módosítása", + "@changeGeneralChatSettings": {}, + "updateInstalled": "🎉 {version} verziójú frissítés telepítve!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Változásnapló", + "@changelog": {}, + "sendCanceled": "Küldés visszavonva", + "@sendCanceled": {}, + "noChatsFoundHere": "Itt még nem található csevegés. Kezdjen egy új csevegést valakivel a lenti gomb segítéségvel. ⤵️", + "@noChatsFoundHere": {}, + "goToSpace": "Ugrás a {space} térre", + "@goToSpace": { + "type": "String", + "space": {} + }, + "changeTheCanonicalRoomAlias": "Csevegés fő, nyilvános címének változtatása", + "@changeTheCanonicalRoomAlias": {}, + "chatPermissionsDescription": "Adja meg milyen erősségi szint kell egyes csevegési művelethez. A 0, 50 és 100-as szintek általában felhasználókat, moderátorokat és adminisztrátorokat jelölnek de bármilyen szintezés lehetséges.", + "@chatPermissionsDescription": {}, + "whatIsAHomeserver": "Mi az a Matrix-kiszolgáló?", + "@whatIsAHomeserver": {}, + "homeserverDescription": "Az összes adata a Mátrix-kiszolgálón tárolódik, pont mint egy e-mail kiszolgálón. Kiválaszthatja melyik Matrix-kiszolgálót akarja használni, miközben tud kommunikálni mindenkivel. Tudjon meg többet a https://matrix.org címen.", + "@homeserverDescription": {}, + "userLevel": "{level} - Felhasználó", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Adminisztrátor", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "inviteOtherUsers": "Más felhasználók meghívása a csevegésbe", + "@inviteOtherUsers": {}, + "changeTheVisibilityOfChatHistory": "Csevegési előzmények láthatóságának változtatása", + "@changeTheVisibilityOfChatHistory": {}, + "changeTheChatPermissions": "Csevegés engedélyek változtatása", + "@changeTheChatPermissions": {}, + "sendRoomNotifications": "@szoba értesítés küldése", + "@sendRoomNotifications": {}, + "changeTheDescriptionOfTheGroup": "Csevegés leírásának változtatása", + "@changeTheDescriptionOfTheGroup": {}, + "swipeRightToLeftToReply": "Húzza balra a válaszoláshoz", + "@swipeRightToLeftToReply": {}, + "alwaysUse24HourFormat": "", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "loginWithMatrixId": "Bejelentkezés Matrix-ID-vel", + "@loginWithMatrixId": {}, + "discoverHomeservers": "Matrix-kiszolgálók felfedezése", + "@discoverHomeservers": {}, + "doesNotSeemToBeAValidHomeserver": "Nem tűnik kompatibilisnek a Mátrix-kiszolgálónak. Hibás a hivatkozás?", + "@doesNotSeemToBeAValidHomeserver": {}, + "countChatsAndCountParticipants": "{chats} csevegések és {participants} résztvevők", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Nem található több csevegés...", + "@noMoreChatsFound": {}, + "joinedChats": "Csatlakozott csevegések", + "@joinedChats": {}, + "checkList": "Tennivalók listája", + "@checkList": {}, + "countInvited": "{count} meghívott", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendImages": "{count} kép küldése", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "aboutHomeserver": "Névjegy {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "normalUser": "Normál felhasználó", + "@normalUser": {}, + "ignoreUser": "Felhasználó ignorálása", + "@ignoreUser": {}, + "commandHint_roomupgrade": "Szoba frissítése a megadott szoba verzióra", + "@commandHint_roomupgrade": {}, + "setCustomPermissionLevel": "Egyedi engedélyszint beállítása", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Kérem, válasszon egy előre meghatározott szerepkört, vagy adjon meg egy egyedi engedély szintet 0 és 100 között.", + "@setPermissionsLevelDescription": {}, + "sendingAttachmentCountOfCount": "{index} csatolmány küldése {length}-ból...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Szerver korlát elérve! {seconds} mp türelem...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Egyik készüléke nem hitelesített", + "@oneOfYourDevicesIsNotVerified": {}, + "synchronizingPleaseWaitCounter": " Szinkronizálás… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "calculatingFileSize": "Fájl méret kalkulálása...", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "Felkészülés csatolmány küldésére...", + "@prepareSendingAttachment": {}, + "sendingAttachment": "Csatolmány küldése...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "Videó miniatűr generálása...", + "@generatingVideoThumbnail": {}, + "compressVideo": "Videó tömörítése...", + "@compressVideo": {}, + "contentNotificationSettings": "Tartalom értesítési beállítások", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "Átalános értesítési beállítások", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "Szoba értesítési beállítások", + "@roomNotificationSettings": {}, + "notificationRuleMasterDescription": "Felülír minden más szabályt, és kikapcsolja az összes értesítést.", + "@notificationRuleMasterDescription": {}, + "notificationRuleInviteForMe": "Meghívás Számomra", + "@notificationRuleInviteForMe": {}, + "notificationRuleMemberEventDescription": "Némítja a tagi események értesítéseit.", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleIsUserMention": "Felhasználó Említése", + "@notificationRuleIsUserMention": {}, + "notificationRuleTombstoneDescription": "Értesíti a felhasználót a szoba deaktiválás üzenetekről.", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleCall": "Hívás", + "@notificationRuleCall": {}, + "notificationRuleEncryptedRoomOneToOneDescription": "Értesíti a felhasználót a titkosított négyszemközti szobákban levő üzenetekről.", + "@notificationRuleEncryptedRoomOneToOneDescription": {}, + "notificationRuleRoomOneToOne": "Négyszemközti Szoba", + "@notificationRuleRoomOneToOne": {}, + "notificationRuleMessage": "Üzenet", + "@notificationRuleMessage": {}, + "notificationRuleMessageDescription": "Értesíti a felhasználót az általános üzenetekről.", + "@notificationRuleMessageDescription": {}, + "notificationRuleEncrypted": "Titkosított", + "@notificationRuleEncrypted": {}, + "notificationRuleEncryptedDescription": "Értesíti a felhasználót a titkosított szobákban levő üzenetekről.", + "@notificationRuleEncryptedDescription": {}, + "notificationRuleServerAcl": "Némítja a Szerver ACL Eseményeket", + "@notificationRuleServerAcl": {}, + "unknownPushRule": "'{rule}' egy ismeretlen push szabály", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "compress": "Tömörítés", + "@compress": {}, + "boldText": "Félkövér szöveg", + "@boldText": {}, + "italicText": "Dőlt szöveg", + "@italicText": {}, + "strikeThrough": "Áthúzott", + "@strikeThrough": {}, + "appWantsToUseForLogin": "Használja a '{server}' szervert a bejelentkezéshez", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "otherPartyNotLoggedIn": "A másik fél jelenleg nincs bejelentkezve, emiatt nem fogadhat üzeneteket!", + "@otherPartyNotLoggedIn": {}, + "appWantsToUseForLoginDescription": "Ezennel engedélyezi az applikáció és weboldal számára, hogy információkat gyűjtsön Önről.", + "@appWantsToUseForLoginDescription": {}, + "waitingForServer": "Várakozás a szerverre...", + "@waitingForServer": {}, + "appIntroduction": "A FluffyChat segítségével cseveghet barátaival, akár más üzenetküldő alkalmazásokon keresztül is. Tudjon meg erről többet a https://matrix.org oldalon, vagy nyomjon a \"Folytatás\" gombra.", + "@appIntroduction": {}, + "open": "Megnyitás", + "@open": {}, + "notificationRuleSuppressNotices": "Minden automata üzenetet némít", + "@notificationRuleSuppressNotices": {}, + "notificationRuleSuppressNoticesDescription": "Némít minden automata klienstől érkező értesítést mint például botok.", + "@notificationRuleSuppressNoticesDescription": {}, + "newChatRequest": "📩 Új csevegés kérelem", + "@newChatRequest": {}, + "notificationRuleContainsUserNameDescription": "Értesíti a felhasználót, ha az üzenet tartalmazza a nevét.", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleInviteForMeDescription": "Értesíti a felhasználót szoba meghívás esetén.", + "@notificationRuleInviteForMeDescription": {}, + "notificationRuleMemberEvent": "Tagi Esemény", + "@notificationRuleMemberEvent": {}, + "notificationRuleIsUserMentionDescription": "Értesíti a felhasználót, ha közvetlenül említésre kerül az üzenetben.", + "@notificationRuleIsUserMentionDescription": {}, + "notificationRuleIsRoomMention": "Szoba Említés", + "@notificationRuleIsRoomMention": {}, + "notificationRuleIsRoomMentionDescription": "Értesíti a felhasználót szoba említéskor.", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleRoomnotif": "Szoba Értesítés", + "@notificationRuleRoomnotif": {}, + "notificationRuleRoomnotifDescription": "Értesíti a felhasználót ha az üzenet tartalmazza a '@szoba' említést.", + "@notificationRuleRoomnotifDescription": {}, + "crossVerifiedDevicesIfEnabled": "Kereszt-hitelesített eszközök ha be van kapcsolva", + "@crossVerifiedDevicesIfEnabled": {}, + "crossVerifiedDevices": "Kereszt-hitelesített eszközök", + "@crossVerifiedDevices": {}, + "serverInformation": "Szerver információ:", + "@serverInformation": {}, + "unableToJoinChat": "Nem csatlakozhat a csevegéshez. Elképzelhető, hogy a másik fél már kilépett.", + "@unableToJoinChat": {}, + "userSpecificNotificationSettings": "Felhasználó specifikus értesítés beállítások", + "@userSpecificNotificationSettings": {}, + "otherNotificationSettings": "Egyéb értesítés beállítások", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "Felhasználó nevet tartalmaz", + "@notificationRuleContainsUserName": {}, + "notificationRuleContainsDisplayName": "Megjelenített Nevet Tartalmaz", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleReaction": "Reakció", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "Némítja a reakciók értesítéseit.", + "@notificationRuleReactionDescription": {}, + "notificationRuleRoomServerAcl": "Szoba Szerver ACL", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleRoomServerAclDescription": "Némítja a szoba szerver hozzáférési kezelő lista (ACL) értesítéseket.", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleSuppressEdits": "Szerkesztések némítása", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "Némítja a szerkesztett üzenetek értesítéseit.", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleEncryptedRoomOneToOne": "Titkosított Négyszemközti Szoba", + "@notificationRuleEncryptedRoomOneToOne": {}, + "notificationRuleRoomOneToOneDescription": "Értesíti a felhasználót a négyszemközti szobában levő üzenetekről.", + "@notificationRuleRoomOneToOneDescription": {}, + "notificationRuleJitsi": "Jitsi", + "@notificationRuleJitsi": {}, + "notificationRuleJitsiDescription": "Értesíti a felhasználót a Jitsi widget eseményekről.", + "@notificationRuleJitsiDescription": {}, + "sentVoiceMessage": "🎙️ {duration} - {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Ha törli ezt az értesítési beállítást, később nem vonható vissza.", + "@deletePushRuleCanNotBeUndone": {}, + "manageAccount": "Fiók kezelése", + "@manageAccount": {}, + "enterNewChat": "Belépés új csevegésbe", + "@enterNewChat": {}, + "blur": "Homályosít:", + "@blur": {}, + "name": "Név", + "@name": {}, + "continueText": "Folytatás", + "@continueText": {}, + "opacity": "Átlátszóság:", + "@opacity": {}, + "welcomeText": "Üdv 👋 Ez a FluffyChat. Bejelentkezhet bármely matrix-kiszolgálóhoz amely kompatibilis a https://matrix.org címmel. Ezután cseveghet bárkivel. Így képez egy óriási decentralizált üzenetküldő hálózatot!", + "@welcomeText": {}, + "addLink": "Hivatkozás hozzáadása", + "@addLink": {}, + "invalidUrl": "Helytelen hivatkozás", + "@invalidUrl": {}, + "setWallpaper": "Háttér beállítás", + "@setWallpaper": {}, + "noContactInformationProvided": "A szervertől nem érkezett vissza kapcsolati információ", + "@noContactInformationProvided": {}, + "contactServerSecurity": "Kapcsolatfelvétel a szerver biztonsággal", + "@contactServerSecurity": {}, + "contactServerAdmin": "Kapcsolatfelvétel a szerver adminnal", + "@contactServerAdmin": {}, + "supportPage": "Támogatási oldal", + "@supportPage": {}, + "version": "Verzió", + "@version": {}, + "verifiedDevicesOnly": "Csak hitelesített eszközök", + "@verifiedDevicesOnly": {}, + "website": "Weboldal", + "@website": {}, + "pleaseFillOut": "Kérem töltse ki", + "@pleaseFillOut": {}, + "previous": "Előző", + "@previous": {}, + "optionalMessage": "(Választható) üzenet...", + "@optionalMessage": {}, + "takeAPhoto": "Készítsen egy fotót", + "@takeAPhoto": {}, + "recordAVideo": "Vegyen fel egy videót", + "@recordAVideo": {}, + "notSupportedOnThisDevice": "Nem támogatott ezen az eszközön", + "@notSupportedOnThisDevice": {}, + "noticeChatBackupDeviceVerification": "Megjegyzés: Minden eszköze amit a csevegés mentéshez kapcsol, automatikusan hitelesítésre kerül.", + "@noticeChatBackupDeviceVerification": {}, + "notificationRuleMaster": "Minden értesítés némítása", + "@notificationRuleMaster": {}, + "notificationRuleContainsDisplayNameDescription": "Értesíti a felhasználót, ha közvetlenül említésre kerül a megjelenített neve az üzenetben.", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleTombstone": "Sírkő", + "@notificationRuleTombstone": {}, + "shareKeysWithDescription": "Mely eszközök tekinthetőek megbízhatónak, hogy olvashassák a titkosított csevegéseket is?", + "@shareKeysWithDescription": {}, + "allDevices": "Minden eszköz", + "@allDevices": {}, + "notificationRuleServerAclDescription": "Némítja a Szerver ACL események értesítéseit.", + "@notificationRuleServerAclDescription": {}, + "notificationRuleCallDescription": "Értesíti a felhasználót a hívásokról.", + "@notificationRuleCallDescription": {}, + "more": "Több", + "@more": {}, + "shareKeysWith": "Kulcsok megosztása...", + "@shareKeysWith": {}, + "approve": "Jóváhagy", + "@approve": {}, + "youHaveKnocked": "Kopogott", + "@youHaveKnocked": {}, + "pleaseWaitUntilInvited": "Kérem várjon, amíg valaki a szobából behívja Önt.", + "@pleaseWaitUntilInvited": {} +} diff --git a/assets/l10n/intl_ia.arb b/lib/l10n/intl_ia.arb similarity index 80% rename from assets/l10n/intl_ia.arb rename to lib/l10n/intl_ia.arb index 7ec650c44..ec6a01f2a 100644 --- a/assets/l10n/intl_ia.arb +++ b/lib/l10n/intl_ia.arb @@ -5,7 +5,7 @@ "@notAnImage": {}, "remove": "Remover", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "importEmojis": "Importar emojis", @@ -20,36 +20,40 @@ "@replace": {}, "about": "A proposito de", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "Acceptar", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "👍 {username} acceptava tu invitation", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "Conto", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "addEmail": "Adder email", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "supposedMxid": "Isto deberea esser {mxid}", "@supposedMxid": { - "type": "text", + "type": "String", "placeholders": { - "mxid": {} + "mxid": { + "type": "String" + } } }, "@custom": {} diff --git a/lib/l10n/intl_id.arb b/lib/l10n/intl_id.arb new file mode 100644 index 000000000..d0cddc25a --- /dev/null +++ b/lib/l10n/intl_id.arb @@ -0,0 +1,3146 @@ +{ + "@@last_modified": "2021-08-14 12:41:10.002360", + "setAsCanonicalAlias": "Atur sebagai alias utama", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Versi ruangan", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "people": "Orang-orang", + "@people": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Pergi ke ruangan yang baru", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "chats": "Obrolan", + "@chats": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "Blokir Perangkat", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Apakah kamu yakin ingin keluar?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Apakah kamu yakin?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "archive": "Arsip", + "@archive": { + "type": "String", + "placeholders": {} + }, + "anyoneCanJoin": "Siapa saja dapat bergabung", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} menjawab panggilan", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "account": "Akun", + "@account": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} menerima undangannya", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "accept": "Terima", + "@accept": { + "type": "String", + "placeholders": {} + }, + "about": "Tentang", + "@about": { + "type": "String", + "placeholders": {} + }, + "isTyping": "sedang mengetik…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} mengundang kamu ke FluffyChat. \n1. Kunjungi fluffychat.im dan instal aplikasi\n2. Daftar atau masuk \n3. Buka tautan undangan: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "inviteForMe": "Undangan untuk saya", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "invitedUsersOnly": "Pengguna yang diundang saja", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} mengundang {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invited": "Diundang", + "@invited": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Undang kontak ke {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "inviteContact": "Undang kontak", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Frasa sandi atau kunci pemulihan yang salah", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Saya sudah klik tautannya", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Pengguna yang diabaikan", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "identity": "Identitas", + "@identity": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Sembunyikan peristiwa tidak dikenal", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Sembunyikan peristiwa yang dihapus", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "help": "Bantuan", + "@help": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} telah mencabut undangan untuk {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "guestsCanJoin": "Tamu bisa bergabung", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "guestsAreForbidden": "Tamu dilarang", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grup dengan {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "groupIsPublic": "Grup bersifat publik", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "group": "Grup", + "@group": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Dari undangan", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Dari bergabung", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "forward": "Teruskan", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fileName": "Nama file", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Semua siap!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Masukkan homeserver-mu", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "enterAnEmailAddress": "Masukkan alamat email", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} mengakhiri panggilan", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "encryption": "Enkripsi", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Terenkripsi", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Kamu tidak akan bisa menonaktifkan enkripsi. Apakah kamu yakin?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Aktifkan paket emote secara global", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Chat kosong", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Kamu harus memilih shortcode emote dan gambar!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Shortcode emote", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Pengaturan Emote", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Paket emote untuk ruangan", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Shortcode emote tidak valid!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emote sudah ada!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Edit alias ruangan", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Edit nama tampilan", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "edit": "Sunting", + "@edit": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Unduh berkas", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Nama tampilan telah diubah", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "directChats": "Chat Langsung", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "devices": "Perangkat", + "@devices": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID Perangkat", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "device": "Perangkat", + "@device": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Hapus pesan", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Hapus akun", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "delete": "Hapus", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deactivateAccountWarning": "Ini akan menonaktifkan akun penggunamu. Ini tidak bisa dibatalkan! Apakah kamu yakin?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateAndTimeOfDay": "{timeOfDay}, {date}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "currentlyActive": "Aktif", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} membuat obrolan ini", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "create": "Buat", + "@create": { + "type": "String", + "placeholders": {} + }, + "countParticipants": "{count} anggota", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "couldNotDecryptMessage": "Tidak dapat mendekripsikan pesan: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "copyToClipboard": "Salin ke papan klip", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Salin", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Disalin ke papan klip", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Cadangan obrolan", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chat": "Obrolan", + "@chat": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Enkripsi telah rusak", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Ubah avatarmu", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Ubah nama grup", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Ubah homeserver", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changePassword": "Ubah kata sandi", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changedTheRoomInvitationLink": "{username} mengubah tautan undangan", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} mengubah alias ruangan", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} mengubah avatarnya", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} mengubah aturan bergabung ke: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} mengubah aturan bergabung", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} mengubah visibilitas sejarah ke: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} mengubah visibilitas sejarah", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} mengubah aturan akses tamu ke: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} mengubah aturan akses tamu", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} mengubah nama tampilan ke: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} mengubah izin obrolan", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} mengubah nama obrolan ke: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} mengubah deskripsi obrolan ke: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatAvatar": "{username} mengubah avatar obrolan", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeDeviceName": "Ganti nama perangkat", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Tidak bisa membuka URI ini {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "cancel": "Batal", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Pesan bot", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "blocked": "Diblokir", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} mencekal {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "banned": "Dicekal", + "@banned": { + "type": "String", + "placeholders": {} + }, + "banFromChat": "Cekal dari obrolan", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "Homeserver ini mendukung versi Spec ini:\n{serverVersions}\nTetapi aplikasi ini hanya mendukung {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendOnEnter": "Kirim dengan enter", + "badServerLoginTypesException": "Homeserver ini mendukung tipe masuk ini:\n{serverVersions}\nTetapi aplikasi ini mendukung:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "autoplayImages": "Mainkan stiker beranimasi dan emote secara otomatis", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "askVerificationRequest": "Terima permintaan verifikasi dari {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "askSSSSSign": "Untuk dapat menandatangani orang lain, silakan masukkan frasa sandi atau kunci pemulihan penyimpanan aman kamu.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Apakah pengguna tamu diizinkan untuk bergabung", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Kunci aplikasi", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "allChats": "Semua obrolan", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "all": "Semua", + "@all": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Tambah ke space", + "addEmail": "Tambah email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Enkripsi tidak diaktifkan", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Berisi nama pengguna", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Berisi nama tampilan", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontak telah diundang ke grup", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "connect": "Hubungkan", + "@connect": { + "type": "String", + "placeholders": {} + }, + "confirm": "Konfirmasi", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Bandingkan angka", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Bandingkan emoji", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "close": "Tutup", + "@close": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Bersihkan arsip", + "chooseAStrongPassword": "Pilih kata sandi yang kuat", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Detail obrolan", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Pesan Anda diamankan dengan kunci pemulihan. Pastikan Anda tidak kehilangannya.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} mengaktifkan enkripsi ujung ke ujung", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "loadingPleaseWait": "Memuat… Mohon tunggu.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Muat {count} anggota", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "license": "Lisensi", + "@license": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Keluar dari obrolan", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "leave": "Tinggalkan", + "@leave": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Terakhir aktif: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "kickFromChat": "Keluarkan dari obrolan", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "kickedAndBanned": "🙅 {username} mengeluarkan dan mencekal {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kicked": "👞 {username} mengeluarkan {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "joinRoom": "Bergabung dengan ruangan", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} telah bergabung dengan obrolan", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "loadMore": "Muat lebih banyak…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Tidak ada izin", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Kamu belum menambahkan cara untuk memulihkan kata sandimu.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "none": "Tidak Ada", + "@none": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Perpesanan Awan Firebase sepertinya tidak tersedia di perangkatmu. Untuk dapat menerima notifikasi dorongan, kami menyarankan memasang ntfy. Dengan ntfy atau penyedia UnifiedPush lainnya, kamu bisa menerima notifikasi dorongan dengan cara yang aman. Kamu bisa mengunduh ntfy dari Play Store atau F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Kamu hanya bisa mengaktifkan enkripsi setelah ruangan tidak lagi dapat diakses secara publik.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Tidak ada emote yang ditemukan. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "next": "Lanjut", + "@next": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Permintaan verifikasi baru!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Pesan baru di FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newChat": "Chat baru", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Perlu diketahui bahwa kamu memerlukan Pantalaimon untuk menggunakan enkripsi ujung-ke-ujung untuk saat ini.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Bisukan obrolan", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "mention": "Sebutkan", + "@mention": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Perubahan anggota", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "logout": "Keluar", + "@logout": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Masuk ke {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "login": "Masuk", + "@login": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Tidak ada ruangan yang ditemukan…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "verified": "Terverifikasi", + "@verified": { + "type": "String", + "placeholders": {} + }, + "userLeftTheChat": "🚪 {username} keluar dari obrolan", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "unavailable": "Tidak tersedia", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Transfer dari perangkat lain", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Tampilkan kata sandi", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Hapus avatarmu", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "register": "Daftar", + "@register": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Aturan push", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Mohon ikuti petunjuk di situs web dan tekan lanjut.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Mohon pilih", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Ups! Sayangnya, terjadi kesalahan saat mengatur pemberitahuan push.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Cadangan Kunci Online dinyalakan", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "online": "Online", + "@online": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "offline": "Offline", + "@offline": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Notifikasi diaktifkan untuk akun ini", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notifikasi", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Kunci publikmu", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Kamu telah dicekal dari obrolan ini", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Kamu tidak berpartisipasi lagi di obrolan ini", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "you": "Kamu", + "@you": { + "type": "String", + "placeholders": {} + }, + "yes": "Ya", + "@yes": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Tulis pesan…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Dengan alamat ini kamu bisa memulihkan kata sandimu.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Hapus cadangan obrolan untuk membuat kunci pemulihan baru?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Kenapa kamu ingin melaporkannya?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Siapa yang dapat bergabung ke grup ini", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Siapa yang dapat melakukan tindakan apa", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Kami mengirim kamu sebuah email", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "warning": "Peringatan!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Latar belakang:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Menunggu pengguna untuk menerima angka…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Menunggu pengguna untuk menerima emoji…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Menunggu pengguna untuk menerima permintaan…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Pesan suara", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Terlihat untuk semua orang", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Terlihat untuk semua anggota", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Visibilitas sejarah obrolan", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Panggilan video", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Memverifikasi akun lain", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Kamu berhasil memverifikasi!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Mulai Verifikasi", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verify": "Verifikasi", + "@verify": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} mengirim peristiwa {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "username": "Nama Pengguna", + "@username": { + "type": "String", + "placeholders": {} + }, + "userIsTyping": "{username} sedang mengetik…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userAndUserAreTyping": "{username} dan {username2} sedang mengetik…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userAndOthersAreTyping": "{username} dan {count} lainnya sedang mengetik…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "unreadChats": "{unreadCount, plural, =1{1 obrolan belum dibaca} other{{unreadCount} obrolan belum dibaca}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "unpin": "Lepaskan pin", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unmuteChat": "Bunyikan obrolan", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Peristiwa tidak dikenal '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unknownEncryptionAlgorithm": "Algoritma enkripsi tidak dikenal", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Perangkat tidak dikenal", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unblockDevice": "Hilangkan Pemblokiran Perangkat", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} menghilangkan cekalan {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "tryToSendAgain": "Coba kirim lagi", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Terlalu banyak permintaan. Coba lagi nanti!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Tandai Baca/Belum Dibaca", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Beralih Bisuan", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Beralih Favorit", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "theyMatch": "Cocok", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Tidak Cocok", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistem", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Menyinkronkan... Mohon tunggu.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "submit": "Kirim", + "@submit": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Apa kabar hari ini?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "status": "Status", + "@status": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} memulai panggilan", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "spaceName": "Nama space", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Space publik", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Kode sumber", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "skip": "Lewat", + "@skip": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Login Masuk Tunggal", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Bagikan lokasi", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} membagikan lokasinya", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "share": "Bagikan", + "@share": { + "type": "String", + "placeholders": {} + }, + "settings": "Pengaturan", + "@settings": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Tetapkan status", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Tetapkan level izin", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Tetapkan tautan undangan", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Tetapkan emote kustom", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "sentCallInformations": "{senderName} mengirim informasi panggilan", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} mengirim video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} mengirim stiker", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} mengirim gambar", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} mengirim suara", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAFile": "📁 {username} mengirim file", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "seenByUser": "Dilihat oleh {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "security": "Keamanan", + "@security": { + "type": "String", + "placeholders": {} + }, + "search": "Cari", + "@search": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Minta izin", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Laporkan pesan", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "reply": "Balas", + "@reply": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Menggantikan ruangan dengan versi baru", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Hilangkan cekalan dari obrolan", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "remove": "Hapus", + "@remove": { + "type": "String", + "placeholders": {} + }, + "rejoin": "Gabung kembali", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} menolak undangannya", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Tolak", + "@reject": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "Hapus pesan", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} menghapus sebuah peristiwa", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "pleaseEnterYourPassword": "Mohon masukkan kata sandimu", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Mohon klik tautan di email dan lanjut.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Mohon pilih kode sandi", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "play": "Mainkan {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pin": "Pin", + "@pin": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Pemulihan kata sandi", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Kata sandi telah diubah", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Lupa kata sandi", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "password": "Kata sandi", + "@password": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "frasa sandi atau kunci pemulihan", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "participant": "Peserta", + "@participant": { + "type": "String", + "placeholders": {} + }, + "or": "Atau", + "@or": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "Server ini harus memvalidasi alamat email kamu untuk registrasi.", + "openInMaps": "Buka di peta", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "enableMultiAccounts": "(BETA) Aktifkan multi-akun di perangkat ini", + "bundleName": "Nama bundel", + "removeFromBundle": "Hilangkan dari bundel ini", + "addToBundle": "Tambah ke bundel", + "editBundlesForAccount": "Edit bundel untuk akun ini", + "addAccount": "Tambah akun", + "oneClientLoggedOut": "Salah satu klienmu telah keluar", + "openCamera": "Buka kamera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Buka aplikasi untuk membaca pesan", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ups, ada yang salah…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "offensive": "Menyinggung", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Mendapatkan lokasi…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} pengguna sedang mengetik…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "scanQrCode": "Pindai kode QR", + "noMatrixServer": "{server1} itu bukan server Matrix, gunakan {server2} saja?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "no": "Tidak", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Tidak ada koneksi ke server", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "messages": "Pesan", + "@messages": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Layanan lokasi dinonaktifkan. Mohon diaktifkan untuk bisa membagikan lokasimu.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Izin lokasi ditolak. Mohon memberikan izin untuk bisa membagikan lokasimu.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Terang", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Tidak menyinggung", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "ignore": "Abaikan", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Seberapa menyinggungnya konten ini?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "groups": "Grup", + "@groups": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Ukuran font", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Gagal mendapat lokasi: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "homeserver": "Homeserver", + "enableEncryption": "Aktifkan enkripsi", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Edit avatar ruangan", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Edit server yang diblokir", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Level izin bawaan untuk pengguna baru", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Gelap", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Space baru", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Konten telah dilaporkan ke admin server", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Konfigurasi obrolan", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "commandMissing": "{command} bukan sebuah perintah.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "commandInvalid": "Perintah tidak valid", + "@commandInvalid": { + "type": "String" + }, + "commandHint_unban": "Hilangkan cekalan untuk pengguna yang dicantumkan dari ruangan ini", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandHint_send": "Kirim teks", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_react": "Kirim balasan sebagai reaksi", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_plain": "Kirim teks yang tidak diformat", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_op": "Tetapkan tingkat kekuatan pengguna yang dicantum (default: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_myroomnick": "Tetapkan nama tampilanmu untuk ruangan ini", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_myroomavatar": "Tetapkan gambarmu untuk ruangan ini (oleh uri-mxc)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_me": "Jelaskan dirimu", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_leave": "Tinggalkan ruangan ini", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_kick": "Keluarkan pengguna yang dicantum dari ruangan ini", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_join": "Gabung ke ruangan yang dicantum", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_invite": "Undang pengguna yang dicantum ke ruangan ini", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_html": "Kirim teks yang diformat dengan HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_ban": "Cekal pengguna yang dicantumkan dari ruangan ini", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "chatHasBeenAddedToThisSpace": "Obrolan telah ditambahkan ke space ini", + "changeTheme": "Ubah tema", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Sangat menyinggung", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Kirim video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Kirim stiker", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Kirim yang asli", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Kirim pesan", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Kirim gambar", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Kirim file", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Kirim suara", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Kirim sebagai teks", + "@sendAsText": { + "type": "String" + }, + "sendAMessage": "Kirim pesan", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "send": "Kirim", + "@send": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Simpan file", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Ruangan telah ditingkatkan", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "removeDevice": "Hapus perangkat", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Dihapus oleh {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeAllOtherDevices": "Hapus semua perangkat lain", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "recording": "Merekam", + "@recording": { + "type": "String", + "placeholders": {} + }, + "reason": "Alasan", + "@reason": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Ruangan Publik", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privasi", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Mohon masukkan nama penggunamu", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Mohon masukkan 4 digit atau tinggalkan kosong untuk menonaktifkan kunci aplikasi.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Masukkan pin", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Pilih gambar", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "link": "Tautan", + "yourChatBackupHasBeenSetUp": "Cadangan obrolanmu telah disiapkan.", + "unverified": "Tidak terverifikasi", + "repeatPassword": "Ulangi kata sandi", + "messageInfo": "Informasi pesan", + "time": "Waktu", + "messageType": "Tipe Pesan", + "sender": "Pengirim", + "openGallery": "Buka galeri", + "addToSpaceDescription": "Pilih sebuah space untuk menambahkan obrolan ke spacenya.", + "start": "Mulai", + "removeFromSpace": "Hilangkan dari space", + "commandHint_clearcache": "Bersihkan tembolok", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_discardsession": "Buang sesi", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Mulai sebuah obrolan langsung\nGunakan --no-encryption untuk menonaktifkan enkripsi", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_create": "Buat sebuah grup obrolan kosong\nGunakan --no-encryption untuk menonaktifkan enkripsi", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "openVideoCamera": "Buka kamera untuk merekam video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "publish": "Publikasi", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "dismiss": "Abaikan", + "markAsRead": "Tandai sebagai dibaca", + "reportUser": "Laporkan pengguna", + "openChat": "Buka Chat", + "reactedWith": "{sender} bereaksi dengan {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "emojis": "Emoji", + "pinMessage": "Sematkan ke ruangan", + "confirmEventUnpin": "Apakah kamu yakin untuk melepaskan pin peristiwa ini secara permanen?", + "unsupportedAndroidVersionLong": "Fitur ini memerlukan versi Android yang baru. Mohon periksa untuk pembaruan atau dukungan LineageOS.", + "unsupportedAndroidVersion": "Versi Android tidak didukung", + "placeCall": "Lakukan panggilan", + "voiceCall": "Panggilan suara", + "videoCallsBetaWarning": "Dicatat bahwa panggilan video sedang dalam beta. Fitur ini mungkin tidak berkerja dengan benar atau tidak berkerja sama sekali pada semua platform.", + "emailOrUsername": "Email atau nama pengguna", + "experimentalVideoCalls": "Panggilan video eksperimental", + "previousAccount": "Akun sebelumnya", + "switchToAccount": "Ganti ke akun {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Akun berikutnya", + "widgetEtherpad": "Catatan teks", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "Kustom", + "errorAddingWidget": "Terjadi kesalahan menambahkan widget.", + "widgetName": "Nama", + "addWidget": "Tambahkan widget", + "widgetVideo": "Video", + "widgetUrlError": "Ini bukan URL yang valid.", + "widgetNameError": "Mohon sediakan sebuah nama tampilan.", + "separateChatTypes": "Pisahkan Pesan Langsung dan Grup", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youInvitedBy": "📩 Kamu telah diundang oleh {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Kamu mengundang {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Kamu mengeluarkan {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Kamu mengeluarkan dan mencekal {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youRejectedTheInvitation": "Kamu menolak undangannya", + "youJoinedTheChat": "Kamu bergabung ke obrolan", + "youAcceptedTheInvitation": "👍 Kamu menerima undangannya", + "youBannedUser": "Kamu mencekal {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Kamu telah membatalkan undangan untuk {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Kamu membatalkan cekalan {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "pleaseEnterRecoveryKeyDescription": "Untuk mengakses pesan lamamu, mohon masukkan kunci pemulihanmu yang telah dibuat di sesi sebelumnya. Kunci pemulihanmu BUKAN kata sandimu.", + "users": "Pengguna", + "storeInSecureStorageDescription": "Simpan kunci pemulihan di penyimpanan aman perangkat ini.", + "saveKeyManuallyDescription": "Simpan kunci ini secara manual dengan memicu dialog pembagian atau papan klip sistem.", + "recoveryKey": "Kunci pemulihan", + "storeInAppleKeyChain": "Simpan di Apple KeyChain", + "pleaseEnterRecoveryKey": "Mohon masukkan kunci pemulihanmu:", + "unlockOldMessages": "Akses pesan lama", + "recoveryKeyLost": "Kunci pemulihan hilang?", + "storeInAndroidKeystore": "Simpan di Android KeyStore", + "storeSecurlyOnThisDevice": "Simpan secara aman di perangkat ini", + "countFiles": "{count} file", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "hydrate": "Pulihkan dari file cadangan", + "indexedDbErrorTitle": "Masalah dengan mode privat", + "indexedDbErrorLong": "Penyimpanan pesan sayangnya tidak diaktifkan dalam mode privat secara default.\nMohon kunjungi\n- about:config\n- tetapkan dom.indexedDB.privateBrowsing.enabled ke true\nJika tidak ditetapkan, FluffyChat tidak akan dapat dijalankan.", + "dehydrate": "Ekspor sesi dan bersihkan perangkat", + "dehydrateWarning": "Tindakan ini tidak dapat diurungkan. Pastikan kamu telah menyimpan file cadangan dengan aman.", + "dehydrateTor": "Pengguna Tor: Ekspor sesi", + "hydrateTorLong": "Apakah kamu mengekspor sesimu terakhir kali di Tor? Impor dengan cepat dan lanjut mengobrol.", + "dehydrateTorLong": "Pengguna Tor disarankan untuk mengekspor sesi sebelum menutup jendela.", + "hydrateTor": "Pengguna Tor: Impor eksporan sesi", + "custom": "Kustom", + "user": "Pengguna", + "confirmMatrixId": "Mohon konfirmasi ID Matrix Anda untuk menghapus akun Anda.", + "supposedMxid": "Ini seharusnya {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasdm": "Tandai sebagai ruangan pesan langsung untuk ID Matrix yang ditentukan", + "commandHint_markasgroup": "Tandai sebagai grup", + "screenSharingTitle": "membagikan layar", + "appearOnTopDetails": "Memperbolehkan aplikasi untuk ditampilkan di atas (tidak dibutuhkan jika kamu memiliki FluffyChat ditetapkan sebagai akun pemanggilan)", + "callingAccountDetails": "Memperbolehkan FluffyChat untuk menggunakan aplikasi penelepon Android bawaan.", + "noKeyForThisMessage": "Hal ini bisa terjadi jika pesan dikirim sebelum kamu masuk ke akunmu di perangkat ini.\n\nMungkin juga pengirim telah memblokir perangkatmu atau ada yang tidak beres dengan koneksi internet.\n\nApakah kamu bisa membaca pesan pada sesi lain? Maka kamu bisa mentransfer pesan dari sesi tersebut! Buka Pengaturan > Perangkat dan pastikan bahwa perangkat Anda telah ditandatangani secara silang. Ketika kamu membuka ruangan di lain waktu dan kedua sesi berada di latar depan, kunci akan ditransmisikan secara otomatis.\n\nApakah kamu tidak mau kehilangan kunci saat keluar atau berpindah perangkat? Pastikan bahwa kamu telah mengaktifkan cadangan obrolan dalam pengaturan.", + "foregroundServiceRunning": "Notifikasi ini ditampilkan ketika layanan latar depan berjalan.", + "callingPermissions": "Perizinan panggilan", + "appearOnTop": "Tampilkan di atas", + "callingAccount": "Akun pemanggilan", + "otherCallingPermissions": "Mikrofon, kamera dan perizinan FluffyChat lainnya", + "whyIsThisMessageEncrypted": "Mengapa pesan ini tidak bisa dibaca?", + "newGroup": "Grup baru", + "newSpace": "Space baru", + "enterSpace": "Masuk space", + "enterRoom": "Masuk ruangan", + "allSpaces": "Semua space", + "screenSharingDetail": "Kamu membagikan layarmu di FluffyChat", + "numChats": "{number} obrolan", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Sembunyikan peristiwa keadaan yang tidak penting", + "doNotShowAgain": "Jangan tampilkan lagi", + "hugContent": "{senderName} memeluk kamu", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "googlyEyesContent": "{senderName} mengirim mata googly", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} berpelukan dengan kamu", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_googly": "Kirim mata googly", + "commandHint_hug": "Kirim pelukan", + "commandHint_cuddle": "Kirim berpelukan", + "wasDirectChatDisplayName": "Obrolan kosong (sebelumnya {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "startFirstChat": "Mulai obrolan pertamamu", + "newSpaceDescription": "Fitur space bisa membantu untuk memisahkan obrolanmu dan membuat komunitas pribadi atau publik.", + "sorryThatsNotPossible": "Maaf... itu tidak mungkin", + "deviceKeys": "Kunci perangkat:", + "encryptThisChat": "Enkripsi obrolan ini", + "disableEncryptionWarning": "Demi keamanan kamu tidak bisa menonaktifkan enkripsi dalam sebuah obrolan di mana sebelumbya sudah diaktifkan.", + "reopenChat": "Buka obrolan lagi", + "noBackupWarning": "Peringatan! Tanpa mengaktifkan cadangan percakapan, kamu akan kehilangan akses ke pesan terenkripsimu. Disarankan untuk mengaktifkan cadangan percakapan terlebih dahulu sebelum keluar dari akun.", + "noOtherDevicesFound": "Tidak ada perangkat lain yang ditemukan", + "fileIsTooBigForServer": "Tidak dapat mengirim! Server hanya mendukung lampiran sampai dengan {max}.", + "fileHasBeenSavedAt": "Berkas telah disimpan di {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Pergi ke pesan terakhir dibaca", + "readUpToHere": "Baca sampai sini", + "jump": "Lompat", + "openLinkInBrowser": "Buka tautan dalam peramban", + "allRooms": "Semua Percakapan Grup", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "report": "laporkan", + "reportErrorDescription": "😭 Aduh. Ada yang salah. Jika kamu mau, kamu bisa melaporkan kutu ini kepada para pengembang.", + "signInWithPassword": "Masuk dengan kata sandi", + "pleaseTryAgainLaterOrChooseDifferentServer": "Silakan coba lagi nanti atau pilih server yang lain.", + "signInWith": "Masuk dengan {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Bukan berkas gambar.", + "importNow": "Impor sekarang", + "importFromZipFile": "Impor dari berkas .zip", + "exportEmotePack": "Ekspor paket Emote sebagai .zip", + "replace": "Ganti", + "importEmojis": "Impor Emoji", + "sendTypingNotifications": "Kirim notifikasi pengetikan", + "createGroup": "Buat grup", + "inviteContactToGroupQuestion": "Apakah kamu ingin mengundang {contact} ke obrolan \"{groupName}\"?", + "tryAgain": "Coba ulang", + "messagesStyle": "Pesan:", + "shareInviteLink": "Bagikan tautan undangan", + "setTheme": "Atur tema:", + "invalidServerName": "Nama server tidak valid", + "addChatDescription": "Tambahkan deskripsi obrolan...", + "chatPermissions": "Perizinan obrolan", + "chatDescription": "Deskripsi obrolan", + "chatDescriptionHasBeenChanged": "Deskripsi obrolan diubah", + "noChatDescriptionYet": "Deskripsi obrolan belum dibuat.", + "redactMessageDescription": "Pesan akan dihilangkan untuk semua anggota dalam percakapan ini. Ini tidak dapat diurungkan.", + "optionalRedactReason": "(Opsional) Alasan menghilangkan pesan ini...", + "redactedBy": "Dihilangkan oleh {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Chat langsung", + "redactedByBecause": "Dihilangkan oleh {username} karena: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "setChatDescription": "Lihat deskripsi obrolan", + "profileNotFound": "Pengguna ini tidak dapat ditemukan di server. Mungkin ada masalah koneksi atau penggunanya tidak ada.", + "setColorTheme": "Atur tema warna:", + "invite": "Undang", + "inviteGroupChat": "📨 Undangan percakapan grup", + "invitePrivateChat": "📨 Undangan percakapan privat", + "emoteKeyboardNoRecents": "Emote yang telah digunakan akan muncul di sini...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "invalidInput": "Masukan tidak valid!", + "wrongPinEntered": "PIN yang dimasukkan salah! Coba lagi dalam {seconds} detik...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "banUserDescription": "Pengguna akan dicekal dari percakapan dan tidak akan dapat memasuki percakapan lagi sampai dibatalkan cekalannya.", + "removeDevicesDescription": "Kamu akan dikeluarkan dari perangkat ini dan tidak akan dapat menerima pesan lagi.", + "unbanUserDescription": "Pengguna akan dapat memasuki percakapannya lagi jika dicoba.", + "pushNotificationsNotAvailable": "Notifikasi dorongan tidak tersedia", + "makeAdminDescription": "Setelah kamu membuat pengguna ini admin, kamu tidak akan dapat mengurungkan ini karena penggunanya akan memiliki perizinan yang sama seperti kamu.", + "archiveRoomDescription": "Percakapan akan dipindahkan ke arsip. Pengguna lain akan melihat bahwa kamu telah meninggalkan percakapan.", + "hasKnocked": "🚪 {user} telah dikeluarkan", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "learnMore": "Pelajari lebih lanjut", + "roomUpgradeDescription": "Percakapannya akan dibuat ulang dengan versi ruangan yang baru. Semua anggota akan diberi tahu bahwa mereka harus ganti ke percakapan yang baru. Kamu bisa mempelajari lebih lanjut tentang versi ruangan di https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Silakan masukkan angka lebih dari 0", + "kickUserDescription": "Pengguna ini dikeluarkan dari percakapan tetapi tidak dicekal. Dalam percakapan publik, penggunanya dapat bergabung ulang kapan pun.", + "groupCanBeFoundViaSearch": "Grup dapat dicari melalui pencarian", + "groupName": "Nama grup", + "wrongRecoveryKey": "Maaf... ini sepertinya bukan kunci pemulihan yang benar.", + "addChatOrSubSpace": "Tambahkan percakapan atau subspace", + "pleaseChooseAStrongPassword": "Silakan pilih kata sandi yang kuat", + "joinSpace": "Bergabung ke space", + "acceptedKeyVerification": "{sender} menerima verifikasi kunci", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} membatalkan verifikasi kunci", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} siap untuk verifikasi kunci", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "verifyOtherDevice": "🔐 Verifikasi perangkat lain", + "requestedKeyVerification": "{sender} meminta verifikasi kunci", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} memulai verifikasi kunci", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "formattedMessagesDescription": "Tampilkan konten pesan kaya seperti teks tebal menggunakan Markdown.", + "noUsersFoundWithQuery": "Sayangnya tidak ada pengguna yang dapat ditemukan dengan \"{query}\". Silakan periksa jika ada tipo.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "databaseBuildErrorBody": "Tidak dapat membangun basis data SQLite. Aplikasi mencoba menggunakan basis data lawas untuk sekarang. Silakan laporkan kesalahan ini kepada pengembang di {url}. Pesan kesalahannya adalah: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "passwordIsWrong": "Kata sandi yang kamu masukkan salah", + "searchChatsRooms": "Cari #percakapan, @pengguna...", + "createGroupAndInviteUsers": "Buat sebuah grup dan undang pengguna", + "pleaseEnterYourCurrentPassword": "Silakan masukkan kata sandimu saat ini", + "passwordsDoNotMatch": "Kata sandi tidak cocok", + "publicLink": "Tautan publik", + "sendTypingNotificationsDescription": "Anggota lain dalam percakapan dapat melihat ketika kamu sedang mengetik sebuah pesan baru.", + "forwardMessageTo": "Teruskan pesan ke {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Kirim laporan dibaca", + "formattedMessages": "Pesan yang diformat", + "verifyOtherUser": "🔐 Verifikasi pengguna lain", + "sessionLostBody": "Sesimu hilang. Silakan laporkan kesalahan ini kepada pengembang di {url}. Pesan kesalahannya adalah: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Aplikasi sekarang mencoba memulihkan sesimu dari cadangan. Silakan laporkan kesalahan ini kepada pengembang di {url}. Pesan kesalahannya adalah: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "presenceStyle": "Presensi:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Tampilkan pesan status dari pengguna lain", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "youInvitedToBy": "📩 Kamu telah diundang melalui surel ke:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "publicSpaces": "Space publik", + "commandHint_sendraw": "Kirim JSON mentah", + "sendReadReceiptsDescription": "Anggota lain dalam percakapan dapat melihat ketika kamu membaca sebuah pesan.", + "block": "Blokir", + "blockedUsers": "Pengguna yang terblokir", + "blockListDescription": "Kamu bisa memblokir pengguna yang sedang menganggumu. Kamu tidak akan mendapatkan pesan atau undangan ruangan dari pengguna dalam daftar blokiran pribadimu.", + "blockUsername": "Abaikan nama pengguna", + "hidePresences": "Sembunyikan Daftar Status?", + "transparent": "Transparan", + "stickers": "Stiker", + "discover": "Jelajahi", + "startConversation": "Mulai percakapan", + "yourGlobalUserIdIs": "ID pengguna globalmu adalah: ", + "select": "Pilih", + "subspace": "Subspace", + "decline": "Tolak", + "nothingFound": "Tidak ada yang ditemukan...", + "thisDevice": "Perangkat ini:", + "newPassword": "Kata sandi baru", + "incomingMessages": "Pesan masuk", + "databaseMigrationTitle": "Basis data sudah dioptimalkan", + "searchForUsers": "Cari @pengguna...", + "completedKeyVerification": "{sender} menyelesaikan verifikasi kunci", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "databaseMigrationBody": "Silakan tunggu. Ini dapat membutuhkan beberapa waktu.", + "leaveEmptyToClearStatus": "Tinggalkan kosong untuk menghapus statusmu.", + "initAppError": "Terjadi kesalahan saat init aplikasi", + "verifyOtherDeviceDescription": "Saat kamu memverifikasi perangkat lain, perangkat tersebut dapat bertukar kunci, sehingga meningkatkan keamananmu secara keseluruhan. 💪 Saat Anda memulai verifikasi, sebuah pemberitahuan akan muncul di aplikasi pada kedua perangkat. Di situ kemudian akan melihat serangkaian emoji atau angka yang harus dibandingkan satu sama lain. Sebaiknya siapkan kedua perangkat sebelum kamu memulai verifikasi. 🤳", + "verifyOtherUserDescription": "Jika kamu memverifikasi pengguna lain, kamu bisa yakin bahwa kamu tahu kepada siapa sebenarnya kamu menulis pesan kepadanya. 💪\n\nSaat kamu memulai verifikasi, kamu dan pengguna lain akan melihat pemberitahuan di aplikasi. Di sana kemudian akan melihat serangkaian emoji atau angka yang harus dibandingkan satu sama lain.\n\nCara terbaik untuk melakukannya adalah dengan bertemu secara langsung atau memulai panggilan video. 👭", + "commandHint_ignore": "Abaikan ID Matrix yang diberikan", + "commandHint_unignore": "Batalkan pengabaian ID Matrix yang diberikan", + "unreadChatsInApp": "{appname}: {unread} obrolan belum dibaca", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Enkripsi basis data tidak didukung di platform ini", + "customEmojisAndStickersBody": "Tambakan atau bagikan emoji atau stiker kustom yang dapat digunakan dalam obrolan apa pun.", + "hideRedactedMessages": "Sembunyikan pesan yang dihapus", + "appLockDescription": "Kunci aplikasi ketika tidak digunakan dengan kode PIN", + "accessAndVisibility": "Akses dan keterlihatan", + "globalChatId": "ID obrolan global", + "accessAndVisibilityDescription": "Siapa yang diperbolehkan bergabung ke obrolan ini dan bagaimana obrolannya dapat ditemukan.", + "calls": "Panggilan", + "customEmojisAndStickers": "Emoji dan stiker kustom", + "hideRedactedMessagesBody": "Jika seseorang menghapus pesan, pesannya tidak akan terlihat lagi dalam obrolan.", + "hideMemberChangesInPublicChatsBody": "Jangan tampilkan dalam lini masa obrolan jika seseorang bergabung atau keluar dari obrolan untuk meningkatkan keterlihatan.", + "notifyMeFor": "Beri tahu aku untuk", + "hideInvalidOrUnknownMessageFormats": "Sembunyikan format pesan yang tidak valid atau tidak diketahui", + "hideMemberChangesInPublicChats": "Sembunyikan perubahan anggota dalam obrolan publik", + "overview": "Ikhtisar", + "passwordRecoverySettings": "Pengaturan pemulihan kata sandi", + "usersMustKnock": "Pengguna harus mengetuk", + "noOneCanJoin": "Tidak ada siapa pun yang dapat bergabung", + "userWouldLikeToChangeTheChat": "{user} ingin bergabung dengan obrolan.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Belum ada tautan publik yang dibuat", + "knock": "Ketuk", + "knocking": "Mengetuk", + "chatCanBeDiscoveredViaSearchOnServer": "Obrolan dapat ditemukan melalui pencarian di {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "Saat ini ada {count} pengguna yang diblokir.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "publicChatAddresses": "Alamat obrolan umum", + "createNewAddress": "Buat alamat baru", + "userRole": "Peran pengguna", + "minimumPowerLevel": "{level} adalah tingkat daya minimum.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "swipeRightToLeftToReply": "Usap dari kanan ke kiri untuk membalas", + "searchMore": "Cari lebih banyak...", + "gallery": "Galeri", + "searchIn": "Cari dalam obrolan \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "files": "Berkas", + "restricted": "Dibatasi", + "knockRestricted": "Ketukan dibatasi", + "alwaysUse24HourFormat": "tidak", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "sendCanceled": "Pengiriman dibatalkan", + "noChatsFoundHere": "Belum ada chat di sini. Mulai chat baru dengan seseorang menggunakan tombol di bawah. ⤵️", + "invitedBy": "📩 Diundang oleh {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "markAsUnread": "Tandai sebagai belum dibaca", + "goToSpace": "Pergi ke space: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "changeTheChatPermissions": "Ubah perizinan chat", + "changeTheCanonicalRoomAlias": "Ubah alamat chat publik utama", + "changeTheVisibilityOfChatHistory": "Ubah keterlihatan riwayat chat", + "changeTheDescriptionOfTheGroup": "Ubah deskripsi chat", + "sendingAttachment": "Mengirim lampiran...", + "compressVideo": "Mengompres video...", + "calculatingFileSize": "Menghitung ukuran berkas...", + "prepareSendingAttachment": "Menyiapkan pengiriman lampiran...", + "sendingAttachmentCountOfCount": "Mengirim lampiran {index} dari {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "userLevel": "{level} - Pengguna", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Admin", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Ubah pengaturan chat umum", + "discoverHomeservers": "Jelajahi homeserver", + "loginWithMatrixId": "Masuk dengan ID Matrix", + "doesNotSeemToBeAValidHomeserver": "Sepertinya bukan homeserver yang kompatibel. URL salah?", + "countChatsAndCountParticipants": "{chats} chat dan {participants} anggota", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "unread": "Tidak dibaca", + "space": "Space", + "spaces": "Space", + "joinedChats": "Bergabung chat", + "noMoreChatsFound": "Tidak ada chat lagi yang ditemukan...", + "generatingVideoThumbnail": "Membuat gambar kecil video...", + "changelog": "Catatan perubahan", + "whatIsAHomeserver": "Apa itu homeserver?", + "sendRoomNotifications": "Kirim notifikasi @room", + "updateInstalled": "🎉 Pembaruan {version} terpasang!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "inviteOtherUsers": "Undang pengguna lain ke chat ini", + "serverLimitReached": "Batasan server tercapai! Menunggu {seconds} detik...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "chatPermissionsDescription": "Tentukan tingkat kekuasaan yang diperlukan untuk tindakan tertentu dalam chat ini. Tingkat kekuasaan 0, 50 dan 100 biasanya mewakili pengguna, moderator dan admin, tetapi gradasi apa pun dimungkinkan.", + "homeserverDescription": "Semua data Anda disimpan di dalam server, seperti halnya penyedia email. Anda dapat memilih homeserver mana yang ingin Anda gunakan, sementara Anda masih dapat berkomunikasi dengan semua orang. Pelajari lebih lanjut di https://matrix.org.", + "oneOfYourDevicesIsNotVerified": "Salah satu perangkat Anda tidak terverifikasi", + "noticeChatBackupDeviceVerification": "Catatan: Ketika Anda menghubungkan semua perangkat Anda ke cadangan chat, mereka akan diverifikasi secara otomatis.", + "welcomeText": "Halo 👋 Ini FluffyChat. Kamu bisa masuk ke homeserver mana pun, yang kompatibel dengan https://matrix.org. Lalu, chat dengan siapa pun. Ini merupakan jaringan perpesanan besar yang terdesentralisasi!", + "continueText": "Lanjutkan", + "aboutHomeserver": "Tentang {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "blur": "Buram:", + "contactServerAdmin": "Hubungi admin server", + "opacity": "Opasitas:", + "setWallpaper": "Atur later belakang", + "serverInformation": "Informasi server:", + "noContactInformationProvided": "Server tidak menyediakan informasi kontak valid apa pun", + "supportPage": "Laman dukungan", + "version": "Versi", + "website": "Situs Web", + "manageAccount": "Kelola akun", + "contactServerSecurity": "Hubungi keamanan server", + "name": "Nama", + "strikeThrough": "Coret", + "pleaseFillOut": "Silakan isi", + "addLink": "Tambahkan tautan", + "invalidUrl": "URL tidak valid", + "boldText": "Teks tebal", + "italicText": "Teks miring", + "unableToJoinChat": "Tidak dapat bergabung dalam chat. Mungkin pihak lain telah menutup percakapan.", + "sendImages": "Kirim {count} gambar", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Kompres", + "contentNotificationSettings": "Pengaturan notifikasi konten", + "generalNotificationSettings": "Pengaturan notifikasi umum", + "roomNotificationSettings": "Pengaturan notifikasi ruangan", + "userSpecificNotificationSettings": "Pengaturan notifikasi spesifik pengguna", + "otherNotificationSettings": "Pengaturan notifikasi lainnya", + "notificationRuleContainsUserName": "Berisi Nama Pengguna", + "notificationRuleContainsUserNameDescription": "Memberi tahu pengguna ketika pesan memiliki nama penggunanya.", + "notificationRuleMaster": "Bisukan semua notifikasi", + "notificationRuleMasterDescription": "Menimpa peraturan lainnya dan menonaktifkan semua notifikasi.", + "notificationRuleSuppressNotices": "Dimakan Pesan Terautomasi", + "notificationRuleSuppressNoticesDescription": "Mendiamkan notifikasi dari klien terautomasi seperti bot.", + "notificationRuleInviteForMe": "Undang untuk Aku", + "notificationRuleInviteForMeDescription": "Memberi tahu pengguna ketika diundang ke ruangan.", + "notificationRuleMemberEvent": "Peristiwa Anggota", + "notificationRuleMemberEventDescription": "Mendiamkan notifikasi peristiwa keanggotaan.", + "notificationRuleIsUserMention": "Sebutan Pengguna", + "notificationRuleIsUserMentionDescription": "Memberi tahu pengguna ketika disebut secara langsung dalam pesan.", + "notificationRuleContainsDisplayName": "Berisi Nama Tampilan", + "notificationRuleIsRoomMention": "Sebutan Ruangan", + "notificationRuleIsRoomMentionDescription": "Memberi tahu pengguna ketika ada sebutan ruangan.", + "notificationRuleRoomnotif": "Notifikasi Ruangan", + "notificationRuleRoomnotifDescription": "Memberi tahu pengguna ketika pesan berisi '@room'.", + "notificationRuleTombstone": "Nisan", + "notificationRuleTombstoneDescription": "Memberi tahu pengguna tentang pesan deaktivasi ruangan.", + "notificationRuleReaction": "Reaksi", + "notificationRuleReactionDescription": "Mendiamkan notifikasi reaksi.", + "notificationRuleRoomServerAcl": "ACL Server Ruangan", + "notificationRuleRoomServerAclDescription": "Mendiamkan notifikasi daftar kontrol akses server ruangan (ACL).", + "notificationRuleSuppressEdits": "Diamkan Penyuntingan", + "notificationRuleSuppressEditsDescription": "Mendiamkan notifikasi pesan tersunting.", + "notificationRuleCall": "Panggilan", + "notificationRuleCallDescription": "Memberi tahu pengguna tentang panggilan.", + "notificationRuleEncryptedRoomOneToOne": "Ruangan Terenkripsi Satu ke Satu", + "notificationRuleEncryptedRoomOneToOneDescription": "Memberi tahu pengguna tentang pesan dalam ruangan satu ke satu.", + "notificationRuleRoomOneToOne": "Ruangan Satu ke Satu", + "notificationRuleRoomOneToOneDescription": "Memberi tahu pengguna tentang pesan dalam ruangan satu ke satu.", + "notificationRuleMessage": "Pesan", + "notificationRuleMessageDescription": "Memberi tahu pengguna tentang pesan umum.", + "notificationRuleEncrypted": "Terenkripsi", + "notificationRuleEncryptedDescription": "Memberi tahu pengguna tentang pesan dalam ruangan terenkripsi.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Memberi tahu pengguna tentang peristiwa widget Jitsi.", + "notificationRuleServerAcl": "Diamkan Peristiwa ACL Server", + "notificationRuleServerAclDescription": "Mendiamkan notifikasi peristiwa ACL server.", + "unknownPushRule": "Aturan dorongan '{rule}' tidak diketahui", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Jika kamu menghapus pengaturan notifikasi ini, maka tidak dapat diurungkan.", + "more": "Tambahan", + "newChatRequest": "📩 Permintaan pesan baru", + "allDevices": "Semua perangkat", + "crossVerifiedDevices": "Perangkat terverifikasi silang", + "waitingForServer": "Menunggu server...", + "appIntroduction": "FluffyChat memungkinkanmu untuk mengobrol dengan teman-temanmu di berbagai perpesanan. Pelajari lebih lanjut di https://matrix.org atau ketuk *Lanjutkan* saja.", + "notificationRuleContainsDisplayNameDescription": "Memberi tahu pengguna ketika pesan berisi nama tampilannya.", + "shareKeysWith": "Bagikan kunci dengan...", + "synchronizingPleaseWaitCounter": " Sinkronisasi… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "shareKeysWithDescription": "Perangkat apa saja yang dipercayai supaya mereka bisa membaca bersama dengan pesanmu dalam obrolan terenkripsi?", + "verifiedDevicesOnly": "Perangkat terverifikasi saja", + "crossVerifiedDevicesIfEnabled": "Verifikasi silang perangkat jika diaktifkan", + "previous": "Sebelumnya", + "otherPartyNotLoggedIn": "Pihak lain belum masuk dan tidak dapat menerima pesan!", + "appWantsToUseForLogin": "Gunakan '{server}' untuk masuk", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Anda memperbolehkan aplikasi dan situs web membagikan informasi tentang Anda.", + "open": "Buka", + "takeAPhoto": "Ambil foto", + "recordAVideo": "Rekam video", + "optionalMessage": "Pesan (opsional)...", + "notSupportedOnThisDevice": "Tidak didukung pada perangkat ini", + "enterNewChat": "Masuk ke obrolan baru", + "commandHint_roomupgrade": "Tingkatkan ruangan ini ke versi ruangan yang ditentukan", + "pleaseWaitUntilInvited": "Silakan menunggu sampai seseorang dari ruangan mengundang Anda.", + "setCustomPermissionLevel": "Atur tingkat perizinan kustom", + "setPermissionsLevelDescription": "Silakan pilih peran yang sudah ditentukan di bawah atau masukkan tingkat perizinan kustom antara 0 dan 100.", + "ignoreUser": "Abaikan pengguna", + "normalUser": "Pengguna biasa", + "approve": "Terima", + "youHaveKnocked": "Anda telah mengetuk", + "sentVoiceMessage": "🎙️ {duration} - Pesan suara dari {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "checkList": "Ceklis", + "countInvited": "{count} diundang", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "commandHint_logout": "Keluar dari perangkatmu saat ini", + "commandHint_logoutall": "Keluarkan semua perangkat aktif", + "displayNavigationRail": "Tampilkan jalur navigasi pada ponsel", + "customReaction": "Reaksi khusus", + "moreEvents": "Peristiwa tambahan", + "declineInvitation": "Tolak undangan", + "noMessagesYet": "Belum ada pesan", + "longPressToRecordVoiceMessage": "Tekan lama untuk merekam pesan suara.", + "pause": "Jeda", + "resume": "Lanjut", + "changedTheChatDescription": "{username} mengubah deskripsi obrolan", + "changedTheChatName": "{username} mengubah nama obrolan", + "newSubSpace": "Sub space baru", + "moveToDifferentSpace": "Pindahkan ke space berbeda", + "moveUp": "Pindah ke atas", + "moveDown": "Pindah ke bawah", + "removeFromSpaceDescription": "Obrolan akan dihapus dari space tetapi masih muncul di daftar obrolan Anda.", + "countChats": "{chats} obrolan", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Anggota space dari {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Anggota space dari {spaces} dapat mengetuk", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Donasi", + "startedAPoll": "{username} memulai polling.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Polling", + "startPoll": "Mulai polling", + "endPoll": "Akhiri polling", + "answersVisible": "Jawaban terlihat", + "answersHidden": "Jawaban tersembunyi", + "pollQuestion": "Pertanyaan polling", + "answerOption": "Opsi jawaban", + "addAnswerOption": "Tambah opsi jawaban", + "allowMultipleAnswers": "Izinkan beberapa jawaban", + "pollHasBeenEnded": "Polling telah diakhiri", + "countVotes": "{count, plural, =1{Satu suara} other{{count} suara}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Jawaban akan terlihat saat polling telah diakhiri", + "replyInThread": "Balas dalam thread", + "countReplies": "{count, plural, =1{Satu balasan} other{{count} balasan}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Thread", + "backToMainChat": "Kembali ke obrolan utama", + "saveChanges": "Simpan perubahan", + "createSticker": "Buat stiker atau emoji", + "useAsSticker": "Gunakan sebagai stiker", + "useAsEmoji": "Gunakan sebagai emoji", + "stickerPackNameAlreadyExists": "Nama paket stiker sudah ada", + "newStickerPack": "Paket stiker baru", + "stickerPackName": "Nama paket stiker", + "attribution": "Atribusi", + "skipChatBackup": "Lewati cadangan obrolan", + "skipChatBackupWarning": "Anda yakin? Tanpa mengaktifkan cadangan obrolan, Anda mungkin kehilangan akses ke pesan Anda jika Anda mengganti perangkat.", + "loadingMessages": "Memuat pesan", + "setupChatBackup": "Siapkan cadangan obrolan", + "noMoreResultsFound": "Tidak ada hasil lagi yang ditemukan", + "chatSearchedUntil": "Obrolan dicari hingga {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "URL Dasar Federasi", + "clientWellKnownInformation": "Informasi Client-Well-Known:", + "baseUrl": "URL Dasar", + "identityServer": "Server Identitas:", + "versionWithNumber": "Versi: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Log", + "advancedConfigs": "Konfigurasi Lanjutan", + "advancedConfigurations": "Konfigurasi lanjutan", + "signIn": "Masuk", + "createNewAccount": "Buat akun baru", + "signUpGreeting": "FluffyChat terdesentralisasi! Pilih server tempat Anda ingin membuat akun dan mari kita mulai!", + "signInGreeting": "Anda sudah memiliki akun di Matrix? Selamat datang kembali! Pilih homeserver Anda dan masuk.", + "appIntro": "Dengan FluffyChat Anda dapat mengobrol dengan teman-teman Anda. Ini adalah messenger [matrix] terdesentralisasi yang aman! Pelajari lebih lanjut di https://matrix.org jika Anda suka atau cukup daftar.", + "theProcessWasCanceled": "Proses dibatalkan." +} diff --git a/assets/l10n/intl_nb.arb b/lib/l10n/intl_ie.arb similarity index 50% rename from assets/l10n/intl_nb.arb rename to lib/l10n/intl_ie.arb index 660517c76..20258f7cb 100644 --- a/assets/l10n/intl_nb.arb +++ b/lib/l10n/intl_ie.arb @@ -1,2184 +1,2346 @@ { - "@@last_modified": "2021-08-14 12:41:09.967351", - "about": "Om", - "@about": { - "type": "text", + "group": "Gruppe", + "@group": { + "type": "String", "placeholders": {} }, - "accept": "Godta", - "@accept": { - "type": "text", + "identity": "Identitá", + "@identity": { + "type": "String", "placeholders": {} }, - "acceptedTheInvitation": "{username} godtok invitasjonen", - "@acceptedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "account": "Konto", - "@account": { - "type": "text", + "close": "Cluder", + "@close": { + "type": "String", "placeholders": {} }, - "activatedEndToEndEncryption": "{username} skrudde på ende-til-ende -kryptering", - "@activatedEndToEndEncryption": { - "type": "text", - "placeholders": { - "username": {} - } + "confirm": "Confirmar", + "@confirm": { + "type": "String", + "placeholders": {} }, "admin": "Administrator", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, - "alias": "alias", - "@alias": { - "type": "text", + "chats": "Conversationes", + "@chats": { + "type": "String", "placeholders": {} }, - "all": "Alle", - "@all": { - "type": "text", - "placeholders": {} - }, - "answeredTheCall": "{senderName} besvarte anropet", - "@answeredTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "anyoneCanJoin": "Hvem som helst kan delta", - "@anyoneCanJoin": { - "type": "text", - "placeholders": {} - }, - "appLock": "Programlås", - "@appLock": { - "type": "text", - "placeholders": {} - }, - "archive": "Arkiv", - "@archive": { - "type": "text", - "placeholders": {} - }, - "areGuestsAllowedToJoin": "Skal gjester tillates å ta del", - "@areGuestsAllowedToJoin": { - "type": "text", - "placeholders": {} - }, - "areYouSure": "Er du sikker?", - "@areYouSure": { - "type": "text", - "placeholders": {} - }, - "areYouSureYouWantToLogout": "Er du sikker på at du vil logge ut?", - "@areYouSureYouWantToLogout": { - "type": "text", - "placeholders": {} - }, - "askSSSSSign": "For å kunne signere den andre personen, skriv inn ditt sikre lagerpassord eller gjenopprettingsnøkkel.", - "@askSSSSSign": { - "type": "text", - "placeholders": {} - }, - "askVerificationRequest": "Godta denne bekreftelsesforespørselen fra {username}?", - "@askVerificationRequest": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "banFromChat": "Bannlys fra sludring", - "@banFromChat": { - "type": "text", - "placeholders": {} - }, - "banned": "Bannlyst", - "@banned": { - "type": "text", - "placeholders": {} - }, - "bannedUser": "{username} bannlyste {targetName}", - "@bannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "blockDevice": "Blokker enhet", - "@blockDevice": { - "type": "text", - "placeholders": {} - }, - "botMessages": "Bot-meldinger", - "@botMessages": { - "type": "text", - "placeholders": {} - }, - "cancel": "Avbryt", - "@cancel": { - "type": "text", - "placeholders": {} - }, - "changeDeviceName": "Endre enhetsnavn", - "@changeDeviceName": { - "type": "text", - "placeholders": {} - }, - "changedTheChatAvatar": "{username} endret sludreavatar", - "@changedTheChatAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheChatDescriptionTo": "{username} endret sludrebeskrivelse til: «{description}»", - "@changedTheChatDescriptionTo": { - "type": "text", - "placeholders": { - "username": {}, - "description": {} - } - }, - "changedTheChatNameTo": "{username} endret sludringsnavn til: «{chatname}»", - "@changedTheChatNameTo": { - "type": "text", - "placeholders": { - "username": {}, - "chatname": {} - } - }, - "changedTheChatPermissions": "{username} endret sludretilgangene", - "@changedTheChatPermissions": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheDisplaynameTo": "{username} endret visningsnavn til: {displayname}", - "@changedTheDisplaynameTo": { - "type": "text", - "placeholders": { - "username": {}, - "displayname": {} - } - }, - "changedTheGuestAccessRules": "{username} endret gjestetilgangsreglene", - "@changedTheGuestAccessRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheGuestAccessRulesTo": "{username} endret gjestetilgangsregler til: {rules}", - "@changedTheGuestAccessRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheHistoryVisibility": "{username} endret historikksynlighet", - "@changedTheHistoryVisibility": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheHistoryVisibilityTo": "{username} endret historikksynlighet til: {rules}", - "@changedTheHistoryVisibilityTo": { - "type": "text", - "placeholders": { - "username": {}, - "rules": {} - } - }, - "changedTheJoinRules": "{username} endret tilgangsreglene", - "@changedTheJoinRules": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheJoinRulesTo": "{username} endret tilgangsreglene til: {joinRules}", - "@changedTheJoinRulesTo": { - "type": "text", - "placeholders": { - "username": {}, - "joinRules": {} - } - }, - "changedTheProfileAvatar": "{username} endret avataren sin", - "@changedTheProfileAvatar": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomAliases": "{username} endret rom-aliasene", - "@changedTheRoomAliases": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changedTheRoomInvitationLink": "{username} endret invitasjonslenken", - "@changedTheRoomInvitationLink": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "changePassword": "Endre passord", - "@changePassword": { - "type": "text", - "placeholders": {} - }, - "changeTheHomeserver": "Endre hjemmetjener", - "@changeTheHomeserver": { - "type": "text", - "placeholders": {} - }, - "changeTheme": "Endre din stil", - "@changeTheme": { - "type": "text", - "placeholders": {} - }, - "changeTheNameOfTheGroup": "Endre gruppens navn", - "@changeTheNameOfTheGroup": { - "type": "text", - "placeholders": {} - }, - "channelCorruptedDecryptError": "Krypteringen er skadet", - "@channelCorruptedDecryptError": { - "type": "text", - "placeholders": {} - }, - "chat": "Sludring", - "@chat": { - "type": "text", - "placeholders": {} - }, - "chatBackup": "Sludringssikkerhetskopi", - "@chatBackup": { - "type": "text", - "placeholders": {} - }, - "chatBackupDescription": "Din sludringssikkerhetskopi er sikret med en sikkerhetsnøkkel. Ikke mist den.", - "@chatBackupDescription": { - "type": "text", - "placeholders": {} - }, - "chatDetails": "Sludringsdetaljer", - "@chatDetails": { - "type": "text", - "placeholders": {} - }, - "chooseAStrongPassword": "Velg et sterkt passord", - "@chooseAStrongPassword": { - "type": "text", - "placeholders": {} - }, - "close": "Lukk", - "@close": { - "type": "text", - "placeholders": {} - }, - "compareEmojiMatch": "Sammenlign og forsikre at følgende smilefjes samsvarer med de på den andre enheten:", - "@compareEmojiMatch": { - "type": "text", - "placeholders": {} - }, - "compareNumbersMatch": "Sammenlign og forsikre at følgende tall samsvarer med de på den andre enheten:", - "@compareNumbersMatch": { - "type": "text", - "placeholders": {} - }, - "configureChat": "Sett opp sludring", - "@configureChat": { - "type": "text", - "placeholders": {} - }, - "confirm": "Bekreft", - "@confirm": { - "type": "text", - "placeholders": {} - }, - "connect": "Koble til", - "@connect": { - "type": "text", - "placeholders": {} - }, - "contactHasBeenInvitedToTheGroup": "Kontakt invitert til gruppen", - "@contactHasBeenInvitedToTheGroup": { - "type": "text", - "placeholders": {} - }, - "containsDisplayName": "Inneholder visningsnavn", - "@containsDisplayName": { - "type": "text", - "placeholders": {} - }, - "containsUserName": "Inneholder brukernavn", + "containsUserName": "Contene li nómine", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, - "contentHasBeenReported": "Innholdet har blitt rapportert til tjeneradministratorene", - "@contentHasBeenReported": { - "type": "text", + "containsDisplayName": "Contene li visibil nómine", + "@containsDisplayName": { + "type": "String", "placeholders": {} }, - "copiedToClipboard": "Kopiert til utklippstavle", + "copiedToClipboard": "Copiat al Paperiere", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, - "copy": "Kopier", - "@copy": { - "type": "text", - "placeholders": {} - }, - "copyToClipboard": "Kopier til utklippstavle", + "copyToClipboard": "Copiar al Paperiere", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, - "couldNotDecryptMessage": "Kunne ikke dekryptere melding: {error}", - "@couldNotDecryptMessage": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "countParticipants": "{count} deltagere", + "countParticipants": "{count} participantes", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, - "create": "Opprett", - "@create": { - "type": "text", + "createNewSpace": "Crear un spacie", + "@createNewSpace": { + "type": "String", "placeholders": {} }, - "createdTheChat": "{username} opprettet sludringen", - "@createdTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "currentlyActive": "Aktiv nå", + "currentlyActive": "Activ actualmen", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, - "darkTheme": "Mørk", - "@darkTheme": { - "type": "text", - "placeholders": {} - }, - "dateAndTimeOfDay": "{timeOfDay}, {date}", + "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, - "dateWithoutYear": "{day} {month}", - "@dateWithoutYear": { - "type": "text", - "placeholders": { - "month": {}, - "day": {} - } - }, - "dateWithYear": "{day} {month} {year}", - "@dateWithYear": { - "type": "text", - "placeholders": { - "year": {}, - "month": {}, - "day": {} - } - }, - "deactivateAccountWarning": "Dette vil skru av din brukerkonto for godt, og kan ikke angres! Er du sikker?", - "@deactivateAccountWarning": { - "type": "text", - "placeholders": {} - }, - "defaultPermissionLevel": "Forvalgt tilgangsnivå", - "@defaultPermissionLevel": { - "type": "text", - "placeholders": {} - }, - "delete": "Slett", - "@delete": { - "type": "text", - "placeholders": {} - }, - "deleteAccount": "Slett konto", + "deleteAccount": "Destructer li conto", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, - "deleteMessage": "Slett melding", + "deleteMessage": "Remover li missage", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, - "device": "Enhet", - "@device": { - "type": "text", - "placeholders": {} - }, - "deviceId": "Enhets-ID", - "@deviceId": { - "type": "text", - "placeholders": {} - }, - "devices": "Enheter", - "@devices": { - "type": "text", - "placeholders": {} - }, - "directChats": "Direktesludringer", - "@directChats": { - "type": "text", - "placeholders": {} - }, - "displaynameHasBeenChanged": "Visningsnavn endret", - "@displaynameHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "downloadFile": "Last ned fil", - "@downloadFile": { - "type": "text", - "placeholders": {} - }, - "edit": "Rediger", - "@edit": { - "type": "text", - "placeholders": {} - }, - "editBlockedServers": "Rediger blokkerte tjenere", + "editBlockedServers": "Modificar blocat servitores", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, - "editDisplayname": "Rediger visningsnavn", - "@editDisplayname": { - "type": "text", - "placeholders": {} - }, - "editRoomAvatar": "Rediger romavatar", - "@editRoomAvatar": { - "type": "text", - "placeholders": {} - }, - "emoteExists": "Smilefjeset finnes allerede!", - "@emoteExists": { - "type": "text", - "placeholders": {} - }, - "emoteInvalid": "Ugyldig smilefjes-kode!", - "@emoteInvalid": { - "type": "text", - "placeholders": {} - }, - "emotePacks": "Smilefjespakker for rommet", - "@emotePacks": { - "type": "text", - "placeholders": {} - }, - "emoteSettings": "Smilefjes-innstillinger", - "@emoteSettings": { - "type": "text", - "placeholders": {} - }, - "emoteShortcode": "Smilefjes-kode", - "@emoteShortcode": { - "type": "text", - "placeholders": {} - }, - "emoteWarnNeedToPick": "Du må velge en smilefjes-kode og et bilde!", - "@emoteWarnNeedToPick": { - "type": "text", - "placeholders": {} - }, - "emptyChat": "Tom sludring", - "@emptyChat": { - "type": "text", - "placeholders": {} - }, - "enableEmotesGlobally": "Skru på smilefjespakke for hele programmet", - "@enableEmotesGlobally": { - "type": "text", - "placeholders": {} - }, - "enableEncryption": "Skru på kryptering", - "@enableEncryption": { - "type": "text", - "placeholders": {} - }, - "enableEncryptionWarning": "Du vil ikke kunne skru av kryptering lenger. Er du sikker?", - "@enableEncryptionWarning": { - "type": "text", - "placeholders": {} - }, - "encrypted": "Kryptert", - "@encrypted": { - "type": "text", - "placeholders": {} - }, - "encryption": "Kryptering", - "@encryption": { - "type": "text", - "placeholders": {} - }, - "encryptionNotEnabled": "Kryptering er ikke påskrudd", - "@encryptionNotEnabled": { - "type": "text", - "placeholders": {} - }, - "endedTheCall": "{senderName} avsluttet samtalen", - "@endedTheCall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "enterAnEmailAddress": "Skriv inn en e-postadresse", - "@enterAnEmailAddress": { - "type": "text", - "placeholders": {} - }, - "enterYourHomeserver": "Skriv inn din hjemmetjener", - "@enterYourHomeserver": { - "type": "text", - "placeholders": {} - }, - "everythingReady": "Alt er klart!", + "everythingReady": "Omni es pret!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, - "extremeOffensive": "Veldig", + "extremeOffensive": "Extremmen offensiv", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, - "fileName": "Filnavn", + "fileName": "Nómine de file", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, - "fluffychat": "FluffyChat", - "@fluffychat": { - "type": "text", - "placeholders": {} - }, - "fontSize": "Skriftstørrelse", + "fontSize": "Dimension de fonde", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, - "forward": "Videre", - "@forward": { - "type": "text", - "placeholders": {} - }, - "fromJoining": "Fra å ta del", + "fromJoining": "Pro adhesion", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, - "fromTheInvitation": "Fra invitasjonen", + "enterYourHomeserver": "Provide vor hem-servitor", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Pro invitation", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, - "group": "Gruppe", - "@group": { - "type": "text", - "placeholders": {} - }, - "groupIsPublic": "Gruppen er offentlig", + "groupIsPublic": "Gruppe es public", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, - "groups": "Grupper", - "@groups": { - "type": "text", - "placeholders": {} - }, - "groupWith": "Gruppe med {displayname}", - "@groupWith": { - "type": "text", - "placeholders": { - "displayname": {} - } - }, - "guestsAreForbidden": "Gjester forbudt", - "@guestsAreForbidden": { - "type": "text", - "placeholders": {} - }, - "guestsCanJoin": "Gjester kan ta del", - "@guestsCanJoin": { - "type": "text", - "placeholders": {} - }, - "hasWithdrawnTheInvitationFor": "{username} har trukket tilbake invitasjonen til {targetName}", - "@hasWithdrawnTheInvitationFor": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "help": "Hjelp", + "help": "Auxilie", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, - "hideRedactedEvents": "Skjul tilbaketrukne hendelser", - "@hideRedactedEvents": { - "type": "text", - "placeholders": {} - }, - "hideUnknownEvents": "Skjul ukjente hendelser", + "hideUnknownEvents": "Celar ínconosset evenimentes", "@hideUnknownEvents": { - "type": "text", - "placeholders": {} - }, - "howOffensiveIsThisContent": "Hvor støtende er innholdet?", - "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "ID", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, - "identity": "Identitet", - "@identity": { - "type": "text", - "placeholders": {} - }, - "ignore": "Ignorer", - "@ignore": { - "type": "text", - "placeholders": {} - }, - "ignoredUsers": "Ignorerte brukere", + "ignoredUsers": "Ignorat usatores", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, - "iHaveClickedOnLink": "Jeg har klikket på lenken", - "@iHaveClickedOnLink": { - "type": "text", - "placeholders": {} - }, - "incorrectPassphraseOrKey": "Feilaktig passord eller gjenopprettingsnøkkel", - "@incorrectPassphraseOrKey": { - "type": "text", - "placeholders": {} - }, - "inoffensive": "Harmløst", - "@inoffensive": { - "type": "text", - "placeholders": {} - }, - "inviteContact": "Inviter kontakt", - "@inviteContact": { - "type": "text", - "placeholders": {} - }, - "inviteContactToGroup": "Inviter kontakt til {groupName}", - "@inviteContactToGroup": { - "type": "text", - "placeholders": { - "groupName": {} - } - }, - "invited": "Invitert", - "@invited": { - "type": "text", - "placeholders": {} - }, - "invitedUser": "{username} inviterte {targetName}", - "@invitedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "invitedUsersOnly": "Kun inviterte brukere", + "invitedUsersOnly": "Solmen invitat usatores", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, - "inviteForMe": "Invitasjon for meg", - "@inviteForMe": { - "type": "text", - "placeholders": {} - }, - "inviteText": "{username} har invitert deg til FluffyChat. \n1. Installer FluffyChat: https://fluffychat.im \n2. Registrer deg eller logg inn \n3. Åpne invitasjonslenken: {link}", - "@inviteText": { - "type": "text", - "placeholders": { - "username": {}, - "link": {} - } - }, - "isTyping": "skriver…", - "@isTyping": { - "type": "text", - "placeholders": {} - }, - "joinedTheChat": "{username}ble med i samtalen", - "@joinedTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "joinRoom": "Ta del i rom", - "@joinRoom": { - "type": "text", - "placeholders": {} - }, - "kicked": "{username} kastet ut {targetName}", - "@kicked": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickedAndBanned": "{username} kastet ut og bannlyste {targetName}", - "@kickedAndBanned": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "kickFromChat": "Kast ut av sludringen", - "@kickFromChat": { - "type": "text", - "placeholders": {} - }, - "lastActiveAgo": "Sist aktiv: {localizedTimeShort}", - "@lastActiveAgo": { - "type": "text", - "placeholders": { - "localizedTimeShort": {} - } - }, - "leave": "Forlat", - "@leave": { - "type": "text", - "placeholders": {} - }, - "leftTheChat": "Forlat sludringen", - "@leftTheChat": { - "type": "text", - "placeholders": {} - }, - "license": "Lisens", - "@license": { - "type": "text", - "placeholders": {} - }, - "lightTheme": "Lys", - "@lightTheme": { - "type": "text", - "placeholders": {} - }, - "loadCountMoreParticipants": "Last inn {count} deltagere til", - "@loadCountMoreParticipants": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "loadingPleaseWait": "Laster inn… Vent.", - "@loadingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "loadMore": "Last inn mer…", - "@loadMore": { - "type": "text", - "placeholders": {} - }, - "login": "Logg inn", + "login": "Aperter li session", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, - "logInTo": "Logg inn på {homeserver}", - "@logInTo": { - "type": "text", + "isTyping": "tippa…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "Adherer al chambre", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Cargar plu…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Invitationes por me", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Ultim activité: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", "placeholders": { - "homeserver": {} + "localizedTimeShort": { + "type": "String" + } } }, - "logout": "Logg ut", - "@logout": { - "type": "text", - "placeholders": {} - }, - "memberChanges": "Medlemsendringer", - "@memberChanges": { - "type": "text", - "placeholders": {} - }, - "mention": "Nevn", + "mention": "Mentionar", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, - "messages": "Meldinger", - "@messages": { - "type": "text", - "placeholders": {} - }, - "moderator": "Moderator", - "@moderator": { - "type": "text", - "placeholders": {} - }, - "muteChat": "Forstum sludring", - "@muteChat": { - "type": "text", - "placeholders": {} - }, - "needPantalaimonWarning": "Merk at du trenger Pantalaimon for å bruke ende-til-ende -kryptering inntil videre.", - "@needPantalaimonWarning": { - "type": "text", - "placeholders": {} - }, - "newChat": "Ny sludring", - "@newChat": { - "type": "text", - "placeholders": {} - }, - "newMessageInFluffyChat": "Ny melding i FluffyChat", - "@newMessageInFluffyChat": { - "type": "text", - "placeholders": {} - }, - "newVerificationRequest": "Ny bekreftelsesforespørsel!", - "@newVerificationRequest": { - "type": "text", - "placeholders": {} - }, - "next": "Neste", + "next": "Sequent", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, - "no": "Nei", + "no": "No", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, - "noEmotesFound": "Fant ingen smilefjes. 😕", - "@noEmotesFound": { - "type": "text", - "placeholders": {} - }, - "noGoogleServicesWarning": "Bruk https://microg.org/ for å få Google-tjenester (uten at det går ut over personvernet) for å få push-merknader i FluffyChat:", - "@noGoogleServicesWarning": { - "type": "text", - "placeholders": {} - }, - "none": "Ingen", - "@none": { - "type": "text", - "placeholders": {} - }, - "noPasswordRecoveryDescription": "Du har ikke lagt til en måte å gjenopprette passordet ditt på.", - "@noPasswordRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "noPermission": "Ingen tilgang", - "@noPermission": { - "type": "text", - "placeholders": {} - }, - "noRoomsFound": "Fant ingen rom …", - "@noRoomsFound": { - "type": "text", - "placeholders": {} - }, - "notifications": "Merknader", - "@notifications": { - "type": "text", - "placeholders": {} - }, - "notificationsEnabledForThisAccount": "Merknader påslått for denne kontoen", - "@notificationsEnabledForThisAccount": { - "type": "text", - "placeholders": {} - }, - "numUsersTyping": "{count} brukere skriver …", - "@numUsersTyping": { - "type": "text", - "placeholders": { - "count": {} - } - }, - "offensive": "Støtende", + "offensive": "Offensiv", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, - "offline": "Frakoblet", + "offline": "For del rete", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "ok": "OK", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, - "online": "Pålogget", + "online": "In li rete", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, - "onlineKeyBackupEnabled": "Nettbasert sikkerhetskopiering av nøkler på", - "@onlineKeyBackupEnabled": { - "type": "text", + "memberChanges": "Cambios inter membres", + "@memberChanges": { + "type": "String", "placeholders": {} }, - "oopsSomethingWentWrong": "Oida, noe gikk galt …", - "@oopsSomethingWentWrong": { - "type": "text", + "muteChat": "Assurdar li conversation", + "@muteChat": { + "type": "String", "placeholders": {} }, - "openAppToReadMessages": "Åpne programmet for å lese meldinger", - "@openAppToReadMessages": { - "type": "text", + "newChat": "Crear un conversation", + "@newChat": { + "type": "String", "placeholders": {} }, - "openCamera": "Åpne kamera", - "@openCamera": { - "type": "text", + "newVerificationRequest": "Nov demanda de verification!", + "@newVerificationRequest": { + "type": "String", "placeholders": {} }, - "participant": "Deltager", - "@participant": { - "type": "text", + "scanQrCode": "Scannar un code QR", + "@scanQrCode": {}, + "noRoomsFound": "Null chambres trovat…", + "@noRoomsFound": { + "type": "String", "placeholders": {} }, - "passphraseOrKey": "Passord eller gjenopprettingsnøkkel", - "@passphraseOrKey": { - "type": "text", + "openInMaps": "Aperter in mappas", + "@openInMaps": { + "type": "String", "placeholders": {} }, - "password": "Passord", + "password": "Contrasigne", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, - "passwordForgotten": "Passord glemt", + "passwordForgotten": "Li contrasigne esset obliviat", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, - "passwordHasBeenChanged": "Passord endret", - "@passwordHasBeenChanged": { - "type": "text", - "placeholders": {} - }, - "passwordRecovery": "Passordgjenoppretting", + "passwordRecovery": "Reganiar li contrasigne", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, - "pickImage": "Velg bilde", - "@pickImage": { - "type": "text", + "pleaseChoose": "Ples selecter", + "@pleaseChoose": { + "type": "String", "placeholders": {} }, - "pin": "Fest", - "@pin": { - "type": "text", - "placeholders": {} - }, - "play": "Spill av {fileName}", - "@play": { - "type": "text", - "placeholders": { - "fileName": {} - } - }, - "pleaseClickOnLink": "Klikk på lenken i e-posten og fortsett.", - "@pleaseClickOnLink": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourPassword": "Skriv inn passordet ditt", - "@pleaseEnterYourPassword": { - "type": "text", - "placeholders": {} - }, - "pleaseEnterYourUsername": "Skriv inn brukernavnet ditt", - "@pleaseEnterYourUsername": { - "type": "text", - "placeholders": {} - }, - "pleaseFollowInstructionsOnWeb": "Følg instruksen på nettsiden og trykk på «Neste».", - "@pleaseFollowInstructionsOnWeb": { - "type": "text", - "placeholders": {} - }, - "privacy": "Personvern", - "@privacy": { - "type": "text", - "placeholders": {} - }, - "publicRooms": "Offentlige rom", - "@publicRooms": { - "type": "text", - "placeholders": {} - }, - "pushRules": "Dyttingsregler", + "pushRules": "Regules de push-notificationes", "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, - "reason": "Grunn", - "@reason": { - "type": "text", + "redactMessage": "Redacter li missage", + "@redactMessage": { + "type": "String", "placeholders": {} }, - "recording": "Opptak", - "@recording": { - "type": "text", - "placeholders": {} - }, - "redactedAnEvent": "{username} har trukket tilbake en hendelse", - "@redactedAnEvent": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "reject": "Avslå", - "@reject": { - "type": "text", - "placeholders": {} - }, - "rejectedTheInvitation": "{username} avslo invitasjonen", - "@rejectedTheInvitation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "rejoin": "Ta del igjen", - "@rejoin": { - "type": "text", - "placeholders": {} - }, - "remove": "Fjern", - "@remove": { - "type": "text", - "placeholders": {} - }, - "removeAllOtherDevices": "Fjern alle andre enheter", - "@removeAllOtherDevices": { - "type": "text", - "placeholders": {} - }, - "removedBy": "Fjernet av {username}", - "@removedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "removeDevice": "Fjern enhet", + "removeDevice": "Remover li aparate", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, - "unbanFromChat": "Opphev bannlysning", - "@unbanFromChat": { - "type": "text", + "saveFile": "Gardar li file", + "@saveFile": { + "type": "String", "placeholders": {} }, - "renderRichContent": "Tegn rikt meldingsinnhold", - "@renderRichContent": { - "type": "text", - "placeholders": {} - }, - "replaceRoomWithNewerVersion": "Erstatt rom med nyere versjon", - "@replaceRoomWithNewerVersion": { - "type": "text", - "placeholders": {} - }, - "reply": "Svar", - "@reply": { - "type": "text", - "placeholders": {} - }, - "reportMessage": "Rapporter melding", - "@reportMessage": { - "type": "text", - "placeholders": {} - }, - "requestPermission": "Forespør tilgang", - "@requestPermission": { - "type": "text", - "placeholders": {} - }, - "roomHasBeenUpgraded": "Rommet har blitt oppgradert", - "@roomHasBeenUpgraded": { - "type": "text", - "placeholders": {} - }, - "search": "Søk", - "@search": { - "type": "text", - "placeholders": {} - }, - "security": "Sikkerhet", - "@security": { - "type": "text", - "placeholders": {} - }, - "seenByUser": "Sett av {username}", - "@seenByUser": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "send": "Send", - "@send": { - "type": "text", - "placeholders": {} - }, - "sendAMessage": "Send en melding", - "@sendAMessage": { - "type": "text", - "placeholders": {} - }, - "sendAudio": "Send lyd", - "@sendAudio": { - "type": "text", - "placeholders": {} - }, - "sendFile": "Send fil", - "@sendFile": { - "type": "text", - "placeholders": {} - }, - "sendImage": "Send bilde", - "@sendImage": { - "type": "text", - "placeholders": {} - }, - "sendMessages": "Send meldinger", + "recoveryKey": "Clave de regania", + "@recoveryKey": {}, + "sendMessages": "Inviar missages", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, - "sendOriginal": "Send original", - "@sendOriginal": { - "type": "text", - "placeholders": {} - }, - "sendVideo": "Send video", + "sendVideo": "Inviar video", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, - "sentAFile": "{username} sendte en fil", - "@sentAFile": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAnAudio": "{username} sendte lyd", - "@sentAnAudio": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAPicture": "{username} sendte et bilde", - "@sentAPicture": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentASticker": "{username} sendte et klistremerke", - "@sentASticker": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentAVideo": "{username} sendte en video", - "@sentAVideo": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "sentCallInformations": "{senderName} sendte anropsinfo", - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "setCustomEmotes": "Sett tilpassede smilefjes", - "@setCustomEmotes": { - "type": "text", + "shareLocation": "Partir un localisation", + "@shareLocation": { + "type": "String", "placeholders": {} }, - "setInvitationLink": "Sett invitasjonslenke", - "@setInvitationLink": { - "type": "text", + "spaceName": "Nómine de spacie", + "@spaceName": { + "type": "String", "placeholders": {} }, - "setPermissionsLevel": "Sett tilgangsnivå", - "@setPermissionsLevel": { - "type": "text", + "unavailable": "Índisponibil", + "@unavailable": { + "type": "String", "placeholders": {} }, - "setStatus": "Angi status", - "@setStatus": { - "type": "text", + "toggleUnread": "Marcar quam (ín)leet", + "@toggleUnread": { + "type": "String", "placeholders": {} }, - "settings": "Innstilinger", + "unblockDevice": "Deblocar li aparate", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Ínconosset aparate", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Voce-missage", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Tapete", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "messageType": "Tip de missage", + "@messageType": {}, + "start": "Iniciar", + "@start": {}, + "messageInfo": "Information pri li missage", + "@messageInfo": {}, + "openGallery": "Aperter li galerie", + "@openGallery": {}, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "reportUser": "Raportar li usator", + "@reportUser": {}, + "voiceCall": "Telefonada", + "@voiceCall": {}, + "nextAccount": "Sequent conto", + "@nextAccount": {}, + "previousAccount": "Precedent conto", + "@previousAccount": {}, + "countFiles": "{count} files", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "all": "Omni", + "@all": { + "type": "String", + "placeholders": {} + }, + "create": "Crear", + "@create": { + "type": "String", + "placeholders": {} + }, + "connect": "Conexer", + "@connect": { + "type": "String", + "placeholders": {} + }, + "copy": "Copiar", + "@copy": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Obscur", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "messages": "Missages", + "@messages": { + "type": "String", + "placeholders": {} + }, + "none": "Null", + "@none": { + "type": "String", + "placeholders": {} + }, + "rejoin": "Re-adherer", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Remover", + "@remove": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notificationes", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "reply": "Responder", + "@reply": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{day}.{month}.{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "delete": "Remover", + "@delete": { + "type": "String", + "placeholders": {} + }, + "search": "Sercha", + "@search": { + "type": "String", + "placeholders": {} + }, + "devices": "Aparates", + "@devices": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Lucid", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "edit": "Redacter", + "@edit": { + "type": "String", + "placeholders": {} + }, + "security": "Securitá", + "@security": { + "type": "String", + "placeholders": {} + }, + "settings": "Parametres", "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, - "share": "Del", + "share": "Partir", "@share": { - "type": "text", + "type": "String", "placeholders": {} }, - "sharedTheLocation": "{username} delte posisjonen", - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "skip": "Hopp over", - "@skip": { - "type": "text", - "placeholders": {} - }, - "sourceCode": "Kildekode", - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "startedACall": "{senderName} startet en samtale", - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "status": "Status", - "@status": { - "type": "text", - "placeholders": {} - }, - "statusExampleMessage": "Hvordan har du det i dag?", - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "submit": "Send inn", - "@submit": { - "type": "text", - "placeholders": {} - }, - "systemTheme": "System", + "systemTheme": "Del sistema", "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, - "theyDontMatch": "Samsvarer ikke", - "@theyDontMatch": { - "type": "text", + "username": "Nómine de usator", + "@username": { + "type": "String", "placeholders": {} }, - "theyMatch": "Samsvarer", + "verify": "Verificar", + "@verify": { + "type": "String", + "placeholders": {} + }, + "submit": "Inviar", + "@submit": { + "type": "String", + "placeholders": {} + }, + "unpin": "Defixar", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "verified": "Verificat", + "@verified": { + "type": "String", + "placeholders": {} + }, + "warning": "Avise!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "yes": "Yes", + "@yes": { + "type": "String", + "placeholders": {} + }, + "time": "Hora", + "@time": {}, + "publish": "Publicar", + "@publish": {}, + "sender": "Autor", + "@sender": {}, + "dismiss": "Demisser", + "@dismiss": {}, + "custom": "Personalisat", + "@custom": {}, + "emojis": "Emoji", + "@emojis": {}, + "widgetCustom": "Personalisat", + "@widgetCustom": {}, + "users": "Usatores", + "@users": {}, + "user": "Usator", + "@user": {}, + "forward": "Avan", + "@forward": { + "type": "String", + "placeholders": {} + }, + "groups": "Gruppes", + "@groups": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorar", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Ínoffensiv", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "invited": "Invitat", + "@invited": { + "type": "String", + "placeholders": {} + }, + "leave": "Forlassar", + "@leave": { + "type": "String", + "placeholders": {} + }, + "license": "Licentie", + "@license": { + "type": "String", + "placeholders": {} + }, + "or": "O", + "@or": { + "type": "String", + "placeholders": {} + }, + "link": "Ligament", + "@link": {}, + "participant": "Participante", + "@participant": { + "type": "String", + "placeholders": {} + }, + "reason": "Cause", + "@reason": { + "type": "String", + "placeholders": {} + }, + "people": "Homes", + "@people": { + "type": "String", + "placeholders": {} + }, + "pin": "Fixar", + "@pin": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privatie", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "recording": "Registrante", + "@recording": { + "type": "String", + "placeholders": {} + }, + "register": "Inregistrar se", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Refuser", + "@reject": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Repetir li contrasigne", + "@repeatPassword": {}, + "addEmail": "Adjunter e-post", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "changePassword": "Cambiar li contrasigne", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Vacuar li archive", + "@clearArchive": {}, + "commandHint_clearcache": "Vacuar li cache", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_send": "Inviar li textu", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "configureChat": "Configurar li conversation", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "directChats": "Direct conversationes", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Activar li ciffration", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Descargar li file", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Parametres de emotiones", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Curt-code de emotion", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Vacui conversation", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videotelefonada", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "openChat": "Aperter li conversation", + "@openChat": {}, + "reportMessage": "Raportar li missage", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Sin permission", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Aperter li cámera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Monstrar li contrasigne", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Inviar un file", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Inviar un image", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Inviar li originale", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Corresponde", "@theyMatch": { - "type": "text", + "type": "String", + "placeholders": {} + }, + "anyoneCanJoin": "Alquí posse adherer se", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Obtenente li localisation…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "addWidget": "Adjunter un widget", + "@addWidget": {}, + "addAccount": "Adjunter un conto", + "@addAccount": {}, + "publicRooms": "Public chambres", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Iniciar li verification", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Version del chambre", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Inviar audio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Inviar un nota adhesiv", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Assignar li statu", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Code de fonte", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "play": "Reproducter {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "about": "Pri", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Acceptar", + "@accept": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Ples confirmar vor Matrix ID por destructer vor conto.", + "@confirmMatrixId": {}, + "allChats": "Omni conversationes", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Adjunter al spacie", + "@addToSpace": {}, + "askVerificationRequest": "Esque acceptar ti demanda de verification de {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Automaticmen reproducter animat images", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendOnEnter": "Inviar per Enter", + "@sendOnEnter": {}, + "blocked": "Blocat", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "Blocar li aparate", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Missages de robots", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Cambiar li nómine de aparate", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Cambiar li hem-servitor", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "chat": "Conversation", + "@chat": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Cambiar vor avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Archive de conversation", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Detallies del conversation", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "commandHint_me": "Ples descrir vos", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_leave": "Forlassar ti chambre", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandInvalid": "Comande es ínvalid", + "@commandInvalid": { + "type": "String" + }, + "widgetEtherpad": "Textual nota", + "@widgetEtherpad": {}, + "banFromChat": "Bannir del conversation", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Cambiar li stil", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasgroup": "Marcar quam gruppe", + "@commandHint_markasgroup": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "screenSharingTitle": "partir li ecran", + "@screenSharingTitle": {}, + "callingPermissions": "Permissiones de telefonada", + "@callingPermissions": {}, + "callingAccount": "Conto telefonante", + "@callingAccount": {}, + "bannedUser": "{username} ha bannit {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "commandHint_html": "Inviar contenete HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_plain": "Inviar textu sin formate", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "editRoomAliases": "Modificar pseudonimos del chambre", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emotion ja existe!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Modificar li avatar del chambre", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Gruppe con {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "invitedUser": "{username} invitat {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "leftTheChat": "Surtit ex li conversation", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "loadingPleaseWait": "Cargante... ples atender.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "{username} ha acceptat li invitation", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "supposedMxid": "To deve esser {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "areYouSureYouWantToLogout": "Esque vu vole cluder li session?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "Li hem-servitor supporta ti tipes de autentication:\n{serverVersions}\nMa ti-ci application supporta solmen:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "cantOpenUri": "Ne successat aperter li adresse {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "badServerVersionsException": "Li hem-servitor supporta ti versiones de specification:\n{serverVersions}\nMa ti-ci application supporta solmen {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}.{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "device": "Aparate", + "@device": { + "type": "String", + "placeholders": {} + }, + "widgetVideo": "Video", + "@widgetVideo": {}, + "widgetName": "Nómine", + "@widgetName": {}, + "account": "Conto", + "@account": { + "type": "String", + "placeholders": {} + }, + "alias": "pseudonim", + "@alias": { + "type": "String", + "placeholders": {} + }, + "archive": "Archive", + "@archive": { + "type": "String", + "placeholders": {} + }, + "banned": "Bannit", + "@banned": { + "type": "String", + "placeholders": {} + }, + "cancel": "Anullar", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Ciffrat", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Ciffration", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Hem-servitor", + "@homeserver": {}, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "newGroup": "Crear un gruppe", + "@newGroup": {}, + "newSpace": "Crear un spacie", + "@newSpace": {}, + "enterSpace": "Intrar li spacie", + "@enterSpace": {}, + "enterRoom": "Intrar li chambre", + "@enterRoom": {}, + "allSpaces": "Omni spacies", + "@allSpaces": {}, + "numChats": "{number} conversationes", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "logout": "Cluder li session", + "@logout": { + "type": "String", + "placeholders": {} + }, + "send": "Inviar", + "@send": { + "type": "String", + "placeholders": {} + }, + "you": "Vu", + "@you": { + "type": "String", "placeholders": {} }, "title": "FluffyChat", "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, - "tooManyRequestsWarning": "For mange forespørsler. Prøv igjen senere!", - "@tooManyRequestsWarning": { - "type": "text", + "skip": "Omisser", + "@skip": { + "type": "String", "placeholders": {} }, - "transferFromAnotherDevice": "Overfør fra en annen enhet", - "@transferFromAnotherDevice": { - "type": "text", + "status": "Statu", + "@status": { + "type": "String", "placeholders": {} }, - "tryToSendAgain": "Prøv å sende igjen", - "@tryToSendAgain": { - "type": "text", + "unverified": "Ínverificat", + "@unverified": {}, + "deviceId": "ID de aparate", + "@deviceId": { + "type": "String", "placeholders": {} }, - "unavailable": "Utilgjengelig", - "@unavailable": { - "type": "text", + "editDisplayname": "Redacter li visibil nómine", + "@editDisplayname": { + "type": "String", "placeholders": {} }, - "unbannedUser": "{username} opphevet bannlysning av {targetName}", - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "unblockDevice": "Opphev blokkering av enhet", - "@unblockDevice": { - "type": "text", + "inviteContact": "Invitar un contacte", + "@inviteContact": { + "type": "String", "placeholders": {} }, - "unknownDevice": "Ukjent enhet", - "@unknownDevice": { - "type": "text", + "requestPermission": "Demandar li permission", + "@requestPermission": { + "type": "String", "placeholders": {} }, - "unknownEncryptionAlgorithm": "Ukjent krypteringsalgoritme", - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "unknownEvent": "Ukjent hendelse «{type}»", - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "unmuteChat": "Opphev forstumming av sludring", - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "unpin": "Løsne", - "@unpin": { - "type": "text", - "placeholders": {} - }, - "unreadChats": "{unreadCount, plural, other{{unreadCount} uleste sludringer}}", - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "userAndOthersAreTyping": "{username} og {count} andre skriver…", - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "userAndUserAreTyping": "{username} og {username2} skriver…", - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "userIsTyping": "{username} skriver…", - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "userLeftTheChat": "{username} har forlatt sludringen", - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "username": "Brukernavn", - "@username": { - "type": "text", - "placeholders": {} - }, - "userSentUnknownEvent": "{username} sendte en {type}-hendelse", - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "verify": "Bekreft", - "@verify": { - "type": "text", - "placeholders": {} - }, - "verifyStart": "Start bekreftelse", - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "verifySuccess": "Du har bekreftet!", - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "verifyTitle": "Bekrefter annen konto", - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "videoCall": "Videosamtale", - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "visibilityOfTheChatHistory": "Sludrehistorikkens synlighet", - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "visibleForAllParticipants": "Synlig for alle deltagere", - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "visibleForEveryone": "Synlig for alle", - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "voiceMessage": "Lydmelding", - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "waitingPartnerNumbers": "Venter på at samtalepartner skal godta tallene …", - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "wallpaper": "Bakgrunnsbilde", - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "warning": "Advarsel!", - "@warning": { - "type": "text", - "placeholders": {} - }, - "weSentYouAnEmail": "Du har fått en e-post", - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "whoCanPerformWhichAction": "Hvem kan utføre hvilken handling", - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "whoIsAllowedToJoinThisGroup": "Hvem tillates å ta del i denne gruppen", - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "whyDoYouWantToReportThis": "Hvorfor ønsker du å rapportere dette?", - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "withTheseAddressesRecoveryDescription": "Med disse adressene kan du gjenopprette passordet ditt hvis du trenger det.", - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "writeAMessage": "Skriv en melding …", - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "yes": "Ja", - "@yes": { - "type": "text", - "placeholders": {} - }, - "you": "Deg", - "@you": { - "type": "text", - "placeholders": {} - }, - "youAreNoLongerParticipatingInThisChat": "Du deltar ikke lenger i denne sludringen", - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "youHaveBeenBannedFromThisChat": "Du har blitt bannlyst fra denne sludringen", - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "yourPublicKey": "Din offentlige nøkkel", - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "toggleUnread": "Marker som lest/ulest", - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "toggleMuted": "Veksle forstumming", - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "toggleFavorite": "Veksle favorittmerking", - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "noConnectionToTheServer": "Ingen tilkobling til tjeneren", - "@noConnectionToTheServer": { - "type": "text", - "placeholders": {} - }, - "addEmail": "Legg til e-post", - "@addEmail": { - "type": "text", - "placeholders": {} - }, - "repeatPassword": "Gjenta passord", - "@repeatPassword": {}, - "addToSpace": "Legg til space", - "@addToSpace": {}, - "allChats": "Alle samtaler", - "@allChats": { - "type": "text", - "placeholders": {} - }, - "autoplayImages": "Automatisk spill av animerte stickers og emojis", - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "badServerLoginTypesException": "Denne hjemme serveren støtter følgende innloggings-typer:\n{serverVersions}\nMen denne applikasjonen støtter kun:\n{supportedVersions}", - "@badServerLoginTypesException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "sendOnEnter": "Trykk på enter for å sende", - "@sendOnEnter": {}, - "badServerVersionsException": "Denne hjemme serveren støtter følgene Spec-versjoner:\n{serverVersions}\nMen denne applikasjonen støtter kun {supportedVersions}", - "@badServerVersionsException": { - "type": "text", - "placeholders": { - "serverVersions": {}, - "supportedVersions": {} - } - }, - "blocked": "Blokkert", - "@blocked": { - "type": "text", - "placeholders": {} - }, - "cantOpenUri": "Kan ikke åpne URI {uri}", - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "changeYourAvatar": "Bytt profilbilde", - "@changeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "@showPassword": { - "type": "text", + "areYouSure": "Esque vu es cert?", + "@areYouSure": { + "type": "String", "placeholders": {} }, "@hugContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, "@jumpToLastReadMessage": {}, "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_cuddle": {}, - "@chats": { - "type": "text", - "placeholders": {} - }, - "@widgetVideo": {}, - "@dismiss": {}, "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "@reportErrorDescription": {}, - "@addAccount": {}, + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, "@chatHasBeenAddedToThisSpace": {}, "@removeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "@unsupportedAndroidVersion": {}, - "@commandHint_html": { - "type": "text", - "description": "Usage hint for the command /html" + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} }, - "@widgetJitsi": {}, - "@messageType": {}, "@indexedDbErrorLong": {}, "@oneClientLoggedOut": {}, + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "@unsupportedAndroidVersionLong": {}, + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, "@startFirstChat": {}, - "@callingAccount": {}, + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, "@setColorTheme": {}, - "@nextAccount": {}, "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", + "@sentAFile": { + "type": "String", "placeholders": { - "mxid": {} + "username": { + "type": "String" + } } }, - "@user": {}, - "@roomVersion": { - "type": "text", - "placeholders": {} - }, "@youAcceptedTheInvitation": {}, "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "@youInvitedBy": { "placeholders": { - "user": {} + "user": { + "type": "String" + } + } + }, + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } } }, "@banUserDescription": {}, - "@widgetEtherpad": {}, + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, "@removeDevicesDescription": {}, + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, "@separateChatTypes": { - "type": "text", + "type": "String", "placeholders": {} }, "@tryAgain": {}, + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, "@youKickedAndBanned": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@unbanUserDescription": {}, - "@saveFile": { - "type": "text", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "@pleaseClickOnLink": { + "type": "String", "placeholders": {} }, + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, "@youRejectedTheInvitation": {}, "@otherCallingPermissions": {}, "@messagesStyle": {}, - "@link": {}, + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, "@widgetUrlError": {}, "@emailOrUsername": {}, "@newSpaceDescription": {}, "@chatDescription": {}, "@callingAccountDetails": {}, - "@editRoomAliases": { - "type": "text", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", "placeholders": {} }, - "@enterSpace": {}, + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, "@encryptThisChat": {}, - "@previousAccount": {}, + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, "@reopenChat": {}, "@pleaseEnterRecoveryKey": {}, + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, "@widgetNameError": {}, "@addToBundle": {}, "@spaceIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, - "@addWidget": {}, - "@countFiles": { - "placeholders": { - "count": {} - } + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} }, "@noKeyForThisMessage": {}, - "@shareLocation": { - "type": "text", + "@enableEncryptionWarning": { + "type": "String", "placeholders": {} }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", + "@inviteText": { + "type": "String", "placeholders": { - "error": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } } }, "@hydrateTor": {}, "@pushNotificationsNotAvailable": {}, "@storeInAppleKeyChain": {}, + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, "@hydrate": {}, "@invalidServerName": {}, "@chatPermissions": {}, "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, - "@sender": {}, "@storeInAndroidKeystore": {}, + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, "@signInWithPassword": {}, + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, "@makeAdminDescription": {}, + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, "@synchronizingPleaseWait": { - "type": "text", + "type": "String", + "placeholders": {} + }, + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "@passwordHasBeenChanged": { + "type": "String", "placeholders": {} }, "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, "@saveKeyManuallyDescription": {}, "@editBundlesForAccount": {}, "@whyIsThisMessageEncrypted": {}, + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, "@setChatDescription": {}, - "@spaceName": { - "type": "text", - "placeholders": {} + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } }, "@importFromZipFile": {}, - "@or": { - "type": "text", - "placeholders": {} - }, "@dehydrateWarning": {}, "@noOtherDevicesFound": {}, + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@storeSecurlyOnThisDevice": {}, "@yourChatBackupHasBeenSetUp": {}, "@redactedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "@videoCallsBetaWarning": {}, - "@signInWith": { - "type": "text", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "@createdTheChat": { + "type": "String", "placeholders": { - "provider": {} + "username": { + "type": "String" + } + } + }, + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } } }, "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@people": { - "type": "text", - "placeholders": {} - }, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@register": { - "type": "text", - "placeholders": {} - }, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", + "@changedTheHistoryVisibilityTo": { + "type": "String", "placeholders": { - "number": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "@readUpToHere": {}, + "@unlockOldMessages": {}, + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } } }, "@optionalRedactReason": {}, + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, "@dehydrate": {}, "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", + "placeholders": {} + }, + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@visibleForAllParticipants": { + "type": "String", "placeholders": {} }, "@sendAsText": { - "type": "text" + "type": "String" }, "@archiveRoomDescription": {}, "@exportEmotePack": {}, - "@sendSticker": { - "type": "text", - "placeholders": {} + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } }, "@switchToAccount": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, - "@commandInvalid": { - "type": "text" - }, "@setAsCanonicalAlias": { - "type": "text", + "type": "String", + "placeholders": {} + }, + "@whyDoYouWantToReportThis": { + "type": "String", "placeholders": {} }, "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, - "@commandHint_plain": { - "type": "text", - "description": "Usage hint for the command /plain" + "@placeCall": {}, + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } }, "@experimentalVideoCalls": {}, "@pleaseEnterRecoveryKeyDescription": {}, - "@openInMaps": { - "type": "text", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "@withTheseAddressesRecoveryDescription": { + "type": "String", "placeholders": {} }, "@inviteContactToGroupQuestion": {}, "@redactedByBecause": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "reason": {} + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } } }, "@youHaveWithdrawnTheInvitationFor": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@pleaseChooseAPasscode": { - "type": "text", + "@roomHasBeenUpgraded": { + "type": "String", "placeholders": {} }, - "@reportUser": {}, - "@commandHint_send": { - "type": "text", - "description": "Usage hint for the command /send" + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } }, "@confirmEventUnpin": {}, "@youInvitedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, "@fileHasBeenSavedAt": { - "type": "text", + "type": "String", "placeholders": { - "path": {} + "path": { + "type": "String" + } } }, + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "@redactMessageDescription": {}, - "@recoveryKey": {}, - "@redactMessage": { - "type": "text", - "placeholders": {} - }, "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "@invalidInput": {}, + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, "@dehydrateTorLong": {}, + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "@doNotShowAgain": {}, + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, "@report": {}, - "@unverified": {}, + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, "@serverRequiresEmail": {}, "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, "@addToSpaceDescription": {}, "@googlyEyesContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "@youBannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, "@addChatDescription": {}, - "@commandHint_leave": { - "type": "text", - "description": "Usage hint for the command /leave" + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } }, "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "@hasKnocked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, - "@publish": {}, "@openLinkInBrowser": {}, - "@clearArchive": {}, + "@appLock": { + "type": "String", + "placeholders": {} + }, "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} }, - "@messageInfo": {}, "@disableEncryptionWarning": {}, "@directChat": {}, + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, "@wrongPinEntered": { - "type": "text", + "type": "String", "placeholders": { - "seconds": {} + "seconds": { + "type": "int" + } } }, "@sendTypingNotifications": {}, "@inviteGroupChat": {}, "@appearOnTop": {}, "@invitePrivateChat": {}, - "@foregroundServiceRunning": {}, - "@voiceCall": {}, - "@commandHint_kick": { - "type": "text", - "description": "Usage hint for the command /kick" - }, - "@createNewSpace": { - "type": "text", + "@verifyTitle": { + "type": "String", "placeholders": {} }, + "@foregroundServiceRunning": {}, + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "@importEmojis": {}, "@wasDirectChatDisplayName": { - "type": "text", + "type": "String", "placeholders": { - "oldDisplayName": {} + "oldDisplayName": { + "type": "String" + } } }, "@noChatDescriptionYet": {}, + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, "@removeFromBundle": {}, - "@confirmMatrixId": {}, + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, "@learnMore": {}, - "notAnImage": "Ikke en bildefil.", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, "@bundleName": {}, "@dehydrateTor": {}, "@removeFromSpace": {}, "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "@roomUpgradeDescription": {}, "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, - "@scanQrCode": {}, + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, "@pleaseEnterANumber": {}, + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, "@youKicked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } + } + }, + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } } }, "@profileNotFound": {}, "@jump": {}, "@reactedWith": { - "type": "text", + "type": "String", "placeholders": { - "sender": {}, - "reaction": {} + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } } }, "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "@loadCountMoreParticipants": { + "type": "String", "placeholders": { - "size": {} + "count": { + "type": "int" + } } }, "@shareInviteLink": {}, "@commandHint_markasdm": {}, "@recoveryKeyLost": {}, "@cuddleContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "@deviceKeys": {}, + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, "@emoteKeyboardNoRecents": { - "type": "text", + "type": "String", + "placeholders": {} + }, + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "@visibilityOfTheChatHistory": { + "type": "String", "placeholders": {} }, "@setTheme": {}, "@youJoinedTheChat": {}, "@openVideoCamera": { - "type": "text", + "type": "String", + "placeholders": {} + }, + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "@statusExampleMessage": { + "type": "String", "placeholders": {} }, "@markAsRead": {}, - "@widgetName": {}, + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, "@errorAddingWidget": {}, "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "@commandHint_hug": {}, "@replace": {}, "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "@youUnbannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, - "@newSpace": {}, - "@emojis": {}, + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, "@pleaseEnterYourPin": { - "type": "text", - "placeholders": {} - }, - "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "@commandHint_googly": {}, "@pleaseTryAgainLaterOrChooseDifferentServer": {}, "@createGroup": {}, "@hydrateTorLong": {}, - "@time": {}, - "@custom": {}, + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, "@noBackupWarning": {}, "@storeInSecureStorageDescription": {}, - "@openChat": {}, "@kickUserDescription": {}, + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, "@importNow": {}, + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, "@pinMessage": {}, + "@screenSharingDetail": {}, "@invite": {}, "@enableMultiAccounts": {}, + "@emotePacks": { + "type": "String", + "placeholders": {} + }, "@indexedDbErrorTitle": {}, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@placeCall": {} + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + } } diff --git a/lib/l10n/intl_it.arb b/lib/l10n/intl_it.arb new file mode 100644 index 000000000..6009bfa31 --- /dev/null +++ b/lib/l10n/intl_it.arb @@ -0,0 +1,3404 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.992206", + "about": "Informazioni", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Accetta", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} ha accettato l'invito", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Account", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} ha abilitato la crittografia end to end", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Aggiungi e-mail", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Amministratore", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Tutto", + "@all": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} ha risposto alla chiamata", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Tutti possono partecipare", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Blocco dell'app", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Archivia", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Gli utenti ospiti possono partecipare", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Sei sicuro/a?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Sei sicuro/a di voler uscire?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Per far accedere l'altra persona, per favore inserisci la tua frase segreta o chiave di recupero.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Accettare questa richiesta di verifica da {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "L'homeserver supporta i tipi di accesso:\n{serverVersions}\nMa questa applicazione supporta solo:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "L'homeserver supporta le versioni Spec:\n{serverVersions}\nMa questa applicazione supporta solo {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Bandisci dalla chat", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Bandito", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} ha bandito {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blocca dispositivo", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Bloccato", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Messaggi bot", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Annulla", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Cambia nome dispositivo", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} ha cambiato l'avatar della discussione", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} ha cambiato la descrizione della chat in: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} ha cambiato il nome della discussione in: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} ha cambiato i permessi della chat", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} ha cambiato nome in: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} ha cambiato le regole di accesso per ospiti", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} ha cambiato le regole di accesso per ospiti con: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} ha cambiato la visibilità della cronologia", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} ha cambiato la visibilità della cronologia in: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} ha cambiato le regole per unirsi", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} ha cambiato le regole per unirsi in: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} ha cambiato il suo avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} ha modificato gli alias della stanza", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} ha cambiato il link di invito", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Cambia la password", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Cambia il server principale", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Cambia il tuo stile", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Cambia il nome del gruppo", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "La crittografia è corrotta", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Backup delle discussioni", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "I tuoi vecchi messaggi sono protetti da una chiave di sicurezza. Assicurati di non perderla.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Dettagli chat", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Discussioni", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Scegli una password complessa", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Chiudi", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Per favore confronta gli emoji", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Per favore confronta i numeri", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Configura la discussione", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Conferma", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Connetti", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Il contatto è stato invitato nel gruppo", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Contiene nome visibile", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Contiene nome utente", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Il contenuto è stato segnalato agli amministratori del server", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Copiato negli Appunti", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Copia", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Copia negli appunti", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Impossibile decriptare messaggio: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} partecipanti", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Crea", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} ha creato la chat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Attualmente attivo", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Scuro", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}/{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}/{month}/{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Disabiliterà il tuo account. Non puoi tornare indietro! Sei sicuro/a?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Livello di autorizzazione predefinito per i nuovi utenti", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Cancella", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Elimina l'account", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Elimina il messaggio", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Dispositivo", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID del dispositivo", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Dispositivi", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Chat dirette", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Il nominativo è stato cambiato", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Scarica il file", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Modifica", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Modifica i server bloccati", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Modifica il nominativo", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Modifica l'avatar della stanza", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "L'emote già esiste!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Shortcode emote invalido!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Pacchetti emotes della stanza", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Impostazioni emote", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Scorciatoia emote", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Devi scegliere una scorciatoia emote e aggiungere un immagine!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Discussione vuota", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Abilita i pacchetti emotes globalmente", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Abilita la crittografia", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Non potrai disabilitare la crittografia in futuro. Sei sicuro?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Crittografato", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Crittografia", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Crittografia non abilitata", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} è entrato in chiamata", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Inserisci un indirizzo e-mail", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Inserisci il tuo server principale", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Tutto pronto!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Estremamente offensivo", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Nome del file", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Dimensione carattere", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Inoltra", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Dall'adesione", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Dall'invito", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Vai nella nuova stanza", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Gruppo", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Il gruppo è pubblico", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Gruppi", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Gruppo con {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Gli ospiti sono vietati", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Gli ospiti possono partecipare", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} ha ritirato l'invito per {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Aiuto", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Nascondi gli eventi eliminati", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Nascondi gli eventi sconosciuti", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Quanto è offensivo questo contenuto?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identità", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignora", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Utenti ignorati", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Ho cliccato sul collegamento", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Frase segrata o chiave di ripristino errate", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Inoffensivo", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Invita contatto", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Invita un contatto a {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Invitato/a", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} ha invitato {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Solo utenti invitati", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Invita per me", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} ti ha invitato/a a FluffyChat.\n1. Visita fluffychat.im e installa l'applicazione\n2. Iscriviti o accedi\n3. Apri il collegamento di invito: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "sta scrivendo…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} si è unito/a alla chat", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Unisciti alla stanza", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} ha espulso {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} ha espulso e bandito {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Espelli dalla chat", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Ultima attività: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Abbandona", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Ha lasciato la chat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licenza", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Chiaro", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Carica altri {count} partecipanti", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Caricamento… Attendere prego.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Carica di più…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Accedi", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Accedi a {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Esci", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Cambiamenti di membri", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Menzione", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Messaggi", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderatore", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Silenzia discussione", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Tieni presente che per ora hai bisogno di Pantalaimon per utilizzare la crittografia dall'inizio alla fine.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Nuova discussione", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nuovo messaggio in FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nuova richiesta di verifica!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Avanti", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "No", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Nessuna connessione al server", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Nessun emote trovato. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Puoi attivare la crittografia solo quando la stanza non è più accessibile pubblicamente.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Firebase Cloud Messaging non sembra essere disponibile sul tuo dispositivo. Per continuare a ricevere notifiche push, ti consigliamo di installare ntfy. Con ntfy o un altro provider Unified Push puoi ricevere notifiche push in modo sicuro per i dati. Puoi scaricare ntfy dal PlayStore o da F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Nessuno", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Non hai ancora aggiunto un modo per recuperare la tua password.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Nessuna autorizzazione", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Nessuna stanza trovata…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notifiche", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Notifiche abilitate per questo account", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} utenti stanno scrivendo…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offensive": "Offensivo", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Fuori linea", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "In linea", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Il backup delle chiavi in linea è abilitato", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ops, qualcosa è andato storto…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Apri l'app per leggere i messaggi", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Apri fotocamera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "participant": "Partecipante", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "frase segreta o chiave di recupero", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Password", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Password dimenticata", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "La password è stata cambiata", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Recupero della password", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Persone", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Scegli un'immagine", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Fissa", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Riproduci {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChooseAPasscode": "Si prega di scegliere un codice di accesso", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Clicca sul collegamenti nell'e-mail e poi procedi.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Inserisci 4 cifre o lascia vuoto per disabilitare il blocco dell'app.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Inserisci la tua password", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Inserisci il tuo nome utente", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Segui le istruzioni sul sito web e tocca Avanti.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privacy", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Stanze pubbliche", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Regole notifiche", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Motivo", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Registrazione", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} ha eliminato un evento", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Elimina un messaggio", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "reject": "Rifiuta", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} ha rifiutato l'invito", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Riunisciti", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Rimuovi", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Rimuovi tutti gli altri dispositivi", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Rimosso da {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Rimuovi il dispositivo", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Rimuovi il ban dalla chat", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Sostituisci la stanza con la versione più recente", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Rispondi", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Segnala il messaggio", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Richiedi l'autorizzazione", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "La stanza è stata aggiornata", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Versione della stanza", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "search": "Cerca", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Sicurezza", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Visto da {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Invia", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Invia un messaggio", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Invia un file audio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Invia un file", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Invia un'immagine", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Invia messaggi", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Invia l'originale", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Invia un video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} ha inviato un file", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} ha inviato un file audio", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} ha inviato un'immagine", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} ha inviato un adesivo", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} ha inviato un video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} ha inviato informazioni sulla chiamata", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setCustomEmotes": "Imposta emoticon personalizzate", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Imposta il collegamento di invito", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Imposta il livello di autorizzazione", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Imposta lo stato", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Impostazioni", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Condividi", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} ha condiviso la sua posizione", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "showPassword": "Mostra la password", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "skip": "Ignora", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Codice sorgente", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} ha iniziato una chiamata", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Stato", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Come stai oggi?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Invia", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistema", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Non corrispondono", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Corrispondono", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Attiva/disattiva preferito", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Attiva/disattiva il silenziatore", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Segna come letto / non letto", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Troppe richieste. Per favore riprova più tardi!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Trasferimento da un altro dispositivo", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Prova a inviare di nuovo", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Non disponibile", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} ha rimosso il bando di {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Sblocca il dispositivo", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Dispositivo sconosciuto", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Algoritmo di crittografia sconosciuto", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Evento sconosciuto '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Riattiva l'audio della discussione", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Rimuovi", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 discussione non letta} other{{unreadCount} discussioni non lette}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} e {count} altri stanno scrivendo…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} e {username2} stanno scrivendo…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} sta scrivendo…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} ha abbandonato la chat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Nome utente", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} ha inviato un evento {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Verificato", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verifica", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Avvia la verifica", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Hai verificato con successo!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verifica dell'altro account", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videochiamata", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Visibilità della cronologia della discussione", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Visibile a tutti i partecipanti", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Visibile a tutti", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Messaggio vocale", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "In attesa che il partner accetti la richiesta…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "In attesa che il partner accetti l'emoji…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "In attesa che il partner accetti i numeri…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Immagine di sfondo:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Attenzione!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Ti abbiamo inviato un'e-mail", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Chi può eseguire quale azione", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Chi è autorizzato a unirsi a questo gruppo", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Perché vuoi segnalarlo?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Cancellare il backup della discussione per creare una nuova chiave di ripristino?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Con questi indirizzi puoi recuperare la tua password se necessario.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Scrivi un messaggio…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Sì", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Tu", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Non stai più partecipando a questa chat", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Sei stato/a bandito/a da questa chat", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "La tua chiave pubblica", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Accesso singolo", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Imposta come alias principale", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Rimuovi il tuo avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "register": "Registrati", + "@register": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Per favore inserisci il tuo PIN", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Si prega di scegliere", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "or": "O", + "@or": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Ops! Purtroppo si è verificato un errore durante l'impostazione delle notifiche push.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Modifica gli alias della stanza", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Cancella archivio", + "@clearArchive": {}, + "changeYourAvatar": "Cambia il tuo avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "allChats": "Tutte le chat", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Aggiungi a uno spazio", + "@addToSpace": {}, + "commandHint_leave": "Abbandona questa stanza", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_ban": "Banna l'utente specificato da questa stanza", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "sendSticker": "Invia adesivo", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "commandHint_html": "Invia testo formattato in HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_plain": "Invia testo non formattato", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_send": "Invia testo", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "locationDisabledNotice": "I servizi di localizzazione sono disabilitati. Per favore abilitali per poter condividere la tua posizione.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Salva file", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "Questo server ha bisogno di validare la tua email per la registrazione.", + "@serverRequiresEmail": {}, + "openInMaps": "Apri in maps", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "Scansiona codice QR", + "@scanQrCode": {}, + "addAccount": "Aggiungi account", + "@addAccount": {}, + "unverified": "Non verificato", + "@unverified": {}, + "sendAsText": "Invia come testo", + "@sendAsText": { + "type": "String" + }, + "repeatPassword": "Ripeti password", + "@repeatPassword": {}, + "autoplayImages": "Riproduci automaticamente adesivi ed emote animati", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "cantOpenUri": "Impossibile aprire l'URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "commandInvalid": "Comando non valido", + "@commandInvalid": { + "type": "String" + }, + "link": "Link", + "@link": {}, + "shareLocation": "Condividi posizione", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Il tuo backup delle chat è stato configurato.", + "@yourChatBackupHasBeenSetUp": {}, + "hugContent": "{senderName} ti abbraccia", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Salta all'ultimo messaggio letto", + "@jumpToLastReadMessage": {}, + "allRooms": "Tutte le chat di gruppo", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Ottengo la posizione…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "commandHint_cuddle": "Invia una coccola", + "@commandHint_cuddle": {}, + "widgetVideo": "Video", + "@widgetVideo": {}, + "dismiss": "Chiudi", + "@dismiss": {}, + "reportErrorDescription": "😭 Oh no. Qualcosa è andato storto. Se vuoi, puoi segnalare questo bug agli sviluppatori.", + "@reportErrorDescription": {}, + "chatHasBeenAddedToThisSpace": "La chat è stata aggiunta a questo spazio", + "@chatHasBeenAddedToThisSpace": {}, + "unsupportedAndroidVersion": "Versione di Android non supportata", + "@unsupportedAndroidVersion": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "messageType": "Tipo del Messaggio", + "@messageType": {}, + "indexedDbErrorLong": "Sfortunatamente l'archiviazione dei messaggi non è abilitata in modalità privata per impostazione predefinita.\nPer favore visita\n - about:config\n - imposta dom.indexedDB.privateBrowsing.enabled su true\nAltrimenti, non è possibile eseguire FluffyChat.", + "@indexedDbErrorLong": {}, + "oneClientLoggedOut": "Uno dei tuoi client è stato disconnesso", + "@oneClientLoggedOut": {}, + "startFirstChat": "Inizia la tua prima chat", + "@startFirstChat": {}, + "callingAccount": "Account di chiamata", + "@callingAccount": {}, + "setColorTheme": "Imposta tema colore:", + "@setColorTheme": {}, + "nextAccount": "Account successivo", + "@nextAccount": {}, + "commandHint_create": "Crea una chat di gruppo vuota\nUtilizza --no-encryption per disattivare la criptazione", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "allSpaces": "Tutti gli spazi", + "@allSpaces": {}, + "supposedMxid": "Dovrebbe essere {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "user": "Utente", + "@user": {}, + "youAcceptedTheInvitation": "👍 Hai accettato l'invito", + "@youAcceptedTheInvitation": {}, + "noMatrixServer": "{server1} non è un server matrix, vuoi invece usare {server2}?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Sei stato invitato/a da {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "banUserDescription": "L'utente sarà bannato dalla chat e non sarà in grado di rientrare finché non verrà sbannato.", + "@banUserDescription": {}, + "widgetEtherpad": "Nota di testo", + "@widgetEtherpad": {}, + "removeDevicesDescription": "Sarai disconnesso da questo dispositivo e non potrai più ricevere messaggi.", + "@removeDevicesDescription": {}, + "separateChatTypes": "Separare le chat dirette e i gruppi", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "tryAgain": "Riprova", + "@tryAgain": {}, + "youKickedAndBanned": "🙅 Hai rimosso e bannato {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unbanUserDescription": "L'utente potrà rientrare nella chat.", + "@unbanUserDescription": {}, + "sendOnEnter": "Invia quando premi Invio", + "@sendOnEnter": {}, + "youRejectedTheInvitation": "Hai rifiutato l'invito", + "@youRejectedTheInvitation": {}, + "otherCallingPermissions": "Microfono, fotocamera e altri permessi di FluffyChat", + "@otherCallingPermissions": {}, + "messagesStyle": "Messaggi:", + "@messagesStyle": {}, + "widgetUrlError": "Questo non è un URL valido.", + "@widgetUrlError": {}, + "emailOrUsername": "Email o nome utente", + "@emailOrUsername": {}, + "newSpaceDescription": "Gli spazi ti permettono di consolidare le tue chat e di creare comunità private o pubbliche.", + "@newSpaceDescription": {}, + "chatDescription": "Descrizione della chat", + "@chatDescription": {}, + "callingAccountDetails": "Dai l'autorizzazione a FluffyChat di usare l'app di composizione Android nativa.", + "@callingAccountDetails": {}, + "enterSpace": "Unirsi allo spazio", + "@enterSpace": {}, + "encryptThisChat": "Cifra questa chat", + "@encryptThisChat": {}, + "previousAccount": "Account precedente", + "@previousAccount": {}, + "reopenChat": "Riapri la chat", + "@reopenChat": {}, + "pleaseEnterRecoveryKey": "Per favore inserisci la tua chiave di recupero:", + "@pleaseEnterRecoveryKey": {}, + "widgetNameError": "Per favore fornire un nome da visualizzare.", + "@widgetNameError": {}, + "addToBundle": "Aggiungi al bundle", + "@addToBundle": {}, + "spaceIsPublic": "Lo spazio è pubblico", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "addWidget": "Aggiungi widget", + "@addWidget": {}, + "countFiles": "{count} file", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noKeyForThisMessage": "Questo può accadere se il messaggio è stato inviato prima che hai fatto l'accesso in questo dispositivo.\n\nÈ anche possibile che il mittente abbia bloccato il tuo dispositivo o che qualcosa sia andato storto con la tua connessione ad internet.\n\nSei in grado di leggere il messaggio su altre sessioni? Allora puoi trasferire il messaggio da lì! Vai su Impostazioni > Dispositivi e verifica che i tuoi dispositivi siano verificati l'un l'altro. Quando aprirai la stanza la prossima volta ed entrambe le sessioni sono in primo piano, le chiavi saranno trasmesse automaticamente.\n\nNon vuoi perdere le chiavi quando ti disconnetti o cambi dispositivo? Assicurati di aver attivato il backup delle chat nelle impostazioni.", + "@noKeyForThisMessage": {}, + "commandHint_markasgroup": "Segna come gruppo", + "@commandHint_markasgroup": {}, + "errorObtainingLocation": "Errore cercando di ottenere la posizione: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "hydrateTor": "Utenti TOR: Importa l'esportazione della sessione", + "@hydrateTor": {}, + "pushNotificationsNotAvailable": "Notifiche push non disponibili", + "@pushNotificationsNotAvailable": {}, + "storeInAppleKeyChain": "Salva nel portachiavi di Apple", + "@storeInAppleKeyChain": {}, + "hydrate": "Ripristina dal file di backup", + "@hydrate": {}, + "invalidServerName": "Nome server non valido", + "@invalidServerName": {}, + "chatPermissions": "Permessi della chat", + "@chatPermissions": {}, + "sender": "Mittente", + "@sender": {}, + "storeInAndroidKeystore": "Salva nel KeyStore di Android", + "@storeInAndroidKeystore": {}, + "signInWithPassword": "Accedi con la password", + "@signInWithPassword": {}, + "makeAdminDescription": "Una volta che fai questo utente amministratore, potresti non essere in grado di rimuoverlo, in quanto avrà i tuoi stessi privilegi.", + "@makeAdminDescription": {}, + "synchronizingPleaseWait": "Sincronizzazione... Attendere prego.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "commandHint_clearcache": "Pulisci cache", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "saveKeyManuallyDescription": "Salva questa chiave manualmente attivando la finestra di condivisione o gli appunti.", + "@saveKeyManuallyDescription": {}, + "editBundlesForAccount": "Modifica i bundle per questo account", + "@editBundlesForAccount": {}, + "whyIsThisMessageEncrypted": "Perché questo messaggio è illeggibile?", + "@whyIsThisMessageEncrypted": {}, + "setChatDescription": "Imposta la descrizione della chat", + "@setChatDescription": {}, + "spaceName": "Nome dello spazio", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "importFromZipFile": "Importa da file .zip", + "@importFromZipFile": {}, + "dehydrateWarning": "Questa azione non può essere annullata. Assicurarsi di aver salvato il file di backup.", + "@dehydrateWarning": {}, + "noOtherDevicesFound": "Nessun altro dispositivo trovato", + "@noOtherDevicesFound": {}, + "redactedBy": "Rimosso da {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "videoCallsBetaWarning": "Nota che le video chiamate sono attualmente in beta. Potrebbero non funzionare come previsto o non funzionare del tutto su alcune piattaforme.", + "@videoCallsBetaWarning": {}, + "signInWith": "Accedi con {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "Impossibile inviare! Il server supporta solo allegati fino a {max}.", + "@fileIsTooBigForServer": {}, + "homeserver": "Homeserver", + "@homeserver": {}, + "callingPermissions": "Permessi di chiamata", + "@callingPermissions": {}, + "readUpToHere": "Letto fino a qui", + "@readUpToHere": {}, + "start": "Inizio", + "@start": {}, + "unlockOldMessages": "Sblocca i vecchi messaggi", + "@unlockOldMessages": {}, + "numChats": "{number} chat", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Opzionale) Ragione per rimuovere questo messaggio...", + "@optionalRedactReason": {}, + "dehydrate": "Esporta la sessione e cancella il dispositivo", + "@dehydrate": {}, + "locationPermissionDeniedNotice": "Permesso per accedere alla posizione negato. Per favore concedilo per essere in grado di condividere la tua posizione.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "archiveRoomDescription": "Questa chat sarà archiviata. Gli altri utenti saranno in grado di vedere che hai abbandonato la chat.", + "@archiveRoomDescription": {}, + "exportEmotePack": "Esporta pack di Emote come .zip", + "@exportEmotePack": {}, + "switchToAccount": "Passa all'account {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "experimentalVideoCalls": "Video chiamate sperimentali", + "@experimentalVideoCalls": {}, + "pleaseEnterRecoveryKeyDescription": "Per sbloccare i tuoi vecchi messaggi, per favore inserisci la tua chiave di recupero che è stata generata nella tua sessione precedente. La tua chiave di recupero NON è la tua password.", + "@pleaseEnterRecoveryKeyDescription": {}, + "inviteContactToGroupQuestion": "Vuoi invitare {contact} nella chat \"{groupName}\"?", + "@inviteContactToGroupQuestion": {}, + "redactedByBecause": "Rimosso da {username} per: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Hai revocato l'invito per {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "appearOnTopDetails": "Permetti all'app di apparire in alto (non necessario se hai già impostato Fluffychat come account di chiamata)", + "@appearOnTopDetails": {}, + "enterRoom": "Unirsi alla stanza", + "@enterRoom": {}, + "reportUser": "Segnala utente", + "@reportUser": {}, + "confirmEventUnpin": "Sei sicuro di voler permanentemente sfissare l'evento?", + "@confirmEventUnpin": {}, + "youInvitedUser": "📩 Hai invitato {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "Il file è stato salvato in {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "commandMissing": "{command} non è un comando.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "redactMessageDescription": "Questo messaggio sarà rimosso per tutti i partecipanti di questa conversazione. Questa operazione non può essere annullata.", + "@redactMessageDescription": {}, + "recoveryKey": "Chiave di recupero", + "@recoveryKey": {}, + "commandHint_discardsession": "Scarta sessione", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "invalidInput": "Contenuto non valido!", + "@invalidInput": {}, + "dehydrateTorLong": "Per gli utenti TOR, è raccomandato esportare la sessione prima di chiudere la finestra.", + "@dehydrateTorLong": {}, + "commandHint_myroomnick": "Imposta il nome visualizzato per questa stanza", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "doNotShowAgain": "Non mostrare più", + "@doNotShowAgain": {}, + "report": "segnala", + "@report": {}, + "hideUnimportantStateEvents": "Nascondi gli eventi di stato non importanti", + "@hideUnimportantStateEvents": {}, + "screenSharingTitle": "condivisione schermo", + "@screenSharingTitle": {}, + "widgetCustom": "Personalizzati", + "@widgetCustom": {}, + "addToSpaceDescription": "Seleziona una spazio a cui aggiungere questa chat.", + "@addToSpaceDescription": {}, + "googlyEyesContent": "{senderName} ti ha inviato degli occhi finti", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "youBannedUser": "Hai bannato {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "addChatDescription": "Aggiungi una descrizione chat...", + "@addChatDescription": {}, + "commandHint_myroomavatar": "Importa la foto profilo per questa stanza ( mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "hasKnocked": "🚪 {user} ha bussato", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "publish": "Pubblicare", + "@publish": {}, + "openLinkInBrowser": "Apri il collegamento nel browser", + "@openLinkInBrowser": {}, + "commandHint_react": "Rispondi con una reazione", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_me": "Descriviti", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "messageInfo": "Informazioni del messaggio", + "@messageInfo": {}, + "disableEncryptionWarning": "Per motivi di sicurezza non puoi disabilitare la crittografia in una chat, se era stata abilitata in precedenza.", + "@disableEncryptionWarning": {}, + "directChat": "Chat diretta", + "@directChat": {}, + "wrongPinEntered": "È stato inserito il pin sbagliato! Riprova tra {seconds} secondi...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "Invia notifiche di scrittura", + "@sendTypingNotifications": {}, + "inviteGroupChat": "📨 Invita a una chat di gruppo", + "@inviteGroupChat": {}, + "appearOnTop": "Appare in alto", + "@appearOnTop": {}, + "invitePrivateChat": "📨 Invita a una chat privata", + "@invitePrivateChat": {}, + "foregroundServiceRunning": "Questa notifica viene mostrata quando il servizio in primo piano è in esecuzione.", + "@foregroundServiceRunning": {}, + "voiceCall": "Chiamata vocale", + "@voiceCall": {}, + "commandHint_kick": "Rimuovi l'utente fornito da questa stanza", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "createNewSpace": "Nuovo spazio", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "commandHint_unban": "Sbanna l'utente fornito da questa stanza", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "importEmojis": "Importa Emoji", + "@importEmojis": {}, + "wasDirectChatDisplayName": "Chat vuota (era {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "La descrizione della chat non è ancora stata creata.", + "@noChatDescriptionYet": {}, + "removeFromBundle": "Rimuovi da questo bundle", + "@removeFromBundle": {}, + "confirmMatrixId": "Per eliminare il tuo account, conferma il tuo Matrix ID.", + "@confirmMatrixId": {}, + "learnMore": "Scopri di più", + "@learnMore": {}, + "notAnImage": "Non è un file immagine.", + "@notAnImage": {}, + "users": "Utenti", + "@users": {}, + "openGallery": "Apri la galleria", + "@openGallery": {}, + "chatDescriptionHasBeenChanged": "Descrizione della chat cambiata", + "@chatDescriptionHasBeenChanged": {}, + "newGroup": "Nuovo gruppo", + "@newGroup": {}, + "bundleName": "Nome del bundle", + "@bundleName": {}, + "dehydrateTor": "Utenti TOR: Esporta la sessione", + "@dehydrateTor": {}, + "removeFromSpace": "Rimuovi dallo spazio", + "@removeFromSpace": {}, + "commandHint_op": "Imposta il livello di privilegi dell'utente specificato (predefinito: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_join": "Unisciti alla stanza fornita", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "roomUpgradeDescription": "Questa chat sarà ricreata con la nuova versione della stanza. Tutti i partecipanti saranno avvertiti che devono passare alla nuova chat. Puoi leggere di più riguardo le versioni delle stanze su https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "commandHint_invite": "Invia l utente fornito in questa stanza", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "pleaseEnterANumber": "Per favore inserisci un numero maggiore di 0", + "@pleaseEnterANumber": {}, + "youKicked": "👞 Hai rimosso {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "profileNotFound": "Impossibile trovare l'utente sul server. Forse c'è un problema di connessione oppure l'utente non esiste.", + "@profileNotFound": {}, + "jump": "Salta", + "@jump": {}, + "reactedWith": "{sender} ha reagito con {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "sorryThatsNotPossible": "Scusa... questo non è possibile", + "@sorryThatsNotPossible": {}, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "shareInviteLink": "Condividi link d'invito", + "@shareInviteLink": {}, + "commandHint_markasdm": "Contrassegna questo Matrix ID come stanza di messaggi diretti", + "@commandHint_markasdm": {}, + "recoveryKeyLost": "Chiave di recupero smarrita?", + "@recoveryKeyLost": {}, + "cuddleContent": "{senderName} ti coccola", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "deviceKeys": "Chiavi del dispositivo:", + "@deviceKeys": {}, + "emoteKeyboardNoRecents": "Le emoticon recentemente usate appariranno qui...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Imposta tema:", + "@setTheme": {}, + "youJoinedTheChat": "Sei entrato/a nella chat", + "@youJoinedTheChat": {}, + "openVideoCamera": "Apri la fotocamera per un video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "markAsRead": "Segna come letto", + "@markAsRead": {}, + "widgetName": "Nome", + "@widgetName": {}, + "errorAddingWidget": "Errore aggiungendo il widget.", + "@errorAddingWidget": {}, + "commandHint_dm": "Avvia una chat diretta\nUsa --no-encryption per disabilitare la crittografia", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_hug": "Invia un abbraccio", + "@commandHint_hug": {}, + "replace": "Sostituisci", + "@replace": {}, + "youUnbannedUser": "Hai sbannato {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "newSpace": "Nuovo spazio", + "@newSpace": {}, + "emojis": "Emoji", + "@emojis": {}, + "commandHint_googly": "Invia degli occhi finti", + "@commandHint_googly": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "Per favore riprova più tardi o scegli un server diverso.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "createGroup": "Crea gruppo", + "@createGroup": {}, + "hydrateTorLong": "Hai esportato la tua sessione l'ultima volta con TOR? Importala velocemente e continua a chattare.", + "@hydrateTorLong": {}, + "time": "Tempo", + "@time": {}, + "custom": "Personalizzato", + "@custom": {}, + "noBackupWarning": "Attenzione! Senza abilitare il backup della chat, perderai l'accesso ai tuoi messaggi crittografati. Si consiglia vivamente di abilitare il backup della chat prima di disconnettersi.", + "@noBackupWarning": {}, + "storeInSecureStorageDescription": "Salva la chiave di recupero nell'archivio sicuro di questo dispositivo.", + "@storeInSecureStorageDescription": {}, + "openChat": "Apri la Chat", + "@openChat": {}, + "kickUserDescription": "L'utente è stato rimosso, ma non bannato. Nelle chat pubbliche, l'utente potrà rientrare quando vuole.", + "@kickUserDescription": {}, + "importNow": "Importa ora", + "@importNow": {}, + "pinMessage": "Fissa alla stanza", + "@pinMessage": {}, + "invite": "Invitare", + "@invite": {}, + "enableMultiAccounts": "(BETA) Abilita account multipli su questo dispositivo", + "@enableMultiAccounts": {}, + "indexedDbErrorTitle": "Problemi con la modalità privata", + "@indexedDbErrorTitle": {}, + "unsupportedAndroidVersionLong": "Questa funzionalità richiede una versione di Android più recente. Si prega di verificare la presenza di aggiornamenti o supporto per Lineage OS.", + "@unsupportedAndroidVersionLong": {}, + "storeSecurlyOnThisDevice": "Salva in modo sicuro su questo dispositivo", + "@storeSecurlyOnThisDevice": {}, + "screenSharingDetail": "Stai condividendo il tuo schermo in FuffyChat", + "@screenSharingDetail": {}, + "placeCall": "Fai una chiamata", + "@placeCall": {}, + "blockListDescription": "Puoi bloccare gli utenti che ti disturbano. Non sarai più in grado di ricevere messaggi o inviti alle stanze dalle persone che hai bloccato.", + "@blockListDescription": {}, + "blockedUsers": "Utenti bloccati", + "@blockedUsers": {}, + "blockUsername": "Nome utente da ignorare", + "@blockUsername": {}, + "createGroupAndInviteUsers": "Crea un gruppo e invita gli utenti", + "@createGroupAndInviteUsers": {}, + "startConversation": "Inizia una conversazione", + "@startConversation": {}, + "groupCanBeFoundViaSearch": "Il gruppo può essere cercato", + "@groupCanBeFoundViaSearch": {}, + "noUsersFoundWithQuery": "Sfortunatamente non è stato trovato nessun utente con \"{query}\". Per favore controlla se hai fatto un errore di battitura.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "block": "Blocca", + "@block": {}, + "yourGlobalUserIdIs": "Il tuo ID dell'utente globale è: ", + "@yourGlobalUserIdIs": {}, + "commandHint_sendraw": "Manda un json grezzo", + "@commandHint_sendraw": {}, + "wrongRecoveryKey": "Mi dispiace... questa non sembra essere la chiave di recupero corretta.", + "@wrongRecoveryKey": {}, + "groupName": "Nome gruppo", + "@groupName": {}, + "databaseMigrationTitle": "Il database è ottimizzato", + "@databaseMigrationTitle": {}, + "searchChatsRooms": "Cerca per #chat, @utenti...", + "@searchChatsRooms": {}, + "databaseMigrationBody": "Attendere prego. L'operazione potrebbe richiedere un momento.", + "@databaseMigrationBody": {}, + "youInvitedToBy": "📩 Sei stato invitato tramite link in:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "addChatOrSubSpace": "Aggiungi chat o sottospazio", + "@addChatOrSubSpace": {}, + "subspace": "Sottospazio", + "@subspace": {}, + "publicSpaces": "Spazio pubblico", + "@publicSpaces": {}, + "hidePresences": "Nascondere l'elenco degli stati?", + "@hidePresences": {}, + "pleaseEnterYourCurrentPassword": "Per favore inserisci la tua password attuale", + "@pleaseEnterYourCurrentPassword": {}, + "passwordIsWrong": "La password inserita è sbagliata", + "@passwordIsWrong": {}, + "databaseBuildErrorBody": "Impossibile costruire il database SQlite. L'applicazione proverà ad usare il database legacy per ora. Per favore segnala questo errore agli sviluppatori su {url}. Il messaggio di errore è: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "select": "Seleziona", + "@select": {}, + "newPassword": "Nuova password", + "@newPassword": {}, + "pleaseChooseAStrongPassword": "Per favore scegli una password forte", + "@pleaseChooseAStrongPassword": {}, + "thisDevice": "Questo dispositivo:", + "@thisDevice": {}, + "forwardMessageTo": "Inoltra messaggio in {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "verifyOtherUser": "🔐 Verifica altro utente", + "@verifyOtherUser": {}, + "verifyOtherUserDescription": "Se verifichi un altro utente, puoi essere certo di sapere a chi stai realmente scrivendo. 💪\n\nQuando inizi una verifica, tu e l'altro utente vedrete un popup nell'app. Lì vedrai una serie di emoji o numeri che dovrai confrontare tra loro.\n\nIl modo migliore per farlo è incontrarsi o avviare una videochiamata. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDevice": "🔐 Verifica altro dispositivo", + "@verifyOtherDevice": {}, + "verifyOtherDeviceDescription": "Quando verifichi un altro dispositivo, questi dispositivi possono scambiarsi le chiavi, aumentando la tua sicurezza complessiva. 💪 Quando inizi una verifica, apparirà un popup nell'app su entrambi i dispositivi. Lì vedrai una serie di emoji o numeri che dovrai confrontare tra loro. È meglio avere entrambi i dispositivi a portata di mano prima di iniziare la verifica. 🤳", + "@verifyOtherDeviceDescription": {}, + "discover": "Scopri", + "@discover": {}, + "presencesToggle": "Mostra i messaggi di stato di altri utenti", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "publicLink": "Link pubblico", + "@publicLink": {}, + "leaveEmptyToClearStatus": "Lascia vuoto per cancellare il tuo stato.", + "@leaveEmptyToClearStatus": {}, + "decline": "Declina", + "@decline": {}, + "transparent": "Trasparente", + "@transparent": {}, + "incomingMessages": "Messaggi in arrivo", + "@incomingMessages": {}, + "noChatsFoundHere": "Nessuna chat trovata. Inizia una nuova chat con qualcuno usando il pulsante qui sotto. ⤵️", + "@noChatsFoundHere": {}, + "joinedChats": "Chat a cui partecipi", + "@joinedChats": {}, + "unread": "Non letti", + "@unread": {}, + "space": "Spazio", + "@space": {}, + "spaces": "Spazi", + "@spaces": {}, + "notifyMeFor": "Avvisami per", + "@notifyMeFor": {}, + "invitedBy": "📩 Invitato da {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "knock": "Bussa", + "@knock": {}, + "hideInvalidOrUnknownMessageFormats": "Nascondi formati di messaggi non validi o sconosciuti", + "@hideInvalidOrUnknownMessageFormats": {}, + "overview": "Panoramica", + "@overview": {}, + "presenceStyle": "Presenza:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "swipeRightToLeftToReply": "Scorri da destra a sinistra per rispondere", + "@swipeRightToLeftToReply": {}, + "globalChatId": "ID chat globale", + "@globalChatId": {}, + "hideMemberChangesInPublicChats": "Nascondi le modifiche dei membri nelle chat pubbliche", + "@hideMemberChangesInPublicChats": {}, + "hideMemberChangesInPublicChatsBody": "Per migliorare la leggibilità, non mostrare nella cronologia della chat se qualcuno si unisce o abbandona una chat pubblica.", + "@hideMemberChangesInPublicChatsBody": {}, + "userWouldLikeToChangeTheChat": "{user} vorrebbe unirsi alla chat.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Non è stato ancora creato alcun link pubblico", + "@noPublicLinkHasBeenCreatedYet": {}, + "appLockDescription": "Blocca l'app con un codice PIN quando non è in uso", + "@appLockDescription": {}, + "noOneCanJoin": "Nessuno può unirsi", + "@noOneCanJoin": {}, + "usersMustKnock": "Gli utenti devono bussare", + "@usersMustKnock": {}, + "alwaysUse24HourFormat": "disattivato", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "accessAndVisibility": "Accesso e visibilità", + "@accessAndVisibility": {}, + "accessAndVisibilityDescription": "Chi è autorizzato a partecipare a questa chat e come è possibile scoprirla.", + "@accessAndVisibilityDescription": {}, + "calls": "Chiamate", + "@calls": {}, + "customEmojisAndStickers": "Emoji e adesivi personalizzati", + "@customEmojisAndStickers": {}, + "customEmojisAndStickersBody": "Aggiungi o condividi emoji o adesivi personalizzati che possono essere utilizzati in qualsiasi chat.", + "@customEmojisAndStickersBody": {}, + "hideRedactedMessages": "Mostra i messaggi rimossi", + "@hideRedactedMessages": {}, + "hideRedactedMessagesBody": "Se qualcuno rimuove un messaggio, il messaggio non sarà più visibile nella chat.", + "@hideRedactedMessagesBody": {}, + "passwordRecoverySettings": "Impostazioni di recupero password", + "@passwordRecoverySettings": {}, + "noMoreChatsFound": "Non sono state trovate altre chat...", + "@noMoreChatsFound": {}, + "countChatsAndCountParticipants": "{chats} chat e {participants} partecipanti", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "stickers": "Adesivi", + "@stickers": {}, + "searchMore": "Cerca di più...", + "@searchMore": {}, + "sessionLostBody": "La tua sessione è andata persa. Segnala questo errore agli sviluppatori all'indirizzo {url}. Il messaggio di errore è: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "formattedMessagesDescription": "Visualizza contenuti di messaggi complessi, come testo in grassetto, utilizzando il markdown.", + "@formattedMessagesDescription": {}, + "canceledKeyVerification": "{sender} ha annullato la verifica della chiave", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "chatPermissionsDescription": "Definisci quale livello di privilegi è necessario per determinate azioni in questa chat. I livelli di privilegi 0, 50 e 100 rappresentano solitamente utenti, moderatori e amministratori, ma qualsiasi valore intermedio è possibile.", + "@chatPermissionsDescription": {}, + "passwordsDoNotMatch": "Le password non corrispondono", + "@passwordsDoNotMatch": {}, + "initAppError": "Si è verificato un errore durante l'inizializzazione dell'app", + "@initAppError": {}, + "startedKeyVerification": "{sender} ha avviato la verifica della chiave", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "chatCanBeDiscoveredViaSearchOnServer": "La chat può essere trovata tramite la ricerca su {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "unreadChatsInApp": "{appname}: {unread} chat non lette", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "Al momento ci sono {count} utenti bloccati.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "nothingFound": "Non è stato trovato nulla...", + "@nothingFound": {}, + "joinSpace": "Unisciti allo spazio", + "@joinSpace": {}, + "commandHint_ignore": "Ignora il Matrix ID fornito", + "@commandHint_ignore": {}, + "commandHint_unignore": "Ignora il Matrix ID specificato", + "@commandHint_unignore": {}, + "noDatabaseEncryption": "La crittografia del database non è supportata su questa piattaforma", + "@noDatabaseEncryption": {}, + "knocking": "Bussare", + "@knocking": {}, + "sendReadReceipts": "Invia ricevute di lettura", + "@sendReadReceipts": {}, + "knockRestricted": "Limitato al bussare", + "@knockRestricted": {}, + "restricted": "Limitato", + "@restricted": {}, + "publicChatAddresses": "Indirizzi di chat pubblici", + "@publicChatAddresses": {}, + "createNewAddress": "Crea un nuovo indirizzo", + "@createNewAddress": {}, + "userRole": "Ruolo utente", + "@userRole": {}, + "minimumPowerLevel": "{level} è il livello minimo di privilegi.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "Cerca nella chat \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "gallery": "Galleria", + "@gallery": {}, + "formattedMessages": "Messaggi formattati", + "@formattedMessages": {}, + "files": "File", + "@files": {}, + "restoreSessionBody": "L'app ora tenta di ripristinare la sessione dal backup. Segnala questo errore agli sviluppatori all'indirizzo {url}. Il messaggio di errore è: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "acceptedKeyVerification": "{sender} ha accettato la verifica della chiave", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} ha completato la verifica della chiave", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} è pronto per la verifica della chiave", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "searchForUsers": "Cerca @utenti...", + "@searchForUsers": {}, + "sendTypingNotificationsDescription": "Gli altri partecipanti alla chat possono vedere quando stai scrivendo un nuovo messaggio.", + "@sendTypingNotificationsDescription": {}, + "sendReadReceiptsDescription": "Gli altri partecipanti alla chat possono vedere quando hai letto un messaggio.", + "@sendReadReceiptsDescription": {}, + "requestedKeyVerification": "{sender} ha richiesto la verifica della chiave", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "changeTheChatPermissions": "Cambia i permessi della chat", + "@changeTheChatPermissions": {}, + "changeTheVisibilityOfChatHistory": "Cambia la visibilità della cronologia chat", + "@changeTheVisibilityOfChatHistory": {}, + "changeTheCanonicalRoomAlias": "Cambia l'indirizzo principale della chat pubblica", + "@changeTheCanonicalRoomAlias": {}, + "sendRoomNotifications": "Invia notifiche alla @stanza", + "@sendRoomNotifications": {}, + "sendCanceled": "Invio annullato", + "@sendCanceled": {}, + "calculatingFileSize": "Calcolo della dimensione del file...", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "Preparazione per l'invio dell'allegato...", + "@prepareSendingAttachment": {}, + "sendingAttachment": "Invio allegato...", + "@sendingAttachment": {}, + "compressVideo": "Compressione video...", + "@compressVideo": {}, + "generatingVideoThumbnail": "Generazione miniatura video...", + "@generatingVideoThumbnail": {}, + "sendingAttachmentCountOfCount": "Invio dell'allegato {index} di {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Limite server raggiunto! Attendere {seconds} secondi...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Uno dei tuoi dispositivi non è verificato", + "@oneOfYourDevicesIsNotVerified": {}, + "noticeChatBackupDeviceVerification": "Nota: quando colleghi tutti i tuoi dispositivi al backup della chat, vengono verificati automaticamente.", + "@noticeChatBackupDeviceVerification": {}, + "moderatorLevel": "{level} - Moderatore", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheDescriptionOfTheGroup": "Cambia la descrizione della chat", + "@changeTheDescriptionOfTheGroup": {}, + "updateInstalled": "🎉 Aggiornamento {version} installato!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "inviteOtherUsers": "Invita altri utenti a questa chat", + "@inviteOtherUsers": {}, + "userLevel": "{level} - Utente", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Amministratore", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Modifica le impostazioni generali della chat", + "@changeGeneralChatSettings": {}, + "loginWithMatrixId": "Accedi con il Matrix ID", + "@loginWithMatrixId": {}, + "homeserverDescription": "Tutti i tuoi dati sono archiviati sull'homeserver, proprio come un provider di posta elettronica. Puoi scegliere quale homeserver vuoi usare, mentre puoi comunque comunicare con tutti. Scopri di più su https://matrix.org.", + "@homeserverDescription": {}, + "discoverHomeservers": "Scopri gli homeserver", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "Cos'è un homeserver?", + "@whatIsAHomeserver": {}, + "changelog": "Registro delle modifiche", + "@changelog": {}, + "doesNotSeemToBeAValidHomeserver": "Non sembra essere un homeserver compatibile. URL sbagliato?", + "@doesNotSeemToBeAValidHomeserver": {}, + "goToSpace": "Vai allo spazio: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Contrassegna come non letto", + "@markAsUnread": {}, + "aboutHomeserver": "Informazioni su {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "continueText": "Continua", + "@continueText": {}, + "welcomeText": "Hey Hey 👋 Questa è FluffyChat. Puoi accedere a qualsiasi homeserver compatibile con https://matrix.org. E poi chattare con chiunque. È un'enorme rete di messaggistica decentralizzata!", + "@welcomeText": {}, + "blur": "Sfocatura:", + "@blur": {}, + "opacity": "Opacità:", + "@opacity": {}, + "setWallpaper": "Imposta sfondo", + "@setWallpaper": {}, + "manageAccount": "Gestisci account", + "@manageAccount": {}, + "noContactInformationProvided": "Il server non fornisce alcuna informazione di contatto valida", + "@noContactInformationProvided": {}, + "contactServerAdmin": "Contatta l'amministratore del server", + "@contactServerAdmin": {}, + "contactServerSecurity": "Contatta la sicurezza del server", + "@contactServerSecurity": {}, + "supportPage": "Pagina di supporto", + "@supportPage": {}, + "serverInformation": "Informazioni sul server:", + "@serverInformation": {}, + "name": "Nome", + "@name": {}, + "version": "Versione", + "@version": {}, + "website": "Sito web", + "@website": {}, + "boldText": "Testo in grassetto", + "@boldText": {}, + "italicText": "Testo in corsivo", + "@italicText": {}, + "strikeThrough": "Barrato", + "@strikeThrough": {}, + "pleaseFillOut": "Si prega di compilare", + "@pleaseFillOut": {}, + "invalidUrl": "URL non valido", + "@invalidUrl": {}, + "addLink": "Aggiungi collegamento", + "@addLink": {}, + "unableToJoinChat": "Impossibile partecipare alla chat. Forse l'altra parte ha già chiuso la conversazione.", + "@unableToJoinChat": {}, + "sendImages": "Invia {count} immagine", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Comprimere", + "@compress": {}, + "contentNotificationSettings": "Impostazioni del contenuto di notifica", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "Impostazioni di notifica generale", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "Impostazioni di notifica della stanza", + "@roomNotificationSettings": {}, + "userSpecificNotificationSettings": "Impostazioni di notifica specifiche dell'utente", + "@userSpecificNotificationSettings": {}, + "otherNotificationSettings": "Altre impostazioni di notifica", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "Contiene il nome utente", + "@notificationRuleContainsUserName": {}, + "notificationRuleContainsUserNameDescription": "Notifica l'utente quando un messaggio contiene il proprio nome utente.", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleMaster": "Silenzia tutte le notifiche", + "@notificationRuleMaster": {}, + "notificationRuleMasterDescription": "Sovrascive tutte le altre regole e disabilita tutte le notifiche.", + "@notificationRuleMasterDescription": {}, + "notificationRuleSuppressNotices": "Silenziare i messaggi automatizzati", + "@notificationRuleSuppressNotices": {}, + "notificationRuleSuppressNoticesDescription": "Silenzia le notifiche da client automatizzati come i bot.", + "@notificationRuleSuppressNoticesDescription": {}, + "notificationRuleInviteForMeDescription": "Notifica l'utente quando viene invitato a una stanza.", + "@notificationRuleInviteForMeDescription": {}, + "notificationRuleMemberEvent": "Eventi per i membri", + "@notificationRuleMemberEvent": {}, + "notificationRuleInviteForMe": "Inviti per me", + "@notificationRuleInviteForMe": {}, + "notificationRuleIsUserMentionDescription": "Notifica l'utente quando viene menzionato direttamente in un messaggio.", + "@notificationRuleIsUserMentionDescription": {}, + "notificationRuleContainsDisplayNameDescription": "Notifica l'utente quando un messaggio contiene il proprio nome visualizzato.", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleIsRoomMention": "Menzioni della stanza", + "@notificationRuleIsRoomMention": {}, + "notificationRuleIsUserMention": "Menzioni dell'utente", + "@notificationRuleIsUserMention": {}, + "notificationRuleRoomnotif": "Notifiche della stanza", + "@notificationRuleRoomnotif": {}, + "notificationRuleRoomnotifDescription": "Notifica l'utente quando un messaggio contiene '@room'.", + "@notificationRuleRoomnotifDescription": {}, + "notificationRuleTombstone": "Tombstone", + "@notificationRuleTombstone": {}, + "notificationRuleTombstoneDescription": "Notifica all'utente i messaggi di disattivazione della stanza.", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleReaction": "Reazioni", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "Silenzia le notifiche per le reazioni.", + "@notificationRuleReactionDescription": {}, + "notificationRuleRoomServerAcl": "ACL del server della stanza", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleRoomServerAclDescription": "Silenzia le notifiche per gli elenchi di controllo degli accessi del server della stanza (ACL).", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleSuppressEdits": "Silenzia le modifiche", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "Silenzia le notifiche per i messaggi modificati.", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleCallDescription": "Notifica all'utente le chiamate.", + "@notificationRuleCallDescription": {}, + "notificationRuleEncryptedRoomOneToOne": "Stanze crittografate One-to-One", + "@notificationRuleEncryptedRoomOneToOne": {}, + "notificationRuleRoomOneToOne": "Stanze One-to-One", + "@notificationRuleRoomOneToOne": {}, + "notificationRuleRoomOneToOneDescription": "Notifica all'utente i messaggi nelle stanze one-to-one.", + "@notificationRuleRoomOneToOneDescription": {}, + "notificationRuleMessage": "Messaggi", + "@notificationRuleMessage": {}, + "notificationRuleMessageDescription": "Notifica all'utente i messaggi generali.", + "@notificationRuleMessageDescription": {}, + "notificationRuleEncryptedDescription": "Notifica all'utente i messaggi nelle stanze crittografate.", + "@notificationRuleEncryptedDescription": {}, + "notificationRuleEncrypted": "Crittografate", + "@notificationRuleEncrypted": {}, + "notificationRuleJitsi": "Jitsi", + "@notificationRuleJitsi": {}, + "notificationRuleJitsiDescription": "Notifica all'utente gli eventi del widget Jitsi.", + "@notificationRuleJitsiDescription": {}, + "notificationRuleServerAcl": "Silenziare gli eventi ACL del server", + "@notificationRuleServerAcl": {}, + "notificationRuleServerAclDescription": "Silenzia le notifiche per gli eventi ACL del server.", + "@notificationRuleServerAclDescription": {}, + "unknownPushRule": "Regola push '{rule}' sconosciuta", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Se si elimina questa impostazione di notifica, questo non può essere annullato.", + "@deletePushRuleCanNotBeUndone": {}, + "more": "Di più", + "@more": {}, + "newChatRequest": "📩 Nuova richiesta di chat", + "@newChatRequest": {}, + "shareKeysWith": "Condividi le chiavi con...", + "@shareKeysWith": {}, + "shareKeysWithDescription": "Quali dispositivi dovrebbero essere fidati in modo che possano leggere i tuoi messaggi in chat crittografate?", + "@shareKeysWithDescription": {}, + "allDevices": "Tutti i dispositivi", + "@allDevices": {}, + "crossVerifiedDevicesIfEnabled": "Verifica incrociata dei dispositivi, se abilitata", + "@crossVerifiedDevicesIfEnabled": {}, + "crossVerifiedDevices": "Dispositivi con verifica incrociata", + "@crossVerifiedDevices": {}, + "verifiedDevicesOnly": "Solo dispositivi verificati", + "@verifiedDevicesOnly": {}, + "appWantsToUseForLogin": "Usa '{server}' per accedere", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "open": "Apri", + "@open": {}, + "appWantsToUseForLoginDescription": "Con la presente consenti all'app e al sito web di condividere informazioni su di te.", + "@appWantsToUseForLoginDescription": {}, + "appIntroduction": "FluffyChat ti consente di chattare con i tuoi amici attraverso diverse app di messaggistica. Ulteriori informazioni su https://matrix.org o semplicemente tocca *Continua*.", + "@appIntroduction": {}, + "waitingForServer": "In attesa del server...", + "@waitingForServer": {}, + "synchronizingPleaseWaitCounter": " Sincronizzazione… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "notificationRuleMemberEventDescription": "Silenzia le notifiche per gli eventi dei membri.", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleContainsDisplayName": "Contiene nome visualizzato", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleIsRoomMentionDescription": "Notifica l'utente quando c'è una menzione della stanza.", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleCall": "Chiamate", + "@notificationRuleCall": {}, + "notificationRuleEncryptedRoomOneToOneDescription": "Notifica all'utente i messaggi in stanze crittografate one-to-one.", + "@notificationRuleEncryptedRoomOneToOneDescription": {}, + "previous": "Precedente", + "@previous": {}, + "otherPartyNotLoggedIn": "L'altra parte non è attualmente connessa e quindi non può ricevere messaggi!", + "@otherPartyNotLoggedIn": {}, + "takeAPhoto": "Scatta una foto", + "@takeAPhoto": {}, + "recordAVideo": "Registra un video", + "@recordAVideo": {}, + "notSupportedOnThisDevice": "Non supportato su questo dispositivo", + "@notSupportedOnThisDevice": {}, + "enterNewChat": "Inizia nuova chat", + "@enterNewChat": {}, + "setCustomPermissionLevel": "Imposta livello di permesso personalizzato", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Scegli un ruolo predefinito qui sotto o inserisci un livello di permesso personalizzato tra 0 e 100.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Ignora utente", + "@ignoreUser": {}, + "normalUser": "Utente normale", + "@normalUser": {}, + "commandHint_roomupgrade": "Aggiorna questa stanza alla versione specificata", + "@commandHint_roomupgrade": {}, + "optionalMessage": "Messaggio (opzionale)...", + "@optionalMessage": {}, + "approve": "Approva", + "@approve": {}, + "youHaveKnocked": "Hai bussato", + "@youHaveKnocked": {}, + "pleaseWaitUntilInvited": "Ora attendi, finché qualcuno dalla stanza non ti invita.", + "@pleaseWaitUntilInvited": {}, + "checkList": "Checklist", + "@checkList": {}, + "countInvited": "{count} invitati", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Messaggio vocale da {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "commandHint_logout": "Disconnetti questo dispositivo", + "@commandHint_logout": {}, + "commandHint_logoutall": "Disconnetti tutti i dispositivi attivi", + "@commandHint_logoutall": {}, + "displayNavigationRail": "Mostra barra di navigazione su mobile", + "@displayNavigationRail": {}, + "customReaction": "Reazione personalizzata", + "@customReaction": {}, + "moreEvents": "Altri eventi", + "@moreEvents": {}, + "declineInvitation": "Rifiuta invito", + "@declineInvitation": {}, + "noMessagesYet": "Ancora nessun messaggio", + "@noMessagesYet": {}, + "longPressToRecordVoiceMessage": "Premi a lungo per registrare un messaggio vocale.", + "@longPressToRecordVoiceMessage": {}, + "pause": "Pausa", + "@pause": {}, + "resume": "Riprendi", + "@resume": {}, + "newSubSpace": "Nuovo sotto sapzio", + "@newSubSpace": {}, + "moveToDifferentSpace": "Cambia spazio", + "@moveToDifferentSpace": {}, + "moveUp": "Muoviti sopra", + "@moveUp": {}, + "moveDown": "Muoviti sotto", + "@moveDown": {} +} diff --git a/assets/l10n/intl_ja.arb b/lib/l10n/intl_ja.arb similarity index 69% rename from assets/l10n/intl_ja.arb rename to lib/l10n/intl_ja.arb index a5016852f..a857c4c04 100644 --- a/assets/l10n/intl_ja.arb +++ b/lib/l10n/intl_ja.arb @@ -3,2347 +3,2479 @@ "@@last_modified": "2021-08-14 12:41:09.978060", "about": "このアプリについて", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "承諾する", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "👍{username}が招待を承諾しました", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "アカウント", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "activatedEndToEndEncryption": "🔐{username}がエンドツーエンド暗号化を有効にしました", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "addEmail": "Eメールを追加", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "admin": "管理者", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "エイリアス", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "すべて", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "answeredTheCall": "{senderName}は通話に出ました", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "誰でも参加できる", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "appLock": "アプリのロック", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "アーカイブ", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "ゲストユーザーの参加を許可する", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "これでよろしいですか?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSureYouWantToLogout": "ログアウトしてよろしいですか?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "他の人を署名するためにはパスフレーズやリカバリーキーを入力してください。", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "{username}の検証リクエストを承認しますか?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "badServerLoginTypesException": "ホームサーバーでサポートされているログインタイプ:\n{serverVersions}\nアプリがサポートしているログインタイプ:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "badServerVersionsException": "ホームサーバーでサポートされているバージョン:\n{serverVersions}\nアプリでは{supportedVersions}しかサポートされていません", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "banFromChat": "チャットからBANする", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "BANされています", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "{username}が{targetName}をBANしました", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "blockDevice": "デバイスをブロックする", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "ブロックしました", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "ボットメッセージ", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "キャンセル", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "changeDeviceName": "デバイス名を変更", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "{username}がチャットアバターを変更しました", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, - "changedTheChatDescriptionTo": "{username}がチャットの説明を「{description}」に変更しました", + "changedTheChatDescriptionTo": "{username}がチャットの説明を「{description}」に変更した", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, - "changedTheChatNameTo": "{username}がチャットの名前を「{chatname}」に変更しました", + "changedTheChatNameTo": "{username}がチャットの名前を「{chatname}」に変更した", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheChatPermissions": "{username}がチャットの権限を変更しました", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, - "changedTheDisplaynameTo": "{username}が表示名を「{displayname}」に変更しました", + "changedTheDisplaynameTo": "{username}が表示名を「{displayname}」に変更した", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username}がゲストのアクセスルールを変更しました", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username}がゲストのアクセスルールを{rules}に変更しました", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheHistoryVisibility": "{username}が履歴の表示設定を変更しました", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "{username}が履歴の表示設定を{rules}に変更しました", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRules": "{username}が参加ルールを変更しました", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username}が参加ルールを{joinRules}に変更しました", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username}がアバターを変更しました", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomAliases": "{username}が部屋のエイリアスを変更しました", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "{username}が招待リンクを変更しました", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changePassword": "パスワードを変更", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheHomeserver": "ホームサーバーの変更", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "スタイルを変更する", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheNameOfTheGroup": "グループの名前を変更する", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "暗号が破損しています", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "チャット", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackup": "チャットのバックアップ", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackupDescription": "古いメッセージはリカバリーキーで保護されます。紛失しないようにご注意ください。", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "チャットの詳細", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chats": "チャット", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "強いパスワードを選択してください", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "アーカイブを消去", - "@clearArchive": {}, "close": "閉じる", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "compareEmojiMatch": "表示されている絵文字が他のデバイスで表示されているものと一致するか確認してください:", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "表示されている数字が他のデバイスで表示されているものと一致するか確認してください:", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "configureChat": "チャットの設定", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "確認", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "接続", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "contactHasBeenInvitedToTheGroup": "連絡先に登録された人が招待されました", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "表示名を含んでいます", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "ユーザー名を含んでいます", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "サーバー管理者に通報されました", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "クリップボードにコピーされました", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "コピー", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "クリップボードにコピー", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "メッセージを解読できませんでした: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "countParticipants": "{count}名の参加者", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "create": "作成", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "createdTheChat": "💬 {username}がチャットを作成しました", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "currentlyActive": "現在アクティブです", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "ダーク", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{month}-{day}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "dateWithYear": "{year}/{month}/{day}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "deactivateAccountWarning": "あなたのアカウントを無効化します。この操作は元に戻せません!よろしいですか?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "defaultPermissionLevel": "デフォルトの権限レベル", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "削除", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "アカウントの削除", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "メッセージの削除", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "デバイス", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "デバイスID", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "デバイス", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "ダイレクトチャット", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "表示名が変更されました", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "ファイルのダウンロード", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "編集", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "ブロックしたサーバーを編集", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "表示名を編集", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "ルームエイリアスを編集", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "部屋のアバターを編集する", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Emoteはすでに存在します!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "不正なEmoteショートコード!", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "部屋のEmoteパック", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Emote設定", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteShortcode": "Emoteショートコード", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Emoteショートコードと画像を選択してください!", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "空のチャット", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "emoteをグローバルに有効にする", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "暗号化を有効にする", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryptionWarning": "一度暗号化を有効にするともとに戻せません。よろしいですか?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "暗号化", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "暗号化", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "暗号化されていません", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName}は通話を切断しました", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "enterAnEmailAddress": "メールアドレスを入力してください", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "enterYourHomeserver": "ホームサーバーを入力してください", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "everythingReady": "すべての準備は完了しました!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "とても攻撃的", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "ファイル名", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "フォントサイズ", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "進む", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "fromJoining": "参加時点から閲覧可能", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "fromTheInvitation": "招待時点から閲覧可能", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "新規ルームへ", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "グループ", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "グループは公開されています", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "groups": "グループ", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "groupWith": "{displayname}とグループを作成する", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "guestsAreForbidden": "ゲストは許可されていません", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "ゲストが許可されています", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "hasWithdrawnTheInvitationFor": "{targetName}の招待を{username}が取り下げました", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "help": "ヘルプ", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "hideRedactedEvents": "編集済みイベントを非表示にする", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "不明なイベントを非表示にする", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "howOffensiveIsThisContent": "どのくらい攻撃的でしたか?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "ID", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "アイデンティティ", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignore": "無視する", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "無視されたユーザー", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "リンクをクリックしました", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "パスフレーズかリカバリーキーが間違っています", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "非攻撃的", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "連絡先から招待する", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "連絡先から{groupName}に招待する", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "invited": "招待されました", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUser": "📩 {username} が {targetName} を招待しました", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "invitedUsersOnly": "招待されたユーザーのみ", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteForMe": "自分への招待", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, - "inviteText": "{username}がFluffyChatにあなたを招待しました. \n1. FluffyChatをインストールしてください: https://fluffychat.im \n2. 新しくアカウントを作成するかサインインしてください\n3. 招待リンクを開いてください: {link}", + "inviteText": "{username}があなたをFluffyChatに招待しました。\n1. FluffyChatをインストール: fluffychat.im \n2. アカウントの作成、またはサインインを行う\n3. 招待リンクを開く\n {link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "isTyping": "が入力しています…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "joinedTheChat": "👋 {username} がチャットに参加しました", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "joinRoom": "部屋に参加", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "kicked": "👞 {username} は {targetName} をキックしました", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickedAndBanned": "🙅 {username} が {targetName} をキックしブロックしました", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickFromChat": "チャットからキックする", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "lastActiveAgo": "最終アクティブ: {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "leave": "退室する", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "leftTheChat": "退室しました", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "ライセンス", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "ライト", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "loadCountMoreParticipants": "あと{count}名参加者を読み込む", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "loadingPleaseWait": "読み込み中…お待ちください。", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "loadMore": "更に読み込む…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "ログイン", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "logInTo": "{homeserver}にログインする", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "logout": "ログアウト", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "memberChanges": "メンバーの変更", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "メンション", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "メッセージ", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "モデレータ", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "muteChat": "チャットのミュート", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "現時点では、エンドツーエンドの暗号化を使用するにはPantalaimonが必要であることに注意してください。", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "新規チャット", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "💬 FluffyChatに新しいメッセージがあります", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newVerificationRequest": "認証リクエスト!", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "次へ", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "いいえ", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "サーバーに接続できません", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "noEmotesFound": "Emoteは見つかりませんでした😕", "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "ルームを非公開にした後暗号化を有効にできます。", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "noGoogleServicesWarning": "あなたのスマホにはGoogleサービスがないようですね。プライバシーを保護するための良い選択です!プッシュ通知を受け取るには https://microg.org/ または https://unifiedpush.org/ を使うことをお勧めします。", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "none": "なし", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "パスワードを回復する方法をまだ追加していません。", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "noPermission": "権限がありません", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "部屋は見つかりませんでした…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "通知", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "このアカウントでは通知が有効です", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "numUsersTyping": "{count}人が入力中…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "offensive": "攻撃的", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "offline": "オフライン", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "ok": "OK", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "オンライン", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "onlineKeyBackupEnabled": "オンライン鍵バックアップは使用されています", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "おっと、何かがうまくいきませんでした…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "アプリを開いてメッセージを確認してください", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "カメラを開く", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "participant": "参加者", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "passphraseOrKey": "パスフレーズかリカバリーキー", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "パスワード", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "パスワードを忘れた", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "パスワードが変更されました", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "パスワードリカバリー", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "人々", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "画像を選択してください", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "ピン", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "play": "{fileName}を再生する", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "pleaseChooseAPasscode": "パスコードを選んでください", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseClickOnLink": "メールのリンクから進めてください。", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "アプリのロック用に4桁の数字を入力してください。空欄の場合は無効になります。", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "パスワードを入力してください", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "PINを入力してください", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "ユーザー名を入力してください", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseFollowInstructionsOnWeb": "ウェブサイトにあるやり方を見てから次をタップしてください。", "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "privacy": "プライバシー", "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "publicRooms": "公開された部屋", "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "pushRules": "ルールを追加する", "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, "reason": "理由", "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "recording": "録音中", "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "redactedAnEvent": "{username}がイベントを編集しました", "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "redactMessage": "メッセージを書く", "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "reject": "拒否", "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "rejectedTheInvitation": "{username}は招待を拒否しました", "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "rejoin": "再参加", "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "remove": "消去", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "removeAllOtherDevices": "他のデバイスをすべて削除", "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "removedBy": "{username}によって削除されました", "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removeDevice": "デバイスの削除", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unbanFromChat": "チャットからのブロックを解除する", "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "リッチメッセージをレンダリングする", - "@renderRichContent": { - "type": "text", + "type": "String", "placeholders": {} }, "replaceRoomWithNewerVersion": "部屋を新しいバージョンに変更する", "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "reply": "返信", "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "reportMessage": "メッセージを通報", "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "requestPermission": "権限を要求する", "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "roomHasBeenUpgraded": "部屋はアップグレードされました", "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "roomVersion": "ルームバージョン", "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "search": "検索", "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "security": "セキュリティ", "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "seenByUser": "{username}が既読", "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "send": "送信", "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAMessage": "メッセージを送信", "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAudio": "音声の送信", "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "sendFile": "ファイルを送信", "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "sendImage": "画像の送信", "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendMessages": "メッセージを送る", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOriginal": "オリジナルの送信", "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "sendVideo": "動画を送信", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAFile": "📁 {username}はファイルを送信しました", "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAnAudio": "🎤 {username}は音声を送信しました", "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAPicture": "🖼️ {username}は画像を送信しました", "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentASticker": "😊 {username}はステッカーを送信しました", "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAVideo": "🎥 {username}は動画を送信しました", "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentCallInformations": "{senderName}は通話情報を送信しました", "@sentCallInformations": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "setAsCanonicalAlias": "メインエイリアスに設定", "@setAsCanonicalAlias": { - "type": "text", + "type": "String", "placeholders": {} }, "setCustomEmotes": "カスタムエモートの設定", "@setCustomEmotes": { - "type": "text", + "type": "String", "placeholders": {} }, "setInvitationLink": "招待リンクを設定する", "@setInvitationLink": { - "type": "text", + "type": "String", "placeholders": {} }, "setPermissionsLevel": "権限レベルをセット", "@setPermissionsLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "setStatus": "ステータスの設定", "@setStatus": { - "type": "text", + "type": "String", "placeholders": {} }, "settings": "設定", "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, "share": "共有", "@share": { - "type": "text", + "type": "String", "placeholders": {} }, "sharedTheLocation": "{username}は現在地を共有しました", "@sharedTheLocation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "showPassword": "パスワードを表示", "@showPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "skip": "スキップ", "@skip": { - "type": "text", + "type": "String", "placeholders": {} }, "sourceCode": "ソースコード", "@sourceCode": { - "type": "text", + "type": "String", "placeholders": {} }, "startedACall": "{senderName}は通話を開始しました", "@startedACall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "status": "ステータス", "@status": { - "type": "text", + "type": "String", "placeholders": {} }, "statusExampleMessage": "お元気ですか?", "@statusExampleMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "submit": "送信", "@submit": { - "type": "text", + "type": "String", "placeholders": {} }, "systemTheme": "システム", "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "theyDontMatch": "違います", "@theyDontMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "theyMatch": "一致しています", "@theyMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "title": "FluffyChat", "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, "toggleFavorite": "お気に入り切り替え", "@toggleFavorite": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleMuted": "ミュート切り替え", "@toggleMuted": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleUnread": "既読/未読にマーク", "@toggleUnread": { - "type": "text", + "type": "String", "placeholders": {} }, "tooManyRequestsWarning": "リクエストが多すぎます。また後で試してみてください!", "@tooManyRequestsWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "transferFromAnotherDevice": "違うデバイスから移行する", "@transferFromAnotherDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "tryToSendAgain": "送信し直してみる", "@tryToSendAgain": { - "type": "text", + "type": "String", "placeholders": {} }, "unavailable": "不在", "@unavailable": { - "type": "text", + "type": "String", "placeholders": {} }, "unbannedUser": "{username}が{targetName}のBANを解除しました", "@unbannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "unblockDevice": "デバイスをブロック解除する", "@unblockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownDevice": "未知デバイス", "@unknownDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEncryptionAlgorithm": "未知の暗号化アルゴリズム", "@unknownEncryptionAlgorithm": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEvent": "未知のイベント'{type}'", "@unknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "type": {} + "type": { + "type": "String" + } } }, "unmuteChat": "チャットをミュート解除する", "@unmuteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "unpin": "ピンを外す", "@unpin": { - "type": "text", + "type": "String", "placeholders": {} }, "unreadChats": "{unreadCount, plural, =1{1件の未読メッセージ} other{{unreadCount}件の未読メッセージ}}", "@unreadChats": { - "type": "text", + "type": "String", "placeholders": { - "unreadCount": {} + "unreadCount": { + "type": "int" + } } }, "userAndOthersAreTyping": "{username}と他{count}名が入力しています…", "@userAndOthersAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "count": {} + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "userAndUserAreTyping": "{username}と{username2}が入力しています…", "@userAndUserAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "username2": {} + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } } }, "userIsTyping": "{username}が入力しています…", "@userIsTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "userLeftTheChat": "🚪 {username}はチャットから退室しました", "@userLeftTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "username": "ユーザー名", "@username": { - "type": "text", + "type": "String", "placeholders": {} }, "userSentUnknownEvent": "{username}は{type}イベントを送信しました", "@userSentUnknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "type": {} + "username": { + "type": "String" + }, + "type": { + "type": "String" + } } }, "verified": "検証済み", "@verified": { - "type": "text", + "type": "String", "placeholders": {} }, "verify": "確認", "@verify": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyStart": "確認を始める", "@verifyStart": { - "type": "text", + "type": "String", "placeholders": {} }, "verifySuccess": "確認が完了しました!", "@verifySuccess": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyTitle": "他のアカウントを確認中", "@verifyTitle": { - "type": "text", + "type": "String", "placeholders": {} }, "videoCall": "音声通話", "@videoCall": { - "type": "text", + "type": "String", "placeholders": {} }, "visibilityOfTheChatHistory": "チャット履歴の表示", "@visibilityOfTheChatHistory": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForAllParticipants": "すべての参加者が閲覧可能", "@visibleForAllParticipants": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForEveryone": "すべての人が閲覧可能", "@visibleForEveryone": { - "type": "text", + "type": "String", "placeholders": {} }, "voiceMessage": "ボイスメッセージ", "@voiceMessage": { - "type": "text", + "type": "String", "placeholders": {} }, - "waitingPartnerAcceptRequest": "パートナーのリクエスト承諾待ちです...", + "waitingPartnerAcceptRequest": "パートナーのリクエスト承諾待ちです…", "@waitingPartnerAcceptRequest": { - "type": "text", + "type": "String", "placeholders": {} }, - "waitingPartnerEmoji": "パートナーの絵文字承諾待ちです...", + "waitingPartnerEmoji": "パートナーの絵文字承諾待ちです…", "@waitingPartnerEmoji": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerNumbers": "パートナーの数字承諾待ちです…", "@waitingPartnerNumbers": { - "type": "text", + "type": "String", "placeholders": {} }, - "wallpaper": "壁紙", + "wallpaper": "壁紙:", "@wallpaper": { - "type": "text", + "type": "String", "placeholders": {} }, "warning": "警告!", "@warning": { - "type": "text", + "type": "String", "placeholders": {} }, "weSentYouAnEmail": "あなたにメールを送信しました", "@weSentYouAnEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "whoCanPerformWhichAction": "誰がどの操作を実行できるか", "@whoCanPerformWhichAction": { - "type": "text", + "type": "String", "placeholders": {} }, "whoIsAllowedToJoinThisGroup": "誰がこのチャットに入れますか", "@whoIsAllowedToJoinThisGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "whyDoYouWantToReportThis": "これを通報する理由", "@whyDoYouWantToReportThis": { - "type": "text", + "type": "String", "placeholders": {} }, "wipeChatBackup": "チャットのバックアップを消去して、新しいリカバリーキーを作りますか?", "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "withTheseAddressesRecoveryDescription": "これらのアドレスを使用すると、パスワードを回復することができます。", "@withTheseAddressesRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "writeAMessage": "メッセージを入力してください…", "@writeAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "yes": "はい", "@yes": { - "type": "text", + "type": "String", "placeholders": {} }, "you": "あなた", "@you": { - "type": "text", + "type": "String", "placeholders": {} }, "youAreNoLongerParticipatingInThisChat": "あなたはもうこのチャットの参加者ではありません", "@youAreNoLongerParticipatingInThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "youHaveBeenBannedFromThisChat": "チャットからBANされてしまいました", "@youHaveBeenBannedFromThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "yourPublicKey": "あなたの公開鍵", "@yourPublicKey": { - "type": "text", + "type": "String", "placeholders": {} }, "allChats": "すべて会話", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "addToSpace": "スペースに追加", - "@addToSpace": {}, "cantOpenUri": "URIが開けません {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "repeatPassword": "パスワードを繰り返そ", - "@repeatPassword": {}, "autoplayImages": "GIFを自動的に再生する", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "yourChatBackupHasBeenSetUp": "チャットバックアップを設定ました。", - "@yourChatBackupHasBeenSetUp": {}, "sendOnEnter": "Enterで送信", - "@sendOnEnter": {}, "changeYourAvatar": "アバタるを変化しする", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "chatHasBeenAddedToThisSpace": "このスペースにチャットが追加されました", - "@chatHasBeenAddedToThisSpace": {}, "commandHint_ban": "このユーザーを禁止する", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_clearcache": "キャッシュをクリアする", "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "commandInvalid": "コマンドが無効", "@commandInvalid": { - "type": "text" + "type": "String" }, "commandHint_create": "空のグループチャットを作成\n暗号化を無効にするには、--no-encryption を使用", "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "commandHint_discardsession": "セッションを破棄", "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "confirmMatrixId": "アカウントを削除するには、Matrix IDを確認してください。", - "@confirmMatrixId": {}, "commandHint_markasgroup": "グループとしてマーク", - "@commandHint_markasgroup": {}, "commandHint_join": "指定した部屋に参加", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_send": "テキストを送信", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "hydrate": "バックアップファイルから復元", - "@hydrate": {}, "commandHint_html": "HTML形式のテキストを送信", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "指定したユーザーをこの部屋に招待", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandMissing": "{command} はコマンドではありません。", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "oneClientLoggedOut": "クライアントの 1つがログアウトしました", - "@oneClientLoggedOut": {}, "addAccount": "アカウントを追加", - "@addAccount": {}, "editBundlesForAccount": "このアカウントのバンドルを編集", - "@editBundlesForAccount": {}, "unverified": "未検証", - "@unverified": {}, "sender": "送信者", - "@sender": {}, "placeCall": "電話をかける", - "@placeCall": {}, "voiceCall": "音声通話", - "@voiceCall": {}, "unsupportedAndroidVersionLong": "この機能を利用するには、より新しいAndroidのバージョンが必要です。アップデートまたはLineage OSのサポートをご確認ください。", - "@unsupportedAndroidVersionLong": {}, "widgetVideo": "動画", - "@widgetVideo": {}, "widgetName": "名称", - "@widgetName": {}, "widgetCustom": "カスタム", - "@widgetCustom": {}, "widgetJitsi": "Jitsi Meet", - "@widgetJitsi": {}, "dehydrateWarning": "この操作は元に戻せません。バックアップファイルを安全に保存してください。", - "@dehydrateWarning": {}, "dehydrate": "セッションのエクスポートとデバイスの消去", - "@dehydrate": {}, "messageType": "メッセージの種類", - "@messageType": {}, "start": "開始", - "@start": {}, "publish": "公開", - "@publish": {}, "indexedDbErrorTitle": "プライベートモードに関する問題", - "@indexedDbErrorTitle": {}, "addWidget": "ウィジェットを追加", - "@addWidget": {}, "youBannedUser": "{user} を禁止しました", "@youBannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youJoinedTheChat": "チャットに参加しました", - "@youJoinedTheChat": {}, "youHaveWithdrawnTheInvitationFor": "{user} への招待を取り下げました", "@youHaveWithdrawnTheInvitationFor": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "users": "ユーザー", - "@users": {}, "youRejectedTheInvitation": "招待を拒否しました", - "@youRejectedTheInvitation": {}, "screenSharingDetail": "FuffyChatで画面を共有しています", - "@screenSharingDetail": {}, "homeserver": "ホームサーバー", - "@homeserver": {}, "scanQrCode": "QRコードをスキャン", - "@scanQrCode": {}, "obtainingLocation": "位置情報を取得しています…", "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "addToBundle": "バンドルに追加", - "@addToBundle": {}, "removeFromBundle": "このバンドルから削除", - "@removeFromBundle": {}, "bundleName": "バンドル名", - "@bundleName": {}, "noMatrixServer": "{server1} はMatrixのサーバーではありません。代わりに {server2} を使用しますか?", "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "openVideoCamera": "ビデオ用にカメラを開く", "@openVideoCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "link": "リンク", - "@link": {}, "or": "または", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "register": "登録", "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "removeYourAvatar": "アバターを削除する", "@removeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "saveFile": "ファイルを保存", "@saveFile": { - "type": "text", + "type": "String", "placeholders": {} }, "recoveryKey": "リカバリーキー", - "@recoveryKey": {}, "singlesignon": "シングルサインオン", "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceIsPublic": "スペースは公開されています", "@spaceIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceName": "スペース名", "@spaceName": { - "type": "text", + "type": "String", "placeholders": {} }, "startFirstChat": "最初のチャットを開始する", - "@startFirstChat": {}, "addToSpaceDescription": "このチャットを追加するスペースを選択してください。", - "@addToSpaceDescription": {}, "messageInfo": "メッセージの情報", - "@messageInfo": {}, "openGallery": "ギャラリーを開く", - "@openGallery": {}, "removeFromSpace": "スペースから削除", - "@removeFromSpace": {}, "pleaseEnterRecoveryKeyDescription": "古いメッセージを解除するには、以前のセッションで生成されたリカバリーキーを入力してください。リカバリーキーはパスワードではありません。", - "@pleaseEnterRecoveryKeyDescription": {}, "videoWithSize": "ビデオ ({size})", "@videoWithSize": { - "type": "text", + "type": "String", "placeholders": { - "size": {} + "size": { + "type": "String" + } } }, "openChat": "チャットを開く", - "@openChat": {}, "experimentalVideoCalls": "実験的なビデオ通話", - "@experimentalVideoCalls": {}, "emailOrUsername": "メールアドレスまたはユーザー名", - "@emailOrUsername": {}, "switchToAccount": "アカウント {number} に切り替える", "@switchToAccount": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "nextAccount": "次のアカウント", - "@nextAccount": {}, "youAcceptedTheInvitation": "👍 招待を承諾しました", - "@youAcceptedTheInvitation": {}, "errorAddingWidget": "ウィジェットの追加中にエラーが発生しました。", - "@errorAddingWidget": {}, "widgetNameError": "表示名を入力してください。", - "@widgetNameError": {}, "youUnbannedUser": "{user} の禁止を解除しました", "@youUnbannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youInvitedBy": "📩 {user} から招待されました", "@youInvitedBy": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youKicked": "👞 {user} をキックしました", "@youKicked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youKickedAndBanned": "🙅 {user} をキックしてブロックしました", "@youKickedAndBanned": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "storeInAppleKeyChain": "Apple KeyChainに保存", - "@storeInAppleKeyChain": {}, "storeInAndroidKeystore": "Android KeyStoreに保存する", - "@storeInAndroidKeystore": {}, "storeInSecureStorageDescription": "このデバイスの安全なストレージにリカバリーキーを保存。", - "@storeInSecureStorageDescription": {}, "unlockOldMessages": "古いメッセージのロックを解除する", - "@unlockOldMessages": {}, "callingAccount": "通話アカウント", - "@callingAccount": {}, "callingPermissions": "通話の権限", - "@callingPermissions": {}, "screenSharingTitle": "画面共有", - "@screenSharingTitle": {}, "foregroundServiceRunning": "この通知は、フォアグラウンド サービスの実行中に表示されます。", - "@foregroundServiceRunning": {}, "custom": "カスタム", - "@custom": {}, "countFiles": "{count}個のファイル", "@countFiles": { "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "storeSecurlyOnThisDevice": "このデバイスに安全に保管する", - "@storeSecurlyOnThisDevice": {}, "whyIsThisMessageEncrypted": "このメッセージが読めない理由", - "@whyIsThisMessageEncrypted": {}, "otherCallingPermissions": "マイク、カメラ、その他FluffyChatの権限", - "@otherCallingPermissions": {}, "appearOnTopDetails": "アプリをトップに表示できるようにする(すでに通話アカウントとしてFluffychatを設定している場合は必要ありません)", - "@appearOnTopDetails": {}, "dehydrateTorLong": "TOR ユーザーの場合、ウィンドウを閉じる前にセッションをエクスポートすることをお勧めします。", - "@dehydrateTorLong": {}, "hydrateTorLong": "前回、TOR でセッションをエクスポートしましたか?すぐにインポートしてチャットを続けましょう。", - "@hydrateTorLong": {}, "enableMultiAccounts": "(ベータ版) このデバイスで複数のアカウントを有効にする", - "@enableMultiAccounts": {}, "pleaseEnterRecoveryKey": "リカバリーキーを入力してください。", - "@pleaseEnterRecoveryKey": {}, "serverRequiresEmail": "このサーバーは、登録のためにメールアドレスを検証する必要があります。", - "@serverRequiresEmail": {}, "sendSticker": "ステッカーを送る", "@sendSticker": { - "type": "text", + "type": "String", "placeholders": {} }, "synchronizingPleaseWait": "同期中...お待ちください。", "@synchronizingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "emojis": "絵文字", - "@emojis": {}, "markAsRead": "既読にする", - "@markAsRead": {}, "videoCallsBetaWarning": "ビデオ通話は、現在ベータ版であることにご注意ください。すべてのプラットフォームで期待通りに動作しない、あるいはまったく動作しない可能性があります。", - "@videoCallsBetaWarning": {}, "confirmEventUnpin": "イベントの固定を完全に解除してもよろしいですか?", - "@confirmEventUnpin": {}, "unsupportedAndroidVersion": "サポートされていないAndroidのバージョン", - "@unsupportedAndroidVersion": {}, "user": "ユーザー", - "@user": {}, "newGroup": "新しいグループ", - "@newGroup": {}, "noBackupWarning": "警告!チャットのバックアップを有効にしないと、暗号化されたメッセージにアクセスできなくなります。ログアウトする前に、まずチャットのバックアップを有効にすることを強くお勧めします。", - "@noBackupWarning": {}, "disableEncryptionWarning": "セキュリティ上の理由から、以前は暗号化が有効だったチャットで暗号化を無効にすることはできません。", - "@disableEncryptionWarning": {}, "youInvitedUser": "📩 {user} を招待しました", "@youInvitedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "reactedWith": "{sender} が {reaction} で反応しました", "@reactedWith": { - "type": "text", + "type": "String", "placeholders": { - "sender": {}, - "reaction": {} + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } } }, "createNewSpace": "新しいスペース", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "widgetUrlError": "有効なURLではありません。", - "@widgetUrlError": {}, "reportUser": "ユーザーを報告", - "@reportUser": {}, "errorObtainingLocation": "位置情報の取得中にエラーが発生しました: {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "pinMessage": "部屋にピン留めする", - "@pinMessage": {}, "previousAccount": "前のアカウント", - "@previousAccount": {}, "pleaseChoose": "選択してください", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsPushError": "おっと!残念ながら、プッシュ通知の設定中にエラーが発生しました。", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "noOtherDevicesFound": "他のデバイスが見つかりません", - "@noOtherDevicesFound": {}, "recoveryKeyLost": "リカバリーキーを紛失した場合", - "@recoveryKeyLost": {}, "shareLocation": "位置情報の共有", "@shareLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "time": "時間", - "@time": {}, "sendAsText": "テキストとして送信", "@sendAsText": { - "type": "text" + "type": "String" }, "commandHint_googly": "ぎょろ目を送る", - "@commandHint_googly": {}, "commandHint_hug": "ハグを送る", - "@commandHint_hug": {}, "encryptThisChat": "このチャットを暗号化する", - "@encryptThisChat": {}, "commandHint_markasdm": "ダイレクトメッセージの部屋としてマークする", - "@commandHint_markasdm": {}, "commandHint_dm": "ダイレクトチャットを開始する\n暗号化を無効にするには、--no-encryptionを使用してください", "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "commandHint_leave": "この部屋を退出", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_myroomavatar": "この部屋の写真を設定する (mxc-uriで)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_myroomnick": "この部屋の表示名を設定する", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_plain": "書式設定されていないテキストを送信する", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_react": "リアクションとして返信を送信する", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "dehydrateTor": "TOR ユーザー: セッションをエクスポート", - "@dehydrateTor": {}, "hydrateTor": "TOR ユーザー: セッションのエクスポートをインポート", - "@hydrateTor": {}, "locationDisabledNotice": "位置情報サービスが無効になっています。位置情報を共有できるようにするには、位置情報サービスを有効にしてください。", "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "locationPermissionDeniedNotice": "位置情報の権限が拒否されました。位置情報を共有できるように許可してください。", "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceKeys": "デバイスキー:", - "@deviceKeys": {}, "sorryThatsNotPossible": "申し訳ありません...それは不可能です", - "@sorryThatsNotPossible": {}, "wasDirectChatDisplayName": "空のチャット (以前は {oldDisplayName})", "@wasDirectChatDisplayName": { - "type": "text", + "type": "String", "placeholders": { - "oldDisplayName": {} + "oldDisplayName": { + "type": "String" + } } }, "doNotShowAgain": "今後表示しない", - "@doNotShowAgain": {}, "hideUnimportantStateEvents": "重要でない状態イベントを非表示にする", - "@hideUnimportantStateEvents": {}, "numChats": "{number} チャット", "@numChats": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "allSpaces": "すべてのスペース", - "@allSpaces": {}, "enterRoom": "部屋に入る", - "@enterRoom": {}, "enterSpace": "スペースに入る", - "@enterSpace": {}, "newSpace": "新しいスペース", - "@newSpace": {}, "reopenChat": "チャットを再開する", - "@reopenChat": {}, "signInWith": "{provider}でログイン", "@signInWith": { - "type": "text", + "type": "String", "placeholders": { - "provider": {} + "provider": { + "type": "String" + } } }, "signInWithPassword": "パスワードでログイン", - "@signInWithPassword": {}, - "@hugContent": { - "type": "text", + "notAnImage": "画像ファイルではありません。", + "ignoreUser": "ユーザーを無視する", + "normalUser": "通常のユーザー", + "aboutHomeserver": "{homeserver} について", + "@aboutHomeserver": { + "type": "String", "placeholders": { - "senderName": {} + "homeserver": { + "type": "String" + } } }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@dismiss": {}, - "@reportErrorDescription": {}, - "@indexedDbErrorLong": {}, - "@setColorTheme": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@unbanUserDescription": {}, - "@messagesStyle": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@noKeyForThisMessage": {}, - "@pushNotificationsNotAvailable": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@makeAdminDescription": {}, - "@saveKeyManuallyDescription": {}, - "@setChatDescription": {}, - "@importFromZipFile": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@fileIsTooBigForServer": {}, - "@readUpToHere": {}, - "@optionalRedactReason": {}, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@redactMessageDescription": {}, - "@invalidInput": {}, - "@report": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@openLinkInBrowser": {}, - "@commandHint_me": { - "type": "text", - "description": "Usage hint for the command /me" - }, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@commandHint_kick": { - "type": "text", + "noMoreChatsFound": "これ以上のチャットが見つかりません…", + "unread": "未読", + "space": "スペース", + "spaces": "スペース", + "changedTheChatDescription": "{username}がチャットの説明を変更した", + "changedTheChatName": "{username}がチャットの名前を変更した", + "commandHint_kick": "入力のユーザーをこの部屋からキックする", + "@commandHint_kick": { + "type": "String", "description": "Usage hint for the command /kick" }, - "@commandHint_unban": { - "type": "text", - "description": "Usage hint for the command /unban" - }, - "@importEmojis": {}, - "@noChatDescriptionYet": {}, - "@learnMore": {}, - "@notAnImage": {}, - "@chatDescriptionHasBeenChanged": {}, - "@commandHint_op": { - "type": "text", - "description": "Usage hint for the command /op" - }, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "@profileNotFound": {}, - "@jump": {}, - "@shareInviteLink": {}, - "@cuddleContent": { - "type": "text", + "countInvited": "{count}人を招待済み", + "@countInvited": { + "type": "String", "placeholders": { - "senderName": {} + "count": { + "type": "int" + } } }, - "@emoteKeyboardNoRecents": { - "type": "text", + "createGroup": "グループを作成する", + "allRooms": "すべてのグループチャット", + "@allRooms": { + "type": "String", "placeholders": {} }, - "@setTheme": {}, - "@replace": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@invite": {} -} \ No newline at end of file + "emoteKeyboardNoRecents": "最近使われた絵文字がここに表示されます…", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "グローバルチャットID", + "calls": "通話", + "chatDescription": "チャットの説明", + "chatDescriptionHasBeenChanged": "チャットの説明が変更された", + "block": "ブロック", + "blockedUsers": "ブロック済みのユーザー", + "blockUsername": "ユーザー名を無視する", + "inviteContactToGroupQuestion": "{contact}を「{groupName}」のチャットに招待しますか?", + "noChatDescriptionYet": "チャットの説明はまだ作成されていません。", + "tryAgain": "再試行", + "messagesStyle": "メッセージ:", + "shareInviteLink": "招待リンクを共有", + "openInMaps": "マップで開く", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "hideMemberChangesInPublicChats": "公開チャットでのメンバー変更を非表示にする", + "notifyMeFor": "お知らせを受ける", + "redactedBy": "{username}によって削除済み", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "ダイレクトチャット", + "redactedByBecause": "{username}によって削除済み。理由:「{reason}」", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "sendImages": "{count}つの画像を送信", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "presencesToggle": "他のユーザーからのステータスメッセージを表示する", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWaitCounter": " 同期中…({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "importEmojis": "絵文字をインポート", + "importNow": "今すぐインポート", + "importFromZipFile": ".zipファイルからインポート", + "exportEmotePack": "エモートパックを.zipでエクスポート", + "replace": "置き換え", + "commandHint_roomupgrade": "このルームを特定のルームバージョンにアップグレード", + "commandHint_cuddle": "笑顔を送る", + "googlyEyesContent": "{senderName}がギョロ目を送りました", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName}が笑顔を送りました", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName}がハグしました", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "appLockDescription": "未使用時にアプリをPINコードでロック", + "sendTypingNotifications": "入力通知を送信", + "swipeRightToLeftToReply": "左にスワイプして返信", + "countChatsAndCountParticipants": "{chats}チャットと{participants}人の参加者", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noChatsFoundHere": "ここにはまだチャットがありません。下のボタンを使ってみんなと新しいチャットを始めましょう。⤵️", + "joinedChats": "チャットに参加しました", + "commandHint_unban": "このルームから禁止されたユーザーを解禁する", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "chatPermissions": "チャット権限", + "checkList": "チェックリスト", + "accessAndVisibility": "アクセスと範囲", + "accessAndVisibilityDescription": "誰がこのチャットに参加できて、どのように発見することができるか。", + "customEmojisAndStickers": "カスタム絵文字とステッカー", + "customEmojisAndStickersBody": "どのチャットでも利用可能なカスタム絵文字やステッカーを追加・共有します。", + "hideRedactedMessages": "削除されたメッセージを隠す", + "hideRedactedMessagesBody": "誰かがメッセージを削除した場合、このメッセージはそれ以降チャット内では見えなくなります。", + "hideInvalidOrUnknownMessageFormats": "無効であるか不明なメッセージ形式を隠す", + "blockListDescription": "迷惑なユーザーをブロックすることができます。あなたの個人的なブロックリストに記載されたユーザーは、あらゆるメッセージやルームへの招待を受け取ることができません。", + "invalidServerName": "無効なサーバー名", + "redactMessageDescription": "メッセージはこの会話のすべての参加者から削除されます。これは取り消すことができません。" +} diff --git a/lib/l10n/intl_ka.arb b/lib/l10n/intl_ka.arb new file mode 100644 index 000000000..c885a04a2 --- /dev/null +++ b/lib/l10n/intl_ka.arb @@ -0,0 +1,820 @@ +{ + "alias": "მეტსახელი", + "@alias": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "პინკოდის გამოყენების გარეშე აპლიკაციის ბლოკირება", + "commandHint_hug": "მეგობრული ჩახუტვის გაგზავნა", + "areYouSure": "დარწმუნებული ხართ?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "დარწმუნებული ხართ, რომ გამოსვლა გსურთ?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "hugContent": "{senderName} მეგობრულად გეხუტება", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "askSSSSSign": "სხვა მომხმარებლის დადასტურებლად, გთხოვთ, ჩაწეროთ თქვენი ან საიდუმლო ფრაზა, ან აღდგენის გასაღები.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "ანიმირებული სტიკერებისა და ემოჯების ავტომატური ჩართვა", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "banFromChat": "ჩატიდან გაგდება და ბლოკირება", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "დაბლოკილია", + "@banned": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "ამ სერვერს აქვს შესვლის მეთოდების მხარდაჭერა:\n{serverVersions}\nმაგრამ ამ აპლიკაციას აქვს მხარდაჭერა მხოლოდ:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendOnEnter": "გაგზავნა enter-ის დაჭერისას", + "bannedUser": "{username} დაბლოკა {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "მოწყობილების ბლოკირება", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "დაბლოკილია", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "ბოტის შეტყობინებები", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "გაუქმება", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changedTheHistoryVisibilityTo": "{username} შეცვალა ისტორიის ხილვადობა: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} გაწევრიანების წესები შეცვალა", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} შეცვალა პროფილის ფოტო", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "chat": "ჩატი", + "@chat": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "პროფილის ფოტოს შეცვლა", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "თქვენი ჩატის სარეზერვო საშუალება კონფიგურირებული იქნა.", + "channelCorruptedDecryptError": "დაშიფვრა დაზიანდა", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "თქვენი შეტყობინებები დაცულია აღდგენის გასაღებით. არ დაკარგოთ ის.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "commandHint_discardsession": "სესიის გაუქმება", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_invite": "მოცემული მომხმარებლის მოწვევა ამ ოთახში", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_plain": "არაფორმატირებული ტექსტის გაგზავნა", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_send": "ტექსტის გაგზავნა", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandMissing": "{command} არაა ბრძანება.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "confirm": "დადასტურება", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "დაკავშირება", + "@connect": { + "type": "String", + "placeholders": {} + }, + "countParticipants": "{count} მონაწილე", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "createGroup": "ჯგუფის შექმნა", + "deactivateAccountWarning": "ეს გააუქმებს თქვენს ანგარიშს. ამის გაუქმება შეუძლებელია. დარწმუნებული ხართ?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "devices": "მოწყობილებები", + "@devices": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "ბნელი", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "ჩატის უფლებები", + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "editRoomAliases": "ოთახის მეტსახელების შეცვლა", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "ეს ემოცია უკვე არსებობს!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "ემოციის არასწორი მოკლე კოდი!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "importNow": "დაიმპორტება", + "importEmojis": "ემოჯის დაიმპორტება", + "importFromZipFile": "იმპორტი .zip ფაილიდან", + "exportEmotePack": "ემოციების .zip ფაილში ექსპორტი", + "replace": "ჩანაცვლება", + "accept": "თანხმობა", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username}-მ(ა) მიიღო მოწვევა", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "ანგარიში", + "@account": { + "type": "String", + "placeholders": {} + }, + "addEmail": "ელ.ფოსტის დამატება", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "გთხოვთ, დაადასტუროთ თქვენი Matrix ID ანგარიშის წაშლისათვის.", + "addChatDescription": "ჩატის აღწერილობის დამატება...", + "addToSpace": "სივრცეში დამატება", + "admin": "ადმინი", + "@admin": { + "type": "String", + "placeholders": {} + }, + "all": "ყველა", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "ყველა ჩატი", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_cuddle": "ჩახუტების გაგზავნა", + "answeredTheCall": "{senderName} უპასუხა ზარს", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "ყველას შეუძლია გაწევრიანება", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "აპლიკაციის ბლოკირება", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "არქივი", + "@archive": { + "type": "String", + "placeholders": {} + }, + "commandHint_googly": "გამოშტერილი თვალების გაგზავნა", + "googlyEyesContent": "{senderName} გამოშტერილ თვალებს გიგზავნის", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} გეხუტება", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "areGuestsAllowedToJoin": "შეუძლიათ სტუმარ მომხმარებლებს გაწევრება?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "მიიღებთ {username} დადასტურების მოთხოვნას?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sendTypingNotifications": "წერის შეტყობინების გაგზავნა", + "cantOpenUri": "ვერ იხსნება ბმული {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "მოწყობილების გადარქმევა", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} ჩატის ფოტო შეცვალა", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} ჩატის ახალი აღწერილობა დააყენა: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} ჩატი გადაარქვა: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} ჩატის უფლებები შეცვალა", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} შეცვალა სტუმრების წვდომის წესები", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} შეცვალა სტუმრების წვდომის წესები: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} შეცვალა ისტორიის ხილვადობა", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} გაწევრიანების წესები შეცვალა: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} ოთახის მეტსახელები შეცვალა", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} მოწვევის ბმული შეცვალა", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "პაროლის შეცვლა", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "სახლის სერვერის შეცვლა", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "სტილის შეცვლა", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "ჯგუფის გადარქმევა", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "ჩატის სარეზერვო საშუალება", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "ჩატის დეტალები", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "ჩატი დაემატა ამ სივრცეს", + "chats": "ჩატები", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "ძლიერი პაროლი აარჩიეთ", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "არქივის გაწმენდა", + "close": "დახურვა", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasgroup": "აღნიშვნა, როგორც ჯგუფის", + "commandHint_ban": "მოცემული მომხმარებლის ბლოკირება ამ ოთახში", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "­ქეშის გაწმენდა", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_join": "მოცემულ ოთახში გაწევრიანება", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "მოცემული მომხმარებლის წაშლა ამ ოთახიდან", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "ამ ოთახიდან გასვლა", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "აღწერეთ თქვენი თავი", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_unban": "ამ ოთახში მომხმარებლისგან ბლოკის მოხსნა", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "არასწორი ბრძანება", + "@commandInvalid": { + "type": "String" + }, + "compareEmojiMatch": "გთხოვთ, შეადაროთ ეს ემოჯი", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "გთხოვთ, შეადაროთ ეს რიცხვები", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "ჩატის კონფიგურაცია", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "კონტაქტი მოწვეული იქნა ჯგუფში", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "შეიცავს სახელს", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "კოპირებულია ბუფერში", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "კოპირება", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "კოპირება ბუფერში", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "შეტყობინების გაშიფვრის შეცდომა: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "create": "შექმნა", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} შექმნა ჩატი", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "ახალი სივრცე", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "ახლა აქტიურია", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "delete": "წაშლა", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "ანგარიშის წაშლა", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "შეტყობინების წაშლა", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "მოწყობილება", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "მოწყობილების ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "directChats": "პირდაპირი ჩატები", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "allRooms": "ყველა ჯგუფური ჩატები", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "ფაილის ჩატვირთვა", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "რედაქტირება", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "ბლოკირებული სერვერების რედაქტირება", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "ოთახის ფოტოს შეცვლა", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "ემოციების პარამეტრები", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "გლობალური ჩატის ID", + "repeatPassword": "გაიმეორეთ პაროლი", + "notAnImage": "ფაილი არაა სურათი.", + "remove": "წაშლა", + "@remove": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username}-მ(ა) გააქტიურა end to end დაშიფვრა", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "supposedMxid": "ეს უნდა იყოს {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "about": "შესახებ", + "@about": { + "type": "String", + "placeholders": {} + }, + "changedTheDisplaynameTo": "{username} შეცვალა ნაჩვენები სახელი: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "commandHint_create": "ცარიელი ჯგუფური ჩატის შექმნა\nგამოიყენეთ --no-encryption გაშიფვრის გასათიშად", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_dm": "პირდაპირი ჩატის დაწყება\nგამოიყენეთ --no-encryption გაშიფვრის გასათიშად", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_html": "HTML ფორმატირებული ტექსტის გაგზავნა", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_myroomavatar": "თქვენი ფოტოს დაყენება ამ ოთახისათვის(mxc-uri-ს დახმარებით)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "ამ ოთახისათვის ნაჩვენები სახელის დაყენება", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "მოცემული მომხმარებლისათვის უფლებების დონის დაყენება (ჩვეულებრივ: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_react": "რეაქციის სახით პასუხის გაგზავნა", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "containsDisplayName": "ნაჩვენებ სახელს შეიცავს", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "ეს კონტენტი გაგზავნილ იქნა სერვერის ადმინისტრატორებთან", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "ნაგულისხმევი უფლების დონე", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "ნაჩვენები სახელი შეიცვალა", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "ნაჩვენები სახელის შეცვლა", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "ignoreUser": "დაიგნორება", + "normalUser": "ჩვეულებრვი მომხმარებელი", + "aboutHomeserver": "{homeserver}-ის შესახებ", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + } +} diff --git a/lib/l10n/intl_kab.arb b/lib/l10n/intl_kab.arb new file mode 100644 index 000000000..4b3cfc7fc --- /dev/null +++ b/lib/l10n/intl_kab.arb @@ -0,0 +1,2478 @@ +{ + "@@locale": "kab", + "repeatPassword": "Ales awal n uɛeddi", + "notAnImage": "Mačči d afaylu n tugna.", + "setCustomPermissionLevel": "Sbadu aswir yugnen n usireg", + "ignoreUser": "Zgel aseqdac", + "setPermissionsLevelDescription": "Ma ulac aɣilif fren tamlilt i yettusbadun ddaw-a neɣ sekcem aswir n usireg yugnen gar 0 akked 100.", + "normalUser": "Aseqdac amagnu", + "remove": "Kkes", + "@remove": { + "type": "String", + "placeholders": {} + }, + "importNow": "Kter tura", + "importEmojis": "Kter imujiten", + "importFromZipFile": "Kter seg ufaylu .zip", + "exportEmotePack": "Sifeḍ akemmus n Izamulen uḥulfu am .zip", + "replace": "Semselsi", + "about": "Ɣef", + "aboutHomeserver": "Ɣef {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "accept": "Qbel", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} yeqbel tinubga", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Amiḍan", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} irmed awgelhen seg yixef ɣer yixef", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Rnu imayl", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Ttxil-ik·im, sentem asulay-ik·im n Matriks akken ad tekkseḍ amiḍan-ik·im.", + "supposedMxid": "A win yufan, ad yili d {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "Rnu aglam n udiwenni...", + "addToSpace": "Rnu ɣer tallunt", + "admin": "Anedbal", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "Tazaẓlut", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Meṛṛa", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Meṛṛa idiwenniyen", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_roomupgrade": "Sali aswir n txxamt-agi ɣer lqem n texxamt i d-yettunefken", + "answeredTheCall": "{senderName} yerra-d i usiwel", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Yal yiwen yezmer ad yettekki", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Asekkeṛ n usnas", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "Sekkeṛ asnas ticki ur tseqdaceḍ ara s tengalt n pin", + "archive": "Aɣbaṛ", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Iseqdacen inebgiwen ttusirgen ad ttekkin", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Tetḥeqqeḍ?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "D tidet tebɣiḍ ad teffɣeḍ?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Iwakken ad teszmeleḍ amdan-nniḍen, ttxil-k·m sekcem tafyirt-ik·im n uḥraz s wudem aɣelsan neɣ tasarut n tririt.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Qbel asuter-agi n usenqed seg {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "spaces": "Tallunin", + "banFromChat": "Gdel seg adiwenni", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Yettwagdel", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} yegdel {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Sewḥel ibenk", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Yettusewḥel", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Iznan n iṛubuten", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Sefsex", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Ur yezmir ara ad yeldi URl {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Snifel isem n yibenk", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} yesnifel avaṭar n udiwenni", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescription": "{username} yesnifel aglam n udiwenni", + "changedTheChatDescriptionTo": "{username} yesnifel aglam n udiwenni ɣer: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatName": "{username} yesnifel isem n udiwenni", + "changedTheChatNameTo": "{username} yesnifel isem n udiwenni ɣer: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} yesnifel tisirag n udiwenni", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} yesnifel tisirag n udiwenni ɣer: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "chat": "Adiwenni", + "@chat": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Aḥraz n udiwenni-ik·im yettusbadu.", + "chatBackup": "Aḥraz n udiwenni", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Iznan-ik·im d iɣelsanen s tsarut n tririt. Ɣur-k·m ad k·em-truḥ.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Ifatusen n udiwenni", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Adiwenni yettwarna ɣer tallunt-agi", + "chats": "Idiwenniyen", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Fren awal n uɛeddi iǧehden", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Sfeḍ aɣbaṛ", + "close": "Mdel", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasdm": "Creḍ d akken taxxamt n yizen usrid i Usulay Matriks i d-yettunefken", + "commandHint_markasgroup": "Creḍ am ugraw", + "commandHint_ban": "Gdel aseqdac i d-ittunefken seg texxamt-agi", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Sfeḍ tazarkatut", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Snulfu-d agraw n udiwenni ilem\nSeqdec -- war awgelhen i tukksa n uwgelhen", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Kkes tiɣimit", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Senker adiwenni usrid\nSeqdec --war awgelhen i tukksa n uwgelhen", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_html": "Azen aḍris s umasal HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Snubg aseqdac i d-ittunefken ɣer texxamt-agi", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Ddu ɣer texxamt i d-ittunefken", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Kkes aseqdac i d-ittunefken seg texxamt-agi", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Ffeɣ seg texxamt-a", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Glem-d iman-ik·im", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Sbadu tawlaft-ik·im i texxamt-a (s mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Sbadu isem n uskan i texxamt-agi", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Sbadu aswir n tnezmert n useqdac i d-ittunefken (amezwer: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "createNewSpace": "Tallunt tamaynut", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Yermed akka tura", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Ubrik", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{timeOfDay}, {date}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Ayagi ad yekkes armed i umiḍan-ik·im n useqdac. Aya ur yezmir ara ad yettwasefsex. Tetḥeqqeḍ s tidet?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Aswir n turagt amezwer i yiseqdacen imaynuten", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "kkes", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "kkes amiḍan", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "kkes izen", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Ibenk", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Asulay n yibenk", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Ibenkan", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Idiwenniyen Usriden", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "allRooms": "Akk Igrawen Usriden", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Isem n uskan yettusnifel", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Sider afaylu", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Ẓreg", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Ẓreg iqeddacen yettusweḥlen", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "Isirigen n Udiwenni", + "encrypted": "Yettwawgelhen", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Awgelhen", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Awgelhen ur yettwarmed ara", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} ifukk asiwel", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Sekcem tansa n yimayl", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Aqeddac agejdan", + "enterYourHomeserver": "Sekcem Aqeddac-ik·im agejdan", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Tuccḍa deg wawway n yideg: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Kullec ihegga!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "fileName": "Isem n ufaylu", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Tiddi n tsefsit", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Ɣer zdat", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Seg unekcam-is", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Seg tinubga", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Ddu ɣer texxamt tamaynut", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Agraw", + "@group": { + "type": "String", + "placeholders": {} + }, + "chatDescription": "Aglam n udiwenni", + "chatDescriptionHasBeenChanged": "Aglam n udiwenni yettwabeddel", + "groupIsPublic": "Agraw d azayez", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Igrawen", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Agraw s {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "tryAgain": "Ɛreḍ tikkelt-nniḍen", + "invalidServerName": "Isem n uqeddac d armeɣtu", + "invited": "Yettwaɛreḍ", + "@invited": { + "type": "String", + "placeholders": {} + }, + "redactMessageDescription": "Izen ad yettwakkesn i imttekkiyen merra deg udiwenni-agi. Ur tezmireḍ ara ad tesfesxeḍ.", + "optionalRedactReason": "(Afrayan) Sebba n tukksa n izen-agi…", + "invitedUser": "📩 {username} yenced {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Iseqdacen kan yettwaɛerḍen", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Snubget i nekk", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "isTyping": "la yettaru…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋{username} yekcem ɣer udiwenni", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Tekki deg texxamt", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞{username} yessuffeɣ-d {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} yessuffeɣ-d udiɣ igdel {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Suffeɣ seg udiwenni", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Yermed i tikkelt taneggarut: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Eǧǧ", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Ffeɣ seg udiwenni", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Turagt", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Aceɛlal", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Sali-d ugar n {count} yimttekkiyen", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrate": "Sifeḍ tiɣimit akked usfaḍ n yibenk", + "dehydrateWarning": "Tigawt-agi ur tezmir ara ad tettwasefsex. Tḥeqqeq belli tesseklaseḍ afaylu n weḥraz.", + "dehydrateTor": "Iseqdacen TOR: Sifeḍ tiɣimit", + "dehydrateTorLong": "I iseqdacen TOR, yettusemter ad tsifeḍ tɣimit send ad tmedleḍ asfaylu.", + "hydrateTor": "Iseqdacen TOR: Akter n tɣimit usifeḍ", + "hydrateTorLong": "Tsifḍeḍ tiɣimit-ik·im taneggarut deg TOR? kter-it-id s wudem arurad u kemmel adiwenni.", + "hydrate": "Err-d seg ufaylu n weḥraz", + "loadingPleaseWait": "Asali... Ttxil-k·m arǧu.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Yettwanɣel ɣer tecfawit", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Nɣel", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Nɣel ɣer tecfawit", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Ur izmer ara tukksa n uwgelhen n yizen: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "checkList": "Senqed tabdart", + "countParticipants": "{count} imttekkiyen", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "countInvited": "{count} yettwaɛerḍen", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Snulfu-d", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} yesnulfa-d adiwenni", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createGroup": "Snulfu-d agraw", + "editDisplayname": "Ẓreg isem n ubeqqeḍ", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Ẓreg avaṭar n texxamt", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Azamul uḥulfu yella yakan!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Tangalt tawezlant n uzamul uḥulfu d tarmeɣtut!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteKeyboardNoRecents": "Izamulen uḥulfu yettwasqedcen melmi kan ad banen dagi…", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Ikemmusen n uzamul uḥulfu i texxamt", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Iɣewwaṛen n uzamul uḥulfu", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "Asulay n udiwenni amatu", + "accessAndVisibility": "Addaf d twalit", + "accessAndVisibilityDescription": "Anwa i yesɛan turagt ad yernu ɣer udiwenni-agi u amek adiwenni yezmer ad yettwaf.", + "calls": "Isawalen", + "customEmojisAndStickers": "Imujiten yugnen akked tcṛeṭ n tesfift", + "customEmojisAndStickersBody": "Rnu neɣ bḍu imujiten yugnen neɣ tcṛeṭ n tesfift i zemren ad ttwasqedcen deg yal adiwenni.", + "emptyChat": "Adiwenni d ilem", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Sermed akemmus n uzamul uḥulfu s wudem amatu", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Rmed awgelhen", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Ur tettizmireḍ ara ad tessenseḍ awgelhen syagi ɣer zdat. Tetḥeqqeḍ s tidet?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "login": "Anekcam", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Anekcam ɣer {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Tuffɣa", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Ibeddilen n iɛeggalen", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Abdar", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Iznan", + "@messages": { + "type": "String", + "placeholders": {} + }, + "messagesStyle": "Iznan:", + "muteChat": "Sgugem adiwenni", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Ttxil-k·m ẓeṛ belli tesriḍ Palaimon akken ad tesqedceḍ awgelhen seg yixef ɣer yixef.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Adiwenni Amaynut", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Izen amaynut deg FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Asuter amaynut n uselken!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Uḍfir", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Ala", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Ulac tuqqna ɣer uqeddac", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Tzemreḍ kan ad tesremdeḍ awgelhen akken kan ara tuɣal taxxamt s war anekcum azayez.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Ulac izamulen uḥulfu yettwafen. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} ur yelli d aqeddac matriks, seqdec axir {server2} ?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "shareInviteLink": "Bḍu aseɣwen n tinubga", + "none": "Ulac", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Mazal ur terniḍ ara tarrayt akken ad terreḍ awal-ik·im n uɛeddi.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Ulac tasiregt", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Ulac taxxamt i yettwafen…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Ilɣa", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Ilɣa remden i umiḍan-agi", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} n iseqdacen la yettarun…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Aguccel n wadig…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Tanṭagt", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Ẓreg tizeẓla n taxxamt", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "link": "Aseɣwen", + "serverRequiresEmail": "Aqeddac-agi ilaq ad isentem tansa imayl i ujerred.", + "or": "Neɣ", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Imttekki", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "tafyirt n uɛeddi neɣ tasarut n tririt", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Awal n uɛeddi", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Awal n uɛeddi yettwattun", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Awal n uɛeddi yettusnifel", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "hideMemberChangesInPublicChats": "Ffer isenfal n iɛeggalen deg udiwenni azayez", + "overview": "Taskant", + "notifyMeFor": "Seɛlem-iyi-d ɣef", + "passwordRecoverySettings": "Iɣewwaṛen n tririt n wawal n uɛeddi", + "passwordRecovery": "Tiririt n wawal n uɛeddi", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Imdanen", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Fren tugna", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "play": "Ɣeṛ {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Ttxil-k·m fren", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Ttxil-k·m fren tangalt n uɛeddi", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Ma ulac aɣilif, sit ɣef useɣwen yellan deg imayl sakin kemmel.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "userAndOthersAreTyping": "{username} akked {count} nniḍen la ad ttarun…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} akked {username2} la ad ttarun…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} la yettaru…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪{username} yeffeɣ seg udiwenni", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Isem n useqdac", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} yuzen-d tadyant {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "unverified": "Ur yettwaselken ara", + "verified": "Yettwaselken", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Selken", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Bdu Aselken", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Yedda uselken-ik·im akken iwata!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Aselken n imiḍanen nniḍen", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Asiwel s tvidyut", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Tawalit n uzray n udiwenni", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Yettban i yimttekkiyen meṛṛa", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Yettban i yal yiwen", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Izen n taɣect", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Araǧu n uneblag ad yeqbel asuter…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Araǧu n uneblag ad yeqbel imujit…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Araǧu n uneblag ad yeqbel uṭṭunen…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Tugna n ugdil:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Ɣur-k·m!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Nuzen-ak-d imayl", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Anwa i izemren ad yexdem anta tigawt", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Anwa i izemren ad yernu ɣer ugraw-agi", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Ayɣer tebɣiḍ ad temleḍ aya?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Sfeḍ aḥraz-ik·im n udiwenni akken ad d-tesnulfuḍ tasarut tamaynut n tririt?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "S tansiwin-agi i tzemreḍ ad terreḍ awal-ik·im n uɛeddi.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Aru izen…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Ih", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "kečč·em", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Ur mazal ara tettekkaḍ deg udiwenni-a", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Tettwagedleḍ seg udiwenni-agi", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Tasarut-ik·im tazayezt", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Talɣut n yizen", + "time": "Akud", + "messageType": "Anaw n yizen", + "sender": "Amazan", + "openGallery": "Ldi timidelt", + "removeFromSpace": "Kkes seg tallunt", + "addToSpaceDescription": "Fren tallunt akken ad ternuḍ adiwenni-a.", + "start": "Senker", + "publish": "Suffeɣ-d", + "videoWithSize": "Avidyu ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "openChat": "Ldi Adiwenni", + "markAsRead": "Creḍ amzun yettwaɣṛa", + "reportUser": "Cetki aseqdac", + "dismiss": "Agi", + "reactedWith": "{sender} err-d s {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Senteḍ ɣer texxamt", + "confirmEventUnpin": "Tebɣiḍ ad tekkseḍ s wudem imezgi asenṭed n tadyant-nni?", + "emojis": "Imujiten", + "placeCall": "Sɛeddi Asiwel", + "voiceCall": "Asiwel n taɣect", + "removeAllOtherDevices": "Kkes akk ibenkan-nniḍen", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Yettwakkes sɣur {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Kkes ibenk", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Kkes agdal seg udiwenni", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Kkes avaṭar-ik·im", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Semselsi taxxamt s lqem amaynut", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Err", + "@reply": { + "type": "String", + "placeholders": {} + }, + "confirm": "Sentem", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Qqen", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Anermis yettwaɛreḍ ɣer ugraw", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Igber askan n yisem", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Igber isem n useqdac", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Agbur yettwammel i inedbalen n uqeddac", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Ttekkiɣ ɣef useɣwen", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Tafyirt n uɛeddi neɣ tasarut n tririt d tarameɣtut", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Ur yettḍurru ara", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Snubg anermis", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroupQuestion": "Tebɣiḍ ad d-ɛerḍeḍ {contact} ɣer udiwenni \"{groupName}\"?", + "inviteContactToGroup": "Snubg anermis ɣer {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "Ulac aglam n udiwenni i d-yenulfan yakan.", + "inviteText": "{username} yeɛreḍ-ik·m ɣer FluffyChat.\n1. Rzu ɣer fluffychat.im syin sbedd asnas \n2. Jerred neɣ kcem \n3. Ldi aseɣwen n tinubga: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "configureChat": "Swel adiwenni", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "id": "Asulay", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Tamagit", + "@identity": { + "type": "String", + "placeholders": {} + }, + "block": "Iḥder", + "blockedUsers": "Iseqdacen yettusweḥlen", + "blockUsername": "Zgel isem n useqdac", + "loadMore": "Sali-d ugar…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Imeẓla n wadig nsan. Ma ulac aɣilif, rmed-iten akken ad izmiren ad bḍun ideg-ik·im.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Tisirag n wadig tettwagdel. Ttxil-k·m efk-asen amek ara bḍun ideg-ik·im.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "Semḍen tangalt QR", + "offline": "Aruqqin", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "iH", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Deg uẓeṭṭa", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Aḥraz n tsarut deg uẓeṭṭa yermed", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "unread": "Ur yettwaɣri ara", + "sendOnEnter": "Azen ɣef Kcem", + "space": "Tallunt", + "oopsPushError": "Ayhu! nesḥissif, teḍra-d tuccḍa deg usbadu n yilɣa usriden.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ihuh, yella wayen ur neddi ara…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Ldi asnas akken ad teɣreḍ iznan", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Ldi takamiṛat", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Ldi takamiṛat i tvidyut", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "moreEvents": "Ugar n ineḍruyen", + "declineInvitation": "Agi tinnubga", + "noMessagesYet": "Ulac iznan akka tura", + "longPressToRecordVoiceMessage": "Asiti aɣezzfan i usekles n yizen n taɣect.", + "pause": "Serǧu", + "resume": "Kemmel", + "newSubSpace": "Tallunt tanaddawt tamaynut", + "moveToDifferentSpace": "Smutti ɣer tallunt yemgaraden", + "moveUp": "Ddu d asawen", + "moveDown": "Ddu d akessar", + "removeFromSpaceDescription": "Adiwenni ad yettwakkes seg tallunt maca mazal ad yettban deg tebdart-ik·im n udiwenni.", + "countChats": "{chats} idiwenniyen", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Aɛeggal n tallunt n {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Mudd tawsa", + "startedAPoll": "{username}yessenker tafrent.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Tafrent", + "startPoll": "Senker tafrent", + "endPoll": "Eg taggara n tafrent", + "answersVisible": "Tiririyin yettbanen", + "answersHidden": "Tiririyin yeffren", + "pollQuestion": "Isteqsiyen n tefrent", + "answerOption": "tanefrunt n tririt", + "addAnswerOption": "Rnu tanefrunt n tririt", + "allowMultipleAnswers": "Sireg aget n tiririyin", + "pollHasBeenEnded": "Tafrent tfukk", + "answersWillBeVisibleWhenPollHasEnded": "Tiririyin ad banent ticki tafrent tfukk", + "replyInThread": "Err deg udras udiwenni", + "thread": "Adras udiwenni", + "oneOfYourDevicesIsNotVerified": "iwen seg ibenkan-ik·im ur yettusenqed ara", + "noticeChatBackupDeviceVerification": "Tamawt: Mi ara teqqneḍ akk ibenkan-ik·im ɣer weḥraz udiwenni, ttusneqden s wudem awurman.", + "continueText": "Ddu", + "blur": "Asluɣu:", + "opacity": "Tiḍullest:", + "setWallpaper": "Sbadu tugna ugilal", + "manageAccount": "Sefrek amiḍan", + "noContactInformationProvided": "Aqeddac ur yezmir ara ad d-yefk talɣut n unermis tameɣtut", + "contactServerAdmin": "Nermes anedbal n uqeddac", + "contactServerSecurity": "Taɣellist uqeddac n unermis", + "supportPage": "Asebter n tallalt", + "serverInformation": "Talɣut n uqeddac:", + "name": "Isem", + "version": "Lqem", + "website": "Asmel Web", + "compress": "Sekussem", + "boldText": "Aḍris azuran", + "italicText": "Aḍris uknan", + "strikeThrough": "Yettwajeṛṛeḍ", + "pleaseFillOut": "Ttxil-k·m, ččar", + "invalidUrl": "url armeɣtu", + "addLink": "Rnu aseɣwen", + "serverLimitReached": "Talast n uqeddac tewweḍ! Araǧu n {seconds} n tasinin…", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "unableToJoinChat": "Ur yezmir ara ad yernu ɣer udiwenni. Ahat aseqdac n udiwenni-agi imdel-it yakan.", + "previous": "Uzwir", + "otherPartyNotLoggedIn": "Aḥric nniḍen ur yeqqin ara akka tura, ihi ur yezmir ara ad d-yeṭṭef iznan!", + "appWantsToUseForLogin": "Seqdec '{server}' akken ad teqqneḍ", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "open": "Ldi", + "waitingForServer": "Araǧu n uqeddac...", + "newChatRequest": "📩 Asuter n udiwenni amaynut", + "contentNotificationSettings": "Iɣewwaṛen n telɣut n ugbur", + "generalNotificationSettings": "Iɣewwaren imuta n ilɣa", + "roomNotificationSettings": "Iɣewwaṛen n telɣut n texxamt", + "userSpecificNotificationSettings": "Iɣewwaṛen n telɣut n useqdac", + "otherNotificationSettings": "Iɣewwaṛen-nniḍen n telɣut", + "notificationRuleContainsUserName": "Yegber isem n useqdac", + "notificationRuleContainsUserNameDescription": "Azen tilɣa i useqdac ma yella yizen yegber isem-is useqdac.", + "notificationRuleMaster": "Sgugem akk tilɣa", + "notificationRuleMasterDescription": "Ad isemselsi akk ilugan-nniḍen sakin ad sexsi akk tilɣa.", + "notificationRuleSuppressNotices": "Kkes iznan s wudem awurman", + "notificationRuleSuppressNoticesDescription": "Kkes ilɣa seg imsaɣen iwurmanen am yiṛubuten.", + "notificationRuleInviteForMe": "Asnubget i nekk", + "notificationRuleInviteForMeDescription": "Azen ilɣa i useqdac ticki yettwaɛreḍ ɣer texxamt.", + "notificationRuleMemberEvent": "Tadyant i yiɛeggalen", + "notificationRuleIsUserMention": "Abdar n useqdac", + "notificationRuleIsUserMentionDescription": "Azen ilɣa i useqdac ma yella yettwabder s srid deg yizen.", + "notificationRuleContainsDisplayName": "Yegber Isem n ubeqqeḍ", + "notificationRuleContainsDisplayNameDescription": "Azen ilɣa i useqdac ma yella yizen yegber Isem-is n ubeqqeḍ.", + "notificationRuleIsRoomMention": "Abdar n Texxamt", + "notificationRuleIsRoomMentionDescription": "Azen ilɣa i useqdac ticki yella ubdar n texxamt.", + "badServerLoginTypesException": "Aqeddac agejdan issefrak anawen n tuqqna:\n{serverVersions}\nMaca asnas-agi issefrak kan:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendTypingNotifications": "Azen alɣu ttaruɣ", + "swipeRightToLeftToReply": "Zuɣer seg uyeffus ɣer uzelmaḍ akken ad d-terreḍ", + "badServerVersionsException": "Aqeddac agejdan issefrak ileqman Spec:\n{serverVersions}\nMaca asnas-agi issefrak kan {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "countChatsAndCountParticipants": "{chats} n yidiwenniyen akked {participants} n yimttekkiyen", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Ulac ugar n idiwenniyen yettwafen…", + "noChatsFoundHere": "Ur d-nufi ula d yiwen n udiwenni da. Bdu adiwenni akked yiwen s useqdec n tqeffalt ukessar-a. ⤵️", + "joinedChats": "Yettwarna ɣer udiwenni", + "widgetName": "Isem", + "widgetUrlError": "Wagi mačči d URL ameɣtu.", + "widgetNameError": "Ttxil-k·m sekcem isem n uskan.", + "errorAddingWidget": "Tuccḍa deg tmerna n uwiǧit.", + "youRejectedTheInvitation": "Tugiḍ tinnubga", + "youJoinedTheChat": "Tekcemeḍ ɣer udiwenni", + "youAcceptedTheInvitation": "👍 Tqebleḍ tinubga", + "youBannedUser": "Tgedleḍ {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Tekkseḍ tinnubga i {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Tettwaɛerḍeḍ s useɣwen ɣer:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Tettwaɛerḍeḍ sɣur {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "invitedBy": "📩 Tettwaɛerḍeɣ sɣur {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Tɛerḍeḍ-d {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Tegliḍ s rrkel {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Tegliḍ s rrkel u tgedleḍ {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Tekkseḍ agdel n {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hasKnocked": "🚪{user} yesṭebṭbed", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Iseqdacen yessefk ad sṭebṭben", + "noOneCanJoin": "Yiwen ur yezmir ad d-yernu", + "userWouldLikeToChangeTheChat": "{user} yebɣa ad yettekki deg udiwenni.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Werɛad ur d-yennulfa ula d yiwen n wassaɣ azayez", + "users": "Iseqdacen", + "unlockOldMessages": "Kkes asekkeṛ i yiznan iqbuṛen", + "storeInSecureStorageDescription": "Ḥrez tasarut n tririt deg usekles aɣelsan n yibenk-a.", + "saveKeyManuallyDescription": "Sekles tasarut-agi s ufus deg udiwenni n beṭṭu n unagraw neɣ ɣef tecfawit.", + "storeInAndroidKeystore": "Sekles deg Android KeyStore", + "storeInAppleKeyChain": "Sekles deg uzrar n tsura n Apple", + "storeSecurlyOnThisDevice": "Ḥrez s wudem aɣelsan ɣef yibenk-a", + "countFiles": "{count} n yifuyla", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "user": "Aseqdac", + "custom": "Yugnen", + "foregroundServiceRunning": "Alɣu-agi yettban-d ticki ameẓlu n uɣawas amezwaru iteddu.", + "screenSharingTitle": "beṭṭu n ugdil", + "screenSharingDetail": "Tbeṭṭuḍ agdil-ik·im deg FluffyChat", + "callingPermissions": "Tisirag n usiwel", + "callingAccount": "amiḍan n usiwel", + "callingAccountDetails": "Sireg FluffyChat ad iseqdec asnas aneṣli n Android i usɛeddi n usiwel.", + "appearOnTop": "Sbeqeḍ deg uksawen", + "otherCallingPermissions": "Tisirag n umikrufun, takamiṛat akked tiyaḍ n FluffyChat", + "whyIsThisMessageEncrypted": "Acuɣer izen-agi ur yettwaɣri ara?", + "recoveryKeyLost": "Tasarut n tririt teɛreq?", + "seenByUser": "Yemmẓer sɣur {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Azen", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Azen izen", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Azen am uḍris", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Azen ameslaw", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Azen afaylu", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Azen tugna", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendImages": "Azen {count} n tugna(iwin)", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendMessages": "Azen iznan", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Azen aneṣli", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Azen ticṛeṭ n tesfift", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Azen avidyu", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} yuzen afaylu", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} yuzen ameslaw", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} yuzen tugna", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} yuzen ticṛeṭ n tesfift", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} yuzen tavidyut", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} yuzen talɣut n usiwel", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Sbadu-t d tazaẓlut tagejdant", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "noOtherDevicesFound": "Ulac ibenkan nniḍen yettwafen", + "fileIsTooBigForServer": "Ur izmir ara ad yazen! Aqeddac yessefrak kan ifuyla imeddayen almi ɣer {max}.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "Afaylu yettwasekles deg {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Ddu ɣer yizen aneggaru yettwaɣen", + "readUpToHere": "Ɣeṛ dagi", + "jump": "Neggez", + "openLinkInBrowser": "Ldi aseɣwen deg yiminig", + "reportErrorDescription": "😭 Uhu. Yella kra n wugur ay yellan. Ma tebɣiḍ, tzemreḍ ad tazneḍ aneqqis-a i yineflayen.", + "report": "aneqqis", + "signInWithPassword": "Kcem s wawal n uɛeddi", + "pleaseTryAgainLaterOrChooseDifferentServer": "Ma ulac aɣilif, ɛreḍ tikelt nniḍen ticki neɣ fren aqeddac nniḍen.", + "profileNotFound": "Aseqdac ur yettwaf ara deg uqeddac. Ahat yella wugur n uẓeṭṭa neɣ aseqdac ulac-it.", + "setTheme": "Sbadu asentel:", + "setColorTheme": "Sbadu asentel n yini:", + "invite": "Snubget", + "inviteGroupChat": "📨Snubget ɣer udiwenni n ugraw", + "invitePrivateChat": "📨Snubget ɣze udiwenni Uslig", + "invalidInput": "Anekcam d armeɣtu!", + "wrongPinEntered": "Tettwasekcem tangalt PIN d armeɣtut! Ɛreḍ tikkelt nniḍen deg {seconds} n tasinin…", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pleaseEnterANumber": "Ma ulac aɣilif sekcem amḍan yugaren 0", + "unknownEncryptionAlgorithm": "Alguritm n uwgelhen d arussin", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Tadyant tarussint '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Kkes asgugem i udiwenni", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unsupportedAndroidVersion": "Lqem Android ur yettwasefrak ara", + "unsupportedAndroidVersionLong": "Tamahilt-a tesra lqem Android tamaynut. Ttxil-k·m senqed ileqman neɣ asefrak n Lineage OS.", + "startFirstChat": "Senker adiwenni-ik·im amezwaru", + "status": "Addad", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Amek telliḍ ass-a?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Ceyyeɛ", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Amtawi... Ttxil-k·m arǧu.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWaitCounter": " Amtawi… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "systemTheme": "Anagraw", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Ur mṣadan ara", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "mṣadan", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Qluqel asmenyif", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Qluqel asgugem", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Creḍ Yettwaɣri/Ur yettwaɣri ara", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Deqs n tuttriwin. Ttxil-k·m, ɛreḍ tikelt nniḍen ticki!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Asiweḍ seg yibenk nniḍen", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Ɛreḍ ad tazneḍ tikkelt nniḍen", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Ur yewjid ara", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} yekkes agdek n {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Kkes asewḥel n yibenk", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Ibenk arussin", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "skip": "Zgel", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Tangalt taɣbalutt", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Tallunt d tazayezt", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Isem n tallunt", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} yebda-d asiwel", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "pleaseEnterRecoveryKeyDescription": "Akken ad tekkseḍ asekkeṛ i yiznan-ik·im iqburen, ttxil-k·m sekcem tasarut n tririt i d-yenulfan di tɣimit tuzwirt. Tasarut-ik·im n tririt UR TELLI ARA d awal-ik·im n uɛeddi.", + "experimentalVideoCalls": "Isawalen uvidya s wudem armitan", + "emailOrUsername": "Imayl neɣ isem n useqdac", + "indexedDbErrorTitle": "Uguren n uskar uslig", + "indexedDbErrorLong": "Asekles n yizen ur yettwarmed ara deg uskar uslig s wudem amezwer.\nTtxil-k·m rzu ɣer\n - ɣef:swel\n - sbadu om.indexedDB.privateBrowsing.enabled ɣer d ilaw\nMa ulac, ur yezmir ara ad isselkem FluffyChat.", + "switchToAccount": "Ddu ɣer umiḍan {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Amiḍan uḍfir", + "previousAccount": "Amiḍan yezrin", + "addWidget": "Rnu awiǧit", + "widgetVideo": "Avidyu", + "widgetEtherpad": "Tazmilt n uḍris", + "widgetJitsi": "Asarag Jitsi", + "widgetCustom": "Sagen", + "newGroup": "Agraw amaynut", + "newSpace": "Tallunt tamaynut", + "enterSpace": "Kcem tallunt", + "enterRoom": "Kcem taxxamt", + "allSpaces": "Akk tallunin", + "numChats": "{number} idiwenniyen", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "verifiedDevicesOnly": "Ibenkan yettwasneqden kan", + "optionalMessage": "(D afrayan) izen…", + "notSupportedOnThisDevice": "Ur itteddu ara deg yibenk-agi", + "approve": "Sqbel", + "enterNewChat": "Sekcem adiwenni amaynut", + "pleaseWaitUntilInvited": "Ttxil-k·m, rǧu arma yeɛreḍ-ik-id yiwen seg texxamt.", + "commandHint_logout": "Senser seg yibenk-ik·im amiran", + "commandHint_logoutall": "Senser akk ibenkan urmiden", + "displayNavigationRail": "Sken afeggag n yinig deg uziraz", + "customReaction": "Tasedmirt yugnen", + "backToMainChat": "Uɣal ɣer udiwenni agejdan", + "createSticker": "Snulfu-d ticṛeṭ n tesfift neɣ imujiten", + "useAsSticker": "Seqdec am tcṛeṭ n tesfift", + "useAsEmoji": "Seqdec am imujit", + "stickerPackNameAlreadyExists": "Isem ukemmus n tcṛeṭ n tesfift yella yakan", + "newStickerPack": "Akemmus n tcṛeṭ n tesfift", + "stickerPackName": "Isem ukemmus n tcṛeṭ n tesfift", + "skipChatBackup": "Zgel aḥraz n udiwenni", + "skipChatBackupWarning": "tetḥeqqeḍ? S war armad n weḥraz n udiwenni, tzemreḍ ad tesruḥeḍ anekcum ɣer yiznan-ik·im ma tbeddeleḍ ibenk-ik·im.", + "loadingMessages": "Asali n yiznan", + "setupChatBackup": "Sbadu aḥraz n udiwenni", + "noMoreResultsFound": "Ulac ugar n igmaḍ yettwafen", + "clientWellKnownInformation": "Talɣut yettwasnen ɣef umsaɣ:", + "advancedConfigs": "Tawila leqqayen", + "advancedConfigurations": "Tawila tinaẓiyin", + "signUpGreeting": "FluffyChat d araslemmes! Fren aqeddac anda tebɣiḍ ad ternuḍ amiḍan-ik·im, u yyaw ad neddu!", + "signInGreeting": "Tesɛiḍ yakan amiḍan deg Matriks? Anṣuf yes-k·m tikkelt niḍen! Fren aqeddac-ik·im, u tkecmeḍ.", + "theProcessWasCanceled": "Tettwasefsex ukala-nni.", + "searchOrEnterHomeserverAddress": "Nadi neɣ sekcem tansa n uqeddac agejdan", + "setPowerLevel": "Sbadu aswir n tezmert", + "removeAdminRights": "Kkes izerfan n unedbal", + "powerLevel": "Aswir n tezmert", + "help": "Tallelt", + "@help": { + "type": "String", + "placeholders": {} + }, + "privacy": "Tabaḍnit", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "reason": "Taɣẓint", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Asekles", + "@recording": { + "type": "String", + "placeholders": {} + }, + "register": "Jerred", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Aggi", + "@reject": { + "type": "String", + "placeholders": {} + }, + "search": "Nadi", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Taɣellist", + "@security": { + "type": "String", + "placeholders": {} + }, + "settings": "Iɣewwaren", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Bḍu", + "@share": { + "type": "String", + "placeholders": {} + }, + "unpin": "Kkes anṭaḍ", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "knock": "Sqeṛbeb", + "knocking": "Sqeṛbeb", + "select": "Fren", + "gallery": "Timidelt", + "files": "Ifuyla", + "transparent": "Afrawan", + "discover": "Snirem", + "changelog": "Aɣmis n ibeddilen", + "notificationRuleCall": "Asiwel", + "notificationRuleMessage": "Izen", + "notificationRuleEncrypted": "Yettwawgelhen", + "notificationRuleJitsi": "Jitsi", + "more": "Ugar", + "logs": "Iɣmisen", + "join": "Ttekki", + "owner": "Amli", + "changePassword": "Asnifel n wawal n uɛeddi", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "commandHint_send": "Azen aḍris", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "addAccount": "Rnu amiḍan", + "directChat": "Adiwenni usrid", + "redactMessage": "Kkes izen", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Suter tasiregt", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Sekles afaylu", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "Tasarut n tririt", + "setStatus": "Sbadu addad", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Bḍu adig", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Sken-d awal n uɛeddi", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "deviceKeys": "Tisura n yibenk:", + "learnMore": "Issin ugar", + "groupName": "Isem n ugraw", + "startConversation": "Bdu adiwenni", + "newPassword": "Awal n uɛeddi amaynut", + "publicLink": "Aseɣwen azayaz", + "thisDevice": "Ibenk-a:", + "userRole": "Tamlilt n useqdac", + "searchMore": "Nadi ugar…", + "allDevices": "Akk ibenkan", + "saveChanges": "Sekles ibeddilen", + "baseUrl": "URL n taffa", + "identityServer": "Aseqdac n tmagit:", + "versionWithNumber": "Lqem: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "signIn": "Qqen", + "matrixId": "Asulay ID Matrix", + "makeAdmin": "Err-it d anedbal", + "openInMaps": "Ldi-t deg maps", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Asesteb asuf", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "encryptThisChat": "Wgelhen adiwenni-a", + "searchForUsers": "Nadi iseqdacen…", + "createNewAddress": "Snulfu-d tansa tamaynut", + "adminLevel": "{level} - Tadbelt", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "loginWithMatrixId": "Tuqqna s usulay ID n Matrix", + "calculatingFileSize": "Asiḍen n tiddi n ufaylu...", + "shareKeysWith": "Bḍu tisura akked…", + "takeAPhoto": "Ṭṭef tawlaft", + "recordAVideo": "Sekles tavidyut", + "createNewAccount": "Snulfu-d amiḍan amaynut", + "pleaseEnterYourPassword": "Ma ulac aɣilif, sekcem-d awal-ik n uɛeddi", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "doNotShowAgain": "Ur t-id-sskan ara tikkelt nniḍen", + "passwordsDoNotMatch": "Awalen n uɛeddi mgarraden", + "searchIn": "Nadi deg udiwenni \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "enableMultiAccounts": "(armitan) Rmed aget n yimiḍanen deg yibenk-agi", + "hideMemberChangesInPublicChatsBody": "Ur d-skan ara deg yizirig n wakud ma yella win i d-yernan neɣ yeffɣen adiwenni azayez i usnerni n tɣara n tɣuṛi.", + "pleaseEnter4Digits": "Ttxil-k·m sekcem 4 n wuṭṭunen neɣ eǧǧ-it d ilem akken ad tsenseḍ asekkeṛ n usnas.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKey": "Ttxil-k·m sekcem tasarut-ik·im n tririt:", + "pleaseEnterYourPin": "Ttxil-k·m sekcem tangalt-ik·im pin", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Ma ulac aɣilif sekcem isem n useqdac", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Ma ulac aɣilif, ḍfeṛ iwellihen n usmel web sakin sit ɣef uḍfir.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Tixxamin tizuyaz", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} yugi tinnubga-nni", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "ales attekki tikkelt nniḍen", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Mmel-d izen", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Taxxamt tettwaleqqem", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Lqem n texxamt", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "separateChatTypes": "Brez Idiwenniyen usriden akked igrawen", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "setChatDescription": "Sbadu aglam n udiwenni", + "setInvitationLink": "Sbadu aseɣwen n tinubga", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Sbadu aswir n tsirag", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} yebḍa adig-is", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "compressVideo": "Asekkussem n tvidyut...", + "sendingAttachmentCountOfCount": "Tuzna umedday {index} n {length}…", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "welcomeText": "Azul Azul 👋 Wa d FluffyChat. Tzemreḍ ad tkecmeḍ ɣer uqeddac agejdan, yellan yemsaḍa akked https://matrix.org. Dɣa meslay d win tebɣiḍ, d aẓeṭṭa n udiwenni araslemmas amuqṛan!", + "notificationRuleRoomnotif": "Alɣu n texxamt", + "notificationRuleRoomnotifDescription": "Azen alɣu i useqdec mi ara yelli yizen yegber '@room'.", + "notificationRuleTombstoneDescription": "Azen alɣu i useqdec ɣef yiznan n usens n texxamt.", + "notificationRuleReaction": "Tasedmirt", + "notificationRuleReactionDescription": "Kkes ilɣa i tsedmirin.", + "notificationRuleSuppressEdits": "Kkes Asiẓreg", + "notificationRuleSuppressEditsDescription": "Kkes ilɣa i yeznan yettwaẓergen.", + "notificationRuleCallDescription": "Azen alɣu i useqdac ɣef isawalen.", + "notificationRuleEncryptedRoomOneToOne": "Taxxamt yettwawgelhen s wudem n yiwen ɣer yiwen", + "notificationRuleRoomOneToOne": "Taxxamt s wudem n yiwen ɣer yiwen" +} diff --git a/lib/l10n/intl_ko.arb b/lib/l10n/intl_ko.arb new file mode 100644 index 000000000..2697a159a --- /dev/null +++ b/lib/l10n/intl_ko.arb @@ -0,0 +1,3295 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.975135", + "about": "소개", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "수락", + "@accept": { + "type": "String", + "placeholders": {} + }, + "allChats": "모든 채팅", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "URI {uri}를 열 수 없습니다", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "chats": "채팅", + "@chats": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "이 방에서 주어진 유저 영구 추방하기", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "HTML 형식의 문자 보내기", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "주어진 유저 이 룸에 초대하기", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_leave": "이 룸 나가기", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "자신을 소개하세요", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_plain": "형식이 지정되지 않은 문자 보내기", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_send": "문자 보내기", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "주어진 유저를 이 방에서 영구추방 해제하기", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "loadMore": "더 불러오기…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "{count}명의 참가자 더 표시", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "lightTheme": "라이트", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "license": "라이선스", + "@license": { + "type": "String", + "placeholders": {} + }, + "help": "도움", + "@help": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "게스트가 참가할 수 있음", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "groups": "그룹 채팅", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "그룹 채팅 공개", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "group": "그룹 채팅", + "@group": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "새로운 방 가기", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "초대받은 후부터", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "참가시점 이후로", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "forward": "전달", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fontSize": "폰트 크기", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fileName": "파일 이름", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "매우 공격적임", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "모든 것이 준비됐어요!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "당신의 홈서버를 입력하세요", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "homeserver": "홈서버", + "@homeserver": {}, + "enterAnEmailAddress": "이메일 주소 입력", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} 이 통화를 종료했습니다", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "encryptionNotEnabled": "암호화가 비활성화됨", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "encryption": "암호화", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encrypted": "암호화됨", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "당신은 다시 암호화를 비활성화할 수 없습니다. 확실한가요?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "암호화 사용", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "이모트 팩 항상 사용하기", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "빈 채팅", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "이모트 단축키와 이미지를 골라야 합니다!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "이모트 단축키", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "이모트 설정", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "방을 위한 이모트 팩", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "올바르지 않은 이모트 단축키!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "이모트가 이미 존재합니다!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "방 아바타 수정", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "방 별명 수정", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "표시 이름 수정", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "edit": "수정", + "@edit": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "파일 다운로드", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "표시 이름이 변경되었습니다", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "devices": "기기", + "@devices": { + "type": "String", + "placeholders": {} + }, + "deviceId": "기기 ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "device": "기기", + "@device": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "메시지 삭제", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "계정 삭제", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "delete": "삭제", + "@delete": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "새로 참가하는 유저들의 기본 권한 레벨", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "deactivateAccountWarning": "이것은 당신의 계정을 비활성화할 것입니다. 이것은 되돌릴 수 없습니다! 확실한가요?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "현재 활동 중", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "새로운 스페이스", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username}님이 채팅을 생성함", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "create": "생성", + "@create": { + "type": "String", + "placeholders": {} + }, + "countParticipants": "{count} 참여자", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "couldNotDecryptMessage": "메시지 복호화할 수 없음: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "copyToClipboard": "클립보드에 복사", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "복사", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "클립보드에 복사됨", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "콘텐츠가 서버 운영자에게 신고되었습니다", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "내 아이디 포함", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "내 닉네임 포함", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "연락처가 채팅에 초대되었습니다", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "connect": "연결", + "@connect": { + "type": "String", + "placeholders": {} + }, + "confirm": "확인", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "configureChat": "채팅 설정", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "아래의 숫자가 일치하는지 비교하세요", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "아래의 이모지가 일치하는지 비교하세요", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "commandMissing": "{command} 는 명령어가 아닙니다.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "commandInvalid": "잘못된 명령어", + "@commandInvalid": { + "type": "String" + }, + "commandHint_react": "답장 반응으로 보내기", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_op": "주어진 유저의 권한 레벨 설정 (기본:50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_myroomnick": "이 방의 표시 이름 설정하기", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_myroomavatar": "이 방의 사진 설정하기 (by mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_kick": "주어진 유저 방에서 삭제하기", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_join": "주어진 방 참가하기", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "close": "닫기", + "@close": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "저장 지우기", + "@clearArchive": {}, + "chooseAStrongPassword": "안전한 비밀번호를 설정하세요", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "이 스페이스에 채팅이 추가되었습니다", + "@chatHasBeenAddedToThisSpace": {}, + "chatDetails": "채팅 정보", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "당신의 오래된 메시지는 보안 키로 보호됩니다. 이 키를 잃어버리지 마세요.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "채팅 백업", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chat": "채팅", + "@chat": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "암호화가 손상되었습니다", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "아바타 바꾸기", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "채팅의 이름 바꾸기", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "스타일 바꾸기", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "홈서버 바꾸기", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changePassword": "비밀번호 바꾸기", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changedTheRoomInvitationLink": "{username}님이 초대 링크를 바꿈", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username}님이 방 별명을 바꿈", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username}님이 자신의 아바타를 바꿈", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username}님이 참가 규칙을 {joinRules} 로 바꿈", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username}님이 참가 규칙을 바꿈", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username}님이 대화 기록 설정을 {rules} 로 바꿈", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username}님이 대화 기록 설정을 변경함", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username}님이 게스트 접근 규칙을 {rules} 로 변경함", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username}님이 게스트 접근 규칙을 변경함", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username}님이 닉네임을 '{displayname}' 로 바꿈", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username}님이 채팅 권한을 바꿈", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username}님이 채팅 이름을 '{chatname}' 으로 바꿈", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username}님이 채팅 설명을 '{description}' 으로 변경함", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatAvatar": "{username}님이 채팅 아바타를 바꿈", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeDeviceName": "기기 이름 바꾸기", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "cancel": "취소", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "botMessages": "봇 메시지", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "blocked": "차단됨", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "기기 차단", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username}님이 {targetName}님을 영구 추방함", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "banned": "영구 추방됨", + "@banned": { + "type": "String", + "placeholders": {} + }, + "banFromChat": "채팅에서 영구 추방", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "이 홈서버가 지원하는 Spec 버전:\n{serverVersions}\n하지만 이 앱은 {supportedVersions}만 지원합니다", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendOnEnter": "엔터로 보내기", + "@sendOnEnter": {}, + "badServerLoginTypesException": "홈서버가 지원하는 로그인 유형:\n{serverVersions}\n하지만 이 앱에서 지원하는 것은:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "autoplayImages": "자동으로 움직이는 스티커와 이모트 재생", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "askVerificationRequest": "{username}님의 인증 요청을 수락할까요?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "askSSSSSign": "다른 사람을 서명하기 위해서, 저장 비밀번호나 복구 키를 입력해주세요.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "로그아웃하고 싶은 것이 확실한가요?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "확실한가요?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "게스트 유저의 참가 여부", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "저장", + "@archive": { + "type": "String", + "placeholders": {} + }, + "appLock": "앱 잠금", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "anyoneCanJoin": "누구나 참가할 수 있음", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName}님이 전화에 응답했습니다", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "alias": "별명", + "@alias": { + "type": "String", + "placeholders": {} + }, + "admin": "운영자", + "@admin": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "스페이스에 추가", + "@addToSpace": {}, + "addEmail": "이메일 추가", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username}님이 종단간 암호화를 활성화함", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "계정", + "@account": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username}님이 초대를 수락함", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "ignore": "무시", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "identity": "신원", + "@identity": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "이 콘텐츠가 얼마나 모욕적인가요?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "알 수 없는 이벤트 숨기기", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "지워진 이벤트 숨기기", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username}님이 {targetName}님에 대한 초대를 철회함", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "guestsAreForbidden": "게스트가 들어올 수 없음", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "groupWith": "{displayname}님과의 그룹", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "errorObtainingLocation": "위치 얻는 중 오류: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "editBlockedServers": "차단된 서버 수정", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "directChats": "다이렉트 채팅", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "darkTheme": "다크", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "yes": "확인", + "@yes": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "메시지 작성…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "이 주소로 당신의 비밀번호를 복구할 수 있습니다.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "새로운 복구키를 생성하기 위해 채팅 백업을 초기화할까요?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "왜 이것을 신고하려고 하나요?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "참가 제한 설정", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "누가 어떤 행동을 할 수 있는지", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "우리가 당신에게 이메일을 보냈습니다", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "warning": "경고!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "배경:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "상대가 숫자를 수락하길 기다리는 중…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "상대가 이모지를 수락하길 기다리는 중…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "상대가 요청을 수락하길 기다리는 중…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "음성 메시지", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "모두에게 보임", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "모든 참가자에게 보임", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "videoCall": "영상 통화", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "다른 계정 확인 중", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "성공적으로 확인했어요!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "확인 시작", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verify": "확인", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verified": "확인됨", + "@verified": { + "type": "String", + "placeholders": {} + }, + "username": "유저 이름", + "@username": { + "type": "String", + "placeholders": {} + }, + "userLeftTheChat": "🚪 {username}님이 채팅을 나감", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userIsTyping": "{username}님이 입력 중…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userAndUserAreTyping": "{username}님과 {username2}님이 입력 중…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userAndOthersAreTyping": "{username}님 + {count}명이 입력 중…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "unpin": "고정 해제", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "알 수 없는 암호화 알고리즘", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unblockDevice": "기기 차단 해제", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "pin": "고정", + "@pin": { + "type": "String", + "placeholders": {} + }, + "pickImage": "이미지 고르기", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "비밀번호 복구", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "비밀번호 까먹음", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "password": "비밀번호", + "@password": { + "type": "String", + "placeholders": {} + }, + "participant": "참여자", + "@participant": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "지도에서 열기", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "addAccount": "계정 추가", + "@addAccount": {}, + "openCamera": "카메라 열기", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "앱을 열어서 메시지를 읽으세요", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "앗, 무언가가 잘못되었습니다…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "앗! 안타깝게도, 푸시 알림을 설정하는 중 오류가 발생했습니다.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "online": "온라인", + "@online": { + "type": "String", + "placeholders": {} + }, + "ok": "확인", + "@ok": { + "type": "String", + "placeholders": {} + }, + "offline": "오프라인", + "@offline": { + "type": "String", + "placeholders": {} + }, + "offensive": "모욕적임", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "위치 얻는 중…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count}명이 입력 중…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "notificationsEnabledForThisAccount": "이 계정에서 알림이 활성화되었습니다", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "notifications": "알림", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "noPermission": "권한 없음", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "QR 코드 스캔", + "@scanQrCode": {}, + "noMatrixServer": "{server1}은 matrix 서버가 아닙니다, {server2}를 대신 사용할까요?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "next": "다음", + "@next": { + "type": "String", + "placeholders": {} + }, + "logInTo": "{homeserver} 에 로그인", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "login": "로그인", + "@login": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "위치 권한이 거부되었습니다. 위치를 공유하기 위해서 허용해주세요.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "위치 서비스가 비활성화되었습니다. 위치를 공유하려면 활성화시켜주세요.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "no": "아니요", + "@no": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "새로운 확인 요청!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 FluffyChat에서 새로운 메시지", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newChat": "새 채팅", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "muteChat": "채팅 음소거", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "messages": "메시지", + "@messages": { + "type": "String", + "placeholders": {} + }, + "mention": "멘션", + "@mention": { + "type": "String", + "placeholders": {} + }, + "logout": "로그아웃", + "@logout": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{읽지 않은 채팅 1} other{{unreadCount} 개}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "unavailable": "사용할 수 없음", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "all": "모두", + "@all": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "당신의 공개 키", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "당신은 이 채팅에서 영구 추방되었습니다", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "당신은 더 이상 이 채팅에 참여하지 않습니다", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "you": "당신", + "@you": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "대화 기록 설정", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username}님이 {type} 이벤트 보냄", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "unmuteChat": "음소거 해제", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "알 수 없는 이벤트 '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unknownDevice": "알 수 없는 기기", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username}님이 {targetName}님에대한 영구추방을 해제함", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "tryToSendAgain": "다시 보내도록 시도", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "다른 기기에서 가져오기", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "너무 많은 요청. 잠시 후에 다시 시도해주세요!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "메시지 안/읽음 으로 표시", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "음소거 토글", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "즐겨찾기 토글", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "theyMatch": "일치합니다", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "일치하지 않습니다", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "시스템", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "동기화 중... 기다려주세요.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "submit": "제출", + "@submit": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "오늘은 어떤 기분인가요?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "status": "상태", + "@status": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} 가 통화 시작함", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "spaceName": "스페이스 이름", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "스페이스 공개", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "단일 계정 로그인(SSO)", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "pushRules": "푸시 규칙", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "마지막 활동: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "ignoredUsers": "무시된 사용자", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "4자리 숫자를 입력하거나 앱 잠금을 사용하지 않도록 하려면 비워두세요.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "비밀번호를 골라주세요", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "선택해주세요", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "play": "{fileName} 재생", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "people": "사람들", + "@people": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "비밀번호가 변경됨", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "비밀번호나 복구 키", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "or": "이나", + "@or": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "이 서버는 가입을 위해 당신의 이메일을 확인해야 합니다.", + "@serverRequiresEmail": {}, + "enableMultiAccounts": "(베타) 이 기기에서 다중 계정 활성화", + "@enableMultiAccounts": {}, + "bundleName": "번들 이름", + "@bundleName": {}, + "removeFromBundle": "이 번들에서 삭제", + "@removeFromBundle": {}, + "addToBundle": "번들에 추가", + "@addToBundle": {}, + "editBundlesForAccount": "이 계정의 번들 수정", + "@editBundlesForAccount": {}, + "oneClientLoggedOut": "당신의 클라이언트 중 하나가 로그아웃 됨", + "@oneClientLoggedOut": {}, + "onlineKeyBackupEnabled": "온라인 키 백업이 활성화됨", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "아무 방도 발견되지 않았어요…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "당신은 비밀번호를 복구할 방법을 추가하지 않았습니다.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "none": "없음", + "@none": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "이 휴대폰에 Firebase Cloud Messaging 서비스가 없는 것 같습니다. FluffyChat에서 푸시 알림을 받으려면 ntfy 사용을 추천합니다. ntfy 혹은 다른 푸시 알림 제공자를 사용하면 알림을 보안적인 방법으로 받을 수 있습니다. ntfy는 PlayStore와 F-Droid에서 설치 가능합니다.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "당신은 방이 공개적으로 접근 가능하지 않을 때만 암호화를 켤 수 있습니다.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "이모트 발견되지 않음. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "서버에 연결 없음", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "지금 종단간 암호화를 사용하기 위해서는 Pantalaimon이 필요하다는 것을 알아주세요.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "moderator": "관리자", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "참가자 변경", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "loadingPleaseWait": "로딩 중... 기다려 주세요.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "채팅을 나갔습니다", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "leave": "나가기", + "@leave": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "소스 코드", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "skip": "스킵", + "@skip": { + "type": "String", + "placeholders": {} + }, + "showPassword": "비밀번호 보이기", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "위치 보내기", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username}님이 위치를 공유함", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "share": "공유", + "@share": { + "type": "String", + "placeholders": {} + }, + "settings": "설정", + "@settings": { + "type": "String", + "placeholders": {} + }, + "setStatus": "상태 설정", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "권한 레벨 설정", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "초대 링크 설정", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "맞춤 이모트 설정", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "주 별명으로 설정", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "sentCallInformations": "{senderName} 이 통화 정보 보냄", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username}님이 영상을 보냄", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sendOriginal": "원본 보내기", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "메시지 보내기", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendImage": "이미지 보내기", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendFile": "파일 보내기", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "오디오 보내기", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "텍스트로 보내기", + "@sendAsText": { + "type": "String" + }, + "sendAMessage": "메시지 보내기", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "send": "보내기", + "@send": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "{username}님이 읽음", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "security": "보안", + "@security": { + "type": "String", + "placeholders": {} + }, + "search": "검색", + "@search": { + "type": "String", + "placeholders": {} + }, + "saveFile": "파일 저장", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "방 버전", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "방이 업그레이드되었습니다", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "권한 요청", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "reason": "이유", + "@reason": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "공개 방", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "privacy": "프라이버시", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "웹사이트의 가이드를 따르고 다음 버튼을 눌러주세요.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "유저 이름을 입력해주세요", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "PIN을 입력해주세요", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "비밀번호를 입력해주세요", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "방 참가하기", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username}님이 채팅에 참가함", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "isTyping": "입력 중…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username}님이 당신을 FluffyChat에 초대했습니다.\n1. FluffyChat 설치: https://fluffychat.im \n2. 가입하거나 로그인 \n3. 초대 링크 열기: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "inviteForMe": "초대됨", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "invitedUsersOnly": "초대된 유저만", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username}님이 {targetName}님을 초대함", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invited": "초대됨", + "@invited": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "연락처를 {groupName}에 초대", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "inviteContact": "연락처 초대", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "모욕적이지 않음", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "올바르지 않은 복구 키나 비밀번호", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "링크를 클릭했어요", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "sentASticker": "😊 {username}님이 스티커를 보냄", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username}님이 사진을 보냄", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username}님이 오디오를 보냄", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAFile": "📁 {username}님이 파일을 보냄", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sendVideo": "영상 보내기", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "스티커 보내기", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "메시지 신고", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "reply": "답장", + "@reply": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "방 새로운 버전으로 대체하기", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "아바타 지우기", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "채팅에서 영구추방 해제됨", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeDevice": "기기 삭제", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "removedBy": "{username}에 의해 지워짐", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeAllOtherDevices": "모든 다른 기기에서 지우기", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "remove": "지우기", + "@remove": { + "type": "String", + "placeholders": {} + }, + "rejoin": "다시 참가", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username}님이 초대를 거절함", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "거절", + "@reject": { + "type": "String", + "placeholders": {} + }, + "register": "가입", + "@register": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "메시지 지우기", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username}님이 이벤트를 지움", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "recording": "녹음", + "@recording": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "이메일의 링크를 클릭하고 진행해주세요.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "kickFromChat": "채팅에서 추방", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "kickedAndBanned": "🙅 {username}님이 {targetName}님을 추방하고 차단함", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kicked": "👞 {username}님이 {targetName}님을 추방함", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "link": "링크", + "@link": {}, + "unverified": "확인되지 않음", + "@unverified": {}, + "yourChatBackupHasBeenSetUp": "당신의 채팅 백업이 설정되었습니다.", + "@yourChatBackupHasBeenSetUp": {}, + "time": "시간", + "@time": {}, + "messageType": "메시지 유형", + "@messageType": {}, + "openGallery": "갤러리 열기", + "@openGallery": {}, + "sender": "발신자", + "@sender": {}, + "messageInfo": "메시지 정보", + "@messageInfo": {}, + "repeatPassword": "비밀번호 다시 입력", + "@repeatPassword": {}, + "start": "시작", + "@start": {}, + "removeFromSpace": "스페이스에서 삭제", + "@removeFromSpace": {}, + "addToSpaceDescription": "이 채팅을 추가할 스페이스를 선택하세요.", + "@addToSpaceDescription": {}, + "commandHint_discardsession": "세션 삭제", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "다이렉트 채팅 시작\t\n--no-encryption을 사용해 암호화 비활성화", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_clearcache": "캐시 지우기", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "빈 그룹 채팅을 생성\n--no-encryption을 사용해 암호화를 비활성화", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "openVideoCamera": "영상용 카메라 열기", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "publish": "공개", + "@publish": {}, + "videoWithSize": "영상 ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "dismiss": "닫기", + "@dismiss": {}, + "markAsRead": "읽음으로 표시하기", + "@markAsRead": {}, + "reportUser": "유저 신고", + "@reportUser": {}, + "openChat": "채팅 열기", + "@openChat": {}, + "reactedWith": "{sender}가 {reaction}로 반응함", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "confirmEventUnpin": "이벤트를 영구적으로 고정 해제할 것이 확실한가요?", + "@confirmEventUnpin": {}, + "pinMessage": "방에 고정", + "@pinMessage": {}, + "emojis": "이모지", + "@emojis": {}, + "voiceCall": "음성 통화", + "@voiceCall": {}, + "placeCall": "전화 걸기", + "@placeCall": {}, + "experimentalVideoCalls": "실험적인 영상 통화", + "@experimentalVideoCalls": {}, + "unsupportedAndroidVersion": "지원되지 않는 안드로이드 버전", + "@unsupportedAndroidVersion": {}, + "unsupportedAndroidVersionLong": "이 기능은 새로운 안드로이드 버전을 요구합니다. Lineage OS 지원이나 업데이트를 확인해주세요.", + "@unsupportedAndroidVersionLong": {}, + "videoCallsBetaWarning": "영상 통화는 베타임을 확인해주세요. 의도한 대로 작동하지 않거나 모든 플랫폼에서 작동하지 않을 수 있습니다.", + "@videoCallsBetaWarning": {}, + "emailOrUsername": "이메일이나 유저 이름", + "@emailOrUsername": {}, + "confirmMatrixId": "계정을 삭제하려면 Matrix ID를 입력해 주세요.", + "@confirmMatrixId": {}, + "commandHint_googly": "왕눈이 눈알 보내기", + "@commandHint_googly": {}, + "googlyEyesContent": "{senderName} 님이 왕눈이 눈알을 보냈습니다", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "그룹 채팅으로 만들기", + "@commandHint_markasgroup": {}, + "dehydrate": "세션을 내보내고 기기 초기화 하기", + "@dehydrate": {}, + "dehydrateWarning": "이 동작은 되돌릴 수 없습니다. 백업 파일을 꼭 안전하게 보관하세요.", + "@dehydrateWarning": {}, + "hugContent": "{senderName}님이 당신을 허그합니다", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "마지막으로 읽은 메시지로 이동", + "@jumpToLastReadMessage": {}, + "allRooms": "모든 그룹 채팅", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "commandHint_cuddle": "미소 보내기", + "@commandHint_cuddle": {}, + "widgetVideo": "영상", + "@widgetVideo": {}, + "reportErrorDescription": "😭 이런. 무언가 잘못되었습니다. 원한다면, 개발자에게 버그를 신고할 수 있습니다.", + "@reportErrorDescription": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "indexedDbErrorLong": "메시지 저장은 기본적으로 사생활 보호 모드에서 사용할 수 없습니다.\n- about:config 로 이동\n- dom.indexedDB.privateBrowsing.enabled 를 true로 설정\n그렇지 않으면 FluffyChat을 실행할 수 없습니다.", + "@indexedDbErrorLong": {}, + "startFirstChat": "첫 번째 채팅을 시작하기", + "@startFirstChat": {}, + "callingAccount": "통화 계정", + "@callingAccount": {}, + "setColorTheme": "색상 테마 설정:", + "@setColorTheme": {}, + "nextAccount": "다음 계정", + "@nextAccount": {}, + "allSpaces": "모든 스페이스", + "@allSpaces": {}, + "supposedMxid": "{mxid} 이어야 함", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "user": "유저", + "@user": {}, + "youAcceptedTheInvitation": "👍 초대를 수락했습니다", + "@youAcceptedTheInvitation": {}, + "youInvitedBy": "📩 {user}님에 의해 초대되었습니다", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "banUserDescription": "유저는 채팅에서 영구 추방되며 추방 해제 전까지 채팅을 다시 입력할 수 없습니다.", + "@banUserDescription": {}, + "widgetEtherpad": "텍스트 메모", + "@widgetEtherpad": {}, + "removeDevicesDescription": "이 기기에서 로그아웃되며 더 이상 메시지를 받을 수 없습니다.", + "@removeDevicesDescription": {}, + "separateChatTypes": "다이렉트 채팅과 그룹 채팅 분리", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "tryAgain": "다시 시도하기", + "@tryAgain": {}, + "youKickedAndBanned": "🙅 {user}님을 영구 추방했습니다", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unbanUserDescription": "유저가 다시 채팅을 입력할 수 있습니다.", + "@unbanUserDescription": {}, + "youRejectedTheInvitation": "초대를 거부했습니다", + "@youRejectedTheInvitation": {}, + "otherCallingPermissions": "마이크, 카메라 그리고 다름 FluffyChat 권한", + "@otherCallingPermissions": {}, + "messagesStyle": "메세지:", + "@messagesStyle": {}, + "widgetUrlError": "유효한 URL이 아닙니다.", + "@widgetUrlError": {}, + "newSpaceDescription": "스페이스를 사용하면 채팅을 통합하고 비공개 또는 공개 커뮤니티를 구축할 수 있습니다.", + "@newSpaceDescription": {}, + "chatDescription": "채팅 설명", + "@chatDescription": {}, + "callingAccountDetails": "FluffyChat이 android 전화앱을 사용 할 수 있도록 허가.", + "@callingAccountDetails": {}, + "enterSpace": "스페이스에 입장", + "@enterSpace": {}, + "encryptThisChat": "이 채팅을 암호화", + "@encryptThisChat": {}, + "previousAccount": "이전 계정", + "@previousAccount": {}, + "reopenChat": "채팅 다시 열기", + "@reopenChat": {}, + "pleaseEnterRecoveryKey": "당신의 복구키를 입력하세요:", + "@pleaseEnterRecoveryKey": {}, + "widgetNameError": "표시 이름을 입력하세요.", + "@widgetNameError": {}, + "addWidget": "위젯 추가", + "@addWidget": {}, + "countFiles": "{count}개의 파일", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noKeyForThisMessage": "이것은 이 메시지가 당신이 이 기기를 서명하기 전에 발송되었기 때문에 일어났을 수 있습니다.\n\n이것은 또한 발송자가 당신의 기기를 차단하였거나 혹은 인터넷 연결이 잘못되었을 수 있습니다.\n\n다른 세션에서 이 메시지를 읽을 수 있나요? 그렇다면 그 메시지를 옮길 수 있습니다! 설정 > 기기로 가서 기기를 서로 증명하세요. 다음번에 방을 열었을 때 두 세션이 모두 작동중이라면, 키가 자동으로 옮겨질것입니다.\n\n로그아웃하거나 기기를 바꿀 때 키를 잃고싶지 않으신가요? 설정에서 채팅 백업을 사용중인지 확인하세요.", + "@noKeyForThisMessage": {}, + "hydrateTor": "TOR 사용자: 내보낸 세션 불러오기", + "@hydrateTor": {}, + "pushNotificationsNotAvailable": "푸시 알림 사용 불가", + "@pushNotificationsNotAvailable": {}, + "storeInAppleKeyChain": "Apple KeyChain에 저장하기", + "@storeInAppleKeyChain": {}, + "hydrate": "백업 파일로부터 가져오기", + "@hydrate": {}, + "invalidServerName": "잘못된 서버 이름", + "@invalidServerName": {}, + "chatPermissions": "채팅 권한", + "@chatPermissions": {}, + "storeInAndroidKeystore": "Android KeyStore에 저장하기", + "@storeInAndroidKeystore": {}, + "signInWithPassword": "비밀번호로 로그인", + "@signInWithPassword": {}, + "makeAdminDescription": "유저를 한 번 관리자로 만들면, 당신과 같은 권한을 가지기때문에 권한 회수가 불가능합니다.", + "@makeAdminDescription": {}, + "saveKeyManuallyDescription": "공유나 클립보드를 이용해 수동으로 키를 저장합니다.", + "@saveKeyManuallyDescription": {}, + "whyIsThisMessageEncrypted": "왜 이 메시지를 읽을 수 없나요?", + "@whyIsThisMessageEncrypted": {}, + "setChatDescription": "채팅 설명 설정", + "@setChatDescription": {}, + "importFromZipFile": ".zip 파일에서 불러오기", + "@importFromZipFile": {}, + "noOtherDevicesFound": "다른 기기 발견되지 않음", + "@noOtherDevicesFound": {}, + "redactedBy": "{username}님이 삭제함", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "signInWith": "{provider}로 로그인", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "전송에 실패했습니다. 서버는 {max}가 넘는 파일을 지원하지 않습니다.", + "@fileIsTooBigForServer": {}, + "callingPermissions": "통화 권한", + "@callingPermissions": {}, + "readUpToHere": "여기까지 읽음", + "@readUpToHere": {}, + "unlockOldMessages": "오래된 메시지 잠금 해제하기", + "@unlockOldMessages": {}, + "numChats": "{number}개의 채팅", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "optionalRedactReason": "(선택) 이 메시지를 편집하는 이유...", + "@optionalRedactReason": {}, + "archiveRoomDescription": "채팅이 보관함으로 이동합니다. 다른 유저들은 당신이 떠난다는것을 볼 수 있습니다.", + "@archiveRoomDescription": {}, + "exportEmotePack": ".zip 파일로 이모트 내보내기", + "@exportEmotePack": {}, + "switchToAccount": "계정 {number}로 전환", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "pleaseEnterRecoveryKeyDescription": "오래된 메시지를 잠금 해제하려면, 이전 세션에서 생성된 복호화 키를 입력하세요. 복호화 키는 비밀번호가 아닙니다.", + "@pleaseEnterRecoveryKeyDescription": {}, + "inviteContactToGroupQuestion": "{contact} 를 \"{groupName}\"에 초대할까요?", + "@inviteContactToGroupQuestion": {}, + "redactedByBecause": "{username}님이 삭제함. 사유: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "{user}님에 대한 초대를 철회함", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "appearOnTopDetails": "앱이 상단에 표시되도록 허용 (이미 FluffyChat을 통화 계정으로 설정한 경우에는 필요하지 않음)", + "@appearOnTopDetails": {}, + "enterRoom": "방에 입장", + "@enterRoom": {}, + "youInvitedUser": "📩 {user}님을 초대했습니다", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "{path}에 파일 저장됨", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "redactMessageDescription": "메시지는 이 대화의 모든 참여자에게 삭제될 것 입니다. 되돌릴 수 없습니다.", + "@redactMessageDescription": {}, + "recoveryKey": "복구키", + "@recoveryKey": {}, + "invalidInput": "잘못된 입력!", + "@invalidInput": {}, + "dehydrateTorLong": "TOR 사용자들은 창을 닫기 전에 세션을 내보내는것이 권장됩니다.", + "@dehydrateTorLong": {}, + "doNotShowAgain": "다시 보지 않기", + "@doNotShowAgain": {}, + "report": "신고", + "@report": {}, + "hideUnimportantStateEvents": "중요하지 않은 상태 이벤트 숨기기", + "@hideUnimportantStateEvents": {}, + "screenSharingTitle": "화면 공유", + "@screenSharingTitle": {}, + "widgetCustom": "사용자 정의", + "@widgetCustom": {}, + "youBannedUser": "{user}님을 영구 추방함", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "addChatDescription": "채팅 설명 추가하기...", + "@addChatDescription": {}, + "hasKnocked": "🚪 {user}님이 참가를 요청했습니다", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "openLinkInBrowser": "브라우저에서 링크 열기", + "@openLinkInBrowser": {}, + "disableEncryptionWarning": "보안상의 이유로 암호화가 활성화된 채팅에서 암호화를 비활성화 할 수 없습니다.", + "@disableEncryptionWarning": {}, + "directChat": "다이렉트 채팅", + "@directChat": {}, + "wrongPinEntered": "잘못된 pin입니다! {seconds}초 후에 다시 시도하세요...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "입력 알림 보내기", + "@sendTypingNotifications": {}, + "inviteGroupChat": "📨 그룹 채팅에 초대", + "@inviteGroupChat": {}, + "appearOnTop": "상단에 표시", + "@appearOnTop": {}, + "invitePrivateChat": "📨 비공개 채팅에 초대", + "@invitePrivateChat": {}, + "foregroundServiceRunning": "이 알림은 백그라운드 서비스가 실행중일때 표시됩니다.", + "@foregroundServiceRunning": {}, + "importEmojis": "이모지 불러오기", + "@importEmojis": {}, + "wasDirectChatDisplayName": "빈 채팅 (전 {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "채팅 설명이 아직 추가되지 않음.", + "@noChatDescriptionYet": {}, + "learnMore": "더 알아보기", + "@learnMore": {}, + "notAnImage": "이미지 파일이 아닙니다.", + "@notAnImage": {}, + "users": "유저", + "@users": {}, + "chatDescriptionHasBeenChanged": "채팅 설명 변경됨", + "@chatDescriptionHasBeenChanged": {}, + "newGroup": "새 그룹 채팅", + "@newGroup": {}, + "dehydrateTor": "TOR 사용자: 세션 내보내기", + "@dehydrateTor": {}, + "roomUpgradeDescription": "채팅이 새로운 방 버전으로 다시 생성됩니다. 모든 참가자는 새로운 채팅으로 전환해야합니다. https://spec.matrix.org/latest/rooms/ 에서 방 버전에 대해 자세히 알아볼 수 있습니다.", + "@roomUpgradeDescription": {}, + "pleaseEnterANumber": "0보다 큰 숫자를 입력하세요", + "@pleaseEnterANumber": {}, + "youKicked": "👞 {user}님을 추방했습니다", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "profileNotFound": "유저를 서버에서 찾을 수 있습니다. 연결 문제가 있거나 유저가 존재하지 않을 수 있습니다.", + "@profileNotFound": {}, + "jump": "점프", + "@jump": {}, + "sorryThatsNotPossible": "죄송합니다...그것은 불가능합니다", + "@sorryThatsNotPossible": {}, + "shareInviteLink": "초대 링크 공유", + "@shareInviteLink": {}, + "commandHint_markasdm": "Matrix ID를 위한 다이렉트 메시지 방으로 표시", + "@commandHint_markasdm": {}, + "recoveryKeyLost": "복구키를 분실하셨나요?", + "@recoveryKeyLost": {}, + "cuddleContent": "{senderName} 님이 당신에게 미소짓습니다", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "deviceKeys": "기기 키:", + "@deviceKeys": {}, + "emoteKeyboardNoRecents": "최근 사용한 이모트가 여기 나타납니다...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "테마 설정:", + "@setTheme": {}, + "youJoinedTheChat": "채팅에 참가하였습니다", + "@youJoinedTheChat": {}, + "widgetName": "이름", + "@widgetName": {}, + "errorAddingWidget": "위젯 추가중 오류 발생.", + "@errorAddingWidget": {}, + "commandHint_hug": "허그 보내기", + "@commandHint_hug": {}, + "replace": "대체", + "@replace": {}, + "youUnbannedUser": "{user}님의 영구 추방을 해제했습니다", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "newSpace": "새 스페이스", + "@newSpace": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "나중에 다시 시도하거나 다른 서버를 선택하십시오.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "createGroup": "새 그룹 채팅", + "@createGroup": {}, + "hydrateTorLong": "지난 TOR 이용에서 세션을 내보내셨나요? 빠르게 불러오고 채팅을 계속하세요.", + "@hydrateTorLong": {}, + "custom": "커스텀", + "@custom": {}, + "noBackupWarning": "경고! 채팅 백업을 켜지 않을경우, 당신은 암호화된 메시지에 대한 접근권한을 잃을것 입니다. 로그아웃 하기 전에 채팅을 백업하는것이 강력히 권장됩니다.", + "@noBackupWarning": {}, + "storeInSecureStorageDescription": "이 기기의 보안 스토리지에 복구키를 저장합니다.", + "@storeInSecureStorageDescription": {}, + "kickUserDescription": "유저는 채팅에서 추방되지만 영구 추방되지 않습니다. 공개 채팅의 경우, 언제든 유저가 다시 참가할 수 있습니다.", + "@kickUserDescription": {}, + "importNow": "지금 불러오기", + "@importNow": {}, + "invite": "초대", + "@invite": {}, + "indexedDbErrorTitle": "사생활 보호 모드의 문제", + "@indexedDbErrorTitle": {}, + "storeSecurlyOnThisDevice": "이 기기에 안전하게 저장", + "@storeSecurlyOnThisDevice": {}, + "screenSharingDetail": "FluffyChat에 당신의 화면을 공유하는중", + "@screenSharingDetail": {}, + "blockUsername": "유저 이름 무시", + "@blockUsername": {}, + "block": "차단", + "@block": {}, + "blockedUsers": "차단된 유저", + "@blockedUsers": {}, + "groupName": "그룹 채팅 이름", + "@groupName": {}, + "commandHint_sendraw": "raw json 전송", + "@commandHint_sendraw": {}, + "pleaseChooseAStrongPassword": "강력한 비밀번호를 사용하세요", + "@pleaseChooseAStrongPassword": {}, + "addChatOrSubSpace": "채팅 또는 하위 스페이스 추가", + "@addChatOrSubSpace": {}, + "subspace": "하위 스페이스", + "@subspace": {}, + "youInvitedToBy": "📩 링크를 통해 초대되셨습니다:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "databaseMigrationBody": "잠시만 기다리세요. 시간이 걸릴 수 있습니다.", + "@databaseMigrationBody": {}, + "select": "선택", + "@select": {}, + "joinSpace": "스페이스 참가", + "@joinSpace": {}, + "decline": "거절", + "@decline": {}, + "formattedMessagesDescription": "마크다운을 이용한 볼드등의 서식이 있는 메시지를 봅니다.", + "@formattedMessagesDescription": {}, + "completedKeyVerification": "{sender}가 키 검증을 완료함", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender}가 키 검증을 취소함", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "createGroupAndInviteUsers": "그룹 채팅을 생성하고 유저를 초대", + "@createGroupAndInviteUsers": {}, + "passwordsDoNotMatch": "비밀번호가 일치하지 않습니다", + "@passwordsDoNotMatch": {}, + "passwordIsWrong": "비밀번호가 틀립니다", + "@passwordIsWrong": {}, + "publicLink": "공개 링크", + "@publicLink": {}, + "thisDevice": "이 기기:", + "@thisDevice": {}, + "sendReadReceipts": "읽음 확인 보내기", + "@sendReadReceipts": {}, + "sendReadReceiptsDescription": "채팅의 다른 참가자들이 당신이 메시지를 읽었는지 볼 수 있습니다.", + "@sendReadReceiptsDescription": {}, + "verifyOtherUser": "🔐 다른 유저 확인", + "@verifyOtherUser": {}, + "hidePresences": "상태 목록을 숨길까요?", + "@hidePresences": {}, + "searchChatsRooms": "#chats, @users 검색...", + "@searchChatsRooms": {}, + "groupCanBeFoundViaSearch": "검색으로 그룹 채팅을 찾을 수 있음", + "@groupCanBeFoundViaSearch": {}, + "restoreSessionBody": "앱이 백업에서 세션을 복원하려 시도중입니다. {url} 에서 개발자에게 오류를 신고하세요. 오류 메시지는 다음과 같습니다: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "acceptedKeyVerification": "{sender}가 키 검증을 수락함", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "presencesToggle": "다른 유저의 상태 메시지 표시", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "wrongRecoveryKey": "죄송합니다... 올바른 복구키가 아닌것 같습니다.", + "@wrongRecoveryKey": {}, + "newPassword": "새 비밀번호", + "@newPassword": {}, + "searchForUsers": "@users 검색...", + "@searchForUsers": {}, + "leaveEmptyToClearStatus": "비워서 상태를 지우세요.", + "@leaveEmptyToClearStatus": {}, + "commandHint_ignore": "주어진 matrix ID를 무시", + "@commandHint_ignore": {}, + "commandHint_unignore": "주어진 matrix ID 무시 해제", + "@commandHint_unignore": {}, + "blockListDescription": "당신은 당신을 방해하는 유저들을 차단할 수 있습니다. 당신은 당신의 개인 차단 목록에 있는 어떠한 유저의 메시지와 방 초대도 받지 않을것 입니다.", + "@blockListDescription": {}, + "presenceStyle": "상태:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "sessionLostBody": "세션을 잃었습니다. {url} 에서 개발자에게 오류를 신고하세요. 오류 메시지는 다음과 같습니다: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "yourGlobalUserIdIs": "글로벌 유저 ID: ", + "@yourGlobalUserIdIs": {}, + "noUsersFoundWithQuery": "안타깝게도 \"{query}\"로 유저를 찾을 수 없습니다. 오타가 없는지 확인하십시오.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "nothingFound": "아무것도 찾지 못했습니다...", + "@nothingFound": {}, + "startConversation": "대화 시작", + "@startConversation": {}, + "databaseMigrationTitle": "데이터베이스가 최적화됨", + "@databaseMigrationTitle": {}, + "pleaseEnterYourCurrentPassword": "현재 비밀번호 입력", + "@pleaseEnterYourCurrentPassword": {}, + "publicSpaces": "공개 스페이스들", + "@publicSpaces": {}, + "initAppError": "앱 초기화중 오류 발생", + "@initAppError": {}, + "databaseBuildErrorBody": "SQlite 데이터베이스를 구축할 수 없습니다. 현재 레거시 데이터베이스 사용을 시도중입니다. {url} 에서 개발자에게 오류를 신고하세요. 오류 메시지는 다음과 같습니다: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "채팅의 다른 참가자들이 당신이 새 메시지를 입력중인것을 볼 수 있습니다.", + "@sendTypingNotificationsDescription": {}, + "formattedMessages": "형식이 지정된 메시지", + "@formattedMessages": {}, + "forwardMessageTo": "{roomName}에 메시지를 전달할까요?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "verifyOtherDevice": "🔐 다른 기기를 확인", + "@verifyOtherDevice": {}, + "verifyOtherUserDescription": "다른 유저를 확인하면, 당신은 당신이 누구에게 말하고있는지 알 수 있습니다. 💪\n\n확인을 시작할 때, 다른 유저는 앱에서 팝업을 볼 수 있습니다. 당신은 그런 다음 서로 비교해야 이모지 또는 숫자의 목록을 볼 수 있습니다.\n\n이 작업을 수행하는 가장 좋은 방법은 직접 만나거나 영상통화를 하는것입니다. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDeviceDescription": "다른 장치를 확인하면, 장치와 키를 교환하고, 전반적인 보안을 증가시킵니다. 💪 확인을 시작하면 팝업은 두 장치에 나타납니다. 그런 다음 서로 비교해야 이모지 또는 숫자의 목록를 볼 수 있습니다. 확인을 시작하기 전에 모든 장치를 준비하세요. 🤳", + "@verifyOtherDeviceDescription": {}, + "isReadyForKeyVerification": "{sender}가 키 검증 준비를 완료함", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender}가 키 검증을 요청함", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender}가 키 검증을 시작함", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "투명", + "@transparent": {}, + "incomingMessages": "메시지 수신함", + "@incomingMessages": {}, + "stickers": "스티커", + "@stickers": {}, + "discover": "탐색", + "@discover": {}, + "unreadChatsInApp": "{appname}: {unread}개의 읽지 않은 채팅", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "appLockDescription": "앱을 사용하지 않을 때 pin으로 잠금", + "@appLockDescription": {}, + "calls": "전화", + "@calls": {}, + "globalChatId": "글로벌 채팅 ID", + "@globalChatId": {}, + "customEmojisAndStickers": "커스텀 이모지와 스티커", + "@customEmojisAndStickers": {}, + "accessAndVisibilityDescription": "채팅에 참가 할 수 있는 사람과 채팅을 볼 수 있는 범위", + "@accessAndVisibilityDescription": {}, + "accessAndVisibility": "채팅 가입과 대화 기록", + "@accessAndVisibility": {}, + "customEmojisAndStickersBody": "모든 채팅에서 사용할 수있는 커스텀 이모지와 스티커를 추가하거나 공유합니다.", + "@customEmojisAndStickersBody": {}, + "hideRedactedMessages": "삭제된 메시지 숨기기", + "@hideRedactedMessages": {}, + "hideRedactedMessagesBody": "누군가가 메시지를 삭제하면 메시지를 더 이상 볼 수 없습니다.", + "@hideRedactedMessagesBody": {}, + "hideInvalidOrUnknownMessageFormats": "잘못되거나 알 수 없는 메시지 형식 숨김", + "@hideInvalidOrUnknownMessageFormats": {}, + "overview": "개요", + "@overview": {}, + "notifyMeFor": "나에게 알림", + "@notifyMeFor": {}, + "passwordRecoverySettings": "비밀번호 복구 설정", + "@passwordRecoverySettings": {}, + "hideMemberChangesInPublicChats": "공개 채팅에서의 참가자 변화 숨김", + "@hideMemberChangesInPublicChats": {}, + "userWouldLikeToChangeTheChat": "{user}님이 참가를 희망합니다.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "공개 링크가 아직 생성되지 않았음", + "@noPublicLinkHasBeenCreatedYet": {}, + "knock": "참가 요청", + "@knock": {}, + "usersMustKnock": "유저들이 참가를 허가받아야함", + "@usersMustKnock": {}, + "knocking": "참가 요청중", + "@knocking": {}, + "chatCanBeDiscoveredViaSearchOnServer": "채팅은 {server} 에서 검색하여 찾을 수 있습니다.", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "noOneCanJoin": "아무도 참가할 수 없음", + "@noOneCanJoin": {}, + "thereAreCountUsersBlocked": "{count}명의 차단된 유저가 있습니다.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "minimumPowerLevel": "{level}은 최소 권한 레벨입니다.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "데이터베이스 암호화는 이 플랫폼에서 지원되지 않음", + "@noDatabaseEncryption": {}, + "publicChatAddresses": "공개 채팅 주소", + "@publicChatAddresses": {}, + "userRole": "유저 역할", + "@userRole": {}, + "createNewAddress": "새 주소 만들기", + "@createNewAddress": {}, + "hideMemberChangesInPublicChatsBody": "공개 채팅에 누군가가 참가하거나 떠날때 타임라인에 표시하지 않습니다.", + "@hideMemberChangesInPublicChatsBody": {}, + "searchMore": "더 검색...", + "@searchMore": {}, + "files": "파일", + "@files": {}, + "searchIn": "{chat}에서 검색...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "gallery": "갤러리", + "@gallery": {}, + "restricted": "스페이스 멤버로 제한", + "@restricted": {}, + "knockRestricted": "스페이스 멤버만 참가 요청 가능", + "@knockRestricted": {}, + "swipeRightToLeftToReply": "오른쪽에서 왼쪽으로 스와이프해서 답장", + "@swipeRightToLeftToReply": {}, + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "unread": "읽지 않은", + "@unread": {}, + "space": "스페이스", + "@space": {}, + "spaces": "스페이스", + "@spaces": {}, + "goToSpace": "스페이스로: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "읽지 않음으로 표시", + "@markAsUnread": {}, + "countChatsAndCountParticipants": "{chats} 채팅과 {participants} 참여자", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "joinedChats": "참가한 채팅", + "@joinedChats": {}, + "noMoreChatsFound": "채팅을 찾을 수 없습니다...", + "@noMoreChatsFound": {}, + "moderatorLevel": "{level} - 관리자", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - 운영자", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "invitedBy": "📩 {user}님이 나를 초대함", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "userLevel": "{level} - 유저", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "noChatsFoundHere": "대화가 발견되지 않았습니다. 아래 버튼을 사용하여 새 대화를 시작해 보세요. ⤵️", + "@noChatsFoundHere": {}, + "changeTheVisibilityOfChatHistory": "채팅 기록 표시 여부 바꾸기", + "@changeTheVisibilityOfChatHistory": {}, + "changeTheCanonicalRoomAlias": "메인 공개 채팅 주소 바꾸기", + "@changeTheCanonicalRoomAlias": {}, + "sendCanceled": "전송 최소됨", + "@sendCanceled": {}, + "homeserverDescription": "당신의 모든 데이터는 이메일과 흡사하게 당신의 홈서버에 저장됩니다. 당신이 소통하고 싶은 사람들과 다른 서버를 사용해도 무관하니 당신이 원하는 홈서버를 선택해도 됩니다. https://matrix.org에서 자세히 알아보세요.", + "@homeserverDescription": {}, + "sendingAttachmentCountOfCount": "첨부파일 {length}개중 {index}번째 전송 중...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "서버 한도에 도달했습니다! {seconds}초 기다리는 중...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "noContactInformationProvided": "서버가 유효한 연락처 정보를 제공하지 않음", + "@noContactInformationProvided": {}, + "welcomeText": "안녕하세요 👋 FluffyChat이에요. 당신은 htpps://matrix.org와 호환되는 모든 홈서버를 사용할 수 있어요. 그리고 모두와 대화해보세요. 거대한 분산 대화망이니까요!", + "@welcomeText": {}, + "changeGeneralChatSettings": "일반 채팅 설정 번경하기", + "@changeGeneralChatSettings": {}, + "inviteOtherUsers": "다른 사용자를 이 채팅에 초대하기", + "@inviteOtherUsers": {}, + "changeTheChatPermissions": "채팅 권한 바꾸기", + "@changeTheChatPermissions": {}, + "calculatingFileSize": "파일 크기 계산 중...", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "첨부된 파일 전송 준비 중...", + "@prepareSendingAttachment": {}, + "oneOfYourDevicesIsNotVerified": "당신의 기기 중 하나가 인증되지 않았음", + "@oneOfYourDevicesIsNotVerified": {}, + "noticeChatBackupDeviceVerification": "참고: 모든 기기에 채팅 백업을 설정하면 자동으로 서로 인증됩니다.", + "@noticeChatBackupDeviceVerification": {}, + "opacity": "불투명:", + "@opacity": {}, + "setWallpaper": "배경화면 설정하기", + "@setWallpaper": {}, + "manageAccount": "계정 관리하기", + "@manageAccount": {}, + "aboutHomeserver": "{homeserver}의 대해서", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "contactServerAdmin": "서버 관리자에게 연락하기", + "@contactServerAdmin": {}, + "contactServerSecurity": "서버 보안 관리자에게 연락하기", + "@contactServerSecurity": {}, + "supportPage": "지원 페이지", + "@supportPage": {}, + "name": "이름", + "@name": {}, + "serverInformation": "서버 정보:", + "@serverInformation": {}, + "version": "버전", + "@version": {}, + "website": "웹사이트", + "@website": {}, + "changeTheDescriptionOfTheGroup": "채팅 설명 바꾸기", + "@changeTheDescriptionOfTheGroup": {}, + "sendRoomNotifications": "@room 알림 보내기", + "@sendRoomNotifications": {}, + "chatPermissionsDescription": "이 채팅에서 특정 작업에 요구할 권한 레벨을 정의합니다. 권한 레벨 0, 50, 100은 일반적으로 유저, 관리자, 운영자를 나타내지만, 모든 숫자가 가능합니다.", + "@chatPermissionsDescription": {}, + "loginWithMatrixId": "Matrix-ID로 로그인", + "@loginWithMatrixId": {}, + "discoverHomeservers": "홈서버 찾아보기", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "홈서버가 무엇인가요?", + "@whatIsAHomeserver": {}, + "doesNotSeemToBeAValidHomeserver": "호환되는 홈서버가 아닌 것 같습니다. URL을 올바르게 입력됐나요?", + "@doesNotSeemToBeAValidHomeserver": {}, + "continueText": "계속하기", + "@continueText": {}, + "updateInstalled": "🎉 {version} 업데이트가 설치되었습니다!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "변경 기록", + "@changelog": {}, + "sendingAttachment": "첨부된 파일 전송 중...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "영상 썸네일 만드는 중...", + "@generatingVideoThumbnail": {}, + "compressVideo": "영상 압축 중...", + "@compressVideo": {}, + "blur": "블러:", + "@blur": {}, + "sendImages": "이미지 {count}개 보내기", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "italicText": "기울어진 글꼴", + "@italicText": {}, + "boldText": "두꺼운 글꼴", + "@boldText": {}, + "appWantsToUseForLoginDescription": "웹사이트와 당신에 대한 정보를 공유하게됩니다.", + "@appWantsToUseForLoginDescription": {}, + "appWantsToUseForLogin": "'{server}'로 로그인", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "otherPartyNotLoggedIn": "다른 구성원이 현재 로그인하지 않아 메시지를 수신하지 못합니다!", + "@otherPartyNotLoggedIn": {}, + "open": "열기", + "@open": {}, + "unableToJoinChat": "채팅에 참가할 수 없습니다. 다른 구성원이 이미 대화를 종료했을 수 있습니다.", + "@unableToJoinChat": {}, + "compress": "압축", + "@compress": {}, + "invalidUrl": "유효하지 않은 url", + "@invalidUrl": {}, + "addLink": "링크 추가", + "@addLink": {}, + "strikeThrough": "취소선", + "@strikeThrough": {}, + "pleaseFillOut": "작성해주세요", + "@pleaseFillOut": {}, + "previous": "이전", + "@previous": {}, + "newChatRequest": "📩 새 채팅 요청", + "@newChatRequest": {}, + "appIntroduction": "FluffyChat는 다른 메신저들을 사용하는 친구들과도 채팅할 수 있습니다. https://matrix.org에 방문하거나 *계속*을 눌러 자세한 정보를 확인하세요.", + "@appIntroduction": {}, + "synchronizingPleaseWaitCounter": " 동기화중… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "waitingForServer": "서버를 기다리는중...", + "@waitingForServer": {}, + "contentNotificationSettings": "콘텐츠 알림 설정", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "일반 알림 설정", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "채팅방 알림 설정", + "@roomNotificationSettings": {}, + "otherNotificationSettings": "기타 알림 설정", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "유저 이름을 포함함", + "@notificationRuleContainsUserName": {}, + "notificationRuleMaster": "모든 알림 음소거", + "@notificationRuleMaster": {}, + "notificationRuleContainsUserNameDescription": "메시지가 유저의 이름을 포함할때 알림합니다.", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleMasterDescription": "모든 규칙을 무시하고 모든 알림을 비활성화합니다.", + "@notificationRuleMasterDescription": {}, + "notificationRuleSuppressNotices": "자동화된 메시지 무시", + "@notificationRuleSuppressNotices": {}, + "notificationRuleSuppressNoticesDescription": "봇을 비롯한 자동화된 메시지로부터 발생하는 알림을 무시합니다.", + "@notificationRuleSuppressNoticesDescription": {}, + "notificationRuleInviteForMe": "초대를 받음", + "@notificationRuleInviteForMe": {}, + "notificationRuleInviteForMeDescription": "채팅방에 초대받았을 때 알림합니다.", + "@notificationRuleInviteForMeDescription": {}, + "notificationRuleMemberEvent": "멤버 이벤트", + "@notificationRuleMemberEvent": {}, + "notificationRuleMemberEventDescription": "멤버 이벤트로 발생하는 알림을 무시합니다.", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleIsUserMentionDescription": "유저가 메시지에 멘션됐을 때 알림합니다.", + "@notificationRuleIsUserMentionDescription": {}, + "notificationRuleContainsDisplayName": "표시 이름을 포함함", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleIsUserMention": "유저가 멘션됨", + "@notificationRuleIsUserMention": {}, + "notificationRuleContainsDisplayNameDescription": "메시지에 표시 이름이 포함되면 알림합니다.", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleIsRoomMention": "방 멘션", + "@notificationRuleIsRoomMention": {}, + "notificationRuleIsRoomMentionDescription": "방 멘션이 있을경우 알림합니다.", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleRoomnotif": "방 알림", + "@notificationRuleRoomnotif": {}, + "notificationRuleRoomnotifDescription": "메시지가 '@room'을 포함하면 알림합니다.", + "@notificationRuleRoomnotifDescription": {}, + "notificationRuleTombstone": "비활성화", + "@notificationRuleTombstone": {}, + "notificationRuleTombstoneDescription": "채팅방 비활성화 메시지를 알림합니다.", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleReaction": "반응", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "반응으로 발생하는 알림을 무시합니다.", + "@notificationRuleReactionDescription": {}, + "notificationRuleRoomServerAcl": "채팅방 서버 ACL", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleRoomServerAclDescription": "채팅방 서버의 접근 권한(ACL)으로부터 오는 알림을 무시합니다.", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleSuppressEdits": "수정 음소거", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "수정된 메시지로부터 오는 알림을 무시합니다.", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleCall": "전화", + "@notificationRuleCall": {}, + "setCustomPermissionLevel": "사용자 지정 권한 수준 설정", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "아래에서 미리 정의된 역할을 선택하거나 0부터 100 사이의 사용자 지정 권한 수준을 입력해 주세요.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "사용자 무시", + "@ignoreUser": {}, + "normalUser": "일반 사용자", + "@normalUser": {}, + "commandHint_roomupgrade": "이 방을 주어진 방 버전으로 업그레이드합니다", + "@commandHint_roomupgrade": {}, + "checkList": "체크리스트", + "@checkList": {}, + "countInvited": "{count}초대받은", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + } +} diff --git a/assets/l10n/intl_lt.arb b/lib/l10n/intl_lt.arb similarity index 75% rename from assets/l10n/intl_lt.arb rename to lib/l10n/intl_lt.arb index 0a77ba065..44f5681e9 100644 --- a/assets/l10n/intl_lt.arb +++ b/lib/l10n/intl_lt.arb @@ -1,1001 +1,1001 @@ { "commandHint_leave": "Palikti pokalbių kambarį", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "confirm": "Patvirtinti", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "Atšaukti", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "Redaguoti", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "Atsisiųsti failą", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "about": "Apie", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "Visi", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "Failo vardas", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "changePassword": "Keisti slaptažodį", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "close": "Uždaryti", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "Archyvas", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "skip": "Praleisti", "@skip": { - "type": "text", + "type": "String", "placeholders": {} }, "share": "Bendrinti", "@share": { - "type": "text", + "type": "String", "placeholders": {} }, "showPassword": "Rodyti slaptažodį", "@showPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "time": "Laikas", "@time": {}, "settings": "Nustatytmai", "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, "sender": "Siuntėjas", "@sender": {}, "yes": "Taip", "@yes": { - "type": "text", + "type": "String", "placeholders": {} }, "you": "Jūs", "@you": { - "type": "text", + "type": "String", "placeholders": {} }, "logout": "Atsijungti", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "Žinutės", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "scanQrCode": "Nuskanuokite QR kodą", "@scanQrCode": {}, "ok": "OK", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "addAccount": "Pridėti paskyrą", "@addAccount": {}, "or": "Arba", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "Slaptažodis", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "Slaptažodis pakeistas", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "Įveskite savo slaptažodį", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "Įveskite savo vartotojo vardą", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "reply": "Atsakyti", "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "blockDevice": "Blokuoti įrenginį", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "Užblokuotas", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "Pasirinkite saugų slaptažodį", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "Ištrinti žinutę", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "Įrenginys", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "Įrenginio ID", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "Įrenginiai", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "homeserver": "Namų serveris", "@homeserver": {}, "enterYourHomeserver": "Įveskite namų serverį", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "everythingReady": "Viskas paruošta!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "Šrifto dydis", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "Išvalyti archyvą", "@clearArchive": {}, "create": "Sukurti", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "Prisijungti", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "Žmonės", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "Moderatorius", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "muteChat": "Nutildyti pokalbį", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "Naujas pokalbis", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "none": "Nė vienas", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "noPermission": "Nėra leidimo", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "Nerasta kambarių…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "Pranešimai", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "Pranešimai aktyvuoti šitai paskyrai", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "obtainingLocation": "Gaunama vieta…", "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "offensive": "Agresyvus", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "offline": "Neprisijungta", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "Prisijungta", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsPushError": "Oi! Deja, nustatant tiesioginius pranešimus įvyko klaida.", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "Oi, kažkas nutiko ne taip…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "Atidarykite programėlę, kad perskaityti žinutes", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "link": "Nuoroda", "@link": {}, "participant": "Dalyvis", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "passphraseOrKey": "Slapta frazė arba atkūrimo raktas", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "Slaptažodis užmirštas", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "Slaptažodžio atkūrimas", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "Pasirinkite paveiksliuką", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "Prisegti", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChoose": "Prašome pasirinkti", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChooseAPasscode": "Pasirinkite slaptą kodą", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseClickOnLink": "Paspauskite nuorodą el. pašte ir tęskite toliau.", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "Įveskite 4 skaitmenis arba palikite tuščią, jei norite išjungti programėlės užraktą.", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "Įveskite savo PIN kodą", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseFollowInstructionsOnWeb": "Vadovaukitės svetainėje pateiktais nurodymais ir bakstelėkite Toliau.", "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "privacy": "Privatumas", "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "publicRooms": "Vieši kambariai", "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "reason": "Priežastis", "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "recording": "Įrašymas", "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "redactMessage": "Pašalinti žinutę", "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "register": "Registruotis", "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "reject": "Atmesti", "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "rejoin": "Vėl prisijungti", "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "remove": "Pašalinti", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "removeAllOtherDevices": "Pašalinti visus kitus įrenginius", "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "removeDevice": "Pašalinti įrenginį", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "removeYourAvatar": "Pašalinti savo avatarą", "@removeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "replaceRoomWithNewerVersion": "Pakeisti kambarį naujesne versija", "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "requestPermission": "Prašyti leidimo", "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "roomHasBeenUpgraded": "Kambarys buvo atnaujintas", "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "roomVersion": "Kambario versija", "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "search": "Ieškoti", "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "Sutinku", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "repeatPassword": "Pakartokite slaptažodį", "@repeatPassword": {}, "addEmail": "Pridėti el. paštą", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "admin": "Administratorius", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "slapyvardis", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "allChats": "Visi pokalbiai", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "anyoneCanJoin": "Bet kas gali prisijungti", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "Ar esate tikri?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSureYouWantToLogout": "Ar tikrai norite atsijungti?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheHomeserver": "Pakeisti namų serverį", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "Keisti savo stilių", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheNameOfTheGroup": "Keisti grupės pavadinimą", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "changeYourAvatar": "Keisti savo avatarą", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "Pokalbis", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "Pokalbio detalės", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chats": "Pokalbiai", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_ban": "Užblokuoti vartotoją šiame kambaryje", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_clearcache": "Išvalyti laikiną talpyklą", "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "commandHint_discardsession": "Atmesti sesiją", "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "commandHint_html": "Siųsti tekstą HTML formatu", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "Pakviesti vartotoją į šitą kambarį", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandHint_join": "Prisijungti prie nurodyto kambario", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_kick": "Pašalinti vartotoja iš šito kambario", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_myroomnick": "Nustatyti savo rodomą vardą šiame kambaryje", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_plain": "Siųsti neformatuotą tekstą", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_send": "Siųsti tekstą", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "commandHint_unban": "Atblokuoti vartotoją šiame kambaryje", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "commandInvalid": "Neteisinga komanda", "@commandInvalid": { - "type": "text" + "type": "String" }, "configureChat": "Konfigūruoti pokalbį", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "Nukopijuota į iškarpinę", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "Kopijuoti", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "Koipjuoti į iškarpinę", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "currentlyActive": "Šiuo metu aktyvus", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "Tamsi", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "Ištrinti", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "Panaikinti paskyra", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "Tiesioginiai pokalbiai", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "Užšifruotas", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "Šifravimas aktyvuotas", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "enterAnEmailAddress": "Įveskite el. pašto adresą", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "Itin įžeidžiantis", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "Toliau", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "fromJoining": "Nuo prisijungimo", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "fromTheInvitation": "Nuo pakvietimo", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "Eiti į naują kambarį", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "Grupė", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "Grupė yra vieša", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "groups": "Grupės", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsAreForbidden": "Svečiams draudžiama", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "Svečiai gali prisijungti", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "help": "Pagalba", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "hideRedactedEvents": "Slėpti pašalintus įvykius", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "Slėpti nežinomus įvykius", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "Tapatybė", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignore": "Ignoruoti", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "Ignoruoti vartotojai", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "leave": "Palikti", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "memberChanges": "Narių pokyčiai", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "Paminėti", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "Šifravimas", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "Aktyvuoti šifravimą", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "Redaguoti blokuotus serverius", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "Prisijungti", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOnEnter": "Išsiųsti paspaudus Enter", "@sendOnEnter": {}, "banFromChat": "Užblokuoti iš pokalbio", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "Užblokuotas", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "changeDeviceName": "Pakeisti įrenginio vardą", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "yourChatBackupHasBeenSetUp": "Jūsų pokalbio atsarginė kopija buvo nustatyta.", "@yourChatBackupHasBeenSetUp": {}, "chatBackup": "Pokalbio atsargine kopija", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_me": "Apibūdinkite save", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "displaynameHasBeenChanged": "Rodomas vardas buvo pakeistas", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "Redaguoti rodomą vardą", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "Redaguoti kambario pseudonimus", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "Redaguoti kambario avatarą", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "howOffensiveIsThisContent": "Kiek įžeižiantis šis turinys?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "ID", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "Aš paspaudžiau nuorodą", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "Neteisinga slaptafrazė arba atkūrimo raktas", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "Neįžeidžiantis", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "Pakviesti kontaktą", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "invited": "Pakviestas", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUsersOnly": "Tik pakviesti vartotojai", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "isTyping": "rašo…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "joinRoom": "Prisijungti prie kambario", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "kickFromChat": "Išmesti iš pokalbio", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "leftTheChat": "Paliko pokalbį", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "Licencija", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "Šviesi", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "loadingPleaseWait": "Kraunama… Prašome palaukti.", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "loadMore": "Rodyti daugiau…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "💬 Nauja žinutė FluffyChat'e", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newVerificationRequest": "Nauja patvirtinimo užklausa!", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "Toliau", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "Ne", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "Nėra ryšio su serveriu", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "setInvitationLink": "Nustatyti pakvietimo nuorodą", "@setInvitationLink": { - "type": "text", + "type": "String", "placeholders": {} }, "singlesignon": "Vienkartinis prisijungimas", "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, "sourceCode": "Programinis kodas", "@sourceCode": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceIsPublic": "Erdvė yra vieša", "@spaceIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceName": "Erdvės pavadinimas", "@spaceName": { - "type": "text", + "type": "String", "placeholders": {} }, "status": "Būsena", "@status": { - "type": "text", + "type": "String", "placeholders": {} }, "statusExampleMessage": "Kaip sekasi šiandien?", "@statusExampleMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "submit": "Pateikti", "@submit": { - "type": "text", + "type": "String", "placeholders": {} }, "synchronizingPleaseWait": "Sinchronizuojama… Prašome palaukti.", "@synchronizingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "transferFromAnotherDevice": "Perkėlimas iš kito įrenginio", "@transferFromAnotherDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "verify": "Patvirtinti", "@verify": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyStart": "Pradėti patvirtinimą", "@verifyStart": { - "type": "text", + "type": "String", "placeholders": {} }, "verifySuccess": "Jūs sėkmingai patvirtinote!", "@verifySuccess": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyTitle": "Patvirtinama kita paskyra", "@verifyTitle": { - "type": "text", + "type": "String", "placeholders": {} }, "visibilityOfTheChatHistory": "Pokalbių istorijos matomumas", "@visibilityOfTheChatHistory": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForAllParticipants": "Matoma visiems dalyviams", "@visibleForAllParticipants": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerAcceptRequest": "Laukiama, kol dalyvis priims užklausą…", "@waitingPartnerAcceptRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "writeAMessage": "Rašyti žinutę…", "@writeAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "youAreNoLongerParticipatingInThisChat": "Jūs nebedalyvaujate šiame pokalbyje", "@youAreNoLongerParticipatingInThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "youHaveBeenBannedFromThisChat": "Jums buvo uždrausta dalyvauti šiame pokalbyje", "@youHaveBeenBannedFromThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "messageInfo": "Žinutės informacija", @@ -1004,118 +1004,118 @@ "@removeFromSpace": {}, "security": "Apsauga", "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAsText": "Siųsti kaip tekstą", "@sendAsText": { - "type": "text" + "type": "String" }, "sendAudio": "Siųsti garso įrašą", "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "sendImage": "Siųsti paveiksliuką", "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendFile": "Sųsti bylą", "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "sendMessages": "Siųsti žinutes", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOriginal": "Siųsti originalą", "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "sendVideo": "Siųsti video", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "separateChatTypes": "Atskirti tiesioginius pokalbius ir grupes", "@separateChatTypes": { - "type": "text", + "type": "String", "placeholders": {} }, "setAsCanonicalAlias": "Nustatyti kaip pagrindinį slapyvardį", "@setAsCanonicalAlias": { - "type": "text", + "type": "String", "placeholders": {} }, "setPermissionsLevel": "Nustatyti leidimų lygį", "@setPermissionsLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "setStatus": "Nustatyti būseną", "@setStatus": { - "type": "text", + "type": "String", "placeholders": {} }, "shareLocation": "Bendrinti vietą", "@shareLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "systemTheme": "Sistema", "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "unavailable": "Nepasiekiamas", "@unavailable": { - "type": "text", + "type": "String", "placeholders": {} }, "unblockDevice": "Atblokuoti įrenginį", "@unblockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEncryptionAlgorithm": "Nežinomas šifravimo algoritmas", "@unknownEncryptionAlgorithm": { - "type": "text", + "type": "String", "placeholders": {} }, "unmuteChat": "Įjungti pokalbio garsą", "@unmuteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "unpin": "Atsegti", "@unpin": { - "type": "text", + "type": "String", "placeholders": {} }, "username": "Vartotojo vardas", "@username": { - "type": "text", + "type": "String", "placeholders": {} }, "unverified": "Nepatvirtinta", "@unverified": {}, "verified": "Patvirtinta", "@verified": { - "type": "text", + "type": "String", "placeholders": {} }, "videoCall": "Vaizdo skambutis", "@videoCall": { - "type": "text", + "type": "String", "placeholders": {} }, "yourPublicKey": "Jūsų viešasis raktas", "@yourPublicKey": { - "type": "text", + "type": "String", "placeholders": {} }, "addToSpaceDescription": "Pasirinkite erdvę, kad prie jos pridėtumėte šį pokalbį.", @@ -1124,141 +1124,141 @@ "@start": {}, "account": "Paskyra", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "addToSpace": "Pridėti į erdvę", "@addToSpace": {}, "appLock": "Programos užraktas", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "Ar svečiams leidžiama prisijungti", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "Botų žinutės", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "Šifravimas buvo sugadintas", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chatHasBeenAddedToThisSpace": "Pokalbis buvo pridėtas prie šios erdvės", "@chatHasBeenAddedToThisSpace": {}, "compareEmojiMatch": "Palyginkite jaustukus", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "Palyginkite skaičius", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "contactHasBeenInvitedToTheGroup": "Kontaktas buvo pakviestas į grupę", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "Apie turinį pranešta serverio administratoriams", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "createNewSpace": "Nauja erdvė", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "deactivateAccountWarning": "Tai deaktyvuos jūsų vartotojo paskyrą. Tai negali būti atšaukta! Ar jūs tuo tikri?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "defaultPermissionLevel": "Numatytasis teisių lygis", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryptionWarning": "Šifravimo nebegalėsite išjungti. Ar jūs tuo tikri?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "send": "Siųsti", "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAMessage": "Siųsti žinutę", "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleUnread": "Pažymėti kaip skaitytą/neskaitytą", "@toggleUnread": { - "type": "text", + "type": "String", "placeholders": {} }, "tooManyRequestsWarning": "Per daug užklausų. Pabandykite dar kartą vėliau!", "@tooManyRequestsWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerEmoji": "Laukiama, kol dalyvis priims jaustukus…", "@waitingPartnerEmoji": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerNumbers": "Laukiama, kol dalyvis priims skaičius…", "@waitingPartnerNumbers": { - "type": "text", + "type": "String", "placeholders": {} }, "wallpaper": "Užsklanda", "@wallpaper": { - "type": "text", + "type": "String", "placeholders": {} }, "warning": "Įspėjimas!", "@warning": { - "type": "text", + "type": "String", "placeholders": {} }, "weSentYouAnEmail": "Išsiuntėme jums el. laišką", "@weSentYouAnEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "whoCanPerformWhichAction": "Kas gali atlikti kokį veiksmą", "@whoCanPerformWhichAction": { - "type": "text", + "type": "String", "placeholders": {} }, "whoIsAllowedToJoinThisGroup": "Kam leidžiama prisijungti prie šios grupės", "@whoIsAllowedToJoinThisGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "whyDoYouWantToReportThis": "Kodėl norite apie tai pranešti?", "@whyDoYouWantToReportThis": { - "type": "text", + "type": "String", "placeholders": {} }, "wipeChatBackup": "Ištrinti atsarginę pokalbių kopiją, kad sukurti naują atkūrimo raktą?", "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "withTheseAddressesRecoveryDescription": "Naudodami šiuos adresus galite atkurti savo slaptažodį.", "@withTheseAddressesRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "messageType": "Žinutės tipas", @@ -1267,75 +1267,75 @@ "@openGallery": {}, "unknownDevice": "Nežinomas įrenginys", "@unknownDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "voiceMessage": "Balso žinutė", "@voiceMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "title": "FluffyChat", "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, "visibleForEveryone": "Matoma visiems", "@visibleForEveryone": { - "type": "text", + "type": "String", "placeholders": {} }, "tryToSendAgain": "Pabandykite išsiųsti dar kartą", "@tryToSendAgain": { - "type": "text", + "type": "String", "placeholders": {} }, "locationPermissionDeniedNotice": "Vietos leidimas atmestas. Suteikite leidimą kad galėtumėte bendrinti savo vietą.", "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "Atminkite, kad norint naudoti end-to-end šifravimą, reikalingas Pantalaimon.", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "Šifravimą galite suaktyvinti tik tada, kai kambarys nebebus viešai pasiekiamas.", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "noEmotesFound": "Nerasta jaustukų. 😕", "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "noGoogleServicesWarning": "Atrodo, kad jūsų telefone nėra Google Services. Tai geras sprendimas jūsų privatumui! Norėdami gauti tiesioginius pranešimus FluffyChat, rekomenduojame naudoti https://microg.org/ arba https://unifiedpush.org/.", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "Dar nepridėjote slaptažodžio atkūrimo būdo.", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "oneClientLoggedOut": "Vienas iš jūsų klientų atsijungė", "@oneClientLoggedOut": {}, "onlineKeyBackupEnabled": "Internetinė atsarginė raktų kopija įjungta", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "Atidarykite kamerą", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "openVideoCamera": "Atidarykite kamerą vaizdo įrašui", "@openVideoCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "editBundlesForAccount": "Redaguoti šios paskyros paketus", @@ -1350,153 +1350,188 @@ "@bundleName": {}, "play": "Groti {fileName}", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "redactedAnEvent": "{username} pašalino įvykį", "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "rejectedTheInvitation": "{username} atmetė kvietimą", "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removedBy": "Pašalino vartotojas {username}", "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "unbanFromChat": "Atblokuoti pokalbyje", "@unbanFromChat": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Atvaizduoti turtingą žinutės turinį", - "@renderRichContent": { - "type": "text", + "type": "String", "placeholders": {} }, "reportMessage": "Pranešti apie žinutę", "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "saveFile": "Išsaugoti failą", "@saveFile": { - "type": "text", + "type": "String", "placeholders": {} }, "seenByUser": "Matė {username}", "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sendSticker": "Siųsti lipduką", "@sendSticker": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAFile": "📁 {username} atsiuntė failą", "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAnAudio": "🎤 {username} atsiuntė garso įrašą", "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentASticker": "😊 {username} atsiuntė lipduką", "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sharedTheLocation": "{username} bendrino savo vietą", "@sharedTheLocation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "startedACall": "{senderName} pradėjo skambutį", "@startedACall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "theyDontMatch": "Jie nesutampa", "@theyDontMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "theyMatch": "Jie sutampa", "@theyMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "unbannedUser": "{username} atblokavo {targetName}", "@unbannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "unknownEvent": "Nežinomas įvykis '{type}'", "@unknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "type": {} + "type": { + "type": "String" + } } }, "userAndOthersAreTyping": "{username} ir dar {count} kiti rašo…", "@userAndOthersAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "count": {} + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "userAndUserAreTyping": "{username} ir {username2} rašo…", "@userAndUserAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "username2": {} + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } } }, "userIsTyping": "{username} rašo…", "@userIsTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "userSentUnknownEvent": "{username} išsiuntė {type} įvykį", "@userSentUnknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "type": {} + "username": { + "type": "String" + }, + "type": { + "type": "String" + } } }, "publish": "Paskelbti", @@ -1509,10 +1544,14 @@ "@dismiss": {}, "reactedWith": "{sender} sureagavo su {reaction}", "@reactedWith": { - "type": "text", + "type": "String", "placeholders": { - "sender": {}, - "reaction": {} + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } } }, "unsupportedAndroidVersion": "Nepalaikoma Android versija", @@ -1525,392 +1564,500 @@ "@widgetNameError": {}, "acceptedTheInvitation": "👍 {username} priėmė kvietimą", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "activatedEndToEndEncryption": "🔐 {username} aktyvavo visapusį šifravimą", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "answeredTheCall": "{senderName} atsiliepė į skambutį", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "askVerificationRequest": "Priimti šią patvirtinimo užklausą iš {username}?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "badServerLoginTypesException": "Namų serveris palaiko šiuos prisijungimo tipus:\n{serverVersions}\nTačiau ši programa palaiko tik:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "badServerVersionsException": "Namų serveris palaiko spec. versijas:\n{serverVersions}\nTačiau ši programa palaiko tik {supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "bannedUser": "{username} užblokavo {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "changedTheHistoryVisibility": "{username} pakeitė istorijos matomumą", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "{username} pakeitė istorijos matomumą į: {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "chatBackupDescription": "Jūsų senos žinutės yra apsaugotos atkūrimo raktu. Pasirūpinkite, kad jo neprarastumėte.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_create": "Sukurti tuščią grupinį pokalbį\nNaudokite --no-encryption kad išjungti šifravimą", "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "commandHint_dm": "Pradėti tiesioginį pokalbį\nNaudokite --no-encryption kad išjungti šifravimą", "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "commandHint_myroomavatar": "Nustatyti savo nuotrauką šiame kambaryje (su mxc-uri)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_op": "Nustatyti naudotojo galios lygį (numatytasis: 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_react": "Siųsti atsakymą kaip reakciją", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "commandMissing": "{command} nėra komanda.", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "containsDisplayName": "Turi rodomą vardą", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "Turi vartotojo vardą", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "Nepavyko iššifruoti pranešimo: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "countParticipants": "{count} dalyviai", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "createdTheChat": "💬 {username} sukūrė pokalbį", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "emptyChat": "Tuščias pokalbis", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Jaustukas jau egzistuoja!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "Neteisingas jaustuko trumpasis kodas!", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "Jaustukų paketai kambariui", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Jaustukų nustatymai", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteShortcode": "Jaustuko trumpasis kodas", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Turite pasirinkti jaustuko trumpąjį kodą ir paveiksliuką!", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "Įgalinti jaustukų paketą visur", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName} baigė skambutį", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "errorObtainingLocation": "Klaida nustatant vietą: {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "groupWith": "Grupė su {displayname}", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "hasWithdrawnTheInvitationFor": "{username} atšaukė {targetName} kvietimą", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "inviteForMe": "Pakvietimas man", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "Pakviesti kontaktą į {groupName}", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "invitedUser": "📩 {username} pakvietė {targetName}", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "inviteText": "{username} pakvietė jus prisijungti prie FluffyChat. \n1. Įdiekite FluffyChat: https://fluffychat.im \n2. Prisiregistruokite arba prisijunkite \n3. Atidarykite pakvietimo nuorodą: {link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "joinedTheChat": "👋 {username} prisijungė prie pokalbio", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "kicked": "👞 {username} išmetė {targetName}", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickedAndBanned": "🙅 {username} išmetė ir užblokavo {targetName}", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "lastActiveAgo": "Paskutinis aktyvumas: {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "loadCountMoreParticipants": "Įkelti dar {count} dalyvius", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "logInTo": "Prisijungti prie {homeserver}", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "toggleFavorite": "Perjungti parankinius", "@toggleFavorite": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleMuted": "Perjungti nutildytą", "@toggleMuted": { - "type": "text", + "type": "String", "placeholders": {} }, "cantOpenUri": "Nepavyksta atidaryti URI {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "changedTheChatAvatar": "{username} pakeitė pokalbio avatarą", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "{username} pakeitė pokalbio aprašymą į: '{description}'", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheChatNameTo": "{username} pakeitė pokalbio pavadinimą į: '{chatname}'", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheChatPermissions": "{username} pakeitė pokalbių leidimus", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheDisplaynameTo": "{username} pakeitė rodomą vardą į: '{displayname}'", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username} pakeitė svečio prieigos taisykles", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username} pakeitė svečio prieigos taisykles į: {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRules": "{username} pakeitė prisijungimo taisykles", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username} pakeitė prisijungimo taisykles į: {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username} pakeitė savo avatarą", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomAliases": "{username} pakeitė kambario pseudonimus", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "{username} pakeitė pakvietimo nuorodą", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "videoWithSize": "Vaizdo įrašas ({size})", "@videoWithSize": { - "type": "text", + "type": "String", "placeholders": { - "size": {} + "size": { + "type": "String" + } } }, "pinMessage": "Prisegti prie kambario", @@ -1933,7 +2080,9 @@ "@switchToAccount": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "nextAccount": "Kita paskyra", @@ -1957,142 +2106,186 @@ "youBannedUser": "Jūs užblokavote {user}", "@youBannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youHaveWithdrawnTheInvitationFor": "Jūs atšaukėte kvietimą {user}", "@youHaveWithdrawnTheInvitationFor": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youInvitedBy": "📩 Jus pakvietė {user}", "@youInvitedBy": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youKicked": "👞 Jūs išmetėte {user}", "@youKicked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youInvitedUser": "📩 Pakvietėte {user}", "@youInvitedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youKickedAndBanned": "🙅 Jūs išmetėte ir užblokavote {user}", "@youKickedAndBanned": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youUnbannedUser": "Jūs atblokavote {user}", "@youUnbannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{month}-{day}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "dateWithYear": "{year}-{month}-{day}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "locationDisabledNotice": "Vietos nustatymo paslaugos yra išjungtos. Kad galėtumėte bendrinti savo buvimo vietą, įjunkite jas.", "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "noMatrixServer": "{server1} nėra Matrix serveris, ar vietoj jo naudoti {server2}?", "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "numUsersTyping": "{count} vartotojai rašo…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "enableMultiAccounts": "(BETA) Įgalinkite kelias paskyras šiame įrenginyje", "@enableMultiAccounts": {}, "openInMaps": "Atidaryti žemėlapiuose", "@openInMaps": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAPicture": "🖼️ {username} atsiuntė nuotrauką", "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAVideo": "🎥 {username} atsiuntė vaizdo įrašą", "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentCallInformations": "{senderName} išsiuntė skambučio informaciją", "@sentCallInformations": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "setCustomEmotes": "Nustatyti pasirinktinius jaustukus", "@setCustomEmotes": { - "type": "text", + "type": "String", "placeholders": {} }, "userLeftTheChat": "🚪 {username} paliko pokalbį", "@userLeftTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "markAsRead": "Žymėti kaip skaitytą", "@markAsRead": {}, "pushRules": "Tiesioginių pranešimų taisyklės", "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, "unreadChats": "{unreadCount, plural, =1{1 unread chat} other{{unreadCount} neperskaityti pokalbiai}}", "@unreadChats": { - "type": "text", + "type": "String", "placeholders": { - "unreadCount": {} + "unreadCount": { + "type": "int" + } } }, "addWidget": "Pridėti programėlę", @@ -2103,12 +2296,12 @@ "@errorAddingWidget": {}, "askSSSSSign": "Kad galėtumėte prijungti kitą asmenį, įveskite savo saugyklos slaptafrazę arba atkūrimo raktą.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "autoplayImages": "Automatiškai leisti animuotus lipdukus ir jaustukus", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "commandHint_markasdm": "Pažymėti kaip tiesioginio pokalbio kambarį", @@ -2149,9 +2342,11 @@ "@confirmMatrixId": {}, "supposedMxid": "Tai turėtų būti {mxid}", "@supposedMxid": { - "type": "text", + "type": "String", "placeholders": { - "mxid": {} + "mxid": { + "type": "String" + } } }, "dehydrate": "Eksportuoti sesiją ir išvalyti įrenginį", @@ -2173,7 +2368,9 @@ "countFiles": "{count} failai", "@countFiles": { "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "storeInSecureStorageDescription": "Atkūrimo raktą laikyti saugioje šio prietaiso saugykloje.", @@ -2210,138 +2407,11 @@ "@numChats": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "hideUnimportantStateEvents": "Slėpti nesvarbius būsenos įvykius", - "@hideUnimportantStateEvents": {}, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@reportErrorDescription": {}, - "@startFirstChat": {}, - "@setColorTheme": {}, - "@banUserDescription": {}, - "@removeDevicesDescription": {}, - "@tryAgain": {}, - "@unbanUserDescription": {}, - "@messagesStyle": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@encryptThisChat": {}, - "@reopenChat": {}, - "@pushNotificationsNotAvailable": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@signInWithPassword": {}, - "@makeAdminDescription": {}, - "@setChatDescription": {}, - "@importFromZipFile": {}, - "@noOtherDevicesFound": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@fileIsTooBigForServer": {}, - "@readUpToHere": {}, - "@optionalRedactReason": {}, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@redactMessageDescription": {}, - "@invalidInput": {}, - "@doNotShowAgain": {}, - "@report": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@openLinkInBrowser": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@invitePrivateChat": {}, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@learnMore": {}, - "@notAnImage": {}, - "@chatDescriptionHasBeenChanged": {}, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "@profileNotFound": {}, - "@jump": {}, - "@sorryThatsNotPossible": {}, - "@shareInviteLink": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@commandHint_hug": {}, - "@replace": {}, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@noBackupWarning": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@invite": {} -} \ No newline at end of file + "@hideUnimportantStateEvents": {} +} diff --git a/lib/l10n/intl_lv.arb b/lib/l10n/intl_lv.arb new file mode 100644 index 000000000..9ad9c22fa --- /dev/null +++ b/lib/l10n/intl_lv.arb @@ -0,0 +1,3131 @@ +{ + "showPassword": "Rādīt paroli", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "hugContent": "{senderName} apskauj Tevi", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "darkTheme": "Tumšs", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "paroles vārdkopa vai atkopes atslēga", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Lūgums ievadīt savu paroli", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Tās sakrīt", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "connect": "Savienot", + "@connect": { + "type": "String", + "placeholders": {} + }, + "jumpToLastReadMessage": "Pārlēkt uz pēdējo izlasīto ziņu", + "allRooms": "Visām kopu tērzēšanām", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Iegūst atrašanās vietu…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "commandHint_cuddle": "Nosūtīt samīļojienu", + "chats": "Tērzēšanas", + "@chats": { + "type": "String", + "placeholders": {} + }, + "widgetVideo": "Video", + "dismiss": "Atmest", + "unknownDevice": "Nezināma ierīce", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Emocijas īskods", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Šifrēšanu var iespējot tikai tad, kad istaba vairs nav publiski pieejama.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "admin": "Pārvaldītājs", + "@admin": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "😭 Ak nē! Kaut kas nogāja greizi. Ja ir vēlēšanas, par šo nepilnību var ziņot izstrādātājiem.", + "directChats": "Tiešās tērzēšanas", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Iestatīt atļauju līmeni", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Uzaicināt kontaktpersonu {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "addAccount": "Pievienot kontu", + "close": "Aizvērt", + "@close": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Konfigurēt tērzēšanu", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Šai vietai tika pievienota tērzēšana", + "reply": "Atbildēt", + "@reply": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Pašreiz darbīgi", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Noņemt savu attēlu", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "unsupportedAndroidVersion": "Neatbalstīta Android versija", + "device": "Ierīce", + "@device": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "Liegt ierīci", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "commandHint_html": "Nosūtīt ar HTML formatētu tekstu", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "widgetJitsi": "Jitsi Meet", + "youAreNoLongerParticipatingInThisChat": "Tu vairs nepiedalies šajā tērzēšanā", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "encryption": "Šifrēšana", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "messageType": "Ziņas veids", + "indexedDbErrorLong": "Diemžēl ziņu krātuve pēc noklusējuma nav iespējota privātajā režīmā.\nLūgums apmeklēt\n - about:config\n - iestatīt dom.indexedDB.privateBrowsing.enabled kā true\nPretējā gadījumā nav iespējams palaist FluffyChat.", + "oneClientLoggedOut": "Viens no klientiem ir atteicies", + "toggleMuted": "Pārslēgt apklusināšanu", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "unsupportedAndroidVersionLong": "Šai iespējai ir nepieciešama jaunāka Android versija. Lūgums pārbaudīt atjauninājumus vai Lineage OS atbalstu.", + "kicked": "👞 {username} izmeta {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Mainīt kopas nosaukumu", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} nomainīja tērzēšanas attēlu", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "verifySuccess": "Apliecināšana bija sekmīga.", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Nosūtīt datni", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Jauns apliecināšanas pieprasījums.", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "startFirstChat": "Uzsāc savu pirmo tērzēšanu", + "callingAccount": "Zvanīšanas konts", + "requestPermission": "Pieprasīt atļauju", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "sentAPicture": "🖼️ {username} nosūtīja attēlu", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "invited": "Uzaicināts", + "@invited": { + "type": "String", + "placeholders": {} + }, + "changedTheDisplaynameTo": "{username} nomainīja savu attēlojamo vārdu uz '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "setColorTheme": "Iestatīt krāsu izskatu:", + "nextAccount": "Nākamais konts", + "commandHint_create": "Izveidot tukšu kopas tērzēšanu\nLai atspējotu šifrēšanu, jāizmanto --no-encryption", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "singlesignon": "Vienotā pieteikšanās", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "warning": "Uzmanību!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "password": "Parole", + "@password": { + "type": "String", + "placeholders": {} + }, + "allSpaces": "Visas vietas", + "supposedMxid": "Tam būtu jābūt {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "editDisplayname": "Labot attēlojamo vārdu", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "user": "Lietotājs", + "roomVersion": "Istabas versija", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} nosūtīja datni", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "videoCall": "Videozvans", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "youAcceptedTheInvitation": "👍 Tu pieņēmi uzaicinājumu", + "banFromChat": "Izslēgt no tērzēšanas", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} nav Matrix serveris, tā vietā izmantot {server2}?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "userAndOthersAreTyping": "{username} un {count} citi raksta…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "youInvitedBy": "📩 {user} Tevi uzaicināja", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "userIsTyping": "{username} raksta…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "openAppToReadMessages": "Atvērt lietotni, lai lasītu ziņas", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "sentAVideo": "🎥 {username} nosūtīja video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banUserDescription": "Lietotājam tiks liegta piekļuve tērzēšanai, un vairs nevarēs vēlreiz pievienoties tērzēšanai, līdz liegums tiks atcelts.", + "inviteContact": "Uzaicināt kontaktpersonu", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Lai varētu parakstīt otru cilvēku, lūgums ievadīt savu drošo krātuves paroles vārdkopu vai atkopes atslēgu.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "widgetEtherpad": "Teksta piezīme", + "waitingPartnerAcceptRequest": "Gaida, līdz biedrs apstiprinās pieprasījumu…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "remove": "Noņemt", + "@remove": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Rakstīt ziņu…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Mainīt izskatu", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "id": "Id", + "@id": { + "type": "String", + "placeholders": {} + }, + "removeDevicesDescription": "Tu tiksi izrakstīts no šīs ierīces un vairs nevarēsi saņemt ziņas.", + "changedTheChatDescriptionTo": "{username} nomainīja tērzēšanas aprakstu uz '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "countParticipants": "{count} dalībnieki", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "separateChatTypes": "Atdalīt tiešās tērzēšanas un kopas", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "tryAgain": "Jāmēģina vēlreiz", + "areGuestsAllowedToJoin": "Vai vieslietotājiem ir ļauts pievienoties", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "blocked": "Liegta", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "youKickedAndBanned": "🙅 Izraidīji {user} un liedzi piekļuvi", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}.{month}.", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "removeDevice": "Noņemt ierīci", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanUserDescription": "Lietotājs varēs atkal pievienoties tērzēšanai, ja mēģinās.", + "userAndUserAreTyping": "{username} un {username2} raksta…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "pleaseClickOnLink": "Lūgums klikšķināt uz saites e-pastā un tad turpināt.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Saglabāt datni", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Nosūtīt ar Enter", + "pickImage": "Izvēlēties attēlu", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} atbildēja uz zvanu", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "youRejectedTheInvitation": "Tu noraidīji uzaicinājumu", + "otherCallingPermissions": "Mikrofons, kamera un citas FluffyChat atļaujas", + "messagesStyle": "Ziņas:", + "couldNotDecryptMessage": "Nevarēja atšifrēt ziņu: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Tikai uzaicināti lietotāji", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "link": "Saite", + "widgetUrlError": "Tas nav derīgs URL.", + "emailOrUsername": "E-pasta adrese vai lietotājvārds", + "newSpaceDescription": "Vietas ļauj apvienot tērzēšanas un būvēt privātas vai publiskas kopienas.", + "chatDescription": "Tērzēšanas apraksts", + "callingAccountDetails": "Ļauj FluffyChat izmantot iebūvēto Android zvanīšanas lietotni.", + "next": "Nākamais", + "@next": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Lūgums sekot norādēm tīmekļvietnē un piesist \"Nākamais\".", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "changedTheGuestAccessRules": "{username} nomainīja viesu piekļuves nosacījumus", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "dateWithYear": "{year}.{month}.{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "editRoomAliases": "Labot istabu aizstājvārdus", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "enterSpace": "Ieiet vietā", + "encryptThisChat": "Šifrēt šo tērzēšanu", + "fileName": "Datnes nosaukums", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Nav pieejams", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "previousAccount": "Iepriekšējais konts", + "publicRooms": "Publiskas istabas", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "No uzaicinājuma", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Nosūtīt ziņas", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Nepareiza paroles vārdkopa vai atkopes atslēga", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Nepieciešams izvēlēties emocijas īskodu un attēlu.", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "reopenChat": "Atkārtoti atvērt tērzēšanu", + "pleaseEnterRecoveryKey": "Lūgums ievadīt savu atkopes atslēgu:", + "create": "Izveidot", + "@create": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Pārslēgt iecienīto", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "no": "Nē", + "@no": { + "type": "String", + "placeholders": {} + }, + "alias": "aizstājvārds", + "@alias": { + "type": "String", + "placeholders": {} + }, + "widgetNameError": "Lūgums norādīt attēlojamo nosaukumu.", + "inoffensive": "Nav aizskarošs", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "unpin": "Atspraust", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "addToBundle": "Pievienot komplektam", + "reportMessage": "Ziņot par ziņu", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Vieta ir publiska", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "addWidget": "Pievienot logrīku", + "all": "Viss", + "@all": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Noņemt visas pārējās ierīces", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "unblockDevice": "Atslēgt ierīci", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "countFiles": "{count} datnes", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noKeyForThisMessage": "Tā var notikt, ja ziņa tika nosūtīta, pirms pieteicies savā kontā šajā ierīcē.\n\nIr arī iespējams, ka sūtītājs noliedza Tavu ierīci vai kaut kas nogāja greizi ar interneta savienojumu.\n\nVai ziņas ir lasāmas citā sesijā? Tad Tu vari pārsūtīt ziņu no tās. Jādodas uz Iestatījumi > Ierīces un jāpārliecinās, ka ierīces viena otru ir apliecinājušas. Kad nākamreiz atvērsi istabu un abas sesijas būs priekšplānā, atslēgas tiks automātiski pārsūtītas.\n\nVai nevēlies zaudēt atslēgas, kad atsakies vai maini ierīces? Jāpārliecinās, ka iestatījumos ir iespējota tērzēšanu rezerves kopija.", + "enableEncryptionWarning": "Vairs nebūs iespējams atspējot šifrēšanu. Vai tiešām to darīt?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} uzaicināja pievienoties FluffyChat.\n1. Jāapmeklē fluffychat.im un jāuzstāda lietotne \n2. Jāizveido konts vai jāpiesakās \n3. Jāatver uzaicinājuma saite: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "shareLocation": "Kopīgot atrašanās vietu", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "reason": "Iemesls", + "@reason": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasgroup": "Atzīmēt kā kopu", + "errorObtainingLocation": "Kļūda atrašanās vietas iegūšanā: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "hydrateTor": "TOR lietotāji: ievietot sesijas izguvi", + "pushNotificationsNotAvailable": "Pašpiegādes paziņojumi nav pieejami", + "passwordRecovery": "Paroles atkope", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "storeInAppleKeyChain": "Glabāt Apple KeyChain", + "replaceRoomWithNewerVersion": "Aizvietot istabu ar jaunāku versiju", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "hydrate": "Atjaunot no rezerves kopijas datnes", + "invalidServerName": "Nederīgs servera nosaukums", + "chatPermissions": "Tērzēšanas atļaujas", + "voiceMessage": "Balss ziņa", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "Mājasserveris nodrošina pieteikšanās veidus:\n{serverVersions}\nSavukārt, šī lietotne atbalsta tikai:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "wipeChatBackup": "Notīrīt tērzēšanu rezerves kopiju, lai izveidotu jaunu atkopes atslēgu?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Nevar atvērt adresi {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "sender": "Sūtītājs", + "storeInAndroidKeystore": "Glabāt Android KeyStore", + "hideRedactedEvents": "Paslēpt labošanas notikumus", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "online": "Tiešsaistē", + "@online": { + "type": "String", + "placeholders": {} + }, + "signInWithPassword": "Pieteikties ar paroli", + "lastActiveAgo": "Pēdējoreiz tiešsaistē: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} nomainīja viesu piekļuves nosacījumus uz {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "weSentYouAnEmail": "Mēs nosūtīja e-pasta ziņu", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "offensive": "Aizskarošs", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Lūgums ņemt vērā, ka pagaidām ir nepieciešams Pantalaimon, lai izmantotu pilnīgu šifrēšanu.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "makeAdminDescription": "Tiklīdz šis lietotājs tiks padarīts par pārvaldītāju, to vairs nevarēs atdarīt, jo tad tam būs tādas pašas atļaujas kā Tev.", + "edit": "Labot", + "@edit": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Ielādēt vēl…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Netika atrasta neviena emocija. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sinhronizē... Lūgums uzgaidīt.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Pārnest no citas ierīces", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Parole tikai nomainīta", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Pašpiegādes nosacījumi", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Doties uz jauno istabu", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "commandHint_clearcache": "Iztīrīt kešatmiņu", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "loadingPleaseWait": "Ielādē... Lūgums uzgaidīt.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "copy": "Ievietot starpliktuvē", + "@copy": { + "type": "String", + "placeholders": {} + }, + "saveKeyManuallyDescription": "Šo atslēgu var pašrocīgi saglabāt ar sistēmas kopīgošanas dialogloga vai starpliktuves izsaukšanu.", + "none": "Neviens", + "@none": { + "type": "String", + "placeholders": {} + }, + "editBundlesForAccount": "Labot šī konta komplektus", + "enableEncryption": "Iespējot šifrēšanu", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "whyIsThisMessageEncrypted": "Kādēļ šī ziņa ir nelasāma?", + "unreadChats": "{unreadCount, plural, zero{{unreadCount} nelasītu tērzēšanu} =1{{unreadCount} nelasīta tērzēšana} other{{unreadCount} nelasītas tērzēšanas}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "rejectedTheInvitation": "{username} noraidīja uzaicinājumu", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "setChatDescription": "Iestatīt tērzēšanas aprakstu", + "userLeftTheChat": "🚪 {username} pameta tērzēšanu", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "spaceName": "Vietas nosaukums", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "importFromZipFile": "Ievietot no .zip datnes", + "toggleUnread": "Atzīmēt kā lasītu/nelasītu", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "or": "Vai", + "@or": { + "type": "String", + "placeholders": {} + }, + "dehydrateWarning": "Šī darbība nav atdarāma. Jānodrošina, ka rezerves kopijas datne tiek droši uzglabāta.", + "sendOriginal": "Nosūtīt sākotnējo", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "noOtherDevicesFound": "Netika atrastas citas ierīces", + "whoIsAllowedToJoinThisGroup": "Kuram ir ļauts pievienoties šai kopai", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Tukša tērzēšana", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "{username} redzēja", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "storeSecurlyOnThisDevice": "Droši uzglabāt šajā ierīcē", + "yourChatBackupHasBeenSetUp": "Tērzēšanu rezerves kopēšana iestatīta.", + "chatBackup": "Tērzēšanu rezerves kopēšana", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "redactedBy": "Laboja {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "submit": "Iesniegt", + "@submit": { + "type": "String", + "placeholders": {} + }, + "videoCallsBetaWarning": "Lūgums ņemt vērā, ka video zvani pašreiz ir beta stāvoklī. Tie visās platformās var nedarboties kā paredzēs vai pat nedarboties vispār.", + "unmuteChat": "Atcelt tērzēšanas apklusināšanu", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} izveidoja tērzēšanu", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactedAnEvent": "{username} laboja notikumu", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Automātiski atskaņot animētas uzlīmes un emocijas", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "compareEmojiMatch": "Lūgums salīdzināt emocijzīmes", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "participant": "Dalībnieks", + "@participant": { + "type": "String", + "placeholders": {} + }, + "logInTo": "PIeteikties {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "yes": "Jā", + "@yes": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Satur attēlojamo vārdu", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "signInWith": "Pieteikties ar {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "username": "Lietotājvārds", + "@username": { + "type": "String", + "placeholders": {} + }, + "changedTheRoomAliases": "{username} nomainīja istabas aizstājvārdus", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "Nevar nosūtīt. Serveris nodrošina pielikums līdz {max}.", + "homeserver": "Mājasserveris", + "help": "Palīdzība", + "@help": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Tērzēšanas izvērsums", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "people": "Cilvēki", + "@people": { + "type": "String", + "placeholders": {} + }, + "changedTheHistoryVisibilityTo": "{username} nomainīja vēstures redzamību uz {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "leftTheChat": "Pameta tērzēšanu", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "verified": "Apliecināta", + "@verified": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Atkārtot paroli", + "setStatus": "Iestatīt stāvokli", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Kopa ar {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "callingPermissions": "Zvanīšanas atļaujas", + "delete": "Izdzēst", + "@delete": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Jauna ziņa FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "readUpToHere": "Izlasīts līdz šejienei", + "start": "Uzsākt", + "downloadFile": "Lejupielādēt datni", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Ierīces Id", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "register": "Reģistrēties", + "@register": { + "type": "String", + "placeholders": {} + }, + "unlockOldMessages": "Atslēgt vecās ziņas", + "identity": "Identitāte", + "@identity": { + "type": "String", + "placeholders": {} + }, + "numChats": "{number} tērzēšanas", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} nomainīja pievienošanās nosacījumus uz {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "recording": "Ieraksta", + "@recording": { + "type": "String", + "placeholders": {} + }, + "changedTheChatPermissions": "{username} nomainīja tērzēšanas atļaujas", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "moderator": "Moderators", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "optionalRedactReason": "(Pēc izvēles) Ziņas labošanas iemesls...", + "acceptedTheInvitation": "👍 {username} pieņēma uzaicinājumu", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "waitingPartnerEmoji": "Gaida, līdz biedrs apstiprinās emocijzīmes…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Šifrēšana tika bojāta", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Mēģināt nosūtīt vēlreiz", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Viesi var pievienoties", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "ok": "Labi", + "@ok": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Ievietot starpliktuvē", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "dehydrate": "Izgūt sesiju un iztīrīt ierīci", + "locationPermissionDeniedNotice": "Atrašanās vietas atļauja noliegta. Lūgums nodrošināt to, lai būtu iespējams kopīgot savu atrašanās vietu.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "send": "Nosūtīt", + "@send": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} atsauca uzaicinājumu {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "visibleForAllParticipants": "Redzama visiem dalībniekiem", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Istabas netika atrastas…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "banned": "Izslēgts", + "@banned": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Nosūtīt kā tekstu", + "@sendAsText": { + "type": "String" + }, + "inviteForMe": "Uzaicinājumu man", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "archiveRoomDescription": "Tērzēšana tiks pārvietota uz arhīvu. Citi lietotāji redzēs, ka pameti tērzēšanu.", + "exportEmotePack": "Izgūt emociju paku kā .zip", + "changedTheChatNameTo": "{username} nomainīja tērzēšanas nosaukumu uz '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "sendSticker": "Nosūtīt uzlīmi", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "account": "Konts", + "@account": { + "type": "String", + "placeholders": {} + }, + "switchToAccount": "Pārslēgties uz kontu {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "commandInvalid": "Nederīga komanda", + "@commandInvalid": { + "type": "String" + }, + "setAsCanonicalAlias": "Iestatīt kā galveno aizstājvārdu", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Kādēļ vēlies ziņot par šo?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Atrašanās vietas pakalpojumi ir atspējoti. Lūgums tos iespējot, lai būtu iespējams kopīgot savu atrašanās vietu.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "placeCall": "Veikt zvanu", + "removedBy": "Noņēma {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} nomainīja uzaicinājuma saiti", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "newChat": "Jauna tērzēšana", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "notifications": "Paziņojumi", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "commandHint_plain": "Nosūtīt neformatētu tekstu", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "emoteSettings": "Emociju iestatījumi", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "experimentalVideoCalls": "Izmēģinājuma video zvani", + "openCamera": "Atvērt kameru", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKeyDescription": "Lai atslēgtu savas vecās ziņas, lūgums ievadīt savu atkopes atslēgu, kas tika izveidota iepriekšējā sesijā. Atkopes atslēga NAV parole.", + "guestsAreForbidden": "Viesi nav ļauti", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "mention": "Pieminēt", + "@mention": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Atvērt kartēs", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Ar šīm adresēm var atjaunot savu paroli.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroupQuestion": "Vai vēlies uzaicināt {contact} uz tērzēšanu \"{groupName}\"?", + "emoteExists": "Emocija jau pastāv.", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "redactedByBecause": "Laboja {username}, jo: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "isTyping": "raksta…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "youHaveWithdrawnTheInvitationFor": "Tu atsauci {user} uzaicinājumu", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "chat": "Tērzēšana", + "@chat": { + "type": "String", + "placeholders": {} + }, + "group": "Kopa", + "@group": { + "type": "String", + "placeholders": {} + }, + "leave": "Pamest", + "@leave": { + "type": "String", + "placeholders": {} + }, + "skip": "Izlaist", + "@skip": { + "type": "String", + "placeholders": {} + }, + "appearOnTopDetails": "Ļauj lietotnei parādīties virspusē (nav nepieciešams, ja FluffyChat jau ir iestatīts kā zvanīšanas konts)", + "roomHasBeenUpgraded": "Istaba tika atjaunināta", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "enterRoom": "Ieiet istabā", + "enableEmotesGlobally": "Iespējot kā vispārēju emociju paku", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Vai tiešām?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Lūgums izvēlēties piekļuves kodu", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Vēl nav pievienots paroles atjaunošanas veids.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "changedTheProfileAvatar": "{username} nomainīja savu attēlu", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "allChats": "Visas tērzēšanas", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "reportUser": "Ziņot par lietotāju", + "sharedTheLocation": "{username} kopīgoja savu atrašanās vietu", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "commandHint_send": "Nosūtīt tekstu", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "onlineKeyBackupEnabled": "Tiešsaistes atslēgas rezerves kopēšana ir iespējota", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} atcēla {targetName} piekļuves liegumu", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "confirmEventUnpin": "Vai tiešām neatgriezeniski atspraust šo notikumu?", + "badServerVersionsException": "Mājasserveris nodrošina specifikācijas versijas:\n{serverVersions}\nSavukārt, lietotne atbalsta tikai {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Tu uzaicināji {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} izmeta {targetName} un liedza piekļuvi", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "noConnectionToTheServer": "Nav savienojuma ar serveri", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "fileHasBeenSavedAt": "Datne tika saglabāta {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "license": "Licence", + "@license": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Pievienot vietai", + "unbanFromChat": "Atcelt liegumu tērzēšanā", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "commandMissing": "{command} nav komanda.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "redactMessageDescription": "Ziņa tiks labota visiem šīs sarunas dalībniekiem. To nevar atdarīt.", + "rejoin": "Pievienoties atkārtoti", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "Atkopes atslēga", + "redactMessage": "Labot ziņu", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "forward": "Pārsūtīt", + "@forward": { + "type": "String", + "placeholders": {} + }, + "commandHint_discardsession": "Atmest sesiju", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "invalidInput": "Nederīga ievade.", + "about": "Par", + "@about": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Jāizvēlas droša parole", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "dehydrateTorLong": "TOR lietotājiem ir ieteicams izgūt sesiju pirms loga aizvēršanas.", + "yourPublicKey": "Tava publiskā atslēga", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Pārāk daudz pieprasījumu. Lūdzu, vēlāk mēģini vēlreiz!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} uzaicināja {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Izmest no tērzēšanas", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "commandHint_myroomnick": "Iestatīt savu attēlojamo vārdu šajā istabā", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "offline": "Bezsaistē", + "@offline": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Nav atļaujas", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "doNotShowAgain": "Vairs nerādīt", + "activatedEndToEndEncryption": "🔐 {username} iespējoja pilnīgu šifrēšanu", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "report": "Ziņot", + "status": "Stāvoklis", + "@status": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Lūgums salīdzināt skaitļus", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Kopa ir publiska", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Uzsākt apliecināšanu", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Dalībnieku izmaiņām", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "Pievienoties istabai", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "unverified": "Neapliecināta", + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Cik aizskarošs ir šis saturs?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "Šim serverim ir nepieciešams pārbaudīt Tavu e-pasta adresi reģistrācijai.", + "hideUnimportantStateEvents": "Paslēpt nebūtiskus stāvokļa notikumus", + "screenSharingTitle": "ekrāna kopīgošana", + "widgetCustom": "Pielāgots", + "sentCallInformations": "{senderName} nosūtīja informāciju par zvanu", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "addToSpaceDescription": "Atlasīt vietu, kurai pievienot šo tērzēšanu.", + "googlyEyesContent": "{senderName} sūta izbolītas acis", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "youBannedUser": "Tu {user} liedzi piekļuvi", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "theyDontMatch": "Tās nesakrīt", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Tev tika liegta piekļuve šai tērzēšanai", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Attēlojamais vārds tika nomainīts", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "addChatDescription": "Pievienot tērzēšanas aprakstu…", + "sentAnAudio": "🎤 {username} nosūtīja skaņu", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "editRoomAvatar": "Labot istabas attēlu", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Šifrēta", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "commandHint_leave": "Pamest šo istabu", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_myroomavatar": "Iestatīt savu attēlu šajā istabā (ar mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "cancel": "Atcelt", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "hasKnocked": "🚪 {user} pieklauvēja", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "publish": "Publicēt", + "openLinkInBrowser": "Atvērt saiti pārlūkā", + "clearArchive": "Iztīrīt arhīvu", + "appLock": "Lietotnes aizslēgšana", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "commandHint_react": "Nosūtīt atbildi kā reakciju", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "changedTheHistoryVisibility": "{username} mainīja vēstures redzamību", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "commandHint_me": "Apraksti sevi", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "pleaseEnterYourUsername": "Lūgums ievadīt savu lietotājvārdu", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Informācija par ziņu", + "disableEncryptionWarning": "Drošības iemeslu dēļ tērzēšanā nevar atspējot šifrēšanu, ja tā ir pirms tam ir bijusi iespējota.", + "directChat": "Tiešā tērzēšana", + "encryptionNotEnabled": "Šifrēšana nav iespējota", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "wrongPinEntered": "Ievadīts nepareizs PIN. Lūgums mēģināt vēlreiz pēc {seconds} sekundēm...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "Nosūtīt rakstīšanas paziņojumus", + "lightTheme": "Gaišs", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "inviteGroupChat": "📨 Uzaicinājums uz kopas tērzēšanu", + "appearOnTop": "Parādīt virspusē", + "invitePrivateChat": "📨 Uzaicinājums uz privātu tērzēšanu", + "verifyTitle": "Apliecina citu kontu", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "foregroundServiceRunning": "Šis paziņojums parādās, kad darbojas priekšplāna pakalpojums.", + "enterAnEmailAddress": "Jāievada e-pasta adrese", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "voiceCall": "Balss zvans", + "commandHint_kick": "Noņemt norādīto lietotāju no šīs istabas", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "copiedToClipboard": "Ievietots starpliktuvē", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Jauna vieta", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "commandHint_unban": "Atcelt norādītā lietotāja izslēgšanu no šīs istabas", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "unknownEncryptionAlgorithm": "Nezināms šifrēšanas algoritms", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Izslēgt norādīto lietotāju no šīs istabas", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "importEmojis": "Ievietot emocijzīmes", + "confirm": "Apstiprināt", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "wasDirectChatDisplayName": "Tukša tērzēšana (bija {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "Tērzēšanas apraksts vēl nav izveidots.", + "defaultPermissionLevel": "Noklusējuma atļauju līmenis jauniem lietotājiem", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "removeFromBundle": "Noņemt no šī komplekta", + "numUsersTyping": "{count} lietotāji raksta…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "fontSize": "Fonta izmērs", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Kurš var veikt kādas darbības", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Lūgums apliecināt savu Matrix Id, lai varētu izdzēst savu kontu.", + "learnMore": "Uzzināt vairāk", + "iHaveClickedOnLink": "Es uzklikšķināju uz saites", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "you": "Tu", + "@you": { + "type": "String", + "placeholders": {} + }, + "notAnImage": "Nav attēla datne.", + "users": "Lietotāji", + "openGallery": "Atvērt galeriju", + "chatDescriptionHasBeenChanged": "Tērzēšanas apraksts ir mainījies", + "search": "Meklēt", + "@search": { + "type": "String", + "placeholders": {} + }, + "newGroup": "Jauna kopa", + "bundleName": "Komplekta nosaukums", + "dehydrateTor": "TOR lietotāji: izgūt sesiju", + "removeFromSpace": "Noņemt no vietas", + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "commandHint_op": "Iestatīt norādītā lietotāja pilnvaru līmeni (noklusējums: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_join": "Pievienoties norādītajai istabai", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "sourceCode": "Pirmkods", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "roomUpgradeDescription": "Tērzēšana tad tiks atkārtoti izveidota ar jauno istabas versiju. Visiem dalībniekiem tiks paziņots, ka viņiem ir jāpārslēdzas uz jauno tērzēšanu. Vairāk par istabu versijām var atrast https://spec.matrix.org/latest/rooms/", + "commandHint_invite": "Uzaicināt norādīto lietotāju šajā istabā", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "userSentUnknownEvent": "{username} nosūtīja notikumu {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "scanQrCode": "Nolasīt kvadrātkodu", + "logout": "Atteikties", + "@logout": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterANumber": "Lūgums ievadīt skaitli lielāku par 0", + "contactHasBeenInvitedToTheGroup": "Kontaktpersona tika uzaicināta kopā", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "youKicked": "👞 Tu izraidīji {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "areYouSureYouWantToLogout": "Vai tiešām atteikties?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "changedTheJoinRules": "{username} nomainīja pievienošanās nosacījumus", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "profileNotFound": "Lietotāju serverī nevarēja atrast. Varbūt ir nebūšanas ar savienojumu vai lietotājs nepastāv.", + "jump": "Pārlēkt", + "groups": "Kopas", + "@groups": { + "type": "String", + "placeholders": {} + }, + "reactedWith": "{sender} atsaucās ar {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "bannedUser": "{username} izslēdza {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "sorryThatsNotPossible": "Atvaino! Tas nav iespējams", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "oopsSomethingWentWrong": "Ups! Kaut kas nogāja greizi…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Ielādēt vēl {count} dalībniekus", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "shareInviteLink": "Kopīgot uzaicinājuma saiti", + "commandHint_markasdm": "Atzīmēt kā tiešo ziņu istabu norādītajam Matrix Id", + "recoveryKeyLost": "Pazaudēta atkopes atslēga?", + "cuddleContent": "{senderName} samīļo Tevi", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "askVerificationRequest": "Pieņemt apliecināšanas pieprasījumu no {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "containsUserName": "Satur lietotājvārdu", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "messages": "Ziņas", + "@messages": { + "type": "String", + "placeholders": {} + }, + "login": "Pieteikties", + "@login": { + "type": "String", + "placeholders": {} + }, + "deviceKeys": "Ierīces atslēgas:", + "waitingPartnerNumbers": "Gaida, līdz biedrs apstiprinās skaitļus…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Izskatās, ka Firebase mākoņziņojumapmaiņa nav pieejama šajā ierīcē. Lai joprojām saņemtu pašpiegādes paziņojumus, mēs iesakām uzstādīt ntfy. Ar ntfy vai citu UnifiedPush nodrošinātāju ir iespējams saņemt pašpiegādes paziņojumus drošā veidā. ntfy var lejupielādēt no Play Store vai F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Viss ir gatavs!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "addEmail": "Pievienot e-pasta adresi", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "emoteKeyboardNoRecents": "Nesen izmantotās emocijas parādīsies šeit...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Iestatīt pielāgotas emocijas", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} uzsāka zvanu", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "emoteInvalid": "Nederīgs emocijas īskods.", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistēmas", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Paziņojumi iespējoti šim kontam", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Izdzēst ziņu", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Tērzēšanas vēstures redzamība", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "settings": "Iestatījumi", + "@settings": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Iestatīt izskatu:", + "changeTheHomeserver": "Mainīt mājasserveri", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "youJoinedTheChat": "Tu pievienojies tērzēšanai", + "wallpaper": "Ekrāntapete:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Atvērt kameru video uzņemšanai", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "play": "Atskaņot {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "chatBackupDescription": "Ziņas ir aizsargātas ar atkopes atslēgu. Lūgums nodrošināt, ka tā netiek pazaudēta.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Mainīt ierīces nosaukumu", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Aizmirsta parole", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Kā Tev šodien klājas?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "security": "Drošība", + "@security": { + "type": "String", + "placeholders": {} + }, + "markAsRead": "Atzīmēt kā lasītu", + "sendAudio": "Nosūtīt skaņu", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "widgetName": "Nosaukums", + "sentASticker": "😊 {username} nosūtīja uzlīmi", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "errorAddingWidget": "Kļūda logrīka pievienošanā.", + "commandHint_dm": "Uzsākt tiešu tērzēšanu\nLai atspējotu šifrēšanu, jāizmanto --no-encryption", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_hug": "Nosūtīt apskāvienu", + "replace": "Aizstāt", + "reject": "Noraidīt", + "@reject": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Īpaši aizskarošs", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Labot liegtos serverus", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Ups! Diemžēl atgadījās kļūda pašpiegādes paziņojumu iestatīšanas laikā.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "youUnbannedUser": "Tu atcēli {user} piekļuves liegumu", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Tas atspējos Tavu lietotāja kontu. To nevar atdarīt. Vai tiešām?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "archive": "Arhīvs", + "@archive": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} pievienojās tērzēšanai", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "visibleForEveryone": "Redzama visiem", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Lūgums ievadīt 4 ciparus vai atstāt tukšu, lai atspējotu lietotnes slēgu.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "newSpace": "Jauna vieta", + "changePassword": "Nomainīt paroli", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "devices": "Ierīces", + "@devices": { + "type": "String", + "placeholders": {} + }, + "accept": "Pieņemt", + "@accept": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Nezināms notikums '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "emojis": "Emocijzīmes", + "pleaseEnterYourPin": "Lūgums ievadīt savu PIN", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Lūgums izvēlēties", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "share": "Kopīgot", + "@share": { + "type": "String", + "placeholders": {} + }, + "commandHint_googly": "Nosūtīt izbolītu acu pāri", + "pleaseTryAgainLaterOrChooseDifferentServer": "Lūgums vēlāk mēģināt vēlreiz vai izvēlēties citu serveri.", + "createGroup": "Izveidot kopu", + "privacy": "Privātums", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Mainīt savu attēlu", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Nosūtīt attēlu", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "hydrateTorLong": "Vai sesija pēdējoreiz tika izgūta TOR? Ātri ievieto to un turpini tērzēšanu!", + "time": "Laiks", + "enterYourHomeserver": "Jāievada mājasserveris", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Robotprogrammatūras ziņām", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Par saturu tika ziņos servera pārvaldītājiem", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "custom": "Pielāgots", + "noBackupWarning": "Uzmanību! Bez tērzēšanu rezerves kopiju veidošanas iespējošanas tiks zaudēta piekļuve savām šifrētajām ziņām. Ir ļoti ieteicams iespējot tērzēšanu rezerves kopiju veidošanu pirms atteikšanās.", + "fromJoining": "No pievienošanās", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "verify": "Apliecināt", + "@verify": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Nosūtīt video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "storeInSecureStorageDescription": "Glabāt atkopes atslēgu šīs ierīces drošajā krātuvē.", + "openChat": "Atvērt tērzēšanu", + "kickUserDescription": "Lietotājs ir izmests no tērzēšanas, bet piekļuve nav liegta. Publiskās tērzēšanās lietotājs var atkārtoti pievienoties jebkurā laikā.", + "sendAMessage": "Nosūtīt ziņu", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "pin": "PIN", + "@pin": { + "type": "String", + "placeholders": {} + }, + "importNow": "Ievietot tagad", + "deleteAccount": "Izdzēst kontu", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Iestatīt uzaicinājumu saiti", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "pinMessage": "Piespraust istabai", + "screenSharingDetail": "Tu kopīgo savu ekrānu FluffyChat", + "muteChat": "Apklusināt tērzēšanu", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "invite": "Uzaicināt", + "enableMultiAccounts": "(BETA) Iespējot vairākus kontus šajā ierīcē", + "anyoneCanJoin": "Ikviens var pievienoties", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Emociju pakas istabai", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "indexedDbErrorTitle": "Privātā režīma nebūšanas", + "endedTheCall": "{senderName} beidza zvanu", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "appLockDescription": "Aizslēgt lietotni, kad tā netiek izmantota, ar PIN kodu", + "globalChatId": "Vispārējais tērzēšanas Id", + "accessAndVisibilityDescription": "Kam ir ļauts pievienoties šai tērzēšanai un kā tērzēšana var tikt atklāta.", + "customEmojisAndStickers": "Pielāgotas emocijzīmes un uzlīmes", + "customEmojisAndStickersBody": "Pievienot vai kopīgot pielāgotas emocijzīmes vai uzlīmes, kas var tikt izmantotas jebkurā tērzēšanā.", + "hideInvalidOrUnknownMessageFormats": "Paslēpt nederīgus vai nezināmus ziņu formātus", + "blockUsername": "Neņemt vērā lietotājvārdu", + "accessAndVisibility": "Piekļuve un redzamība", + "calls": "Zvani", + "hideRedactedMessages": "Paslēpt labošanas ziņas", + "hideRedactedMessagesBody": "Ja kāds labo ziņu, tā vairs nebūs redzama tērzēšanā.", + "blockListDescription": "Ir iespējams atslēgt traucējošus lietotājus. Nebūs iespējams saņem jebkādas ziņas vai uzaicinājumus uz istabām no lietotājiem, kas ir personīgajā izslēgšanas sarakstā.", + "hideMemberChangesInPublicChatsBody": "Nerādīt tērzēšanas plūsmā, ja kāds pievienojas publiskai tērzēšanai vai pamet to, lai uzlabotu lasāmību.", + "overview": "Pārskats", + "notifyMeFor": "Paziņot man par", + "wrongRecoveryKey": "Atvaino... Nešķiet, ka šī būtu pareiza atkopes atslēga.", + "block": "Izslēgt", + "hideMemberChangesInPublicChats": "Paslēpt dalībnieku izmaiņas publiskajās tērzēšanās", + "passwordRecoverySettings": "Paroles atkopes iestatījumi", + "blockedUsers": "Atslēgtie lietotāji", + "transparent": "Caurspīdīgs", + "searchForUsers": "Meklēt @lietotājus...", + "pleaseEnterYourCurrentPassword": "Lūgums ievadīt savu pašreizējo paroli", + "publicSpaces": "Publiskas vietas", + "decline": "Atteikt", + "joinSpace": "Pievienoties vietai", + "createGroupAndInviteUsers": "Izveidot kopu un uzaicināt lietotājus", + "groupCanBeFoundViaSearch": "Kopu var atrast meklēšanā", + "commandHint_sendraw": "Nosūtīt neapstrādātu JSON", + "newPassword": "Jauna parole", + "forwardMessageTo": "Pārsūtīt ziņu uz {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Nosūtīt lasīšanas atskaites", + "verifyOtherUser": "🔐 Apliecināt otru lietotāju", + "verifyOtherDevice": "🔐 Apliecināt otru ierīci", + "yourGlobalUserIdIs": "Vispārējais lietotāja Id ir: ", + "select": "Atlasīt", + "initAppError": "Atgadījās kļūda lietotnes sāknēšanas laikā", + "formattedMessages": "Formatētas ziņas", + "canceledKeyVerification": "{sender} atcēla atslēgas apliecināšanu", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} pabeidza atslēgas apliecināšanu", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} pieprasīja atslēgas apliecināšanu", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} uzsāka atslēgas apliecināšanu", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "incomingMessages": "Ienākošās ziņas", + "isReadyForKeyVerification": "{sender} ir gatavs atslēgas apliecināšanai", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "commandHint_unignore": "Atcelt norādītā Matrix Id neņemšanu vērā", + "commandHint_ignore": "Neņemt vērā norādīto Matrix Id", + "searchChatsRooms": "Meklēt #tērzēšanas, @lietotājus...", + "groupName": "Kopas nosaukums", + "presenceStyle": "Klātesamība:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "youInvitedToBy": "📩 Tu tiki uzaicināts ar saiti:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "userWouldLikeToChangeTheChat": "{user} vēlas pievienoties tērzēšanai.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Vēl nav izveidota neviena publiska saite", + "knock": "Pieklauvēt", + "stickers": "Uzlīmes", + "usersMustKnock": "Lietotājiem jāpieklauvē", + "noOneCanJoin": "Neviens nevar pievienoties", + "hidePresences": "Paslēpt stāvokļu sarakstu?", + "knocking": "Klauvē", + "chatCanBeDiscoveredViaSearchOnServer": "Tērzēšana var tikt atklāta ar meklēšanu {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "nothingFound": "Nekas netika atrasts...", + "startConversation": "Uzsākt sarunu", + "databaseMigrationTitle": "Datubāze ir optimizēta", + "leaveEmptyToClearStatus": "Atstāt tukšu, lai notīrītu savu stāvokli.", + "pleaseChooseAStrongPassword": "Lūgums izvēlēties spēcīgu paroli", + "passwordIsWrong": "Ievadītā parole ir nepareiza", + "publicLink": "Publiska saite", + "thisDevice": "Šī ierīce:", + "acceptedKeyVerification": "{sender} apstiprināja atslēgas apliecināšanu", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "userRole": "Lietotāja loma", + "noDatabaseEncryption": "Šajā platformā datubāzes šifrēšana netiek nodrošināta", + "presencesToggle": "Rādīt citu lietotāju stāvokļa ziņas", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "databaseMigrationBody": "Lūgums uzgaidīt. Tas var aizņemt kādu brīdi.", + "passwordsDoNotMatch": "Paroles nesakrīt", + "publicChatAddresses": "Publiskas tērzēšanas adreses", + "createNewAddress": "Izveidot jaunu adresi", + "minimumPowerLevel": "{level} ir zemākais spēka līmenis.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "discover": "Atklāt", + "unreadChatsInApp": "{appname}: {unread} nelasītas tērzēšanas", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "subspace": "Apakšvieta", + "addChatOrSubSpace": "Pievienot tērzēšanu vai apakšvietu", + "formattedMessagesDescription": "Attēlot bagātinātu ziņu saturu, piemēram, ar Markdown iezīmētu treknrakstu.", + "databaseBuildErrorBody": "Nebija iespējams izveidot SQlite datubāzi. Lietotne pagaidām mēģina izmantot iepriekšējo datubāzi. Lūgums ziņot par šo kļūdu izstrādātājiem {url}. Kļūdas ziņojums ir: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Sesija ir zaudēta. Lūgums ziņot par šo kļūdu izstrādātājiem {url}. Kļūdas ziņojums ir: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "verifyOtherUserDescription": "Ar cita lietotāja apliecināšanu vari pārliecināties, ka zini, kam Tu tiešām raksti. 💪\n\nKad uzsāc apliecināšanu, Tu un otrs lietotājs lietotnē redzēs uznirstošo logu. Tajā jūs redzēsiet dažādas emocijzīmes vai skaitļus, kas ir jāsalīdzina savā starpā.\n\nLabākais veids, kā to izdarīt, ir satikties vai uzsākt videozvanu. 👭", + "sendTypingNotificationsDescription": "Citi tērzēšanas dalībnieki var redzēt, kad raksti jaunu ziņu.", + "noUsersFoundWithQuery": "Diemžēl ar \"{query}\" netika atrasts neviens lietotājs. Lūgums pārbaudīt, vai ir pieļauta drukas kļūda.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "restoreSessionBody": "Lietotne tagad mēģina atjaunot sesiju no rezerves kopijas. Lūgums ziņot par šo kļūdu izstrādātājiem {url}. Kļūdas ziņojums ir: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "Citi tērzēšanas dalībnieki var redzēt, kad izlasīji ziņu.", + "thereAreCountUsersBlocked": "Šobrīd ir izslēgti {count} lietotāji.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "verifyOtherDeviceDescription": "Kad apliecini citu ierīci, šīs ierīces var apmainīt atslēgas, palielinot vispārējo drošību. 💪 Pēc apliecināšanas uzsākšanas abās ierīcēs lietotnē parādīsies uznirstošais logs. Tajā būs redzamas dažādas emocijzīmes vai skaitļi, kas jāsalīdzina abās ierīcēs. Vislabāk, ja abas ierīces ir pieejamas, pirms tiek uzsākta apliecināšana. 🤳", + "swipeRightToLeftToReply": "Pavilkt no labās puses uz kreiso, lai atbildētu", + "searchIn": "Meklēt tērzēšanā \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Meklēt vairāk...", + "gallery": "Galerija", + "files": "Datnes", + "restricted": "Ierobežots", + "knockRestricted": "Pieklauvēt ierobežotajiem", + "sendCanceled": "Sūtīšana atcelta", + "noChatsFoundHere": "Šeit vēl nav tērzēšanu. Jauna saruna ar kādu ir uzsākama ar zemāk esošo pogu. ⤵️", + "invitedBy": "📩 {user} uzaicināja", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "moderatorLevel": "{level} - Moderators", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Pārvaldītājs", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheVisibilityOfChatHistory": "Mainīt tērzēšanas vēstures redzamību", + "changeTheCanonicalRoomAlias": "Mainīt tērzēšanas galveno publisko adresi", + "sendRoomNotifications": "Sūtīt @istaba paziņojumus", + "changeTheDescriptionOfTheGroup": "Mainīt tērzēšanas aprakstu", + "alwaysUse24HourFormat": "nē", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "userLevel": "{level} - Lietotājs", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "goToSpace": "Doties uz vietu: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "changeGeneralChatSettings": "Mainīt vispārējos tērzēšanas iestatījumus", + "inviteOtherUsers": "Uzaicināt šajā tērzēšanā citus lietotājus", + "changeTheChatPermissions": "Mainīt tērzēšanas atļaujas", + "chatPermissionsDescription": "Noteikt, kurš spēka līmenis ir nepieciešams noteiktām darbībām šajā tērzēšanā. Spēka līmeņi 0, 50 un 100 parasti atbilst lietotājiem, moderatoriem un pārvaldītājiem, bet ir iespējams jebkāds iedalījums.", + "doesNotSeemToBeAValidHomeserver": "Neizskatās pēc saderīga mājasservera. Nepareizs URL?", + "loginWithMatrixId": "Pieteikties ar Matrix-Id", + "discoverHomeservers": "Atklāt mājasserverus", + "whatIsAHomeserver": "Kas ir mājasserveris?", + "homeserverDescription": "Visi lietotāja dati tiek glabāti mājasserverī, gluži kā ar e-pasta nodrošinātāju. Ir iespējams izvēlēties, kuru mājasserveri izmantot, saglabājot iespēju sazināties ar ikvienu. Vairāk var uzzināt https://matrix.org.", + "updateInstalled": "🎉 Atjauninājums {version} uzstādīts.", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Izmaiņu žurnāls", + "countChatsAndCountParticipants": "{chats} tērzēšanas un {participants} dalībnieki", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Vairs netika atrasta neviena tērzēšana...", + "joinedChats": "Tērzēšanas, kurās piedalos", + "unread": "Nelasītas", + "space": "Vieta", + "spaces": "Vietas", + "markAsUnread": "Atzīmēt kā nelasītu", + "sendingAttachment": "Nosūta pielikumu...", + "generatingVideoThumbnail": "Izveido video sīktēlu...", + "sendingAttachmentCountOfCount": "Nosūta {index}. pielikumu no {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Sasniegts servera ierobežojums. Gaida {seconds} sekundes...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "calculatingFileSize": "Aprēķina datnes lielumu...", + "prepareSendingAttachment": "Sagatavo pielikuma nosūtīšanu...", + "compressVideo": "Saspiež video...", + "oneOfYourDevicesIsNotVerified": "Viena no ierīcēm nav apliecināta", + "noticeChatBackupDeviceVerification": "Piezīme: kad visas ierīces tiek savienotas ar tērzēšanu rezerves kopiju, tās tiek automātiski apliecinātas.", + "continueText": "Turpināt", + "welcomeText": "Sveicieni! 👋 Šis ir FluffyChat. Tu vari pieteikties jebkurā mājasserverī, kas ir saderīgs ar https://matrix.org. Tad vari tērzēt ar ikvienu. Tas ir milzīgs decentralizētās saziņas tīkls.", + "blur": "Aizmiglojums:", + "setWallpaper": "Iestatīt ekrāntapeti", + "opacity": "Necaurredzamība:", + "manageAccount": "Pārvaldīt kontu", + "noContactInformationProvided": "Serveris nesniedz nekādu derīgu saziņas informāciju", + "serverInformation": "Informācija par serveri:", + "aboutHomeserver": "Par {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "contactServerAdmin": "Sazināties ar servera pārvaldītāju", + "contactServerSecurity": "Sazināties ar servera drošības uzturētājiem", + "supportPage": "Atbalsta lapa", + "name": "Nosaukums", + "version": "Versija", + "website": "Tīmekļvietne", + "boldText": "Teksts treknrakstā", + "strikeThrough": "Pārsvītrots", + "invalidUrl": "Nederīgs URL", + "addLink": "Pievienot saiti", + "italicText": "Teksts slīprakstā", + "pleaseFillOut": "Lūgums aizpildīt", + "sendImages": "Nosūtīt {count} attēlu(s)", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Saspiest", + "unableToJoinChat": "Nevarēja pievienoties tērzēšanai. Varbūt otra puse jau ir aizvērusi sarunu.", + "appWantsToUseForLoginDescription": "Ar šo tiek ļauts lietotnei un tīmekļvietnei kopīgot informāciju par Tevi.", + "appIntroduction": "FluffyChat ļauj tērzēt ar draugiem, kuri izmanto dažādas ziņojumapmaiņas lietotnes. Vairāk var uzzināt https://matrix.org vai vienkārši piesitot *Turpināt*.", + "synchronizingPleaseWaitCounter": " Sinhronizē... ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "previous": "Iepriekšējais", + "otherPartyNotLoggedIn": "Otra puse pašlaik nav pieteikusies un tādēļ nevar saņemt ziņas.", + "appWantsToUseForLogin": "Izmantot '{server}', lai pieteiktos", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "open": "Atvērt", + "waitingForServer": "Gaida serveri...", + "notificationRuleContainsDisplayNameDescription": "Paziņo lietotājam, kad ziņa satur viņa attēlojamo vārdu.", + "notificationRuleServerAcl": "Apspiest servera ACL notikumus", + "notificationRuleSuppressNoticesDescription": "Apspiež paziņojumus no automatizētiem klientiem, piemēram, robotprogrammatūras.", + "notificationRuleInviteForMeDescription": "Paziņo lietotājam, kad viņš ir uzaicināts pievienoties istabai.", + "generalNotificationSettings": "Vispārēji paziņojumu iestatījumi", + "otherNotificationSettings": "Citi paziņojumu iestatījumi", + "notificationRuleContainsUserName": "Saturs lietotāja vārdu", + "notificationRuleMasterDescription": "Aizvieto visas pārējās kārtulas un atspējo visus paziņojumus.", + "notificationRuleInviteForMe": "Uzaicinājums man", + "notificationRuleMemberEvent": "Dalībnieka notikums", + "notificationRuleMemberEventDescription": "Apspiež paziņojums par dalības notikumiem.", + "notificationRuleIsUserMentionDescription": "Paziņo lietotājam, kad viņš ziņā ir tieši pieminēts.", + "notificationRuleIsRoomMention": "Istabas pieminēšana", + "notificationRuleRoomnotif": "Istabas paziņojums", + "notificationRuleReaction": "Reakcija", + "notificationRuleRoomServerAcl": "Istabas servera ACL", + "notificationRuleCall": "Zvans", + "notificationRuleCallDescription": "Paziņo lietotājam par zvaniem.", + "deletePushRuleCanNotBeUndone": "Ja tiek izdzēsts šis paziņojuma iestatījums, to nevar atsaukt.", + "more": "Vairāk", + "roomNotificationSettings": "Istabu paziņojumu iestatījumi", + "notificationRuleEncrypted": "Šifrēts", + "notificationRuleJitsi": "Jitsi", + "notificationRuleIsUserMention": "Lietotāja pieminēšana", + "notificationRuleIsRoomMentionDescription": "Paziņo lietotājam, kad tiek pieminēta istaba.", + "notificationRuleMessageDescription": "Paziņo lietotājam par vispārējām ziņām.", + "notificationRuleServerAclDescription": "Apspiež notikumus par servera ACL notikumiem.", + "notificationRuleReactionDescription": "Apspiež paziņojums par reakcijām.", + "unknownPushRule": "Nezināma pašpiegādes kārtula '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "newChatRequest": "📩 Jauns tērzēšanas pieprasījums", + "notificationRuleContainsUserNameDescription": "Paziņo lietotājam, kad ziņa satur viņa lietotājvārdu.", + "notificationRuleRoomnotifDescription": "Paziņo lietotājam, kad ziņa satur \"@istaba\".", + "notificationRuleEncryptedRoomOneToOneDescription": "Paziņo lietotājam par ziņām šifrētās viens pret viens istabās.", + "notificationRuleRoomServerAclDescription": "Apspiež paziņojumus par istabas servera piekļuves kontroles sarakstiem (ACL).", + "contentNotificationSettings": "Satura paziņojumu iestatījumi", + "notificationRuleContainsDisplayName": "Satur attēlojamo vārdu", + "notificationRuleRoomOneToOne": "Viens pret viens istaba", + "notificationRuleJitsiDescription": "Paziņo lietotājam par Jitsi logrīka notikumiem.", + "notificationRuleSuppressEditsDescription": "Apspiež paziņojumus par labotām ziņām.", + "notificationRuleTombstone": "Kapakmens", + "notificationRuleTombstoneDescription": "Paziņo lietotājam par istabu aizvēršanas ziņām.", + "notificationRuleSuppressEdits": "Apspiest labojumus", + "notificationRuleEncryptedRoomOneToOne": "Šifrēta viens pret viens istaba", + "notificationRuleRoomOneToOneDescription": "Paziņo lietotājam par ziņām viens pret viens istabās.", + "notificationRuleMessage": "Ziņa", + "notificationRuleEncryptedDescription": "Paziņo lietotājam par ziņām šifrētās istabās.", + "userSpecificNotificationSettings": "Lietotāja paziņojumu iestatījumi", + "notificationRuleMaster": "Apklusināt visus paziņojumus", + "notificationRuleSuppressNotices": "Apspiest automātiskās ziņas", + "crossVerifiedDevices": "Savstarpēji apliecinātas ierīces", + "shareKeysWith": "Kopīgot atslēgas ar...", + "shareKeysWithDescription": "Kurām ierīcēm vajadzētu uzticēties, lai tajās varētu lasīt ziņas šifrētajās tērzēšanās?", + "allDevices": "Visas ierīces", + "crossVerifiedDevicesIfEnabled": "Savstarpēji apliecinātas ierīces, ja iespējots", + "verifiedDevicesOnly": "Tikai apliecinātas ierīces", + "optionalMessage": "(Pēc izvēles) Ziņojums...", + "takeAPhoto": "Uzņemt attēlu", + "recordAVideo": "Ierakstīt video", + "notSupportedOnThisDevice": "Šajā ierīcē nav atbalstīts", + "enterNewChat": "Ieiet jaunajā tērzēšanā", + "commandHint_roomupgrade": "Uzlabot šo istabu uz norādīto istabas versiju", + "setCustomPermissionLevel": "Iestatīt pielāgotu atļauju līmeni", + "setPermissionsLevelDescription": "Lūgums zemāk atlasīt iepriekšizveidotu lomu vai ievadīt pielāgotu atļauju līmeni starp 0 un 100.", + "ignoreUser": "Neņemt vērā lietotāju", + "normalUser": "Parasts lietotājs", + "youHaveKnocked": "Tu pieklauvēji", + "pleaseWaitUntilInvited": "Lūgums tagad uzgaidīt, līdz kāds no istabas uzaicinās Tevi.", + "approve": "Apstiprināt", + "checkList": "Pārbaužu saraksts", + "countInvited": "{count} uzaicināti", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Balss ziņa no {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "commandHint_logout": "Atteikties pašreizējā ierīcē", + "commandHint_logoutall": "Atteikties visās izmantotajās ierīcēs", + "displayNavigationRail": "Rādīt pārvietošanās sliedi viedierīcēs", + "customReaction": "Pielāgota reakcija", + "moreEvents": "Vairāk notikumu", + "declineInvitation": "Noraidīt uzaicinājumu", + "noMessagesYet": "Vēl nav ziņu", + "longPressToRecordVoiceMessage": "Ilga piespiešana, lai ierakstītu balss ziņu.", + "pause": "Apturēt", + "resume": "Atsākt", + "newSubSpace": "Jauna apakšvieta", + "moveToDifferentSpace": "Pārvietot uz citu vietu", + "moveUp": "Pārvietot augšup", + "moveDown": "Pārvietot lejup", + "removeFromSpaceDescription": "Tērzēšana tiks noņemta no vietas, bet tā joprojām būs redzama tērzēšanu sarakstā.", + "countChats": "{chats} tērzēšanas", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "{spaces} dalībnieks", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "{spaces} dalībnieks var pieklauvēt", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Ziedot", + "startedAPoll": "{username} uzsāka aptauju.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Aptauja", + "startPoll": "Sākt aptauju", + "endPoll": "Noslēgt aptauju", + "answersVisible": "Atbildes ir redzamas", + "answersHidden": "Atbildes ir paslēptas", + "pollQuestion": "Aptaujas jautājums", + "answerOption": "Atbildes iespēja", + "addAnswerOption": "Pievienot atbildes iespēju", + "allowMultipleAnswers": "Atļaut vairākas atbildes", + "pollHasBeenEnded": "Aptauja ir noslēgusies", + "countVotes": "{count, plural, =0{{count} balsu} =1{{count} balss} other{{count} balsis}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Atbildes būs redzams, kad aptauja noslēgsies", + "replyInThread": "Atbildēt pavedienā", + "countReplies": "{count, plural, =0{{count} atbilžu} =1{{count} atbilde} other{{count} atbildes}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Pavediens", + "backToMainChat": "Atgriezties galvenajā tērzēšanā", + "saveChanges": "Saglabāt izmaiņas", + "createSticker": "Izveidot uzlīmi vai emocijzīmi", + "useAsSticker": "Izmantot kā uzlīmi", + "useAsEmoji": "Izmantot kā emocijzīmi", + "stickerPackNameAlreadyExists": "Uzlīmju pakas nosaukums jau pastāv", + "newStickerPack": "Jauna uzlīmju paka", + "stickerPackName": "Uzlīmju pakas nosaukums", + "attribution": "Piedēvējums", + "skipChatBackup": "Izlaist tērzēšanu rezerves kopēšanu", + "skipChatBackupWarning": "Vai tiešām? Bez tērzēšanu rezerves kopēšanas var tikt zaudēta piekļuve savām ziņām, kad tiks mainīta ierīce.", + "loadingMessages": "Ielādē ziņas", + "setupChatBackup": "Iestatīt tērzēšanu rezerves kopēšanu", + "changedTheChatDescription": "{username} nomainīja tērzēšanas aprakstu", + "changedTheChatName": "{username} nomainīja tērzēšanas nosaukumu", + "noMoreResultsFound": "Vairs nekas netika atrasts", + "chatSearchedUntil": "Tērzēšanā meklēts līdz {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "Federācijas pamata URL", + "clientWellKnownInformation": "Client-Well-Known informācija:", + "baseUrl": "Pamata URL", + "identityServer": "Identitāšu serveris:", + "versionWithNumber": "Versija: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Žurnāli", + "advancedConfigs": "Izvērsta konfigurācijas", + "advancedConfigurations": "Izvērstas konfigurācijas", + "signInWithLabel": "Pieteikties ar:", + "theProcessWasCanceled": "Darbība tika atcelta.", + "signIn": "Pieteikties", + "createNewAccount": "Izveidot jaunu kontu", + "signUpGreeting": "FluffyChat ir decentralizēta. Jāatlasa serveris, kurā ir vēlēšanās izveidot savu kontu, un aiziet!", + "signInGreeting": "Jau ir Matrix konts? Laipni lūdzam atpakaļ! Jāatlasa savs mājasserveris un jāpiesakās.", + "appIntro": "Ar FluffyChat vari tērzēt ar saviem draugiem. Tā ir droša un decentralizēta [matrix] ziņapmaiņas lietotne. Vairāk var uzzināt https://matrix.org, ja ir vēlēšanās, vai vienkārši jāpiesakās." +} diff --git a/lib/l10n/intl_nb.arb b/lib/l10n/intl_nb.arb new file mode 100644 index 000000000..863b667b9 --- /dev/null +++ b/lib/l10n/intl_nb.arb @@ -0,0 +1,3166 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.967351", + "about": "Om", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Godta", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} godtok invitasjonen", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Konto", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "{username} skrudde på ende-til-ende -kryptering", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Administrator", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Alle", + "@all": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} besvarte anropet", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Hvem som helst kan delta", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Programlås", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arkiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Kan gjester bli med?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Er du sikker?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Er du sikker på at du vil logge ut?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "For å kunne signere den andre personen, skriv inn ditt sikre lagerpassord eller gjenopprettingsnøkkel.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Godta denne bekreftelsesforespørselen fra {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banFromChat": "Bannlys fra sludring", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Bannlyst", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} bannlyste {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blokker enhet", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot-meldinger", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Avbryt", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Endre enhetsnavn", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} endret sludreavatar", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} endret chatbeskrivelsen til: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} endret chatnavnet til: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} endret sludretilgangene", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} endret visningsnavn til: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} endret gjestetilgangsreglene", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} endret gjestetilgangsregler til: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} endret historikksynlighet", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} endret historikksynlighet til: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} endret tilgangsreglene", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} endret tilgangsreglene til: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} endret avataren sin", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} endret rom-aliasene", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} endret invitasjonslenken", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Endre passord", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Endre hjemmetjener", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Endre din stil", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Endre gruppens navn", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Krypteringen er skadet", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Sludring", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Sludringssikkerhetskopi", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Meldingene dine er sikret med en gjenopprettingsnøkkel. Pass på at du ikke mister den.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Sludringsdetaljer", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Velg et sterkt passord", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Lukk", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Sammenlign og forsikre at følgende emojiene samsvarer med de på den andre enheten", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Sammenlign og forsikre at følgende tall samsvarer med de på den andre enheten", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Sett opp sludring", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Bekreft", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Koble til", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt invitert til gruppen", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Inneholder visningsnavn", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Inneholder brukernavn", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Innholdet har blitt rapportert til tjeneradministratorene", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Kopiert til utklippstavle", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopier", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopier til utklippstavle", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Kunne ikke dekryptere melding: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} deltagere", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Opprett", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "{username} opprettet sludringen", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Aktiv nå", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Mørk", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{timeOfDay}, {date}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day} {month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day} {month} {year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Dette vil skru av din brukerkonto for godt, og kan ikke angres! Er du sikker?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Forvalgt tilgangsnivå", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Slett", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Slett konto", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Slett melding", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Enhet", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Enhets-ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Enheter", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Direktesludringer", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Visningsnavn endret", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Last ned fil", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Rediger", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Rediger blokkerte tjenere", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Rediger visningsnavn", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Rediger romavatar", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Smilefjeset finnes allerede!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Ugyldig smilefjes-kode!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Smilefjespakker for rommet", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Smilefjes-innstillinger", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Smilefjes-kode", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Du må velge en smilefjes-kode og et bilde!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Tom sludring", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Skru på smilefjespakke for hele programmet", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Skru på kryptering", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Du vil ikke kunne skru av kryptering lenger. Er du sikker?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Kryptert", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Kryptering", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Kryptering er ikke påskrudd", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} avsluttet samtalen", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Skriv inn en e-postadresse", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Skriv inn din hjemmetjener", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Alt er klart!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Veldig", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Filnavn", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Skriftstørrelse", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Videre", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Fra å ta del", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Fra invitasjonen", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Gruppe", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Gruppen er offentlig", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Grupper", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Gruppe med {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Gjester forbudt", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Gjester kan ta del", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} har trukket tilbake invitasjonen til {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Hjelp", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Skjul tilbaketrukne hendelser", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Skjul ukjente hendelser", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Hvor støtende er innholdet?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identitet", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorer", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Ignorerte brukere", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Jeg har klikket på lenken", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Feilaktig passord eller gjenopprettingsnøkkel", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Harmløst", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Inviter kontakt", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Inviter kontakt til {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Invitert", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "{username} inviterte {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Kun inviterte brukere", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Invitasjon for meg", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} har invitert deg til FluffyChat. \n1. Installer FluffyChat: https://fluffychat.im \n2. Registrer deg eller logg inn \n3. Åpne invitasjonslenken: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "skriver…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "{username}ble med i samtalen", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Ta del i rom", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "{username} kastet ut {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "{username} kastet ut og bannlyste {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Kast ut av sludringen", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Sist aktiv: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Forlat", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Forlat sludringen", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Lisens", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Lys", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Last inn {count} deltagere til", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Laster inn… Vent.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Last inn mer…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Logg inn", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Logg inn på {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Logg ut", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Medlemsendringer", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Nevn", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Meldinger", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Forstum sludring", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Merk at du trenger Pantalaimon for å bruke ende-til-ende -kryptering inntil videre.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Ny sludring", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "Ny melding i FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Ny bekreftelsesforespørsel!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Neste", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Nei", + "@no": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Fant ingen smilefjes. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Firebase Cloud Messaging ser ikke ut til å være tilgjengelig på enheten din. For å fortsatt kunne motta push-varsler, anbefaler vi at du installerer ntfy. Med ntfy eller en annen UnifiedPush-leverandør kan du motta push-varsler på en datasikker måte. Du kan laste ned ntfy fra Play Store eller F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Ingen", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Du har ikke lagt til en måte å gjenopprette passordet ditt på.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Ingen tilgang", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Fant ingen rom …", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Merknader", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Merknader påslått for denne kontoen", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} brukere skriver …", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offensive": "Støtende", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Frakoblet", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Pålogget", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Nettbasert sikkerhetskopiering av nøkler på", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Oida, noe gikk galt …", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Åpne programmet for å lese meldinger", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Åpne kamera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "participant": "Deltager", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "Passord eller gjenopprettingsnøkkel", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Passord", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Passord glemt", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Passord endret", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Passordgjenoppretting", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Velg bilde", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Fest", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Spill av {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseClickOnLink": "Klikk på lenken i e-posten og fortsett.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Skriv inn passordet ditt", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Skriv inn brukernavnet ditt", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Følg instruksen på nettsiden og trykk på «Neste».", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Personvern", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Offentlige rom", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Dyttingsregler", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Grunn", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Opptak", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} har trukket tilbake en hendelse", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Avslå", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} avslo invitasjonen", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Ta del igjen", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Fjern", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Fjern alle andre enheter", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Fjernet av {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Fjern enhet", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Opphev bannlysning", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Erstatt rom med nyere versjon", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Svar", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Rapporter melding", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Forespør tilgang", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Rommet har blitt oppgradert", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "search": "Søk", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Sikkerhet", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Sett av {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Send", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Send en melding", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Send lyd", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Send fil", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Send bilde", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Send meldinger", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Send original", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Send video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "{username} sendte en fil", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "{username} sendte lyd", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "{username} sendte et bilde", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "{username} sendte et klistremerke", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "{username} sendte en video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} sendte anropsinfo", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setCustomEmotes": "Sett tilpassede smilefjes", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Sett invitasjonslenke", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Sett tilgangsnivå", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Angi status", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Innstilinger", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Del", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} delte posisjonen", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "skip": "Hopp over", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Kildekode", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} startet en samtale", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Status", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Hvordan har du det i dag?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Send inn", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "System", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Samsvarer ikke", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Samsvarer", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "For mange forespørsler. Prøv igjen senere!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Overfør fra en annen enhet", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Prøv å sende igjen", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Utilgjengelig", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} opphevet bannlysning av {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Opphev blokkering av enhet", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Ukjent enhet", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Ukjent krypteringsalgoritme", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Ukjent hendelse '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Opphev forstumming av sludring", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Løsne", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, other{{unreadCount} uleste sludringer}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} og {count} andre skriver…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} og {username2} skriver…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} skriver…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "{username} har forlatt sludringen", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Brukernavn", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} sendte en {type}-hendelse", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "Bekreft", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Start bekreftelse", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Du har bekreftet!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Bekrefter annen konto", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videosamtale", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Sludrehistorikkens synlighet", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Synlig for alle deltagere", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Synlig for alle", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Lydmelding", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Venter på at samtalepartner skal godta tallene …", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Bakgrunnsbilde:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Advarsel!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Du har fått en e-post", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Hvem kan utføre hvilken handling", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Hvem tillates å ta del i denne gruppen", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Hvorfor ønsker du å rapportere dette?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Med disse adressene kan du gjenopprette passordet ditt hvis du trenger det.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Skriv en melding …", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Ja", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Deg", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Du deltar ikke lenger i denne sludringen", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Du har blitt bannlyst fra denne sludringen", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Din offentlige nøkkel", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Marker som lest/ulest", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Veksle forstumming", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Veksle favorittmerking", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Ingen tilkobling til tjeneren", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "addEmail": "Legg til e-post", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Gjenta passord", + "addToSpace": "Legg til område", + "allChats": "Alle samtaler", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "Automatisk spill av animerte stickers og emojis", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "Denne hjemme serveren støtter følgende innloggings-typer:\n{serverVersions}\nMen denne applikasjonen støtter kun:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendOnEnter": "Trykk på enter for å sende", + "badServerVersionsException": "Hjemmeserveren støtter følgene Spec-versjoner:\n{serverVersions}\nMen applikasjonen støtter kun {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "blocked": "Blokkert", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Kan ikke åpne URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeYourAvatar": "Bytt profilbilde", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "notAnImage": "Ikke en bildefil.", + "importNow": "Importer nå", + "hugContent": "{senderName} klemmer deg", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "space": "Område", + "spaces": "Områder", + "cuddleContent": "{senderName} koser med deg", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "appLockDescription": "Lås appen med en PIN-kode når den ikke er i bruk", + "ignoreUser": "Ignorer bruker", + "setCustomPermissionLevel": "Angi egendefinert tillatelsesnivå", + "normalUser": "Vanlig bruker", + "replace": "Erstatt", + "noMoreChatsFound": "Ingen flere chatter funnet ...", + "confirmMatrixId": "Bekreft Matrix-IDen din for å slette kontoen din.", + "unread": "Ulest", + "aboutHomeserver": "Om {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "commandHint_hug": "Send en klem", + "markAsRead": "Marker som lest", + "openLinkInBrowser": "Åpne lenke i nettleser", + "start": "Start", + "passwordsDoNotMatch": "Passordene stemmer ikke overens", + "decline": "Avslå", + "emailOrUsername": "E-post eller brukernavn", + "encryptThisChat": "Krypter denne chatten", + "nextAccount": "Neste konto", + "doNotShowAgain": "Ikke vis igjen", + "notificationRuleContainsUserName": "Inneholder brukernavn", + "notificationRuleMaster": "Demp alle varslinger", + "presenceStyle": "Tilstedeværelse:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "verified": "Verifisert", + "@verified": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Lagre fil", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "Gjenopprettingsnøkkel", + "sendSticker": "Send sticker", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Del lokasjon", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Vis passord", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synkroniserer … Vent litt.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "dismiss": "Avvis", + "openChat": "Åpne chat", + "addWidget": "Legg til widget", + "reopenChat": "Gjenåpne chat", + "changeTheDescriptionOfTheGroup": "Endre beskrivelsen til chatten", + "inviteOtherUsers": "Inviter andre brukere til denne chatten", + "open": "Åpne", + "waitingForServer": "Venter på server...", + "notificationRuleJitsi": "Jitsi", + "takeAPhoto": "Ta et bilde", + "setChatDescription": "Sett chat beskrivelse", + "singlesignon": "Single Sign on (SSO)", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "openGallery": "Åpne galleri", + "widgetCustom": "Egendefinert", + "widgetVideo": "Video", + "pushNotificationsNotAvailable": "Push-varsler er ikke tilgjengelige", + "gallery": "Galleri", + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Admin", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "restricted": "Begrenset", + "updateInstalled": "🎉 Oppdatering {version} installert!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "calculatingFileSize": "Beregner filstørrelse...", + "continueText": "Fortsett", + "serverInformation": "Serverinformasjon:", + "previous": "Forrige", + "name": "Navn", + "version": "Versjon", + "invalidUrl": "Ugyldig url", + "notificationRuleReaction": "Reaksjon", + "notificationRuleMessage": "Melding", + "notificationRuleEncrypted": "Kkryptert", + "more": "Mer", + "passwordIsWrong": "Det inntastede passordet ditt er feil", + "startConversation": "Start samtale", + "manageAccount": "Administrer konto", + "nothingFound": "Ingenting funnet...", + "incomingMessages": "Innkommende meldinger", + "changelog": "Endringslogg", + "contactServerAdmin": "Kontakt serveradministrator", + "setWallpaper": "Sett bakgrunnsbilde", + "unsupportedAndroidVersion": "Usupportert Android-versjon", + "widgetName": "Navn", + "youJoinedTheChat": "Du har blitt med i chatten", + "widgetJitsi": "Jitsi Meet", + "widgetNameError": "Vennligst oppgi et visningsnavn.", + "youRejectedTheInvitation": "Du har avvist invitasjonen", + "formattedMessages": "Formaterte meldinger", + "allDevices": "Alle enheter", + "learnMore": "Lær mer", + "sorryThatsNotPossible": "Beklager... det er ikke mulig", + "markAsUnread": "Marker som ulest", + "newGroup": "Ny gruppe", + "userRole": "Brukerrolle", + "addLink": "Legg til lenke", + "synchronizingPleaseWaitCounter": " Synkroniserer… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "unverified": "Ikke verifisert", + "thisDevice": "Denne enheten:", + "sendingAttachment": "Sender vedlegg...", + "removeYourAvatar": "Fjern din avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "importFromZipFile": "Importer fra .zip-fil", + "select": "Velg", + "databaseMigrationTitle": "Databasen er optimalisert", + "newPassword": "Nytt passord", + "files": "Filer", + "searchIn": "Søk i chatten «{chat}»...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "approve": "Godkjenn", + "goToSpace": "Gå til område: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "userLevel": "{level} - Bruker", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "En av dine enheter er ikke verifisert", + "website": "Nettside", + "boldText": "Fet skrift", + "pleaseFillOut": "Vennligst fyll ut", + "importEmojis": "Importer emojier", + "supposedMxid": "Denne bør være {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "Legg til chat beskrivelse...", + "commandHint_roomupgrade": "Oppgrader dette rommet til den gitte romversjonen", + "hideMemberChangesInPublicChatsBody": "Ikke vis i chattens tidslinje hvis noen blir med i eller forlater en offentlig chat for økt lesbarhet.", + "overview": "Oversikt", + "notifyMeFor": "Varsle meg om", + "passwordRecoverySettings": "Innstillinger for gjenoppretting av passord", + "people": "Folk", + "@people": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Vennligst velg", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Vennligst velg en passordkode", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Skriv inn fire sifre eller la feltet stå tomt for å deaktivere applåsen.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKey": "Vennligst skriv inn gjenopprettingsnøkkelen din:", + "pleaseEnterYourPin": "Oppgi din PIN-kode", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "Global chat-ID", + "allRooms": "Alle gruppechatter", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "Chat tillatelser", + "setPermissionsLevelDescription": "Vennligst velg en forhåndsdefinert rolle nedenfor eller skriv inn et tilpasset tillatelsesnivå mellom 0 og 100.", + "commandHint_invite": "Inviter den gitte brukeren til dette rommet", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Bli med i det gitte rommet", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "chats": "Chatter", + "@chats": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Sikkerhetskopien av chatten din er konfigurert.", + "discover": "Oppdag", + "thereAreCountUsersBlocked": "Akkurat nå er det {count} blokkerte brukere.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "sendCanceled": "Sending avbrutt", + "loginWithMatrixId": "Logg på med Matrix ID", + "discoverHomeservers": "Oppdag hjemmeservere", + "shareInviteLink": "Del invitasjonslenke", + "scanQrCode": "Skann QR-kode", + "messagesStyle": "Meldinger:", + "hydrate": "Gjenopprett fra sikkerhetskopifil", + "oneClientLoggedOut": "En av klientene dine har blitt logget ut", + "addAccount": "Legg til konto", + "enableMultiAccounts": "(BETA) Aktiver flere kontoer på denne enheten", + "openInMaps": "Åpne i kart", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "link": "Lenke", + "serverRequiresEmail": "Denne serveren må validere e-postadressen din for registrering.", + "or": "Eller", + "@or": { + "type": "String", + "placeholders": {} + }, + "previousAccount": "Forrige konto", + "widgetUrlError": "Dette er ikke en gyldig URL.", + "custom": "Egendefinert", + "user": "Bruker", + "users": "Brukere", + "countInvited": "{count} inviterte", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "createGroup": "Opprett gruppe", + "editRoomAliases": "Rediger rom aliaser", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "accessAndVisibility": "Tilgang og synlighet", + "hideInvalidOrUnknownMessageFormats": "Skjul ugyldige eller ukjente meldingsformater", + "block": "Blokkér", + "blockedUsers": "Blokkerte brukere", + "tryAgain": "Prøv igjen", + "invalidServerName": "Ugyldig servernavn", + "messageInfo": "Meldingsinformasjon", + "time": "Tid", + "messageType": "Meldingstype", + "sender": "Avsender", + "publish": "Publiser", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "reportUser": "Rapporter bruker", + "youHaveWithdrawnTheInvitationFor": "Du har trukket tilbake invitasjonen for {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youAcceptedTheInvitation": "👍 Du har akseptert invitasjonen", + "youBannedUser": "Du stengte ute {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "chatDescriptionHasBeenChanged": "Chatbeskrivelsen er endret", + "goToTheNewRoom": "Gå til det nye rommet", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "screenSharingTitle": "skjermdeling", + "screenSharingDetail": "Du deler skjermen din i FuffyChat", + "callingPermissions": "Anropstillatelser", + "callingAccountDetails": "Lar FluffyChat bruke den innebygde Android-oppringingsappen.", + "appearOnTop": "Vis øverst", + "otherCallingPermissions": "Mikrofon, kamera og andre FluffyChat-tillatelser", + "whyIsThisMessageEncrypted": "Hvorfor er denne meldingen uleselig?", + "yourGlobalUserIdIs": "Din globale bruker-ID er: ", + "searchChatsRooms": "Søk etter #chatter, @brukere...", + "groupName": "Gruppenavn", + "createGroupAndInviteUsers": "Opprett en gruppe og inviter brukere", + "invite": "Inviter", + "wrongPinEntered": "Feil PIN-kode oppgitt! Prøv igjen om {seconds} sekunder...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendAsText": "Send som tekst", + "@sendAsText": { + "type": "String" + }, + "sendImages": "Send {count} bilde", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "presencesToggle": "Vis statusmeldinger fra andre brukere", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "voiceCall": "Taleanrop", + "accessAndVisibilityDescription": "Hvem som har lov til å bli med i denne chatten og hvordan chatten kan oppdages.", + "calls": "Anrop", + "customEmojisAndStickers": "Egendefinerte emojier og klistremerker", + "oopsPushError": "Oops! Dessverre oppsto det en feil under oppsettet av push-varsler.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Åpne kameraet for en video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Henter sted …", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "noDatabaseEncryption": "Databasekryptering støttes ikke på denne plattformen", + "changeGeneralChatSettings": "Endre generelle chatinnstillinger", + "changeTheChatPermissions": "Endre chattillatelsene", + "youInvitedToBy": "📩 Du har blitt invitert via lenke til:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Du har blitt invitert av {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "invitedBy": "📩 Invitert av {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Du inviterte {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 You sparket ut {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Du sparket og stengte ute {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "countFiles": "{count} filer", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noOtherDevicesFound": "Ingen andre enheter funnet", + "fileIsTooBigForServer": "Kan ikke sende! Serveren støtter bare vedlegg opptil {max}.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "Filen er lagret på {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Hopp til sist leste melding", + "serverLimitReached": "Grensen for server er nådd! Venter i {seconds} sekunder...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "blur": "Uskarphet:", + "opacity": "Ugjennomsiktighet:", + "noContactInformationProvided": "Serveren oppgir ingen gyldig kontaktinformasjon", + "supportPage": "Supportside", + "compress": "Komprimer", + "italicText": "Kursiv tekst", + "strikeThrough": "Gjennomstreking", + "youUnbannedUser": "Du opphevet utestengelsen av {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "disableEncryptionWarning": "Av sikkerhetshensyn kan du ikke deaktivere kryptering i en chat der det har vært aktivert tidligere.", + "deviceKeys": "Enhetsnøkler:", + "readUpToHere": "Lest frem til her", + "jump": "Hopp", + "reportErrorDescription": "😭 Å nei. Noe gikk galt. Hvis du ønsker det, kan du rapportere denne feilen til utviklerne.", + "invalidInput": "Ugyldig inndata!", + "pleaseEnterANumber": "Vennligst skriv inn et tall større enn 0", + "archiveRoomDescription": "Chatten vil bli flyttet til arkivet. Andre brukere vil kunne se at du har forlatt chatten.", + "removeDevicesDescription": "Du vil bli logget ut av denne enheten og vil ikke lenger kunne motta meldinger.", + "profileNotFound": "Brukeren ble ikke funnet på serveren. Kanskje det er et tilkoblingsproblem, eller brukeren finnes ikke.", + "setTheme": "Angi tema:", + "setColorTheme": "Angi fargetema:", + "inviteGroupChat": "📨 Invitasjon til gruppechat", + "invitePrivateChat": "📨 Invitasjon til privat chat", + "pleaseChooseAStrongPassword": "Vennligst velg et sterkt passord", + "publicLink": "Offentlig lenke", + "publicChatAddresses": "Offentlige chatadresser", + "createNewAddress": "Opprett ny adresse", + "initAppError": "Det oppsto en feil under oppstart av appen", + "minimumPowerLevel": "{level} er det laveste strømnivået.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "sendReadReceipts": "Send lesebekreftelser", + "searchMore": "Søk mer...", + "shareKeysWithDescription": "Hvilke enheter bør man stole på, slik at de kan lese meldingene dine i krypterte chatter?", + "crossVerifiedDevicesIfEnabled": "Kryssbekreftede enheter hvis dette er aktivert", + "crossVerifiedDevices": "Kryssverifiserte enheter", + "verifiedDevicesOnly": "Bare verifiserte enheter", + "recordAVideo": "Ta opp en video", + "optionalMessage": "(Valgfritt) melding...", + "notSupportedOnThisDevice": "Ikke støttet på denne enheten", + "enterNewChat": "Bli med i ny chat", + "pleaseWaitUntilInvited": "Vennligst vent nå, til noen fra rommet inviterer deg.", + "notificationRuleSuppressNoticesDescription": "Demper varsler fra automatiserte klienter som roboter.", + "notificationRuleInviteForMe": "Inviter for meg", + "notificationRuleInviteForMeDescription": "Varsler bruker når en blir invitert til et rom.", + "newChatRequest": "📩 Ny chatforespørsel", + "appWantsToUseForLogin": "Bruk '{server}' for å logge inn", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Du gir herved tillatelse til at appen og nettstedet deler informasjon om deg.", + "exportEmotePack": "Eksporter smilefjes som .zip-fil", + "noUsersFoundWithQuery": "Dessverre ble ingen bruker funnet med \"{query}\". Sjekk om du har skrevet feil.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "chatCanBeDiscoveredViaSearchOnServer": "Chatten kan oppdages via søket på {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "leaveEmptyToClearStatus": "La stå tomt for å slette statusen din.", + "searchForUsers": "Søk etter @brukere...", + "pleaseEnterYourCurrentPassword": "Skriv inn ditt nåværende passord", + "databaseMigrationBody": "Vent litt. Dette kan ta et øyeblikk.", + "wrongRecoveryKey": "Beklager ... dette ser ikke ut til å være riktig gjenopprettingsnøkkel.", + "declineInvitation": "Avslå invitasjon", + "restoreSessionBody": "Appen prøver nå å gjenopprette økten din fra sikkerhetskopien. Rapporter denne feilen til utviklerne på {url}. Feilmeldingen er: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Videresende melding til {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Skjul uviktige tilstandshendelser", + "hidePresences": "Skjul statuslisten?", + "signInWithPassword": "Logg inn med passord", + "pleaseTryAgainLaterOrChooseDifferentServer": "Prøv igjen senere eller velg en annen server.", + "signInWith": "Logg inn med {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "noMessagesYet": "Ingen meldinger enda", + "notificationRuleMasterDescription": "Overstyrer alle andre regler og deaktiverer alle varsler.", + "notificationRuleSuppressNotices": "Undertrykk automatiserte meldinger", + "startedKeyVerification": "{sender} startet nøkkelverifisering", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Gjennomsiktig", + "stickers": "Stickers", + "commandHint_ignore": "Ignorer den oppgitte matrix IDen", + "commandHint_unignore": "Opphev ignorering av den gitte matrix IDen", + "unreadChatsInApp": "{appname}: {unread} uleste chatter", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "changeTheVisibilityOfChatHistory": "Endre synligheten til chatloggen", + "changeTheCanonicalRoomAlias": "Endre hovedadressen til den offentlige chatten", + "sendRoomNotifications": "Send en @room varsling", + "formattedMessagesDescription": "Vis rikt meldingsinnhold som fet skrift ved hjelp av markdown.", + "verifyOtherUser": "🔐 Verifiser annen bruker", + "verifyOtherDevice": "🔐 Verifiser annen enhet", + "sendTypingNotificationsDescription": "Andre deltakere i en chat kan se når du skriver en ny melding.", + "sendReadReceiptsDescription": "Andre deltakere i en chat kan se når du har lest en melding.", + "commandHint_logout": "Logg av din nåværende enhet", + "commandHint_logoutall": "Logg ut alle aktive enheter", + "resume": "Gjenoppta", + "unknownPushRule": "Ukjent push-regel '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} – Talemelding fra {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Hvis du sletter denne varslingsinnstillingen, kan du ikke angre dette.", + "shareKeysWith": "Del nøkler med...", + "canceledKeyVerification": "{sender} avbrøt nøkkelverifisering", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} fullførte nøkkelverifisering", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} er klar for nøkkelverifisering", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} har bedt om nøkkelverifisering", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "notificationRuleEncryptedRoomOneToOne": "Kryptert rom én-til-én", + "notificationRuleEncryptedRoomOneToOneDescription": "Varsler brukeren om meldinger i krypterte en-til-en-rom.", + "notificationRuleRoomOneToOne": "Rom én-til-én", + "customEmojisAndStickersBody": "Legg til eller del tilpassede emojier eller klistremerker som kan brukes i hvilken som helst chat.", + "homeserver": "Hjemmeserver", + "errorObtainingLocation": "Feil ved henting av posisjon: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "chatDescription": "Chat beskrivelse", + "hideRedactedMessages": "Skjul redigerte meldinger", + "hideRedactedMessagesBody": "Hvis noen redigerer en melding, vil ikke denne meldingen lenger være synlig i chatten.", + "blockListDescription": "Du kan blokkere brukere som forstyrrer deg. Du vil ikke kunne motta meldinger eller rominvitasjoner fra brukerne på din personlige blokkeringsliste.", + "blockUsername": "Ignorer brukernavn", + "inviteContactToGroupQuestion": "Vil du invitere {contact} til chatten «{groupName}»?", + "noChatDescriptionYet": "Ingen chatbeskrivelse er opprettet ennå.", + "redactMessageDescription": "Meldingen vil bli redigert for alle deltakerne i denne samtalen. Dette kan ikke angres.", + "optionalRedactReason": "(Valgfritt) Årsak til redigering av denne meldingen...", + "locationDisabledNotice": "Lokasjonstjenester er deaktivert. Vennligst aktiver dem for at du skal kunne dele posisjonen din.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Lokasjonstillatelse nektet. Gi dem tillatelse til å dele din lokasjon.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "dehydrate": "Eksporter økten og slett enheten", + "dehydrateWarning": "Denne handlingen kan ikke angres. Sørg for at du lagrer sikkerhetskopifilen på en trygg måte.", + "dehydrateTor": "TOR-brukere: Eksporter økt", + "dehydrateTorLong": "For TOR-brukere anbefales det å eksportere økten før vinduet lukkes.", + "hydrateTor": "TOR-brukere: Importer eksportert økt", + "hydrateTorLong": "Eksporterte du økten din sist gang på TOR? Importer den raskt og fortsett å chatte.", + "noEncryptionForPublicRooms": "Du kan bare aktivere kryptering på rom som ikke er offentlig tilgjengelig.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} er ingen matrix-server, bruk {server2} i stedet?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "roomNotificationSettings": "Innstillinger for romvarsler", + "userSpecificNotificationSettings": "Brukerspesifikke varslingsinnstillinger", + "otherNotificationSettings": "Andre varslingsinnstillinger", + "contentNotificationSettings": "Innstillinger for innholdsvarslinger", + "generalNotificationSettings": "Generelle varslingsinnstillinger", + "appIntroduction": "Med FluffyChat kan du chatte med vennene dine på tvers av forskjellige meldingstjenester. Finn ut mer på https://matrix.org eller trykk bare på *Fortsett*.", + "notificationRuleContainsUserNameDescription": "Varsler bruker når en melding inneholder ens brukernavn.", + "hideMemberChangesInPublicChats": "Skjul medlemsendringer i offentlige chatter", + "removeFromSpace": "Fjern fra området", + "addToSpaceDescription": "Velg områder hvor denne chatten legges til.", + "pleaseEnterRecoveryKeyDescription": "For å låse opp gamle meldinger, vennligst skriv inn gjenopprettingsnøkkelen som ble generert i en tidligere økt. Gjenopprettingsnøkkelen er IKKE passordet ditt.", + "reactedWith": "{sender} reagerte med {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Fest til rommet", + "emojis": "Emojier", + "placeCall": "Ringe opp", + "unsupportedAndroidVersionLong": "Denne funksjonen krever en nyere Android-versjon. Se etter oppdateringer eller støtte for Lineage OS.", + "videoCallsBetaWarning": "Vær oppmerksom på at videosamtaler for øyeblikket er i betaversjon. Det fungerer kanskje ikke som forventet eller i det hele tatt.", + "experimentalVideoCalls": "Eksperimentelle videoanrop", + "notificationRuleRoomnotifDescription": "Varsler brukeren når en melding inneholder ‘@room’.", + "notificationRuleTombstoneDescription": "Varsler brukeren om meldinger om deaktivering av rom.", + "notificationRuleReactionDescription": "Demper varsler for reaksjoner.", + "notificationRuleSuppressEdits": "Demp redigeringer", + "chatHasBeenAddedToThisSpace": "Chatten er lagt til i dette området", + "clearArchive": "Tøm arkivet", + "commandHint_markasgroup": "Merk som gruppe", + "commandHint_ban": "Utesteng den gitte brukeren fra dette rommet", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Tøm cache", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "homeserverDescription": "Alle dataene dine lagres på hjemmeserveren, akkurat som hos en e-postleverandør. Du kan velge hvilken hjemmeserver du vil bruke, samtidig som du fortsatt kan kommunisere med alle. Lær mer på https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Ser ikke ut til å være en kompatibel hjemmeserver. Feil URL?", + "prepareSendingAttachment": "Forbered sending av vedlegg...", + "generatingVideoThumbnail": "Genererer videominiatyrbilde ...", + "compressVideo": "Komprimerer video...", + "welcomeText": "Hei, hei! 👋 Dette er FluffyChat. Du kan logge på hvilken som helst hjemmeserver som er kompatibel med https://matrix.org. Og deretter chatte med hvem som helst. Det er et stort desentralisert meldingsnettverk!", + "notificationRuleIsUserMentionDescription": "Varsler brukeren når de er direkte nevnt i en melding.", + "notificationRuleContainsDisplayName": "Inneholder visningsnavn", + "notificationRuleContainsDisplayNameDescription": "Varsler brukeren når en melding inneholder ens visningsnavnet.", + "notificationRuleIsUserMention": "Brukeromtale", + "notificationRuleIsRoomMention": "Romomtale", + "whatIsAHomeserver": "Hva er en hjemmeserver?", + "commandHint_me": "Beskriv deg selv", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Angi bilde for dette rommet (med mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Angi visningsnavnet ditt for dette rommet", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_plain": "Send uformatert tekst", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Send svar som en reaksjon", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Send tekst", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Opphev utestengelsen til den gitte brukeren fra dette rommet", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Ugyldig kommando", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} er ikke en kommando.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "checkList": "Sjekkliste", + "createNewSpace": "Nytt område", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "emoteKeyboardNoRecents": "Nylig brukte emotes vil vises her ...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "unableToJoinChat": "Kan ikke bli med i chatten. Kanskje den andre parten allerede har lukket samtalen.", + "otherPartyNotLoggedIn": "Den andre parten er ikke logget inn og kan derfor ikke motta meldinger!", + "notificationRuleIsRoomMentionDescription": "Varsler brukeren når det er en romomtale.", + "notificationRuleRoomnotif": "Romvarsel", + "notificationRuleCall": "Anrop", + "notificationRuleCallDescription": "Varsler brukeren om anrop.", + "waitingPartnerAcceptRequest": "Venter på at partneren skal godta forespørselen…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Venter på at partneren skal godta emojien…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Vil du slette sikkerhetskopien av chatten din for å opprette en ny gjenopprettingsnøkkel?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "switchToAccount": "Bytt til konto {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "widgetEtherpad": "Tekstnotat", + "noOneCanJoin": "Ingen kan bli med", + "userWouldLikeToChangeTheChat": "{user} vil gjerne bli med i chatten.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Ingen offentlig lenke er opprettet ennå", + "commandHint_html": "Send HTML-formatert tekst", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_kick": "Fjern den gitte brukeren fra dette rommet", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Forlat dette rommet", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_discardsession": "Forkast økten", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Start en direkte chat\nBruk --no-encryption for å deaktivere kryptering", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_create": "Opprett en tom gruppechat\nBruk --no-encryption for å deaktivere kryptering", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "redactedBy": "Redigert av {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Direkte chat", + "redactedByBecause": "Redigert av {username} fordi: «{reason}»", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactMessage": "Rediger melding", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Rom versjon", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "newSpace": "Nytt område", + "allSpaces": "Alle områder", + "numChats": "{number} chats", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "wasDirectChatDisplayName": "Tom chat (var {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "moveDown": "Flytt ned", + "removeFromSpaceDescription": "Chatten blir fjernet fra området, men vises fortsatt i chatlisten din.", + "countChats": "{chats} chats", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "donate": "Doner", + "banUserDescription": "Brukeren vil bli utestengt fra chatten og vil ikke kunne delta i chatten igjen før utestengelsen er opphevet.", + "unbanUserDescription": "Brukeren vil kunne gå inn i chatten igjen hvis vedkommende prøver.", + "kickUserDescription": "Brukeren blir kastet ut av chatten, men ikke utestengt. I offentlige chatter kan brukeren bli med på nytt når som helst.", + "sendTypingNotifications": "Send varsler ved skriving", + "swipeRightToLeftToReply": "Sveip fra høyre mot venstre for å svare", + "startFirstChat": "Start din første chat", + "unlockOldMessages": "Lås opp gamle meldinger", + "storeInAndroidKeystore": "Lagre i Android KeyStore", + "storeInAppleKeyChain": "Lagre i Apple nøkkelring", + "storeSecurlyOnThisDevice": "Lagre sikkert på denne enheten", + "acceptedKeyVerification": "{sender} godtok nøkkelverifisering", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "notificationRuleMessageDescription": "Varsler brukeren om generelle meldinger.", + "notificationRuleSuppressEditsDescription": "Demper varsler for redigerte meldinger.", + "notificationRuleEncryptedDescription": "Varsler brukeren om meldinger i krypterte rom.", + "notificationRuleRoomServerAcl": "Romserverens tilgangskontrolliste", + "notificationRuleRoomOneToOneDescription": "Varsler brukeren om meldinger i én-til-én-rom.", + "notificationRuleJitsiDescription": "Varsler brukeren om hendelser i Jitsi-widgeten.", + "customReaction": "Egendefinert reaksjon", + "pause": "Pause", + "moveToDifferentSpace": "Flytt til et annet område", + "moveUp": "Flytt opp", + "storeInSecureStorageDescription": "Oppbevar gjenopprettingsnøkkelen på en sikker lagringsplass på denne enheten.", + "foregroundServiceRunning": "Denne varslingen vises når forgrunnstjenesten kjører.", + "callingAccount": "Ringekonto", + "appearOnTopDetails": "Lar appen vises øverst (ikke nødvendig hvis du allerede har Fluffychat konfigurert som en ringekonto)", + "longPressToRecordVoiceMessage": "Langt trykk for å spille inn talemelding.", + "startedAPoll": "{username} startet en avstemning.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Avstemning", + "startPoll": "Start avstemning", + "endPoll": "Avslutt avstemning", + "answersVisible": "Svar synlige", + "answersHidden": "Svar skjult", + "addAnswerOption": "Legg til svaralternativ", + "answerOption": "Svaralternativ", + "allowMultipleAnswers": "Tillat flere svar", + "pollHasBeenEnded": "Avstemningen er avsluttet", + "roomUpgradeDescription": "Chatten vil deretter bli gjenskapt med den nye romversjonen. Alle deltakere vil bli varslet om at de må bytte til den nye chatten. Du kan finne ut mer om romversjoner på https://spec.matrix.org/latest/rooms/", + "groupCanBeFoundViaSearch": "Gruppen kan finnes via søk", + "commandHint_sendraw": "Send raw json", + "replyInThread": "Svar i tråden", + "sessionLostBody": "Sesjonen din er tapt. Vennligst rapporter denne feilen til utviklerne på {url}. Feilmeldingen er: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "noticeChatBackupDeviceVerification": "Merk: Når du kobler alle enhetene dine til chat-sikkerhetskopien, blir de automatisk bekreftet.", + "notificationRuleTombstone": "Gravstein", + "answersWillBeVisibleWhenPollHasEnded": "Svarene vil være synlige når avstemningen er avsluttet", + "thread": "Tråd", + "backToMainChat": "Tilbake til hovedchatten", + "saveChanges": "Lagre endringer", + "skipChatBackup": "Hopp over sikkerhetskopiering av chat", + "loadingMessages": "Laster inn meldinger", + "setupChatBackup": "Konfigurer sikkerhetskopi av chat", + "commandHint_googly": "Send noen googly-eyes", + "commandHint_cuddle": "Send en kos", + "googlyEyesContent": "{senderName} sender deg googly-eyes", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "countChatsAndCountParticipants": "{chats} chatter og {participants} deltakere", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noChatsFoundHere": "Ingen chatter her. Bruk knappen under for å starte en ny samtale. ⤵️", + "joinedChats": "Mine chatter", + "changedTheChatDescription": "{username} endret beskrivelsen av chatten", + "changedTheChatName": "{username} endret navnet på chatten", + "commandHint_markasdm": "Marker som rom for direktemeldinger for den angitte Matrix-IDen", + "indexedDbErrorTitle": "Problemer med privat modus", + "recoveryKeyLost": "Mistet gjenopprettingsnøkkel?", + "separateChatTypes": "Skille direktemeldinger og grupper", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Angi som hovedalias", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Området er offentlig", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Navn på område", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "useAsEmoji": "Bruk som emoji", + "stickerPackNameAlreadyExists": "Klistremerkepakken finnes allerede", + "newStickerPack": "Ny klistremerkepakke", + "stickerPackName": "Navn på klistremerkepakke", + "signInWithLabel": "Logg inn med:", + "enterSpace": "Bli med i området", + "enterRoom": "Bli med i rommet", + "addToBundle": "Legg til i pakke", + "removeFromBundle": "Fjern fra denne pakken", + "bundleName": "Navn på pakke", + "noBackupWarning": "Advarsel! Hvis du ikke aktiverer sikkerhetskopiering av chatten, vil du miste tilgangen til dine krypterte meldinger. Det anbefales sterkt å aktivere sikkerhetskopiering før du logger ut.", + "commandHint_op": "Angi makt-nivå for valgt bruker (standard: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "editBundlesForAccount": "Rediger pakker for denne kontoen", + "register": "Registrer", + "@register": { + "type": "String", + "placeholders": {} + }, + "errorAddingWidget": "Kunne ikke legge til widget.", + "makeAdminDescription": "Når du gjør denne brukeren til administrator, kan du kanskje ikke omgjøre det senere. Brukeren vil da få de samme rettighetene som deg.", + "joinSpace": "Bli med i området", + "publicSpaces": "Offentlige områder", + "databaseBuildErrorBody": "Kunne ikke bygge SQLite-databasen. Appen prøver å bruke den gamle databasen enn så lenge. Vennligst rapporter denne feilen til utviklerne på {url}. Feilmeldingen er: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "verifyOtherUserDescription": "Hvis du verifiserer en annen bruker, kan du være trygg på at du vet hvem du faktisk skriver med. 💪\n\nNår du starter en verifisering, vil både du og den andre brukeren se et popup-vindu i appen. Der vil dere se en serie emojier eller tall som dere må sammenligne med hverandre.\n\nDen beste måten å gjøre dette på er å møtes ansikt til ansikt eller starte en videosamtale. 👭", + "verifyOtherDeviceDescription": "Når du verifiserer en annen enhet, kan disse enhetene utveksle nøkler, noe som øker den generelle sikkerheten din. 💪 Når du starter en verifisering, vil det dukke opp et popup-vindu i appen på begge enhetene. Der vil du se en serie emojier eller tall som du må sammenligne med hverandre. Det er best å ha begge enhetene forhånden før du starter verifiseringen. 🤳", + "clientWellKnownInformation": "Velkjent informasjon om klienten:", + "baseUrl": "Base URL", + "identityServer": "Identitetsserver:", + "versionWithNumber": "Versjon: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Logger", + "advancedConfigs": "Avanserte innstillinger", + "advancedConfigurations": "Avanserte innstillinger", + "createSticker": "Lag sticker eller emoji", + "useAsSticker": "Bruk som sticker", + "pollQuestion": "Spørsmål til avstemning", + "hasKnocked": "🚪{user} har banket på", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Brukere må banke på", + "knock": "Bank på", + "notificationRuleRoomServerAclDescription": "Skjuler varsler for tilgangskontrollister (ACL) for romservere.", + "displayNavigationRail": "Vis navigasjonsfelt på mobil", + "attribution": "Kreditering", + "skipChatBackupWarning": "Er du sikker? Uten sikkerhetskopi av chattene kan du miste meldingene dine hvis du bytter enhet.", + "noMoreResultsFound": "Ingen flere treff", + "federationBaseUrl": "Federation Base URL", + "notificationRuleServerAclDescription": "Skjuler varslinger for Server ACL-hendelser.", + "notificationRuleServerAcl": "Skjul Server ACL-hendelser", + "notificationRuleMemberEventDescription": "Skjuler varslinger for medlemsskapshendelser.", + "youHaveKnocked": "Du har banket på", + "moreEvents": "Flere hendelser", + "knockRestricted": "Banking deaktivert", + "contactServerSecurity": "Kontakt sikkerhetsansvarlig for serveren", + "notificationRuleMemberEvent": "Medlemshendelse", + "spaceMemberOfCanKnock": "Et medlem av området {spaces} kan banke på", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "countVotes": "{count, plural, =1{En stemme} other{{count} stemmer}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "countReplies": "{count, plural, =1{Et svar} other{{count} svar}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "chatSearchedUntil": "Søkte i chatten frem til {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "sendingAttachmentCountOfCount": "Sender vedlegg {index} av {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "spaceMemberOf": "Områdemedlem av {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "confirmEventUnpin": "Er du sikker på at du vil løsne hendelsen permanent?", + "indexedDbErrorLong": "Lagring av meldinger er dessverre ikke aktivert i privat modus som standard.\nVennligst gå til:\n - about:config\n - Sett dom.indexedDB.privateBrowsing.enabled til true\nEllers er det ikke mulig å kjøre FluffyChat.", + "saveKeyManuallyDescription": "Lagre denne nøkkelen manuelt ved å åpne systemets delingsmeny eller kopiere til utklippstavlen.", + "newSpaceDescription": "Områder lar deg samle chattene dine og bygge private eller offentlige fellesskap.", + "chatPermissionsDescription": "Definer hvilket tilgangsnivå som kreves for bestemte handlinger i denne chatten. Nivåene 0, 50 og 100 representerer vanligvis brukere, moderatorer og administratorer, men alle mellomtrinn er mulige.", + "knocking": "Banker på", + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "noKeyForThisMessage": "Dette kan skje hvis meldingen ble sendt før du logget inn på kontoen din på denne enheten.\n\nDet er også mulig at senderen har blokkert enheten din, eller at noe gikk galt med internettforbindelsen.\n\nEr du i stand til å lese meldingen i en annen sesjon? Da kan du overføre meldingen fra den! Gå til Innstillinger > Enheter og sørg for at enhetene dine har verifisert hverandre. Neste gang du åpner rommet og begge sesjonene er i forgrunnen, vil nøklene bli overført automatisk.\n\nVil du unngå å miste nøklene når du logger ut eller bytter enhet? Sørg for at du har aktivert sikkerhetskopiering av chat i innstillingene.", + "report": "rapportere", + "addChatOrSubSpace": "Legg til chat eller underområde", + "subspace": "Underområde", + "newSubSpace": "Nytt underområde", + "signIn": "Logg på", + "createNewAccount": "Opprett ny konto", + "signUpGreeting": "FluffyChat er desentralisert! Velg en server der du vil opprette kontoen din, så kjører vi på!", + "signInGreeting": "Har du allerede en Matrix-konto? Velkommen tilbake! Velg hjemmeserveren din og logg inn.", + "appIntro": "Med FluffyChat kan du chatte med vennene dine. Det er en sikker, desentralisert [matrix]-meldingsapp! Les mer på https://matrix.org hvis du vil, eller bare registrer deg.", + "theProcessWasCanceled": "Prosessen ble avbrutt.", + "join": "Bli med", + "searchOrEnterHomeserverAddress": "Søk eller angi adresse til hjemmeserver", + "matrixId": "Matrix ID", + "setPowerLevel": "Angi styrkenivå", + "makeModerator": "Gjør til moderator", + "makeAdmin": "Gjør til admin", + "removeModeratorRights": "Fjern moderator-rettigheter", + "removeAdminRights": "Fjern admin-rettigheter", + "powerLevel": "Styrkenivå", + "setPowerLevelDescription": "Styrkenivåer definerer hva et medlem har lov til å gjøre i dette rommet, og varierer vanligvis mellom 0 og 100.", + "owner": "Eier" +} diff --git a/lib/l10n/intl_nl.arb b/lib/l10n/intl_nl.arb new file mode 100644 index 000000000..bb31e4d80 --- /dev/null +++ b/lib/l10n/intl_nl.arb @@ -0,0 +1,3158 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.955292", + "about": "Over ons", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Accepteren", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} heeft de uitnodiging geaccepteerd", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Account", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} heeft eind-tot-eindversleuteling geactiveerd", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Email toevoegen", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Aan space toevoegen", + "admin": "Beheerder", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Alle", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Alle chats", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} heeft de oproep beantwoord", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Iedereen kan toetreden", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "App-vergrendeling", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Archief", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Mogen gasten deelnemen?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Weet je het zeker?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Weet je zeker dat je wilt uitloggen?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Voer je beveiligde opslag wachtwoordzin of herstelsleutel in om de andere persoon te kunnen ondertekenen.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Accepteer je dit verificatieverzoek van {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Automatisch geanimeerde stickers en emoticons afspelen", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "De homeserver ondersteunt de login types:\n{serverVersions}\nMaar deze app ondersteunt alleen:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "De homeserver ondersteunt de Spec-versies:\n{serverVersions}\nMaar deze app ondersteunt alleen {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Van chat verbannen", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Verbannen", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} verbant {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Apparaat blokkeren", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Geblokkeerd", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot-berichten", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Annuleren", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Kan de URI {uri} niet openen", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Apparaatnaam wijzigen", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} heeft de chatavatar gewijzigd", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} heeft de chatomschrijving gewijzigd in: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} heeft de chatnaam gewijzigd in: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} heeft de chatrechten gewijzigd", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username}'s naam is nu '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} heeft de toegangsregels voor gasten gewijzigd", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} heeft de gastenregels gewijzigd in: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} heeft de zichtbaarheid van de geschiedenis gewijzigd", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} heeft de zichtbaarheid van de geschiedenis gewijzigd in: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} heeft de toetredingsregels gewijzigd", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} heeft de toetredingsregels gewijzigd in: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username}'s avatar is gewijzigd", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} heeft de chat aliassen gewijzigd", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} heeft de uitnodigingslink gewijzigd", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Wachtwoord wijzigen", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Homeserver wijzigen", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Je stijl veranderen", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Groepsnaam wijzigen", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Jouw avatar veranderen", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "De versleuteling is beschadigd", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Chatback-up", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Je berichten zijn beveiligd met een herstelsleutel. Zorg ervoor dat je deze niet verliest.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Chatdetails", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Chat is toegevoegd aan deze space", + "chats": "Chats", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Kies een sterk wachtwoord", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Archief wissen", + "close": "Sluiten", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Persoon uit deze chat verbannen", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Tekst met HTML-opmaak versturen", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Persoon in deze chat uitnodigen", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Toetreden tot de vermelde chat", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Persoon uit deze chat verwijderen", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Deze chat verlaten", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Beschrijf jezelf", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Jouw avatar voor deze chat instellen (met mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Jouw naam voor deze chat instellen", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Rechtenniveau van de persoon instellen (standaard: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Niet-opgemaakte tekst versturen", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Antwoord als reactie versturen", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Tekst versturen", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Persoon weer in deze chat toestaan", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Opdracht ongeldig", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} is geen opdracht.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Vergelijk de emoji's", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Vergelijk de cijfers", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Chat configureren", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Bevestigen", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Verbinden", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Contact is voor de groep uitgenodigd", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Bevat naam", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Bevat inlognaam", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "De inhoud is gerapporteerd aan de serverbeheerders", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Gekopieerd naar klembord", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Bericht kopiëren", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopieer naar klembord", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Kan het bericht niet ontsleutelen: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} personen", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Aanmaken", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} heeft de chat gemaakt", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Maak nieuwe space aan", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Momenteel actief", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Donker", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Hierdoor wordt je account gedeactiveerd. Dit kan niet ongedaan gemaakt worden! Weet je het zeker?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Standaard rechten-niveau voor nieuwe personen", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Verwijderen", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Account verwijderen", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Bericht verwijderen", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Apparaat", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Apparaat-ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Apparaten", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Directe chats", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "De naam is gewijzigd", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Bestand downloaden", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Wijzig", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Geblokkeerde servers wijzigen", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Naam wijzigen", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Chat aliassen wijzigen", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Chat avatar wijzigen", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emoticon bestaat al!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Ongeldige emoticon korte code!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Emoticonpakketten voor de chat", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emoticon-instellingen", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Emoticon korte code", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Je moet een emoticon korte code en afbeelding kiezen!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Lege chat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Emoticonpakket overal inschakelen", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Versleuteling inschakelen", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Je kunt de versleuteling hierna niet meer uitschakelen. Weet je het zeker?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Versleuteld", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Versleuteling", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Versleuteling is niet ingeschakeld", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} heeft het gesprek beëindigd", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Voer een emailadres in", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Vul je homeserver in", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Locatie ophalen fout: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Alles klaar!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extreem beledigend", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Bestandsnaam", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Lettergrootte", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Stuur door", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Vanaf toetreden", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Vanaf uitnodiging", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Ga naar de nieuwe chat", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Groep", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Groep is publiek", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Groepen", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Groep met {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Gasten zijn verboden", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Gasten kunnen deelnemen", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} heeft de uitnodiging voor {targetName} ingetrokken", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Help", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Bewerkte gebeurtenissen verbergen", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Onbekende gebeurtenissen verbergen", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Hoe beledigend is deze inhoud?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identiteit", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Negeer", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Genegeerde personen", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Ik heb op de link geklikt", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Onjuiste wachtwoordzin of herstelsleutel", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Niet beledigend", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Contact uitnodigen", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Contact voor {groupName} uitnodigen", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Uitgenodigd", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} heeft {targetName} uitgenodigd", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Alleen uitgenodigde personen", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Persoonlijke uitnodiging", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} heeft je uitgenodigd voor FluffyChat.\n1. Bezoek https://fluffychat.im en installeer de app\n2. Registreer of log in\n3. Open deze uitnodigingslink:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "is aan het typen…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} is toegetreden tot de chat", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Toetreden tot de chat", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} heeft {targetName} verwijderd", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} heeft {targetName} verwijderd en verbannen", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Uit chat verwijderen", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Laatst actief: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Chat verlaten", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Verliet de chat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licentie", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Licht", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Laad nog {count} personen", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Bezig met laden… Even geduld.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Meer laden…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Locatievoorzieningen is uitgeschakeld. Zet dit eerst aan om je locatie te delen.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Locatie toegang is geweigerd. Geef toegang om de locatie delen-functie te gebruiken.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Inloggen", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Inloggen bij {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Uitloggen", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Persoon wijzigingen", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Vermeld", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Berichten", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Chat dempen", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Houd er rekening mee dat je voorlopig Pantalaimon nodig hebt om eind-tot-eind versleuteling te gebruiken.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Nieuwe chat", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nieuw bericht in FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nieuw verificatieverzoek!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Volgende", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Nee", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Geen verbinding met de server", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Geen emoticons gevonden. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Je kunt de versleuteling pas activeren zodra de chat niet meer publiek toegankelijk is.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Firebase Cloud Messaging lijkt niet beschikbaar op je apparaat. Om pushmeldingen te krijgen, adviseren we om ntfy te installeren. Met ntfy of een andere Unified Push-provider kun je pushmeldingen ontvangen op een veilige manier. Je kunt ntfy downloaden in de PlayStore of F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} is geen Matrix-server, wil je {server2} gebruiken?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "none": "Geen", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Je hebt nog geen manier toegevoegd om je wachtwoord te herstellen.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Geen toestemming", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Geen chats gevonden …", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Meldingen", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Meldingen ingeschakeld voor dit account", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} personen typen…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Locatie ophalen…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Beledigend", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Offline", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Online", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Online sleutelback-up is ingeschakeld", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Oeps! Helaas is er een fout opgetreden bij het instellen van de pushmeldingen.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Oeps, er ging iets mis…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Open app om de berichten te lezen", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Camera openen", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "In kaarten openen", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Of", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Personen", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "wachtwoordzin of herstelsleutel", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Wachtwoord", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Wachtwoord vergeten", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Wachtwoord gewijzigd", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Wachtwoordherstel", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Personen", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Kies een afbeelding", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Pin", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Speel {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Maak een keuze", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Kies een toegangscode", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Klik op de link in de email en ga dan verder.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Voer 4 cijfers in of laat leeg om app-vergrendeling uit te schakelen.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Voer jouw wachtwoord in", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Voer je pincode in", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Voer je inlognaam in", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Volg de instructies op de website en tik op volgende.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privacy", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Publieke chats", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Meldingsinstellingen", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Reden", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Opnemen", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} heeft een event verwijderd", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Aangepast bericht", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Registeren", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Afwijzen", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} heeft de uitnodiging afgewezen", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Opnieuw deelnemen", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Verwijder", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Verwijder alle andere apparaten", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Verwijderd door {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Verwijder apparaat", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Verbanning opheffen", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Jouw avatar verwijderen", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Kamerversie upgraden", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Antwoord", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Bericht rapporteren", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Vraag toestemming", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Chat is geüpgrade", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Kamerversie", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Bestand opslaan", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Zoeken", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Beveiliging", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Gezien door {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Verstuur", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Stuur een bericht", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Als tekst versturen", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Audio versturen", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Bestand versturen", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Afbeelding versturen", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Berichten versturen", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Origineel versturen", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Sticker versturen", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Video versturen", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} heeft een bestand verzonden", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} heeft een audio verzonden", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} heeft een afbeelding verzonden", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} heeft een sticker verzonden", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} heeft een video verzonden", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} heeft oproepgegevens verzonden", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Als hoofdalias instellen", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Aangepaste emoticons instellen", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Uitnodigingslink instellen", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Rechten-niveau instellen", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Status instellen", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Instellingen", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Delen", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} heeft deze locatie gedeeld", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Locatie delen", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Wachtwoord weergeven", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Eenmalig Inloggen", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Overslaan", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Broncode", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Space is publiek", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Spacenaam", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} heeft een gesprek gestart", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Status", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Hoe gaat het met jouw vandaag?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Indienen", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synchroniseren... Even geduld.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Systeem", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Ze komen niet overeen", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Ze komen overeen", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Favoriet in- of uitschakelen", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Dempen in- of uitschakelen", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Markeer gelezen/ongelezen", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Te veel verzoeken. Probeer het later nog eens!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Overzetten vanaf een ander apparaat", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Probeer nogmaals te verzenden", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Niet beschikbaar", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} heeft verbanning {targetName} ongedaan gemaakt", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Deblokkeer apparaat", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Onbekend apparaat", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Onbekend versleutelingsalgoritme", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Onbekend evenement '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Dempen uitschakelen", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Pin losmaken", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 ongelezen chat} other{{unreadCount} ongelezen chats}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} en {count} anderen zijn aan het typen …", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} en {username2} zijn aan het typen …", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} is aan het typen …", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} is vertrokken uit de chat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Inlognaam", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} heeft een {type} -gebeurtenis gestuurd", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Geverifieerd", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verifieer", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Verificatie starten", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Je bent succesvol geverifieerd!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Ander account verifiëren", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videogesprek", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Chatgeschiedenis zichtbaarheid", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Zichtbaar voor alle personen", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Zichtbaar voor iedereen", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Spraakbericht versturen", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Wachten tot partner het verzoek accepteert …", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Wachten tot je partner de emoji accepteert…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Wachten tot partner de nummers accepteert …", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Achtergrond:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Waarschuwing!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "We hebben je een email gestuurd", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Wie kan welke actie uitvoeren", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Wie mag deelnemen aan deze groep", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Waarom wil je dit rapporteren?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Wil je de chatback-up wissen om een nieuwe herstelsleutel te kunnen maken?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Met deze adressen kun je je wachtwoord herstellen.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Schrijf een bericht…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Ja", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Jij", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Je neemt niet langer deel aan deze chat", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Je bent verbannen uit deze chat", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Je publieke sleutel", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "QR-code scannen", + "sendOnEnter": "Verstuur met enter", + "homeserver": "Server", + "serverRequiresEmail": "Deze server wil je email laten bevestigen bij de registratie.", + "oneClientLoggedOut": "Één van jouw apparaten is uitgelogd", + "enableMultiAccounts": "(BETA) Meerdere accounts op dit apparaat inschakelen", + "bundleName": "Bundelnaam", + "removeFromBundle": "Van bundel verwijderen", + "addToBundle": "Aan bundel toevoegen", + "editBundlesForAccount": "Bundels voor dit account wijzigen", + "addAccount": "Account toevoegen", + "link": "Link", + "yourChatBackupHasBeenSetUp": "Jouw chatback-up is ingesteld.", + "unverified": "Niet geverifieerd", + "repeatPassword": "Wachtwoord herhalen", + "messageInfo": "Berichtinfo", + "time": "Tijd", + "messageType": "Berichttype", + "sender": "Afzender", + "openGallery": "Galerij openen", + "addToSpaceDescription": "Selecteer een space om deze chat aan toe te voegen.", + "removeFromSpace": "Uit de space verwijderen", + "start": "Start", + "commandHint_clearcache": "Cache wissen", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Maak een lege groepschat\nGebruik --no-encryption om de versleuteling uit te schakelen", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_dm": "Start een directe chat\nGebruik --no-encryption om de versleuteling uit te schakelen", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_discardsession": "Sessie weggooien", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "openVideoCamera": "Videocamera openen", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "publish": "Publiceren", + "dismiss": "Sluiten", + "markAsRead": "Markeer als gelezen", + "reportUser": "Persoon rapporteren", + "openChat": "Chat openen", + "reactedWith": "{sender} reageerde met {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Maak vast aan chat", + "emojis": "Emoji's", + "placeCall": "Bellen", + "unsupportedAndroidVersion": "Niet-ondersteunde Android-versie", + "unsupportedAndroidVersionLong": "Voor deze functie is een nieuwe Android-versie verplicht. Controleer je updates of Lineage OS-ondersteuning.", + "videoCallsBetaWarning": "Houd er rekening mee dat videogesprekken momenteel in bèta zijn. Ze werken misschien niet zoals je verwacht of werken niet op alle platformen.", + "voiceCall": "Spraakoproep", + "confirmEventUnpin": "Weet je zeker dat je de gebeurtenis definitief wilt losmaken?", + "experimentalVideoCalls": "Videogesprekken (experimenteel)", + "emailOrUsername": "Email of inlognaam", + "nextAccount": "Volgende account", + "switchToAccount": "Naar account {number} overschakelen", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "previousAccount": "Vorige account", + "widgetCustom": "Aangepast", + "widgetName": "Naam", + "widgetUrlError": "Dit is geen geldige link.", + "widgetNameError": "Geef een naam op.", + "errorAddingWidget": "Fout bij het toevoegen van de widget.", + "widgetJitsi": "Jitsi Meet", + "addWidget": "Widget toevoegen", + "widgetVideo": "Video", + "widgetEtherpad": "Tekstnotitie", + "separateChatTypes": "Directe chats en groepen los weergeven", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youAcceptedTheInvitation": "👍 Je hebt de uitnodiging geaccepteerd", + "youRejectedTheInvitation": "Je hebt de uitnodiging afgewezen", + "youJoinedTheChat": "Je bent toegetreden tot de chat", + "youBannedUser": "Je hebt {user} verbannen", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Je hebt de uitnodiging voor {user} ingetrokken", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Je bent uitgenodigd door {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Je hebt {user} uitgenodigd", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Je hebt {user} weggestuurd", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Je hebt weggestuurd en verbannen {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Je hebt de ban op {user} opgeheven", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "recoveryKey": "Herstelsleutel", + "recoveryKeyLost": "Herstelsleutel verloren?", + "pleaseEnterRecoveryKey": "Voer jouw herstelsleutel in:", + "users": "Personen", + "unlockOldMessages": "Oude berichten ontgrendelen", + "storeInAndroidKeystore": "In Android KeyStore opslaan", + "storeInAppleKeyChain": "In Apple KeyChain opslaan", + "saveKeyManuallyDescription": "Sla deze sleutel handmatig op via delen of het klembord.", + "pleaseEnterRecoveryKeyDescription": "Om je oude berichten te ontgrendelen voer je jouw herstelsleutel in die gemaakt is in je vorige sessie. Je sleutel is niet je wachtwoord.", + "storeInSecureStorageDescription": "Sla de herstelsleutel op in de beveiligde opslag van dit apparaat.", + "storeSecurlyOnThisDevice": "Veilig opslaan op dit apparaat", + "dehydrate": "Sessie exporteren en apparaat wissen", + "dehydrateWarning": "Deze actie kan niet ongedaan worden gemaakt. Zorg ervoor dat je het back-upbestand veilig opslaat.", + "dehydrateTor": "TOR-sessies: Exporteer sessie", + "dehydrateTorLong": "Voor TOR-sessies is het aanbevolen de sessie te exporteren alvorens het venster te sluiten.", + "hydrateTor": "TOR-sessie: Importeren sessie export", + "hydrateTorLong": "Heb je de vorige keer jouw sessie geëxporteerd met TOR? Importeer het dan snel en ga verder met chatten.", + "hydrate": "Herstellen vanuit back-upbestand", + "indexedDbErrorTitle": "Problemen met privémodus", + "indexedDbErrorLong": "Het opslaan van berichten is helaas niet standaard ingeschakeld in de privémodus.\nBezoek alsjeblieft\n - about:config\n - stel dom.indexedDB.privateBrowsing.enabled in op true\nAnders is het niet mogelijk om FluffyChat op te starten.", + "countFiles": "{count} bestanden", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "user": "Persoon", + "custom": "Aangepast", + "confirmMatrixId": "Bevestig jouw Matrix-ID om je account te verwijderen.", + "supposedMxid": "Dit moet {mxid} zijn", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasdm": "Markeer als privé-chat voor de Matrix-ID", + "commandHint_markasgroup": "Markeer als groep", + "whyIsThisMessageEncrypted": "Waarom is dit bericht onleesbaar?", + "noKeyForThisMessage": "Dit kan gebeuren als het bericht is verzonden voordat je bij je account op dit apparaat hebt aangemeld.\n\nHet is ook mogelijk dat de afzender je apparaat heeft geblokkeerd of dat er iets mis is gegaan met de internetverbinding.\n\nKan je het bericht wel lezen in een andere sessie? Dan kan je het bericht daarvandaan overzetten! Ga naar Instellingen > Apparaten en zorg ervoor dat je apparaten elkaar hebben geverifieerd. Wanneer je de chat de volgende keer opent en beide sessies op de voorgrond staan, zullen de sleutels automatisch worden verzonden.\n\nWil je de sleutels niet verliezen als je uitlogt of van apparaat wisselt? Zorg er dan voor dat je de chatback-up hebt aangezet in de instellingen.", + "enterSpace": "Space betreden", + "allSpaces": "Alle spaces", + "foregroundServiceRunning": "Deze melding verschijnt wanneer de voorgronddienst draait.", + "screenSharingTitle": "scherm delen", + "screenSharingDetail": "Je deelt je scherm in FuffyChat", + "callingPermissions": "Telefoon-rechten", + "callingAccount": "Telefoon-account", + "callingAccountDetails": "Hiermee kan FluffyChat de Android telefoon-app gebruiken.", + "appearOnTop": "Bovenaan verschijnen", + "appearOnTopDetails": "Laat de app bovenaan verschijnen (niet nodig als je FluffyChat al hebt ingesteld als een bel-account)", + "otherCallingPermissions": "Microfoon, camera en andere FluffyChat-rechten", + "newGroup": "Nieuwe groep", + "newSpace": "Space aanmaken", + "enterRoom": "Chat betreden", + "numChats": "{number} chats", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Onbelangrijke statusgebeurtenissen verbergen", + "doNotShowAgain": "Niet meer tonen", + "googlyEyesContent": "{senderName} stuurt je wiebelogen", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_googly": "Wiebel-ogen versturen", + "commandHint_cuddle": "Een knuffel versturen", + "commandHint_hug": "Een knuffel versturen", + "cuddleContent": "{senderName} knuffelt je", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} omhelst je", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "wasDirectChatDisplayName": "Lege chat (was {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "disableEncryptionWarning": "Om veiligheidsredenen kun je versleuteling niet uitschakelen in een chat, waar deze eerder is ingeschakeld.", + "sorryThatsNotPossible": "Sorry, dat is niet mogelijk", + "reopenChat": "Chat heropenen", + "encryptThisChat": "Versleutel deze chat", + "deviceKeys": "Apparaatsleutels:", + "startFirstChat": "Begin je eerste chat", + "newSpaceDescription": "Met spaces kun je je chats samenvoegen en privé- of publieke community's bouwen.", + "noOtherDevicesFound": "Geen andere apparaten gevonden", + "noBackupWarning": "Waarschuwing! Zonder de chatback-up in te schakelen, verlies je de toegang tot je versleutelde berichten. Het is sterk aanbevolen om eerst de chatback-up in te schakelen voordat je uitlogt.", + "fileIsTooBigForServer": "Kan niet verzenden! De server ondersteunt alleen bijlages tot {max}.", + "fileHasBeenSavedAt": "Het bestand is opgeslagen op {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Spring naar het laatst gelezen bericht", + "readUpToHere": "Lees tot hier", + "jump": "Spring", + "openLinkInBrowser": "Link in browser openen", + "allRooms": "Alle groepschats", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "signInWith": "Aanmelden met {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Geen afbeeldingsbestand.", + "importNow": "Nu importeren", + "importEmojis": "Emoji's importeren", + "importFromZipFile": "Uit zip-bestand importeren", + "exportEmotePack": "Emote-pakket als zip exporteren", + "replace": "Vervang", + "report": "Rapporteer", + "reportErrorDescription": "😭 Oh nee. Er is iets misgegaan. Probeer het later nog eens. Als je wilt, kun je de bug rapporteren aan de ontwikkelaars.", + "sendTypingNotifications": "Typemeldingen verzenden", + "pleaseTryAgainLaterOrChooseDifferentServer": "Probeer het later nog eens of kies een andere server.", + "signInWithPassword": "Aanmelden met wachtwoord", + "chatPermissions": "Chatrechten", + "chatDescription": "Onderwerp", + "chatDescriptionHasBeenChanged": "Onderwerp gewijzigd", + "noChatDescriptionYet": "Nog geen onderwerp gemaakt.", + "tryAgain": "Opnieuw proberen", + "redactMessageDescription": "Het bericht zal worden aangepast voor alle deelnemers in dit gesprek. Dit kan niet ongedaan gemaakt worden.", + "redactedByBecause": "Aangepast door {username}, reden: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "profileNotFound": "De persoon kan niet gevonden worden op de server. Misschien is er een verbindingsprobleem of de persoon bestaat niet.", + "createGroup": "Groep aanmaken", + "inviteContactToGroupQuestion": "Wil je {contact} uitnodigingen voor de chat \"{groupName}\"?", + "optionalRedactReason": "(Optioneel) Reden voor aanpassing van dit bericht...", + "addChatDescription": "Voeg een onderwerp toe...", + "invalidServerName": "Foute servernaam", + "messagesStyle": "Berichten:", + "shareInviteLink": "Uitnodigingslink delen", + "redactedBy": "Aangepast door {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Directe chat", + "setChatDescription": "Onderwerp instellen", + "setTheme": "Thema instellen:", + "setColorTheme": "Kleurthema instellen:", + "invite": "Uitnodigen", + "inviteGroupChat": "📨 Groeps-chat uitnodiging", + "invitePrivateChat": "📨 Privé-chat uitnodiging", + "emoteKeyboardNoRecents": "Recent gebruikte emoticons zullen hier verschijnen...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "invalidInput": "Ongeldige invoer!", + "wrongPinEntered": "Verkeerde pin ingevoerd! Probeer het nog eens over {seconds} seconden...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "banUserDescription": "De persoon zal worden verbannen van de chat en kan niet meer toetreden totdat de verbanning is opgeheven.", + "removeDevicesDescription": "Je wordt op dit apparaat uitgelogd en zal niet langer in staat zijn om berichten te ontvangen.", + "unbanUserDescription": "De persoon zal weer in staat zijn om de chat te betreden als ze het proberen.", + "pushNotificationsNotAvailable": "Pushmeldingen zijn niet beschikbaar", + "makeAdminDescription": "Wanneer je deze persoon beheerder maakt kun je dit niet ongedaan maken als jullie dezelfde rechten hebben.", + "archiveRoomDescription": "De chat zal naar het archief worden verplaatst. Andere personen zullen in staat zijn te zien dat je de chat hebt verlaten.", + "hasKnocked": "🚪 {user} heeft geklopt", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "learnMore": "Lees meer", + "roomUpgradeDescription": "De chat zal dan opnieuw gemaakt worden met de nieuwe kamerversie. Alle deelnemers worden geïnformeerd dat ze moeten overstappen naar de nieuwe chat. Je kan meer lezen over kamerversies op https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Vul een getal in groter dan 0", + "kickUserDescription": "De persoon is verwijderd uit de chat, maar is niet verbannen. In publieke chats kan de persoon op elk moment opnieuw deelnemen.", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "joinSpace": "Toetreden tot de space", + "block": "Blokkeren", + "blockedUsers": "Geblokkeerde personen", + "presenceStyle": "Aanwezigheid:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "searchChatsRooms": "Zoek #chats, @personen...", + "swipeRightToLeftToReply": "Veeg van rechts naar links om te reageren", + "calls": "Gesprekken", + "customEmojisAndStickers": "Aangepaste emoji's en stickers", + "accessAndVisibilityDescription": "Wie mag toetreden tot deze chat en hoe de chat ontdekt kan worden.", + "customEmojisAndStickersBody": "Voeg toe of deel aangepaste emoji's en stickers die in elke chat gebruikt kunnen worden.", + "hideRedactedMessages": "Verwijderde berichten verbergen", + "hideRedactedMessagesBody": "Als iemand een bericht verwijdert is dit bericht niet meer zichtbaar in de chat.", + "hideInvalidOrUnknownMessageFormats": "Ongeldige of onbekende berichtformaten verbergen", + "passwordRecoverySettings": "Wachtwoordherstel-instellingen", + "youInvitedToBy": "📩 Je bent uitgenodigd via een link voor:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "knock": "Klop", + "overview": "Overzicht", + "hidePresences": "Verberg statuslijst?", + "noOneCanJoin": "Niemand kan deelnemen", + "yourGlobalUserIdIs": "Je Matrix-ID is: ", + "appLockDescription": "Vergendel de app wanneer het niet gebruikt wordt met een pincode", + "globalChatId": "Globale chat ID", + "accessAndVisibility": "Toegang en zichtbaarheid", + "invitedBy": "📩 Uitgenodigd door: {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "publicSpaces": "Publieke spaces", + "blockUsername": "Negeer inlognaam", + "publicChatAddresses": "Publieke chat adressen", + "createNewAddress": "Creëer nieuw adres", + "countChatsAndCountParticipants": "{chats} chats en {participants} deelnemers", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Geen chats gevonden...", + "joinedChats": "Chats waaraan je deelneemt", + "knocking": "Kloppen", + "space": "Space", + "spaces": "Spaces", + "unread": "Ongelezen", + "databaseBuildErrorBody": "Het aanmaken van de SQlite database is mislukt. De app probeert nu een traditionele database te gebruiken. Meldt alsjeblieft deze fout aan de ontwikkelaars via deze {url}. De foutmelding is: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "groupName": "Groepsnaam", + "changeGeneralChatSettings": "Algemene chat instellingen wijzigen", + "restricted": "Beperkt", + "searchForUsers": "Zoek @personen...", + "searchMore": "Zoek meer...", + "noPublicLinkHasBeenCreatedYet": "Publieke link is nog niet gecreëerd", + "groupCanBeFoundViaSearch": "Groep kan gevonden worden via zoeken", + "searchIn": "Zoek in chat \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "files": "Bestanden", + "unreadChatsInApp": "{appname}: {unread} ongelezen chats", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Database versleuteling is niet ondersteund op dit platform", + "thereAreCountUsersBlocked": "Momenteel zijn er {count} personen geblokkeerd.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "markAsUnread": "Als ongelezen markeren", + "userLevel": "{level} - Persoon", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Beheerder", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "stickers": "Stickers", + "nothingFound": "Niets gevonden...", + "gallery": "Galerij", + "transparent": "Transparant", + "incomingMessages": "Inkomende berichten", + "discover": "Ontdek", + "commandHint_ignore": "Negeer de gegeven Matrix-ID", + "noChatsFoundHere": "Hier zijn nog geen chats. Begin een nieuwe chat met iemand door op de onderstaande knop te klikken. ⤵️", + "unableToJoinChat": "Kan niet toetreden tot de chat. Misschien heeft de andere partij het gesprek al afgesloten.", + "aboutHomeserver": "Over {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "boldText": "Vet gedrukte tekst", + "italicText": "Cursieve tekst", + "strikeThrough": "Doorhalen", + "pleaseFillOut": "Vul alsjeblieft in", + "invalidUrl": "Ongeldige url", + "addLink": "Koppeling toevoegen", + "compress": "Comprimeren", + "previous": "Vorige", + "otherPartyNotLoggedIn": "De andere partij is momenteel niet ingelogd en kan daarom geen berichten ontvangen!", + "notifyMeFor": "Waarschuw mij voor", + "blockListDescription": "Je kunt personen blokkeren die je lastig vallen. Je kan dan geen berichten meer ontvangen of chat uitnodigingen krijgen van de personen op je blokkeerlijst.", + "sendImages": "Stuur {count} afbeelding(en)", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "presencesToggle": "Statusberichten van andere personen tonen", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "website": "Website", + "hideMemberChangesInPublicChats": "Verberg persoon veranderingen in publieke chats", + "hideMemberChangesInPublicChatsBody": "Verberg in de tijdlijn van de chat als iemand zich aanmeldt bij een publieke chat of deze verlaat om de leesbaarheid te verbeteren.", + "startConversation": "Start gesprek", + "usersMustKnock": "Personen moeten kloppen", + "noUsersFoundWithQuery": "Helaas kan er geen persoon gevonden worden met \"{query}\". Controleer of je een typfout hebt gemaakt.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "createGroupAndInviteUsers": "Maak groep en nodig personen uit", + "userWouldLikeToChangeTheChat": "{user} wil graag deelnemen aan de chat.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "chatCanBeDiscoveredViaSearchOnServer": "Chat kan worden gevonden via een zoekopdracht op {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "wrongRecoveryKey": "Helaas... dit lijkt niet de correcte herstelsleutel.", + "synchronizingPleaseWaitCounter": " Synchroniseren… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "databaseMigrationTitle": "Database is geoptimaliseerd", + "databaseMigrationBody": "Een ogenblik. Dit kan even duren.", + "commandHint_sendraw": "Stuur kale json", + "passwordIsWrong": "Je ingevoerde wachtwoord is fout", + "newPassword": "Nieuw wachtwoord", + "pleaseChooseAStrongPassword": "Kies a.j.b. een sterk wachtwoord", + "publicLink": "Publieke link", + "select": "Selecteer", + "leaveEmptyToClearStatus": "Laat leeg om je status te resetten.", + "addChatOrSubSpace": "Voeg chat of subspace toe", + "subspace": "Subspace", + "pleaseEnterYourCurrentPassword": "Vul je huidige wachtwoord in", + "passwordsDoNotMatch": "Wachtwoorden komen niet overeen", + "decline": "Weiger", + "thisDevice": "Dit apparaat:", + "contentNotificationSettings": "Contentmelding instellingen", + "roomNotificationSettings": "Kamermelding instellingen", + "userSpecificNotificationSettings": "Persoon specifieke melding instellingen", + "otherNotificationSettings": "Andere melding instellingen", + "notificationRuleContainsUserName": "Bevat naam van persoon", + "notificationRuleContainsUserNameDescription": "Stuur een melding als een bericht je inlognaam vermeld.", + "notificationRuleMaster": "Alle meldingen uitschakelen", + "notificationRuleMasterDescription": "Overschrijf alle andere regels en schakel alle meldingen uit.", + "notificationRuleMemberEventDescription": "Meldingen voor chat-gebeurtenissen uitschakelen.", + "notificationRuleIsUserMention": "Persoonvermelding", + "initAppError": "Er is een fout opgetreden bij het laden van de app", + "requestedKeyVerification": "{sender} vraagt een sleutelverificatie", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sessionLostBody": "Je sessie is verlopen. Meldt alsjeblieft deze fout aan de ontwikkelaars via deze link {url}. De foutmelding is: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Andere deelnemers in de chat kunnen zien wanneer je een bericht aan het typen bent.", + "sendCanceled": "Versturen geannuleerd", + "opacity": "Doorzichtigheid:", + "verifyOtherUserDescription": "Als je een persoon verifieert ben je er zeker van dat je echt met haar contact hebt. 💪\n\nWanneer je een verificatie start ziet de persoon een popup in de app. Hier staat een serie van emoji's of getallen die je met elkaar moet vergelijken.\n\nDe beste manier om dit te doen is in persoon of met een videogesprek. 👭", + "changeTheVisibilityOfChatHistory": "Zichtbaarheid van de chat-geschiedenis wijzigen", + "whatIsAHomeserver": "Wat is een server?", + "sendRoomNotifications": "@room-meldingen versturen", + "noticeChatBackupDeviceVerification": "Opmerking: Als al je apparaten zijn verbonden met de chat back-up worden ze automatisch geverifieerd.", + "notificationRuleMemberEvent": "Chat-gebeurtenis uitschakelen", + "notificationRuleSuppressNotices": "Automatische berichten uitschakelen", + "setWallpaper": "Achtergrond instellen", + "oneOfYourDevicesIsNotVerified": "Een van jouw apparaten is niet geverifieerd", + "contactServerAdmin": "Contact opnemen met serverbeheerder", + "manageAccount": "Account beheren", + "noContactInformationProvided": "Server geeft geen geldige contactinformatie", + "waitingForServer": "Wachten op server...", + "generalNotificationSettings": "Algemene melding instellingen", + "notificationRuleInviteForMeDescription": "Stuur een melding wanneer je wordt uitgenodigd voor een chat.", + "notificationRuleSuppressNoticesDescription": "Meldingen van automatische accounts zoals bots uitschakelen.", + "notificationRuleInviteForMe": "Persoonlijke uitnodiging", + "inviteOtherUsers": "Personen voor deze chat uitnodigen", + "changeTheChatPermissions": "Chatrechten wijzigen", + "changeTheCanonicalRoomAlias": "Standaard publiek chat-adres wijzigen", + "blur": "Vervaag:", + "isReadyForKeyVerification": "{sender} is klaar voor de sleutelverificatie", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} start een sleutelverificatie", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "acceptedKeyVerification": "{sender} accepteerde de sleutelverificatie", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} annuleerde de sleutelverificatie", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "knockRestricted": "Kloppen is beperkt", + "goToSpace": "Ga naar space: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "contactServerSecurity": "Contact opnemen met serverbeveiliger", + "newChatRequest": "📩 Nieuw chat verzoek", + "updateInstalled": "🎉 Update {version} geïnstalleerd!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "discoverHomeservers": "Ontdek servers", + "changelog": "Wijzigingengeschiedenis", + "loginWithMatrixId": "Inloggen met Matrix-ID", + "calculatingFileSize": "Bestandsgrootte berekenen...", + "sendingAttachment": "Bijlage versturen...", + "generatingVideoThumbnail": "Video-voorbeeld genereren...", + "prepareSendingAttachment": "Bijlage versturen voorbereiden...", + "compressVideo": "Video comprimeren...", + "serverLimitReached": "Server limiet bereikt! Wacht {seconds} seconden...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "version": "Versie", + "supportPage": "Supportpagina", + "serverInformation": "Server-informatie:", + "name": "Naam", + "verifyOtherDeviceDescription": "Een geverifieerd ander apparaat zorgt ervoor dat de apparaten sleutels uitwisselen, wat je beveiliging versterkt. 💪 Als je de verificatie start verschijnt er een popup op beide apparaten. Hier staat een reeks emoji's of getallen die je met elkaar moet vergelijken. Het is handig om beide apparaten bij de hand te hebben voordat je de verificatie start. 🤳", + "commandHint_unignore": "Herstel de negeerde Matrix-ID", + "forwardMessageTo": "Bericht doorsturen naar {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "restoreSessionBody": "De app probeert nu je sessie te herstellen van een back-up. Meldt alsjeblieft deze fout aan de ontwikkelaars via deze link {url}. De foutmelding is: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceipts": "Leesbevestigingen versturen", + "formattedMessages": "Opgemaakte berichten", + "chatPermissionsDescription": "Stel het gewenste rechten-niveau in voor bepaalde acties in deze chat. Het rechten-niveau 0, 50 en 100 zijn gebruikelijk voor deelnemer, moderator en beheerder, maar elke verdeling is mogelijk.", + "changeTheDescriptionOfTheGroup": "Onderwerp wijzigen", + "userRole": "Rol", + "minimumPowerLevel": "{level} is het minimale rechten-niveau.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "Andere deelnemers van de chat kunnen zien of je een bericht hebt gelezen.", + "formattedMessagesDescription": "Geef rijke berichtinhoud weer zoals vetgedrukte tekst met markdown.", + "verifyOtherUser": "🔐 Persoon verifiëren", + "verifyOtherDevice": "🔐 Ander apparaat verifiëren", + "doesNotSeemToBeAValidHomeserver": "Dit lijkt geen ondersteunde server. Verkeerde URL?", + "sendingAttachmentCountOfCount": "Bijlage versturen {index} van {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "continueText": "Doorgaan", + "welcomeText": "Hallo hallo 👋 Dit is FluffyChat. Je kan inloggen op elke server die werkt met https://matrix.org. En dan chat je met iedereen. Het is een groot decentraal chat-netwerk!", + "appWantsToUseForLogin": "Inloggen met '{server}'", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Hierbij sta je toe dat de app en website informatie over je delen.", + "open": "Open", + "appIntroduction": "FluffyChat laat je chatten met je vrienden tussen verschillende chat-netwerken. Lees meer op https://matrix.org of tik *Continue*.", + "completedKeyVerification": "{sender} ronde de sleutelverificatie af", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "homeserverDescription": "Al je data is opgeslagen op de server, net als bij een email-leverancier. Je kan kiezen welke server je gebruikt en toch communiceren met iedereen. Lees meer op https://matrix.org.", + "notificationRuleContainsDisplayName": "Bevat de naam", + "notificationRuleIsUserMentionDescription": "Stuur een melding als je direct genoemd wordt in een bericht.", + "notificationRuleContainsDisplayNameDescription": "Stuur een melding als je genoemd wordt in een bericht.", + "notificationRuleIsRoomMention": "Kamervermelding", + "notificationRuleIsRoomMentionDescription": "Stuur een melding als er een kamervermelding is.", + "notificationRuleRoomnotif": "Kamermelding", + "notificationRuleRoomnotifDescription": "Stuur een melding als een bericht '@room' bevat.", + "notificationRuleTombstone": "Sluitingsbericht", + "notificationRuleReaction": "Reactie", + "notificationRuleRoomServerAcl": "Kamer Server ACL", + "notificationRuleTombstoneDescription": "Stuur een melding bij een chat-sluitingsbericht.", + "notificationRuleReactionDescription": "Meldingen voor reacties uitschakelen.", + "notificationRuleRoomServerAclDescription": "Meldingen voor kamer server toegangscontrolelijst (ACL) uitschakelen.", + "notificationRuleSuppressEdits": "Bewerkingen uitschakelen", + "notificationRuleCall": "Oproep", + "notificationRuleSuppressEditsDescription": "Meldingen voor bewerkte berichten uitschakelen.", + "notificationRuleEncryptedRoomOneToOneDescription": "Stuur een melding bij berichten in versleutelde een-op-een chats.", + "notificationRuleEncryptedRoomOneToOne": "Versleutelde een-op-een chat", + "notificationRuleRoomOneToOne": "Een-op-een chat", + "notificationRuleMessage": "Bericht", + "notificationRuleEncrypted": "Versleuteld", + "notificationRuleRoomOneToOneDescription": "Stuur een melding bij berichten in een-op-een chats.", + "notificationRuleMessageDescription": "Stuur een melding bij algemene berichten.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleEncryptedDescription": "Stuur een melding bij berichten in versleutelde chats.", + "notificationRuleJitsiDescription": "Stuur een melding bij Jitsi widget-gebeurtenissen.", + "unknownPushRule": "Onbekende notificatieregel '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "notificationRuleServerAcl": "Server ACL-gebeurtenissen uitschakelen", + "notificationRuleServerAclDescription": "Meldingen over server ACL-gebeurtenissen uitschakelen.", + "more": "Meer", + "enterNewChat": "Nieuwe chat openen", + "crossVerifiedDevices": "Kruislings geverifieerde apparaten", + "allDevices": "Alle apparaten", + "shareKeysWithDescription": "Welke apparaten moeten vertrouwd worden zodat ze je berichten kunnen lezen in versleutelde chats?", + "verifiedDevicesOnly": "Alleen geverifieerde apparaten", + "crossVerifiedDevicesIfEnabled": "Kruislings geverifieerde apparaten als ingeschakeld", + "shareKeysWith": "Deel sleutels met...", + "notificationRuleCallDescription": "Stuur een melding bij oproepen.", + "deletePushRuleCanNotBeUndone": "Als je deze melding-instelling verwijderd, kan dit niet ongedaan gemaakt worden.", + "takeAPhoto": "Foto maken", + "recordAVideo": "Video opnemen", + "optionalMessage": "(Optioneel) bericht...", + "notSupportedOnThisDevice": "Niet ondersteund op dit apparaat", + "commandHint_roomupgrade": "Upgradeer deze chat naar de aangegeven kamerversie", + "setCustomPermissionLevel": "Aangepast rechten-niveau instellen", + "setPermissionsLevelDescription": "Kies hieronder een standaard rol of voer een aangepast rechten-niveau in tussen 0 en 100.", + "ignoreUser": "Persoon negeren", + "normalUser": "Normaal persoon", + "pleaseWaitUntilInvited": "Wacht even alsjeblieft tot iemand van de chat je uitnodigt.", + "approve": "Goedkeuren", + "youHaveKnocked": "Je hebt geklopt", + "sentVoiceMessage": "🎙️ {duration} - Spraakbericht van {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "countInvited": "{count} uitgenodigd", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "checkList": "Checklist", + "commandHint_logout": "Uw huidige apparaat uitloggen", + "commandHint_logoutall": "Alle actieve apparaten uitloggen", + "displayNavigationRail": "Navigatiebalk op mobiel tonen", + "moreEvents": "Meer gebeurtenissen", + "customReaction": "Aangepaste reactie", + "declineInvitation": "Uitnodiging afwijzen", + "noMessagesYet": "Nog geen berichten", + "longPressToRecordVoiceMessage": "Lang drukken om een spraakbericht op te nemen.", + "pause": "Pauzeer", + "resume": "Hervat", + "donate": "Doneer", + "newSubSpace": "Nieuwe sub-space", + "moveToDifferentSpace": "Naar andere space verplaatsen", + "moveUp": "Omhoog verplaatsen", + "moveDown": "Omlaag verplaatsen", + "removeFromSpaceDescription": "De chat zal worden verwijderd uit de space, maar blijft in je chats.", + "countChats": "{chats} chats", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "{spaces} personen in space", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "{spaces} personen in space kunnen kloppen", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "startedAPoll": "{username} is een peiling begonnen.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Peiling", + "startPoll": "Peiling starten", + "endPoll": "Peiling beëindigen", + "answersVisible": "Zichtbaar invullen", + "answersHidden": "Antwoorden verborgen", + "pollQuestion": "Peiling vraag", + "answerOption": "Antwoord optie", + "addAnswerOption": "Antwoord optie toevoegen", + "allowMultipleAnswers": "Meerdere antwoorden toestaan", + "pollHasBeenEnded": "Peiling is geëindigd", + "countVotes": "{count, plural, =1{Één stem} other{{count} stemmen}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "Antwoorden zullen zichtbaar zijn wanneer de peiling is geëindigd", + "replyInThread": "Antwoord in gesprek", + "countReplies": "{count, plural, =1{Één antwoord} other{{count} antwoorden}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Gesprek", + "backToMainChat": "Terug naar hoofdchat", + "saveChanges": "Wijzigingen opslaan", + "createSticker": "Sticker of emoji maken", + "useAsSticker": "Gebruik als sticker", + "useAsEmoji": "Gebruik als emoji", + "stickerPackNameAlreadyExists": "Stickerpakketnaam bestaat al", + "newStickerPack": "Nieuw stickerpakket", + "stickerPackName": "Stickerpakketnaam", + "attribution": "Toeschrijving", + "skipChatBackup": "Chatback-up overslaan", + "skipChatBackupWarning": "Weet je het zeker? Zonder chat back-up verlies je toegang tot je berichten als je van apparaat wisselt.", + "loadingMessages": "Berichten laden", + "setupChatBackup": "Chatback-up instellen", + "changedTheChatDescription": "{username} heeft het onderwerp gewijzigd", + "changedTheChatName": "{username} heeft de chatnaam gewijzigd", + "noMoreResultsFound": "Geen resultaten meer gevonden", + "chatSearchedUntil": "Chat doorzocht tot {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "Federatie Basis URL", + "clientWellKnownInformation": "Client-Well-Known Informatie:", + "baseUrl": "Basis URL", + "identityServer": "Identiteit Server:", + "versionWithNumber": "Versie: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Logs", + "advancedConfigs": "Geavanceerde configuratie", + "advancedConfigurations": "Geavanceerde configuraties", + "signInWithLabel": "Log in met:", + "signIn": "Log in", + "createNewAccount": "Registreer nieuw account", + "signUpGreeting": "FluffyChat is decentraal! Kies een server waar je wil voor jouw account en laten we gaan!", + "signInGreeting": "Heb je al een Matrix account? Welkom terug! Kies jouw server en log in.", + "appIntro": "Met FluffyChat kan je chatten met je vrienden. Het is een veilige en decentrale [matrix] app! Lees meer op https://matrix.org als je wilt of kies registreren.", + "theProcessWasCanceled": "Het proces is geannuleerd.", + "join": "Deelnemen", + "searchOrEnterHomeserverAddress": "Zoek of voer serveradres in", + "matrixId": "Matrix-ID", + "setPowerLevel": "Rechtenniveau instellen", + "makeModerator": "Maak moderator", + "makeAdmin": "Maak beheerder", + "removeModeratorRights": "Verwijder moderator-rechten", + "removeAdminRights": "Verwijder beheerder-rechten", + "powerLevel": "Rechtenniveau", + "setPowerLevelDescription": "Rechtenniveau's definiëren wat een persoon mag doen in deze chat en variëren meestal tussen 0 en 100.", + "owner": "Eigenaar" +} diff --git a/lib/l10n/intl_pl.arb b/lib/l10n/intl_pl.arb new file mode 100644 index 000000000..167540226 --- /dev/null +++ b/lib/l10n/intl_pl.arb @@ -0,0 +1,3389 @@ +{ + "@@locale": "pl", + "@@last_modified": "2021-08-14 12:41:09.943634", + "about": "O aplikacji", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Akceptuj", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} zaakceptował/-a zaproszenie", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Konto", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} aktywował/-a szyfrowanie od końca do końca", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Dodaj adres email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Administrator", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} odebrał/-a połączenie", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Każdy może dołączyć", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "Archiwum", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Czy użytkownicy-goście mogą dołączyć", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Czy na pewno?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Czy na pewno chcesz się wylogować?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Aby zalogować inną osobę, proszę wpisać hasło przechowywania lub klucz odzyskiwania.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Zaakceptować tą prośbę weryfikacji od {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "Serwer obsługuje typy logowania:\n{serverVersions}\nAle ta aplikacja obsługuje tylko:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "Serwer obsługuje wersje Spec:\n{serverVersions}\nAle aplikacja obsługuje tylko {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Ban w czacie", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Zbanowany/-a", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} zbanował/-a {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Zablokuj urządzenie", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Zablokowane", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Wiadomości botów", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Anuluj", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Zmień nazwę urządzenia", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} zmienił/-a zdjęcie profilowe", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} zmienił/-a opis czatu na '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} zmienił/-a nazwę czatu na '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} zmienił/-a uprawnienia w czacie", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} zmienił/-a swoją nazwę wyświetlaną na '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} zmienił/-a zasady dostępu dla gości", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} zmienił/-a zasady dostępu dla gości na {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} zmienił/-a widoczność historii", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} zmienił/-a widoczność historii na {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} zmienił/-a zasady wejścia", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} zmienił/-a zasady wejścia na {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} zmienił/-a zdjęcie profilowe", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} zmienił/-a alias pokoju", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} zmienił/-a link z zaproszeniem do pokoju", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Zmień hasło", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Zmień serwer domyślny", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Zmień swój styl", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Zmień nazwę grupy", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Szyfrowanie zostało uszkodzone", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Czat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Kopia zapasowa czatów", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Twoje stare wiadomości są zabezpieczone kluczem odzyskiwania. Uważaj żeby go nie zgubić.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Szczegóły czatu", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Czaty", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Wybierz silne hasło", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Wyczyść archiwum", + "@clearArchive": {}, + "close": "Zamknij", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Zbanuj użytkownika w tym pokoju", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Wyślij tekst sformatowany w HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Zaproś użytkownika do pokoju", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Dołącz do podanego pokoju", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Usuń tego użytkownika z tego pokoju", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Opuść ten pokój", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Opisz siebie", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Ustaw swoje zdjęcie w tym pokoju (przez mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Ustaw swoją nazwę wyświetlaną w tym pokoju", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Ustaw poziom uprawnień tego użytkownika (domyślnie: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Wyślij niesformatowany tekst", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Wyślij odpowiedź jako reakcję", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Wyślij wiadomość", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Odbanuj użytkownika w tym pokoju", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Nieprawidłowe polecenie", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} nie jest poleceniem.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Porównaj emoji", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Porównaj cyfry", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Potwierdź", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Połącz", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt został zaproszony do grupy", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Zawiera nazwę wyświetlaną", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Zawiera nazwę użytkownika", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Skopiowano do schowka", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopiuj", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Skopiuj do schowka", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Nie można odszyfrować wiadomości: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} uczestników", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Stwórz", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} utworzył/-a czat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Obecnie aktywny/-a", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Ciemny", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date} {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}.{month}.{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "To zdezaktywuje twoje konto. To jest nieodwracalne! Na pewno chcesz to zrobić?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "delete": "Usuń", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Usuń konto", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Usuń wiadomość", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Urządzenie", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Identyfikator urządzenia", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Urządzenia", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Czaty bezpośrednie", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Nazwa wyświetlana została zmieniona", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Pobierz plik", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Edytuj", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Edytuj nazwę wyświetlaną", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Zmień aliasy pokoju", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emotikon już istnieje!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Nieprawidłowy kod emotikonu!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Paczki emotikonów dla pokoju", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Ustawienia emotikonów", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Skrócony kod emotikonu", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Musisz wybrać kod emotikonu oraz obraz!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Pusty czat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Włącz paczkę emotikonów globalnie", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Nie będziesz już mógł wyłączyć szyfrowania. Jesteś pewny?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Szyfrowane", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Szyfrowanie", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Szyfrowanie nie jest włączone", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} zakończył/-a połączenie", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Wpisz adres e-mail", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Wpisz swój serwer domowy", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Wszystko gotowe!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "fileName": "Nazwa pliku", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Przekaż", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Od dołączenia", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Od zaproszenia", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Przejdź do nowego pokoju", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Grupa", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Grupa jest publiczna", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grupa z {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Goście są zakazani", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Goście mogą dołączyć", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} wycofał/-a zaproszenie dla {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Pomoc", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Ukryj informacje o usuniętych zdarzeniach", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Ukryj nieznane wdarzenia", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "id": "Identyfikator", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Tożsamość", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Ignorowani użytkownicy", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Nacisnąłem na link", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Złe hasło bezpieczeństwa lub klucz odzyskiwania", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Zaproś kontakt", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Zaproś kontakty do {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Zaproszono", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} zaprosił/-a {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Tylko zaproszeni użytkownicy", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Zaproszenie dla mnie", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} zaprosił/-a Cię do FluffyChat.\n1. Odwiedź fluffychat.im i zainstaluj aplikację\n2. Zarejestuj się lub zaloguj\n3. Otwórz link zaproszenia:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "pisze…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} dołączył/-a do czatu", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Dołącz do pokoju", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} wyrzucił/-a {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} wyrzucił/-a i zbanował/-a {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Wyrzuć z czatu", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Ostatnio widziano {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Opuść", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Opuścił/-a czat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licencja", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Jasny", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Załaduj jeszcze {count} uczestników", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Ładowanie… Proszę czekać.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Załaduj więcej…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Zaloguj się", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Zaloguj się do {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Wyloguj się", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Zmiany członków", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Wzmianka", + "@mention": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Wycisz czat", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Należy pamiętać, że Pantalaimon wymaga na razie szyfrowania od końca do końca.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Nowa rozmowa", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nowa wiadomość we FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nowa prośba o weryfikację!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Dalej", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Nie", + "@no": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Możesz aktywować szyfrowanie dopiero kiedy pokój nie będzie publicznie dostępny.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Wygląda na to, że Twoje urządzenie nie obsługuje Firebase Cloud Messaging. Aby wciąż otrzymywać powiadomienia push, zalecamy istalację ntfy. Używając ntfy lub inengo zunifikowanego dostawcy powiadomień push, możesz bezpiecznie otrzymywać takowe powiadomienia. Ntfy można pobrać ze sklepu Google Play Store lub z F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Brak", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Nie dodałeś/-aś jeszcze sposobu odzyskiwania swojego hasła.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Brak uprawnień", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Nie znaleziono pokojów…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Powiadomienia", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Powiadomienia są włączone dla tego konta", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ojej! Coś poszło nie tak…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Otwórz aplikację by odczytać wiadomości", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Otwórz aparat", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "password": "Hasło", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Hasło zostało zmienione", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "people": "Osoby", + "@people": { + "type": "String", + "placeholders": {} + }, + "pin": "Przypnij", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Otwórz {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnterYourPassword": "Wprowadź swoje hasło", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Wpisz swoją nazwę użytkownika", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Wykonaj instrukcje na stronie internetowej i naciśnij „dalej”.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Publiczne pokoje", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Reguły push", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "recording": "Nagranie", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} usunął/-ęła zdarzenie", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "register": "Zarejestruj", + "@register": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} odrzucił/-a zaproszenie", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Dołącz ponownie", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Usuń", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Usuń wszystkie inne urządzenia", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Usunięta przez {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Usuń urządzenie", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Odbanuj w czacie", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "Odpowiedz", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Prośba o pozwolenie", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Wersja pokoju", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Zobaczone przez {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Wyślij", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Wyślij wiadomość", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Wyślij plik", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Wyślij obraz", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} wysłał/-a plik", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} wysłał/-a plik dżwiękowy", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} wysłał/-a zdjęcie", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} wysłał/-a naklejkę", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} wysłał/-a film", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Ustaw jako główny alias", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Ustaw link z zaproszeniem", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Ustaw status", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Ustawienia", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Udostępnij", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} udostępnił/-a swoją lokalizację", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "showPassword": "Pokaż hasło", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Kod żródłowy", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Jak się masz dziś?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synchronizowanie… Proszę czekać.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "System", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Przenieś z innego urządzenia", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Spróbuj wysłać ponownie", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} odbanował/-a {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unknownDevice": "Nieznane urządzenie", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Nieznany algorytm szyfrowania", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Nieznane zdarzenie '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Wyłącz wyciszenie", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Odepnij", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 unread chat} other{{unreadCount} unread chats}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} oraz {count} pozostałych pisze…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} i {username2} piszą…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} pisze…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} opuścił/-a czat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Nazwa użytkownika", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} wysłał/-a zdarzenie {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Zweryfikowane", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "zweryfikuj", + "@verify": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Rozmowa wideo", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Widoczność historii czatu", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Widoczny dla wszystkich użytkowników", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Widoczne dla każdego", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Wiadomość głosowa", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Tapeta:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Kto może dołączyć do tej grupy", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Napisz wiadomość…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Tak", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Ty", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Nie uczestniczysz już w tym czacie", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Zostałeś/-aś zbanowany/-a w tym czacie", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "allChats": "Wszystkie", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignoruj", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Brak połączenia z serwerem", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Uzyskiwanie lokalizacji…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "addAccount": "Dodaj konto", + "@addAccount": {}, + "serverRequiresEmail": "Ten serwer wymaga potwierdzenia Twojego adresu email w celu rejestracji.", + "@serverRequiresEmail": {}, + "or": "Lub", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Uczestnik", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Nie pamiętam hasła", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Proszę wybrać", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Proszę kliknij w odnośnik wysłany w wiadomości e-mail, aby kontynuować.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Proszę podaj 4 cyfry. By wyłączyć blokadę pozostaw puste.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Usuń swoje zdjęcie", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Zamień pokój na nowszą wersję", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Zgłoś wiadomość", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Zapisz plik", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "security": "Bezpieczeństwo", + "@security": { + "type": "String", + "placeholders": {} + }, + "search": "Szukaj", + "@search": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Wyślij jako tekst", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Wyślij dźwięk", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Wyślij wiadomości", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Wyślij oryginał", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Wyślij naklejkę", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Wyślij film", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} rozpoczął/-ęła rozmowę", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "yourPublicKey": "Twój klucz publiczny", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "enableMultiAccounts": "(BETA) Włącza obsługę wielu kont na tym urządzeniu", + "@enableMultiAccounts": {}, + "pickImage": "Wybierz obraz", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Odzyskiwanie hasła", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Otwórz w mapach", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "link": "Link", + "@link": {}, + "roomHasBeenUpgraded": "Pokój został zaktualizowany", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Powtórz hasło", + "@repeatPassword": {}, + "all": "Wszystkie", + "@all": { + "type": "String", + "placeholders": {} + }, + "appLock": "Blokada aplikacji", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Zgadzają się", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Wyślij enterem", + "@sendOnEnter": {}, + "autoplayImages": "Automatycznie odtwarzaj animowane naklejki i emotikony", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "cantOpenUri": "Nie można otworzyć linku {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "configureChat": "Konfiguruj czat", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Adres serwera", + "@homeserver": {}, + "locationDisabledNotice": "Usługi lokalizacji są wyłączone. Proszę włącz je aby móc udostępnić swoją lokalizację.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "Jedno z twoich urządzeń zostało wylogowane", + "@oneClientLoggedOut": {}, + "privacy": "Prywatność", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Nie zgadzają się", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Przełącz ulubione", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Kopia zapasowa Twojego czatu została ustawiona.", + "@yourChatBackupHasBeenSetUp": {}, + "chatHasBeenAddedToThisSpace": "Czat został dodany do tej przestrzeni", + "@chatHasBeenAddedToThisSpace": {}, + "contentHasBeenReported": "Treść została zgłoszona administratorom serwera", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Edytuj zdjęcie pokoju", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Rozmiar fontu", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "groups": "Grupy", + "@groups": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Brak uprawnień. Proszę zezwól aplikacji na dostęp do lokalizacji aby móc ją udostępnić.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Nagraj film", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "messages": "Wiadomości", + "@messages": { + "type": "String", + "placeholders": {} + }, + "offensive": "Obraźliwe", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Podaj swój PIN", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "reason": "Powód", + "@reason": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "Usuń wiadomość", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Ustaw niestandardowe emotikony", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Dzięki tym adresom możesz odzyskać swoje hasło.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Ustaw jako publiczną", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Udostępnij lokalizację", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Ustaw poziom uprawnień", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "skip": "Pomiń", + "@skip": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Nazwa przestrzeni", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Przełącz wyciszone", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Oznacz przeczytane/nieprzeczytane", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Niedostępne", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "publish": "Opublikuj", + "@publish": {}, + "scanQrCode": "Skanuj kod QR", + "@scanQrCode": {}, + "createNewSpace": "Nowa przestrzeń", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "offline": "Offline", + "@offline": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Dodaj do przestrzeni", + "@addToSpace": {}, + "changeYourAvatar": "Zmień swoje zdjęcie", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "commandHint_clearcache": "Wyczyść pamięć podręczną", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Stwórz pusty czat\nUżyj --no-encryption by wyłączyć szyfrowanie", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_dm": "Rozpocznij czat bezpośredni\nUżyj --no-encryption by wyłączyć szyfrowanie", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "editBlockedServers": "Edytuj zablokowane serwery", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Włącz szyfowanie", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Domyślny poziom uprawnień dla nowych użytkowników", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Ojej! Wystąpił błąd podczas ustawiania powiadomień push.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "reject": "Odrzuć", + "@reject": { + "type": "String", + "placeholders": {} + }, + "online": "Online", + "@online": { + "type": "String", + "placeholders": {} + }, + "status": "Status", + "@status": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Zbyt wiele żądań. Proszę spróbować później.", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "commandHint_discardsession": "Odrzuć sesję", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "warning": "Uwaga!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Informacje o wiadomości", + "@messageInfo": {}, + "time": "Czas", + "@time": {}, + "messageType": "Rodzaj wiadomości", + "@messageType": {}, + "separateChatTypes": "Oddzielenie czatów bezpośrednich i grupowych", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Oczekiwanie na zaakceptowanie prośby przez drugą osobę…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Oczekiwanie na zaakceptowanie emoji przez drugą osobę…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Wybierz kod dostępu", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "unblockDevice": "Odblokuj urządzenie", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Dlaczego chcesz to zgłosić?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "removeFromSpace": "Usuń z przestrzeni", + "@removeFromSpace": {}, + "extremeOffensive": "Bardzo obraźliwe", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Błąd w ustalaniu lokalizacji: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "howOffensiveIsThisContent": "Jak bardzo obraźliwa jest ta treść?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Nieobraźliwe", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "Klucz odzyskiwania", + "@recoveryKey": {}, + "recoveryKeyLost": "Utracono klucz odzyskiwania?", + "@recoveryKeyLost": {}, + "sentCallInformations": "{senderName} wysłał/-a informacje o połączeniu", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "singlesignon": "Pojedyncze logowanie", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "startFirstChat": "Rozpocznij swój pierwszy czat", + "@startFirstChat": {}, + "verifyStart": "Rozpocznij weryfikację", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Pomyślnie zweryfikowano!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Weryfikowanie innego konta", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Oczekiwanie na zaakceptowanie numerów przez drugą osobę…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "sender": "Nadawca", + "@sender": {}, + "openGallery": "Otwórz galerię", + "@openGallery": {}, + "start": "Start", + "@start": {}, + "pleaseEnterRecoveryKeyDescription": "Aby odblokować wcześniejsze wiadomości, wprowadź swój klucz odzyskiwania, który został wygenerowany w poprzedniej sesji. Twój klucz odzyskiwania NIE jest Twoim hasłem.", + "@pleaseEnterRecoveryKeyDescription": {}, + "videoWithSize": "Film ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "hydrateTorLong": "Czy ostatnio eksportowałeś/-aś swoją sesję na TOR? Szybko ją zaimportuj i kontynuuj rozmowy.", + "@hydrateTorLong": {}, + "dehydrateTorLong": "W przypadku użytkowników sieci TOR zaleca się eksportowanie sesji przed zamknięciem okna.", + "@dehydrateTorLong": {}, + "hydrate": "Przywracanie z pliku kopii zapasowej", + "@hydrate": {}, + "noMatrixServer": "{server1} nie jest serwerem Matriksa, czy chcesz zamiast niego użyć {server2}?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "hydrateTor": "Użytkownicy TOR: Importuj eksport sesji", + "@hydrateTor": {}, + "numUsersTyping": "{count} użytkowników pisze…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "onlineKeyBackupEnabled": "Kopia zapasowa kluczy online jest włączona", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKey": "Wprowadź swój klucz odzyskiwania:", + "@pleaseEnterRecoveryKey": {}, + "submit": "Odeślij", + "@submit": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Wysłaliśmy Ci wiadomość e-mail", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "unverified": "Niezweryfikowane", + "@unverified": {}, + "wipeChatBackup": "Wymazać kopię zapasową czatu, aby utworzyć nowy klucz odzyskiwania?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Kto może wykonywać jakie czynności", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "reportUser": "Zgłoś użytkownika", + "@reportUser": {}, + "dismiss": "Odrzuć", + "@dismiss": {}, + "markAsRead": "Oznacz jako przeczytane", + "@markAsRead": {}, + "passphraseOrKey": "fraza dostępu lub klucz odzyskiwania", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "openChat": "Otwórz czat", + "@openChat": {}, + "addToSpaceDescription": "Wybierz przestrzeń, do której ten czat ma być dodany.", + "@addToSpaceDescription": {}, + "supposedMxid": "To powinno być {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasdm": "Oznacz jako pokój wiadomości bezpośrednich dla podanego Matrix ID", + "@commandHint_markasdm": {}, + "confirmMatrixId": "Potwierdź swój identyfikator Matrix w celu usunięcia konta.", + "@confirmMatrixId": {}, + "commandHint_markasgroup": "Oznacz jako grupę", + "@commandHint_markasgroup": {}, + "noEmotesFound": "Nie znaleziono żadnych emotikonów. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "dehydrate": "Eksportuj sesję i wymaż urządzenie", + "@dehydrate": {}, + "dehydrateWarning": "Tego nie można cofnąć. Upewnij się, że plik kopii zapasowej jest bezpiecznie przechowywany.", + "@dehydrateWarning": {}, + "dehydrateTor": "Użytkownicy TOR: Eksportuj sesję", + "@dehydrateTor": {}, + "unsupportedAndroidVersion": "Nieobsługiwana wersja systemu Android", + "@unsupportedAndroidVersion": {}, + "widgetCustom": "Własny", + "@widgetCustom": {}, + "widgetEtherpad": "Notatka", + "@widgetEtherpad": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "pinMessage": "Przypnij do pokoju", + "@pinMessage": {}, + "confirmEventUnpin": "Czy na pewno chcesz trwale odpiąć wydarzenie?", + "@confirmEventUnpin": {}, + "youJoinedTheChat": "Dołączono do czatu", + "@youJoinedTheChat": {}, + "user": "Użytkownik", + "@user": {}, + "custom": "Własne", + "@custom": {}, + "newGroup": "Nowa grupa", + "@newGroup": {}, + "newSpace": "Nowa przestrzeń", + "@newSpace": {}, + "fileIsTooBigForServer": "Nie udało się wysłać! Ten serwer obsługuje załączniki o maksymalnej wielkości {max}.", + "@fileIsTooBigForServer": {}, + "youBannedUser": "Zbanowałeś/-aś {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "users": "Użytkownicy", + "@users": {}, + "countFiles": "{count} plików", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noOtherDevicesFound": "Nie znaleziono innych urządzeń", + "@noOtherDevicesFound": {}, + "widgetUrlError": "Niepoprawny URL.", + "@widgetUrlError": {}, + "widgetNameError": "Podaj nazwę wyświetlaną.", + "@widgetNameError": {}, + "encryptThisChat": "Zaszyfruj ten czat", + "@encryptThisChat": {}, + "disableEncryptionWarning": "Ze względów bezpieczeństwa nie można wyłączyć szyfrowania w czacie, w którym zostało ono wcześniej włączone.", + "@disableEncryptionWarning": {}, + "deviceKeys": "Klucze urządzenia:", + "@deviceKeys": {}, + "emailOrUsername": "Adres e-mail lub nazwa użytkownika", + "@emailOrUsername": {}, + "indexedDbErrorLong": "Przechowywanie wiadomości niestety nie jest domyślnie włączone w trybie prywatnym.\nOdwiedź\n - about:config\n - ustaw dom.indexedDB.privateBrowsing.enabled na true\nW przeciwnym razie nie jest możliwe uruchomienie FluffyChat.", + "@indexedDbErrorLong": {}, + "saveKeyManuallyDescription": "Zapisz ten klucz ręcznie, uruchamiając systemowe okno dialogowe udostępniania lub schowek.", + "@saveKeyManuallyDescription": {}, + "screenSharingTitle": "udostępnianie ekranu", + "@screenSharingTitle": {}, + "appearOnTopDetails": "Umożliwia wyświetlanie aplikacji nad innymi (nie jest to konieczne, jeśli FluffyChat jest już ustawiony jako konto do dzwonienia)", + "@appearOnTopDetails": {}, + "noKeyForThisMessage": "Może się to zdarzyć, jeśli wiadomość została wysłana przed zalogowaniem się na to konto na tym urządzeniu.\n\nMożliwe jest również, że nadawca zablokował Twoje urządzenie lub coś poszło nie tak z połączeniem internetowym.\n\nJesteś w stanie odczytać wiadomość na innej sesji? W takim razie możesz przenieść z niej wiadomość! Wejdź w Ustawienia > Urządzenia i upewnij się, że Twoje urządzenia zweryfikowały się wzajemnie. Gdy następnym razem otworzysz pokój i obie sesje będą włączone, klucze zostaną przekazane automatycznie.\n\nNie chcesz stracić kluczy podczas wylogowania lub przełączania urządzeń? Upewnij się, że w ustawieniach masz włączoną kopię zapasową czatu.", + "@noKeyForThisMessage": {}, + "sorryThatsNotPossible": "Przepraszamy... to nie jest możliwe", + "@sorryThatsNotPossible": {}, + "noBackupWarning": "Uwaga! Bez włączenia kopii zapasowej czatu, stracisz dostęp do swoich zaszyfrowanych wiadomości. Zaleca się włączenie kopii zapasowej czatu przed wylogowaniem.", + "@noBackupWarning": {}, + "commandHint_googly": "Wyślij kręcące się oczka", + "@commandHint_googly": {}, + "callingPermissions": "Uprawnienia połączeń", + "@callingPermissions": {}, + "storeInAndroidKeystore": "Przechowaj w Android KeyStore", + "@storeInAndroidKeystore": {}, + "commandHint_cuddle": "Wyślij przytulenie", + "@commandHint_cuddle": {}, + "googlyEyesContent": "{senderName} wysyła ci kręcące się oczka", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} przytula cię", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} uściska cię", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_hug": "Wyślij uścisk", + "@commandHint_hug": {}, + "reactedWith": "{sender} zareagował/-a z {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "emojis": "Emoji", + "@emojis": {}, + "placeCall": "Zadzwoń", + "@placeCall": {}, + "voiceCall": "Połączenie głosowe", + "@voiceCall": {}, + "unsupportedAndroidVersionLong": "Ta funkcja wymaga nowszej wersji systemu Android. Sprawdź aktualizacje lub wsparcie Lineage OS.", + "@unsupportedAndroidVersionLong": {}, + "videoCallsBetaWarning": "Należy pamiętać, że połączenia wideo są obecnie w fazie beta. Mogą nie działać zgodnie z oczekiwaniami lub nie działać w ogóle na wszystkich platformach.", + "@videoCallsBetaWarning": {}, + "experimentalVideoCalls": "Eksperymentalne połączenia wideo", + "@experimentalVideoCalls": {}, + "indexedDbErrorTitle": "Problemy związane z trybem prywatnym", + "@indexedDbErrorTitle": {}, + "switchToAccount": "Przełącz na konto {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Następne konto", + "@nextAccount": {}, + "previousAccount": "Poprzednie konto", + "@previousAccount": {}, + "addWidget": "Dodaj widżet", + "@addWidget": {}, + "widgetVideo": "Film", + "@widgetVideo": {}, + "widgetName": "Nazwa", + "@widgetName": {}, + "errorAddingWidget": "Błąd podczas dodawania widżetu.", + "@errorAddingWidget": {}, + "youRejectedTheInvitation": "Odrzucono zaproszenie", + "@youRejectedTheInvitation": {}, + "youAcceptedTheInvitation": "👍 Zaakceptowałeś/-aś zaproszenie", + "@youAcceptedTheInvitation": {}, + "youHaveWithdrawnTheInvitationFor": "Wycofano zaproszenie dla {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Zostałeś/-aś zaproszony/-a przez {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Zaprosiłeś/-aś {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Wyrzuciłeś/-aś {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Wyrzuciłeś/-aś i zbanowałeś/-aś {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Odbanowałeś/-aś {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unlockOldMessages": "Odblokuj stare wiadomości", + "@unlockOldMessages": {}, + "storeInSecureStorageDescription": "Przechowaj klucz odzyskiwania w bezpiecznym magazynie tego urządzenia.", + "@storeInSecureStorageDescription": {}, + "storeInAppleKeyChain": "Przechowaj w pęku kluczy Apple", + "@storeInAppleKeyChain": {}, + "storeSecurlyOnThisDevice": "Przechowaj bezpiecznie na tym urządzeniu", + "@storeSecurlyOnThisDevice": {}, + "foregroundServiceRunning": "To powiadomienie pojawia się, gdy usługa w tle jest uruchomiona.", + "@foregroundServiceRunning": {}, + "screenSharingDetail": "Udostępniasz swój ekran w FluffyChat", + "@screenSharingDetail": {}, + "callingAccount": "Konto połączeń", + "@callingAccount": {}, + "callingAccountDetails": "Pozwala FluffyChat używać natywnej aplikacji do wykonywania połączeń w Androidzie.", + "@callingAccountDetails": {}, + "appearOnTop": "Wyświetlaj nad innymi", + "@appearOnTop": {}, + "otherCallingPermissions": "Mikrofon, kamera i inne uprawnienia FluffyChat", + "@otherCallingPermissions": {}, + "whyIsThisMessageEncrypted": "Dlaczego nie można odczytać tej wiadomości?", + "@whyIsThisMessageEncrypted": {}, + "enterSpace": "Wejdź do przestrzeni", + "@enterSpace": {}, + "enterRoom": "Wejdź do pokoju", + "@enterRoom": {}, + "allSpaces": "Wszystkie przestrzenie", + "@allSpaces": {}, + "numChats": "{number} czatów", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Ukryj nieistotne wydarzenia stanu", + "@hideUnimportantStateEvents": {}, + "doNotShowAgain": "Nie pokazuj ponownie", + "@doNotShowAgain": {}, + "wasDirectChatDisplayName": "Pusty czat (wcześniej {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "newSpaceDescription": "Przestrzenie pozwalają na konsolidację czatów i budowanie prywatnych lub publicznych społeczności.", + "@newSpaceDescription": {}, + "reopenChat": "Otwórz ponownie czat", + "@reopenChat": {}, + "fileHasBeenSavedAt": "Plik został zapisany w ścieżce {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "addToBundle": "Dodaj do pakietu", + "@addToBundle": {}, + "bundleName": "Nazwa pakietu", + "@bundleName": {}, + "editBundlesForAccount": "Edytuj pakiety dla tego konta", + "@editBundlesForAccount": {}, + "jumpToLastReadMessage": "Przejdź do ostatnio przeczytanej wiadomości", + "@jumpToLastReadMessage": {}, + "readUpToHere": "Czytaj do tego miejsca", + "@readUpToHere": {}, + "jump": "Przejdź", + "@jump": {}, + "removeFromBundle": "Usuń z tego pakietu", + "@removeFromBundle": {}, + "openLinkInBrowser": "Otwórz link w przeglądarce", + "@openLinkInBrowser": {}, + "allRooms": "Wszystkie czaty grupowe", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "😭 O nie! Coś poszło nie tak. Spróbuj ponownie później. Jeśli chcesz, możesz zgłosić ten błąd autorom programu.", + "@reportErrorDescription": {}, + "setColorTheme": "Ustal styl kolorów:", + "@setColorTheme": {}, + "tryAgain": "Spróbuj ponownie", + "@tryAgain": {}, + "messagesStyle": "Wiadomości:", + "@messagesStyle": {}, + "chatDescription": "Opis czatu", + "@chatDescription": {}, + "invalidServerName": "Nieprawidłowa nazwa serwera", + "@invalidServerName": {}, + "chatPermissions": "Uprawnienia w czacie", + "@chatPermissions": {}, + "signInWithPassword": "Zaloguj się z hasłem", + "@signInWithPassword": {}, + "setChatDescription": "Ustaw opis czatu", + "@setChatDescription": {}, + "importFromZipFile": "Zaimportuj z pliku .zip", + "@importFromZipFile": {}, + "redactedBy": "Usunięte przez {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "signInWith": "Zaloguj się z {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Opcjonalnie) Powód usunięcia tej wiadomości...", + "@optionalRedactReason": {}, + "exportEmotePack": "Eksportuj pakiet emotikonów jako .zip", + "@exportEmotePack": {}, + "inviteContactToGroupQuestion": "Czy chcesz zaprosić {contact} do czatu „{groupName}”?", + "@inviteContactToGroupQuestion": {}, + "redactedByBecause": "Usunięte przez {username} z powodu „{reason}”", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactMessageDescription": "Wiadomość zostanie usunięta u wszystkich uczestników tej rozmowy. Tego nie można cofnąć.", + "@redactMessageDescription": {}, + "invalidInput": "Nieprawidłowe dane!", + "@invalidInput": {}, + "report": "zgłoś", + "@report": {}, + "addChatDescription": "Dodaj opis tego czatu...", + "@addChatDescription": {}, + "directChat": "Czat bezpośredni", + "@directChat": {}, + "wrongPinEntered": "Wprowadzono nieprawidłowy kod PIN! Spróbuj ponownie za {seconds} sekund...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "Wysyłaj powiadomienie o pisaniu", + "@sendTypingNotifications": {}, + "inviteGroupChat": "📨 Zaproszenie do rozmowy grupowej", + "@inviteGroupChat": {}, + "invitePrivateChat": "📨 Zaproszenie do rozmowy prywatnej", + "@invitePrivateChat": {}, + "importEmojis": "Zaimportuj emotikony", + "@importEmojis": {}, + "noChatDescriptionYet": "Nie utworzono jeszcze opisu czatu.", + "@noChatDescriptionYet": {}, + "notAnImage": "To nie jest plik obrazu.", + "@notAnImage": {}, + "chatDescriptionHasBeenChanged": "Zmieniono opis czatu", + "@chatDescriptionHasBeenChanged": {}, + "profileNotFound": "Nie można odnaleźć użytkownika na serwerze. Być może wystąpił problem z połączeniem lub użytkownik nie istnieje.", + "@profileNotFound": {}, + "shareInviteLink": "Udostępnij link z zaproszeniem", + "@shareInviteLink": {}, + "emoteKeyboardNoRecents": "Tutaj pojawiają się ostatnio używane emotikony...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Ustaw wygląd:", + "@setTheme": {}, + "replace": "Zastąp", + "@replace": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "Spróbuj ponownie później lub wybierz inny serwer.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "createGroup": "Utwórz grupę", + "@createGroup": {}, + "importNow": "Zaimportuj", + "@importNow": {}, + "invite": "Zaproszenie", + "@invite": {}, + "block": "Zablokuj", + "@block": {}, + "blockedUsers": "Zablokowani użytkownicy", + "@blockedUsers": {}, + "blockUsername": "Ignoruj użytkownika", + "@blockUsername": {}, + "publicLink": "Link publiczny", + "@publicLink": {}, + "transparent": "Przezroczystość", + "@transparent": {}, + "select": "Zaznacz", + "@select": {}, + "calls": "Połączenia", + "@calls": {}, + "overview": "Podsumowanie", + "@overview": {}, + "learnMore": "Dowiedz się więcej", + "@learnMore": {}, + "groupName": "Nazwa grupy", + "@groupName": {}, + "startConversation": "Rozpocznij rozmowę", + "@startConversation": {}, + "newPassword": "Nowe hasło", + "@newPassword": {}, + "thisDevice": "To urządzenie:", + "@thisDevice": {}, + "gallery": "Galeria", + "@gallery": {}, + "files": "Pliki", + "@files": {}, + "discover": "Odkrywaj", + "@discover": {}, + "restricted": "Ograniczone", + "@restricted": {}, + "decline": "Odmów", + "@decline": {}, + "nothingFound": "Nic nie odnaleziono...", + "@nothingFound": {}, + "stickers": "Naklejki", + "@stickers": {}, + "noChatsFoundHere": "Nie jeszcze ma żadnych czatów. Wciśnij poniższy przycisk, aby rozpocząć nowy czat. ⤵️", + "@noChatsFoundHere": {}, + "hideRedactedMessagesBody": "Usunięte wiadomości nie będą widoczne w czacie.", + "@hideRedactedMessagesBody": {}, + "hideMemberChangesInPublicChats": "Ukryj zmiany członkostwa w publicznych czatach", + "@hideMemberChangesInPublicChats": {}, + "passwordRecoverySettings": "Ustawienia odzyskiwania hasła", + "@passwordRecoverySettings": {}, + "hideMemberChangesInPublicChatsBody": "W celu poprawienia czytelności, nie pokazuj w historii publicznego czatu, czy ktoś do niego dołączył lub go opuścił.", + "@hideMemberChangesInPublicChatsBody": {}, + "presenceStyle": "Obecność:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "invitedBy": "Zaproszony/-a przez {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "archiveRoomDescription": "Czat zostanie przeniesiony do archiwum. Pozostali użytkownicy będą mogli zobaczyć, że opuściłeś/-aś czat.", + "@archiveRoomDescription": {}, + "yourGlobalUserIdIs": "Twój globalny identyfikator to: ", + "@yourGlobalUserIdIs": {}, + "canceledKeyVerification": "{sender} anulował/-a weryfikację kluczy", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} jest gotowy/-a do weryfikacji kluczy", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "commandHint_ignore": "Ignoruj podany identyfikator Matrix", + "@commandHint_ignore": {}, + "commandHint_unignore": "Przestań ignorować podany identyfikator Matrix", + "@commandHint_unignore": {}, + "changeTheChatPermissions": "Zmień uprawnienia w czacie", + "@changeTheChatPermissions": {}, + "changelog": "Lista zmian", + "@changelog": {}, + "inviteOtherUsers": "Zaproś innych użytkowników do tego czatu", + "@inviteOtherUsers": {}, + "blockListDescription": "Możesz zablokować uciążliwych użytkowników. Nie będziesz widzieć ani otrzymywać wiadomości oraz zaproszeń od nich.", + "@blockListDescription": {}, + "formattedMessages": "Sformatowane wiadomości", + "@formattedMessages": {}, + "banUserDescription": "Użytkownik zostanie zbanowany w czacie i nie będzie w stanie dołączyć do czatu do momentu odbanowania.", + "@banUserDescription": {}, + "subspace": "Podprzestrzeń", + "@subspace": {}, + "sendReadReceipts": "Wysyłaj powiadomienia o przeczytaniu wiadomości", + "@sendReadReceipts": {}, + "verifyOtherDevice": "🔐 Zweryfikuj inne urządzenie", + "@verifyOtherDevice": {}, + "prepareSendingAttachment": "Przygotuj wysyłanie załącznika...", + "@prepareSendingAttachment": {}, + "acceptedKeyVerification": "{sender} zaakceptował/-a weryfikację kluczy", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "databaseMigrationTitle": "Baza danych jest zoptymalizowana", + "@databaseMigrationTitle": {}, + "hasKnocked": "{user} zapukał-/a", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "userLevel": "{level} - Użytkownik", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheVisibilityOfChatHistory": "Zmień widoczność historii czatu", + "@changeTheVisibilityOfChatHistory": {}, + "sendImages": "Wyślij {count} obrazów", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Nie utworzono jeszcze żadnego publicznego linku", + "@noPublicLinkHasBeenCreatedYet": {}, + "knock": "Zapukaj", + "@knock": {}, + "databaseBuildErrorBody": "Nie udało się utworzyć bazy danych SQLite. Aplikacja na razie spróbuje korzystać ze starej bazy. Prosimy zgłosić ten błąd autorom aplikacji na {url}. Treść błędu to: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Aplikacja spróbuje teraz odzyskać Twoją sesję z kopii zapasowej. Prosimy zgłosić ten błąd autorom aplikacji na {url}. Treść błędu to: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} rozpoczął/-ęła weryfikację kluczy", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Pozostali uczestnicy czatu mogą widzieć kiedy piszesz nową wiadomość.", + "@sendTypingNotificationsDescription": {}, + "sendReadReceiptsDescription": "Pozostali uczestnicy czatu mogą widzieć zobaczyć kiedy przeczytasz wiadomość.", + "@sendReadReceiptsDescription": {}, + "noDatabaseEncryption": "Szyfrowanie bazy danych nie jest obsługiwane na tej platformie", + "@noDatabaseEncryption": {}, + "thereAreCountUsersBlocked": "Obecnie jest {count} zablokowanych użytkowników.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "goToSpace": "Przejdź do przestrzeni {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Oznacz jako nieprzeczytane", + "@markAsUnread": {}, + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Administrator", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "sendRoomNotifications": "Wysyłaj powiadomienia @room", + "@sendRoomNotifications": {}, + "chatPermissionsDescription": "Ustal jaki poziom uprawnień jest wymagany dla określonych czynności w czacie. Poziomy uprawnień 0, 50 i 100 zwykle dotyczą odpowiednio użytkowników, moderatorów i administratorów, ale możliwa jest dowolna gradacja.", + "@chatPermissionsDescription": {}, + "changeTheCanonicalRoomAlias": "Zmień główny publiczny czatu", + "@changeTheCanonicalRoomAlias": {}, + "changeTheDescriptionOfTheGroup": "Zmień opis czatu", + "@changeTheDescriptionOfTheGroup": {}, + "sendCanceled": "Anulowano wysyłanie", + "@sendCanceled": {}, + "homeserverDescription": "Wszystkie Twoje dane trzymane są na serwerze domowym, jak u dostawców usług e-mail. Możesz wybrać swój serwer domowy i nadal rozmawiać ze wszystkimi. Dowiedz się więcej na https://matrix.org.", + "@homeserverDescription": {}, + "doesNotSeemToBeAValidHomeserver": "Wydaje się nie być kompatybilnym serwerem domowym. Niepoprawny adres URL?", + "@doesNotSeemToBeAValidHomeserver": {}, + "calculatingFileSize": "Obliczanie rozmiaru pliku...", + "@calculatingFileSize": {}, + "sendingAttachment": "Wysyłanie załącznika...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "Generowanie podglądu filmu...", + "@generatingVideoThumbnail": {}, + "compressVideo": "Kompresowanie filmu...", + "@compressVideo": {}, + "sendingAttachmentCountOfCount": "Wysyłanie {index} z {length} części załącznika...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "welcomeText": "No cześć! 👋 Tutaj FluffyChat. Możesz zapisać się do dowolnego serwera domowego, kompatybilnego z https://matrix.org i rozmawiać ze wszystkimi. To duża zdecentralizowana sieć czatów!", + "@welcomeText": {}, + "blur": "Rozmazanie:", + "@blur": {}, + "opacity": "Przezroczystość:", + "@opacity": {}, + "setWallpaper": "Ustaw tapetę", + "@setWallpaper": {}, + "manageAccount": "Zarządzaj kontem", + "@manageAccount": {}, + "noContactInformationProvided": "Serwer nie dostarcza żadnych poprawnych danych kontaktowych", + "@noContactInformationProvided": {}, + "contactServerAdmin": "Skontaktuj się z administratorem serwera", + "@contactServerAdmin": {}, + "compress": "Skompresuj", + "@compress": {}, + "pleaseFillOut": "Proszę wypełnić", + "@pleaseFillOut": {}, + "invalidUrl": "Niepoprawny adres URL", + "@invalidUrl": {}, + "unableToJoinChat": "Nie udało się dołączyć do czatu. Może druga strona zakończyła już rozmowę?", + "@unableToJoinChat": {}, + "aboutHomeserver": "O {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "updateInstalled": "🎉 Zainstalowano aktualizację do wersji {version}!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "continueText": "Kontynuuj", + "@continueText": {}, + "noticeChatBackupDeviceVerification": "Uwaga: Urządzenia dodane do kopii zapasowej czatu automatycznie zostają zweryfikowane.", + "@noticeChatBackupDeviceVerification": {}, + "serverLimitReached": "Osiągnięto limit serwera. Czekanie {seconds} sekund...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Jedno z Twoich urządzeń nie jest zweryfikowane", + "@oneOfYourDevicesIsNotVerified": {}, + "supportPage": "Strona obsługi użytkownika", + "@supportPage": {}, + "serverInformation": "Informacje o serwerze:", + "@serverInformation": {}, + "name": "Nazwa", + "@name": {}, + "website": "Strona internetowa", + "@website": {}, + "contactServerSecurity": "Skontaktuj się z działem bezpieczeństwa serwera", + "@contactServerSecurity": {}, + "version": "Wersja", + "@version": {}, + "accessAndVisibility": "Dostęp i widoczność", + "@accessAndVisibility": {}, + "customEmojisAndStickers": "Własne emotikony i naklejki", + "@customEmojisAndStickers": {}, + "globalChatId": "Globalny identyfikator czatu", + "@globalChatId": {}, + "accessAndVisibilityDescription": "Kto może dołączyć do tego czatu i w jaki sposób można ten czat znaleźć.", + "@accessAndVisibilityDescription": {}, + "customEmojisAndStickersBody": "Dodaj lub podziel się własnymi emotikonami i naklejkami, które będą mogły być użyte w dowolnym czacie.", + "@customEmojisAndStickersBody": {}, + "hideRedactedMessages": "Nie pokazuj usuniętych wiadomości", + "@hideRedactedMessages": {}, + "hideInvalidOrUnknownMessageFormats": "Ukryj niepoprawne lub nieznane typy wiadomości", + "@hideInvalidOrUnknownMessageFormats": {}, + "notifyMeFor": "Powiadom mnie o", + "@notifyMeFor": {}, + "pushNotificationsNotAvailable": "Powiadomienia push nie są dostępne", + "@pushNotificationsNotAvailable": {}, + "noUsersFoundWithQuery": "Niestety nie udało się nikogo znaleźć poprzez \"{query}\". Proszę sprawdzić, czy w zapytaniu nie ma literówek.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "chatCanBeDiscoveredViaSearchOnServer": "Czat będzie można znaleźć, szukając na {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "publicSpaces": "Przestrzenie publiczne", + "@publicSpaces": {}, + "searchMore": "Szukaj dalej...", + "@searchMore": {}, + "formattedMessagesDescription": "Używaj Markdown do wyświetlania dodatkowego formatowania w wiadomościach, jak np. pogrubienie tekstu.", + "@formattedMessagesDescription": {}, + "verifyOtherUser": "🔐 Zweryfikuj innego użytkownika", + "@verifyOtherUser": {}, + "knockRestricted": "Pukanie jest ograniczone", + "@knockRestricted": {}, + "appLockDescription": "Zablokuj aplikację pinem kiedy nie jest używana", + "@appLockDescription": {}, + "knocking": "Pukanie", + "@knocking": {}, + "pleaseChooseAStrongPassword": "Proszę wybrać silne hasło", + "@pleaseChooseAStrongPassword": {}, + "usersMustKnock": "Użytkownicy muszą zapukać", + "@usersMustKnock": {}, + "noOneCanJoin": "Nikt nie może dołączyć", + "@noOneCanJoin": {}, + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "swipeRightToLeftToReply": "Przeciągnij w lewo, by odpowiedzieć", + "@swipeRightToLeftToReply": {}, + "presencesToggle": "Pokazuj zmiany statusów innych użytkowników", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "hidePresences": "Ukryć listę statusów?", + "@hidePresences": {}, + "pleaseEnterANumber": "Proszę podać liczbę większą od 0", + "@pleaseEnterANumber": {}, + "commandHint_sendraw": "Wyślij zwykły JSON", + "@commandHint_sendraw": {}, + "databaseMigrationBody": "Proszę czekać. Może to potrwać chwilę.", + "@databaseMigrationBody": {}, + "leaveEmptyToClearStatus": "Pozostaw puste, aby wyczyścić swój status.", + "@leaveEmptyToClearStatus": {}, + "sessionLostBody": "Twoja sesja została utracona. Prosimy zgłosić ten błąd autorom aplikacji na {url}. Treść błędu to: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Przekazać wiadomość do {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "publicChatAddresses": "Adresy publicznych czatów", + "@publicChatAddresses": {}, + "createNewAddress": "Utwórz nowy adres", + "@createNewAddress": {}, + "userRole": "Rola użytkownika/-czki", + "@userRole": {}, + "completedKeyVerification": "{sender} zakończył/-a weryfikację kluczy", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "italicText": "Kursywa", + "@italicText": {}, + "boldText": "Pogrubienie", + "@boldText": {}, + "strikeThrough": "Przekreślenie", + "@strikeThrough": {}, + "incomingMessages": "Wiadomości przychodzące", + "@incomingMessages": {}, + "discoverHomeservers": "Odkrywaj serwery domowe", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "Czym jest serwer domowy?", + "@whatIsAHomeserver": {}, + "loginWithMatrixId": "Zaloguj się identyfikatorem Matrix", + "@loginWithMatrixId": {}, + "passwordsDoNotMatch": "Hasła się nie zgadzają", + "@passwordsDoNotMatch": {}, + "unbanUserDescription": "Użytkownik będzie w stanie dołączyć do czatu ponownie.", + "@unbanUserDescription": {}, + "roomUpgradeDescription": "Czat zostanie przeniesiony do pokoju w nowej wersji. Wszyscy użytkownicy zostaną powiadomieni o konieczności dołączenia do nowego czatu. Możesz dowiedzieć się więcej o wersjach pokojów na https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "userWouldLikeToChangeTheChat": "{user} chce dołączyć do czatu.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} poprosił/-a o weryfikację kluczy", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "changeGeneralChatSettings": "Zmień ogólne ustawienia czatu", + "@changeGeneralChatSettings": {}, + "youInvitedToBy": "Otrzymałeś/-aś link z zaproszeniem do:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "verifyOtherUserDescription": "Jeśli zweryfikujesz innego użytkownika, możesz być pewien/-na z kim naprawdę piszesz. 💪\n\nKiedy rozpoczniesz weryfikację, Ty i ta druga osoba zobaczycie okienko dialogowe. Zobaczycie w nim serię emotikonów lub numery do porównania.\n\nNajlepiej potwierdzić ich zgodność osobiście lub przez wideorozmowę. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDeviceDescription": "Jeśli zweryfikujesz inne urządzenie, będzie mogło ono wymienić klucze z dotychczasowym, zwiększając ogólne bezpieczeństwo. 💪 Kiedy rozpoczniesz weryfikację, na obu urządzeniach wyświetli się okno dialogowe. Zobaczysz w nim serię emotikonów lub numery do porównania. Najlepiej mieć oba urządzenia pod ręką przed rozpoczęciem weryfikacji. 🤳", + "@verifyOtherDeviceDescription": {}, + "unreadChatsInApp": "{appname}: {unread} nieprzeczytanych czatów", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "addLink": "Dodaj link", + "@addLink": {}, + "unread": "Nieprzeczytane", + "@unread": {}, + "space": "Przestrzeń", + "@space": {}, + "spaces": "Przestrzenie", + "@spaces": {}, + "countChatsAndCountParticipants": "{participants}{chats} czatów i {participants} uczestników", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Nie znaleziono więcej czatów...", + "@noMoreChatsFound": {}, + "joinedChats": "Czaty, do których dołączono", + "@joinedChats": {}, + "removeDevicesDescription": "Nastąpi wylogowanie z tego urządzenia. Nie będziesz w stanie odbierać na nim wiadomości.", + "@removeDevicesDescription": {}, + "makeAdminDescription": "Kiedy użytkownik zostanie adminem, nie będziesz móc tego cofnąć, bo nabierze takich samych uprawnień, jak Ty.", + "@makeAdminDescription": {}, + "searchChatsRooms": "Szukaj #czatów, @użytkowników...", + "@searchChatsRooms": {}, + "createGroupAndInviteUsers": "Utwórz grupę i zaproś użytkowników", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "Grupa może być znaleziona poprzez wyszukiwanie", + "@groupCanBeFoundViaSearch": {}, + "wrongRecoveryKey": "Niestety to nie wygląda na poprawny klucz odzyskiwania.", + "@wrongRecoveryKey": {}, + "searchForUsers": "Szukaj @użytkowników...", + "@searchForUsers": {}, + "pleaseEnterYourCurrentPassword": "Proszę podać swoje obecne hasło", + "@pleaseEnterYourCurrentPassword": {}, + "passwordIsWrong": "Podano niepoprawne hasło", + "@passwordIsWrong": {}, + "joinSpace": "Dołącz do przestrzeni", + "@joinSpace": {}, + "addChatOrSubSpace": "Dodaj czat lub podprzestrzeń", + "@addChatOrSubSpace": {}, + "initAppError": "Wystąpił błąd podczas inicjalizacji aplikacji", + "@initAppError": {}, + "minimumPowerLevel": "{level} jest minimalnym poziomem uprawnień.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchIn": "Szukaj w czacie \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "kickUserDescription": "Użytkownik jest wyrzucony z czatu, ale nie zbanowany. Do czatu publicznego może dołączyć ponownie.", + "@kickUserDescription": {}, + "appWantsToUseForLogin": "Użyj serwera '{server}' do zalogowania się", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Niniejszym zezwalasz aplikacji i witrynie na udostępnianie informacji o sobie.", + "@appWantsToUseForLoginDescription": {}, + "open": "Otwórz", + "@open": {}, + "contentNotificationSettings": "Ustawienia powiadomień o treści", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "Ogólne ustawienia powiadomień", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "Ustawienia powiadomień w pokoju", + "@roomNotificationSettings": {}, + "userSpecificNotificationSettings": "Ustawienia powiadomień dla użytkownika", + "@userSpecificNotificationSettings": {}, + "otherNotificationSettings": "Inne ustawienia powiadomień", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "Włącz dla wiadomości z nazwą użytkownika", + "@notificationRuleContainsUserName": {}, + "notificationRuleContainsUserNameDescription": "Włącza powiadomienia kiedy wiadomość zawiera Twoją nazwę użytkownika.", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleMaster": "Wyłącz wszystkie powiadomienia", + "@notificationRuleMaster": {}, + "notificationRuleMasterDescription": "Zastępuje inne reguły i wyłącza wszystkie powiadomienia.", + "@notificationRuleMasterDescription": {}, + "notificationRuleSuppressNotices": "Wyłącz dla automatycznych wiadomości", + "@notificationRuleSuppressNotices": {}, + "notificationRuleSuppressNoticesDescription": "Wyłącza powiadomienia z automatycznych klientów, takich jak boty.", + "@notificationRuleSuppressNoticesDescription": {}, + "notificationRuleInviteForMe": "Włącz dla zaproszeń", + "@notificationRuleInviteForMe": {}, + "notificationRuleInviteForMeDescription": "Włącza powiadomienia o zaproszeniach do pokoju.", + "@notificationRuleInviteForMeDescription": {}, + "notificationRuleMemberEvent": "Wyłącz dla zmian członkostwa", + "@notificationRuleMemberEvent": {}, + "notificationRuleMemberEventDescription": "Wyłącza powiadomienia o zmianach członkostwa w pokoju.", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleIsUserMention": "Włącz dla wzmianek", + "@notificationRuleIsUserMention": {}, + "notificationRuleIsUserMentionDescription": "Włącza powiadomienia o byciu wzmiankowanym w wiadomości.", + "@notificationRuleIsUserMentionDescription": {}, + "notificationRuleContainsDisplayName": "Włącz dla wiadomości z nazwą wyświetlaną", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleContainsDisplayNameDescription": "Włącza powiadomienia o wiadomościach zawierających Twoją nazwę wyświetlaną.", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleIsRoomMention": "Włącz dla wzmianek pokoju", + "@notificationRuleIsRoomMention": {}, + "notificationRuleIsRoomMentionDescription": "Włącza powiadomienia o wzmiankowaniu całego pokoju.", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleRoomnotif": "Włącz dla powiadomień w pokoju", + "@notificationRuleRoomnotif": {}, + "notificationRuleRoomnotifDescription": "Włącza powiadomienia o wiadomościach zawierających „@room”.", + "@notificationRuleRoomnotifDescription": {}, + "notificationRuleTombstone": "Włącz dla „nagrobków”", + "@notificationRuleTombstone": {}, + "notificationRuleTombstoneDescription": "Włącza powiadomienia o komunikatach dezaktywacji pokojów.", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleReaction": "Wyłącz dla reakcji", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "Wyłącza powiadomienia o reakcjach.", + "@notificationRuleReactionDescription": {}, + "notificationRuleSuppressEdits": "Wyłącz dla edycji", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "Wyłącza powiadomienia o edycjach wiadomości.", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleCall": "Włącz dla połączeń", + "@notificationRuleCall": {}, + "notificationRuleRoomServerAclDescription": "Wyłącza powiadomienia dla list kontroli dostępu (ACL) serwera.", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleRoomServerAcl": "Wyłącz dla list kontroli dostępu serwera", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleEncryptedRoomOneToOne": "Włącz dla szyfrowanych pokojów „jeden na jeden”", + "@notificationRuleEncryptedRoomOneToOne": {}, + "notificationRuleCallDescription": "Włącza powiadomienia o przychodzących połączeniach.", + "@notificationRuleCallDescription": {}, + "notificationRuleRoomOneToOne": "Włącz dla pokojów „jeden na jeden”", + "@notificationRuleRoomOneToOne": {}, + "notificationRuleRoomOneToOneDescription": "Włącza powiadomienia o wiadomościach w pokojach „jeden na jeden” (one-to-one).", + "@notificationRuleRoomOneToOneDescription": {}, + "notificationRuleMessage": "Włącz dla wiadomości", + "@notificationRuleMessage": {}, + "unknownPushRule": "Nieznana reguła: '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "notificationRuleEncryptedRoomOneToOneDescription": "Włącza powiadomienia o wiadomościach w szyfrowanych pokojach „jeden na jeden” (one-to-one).", + "@notificationRuleEncryptedRoomOneToOneDescription": {}, + "notificationRuleEncrypted": "Włącz dla zaszyfrowanych pokojów", + "@notificationRuleEncrypted": {}, + "notificationRuleJitsi": "Włącz dla Jitsi", + "@notificationRuleJitsi": {}, + "notificationRuleServerAcl": "Wyłącz dla komunikatów o listach kontroli dostępu serwera", + "@notificationRuleServerAcl": {}, + "notificationRuleJitsiDescription": "Włącza powiadomienia o komunikatach widżetów Jitsi.", + "@notificationRuleJitsiDescription": {}, + "notificationRuleMessageDescription": "Włącza powiadomienia o ogólnych wiadomościach.", + "@notificationRuleMessageDescription": {}, + "notificationRuleEncryptedDescription": "Włącza powiadomienia o wiadomościach w zaszyfrowanych pokojach.", + "@notificationRuleEncryptedDescription": {}, + "notificationRuleServerAclDescription": "Wyłącza powiadomienia o komunikatach o listach kontroli dostępu (ACL) serwera.", + "@notificationRuleServerAclDescription": {}, + "newChatRequest": "📩 Nowa prośba o czat", + "@newChatRequest": {}, + "synchronizingPleaseWaitCounter": " Synchronizowanie… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "waitingForServer": "Oczekiwanie na serwer...", + "@waitingForServer": {}, + "appIntroduction": "FluffyChat umożliwia czatowanie ze znajomymi za pośrednictwem różnych komunikatorów. Dowiedz się więcej na stronie https://matrix.org lub kliknij na *Kontynuuj*.", + "@appIntroduction": {}, + "previous": "Poprzedni", + "@previous": {}, + "otherPartyNotLoggedIn": "Druga strona nie jest obecnie zalogowana i dlatego nie może odbierać wiadomości!", + "@otherPartyNotLoggedIn": {}, + "deletePushRuleCanNotBeUndone": "Jeśli skasujesz to ustawienie powiadomień, nie będzie się dało tego cofnąć.", + "@deletePushRuleCanNotBeUndone": {}, + "more": "Więcej", + "@more": {}, + "shareKeysWith": "Udostępnij klucze...", + "@shareKeysWith": {}, + "crossVerifiedDevicesIfEnabled": "Urządzenia zweryfikowane krzyżowo, jeśli włączone", + "@crossVerifiedDevicesIfEnabled": {}, + "crossVerifiedDevices": "Urządzenia zweryfikowane krzyżowo", + "@crossVerifiedDevices": {}, + "takeAPhoto": "Zrób zdjęcie", + "@takeAPhoto": {}, + "recordAVideo": "Nagraj film", + "@recordAVideo": {}, + "optionalMessage": "(Opcjonalna) wiadomość...", + "@optionalMessage": {}, + "verifiedDevicesOnly": "Tylko zweryfikowane urządzenia", + "@verifiedDevicesOnly": {}, + "shareKeysWithDescription": "Które urządzenia powinny być zaufane, aby mogły odczytywać Twoje wiadomości w zaszyfrowanych czatach?", + "@shareKeysWithDescription": {}, + "allDevices": "Wszystkie urządzenia", + "@allDevices": {}, + "notSupportedOnThisDevice": "Niewspierane na tym urządzeniu", + "@notSupportedOnThisDevice": {}, + "commandHint_roomupgrade": "Zaktualizuj ten pokój do podanej wersji", + "@commandHint_roomupgrade": {}, + "enterNewChat": "Dołącz do nowego czatu", + "@enterNewChat": {}, + "countInvited": "{count} zaproszonych", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sentVoiceMessage": "🎙️ {duration} - Wiadomość głosowa od: {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "checkList": "Lista kontrolna", + "@checkList": {}, + "setCustomPermissionLevel": "Ustaw własny poziom uprawnień", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Proszę wybrać predefiniowaną rolę poniżej, lub wprowadzić własny poziom uprawnień pomiędzy 0 a 100.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Ignoruj użytkownika", + "@ignoreUser": {}, + "normalUser": "Zwykły użytkownik", + "@normalUser": {}, + "approve": "Zaakceptuj", + "@approve": {}, + "youHaveKnocked": "Zapukałeś/-aś", + "@youHaveKnocked": {}, + "pleaseWaitUntilInvited": "Proszę zaczekać na zaproszenie przez kogoś z pokoju.", + "@pleaseWaitUntilInvited": {}, + "commandHint_logout": "Wyloguj bieżące urządzenie", + "@commandHint_logout": {}, + "commandHint_logoutall": "Wyloguj wszystkie aktywne urządzenia", + "@commandHint_logoutall": {}, + "displayNavigationRail": "Pokazuj pasek nawigacyjny na urządzeniach mobilnych", + "@displayNavigationRail": {}, + "customReaction": "Własna reakcja", + "@customReaction": {}, + "moreEvents": "Więcej zdarzeń", + "@moreEvents": {}, + "declineInvitation": "Odrzuć zaproszenie", + "@declineInvitation": {} +} diff --git a/lib/l10n/intl_pt.arb b/lib/l10n/intl_pt.arb new file mode 100644 index 000000000..22ba7e661 --- /dev/null +++ b/lib/l10n/intl_pt.arb @@ -0,0 +1,146 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.940318", + "copiedToClipboard": "Copiada para a área de transferência", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "login": "Iniciar sessão", + "@login": { + "type": "String", + "placeholders": {} + }, + "about": "Sobre", + "@about": { + "type": "String", + "placeholders": {} + }, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Tens a certeza?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notificações", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "account": "Conta", + "@account": { + "type": "String", + "placeholders": {} + }, + "cancel": "Cancelar", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "delete": "Eliminar", + "@delete": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "help": "Ajuda", + "@help": { + "type": "String", + "placeholders": {} + }, + "messages": "Mensagens", + "@messages": { + "type": "String", + "placeholders": {} + }, + "reason": "Razão", + "@reason": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privacidade", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Abrir câmara", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "settings": "Configurações", + "@settings": { + "type": "String", + "placeholders": {} + }, + "logout": "Terminar sessão", + "@logout": { + "type": "String", + "placeholders": {} + }, + "search": "Pesquisar", + "@search": { + "type": "String", + "placeholders": {} + }, + "users": "Utilizadores", + "@users": {}, + "close": "Fechar", + "@close": { + "type": "String", + "placeholders": {} + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "repeatPassword": "Repita a senha", + "@repeatPassword": {}, + "notAnImage": "Não é um arquivo de imagem.", + "@notAnImage": {}, + "setCustomPermissionLevel": "Definir nível de permissão personalizado", + "@setCustomPermissionLevel": {}, + "addChatDescription": "Adicionar uma descrição de chat...", + "@addChatDescription": {} +} diff --git a/lib/l10n/intl_pt_BR.arb b/lib/l10n/intl_pt_BR.arb new file mode 100644 index 000000000..ab6903004 --- /dev/null +++ b/lib/l10n/intl_pt_BR.arb @@ -0,0 +1,3125 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.925971", + "about": "Sobre", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Aceitar", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} aceitou o convite", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Conta", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} ativou a criptografia de ponta-a-ponta", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Adicionar e-mail", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "cognome", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Tudo", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Todas as conversas", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} atendeu à chamada", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Qualquer pessoa pode entrar", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Bloqueio do app", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arquivo", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Visitantes podem entrar", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Tem certeza?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Tem certeza que deseja se desconectar?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Para poder validar a outra pessoa, digite sua frase secreta ou chave de recuperação.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Aceitar esta solicitação de verificação de {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Reproduzir automaticamente figurinhas animadas e emojis", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "O servidor suporta os tipos de entrada/login:\n{serverVersions}\nMas este app suporta apenas:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "O servidor suporta as versões de especificação:\n{serverVersions}\nMas este app suporta apenas {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Banir da conversa", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Banidos", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} baniu {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Bloquear dispositivo", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Bloqueado", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Mensagens de bots", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Cancelar", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Não foi possível abrir a URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Alterar o nome do dispositivo", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} alterou o avatar da conversa", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} alterou a descrição da conversa para: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} alterou o nome da conversa para: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} alterou as permissões na conversa", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} mudou o seu nome de exibição para: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} alterou as regras de acesso dos visitantes", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} alterou as regras de acesso dos visitantes para: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} alterou a visibilidade do histórico", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} alterou a visibilidade do histórico para: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} alterou as regras de entrada", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} alterou as regras de entrada para: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} alterou seu avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} alterou os apelidos da sala", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} alterou o link de convite", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Alterar a senha", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Alterar o servidor", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Alterar o tema", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Alterar o nome do grupo", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Alterar seu avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "A criptografia foi corrompida", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Conversar", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Backup de conversas", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Suas mensagens são protegidas com sua chave de recuperação. Evite perdê-la.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Detalhes da conversa", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Conversas", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Escolha uma senha forte", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Limpar arquivo", + "close": "Fechar", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Banir o usuário especificado desta sala", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Enviar mensagem formatada em HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Convidar o usuário especificado para esta sala", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Entrar na sala especificada", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Remover o usuário especificado da sala", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Sair desta sala", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Descrever você mesmo", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Configurar sua imagem para esta sala (via mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Configurar seu nome de exibição para esta sala", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Determinar o nível de poderes do usuário especificado (padrão: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Enviar mensagem sem formatação", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Enviar uma resposta como reação", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Enviar mensagem", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Desbanir o usuário especificado desta sala", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Comando inválido", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} não é um comando.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Compare os emojis", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Compare os números", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Configurar conversa", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Confirmar", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Conectar", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "O contato foi convidado ao grupo", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Contém nome de exibição", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Contém nome de usuário", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "O conteúdo foi denunciado para os administradores do servidor", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Copiado para a área de transferência", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Copiar", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Copiar para a área de transferência", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Não foi possível descriptografar a mensagem: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} participantes", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Criar", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} criou a conversa", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Novo espaço", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Ativo", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Escuro", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date} às {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}/{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}/{month}/{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Isto desativará a sua conta. Isto é irreversível! Tem certeza?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Nível de permissão padrão para usuários novos", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Apagar", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Apagar conta", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Apagar mensagem", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Dispositivo", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID do dispositivo", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Dispositivos", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Conversas diretas", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "O nome de exibição foi alterado", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Baixar arquivo", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Editar", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Editar servidores bloqueados", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Editar nome de exibição", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Editar apelidos da sala", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Editar o avatar da sala", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emoji já existe!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Código emoji inválido!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Pacote de emoji para a sala", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Configuração dos Emoji", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Código Emoji", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Você tem que escolher um código emoji e uma imagem!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Conversa vazia", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Habilitar globalmente o pacote de emoji", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Ativar criptografia", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Você não poderá desativar a criptografia posteriormente. Tem certeza?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Criptografado", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Criptografia", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "A criptografia não está ativada", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} finalizou a chamada", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Digite um endereço de e-mail", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Digite o seu servidor", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Erro ao obter localização: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Tudo pronto!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extremamente ofensivo", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Nome do arquivo", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Tamanho da fonte", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Encaminhar", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Desde que entrou", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Desde o convite", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Ir para a sala nova", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Grupo", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "O grupo é público", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Grupos", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Grupo com {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Visitantes são proibidos", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Visitantes podem entrar", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} revogou o convite para {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Ajuda", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Ocultar eventos removidos", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Ocultar eventos desconhecidos", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "O quão ofensivo é este conteúdo?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identidade", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorar", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Usuários ignorados", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Eu cliquei no link", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Frase secreta ou chave de recuperação incorreta", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Inofensivo", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Convidar contato", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Convidar contato para {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Convidado", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} convidou {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Apenas usuários convidados", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Convite para mim", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} convidou você para o FluffyChat.\n1. Visite fluffychat.im e instale o aplicativo\n2. Entre ou crie uma conta\n3. Abra o link do convite:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "está digitando…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} entrou na conversa", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Entrar na sala", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} expulsou {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} expulsou e baniu {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Expulsar da conversa", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Última vez ativo: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Sair", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Saiu da conversa", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licença", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Claro", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Carregar mais {count} participantes", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Carregando... Aguarde.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Carregar mais…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Os serviços de localização estão desativados. Ative-os para compartilhar sua localização.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Permissão de localização bloqueada. Conceda as permissões para poder compartilhar sua localização.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Conectar-se", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Conectar com {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Desconectar-se", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Alterações de membros", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Mencionar", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Mensagens", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderador", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Silenciar conversa", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Esteja ciente que você precisa do Pantalaimon para usar a criptografia de ponta a ponta.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Nova conversa", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nova mensagem no FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nova solicitação de verificação!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Avançar", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Não", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Sem conexão com o servidor", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Nenhum emoji encontrado. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Você só poderá ativar a criptografia quando a sala não for mais publicamente acessível.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "O Firebase Cloud Messaging não parece estar disponível no seu dispositivo. Para receber notificações push, recomendados que você instwl3 o ntfy. Com o ntfy outro provedor do UnifiedPush, você pode receber notificações push de um modo seguro em relação aos dados. Você pode baixar o ntfy da Play Store ou do F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} não é um servidor matrix, usar {server2}?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "none": "Nenhum", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Você ainda não adicionou uma forma de recuperar sua senha.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Sem permissão", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Nenhuma sala encontrada…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Notificações", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Notificações ativadas para esta conta", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} usuários estão digitando…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Obtendo localização…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Ofensivo", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Desconectado", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Disponível", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "O backup de chaves on-line está ativado", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Opa! Infelizmente, um erro ocorreu ao configurar as notificações push.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Opa, algo deu errado…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Abra o app para ler as mensagens", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Abrir câmera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Abrir no mapa", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Ou", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Participante", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "frase secreta ou chave de recuperação", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Senha", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Esqueci a senha", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Senha foi alterada", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Recuperação de senha", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Pessoas", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Selecione uma imagem", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Fixar", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Tocar {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Selecione", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Escolha um código", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Clique no link do e-mail para prosseguir.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Digite 4 dígitos ou deixe em branco para desativar o bloqueio do app.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Digite sua senha", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Digite seu PIN", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Digite seu nome de usuário", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Siga as instruções no site e toque em avançar.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Privacidade", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Salas públicas", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Regras de push", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Motivo", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Gravação", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} apagou um evento", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Apagar mensagem", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Cadastrar-se", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Recusar", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} recusou o convite", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Entrar novamente", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Remover", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Remover todos os outros dispositivos", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Removido por {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Remover dispositivo", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Desbanir da conversa", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Remover seu avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Substituir sala por uma nova versão", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Responder", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Denunciar mensagem", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Solicitar permissão", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "A sala foi atualizada", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Versão da sala", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Salvar arquivo", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Pesquisar", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Segurança", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Visto por {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Enviar", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Enviar uma mensagem", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Enviar como texto", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Enviar áudio", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Enviar arquivo", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Enviar imagem", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Enviar mensagens", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Enviar original", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Enviar figurinha", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Enviar vídeo", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} enviou um arquivo", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} enviou um áudio", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} enviou uma imagem", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} enviou uma figurinha", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} enviou um vídeo", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} enviou informações de chamada", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Configurar como apelido principal", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Implantar emojis personalizados", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Enviar link de convite", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Configurar níveis de permissão", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Alterar estado", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Configurações", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Compartilhar", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} compartilhou sua localização", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Compartilhar localização", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Mostrar senha", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Entrada única", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Pular", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Código-fonte", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "O espaço é público", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Nome do espaço", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} iniciou uma chamada", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Estado", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Como vai você?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Enviar", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sincronizando… Aguarde.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistema", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Não correspondem", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Correspondem", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Alternar favorito", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Alternar Silenciado", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Marcar lido/não lido", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Demasiadas requisições. Por favor, tente novamente mais tarde!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Transferir de outro dispositivo", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Tentar enviar novamente", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Indisponível", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} desbaniu {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Desbloquear dispositivo", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Dispositivo desconhecido", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Algoritmo de criptografia desconhecido", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Evento desconhecido '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Dessilenciar", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Desafixar", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 conversa não lida} other{{unreadCount} conversas não lidas}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} e mais {count} pessoas estão digitando…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} e {username2} estão digitando…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} está digitando…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} saiu da conversa", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Nome de usuário", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} enviou um evento de {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Verificado", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Verificar", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Iniciar verificação", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Verificação efetivada!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verificando outra conta", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Chamada de vídeo", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Visibilidade do histórico da conversa", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Visível para todos os participantes", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Visível para qualquer pessoa", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Mensagem de voz", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Esperando que a outra pessoa aceite a solicitação…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Esperando que a outra pessoa aceite os emojis…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Aguardando a outra pessoa aceitar os números…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Plano de fundo:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Atenção!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Enviamos um e-mail para você", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Quem pode desempenhar quais ações", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Quem pode entrar no grupo", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Por que quer denunciar isto?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Apagar o backup de conversas para criar uma nova chave de recuperação?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Você pode recuperar a sua senha com estes endereços.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Digite sua mensagem…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Sim", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Você", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Você não está mais participando desta conversa", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Você foi banido desta conversa", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Sua chave pública", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "Um dos seus clientes foi desconectado", + "addAccount": "Adicionar conta", + "unverified": "Não verificado", + "yourChatBackupHasBeenSetUp": "Seu backup de conversas foi configurado.", + "editBundlesForAccount": "Editar coleções para esta conta", + "serverRequiresEmail": "Este servidor precisa validar seu e-mail para efetuar o cadastro.", + "messageInfo": "Informações da mensagem", + "sender": "Remetente", + "publish": "Publicar", + "removeFromSpace": "Remover do espaço", + "link": "Link", + "start": "Iniciar", + "repeatPassword": "Repita a senha", + "addToSpace": "Adicionar ao espaço", + "sendOnEnter": "Enviar ao pressionar enter", + "homeserver": "Servidor", + "chatHasBeenAddedToThisSpace": "A conversa foi adicionada a este espaço", + "commandHint_clearcache": "Limpar dados temporários", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Criar uma conversa em grupo vazia.\nUse --no-encryption para desativar a criptografia", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Descartar sessão", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Iniciar uma conversa direta\nUse --no-encryption para desativar a criptografia", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "scanQrCode": "Ler código QR", + "openVideoCamera": "Abrir a câmera para um vídeo", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "addToBundle": "Adicionar à coleção", + "removeFromBundle": "Remover desta coleção", + "bundleName": "Nome da coleção", + "enableMultiAccounts": "(BETA) Ativar múltiplas contas neste dispositivo", + "time": "Horário", + "messageType": "Tipo da mensagem", + "openGallery": "Abrir galeria", + "addToSpaceDescription": "Selecione um espaço para adicionar esta conversa.", + "videoWithSize": "Vídeo ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "markAsRead": "Marcar como lido", + "dismiss": "Descartar", + "separateChatTypes": "Separar conversas diretas e grupos", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "openChat": "Abrir conversa", + "reportUser": "Denunciar usuário", + "emojis": "Emojis", + "placeCall": "Chamar", + "reactedWith": "{sender} reagiu com {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "confirmEventUnpin": "Tem certeza que quer desafixar o evento permanentemente?", + "pinMessage": "Fixar na sala", + "voiceCall": "Chamada de voz", + "unsupportedAndroidVersion": "Versão Android sem suporte", + "widgetNameError": "Forneça um nome de exibição.", + "unsupportedAndroidVersionLong": "Esta funcionalidade requer uma versão mais nova do Android. Verifique se há atualizações ou suporte ao LineageOS.", + "emailOrUsername": "E-mail ou nome de usuário", + "videoCallsBetaWarning": "Observe que chamadas de vídeo estão atualmente em teste. Podem não funcionar como esperado ou sequer funcionar em algumas plataformas.", + "experimentalVideoCalls": "Vídeo chamadas experimentais", + "widgetVideo": "Vídeo", + "errorAddingWidget": "Erro ao adicionar o widget.", + "addWidget": "Adicionar widget", + "widgetEtherpad": "Anotação de texto", + "widgetUrlError": "Isto não é uma URL válida.", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "Personalizado", + "widgetName": "Nome", + "switchToAccount": "Alternar para a conta {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Próxima conta", + "previousAccount": "Conta anterior", + "youRejectedTheInvitation": "Você rejeitou o convite", + "youBannedUser": "Você baniu {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Você revogou o convite para {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Você foi convidado por {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Você convidou {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youAcceptedTheInvitation": "👍 Você aceitou o convite", + "youJoinedTheChat": "Você entrou na conversa", + "youKicked": "👞 Você expulsou {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Você expulsou e baniu {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Você desbaniu {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} afagou você", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "pleaseEnterRecoveryKeyDescription": "Para desbloquear as suas mensagens antigas, digite a sua chave de recuperação gerada numa sessão prévia. Sua chave de recuperação NÃO é sua senha.", + "indexedDbErrorLong": "Infelizmente, o armazenamento de mensagens não é ativado por padrão no modo privado.\nVisite\n- about:config\n- atribua \"true\" a \"dom.indexedDB.privateBrowsing.enabled\"\nSe não fizer isto, não será possível executar o FluffyChat.", + "users": "Usuários", + "confirmMatrixId": "Confirme seu ID Matrix para apagar sua conta.", + "supposedMxid": "Isto deveria ser {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "dehydrateTor": "Usuários TOR: Exportar sessão", + "recoveryKey": "Chave de recuperação", + "recoveryKeyLost": "Perdeu a chave de recuperação?", + "commandHint_cuddle": "Enviar um afago", + "commandHint_hug": "Enviar um abraço", + "commandHint_googly": "Enviar olhos arregalados", + "googlyEyesContent": "{senderName} enviou olhos arregalados", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} abraçou você", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_markasdm": "Marcar como sala de mensagens diretas para o ID Matrix fornecido", + "commandHint_markasgroup": "Marcar como grupo", + "hydrateTor": "Usuários TOR: Importar sessão", + "hydrateTorLong": "Você exportou sua última sessão no TOR? Importe ela rapidamente e continue conversando.", + "hydrate": "Restaurar a partir de um arquivo de backup", + "pleaseEnterRecoveryKey": "Digite sua chave de recuperação:", + "indexedDbErrorTitle": "Problemas no modo privado", + "storeInSecureStorageDescription": "Guardar a chave de recuperação no armazenamento seguro deste dispositivo.", + "saveKeyManuallyDescription": "Salvar esta chave manualmente via compartilhamento do sistema ou área de transferência.", + "storeInAndroidKeystore": "Guardar no cofre do Android (KeyStore)", + "storeInAppleKeyChain": "Guardar no chaveiro da Apple", + "storeSecurlyOnThisDevice": "Guardar de modo seguro neste dispositivo", + "user": "Usuário", + "custom": "Personalizado", + "foregroundServiceRunning": "Esta notificação aparece quando o serviço de primeiro plano está sendo executado.", + "callingPermissions": "Permissões de chamada", + "callingAccount": "Conta para chamadas", + "callingAccountDetails": "Permitir que o FluffyChat use o app de chamadas nativo do Android.", + "appearOnTop": "Aparecer no topo", + "appearOnTopDetails": "Permite que o app apareça no topo (desnecessário caso o FluffyChat já esteja configurado como conta para chamadas)", + "otherCallingPermissions": "Microfone, câmera e outras permissões do FluffyChat", + "newGroup": "Novo grupo", + "newSpace": "Novo espaço", + "enterSpace": "Abrir espaço", + "enterRoom": "Abrir sala", + "allSpaces": "Todos os espaços", + "hideUnimportantStateEvents": "Ocultar eventos de estado desimportantes", + "countFiles": "{count} arquivos", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "doNotShowAgain": "Não mostrar novamente", + "unlockOldMessages": "Desbloquear mensagens antigas", + "dehydrate": "Exportar sessão e apagar dispositivo", + "dehydrateWarning": "Esta ação não pode ser desfeita. Certifique-se de que o arquivo de backup está guardado e seguro.", + "dehydrateTorLong": "Para usuários TOR, é recomendado exportar a sessão antes de fechar a janela.", + "whyIsThisMessageEncrypted": "Por que não consigo ler esta mensagem?", + "screenSharingTitle": "compartilhamento de tela", + "screenSharingDetail": "Você está compartilhando sua tela no FluffyChat", + "numChats": "{number} conversas", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "noKeyForThisMessage": "Isto pode ocorrer caso a mensagem tenha sido enviada antes de você ter se conectado à sua conta com este dispositivo.\n\nTambém é possível que o remetente tenha bloqueado o seu dispositivo ou ocorreu algum problema com a conexão.\n\nVocê consegue ler as mensagens em outra sessão? Então, pode transferir as mensagens de lá! Vá em Configurações > Dispositivos e confira se os dispositivos verificaram um ao outro. Quando abrir a sala da próxima vez e ambas as sessões estiverem abertas, as chaves serão transmitidas automaticamente.\n\nNão gostaria de perder suas chaves ao desconectar ou trocar de dispositivos? Certifique-se que o backup de conversas esteja ativado nas configurações.", + "allRooms": "Todas as conversas em grupo", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "notAnImage": "Não é um arquivo de imagem.", + "importNow": "Importar agora", + "importEmojis": "Importar emojis", + "importFromZipFile": "Importar de arquivo .zip", + "sendTypingNotifications": "Enviar indicadores de digitação", + "startFirstChat": "Inicie sua primeira conversa", + "exportEmotePack": "Exportar pacote de emojis como .zip", + "replace": "Substituir", + "jumpToLastReadMessage": "Pular para a última mensagem lida", + "reportErrorDescription": "😭 Ah, não. Algo deu errado. Se quiser, pode relatar isto aos desenvolvedores.", + "setColorTheme": "Aplicar paleta de cor:", + "banUserDescription": "O usuário será banido da conversa e não poderá participar novamente até que sejam desbanidos.", + "removeDevicesDescription": "Você será desconectado deste dispositivo e não poderá mais receber mensagens.", + "tryAgain": "Tentar novamente", + "unbanUserDescription": "O usuário poderá entrar novamente na conversa, caso tente.", + "messagesStyle": "Mensagens:", + "newSpaceDescription": "Os espaços permitem que você consolide suas conversas e construa comunidades públicas ou privadas.", + "chatDescription": "Descrição da conversa", + "encryptThisChat": "Criptografar esta conversa", + "reopenChat": "Reabrir conversa", + "pushNotificationsNotAvailable": "Notificações push não estão disponíveis", + "invalidServerName": "Nome do servidor inválido", + "chatPermissions": "Permissões da conversa", + "signInWithPassword": "Conectar com senha", + "makeAdminDescription": "Assim que promover este usuário a administrador, não poderá desfazer isto e ele terá as mesmas permissões que você.", + "setChatDescription": "Configurar descrição da conversa", + "noOtherDevicesFound": "Nenhum outro dispositivo encontrado", + "redactedBy": "Apagado por {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "signInWith": "Conectar com {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "Não foi possível enviar! O servidor suporta anexos somente até {max}.", + "readUpToHere": "Lido até aqui", + "optionalRedactReason": "(Opcional) Motivo para apagar esta mensagem.", + "archiveRoomDescription": "A conversa será movida para o arquivo. Outros usuários verão que você deixou a conversa.", + "inviteContactToGroupQuestion": "Deseja convidar {contact} para a conversa \"{groupName}\"?", + "redactedByBecause": "Apagado por {username}, pois: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "Arquivo salvo em {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "redactMessageDescription": "A mensagem será apagada para todos os participantes desta conversa. Isto não poderá ser desfeito.", + "invalidInput": "Entrada inválida!", + "report": "relatar", + "addChatDescription": "Adicionar uma descrição à conversa...", + "hasKnocked": "🚪 {user} bateu na porta", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "openLinkInBrowser": "Abrir link no navegador", + "disableEncryptionWarning": "Por razões de segurança, não é possível desativar a criptografada uma vez ativada.", + "directChat": "Conversa direta", + "wrongPinEntered": "PIN incorreto! Tente novamente em {seconds} segundos...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "inviteGroupChat": "📨 Convite para conversa em grupo", + "invitePrivateChat": "📨 Convite para conversa privada", + "wasDirectChatDisplayName": "Conversa vazia (era {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "Nenhuma descrição para a conversa foi criada ainda.", + "learnMore": "Saiba mais", + "chatDescriptionHasBeenChanged": "Descrição da conversa alterada", + "roomUpgradeDescription": "A conversa será recriada com a nova versão de sala. Todos participantes será notificados e terão que migrar para a nova sala. Você pode encontrar mais informações sobre versões de sala em https://spec.matrix.org/latest/room/", + "pleaseEnterANumber": "Digite um número maior que 0", + "profileNotFound": "O usuário não foi encontrado neste servidor. Talvez um problema de conexão ou o usuário não existe.", + "jump": "Pular", + "sorryThatsNotPossible": "Desculpe... isto não é possível", + "shareInviteLink": "Compartilhar link de convite", + "deviceKeys": "Chaves de dispositivo:", + "emoteKeyboardNoRecents": "Emojis recentes aparecem aqui...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Aplicar tema:", + "pleaseTryAgainLaterOrChooseDifferentServer": "Tente novamente mais tarde ou escolha um servidor diferente.", + "createGroup": "Criar grupo", + "noBackupWarning": "Atenção! Se não ativar o backup de conversas, você perderá acesso a suas mensagens criptografadas. É altamente recomendável ativar o backup antes de sair.", + "kickUserDescription": "O usuário foi expulso da conversa, mas não banido. Em conversas públicas, o usuário pode entrar novamente a qualquer momento.", + "invite": "Convidar", + "blockListDescription": "Você pode bloquear usuários que estejam te perturbando. Você não receberá mensagens ou convites de usuários na sua lista pessoal de bloqueios.", + "createGroupAndInviteUsers": "Criar um grupo e convidar pessoas", + "thisDevice": "Este dispositivo:", + "startConversation": "Iniciar uma conversa", + "publicSpaces": "Espaços públicos", + "blockedUsers": "Usuários bloqueados", + "passwordIsWrong": "A senha digitada está incorreta", + "pleaseEnterYourCurrentPassword": "Digite sua senha atual", + "groupCanBeFoundViaSearch": "Grupos podem ser encontrados por pesquisa", + "publicLink": "Link público", + "noUsersFoundWithQuery": "Infelizmente, não foi encontrado usuário com \"{query}\". Verifique se digitou corretamente.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "block": "Bloquear", + "nothingFound": "Nada foi encontrado...", + "yourGlobalUserIdIs": "Seu ID global de usuário é: ", + "decline": "Rejeitar", + "newPassword": "Nova senha", + "passwordsDoNotMatch": "As senhas não correspondem", + "commandHint_sendraw": "Enviar JSON puro", + "wrongRecoveryKey": "Desculpe... esta não parece ser a chave de recuperação correta.", + "subspace": "Subespaço", + "select": "Selecionar", + "pleaseChooseAStrongPassword": "Escolha uma senha forte", + "blockUsername": "Ignorar nome de usuário", + "addChatOrSubSpace": "Adicionar conversa ou subespaço", + "groupName": "Nome do grupo", + "leaveEmptyToClearStatus": "Deixe em branco para limpar seu estado.", + "joinSpace": "Entrar no espaço", + "searchForUsers": "Pesquisar por @usuários...", + "databaseMigrationTitle": "O banco de dados está otimizado", + "searchChatsRooms": "Pesquisar por #conversas, @usuários...", + "databaseMigrationBody": "Aguarde. Isto pode demorar um pouco.", + "youInvitedToBy": "📩 Você foi convidado através do link para:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "forwardMessageTo": "Encaminhar mensagem para {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "formattedMessagesDescription": "Exibir conteúdo de mensagem rico, como texto em negrito usando markdown.", + "verifyOtherUser": "🔐 Verificar outro usuário", + "verifyOtherDevice": "🔐 Verificar outro dispositivo", + "acceptedKeyVerification": "{sender} aceitou a verificação de chaves", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} iniciou a verificação de chaves", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Transparente", + "databaseBuildErrorBody": "Não foi possível construir o banco de dados SQLite. O app tentará utilizar o banco de dados legado por enquanto. Relate este erro aos desenvolvedores em {url}. A mensagem de erro é: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "Ocorreu um erro enquanto o app era iniciado", + "restoreSessionBody": "O app tentará agora restaurar sua sessão a partir do backup. Relate isto ao desenvolvedor em {url}. A mensagem de erro é: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceipts": "Enviar recibos de leitura", + "sendTypingNotificationsDescription": "Outros participantes nesta conversa podem ver quando você está digitando uma nova mensagem.", + "formattedMessages": "Mensagens formatadas", + "presenceStyle": "Presença:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Mostrar as mensagens de estado de outros usuários", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "commandHint_ignore": "Ignorar o ID Matrix especificado", + "commandHint_unignore": "Parar de ignorar o ID Matrix especificado", + "hidePresences": "Ocultar lista de estado?", + "sessionLostBody": "Sua sessão foi desconectada. Relate este ao desenvolvedor em {url}. A mensagem de erro é: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "Outros participantes nesta conversa podem ver quando você tiver lido uma mensagem.", + "verifyOtherUserDescription": "Se você verificar outro usuário, você terá certeza que você conhece com quem está conversando. 💪\n\nAo iniciar uma verificação, você e o outro usuário receberão um pop-up no app. Então vocês receberão uma série de emojis ou números para comparar um com o outro.\n\nA melhor maneira de fazer este procedimento é se encontrar pessoalmente ou através de uma chamada de vídeo. 👭", + "requestedKeyVerification": "{sender} solicitou uma verificação de chaves", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "verifyOtherDeviceDescription": "Ao verificar outro dispositivo, os dispositivos poderão trocar chaves, aumentando sua segurança. 💪 Ao iniciar a verificação, um pop-up aparecerá no app em ambos os aparelhos. Então você verá uma série de emojis ou números que você terá que comparar um com o outro. É melhor fazer esse procedimento com ambos os dispositivos em mãos antes de começar a verificação. 🤳", + "canceledKeyVerification": "{sender} cancelou a verificação de chaves", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} está pronto para a verificação de chaves", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} concluiu a verificação de chaves", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "stickers": "Figurinhas", + "discover": "Explorar", + "incomingMessages": "Mensagens recebidas", + "unreadChatsInApp": "{appname}: {unread} conversas não lidas", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "appLockDescription": "Bloquear o app com um código PIN quando não estiver usando", + "accessAndVisibilityDescription": "Quem pode entrar nesta conversa e como a conversa pode ser descoberta.", + "calls": "Chamadas", + "customEmojisAndStickers": "Emojis e stickers customizados", + "customEmojisAndStickersBody": "Adicionar ou compartilhar emojis ou stickers customizados que podem ser usados em qualquer conversa.", + "hideRedactedMessages": "Ocultar mensagens apagadas", + "hideRedactedMessagesBody": "Se alguém apagar uma mensagem, esta mensagem não será mais visível na conversa.", + "hideInvalidOrUnknownMessageFormats": "Ocultar formatos de mensagem inválidos ou desconhecidos", + "hideMemberChangesInPublicChats": "Ocultar mudanças de membro em conversas públicas", + "hideMemberChangesInPublicChatsBody": "Não mostre se alguém entrou ou saiu da conversa para melhorar a legibilidade.", + "overview": "Visão geral", + "notifyMeFor": "Notificar me para", + "usersMustKnock": "Usuários devem bater na porta", + "noOneCanJoin": "Ninguém pode entrar", + "knocking": "Batendo na porta", + "chatCanBeDiscoveredViaSearchOnServer": "A conversa pode ser descoberta por pesquisa em {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "publicChatAddresses": "Endereços de conversas públicas", + "thereAreCountUsersBlocked": "Nesse momento, há {count} usuários bloqueados.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "globalChatId": "ID global de conversa", + "accessAndVisibility": "Acesso e visibilidade", + "passwordRecoverySettings": "Configurações de recuperação de senha", + "userWouldLikeToChangeTheChat": "{user} gostaria de entrar na conversa.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Nenhum link público foi criado ainda", + "userRole": "Cargo do usuário", + "minimumPowerLevel": "{level} é o nível mínimo de poder.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "A criptografia do banco de dados não é suportada nesta plataforma", + "createNewAddress": "Criar um novo endereço", + "knock": "Bater na porta", + "searchIn": "Procurar na conversa {chat}...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "restricted": "Restrito", + "knockRestricted": "Bater na porta restrito", + "searchMore": "Pesquisar mais...", + "gallery": "Galeria", + "files": "Arquivos", + "more": "Mais", + "deletePushRuleCanNotBeUndone": "Se você apagar esta configuração de notificação, isso não poderá ser desfeito.", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "setPermissionsLevelDescription": "Selecione um cargo pré-definido abaixo ou digite um nível de permissão personalizado entre 0 e 100.", + "shareKeysWith": "Compartilhar chaves com...", + "setCustomPermissionLevel": "Configurar nível personalizado de permissão", + "ignoreUser": "Ignorar usuário", + "contentNotificationSettings": "Configurações de notificações de conteúdo", + "generalNotificationSettings": "Configurações de notificações gerais", + "notificationRuleContainsUserNameDescription": "Notifica o usuário quando a mensagem contém o seu nome de usuário.", + "notificationRuleMaster": "Silenciar todas as notificações", + "notificationRuleMasterDescription": "Sobrescreve todas as outras regras e desativa todas as notificações.", + "notificationRuleContainsDisplayName": "Contém o nome de exibição", + "notificationRuleRoomnotif": "Notificação de sala", + "notificationRuleIsRoomMentionDescription": "Notifica o usuário quando há uma menção de sala.", + "notificationRuleRoomnotifDescription": "Notifica o usuário quando uma mensagem contém '@room'.", + "notificationRuleTombstone": "Morte", + "notificationRuleReaction": "Reação", + "notificationRuleSuppressEditsDescription": "Omite notificações de mensagens editadas.", + "notificationRuleEncryptedRoomOneToOneDescription": "Notifica o usuário de mensagens em salas criptografas de 2 pessoas.", + "notificationRuleRoomOneToOne": "Sala de 2 pessoas", + "notificationRuleMessageDescription": "Notifica o usuário de mensagens gerais.", + "notificationRuleEncrypted": "Criptografado", + "unknownPushRule": "Regra de push desconhecida '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "notificationRuleServerAclDescription": "Omite notificações de eventos de ACL de servidor.", + "unread": "Não lido", + "changeTheCanonicalRoomAlias": "Alterar o endereço público principal da conversa", + "doesNotSeemToBeAValidHomeserver": "Não parece ser um servidor compatível. URL errada?", + "website": "Site", + "compress": "Comprimir", + "invalidUrl": "URL inválida", + "appWantsToUseForLoginDescription": "Aqui, você permite que o app e o site compartilhem informações sobre você.", + "notificationRuleMemberEvent": "Evento de membro", + "crossVerifiedDevicesIfEnabled": "Dispositivos verificados por ambos se ativado", + "countInvited": "{count} convidados", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "checkList": "Lista de tarefas", + "synchronizingPleaseWaitCounter": " Sincronizando… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "invitedBy": "📩 Convidado por {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "markAsUnread": "Marcar como não lido", + "updateInstalled": "🎉 Atualização da versão {version} instalada!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Registro de mudanças", + "sendCanceled": "Envio cancelado", + "unableToJoinChat": "Não foi possível entrar na conversa. Talvez a outra pessoa já fechou a conversa.", + "whatIsAHomeserver": "O que é um servidor?", + "prepareSendingAttachment": "Preparando o envio do anexo...", + "sendingAttachment": "Enviando o anexo...", + "noticeChatBackupDeviceVerification": "Observação: Quando você conecta todos os seus dispositivos ao backup de conversas, eles são verificados automaticamente.", + "continueText": "Continuar", + "blur": "Borrar:", + "opacity": "Opacidade:", + "setWallpaper": "Configurar plano de fundo", + "noContactInformationProvided": "O servidor não fornece nenhuma informação válida de contato", + "contactServerAdmin": "Contatar o administrador do servidor", + "contactServerSecurity": "Contatar a segurança do servidor", + "supportPage": "Página de ajuda", + "italicText": "Texto em itálico", + "strikeThrough": "Risco", + "appWantsToUseForLogin": "Usar '{server}' para conectar", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "open": "Abrir", + "roomNotificationSettings": "Configurações de notificações de sala", + "userSpecificNotificationSettings": "Configurações de notificações específicas ao usuário", + "otherNotificationSettings": "Configurações de outras notificações", + "notificationRuleContainsUserName": "Contém o nome de usuário", + "notificationRuleSuppressNotices": "Omitir mensagens automáticas", + "notificationRuleInviteForMe": "Convite para mim", + "notificationRuleMemberEventDescription": "Omite todas as notificações de eventos de membro.", + "notificationRuleIsUserMention": "Menção de usuário", + "notificationRuleContainsDisplayNameDescription": "Notifica o usuário quando uma mensagem contém seu nome de exibição.", + "notificationRuleCall": "Chamada", + "sentVoiceMessage": "🎙️ {duration} - Mensagem de voz de {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "crossVerifiedDevices": "Dispositivos verificados por ambos", + "takeAPhoto": "Tirar uma foto", + "youHaveKnocked": "Bateram na sua porta", + "changeGeneralChatSettings": "Alterar configurações gerais de conversa", + "inviteOtherUsers": "Convidar outros usuários para esta conversa", + "adminLevel": "{level} - Administrador", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheChatPermissions": "Alterar as permissões da conversa", + "changeTheVisibilityOfChatHistory": "Alterar a visibilidade do histórico de conversa", + "sendImages": "Enviar {count} imagens", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "goToSpace": "Ir ao espaço: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "discoverHomeservers": "Explorar servidores", + "loginWithMatrixId": "Conectar com ID Matrix", + "calculatingFileSize": "Calculando o tamanho do arquivo...", + "compressVideo": "Comprimindo o vídeo...", + "generatingVideoThumbnail": "Gerando a miniatura do vídeo...", + "oneOfYourDevicesIsNotVerified": "Um dos seus dispositivos não está verificado", + "serverLimitReached": "Limite do servidor alcançado! Esperando {seconds} segundos...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "manageAccount": "Gerenciar conta", + "newChatRequest": "📩 Nova solicitação de conversa", + "userLevel": "{level} - Usuário", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "enterNewChat": "Abrir a conversa nova", + "notificationRuleSuppressNoticesDescription": "Omite notificações de clientes automatizados, como bots.", + "notificationRuleInviteForMeDescription": "Notifica o usuário quando for convidado para uma sala.", + "approve": "Aprovar", + "homeserverDescription": "Todos os seus dados são armazenados no servidor, parecido como um provedor de e-mail. Pode escolher qual servidor quer usar, enquanto ainda conversa com todo mundo. Aprenda mais em https://matrix.org.", + "notificationRuleEncryptedRoomOneToOne": "Sala criptografada de 2 pessoas", + "pleaseWaitUntilInvited": "Aguarde até que alguém da sala te convide.", + "waitingForServer": "Aguardando o servidor...", + "notificationRuleEncryptedDescription": "Notifica o usuário de mensagens em salas criptografadas.", + "sendRoomNotifications": "Enviar notificações de @room", + "sendingAttachmentCountOfCount": "Enviando o {index}° anexo de {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "welcomeText": "Olá! 👋 Este é o FluffyChat. Você pode se conectar com qualquer servidor que é compatível com o https://matrix.org. E então conversar com qualquer um. É uma rede gigante e descentralizada de conversa!", + "notificationRuleRoomServerAclDescription": "Omite notificações de listas de controle de acesso de servidor de uma sala (ACL).", + "appIntroduction": "O FluffyChat permite que você converse com os seus amigos entre mensageiros diferentes. Aprenda mais em https://matrix.org ou toque em *Continuar*.", + "notificationRuleIsUserMentionDescription": "Notifica o usuário quando é mencionado diretamente em uma mensagem.", + "notificationRuleSuppressEdits": "Omitir edições", + "shareKeysWithDescription": "Quais dispositivos devem ser confiados para que possam ler suas mensagens em conversas criptografas?", + "allDevices": "Todos os dispositivos", + "aboutHomeserver": "Sobre {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "swipeRightToLeftToReply": "Deslizar da direita pra esquerda para responder", + "verifiedDevicesOnly": "Somente dispositivos verificados", + "boldText": "Texto em negrito", + "recordAVideo": "Gravar um vídeo", + "optionalMessage": "(Opcional) mensagem...", + "joinedChats": "Conversas que entrou", + "notSupportedOnThisDevice": "Não há suporte neste dispositivo", + "normalUser": "Usuário normal", + "commandHint_roomupgrade": "Atualizar esta sala para a versão de sala especificada", + "countChatsAndCountParticipants": "{chats} conversas e {participants} participantes", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Mais nenhuma conversa foi encontrada...", + "noChatsFoundHere": "Nenhuma conversa encontrada aqui ainda. Inicie uma nova conversa com alguém usando o botão abaixo. ⤵️", + "space": "Espaço", + "spaces": "Espaços", + "moderatorLevel": "{level} - Moderador", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeTheDescriptionOfTheGroup": "Alterar a descrição da conversa", + "chatPermissionsDescription": "Configurar qual o nível de poder é necessário para certas ações nesta conversa. Os níveis de poder 0, 50, e 100 são normalmente para representar usuários, moderadores, e administradores, mas qualquer configuração é possível.", + "serverInformation": "Informações do servidor:", + "name": "Nome", + "version": "Versão", + "pleaseFillOut": "Preencha", + "addLink": "Adicionar link", + "notificationRuleRoomServerAcl": "ACL de servidores de sala", + "notificationRuleCallDescription": "Notifica o usuário de chamadas.", + "notificationRuleRoomOneToOneDescription": "Notifica o usuário de mensagens em salas de duas pessoas.", + "notificationRuleMessage": "Mensagem", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Notifica o usuário de eventos de widget do Jitsi.", + "notificationRuleServerAcl": "Omitir eventos de ACL de servidor", + "notificationRuleIsRoomMention": "Menção de sala", + "notificationRuleTombstoneDescription": "Notifica o usuário de mensagens de desativação de salas.", + "notificationRuleReactionDescription": "Omite notificações de reações.", + "commandHint_logout": "Desconecte-se do seu dispositivo atual", + "commandHint_logoutall": "Desconecte-se de todos os dispositivos ativos", + "displayNavigationRail": "Mostrar trilha de navegação em dispositivo móvel", + "previous": "Anterior", + "otherPartyNotLoggedIn": "A outra pessoa não tem nenhum dispositivo conectado no momento e portanto não consegue receber mensagens!", + "customReaction": "Reação personalizada", + "moreEvents": "Mais eventos", + "declineInvitation": "Rejeitar convite", + "noMessagesYet": "Nenhuma mensagem ainda", + "longPressToRecordVoiceMessage": "Segure para gravar uma mensagem de voz.", + "pause": "Pausar", + "resume": "Retomar", + "newSubSpace": "Novo sub espaço", + "moveToDifferentSpace": "Mover para espaço diferente", + "moveUp": "Mover para cima", + "moveDown": "Mover para baixo", + "removeFromSpaceDescription": "A conversa será removida do espaço mas ainda aparecerá na sua lista de conversas.", + "countChats": "{chats} conversas", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Membro do espaço de {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Membro do espaço de {spaces} pode bater na porta", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Doar", + "startedAPoll": "{username} iniciou uma enquete.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Enquete", + "startPoll": "Abrir enquete", + "endPoll": "Fechar enquete", + "answersVisible": "Respostas visíveis", + "answersHidden": "Respostas ocultas", + "pollQuestion": "Questão da enquete", + "answerOption": "Opção de resposta", + "addAnswerOption": "Adicionar opção de resposta", + "allowMultipleAnswers": "Permitir várias respostas", + "pollHasBeenEnded": "A enquete terminou", + "countVotes": "{count, plural, =1{Um voto} other{{count} votos}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "As respostas ficarão visíveis quando a enquete terminar", + "replyInThread": "Responder no tópico", + "countReplies": "{count, plural, =1{Uma resposta} other{{count} respostas}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Tópico", + "backToMainChat": "Voltar à conversa principal", + "saveChanges": "Salvar alterações", + "createSticker": "Criar figurinha ou emoji", + "useAsSticker": "Usar como figurinha", + "useAsEmoji": "Usar como emoji", + "stickerPackNameAlreadyExists": "O nome do pacote de figurinhas já existe", + "newStickerPack": "Novo pacote de figurinhas", + "stickerPackName": "Nome do pacote de figurinhas", + "attribution": "Créditos", + "skipChatBackup": "Pular backup de conversas", + "skipChatBackupWarning": "Tem certeza? Se não ativar o backup de conversas, você pode perder o acesso às suas mensagens se trocar de dispositivo.", + "loadingMessages": "Carregando mensagens", + "setupChatBackup": "Configurar backup de conversas", + "changedTheChatDescription": "{username} alterou a descrição da conversa", + "changedTheChatName": "{username} alterou o nome da conversa", + "versionWithNumber": "Versão: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "advancedConfigs": "", + "theProcessWasCanceled": "" +} diff --git a/assets/l10n/intl_pt_PT.arb b/lib/l10n/intl_pt_PT.arb similarity index 60% rename from assets/l10n/intl_pt_PT.arb rename to lib/l10n/intl_pt_PT.arb index 9db37c78e..c6a01d358 100644 --- a/assets/l10n/intl_pt_PT.arb +++ b/lib/l10n/intl_pt_PT.arb @@ -3,1205 +3,1331 @@ "@repeatPassword": {}, "about": "Acerca de", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "Aceitar", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "{username} aceitou o convite", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "Conta", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "activatedEndToEndEncryption": "{username} ativou encriptação ponta-a-ponta", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "addEmail": "Adicionar correio eletrónico", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "addToSpace": "Adicionar ao espaço", "@addToSpace": {}, "admin": "Admin", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "alcunha", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "Todos(as)", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "allChats": "Todas as conversas", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "answeredTheCall": "{senderName} atendeu a chamada", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "Qualquer pessoa pode entrar", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "Arquivo", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "Todos os visitantes podem entrar", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "Tens a certeza?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSureYouWantToLogout": "Tens a certeza que queres sair?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "Para poderes assinar a outra pessoa, por favor, insere a tua senha de armazenamento seguro ou a chave de recuperação.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "Aceitar este pedido de verificação de {username}?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "autoplayImages": "Automaticamente reproduzir autocolantes e emotes animados", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "sendOnEnter": "Enviar com Enter", "@sendOnEnter": {}, "badServerVersionsException": "O servidor suporta as versões Spec:\n{serverVersions}\nMas esta aplicação apenas suporta {suportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "badServerLoginTypesException": "O servidor suporta os tipos de início de sessão:\n{serverVersions}\nMas esta aplicação apenas suporta:\n{suportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "banFromChat": "Banir da conversa", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "Banido(a)", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "{username} baniu {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "blockDevice": "Bloquear dispositivo", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "Bloqueado", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "Mensagens de robôs", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "Cancelar", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "cantOpenUri": "Não é possível abrir o URI {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "changeDeviceName": "Alterar nome do dispositivo", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatPermissions": "{username} alterou as permissões da conversa", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheDisplaynameTo": "{username} alterou o seu nome para: '{displayname}'", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username} alterou as regras de acesso de visitantes para: {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRules": "{username} alterou as regras de entrada", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username} alterou as regras de entrada para: {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username} alterou o seu avatar", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomAliases": "{username} alterou as alcunhas da sala", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "{username} alterou a ligação de convite", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changePassword": "Alterar palavra-passe", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheHomeserver": "Alterar o servidor", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "Alterar o teu estilo", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheNameOfTheGroup": "Alterar o nome do grupo", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "changeYourAvatar": "Alterar o teu avatar", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "A encriptação foi corrompida", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "Conversa", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "yourChatBackupHasBeenSetUp": "A cópia de segurança foi configurada.", "@yourChatBackupHasBeenSetUp": {}, "chatBackup": "Cópia de segurança de conversas", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackupDescription": "A tuas mensagens antigas estão protegidas com uma chave de recuperação. Por favor, certifica-te que não a perdes.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "Detalhes de conversa", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chatHasBeenAddedToThisSpace": "A conversa foi adicionada a este espaço", "@chatHasBeenAddedToThisSpace": {}, "chats": "Conversas", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "Escolhe uma palavra-passe forte", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "Limpar arquivo", "@clearArchive": {}, "close": "Fechar", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_ban": "Banir o utilizador dado desta sala", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_html": "Enviar texto formatado com HTML", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "Convidar o utilizador dado a esta sala", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandHint_join": "Entrar na sala dada", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_kick": "Remover o utilizador dado desta sala", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_leave": "Sair desta sala", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_me": "Descreve-te", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "commandHint_myroomavatar": "Definir a tua imagem para esta sala (por mxc-uri)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_myroomnick": "Definir o teu nome para esta sala", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_op": "Definir o nível de poder do utilizador dado (por omissão: 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_plain": "Enviar texto não formatado", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_react": "Enviar respostas como reações", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "commandHint_send": "Enviar texto", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "commandHint_unban": "Perdoar o utilizador dado", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "commandInvalid": "Comando inválido", "@commandInvalid": { - "type": "text" + "type": "String" }, "commandMissing": "{command} não é um comando.", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "compareEmojiMatch": "Compara e certifica-te que os emojis que se seguem correspondem aos do outro dispositivo:", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "Compara e certifica-te que os números que se seguem correspondem aos do outro dispositivo:", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "configureChat": "Configurar conversa", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "Confirmar", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "Ligar", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "contactHasBeenInvitedToTheGroup": "O contacto foi convidado para o grupo", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "Contém nome de exibição", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "Contém nome de utilizador", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "O conteúdo foi denunciado aos admins do servidor", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "Copiado para a área de transferência", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "Copiar", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "Copiar para a área de transferência", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "Não foi possível desencriptar mensagem: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "countParticipants": "{count} participantes", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "create": "Criar", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "createdTheChat": "{username} criou a conversa", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "createNewSpace": "Novo espaço", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "currentlyActive": "Ativo(a) agora", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "Escuro", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "dateAndTimeOfDay": "{date} às {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{day}-{month}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "dateWithYear": "{day}-{month}-{year}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "deactivateAccountWarning": "Isto irá desativar a tua conta. Não é reversível! Tens a certeza?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "defaultPermissionLevel": "Nível de permissão normal", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "Eliminar", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "Eliminar conta", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "Eliminar mensagem", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "Dispositivo", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "ID de dispositivo", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "Dispositivos", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "Conversas diretas", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "Nome de exibição alterado", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "Descarregar ficheiro", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "Editar", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "Editar servidores bloqueados", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "Editar nome de exibição", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "Editar alcunhas da sala", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "Editar avatar da sala", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Emote já existente!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "Código de emote inválido!", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "Pacotes de emotes da sala", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Configurações de emotes", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteShortcode": "Código do emote", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Precisas de escolher um código de emote e uma imagem!", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "Conversa vazia", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "Ativar pacote de emotes globalmente", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "Ativar encriptação", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryptionWarning": "Nunca mais poderás desativar a encriptação. Tens a certeza?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "Encriptada", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "Encriptação", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "A encriptação não está ativada", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName} terminou a chamada", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "enterAnEmailAddress": "Insere um endereço de correio eletrónico", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "homeserver": "Servidor", "@homeserver": {}, "enterYourHomeserver": "Insere o teu servidor", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "errorObtainingLocation": "Erro ao obter localização: {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "everythingReady": "Tudo a postos!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "Extremamente ofensivo", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "Nome do ficheiro", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "Tamanho da letra", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "Reencaminhar", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "Ir para a nova sala", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "Grupo", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "O grupo é público", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "groups": "Grupos", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "groupWith": "Grupo com {displayname}", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "guestsAreForbidden": "São proibidos visitantes", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "Podem entrar visitantes", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "hasWithdrawnTheInvitationFor": "{username} revogou o convite para {targetName}", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "help": "Ajuda", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "hideRedactedEvents": "Esconder eventos eliminados", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "Esconder eventos desconhecidos", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "howOffensiveIsThisContent": "Quão ofensivo é este conteúdo?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "ID", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "Identidade", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignore": "Ignorar", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "Utilizadores ignorados", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "Eu cliquei na ligação", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "Senha ou chave de recuperação incorretos", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "Inofensivo", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "Convidar contacto", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "Convidar contacto para {groupName}", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "invited": "Convidado(a)", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUser": "{username} convidou {targetName}", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "invitedUsersOnly": "Utilizadores(as) convidados(as) apenas", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteForMe": "Convite para mim", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteText": "{username} convidou-te para o FluffyChat.\n1. Instala o FluffyChat: https://fluffychat.im\n2. Regista-te ou inicia sessão.\n3. Abre a ligação de convite: {link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "isTyping": "está a escrever…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "joinedTheChat": "{username} entrou na conversa", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "joinRoom": "Entrar na sala", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "kicked": "{username} expulsou {targetName}", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickedAndBanned": "{username} expulsou e baniu {targetName}", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickFromChat": "Expulsar da conversa", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "lastActiveAgo": "Ativo(a) pela última vez: {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "leave": "Sair", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "leftTheChat": "Saiu da conversa", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "Licença", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "Claro", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "loadCountMoreParticipants": "Carregar mais {count} participantes", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "loadingPleaseWait": "A carregar... Por favor aguarde.", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "loadMore": "Carregar mais…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "locationDisabledNotice": "Os serviços de localização estão desativados. Por favor, ativa-os para poder partilhar a sua localização.", "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "locationPermissionDeniedNotice": "Permissão de localização recusada. Por favor, concede permissão para poderes partilhar a tua posição.", "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "Entrar", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "logInTo": "Entrar em {homeserver}", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "logout": "Sair", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "memberChanges": "Alterações de membros", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "Mencionar", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "Mensagens", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "Moderador", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "muteChat": "Silenciar conversa", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "Por favor,", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "Nova conversa", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "Nova mensagem no FluffyChat", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newVerificationRequest": "Novo pedido de verificação!", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "Próximo", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "Não", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "Nenhuma ligação ao servidor", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "noEmotesFound": "Nenhuns emotes encontrados. 😕", "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "Só podes ativar a encriptação quando a sala não for publicamente acessível.", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "noGoogleServicesWarning": "Parece que não tens nenhuns serviços da Google no seu telemóvel. É uma boa decisão para a sua privacidade! Para receber notificações instantâneas no FluffyChat, recomendamos que uses https://microg.org/ ou https://unifiedpush.org/.", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "noMatrixServer": "{server1} não é um servidor Matrix, usar {server2}?", "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "none": "Nenhum", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "{username} alterou o avatar da conversa", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "{username} alterou a visibilidade do histórico para: {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "{username} alterou a descrição da conversa para: '{description}'", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheChatNameTo": "{username} alterou o nome da conversa para: '{chatname}'", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username} alterou as regras de acesso de visitantes", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibility": "{username} alterou a visibilidade do histórico", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sendAMessage": "Enviar a mensagem", "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAudio": "Enviar áudio", "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAsText": "Enviar como texto", "@sendAsText": { - "type": "text" + "type": "String" }, "send": "Enviar", "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "appLock": "Bloqueio da aplicação", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "Ainda não adicionaste uma forma de recuperar a tua palavra-passe.", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "noPermission": "Sem permissão", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "Não foram encontradas nenhumas salas…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "Notificações", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "Notificações ativadas para esta conta", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "numUsersTyping": "Estão {count} utilizadores(as) a escrever…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "obtainingLocation": "A obter localização…", "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "offensive": "Offensivo", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "offline": "Offline", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "ok": "ok", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "Online", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "onlineKeyBackupEnabled": "A cópia de segurança online de chaves está ativada", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsPushError": "Ups! Infelizmente, ocorreu um erro ao configurar as notificações instantâneas.", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "Ups, algo correu mal…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "Abrir aplicação para ler mensagens", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "Abrir câmara", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "oneClientLoggedOut": "Um dos teus clientes terminou sessão", @@ -1220,7 +1346,7 @@ "@enableMultiAccounts": {}, "openInMaps": "Abrir nos mapas", "@openInMaps": { - "type": "text", + "type": "String", "placeholders": {} }, "link": "Ligação", @@ -1229,327 +1355,342 @@ "@serverRequiresEmail": {}, "or": "Ou", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "participant": "Participante", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "passphraseOrKey": "senha ou chave de recuperação", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "Palavra-passe", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "Palavra-passe esquecida", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "A palavra-passe foi alterada", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "Recuperação de palavra-passe", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "Pessoas", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "Escolher uma imagem", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "Afixar", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "play": "Reproduzir {fileName}", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "pleaseChoose": "Por favor, escolhe", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChooseAPasscode": "Por favor, escolhe um código-passe", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseClickOnLink": "Por favor, clica na ligação no correio eletrónico e depois continua.", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "Por favor, insere 4 dígitos ou deixa vazio para desativar o bloqueio da aplicação.", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "Por favor, insere a tua palavra-passe", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "Por favor, insere o teu código", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "Por favor, insere o teu nome de utilizador", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseFollowInstructionsOnWeb": "Por favor, segue as instruções no website e clica em \"Seguinte\".", "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "privacy": "Privacidade", "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "publicRooms": "Salas públicas", "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "reason": "Razão", "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "redactedAnEvent": "{username} eliminou um evento", "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "recording": "A gravar", "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "redactMessage": "Eliminar mensagem", "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "register": "Registar", "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "reject": "Rejeitar", "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "rejectedTheInvitation": "{username} rejeitou o convite", "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "rejoin": "Reentrar", "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "remove": "Remover", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "removeAllOtherDevices": "Remover todos os outros dispositivos", "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "removedBy": "Removido por {username}", "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removeDevice": "Remover dispositivo", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unbanFromChat": "Perdoar nesta conversa", "@unbanFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "removeYourAvatar": "Remover o teu avatar", "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Exibir conteúdo de mensagem rico", - "@renderRichContent": { - "type": "text", + "type": "String", "placeholders": {} }, "replaceRoomWithNewerVersion": "Substituir sala com versão mais recente", "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "reply": "Responder", "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "reportMessage": "Reportar mensagem", "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "requestPermission": "Pedir permissão", "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "roomHasBeenUpgraded": "A sala foi atualizada", "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "roomVersion": "Versão da sala", "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "saveFile": "Guardar ficheiro", "@saveFile": { - "type": "text", + "type": "String", "placeholders": {} }, "search": "Procurar", "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "security": "Segurança", "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "seenByUser": "Visto por {username}", "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sendFile": "Enviar ficheiro", "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "sendImage": "Enviar imagem", "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendMessages": "Enviar mensagens", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOriginal": "Enviar original", "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "sendSticker": "Enviar autocolante", "@sendSticker": { - "type": "text", + "type": "String", "placeholders": {} }, "sendVideo": "Enviar vídeo", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAFile": "{username} enviar um ficheiro", "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAnAudio": "{username} enviar um áudio", "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAPicture": "{username} enviar uma imagem", "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentASticker": "{username} enviou um autocolante", "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAVideo": "{username} enviou um vídeo", "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "commandHint_clearcache": "Limpar cache", "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "commandHint_create": "Criar uma conversa de grupo vazia\nUsa --no-encryption para desativar a encriptação", "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "commandHint_discardsession": "Descartar sessão", "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "commandHint_dm": "Iniciar uma conversa direta\nUsa --no-encryption para desativar a encriptação", "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "dehydrate": "Exportar sessão e limpar dispositivo", @@ -1565,618 +1706,5 @@ "hydrateTor": "Utilizadores do TOR: Importar sessão", "@hydrateTor": {}, "dehydrateTorLong": "Para utilizadores do TOR, é recomendado exportar a sessão antes de fechar a janela.", - "@dehydrateTorLong": {}, - "@showPassword": { - "type": "text", - "placeholders": {} - }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@theyMatch": { - "type": "text", - "placeholders": {} - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@unknownDevice": { - "type": "text", - "placeholders": {} - }, - "@reportErrorDescription": {}, - "@setPermissionsLevel": { - "type": "text", - "placeholders": {} - }, - "@unsupportedAndroidVersion": {}, - "@widgetJitsi": {}, - "@youAreNoLongerParticipatingInThisChat": { - "type": "text", - "placeholders": {} - }, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@toggleMuted": { - "type": "text", - "placeholders": {} - }, - "@title": { - "description": "Title for the application", - "type": "text", - "placeholders": {} - }, - "@verifySuccess": { - "type": "text", - "placeholders": {} - }, - "@startFirstChat": {}, - "@callingAccount": {}, - "@setColorTheme": {}, - "@nextAccount": {}, - "@singlesignon": { - "type": "text", - "placeholders": {} - }, - "@warning": { - "type": "text", - "placeholders": {} - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@user": {}, - "@videoCall": { - "type": "text", - "placeholders": {} - }, - "@youAcceptedTheInvitation": {}, - "@userAndOthersAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "count": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@userIsTyping": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@waitingPartnerAcceptRequest": { - "type": "text", - "placeholders": {} - }, - "@writeAMessage": { - "type": "text", - "placeholders": {} - }, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "@userAndUserAreTyping": { - "type": "text", - "placeholders": { - "username": {}, - "username2": {} - } - }, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@unavailable": { - "type": "text", - "placeholders": {} - }, - "@previousAccount": {}, - "@fromTheInvitation": { - "type": "text", - "placeholders": {} - }, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@toggleFavorite": { - "type": "text", - "placeholders": {} - }, - "@widgetNameError": {}, - "@unpin": { - "type": "text", - "placeholders": {} - }, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@unblockDevice": { - "type": "text", - "placeholders": {} - }, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@pushNotificationsNotAvailable": {}, - "@storeInAppleKeyChain": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@voiceMessage": { - "type": "text", - "placeholders": {} - }, - "@wipeChatBackup": { - "type": "text", - "placeholders": {} - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@signInWithPassword": {}, - "@weSentYouAnEmail": { - "type": "text", - "placeholders": {} - }, - "@makeAdminDescription": {}, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@transferFromAnotherDevice": { - "type": "text", - "placeholders": {} - }, - "@pushRules": { - "type": "text", - "placeholders": {} - }, - "@saveKeyManuallyDescription": {}, - "@whyIsThisMessageEncrypted": {}, - "@unreadChats": { - "type": "text", - "placeholders": { - "unreadCount": {} - } - }, - "@setChatDescription": {}, - "@userLeftTheChat": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@toggleUnread": { - "type": "text", - "placeholders": {} - }, - "@noOtherDevicesFound": {}, - "@whoIsAllowedToJoinThisGroup": { - "type": "text", - "placeholders": {} - }, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@submit": { - "type": "text", - "placeholders": {} - }, - "@videoCallsBetaWarning": {}, - "@unmuteChat": { - "type": "text", - "placeholders": {} - }, - "@yes": { - "type": "text", - "placeholders": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@username": { - "type": "text", - "placeholders": {} - }, - "@fileIsTooBigForServer": {}, - "@verified": { - "type": "text", - "placeholders": {} - }, - "@setStatus": { - "type": "text", - "placeholders": {} - }, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@optionalRedactReason": {}, - "@waitingPartnerEmoji": { - "type": "text", - "placeholders": {} - }, - "@tryToSendAgain": { - "type": "text", - "placeholders": {} - }, - "@visibleForAllParticipants": { - "type": "text", - "placeholders": {} - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@setAsCanonicalAlias": { - "type": "text", - "placeholders": {} - }, - "@whyDoYouWantToReportThis": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@withTheseAddressesRecoveryDescription": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@skip": { - "type": "text", - "placeholders": {} - }, - "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@reportUser": {}, - "@sharedTheLocation": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@unbannedUser": { - "type": "text", - "placeholders": { - "username": {}, - "targetName": {} - } - }, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@redactMessageDescription": {}, - "@recoveryKey": {}, - "@invalidInput": {}, - "@yourPublicKey": { - "type": "text", - "placeholders": {} - }, - "@tooManyRequestsWarning": { - "type": "text", - "placeholders": {} - }, - "@doNotShowAgain": {}, - "@report": {}, - "@status": { - "type": "text", - "placeholders": {} - }, - "@verifyStart": { - "type": "text", - "placeholders": {} - }, - "@unverified": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@sentCallInformations": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@theyDontMatch": { - "type": "text", - "placeholders": {} - }, - "@youHaveBeenBannedFromThisChat": { - "type": "text", - "placeholders": {} - }, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@verifyTitle": { - "type": "text", - "placeholders": {} - }, - "@foregroundServiceRunning": {}, - "@voiceCall": {}, - "@unknownEncryptionAlgorithm": { - "type": "text", - "placeholders": {} - }, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@whoCanPerformWhichAction": { - "type": "text", - "placeholders": {} - }, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@you": { - "type": "text", - "placeholders": {} - }, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, - "@removeFromSpace": {}, - "@sourceCode": { - "type": "text", - "placeholders": {} - }, - "@roomUpgradeDescription": {}, - "@userSentUnknownEvent": { - "type": "text", - "placeholders": { - "username": {}, - "type": {} - } - }, - "@scanQrCode": {}, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@waitingPartnerNumbers": { - "type": "text", - "placeholders": {} - }, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setCustomEmotes": { - "type": "text", - "placeholders": {} - }, - "@startedACall": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@systemTheme": { - "type": "text", - "placeholders": {} - }, - "@visibilityOfTheChatHistory": { - "type": "text", - "placeholders": {} - }, - "@settings": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@wallpaper": { - "type": "text", - "placeholders": {} - }, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@statusExampleMessage": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@widgetName": {}, - "@errorAddingWidget": {}, - "@commandHint_hug": {}, - "@replace": {}, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@visibleForEveryone": { - "type": "text", - "placeholders": {} - }, - "@newSpace": {}, - "@unknownEvent": { - "type": "text", - "placeholders": { - "type": {} - } - }, - "@emojis": {}, - "@share": { - "type": "text", - "placeholders": {} - }, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@time": {}, - "@custom": {}, - "@noBackupWarning": {}, - "@fromJoining": { - "type": "text", - "placeholders": {} - }, - "@verify": { - "type": "text", - "placeholders": {} - }, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@setInvitationLink": { - "type": "text", - "placeholders": {} - }, - "@pinMessage": {}, - "@invite": {}, - "@indexedDbErrorTitle": {}, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@placeCall": {} -} \ No newline at end of file + "@dehydrateTorLong": {} +} diff --git a/assets/l10n/intl_ro.arb b/lib/l10n/intl_ro.arb similarity index 76% rename from assets/l10n/intl_ro.arb rename to lib/l10n/intl_ro.arb index 00b17e74c..4fde7117d 100644 --- a/assets/l10n/intl_ro.arb +++ b/lib/l10n/intl_ro.arb @@ -2,372 +2,412 @@ "@@last_modified": "2021-08-14 12:41:09.918296", "about": "Despre", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "Accept", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "{username} a aceptat invitați", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "Cont", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "activatedEndToEndEncryption": "{username} a activat criptarea end-to-end", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "admin": "Administrator", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "poreclă", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "answeredTheCall": "{senderName} a acceptat apelul", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "Oricine se poate alătura", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "Arhivă", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "Vizitatorii \"guest\" se pot alătura", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "Ești sigur?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "Pentru a putea conecta cealaltă persoană, te rog introdu parola sau cheia ta de recuperare.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "Accepți cererea de verificare de la {username}?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "banFromChat": "Interzis din conversație", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "Interzis", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "{username} a interzis pe {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "blockDevice": "Blochează dispozitiv", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "Anulează", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "changeDeviceName": "Schimbă numele dispozitiv", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "{username} a schimbat poza conversați", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "{username} a schimbat descrierea grupului în '{description}'", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheChatNameTo": "{username} a schimbat porecla în '{chatname}'", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "commandHint_unban": "Dezinterziceți utilizatorul ales din această cameră", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "deviceId": "ID-ul Dispozitiv", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "Dispozitive", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "Chaturi directe", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName} a terminat apelul", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "enterYourHomeserver": "Introduceți homeserverul vostru", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "groupWith": "Grup cu {displayname}", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "howOffensiveIsThisContent": "Cât de ofensiv este acest conținut?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "kickFromChat": "Dați afară din chat", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "rejoin": "Reintrați", "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "sentCallInformations": "{senderName} a trimis informație de apel", "@sentCallInformations": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "showPassword": "Afișați parola", "@showPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "Nu", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "sendMessages": "Trimiteți mesaje", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "submit": "Trimiteți", "@submit": { - "type": "text", + "type": "String", "placeholders": {} }, "unreadChats": "{unreadCount, plural, =1{Un chat necitit} other{{unreadCount} chaturi necitite}}", "@unreadChats": { - "type": "text", + "type": "String", "placeholders": { - "unreadCount": {} + "unreadCount": { + "type": "int" + } } }, "verifySuccess": "A reușit verificarea!", "@verifySuccess": { - "type": "text", + "type": "String", "placeholders": {} }, "voiceMessage": "Mesaj vocal", "@voiceMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "wallpaper": "Imagine de fundal", "@wallpaper": { - "type": "text", + "type": "String", "placeholders": {} }, "reactedWith": "{sender} a reacționat cu {reaction}", "@reactedWith": { - "type": "text", + "type": "String", "placeholders": { - "sender": {}, - "reaction": {} + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } } }, "changePassword": "Schimbați parola", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "Următor", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "Fără conexiune la server", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "Nu ați adăugat încă nici un mod de recuperare pentru parola voastră.", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "Notificări", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "openVideoCamera": "Deschideți camera pentru video", "@openVideoCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "Deschideți aplicația să citiți mesajele", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "Deschideți camera", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "removedBy": "Eliminat de {username}", "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removeDevice": "Eliminați dispozitivul", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "share": "Partajați", "@share": { - "type": "text", + "type": "String", "placeholders": {} }, "shareLocation": "Partajați locația", "@shareLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "skip": "Săriți peste", "@skip": { - "type": "text", + "type": "String", "placeholders": {} }, "sourceCode": "Codul surs", "@sourceCode": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceIsPublic": "Spațiul este public", "@spaceIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "spaceName": "Numele spațiului", "@spaceName": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleFavorite": "Comutați favoritul", "@toggleFavorite": { - "type": "text", + "type": "String", "placeholders": {} }, "unblockDevice": "Debloca dispozitiv", "@unblockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownDevice": "Dispozitiv necunoscut", "@unknownDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "verify": "Verificați", "@verify": { - "type": "text", + "type": "String", "placeholders": {} }, "weSentYouAnEmail": "V-am trimis un email", "@weSentYouAnEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "youAreNoLongerParticipatingInThisChat": "Nu mai participați în acest chat", "@youAreNoLongerParticipatingInThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "yourPublicKey": "Cheia voastră publică", "@yourPublicKey": { - "type": "text", + "type": "String", "placeholders": {} }, "addToSpaceDescription": "Alegeți un spațiu în care să adăugați acest chat.", @@ -382,9 +422,11 @@ "@previousAccount": {}, "userIsTyping": "{username} tastează…", "@userIsTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "widgetCustom": "Personalizat", @@ -395,39 +437,41 @@ "@newGroup": {}, "changedTheRoomInvitationLink": "{username} a schimbat linkul de invitație", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "chat": "Chat", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "chats": "Chaturi", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "invited": "Invitat", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "Conectați-vă", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "Online", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "onlineKeyBackupEnabled": "Backup de cheie online este activat", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "removeFromBundle": "Stergeți din acest pachet", @@ -436,113 +480,121 @@ "@enableMultiAccounts": {}, "participant": "Participant", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "openInMaps": "Deschideți pe hartă", "@openInMaps": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "Vă rugăm să introduceți pinul vostru", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "privacy": "Confidențialitate", "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "pushRules": "Regulile Push", "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, "recording": "Înregistrare", "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "register": "Înregistrați-vă", "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "redactMessage": "Redactați mesaj", "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "roomVersion": "Versiunea camerei", "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "security": "Securitate", "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "sendFile": "Trimiteți fișier", "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "setStatus": "Stabiliți status", "@setStatus": { - "type": "text", + "type": "String", "placeholders": {} }, "settings": "Configurări", "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteForMe": "Invitați pentru mine", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "hasWithdrawnTheInvitationFor": "{username} a retras invitația pentru {targetName}", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "help": "Ajutor", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEncryptionAlgorithm": "Algoritm de criptare necunoscut", "@unknownEncryptionAlgorithm": { - "type": "text", + "type": "String", "placeholders": {} }, "unmuteChat": "Dezamuțați chat", "@unmuteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "unpin": "Anulează fixarea", "@unpin": { - "type": "text", + "type": "String", "placeholders": {} }, "unbannedUser": "{username} a ridicat interzicerea lui {targetName}", "@unbannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "openChat": "Deschideți Chat", @@ -552,7 +604,9 @@ "youBannedUser": "Ați interzis pe {user}", "@youBannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "fileIsTooBigForServer": "Serverul reportează că fișierul este prea mare să fie trimis.", @@ -563,30 +617,32 @@ "@sorryThatsNotPossible": {}, "enableEncryptionWarning": "Activând criptare, nu mai puteți să o dezactivați în viitor. Sunteți sigur?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "commandMissing": "{command} nu este o comandă.", "@commandMissing": { - "type": "text", + "type": "String", "placeholders": { - "command": {} + "command": { + "type": "String" + } }, "description": "State that {command} is not a valid /command." }, "status": "Status", "@status": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "Conectați", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "you": "Voi", "@you": { - "type": "text", + "type": "String", "placeholders": {} }, "start": "Începeți", @@ -597,62 +653,68 @@ "@pinMessage": {}, "wasDirectChatDisplayName": "Chat gol (a fost {oldDisplayName})", "@wasDirectChatDisplayName": { - "type": "text", + "type": "String", "placeholders": { - "oldDisplayName": {} + "oldDisplayName": { + "type": "String" + } } }, "pleaseClickOnLink": "Vă rugăm să deschideți linkul din email și apoi să procedați.", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "reportUser": "Reportați utilizator", "@reportUser": {}, "encryptionNotEnabled": "Criptare nu e activată", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "publicRooms": "Camere Publice", "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "addToBundle": "Adăugați în pachet", "@addToBundle": {}, "theyDontMatch": "Nu sunt asemănători", "@theyDontMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "loadingPleaseWait": "Încărcând... Vă rugăm să așteptați.", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "dateWithoutYear": "{month}-{day}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "theyMatch": "Sunt asemănători", "@theyMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "title": "FluffyChat", "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, "toggleMuted": "Comutați amuțeștarea", "@toggleMuted": { - "type": "text", + "type": "String", "placeholders": {} }, "scanQrCode": "Scanați cod QR", @@ -669,7 +731,9 @@ "@switchToAccount": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "nextAccount": "Contul următor", @@ -694,29 +758,29 @@ "@appearOnTopDetails": {}, "currentlyActive": "Activ acum", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "Conține displayname", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "isTyping": "tastează…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackup": "Backup de chat", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "repeatPassword": "Repetați parola", "@repeatPassword": {}, "changeTheme": "Schimbați tema aplicației", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "chatHasBeenAddedToThisSpace": "Chatul a fost adăugat la acest spațiu", @@ -729,233 +793,259 @@ "@commandHint_markasgroup": {}, "commandHint_ban": "Interziceți acesul utilizatorului ales din această cameră", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_clearcache": "Ștergeți cache", "@commandHint_clearcache": { - "type": "text", + "type": "String", "description": "Usage hint for the command /clearcache" }, "commandHint_create": "Creați un grup de chat gol\nFolosiți --no-encryption să dezactivați criptare", "@commandHint_create": { - "type": "text", + "type": "String", "description": "Usage hint for the command /create" }, "commandHint_discardsession": "Renunțați sesiunea", "@commandHint_discardsession": { - "type": "text", + "type": "String", "description": "Usage hint for the command /discardsession" }, "commandHint_kick": "Dați afară pe utilizatorul ales din această cameră", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_leave": "Renunțați la această cameră", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_myroomavatar": "Alegeți un avatar pentru această cameră (foloșește mxc-uri)", "@commandHint_myroomavatar": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomavatar" }, "commandHint_myroomnick": "Alegeți un displayname pentru această cameră", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_op": "Stabiliți nivelul de putere a utilizatorul ales (implicit: 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_plain": "Trimiteți text simplu/neformatat", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_react": "Trimiteți răspuns ca reacție", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "commandHint_send": "Trimiteți text", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "commandInvalid": "Comandă nevalibilă", "@commandInvalid": { - "type": "text" + "type": "String" }, "compareEmojiMatch": "Vă rugăm să comparați emoji-urile", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "Vă rugăm să comparați numerele", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "Dezcriptarea mesajului a eșuat: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "create": "Creați", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "createdTheChat": "💬{username} a creat chatul", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "createNewSpace": "Spațiu nou", "@createNewSpace": { - "type": "text", + "type": "String", "placeholders": {} }, "dateWithYear": "{year}-{month}-{day}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "allRooms": "Toate chaturi de grup", "@allRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "Înainte", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "groups": "Grupuri", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "hideRedactedEvents": "Ascunde evenimente redactate", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "Ascunde evenimente necunoscute", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "Identitate", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignore": "Ignorați", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "Utilizatori ignorați", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "Am făcut click pe link", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "Parolă sau cheie de recuperare incorectă", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "Inofensiv", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "Invitați contact", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "Invitați contact la {groupName}", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "inviteText": "{username} v-a invitat la FluffyChat.\n1. Instalați FluffyChat: https://fluffychat.im\n2. Înregistrați-vă sau conectați-vă\n3. Deschideți invitația: {link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "joinedTheChat": "👋{username} a intrat în chat", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "kicked": "👞{username} a dat afară pe {targetName}", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "lastActiveAgo": "Ultima dată activ: {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "leave": "Renunțați", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "leftTheChat": "A plecat din chat", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "Permis", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "Luminat", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "loadCountMoreParticipants": "Încărcați încă mai {count} participanți", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "dehydrate": "Exportați sesiunea și ștergeți dispozitivul", @@ -972,196 +1062,200 @@ "@hydrate": {}, "loadMore": "Încarcă mai multe…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "logout": "Deconectați-vă", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "Menționați", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "Mesaje", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "Moderator", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "noEmotesFound": "Nu s-a găsit nici un emote. 😕", "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "Criptare nu poate fi activată până când camera este accesibilă public.", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "none": "Niciunul", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "noPermission": "Fără permisie", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "Nici o cameră nu s-a găsit…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "Notificări activate pentru acest cont", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "obtainingLocation": "Obținând locație…", "@obtainingLocation": { - "type": "text", + "type": "String", "placeholders": {} }, "offline": "Offline", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "Ups, ceva a eșuat…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "reject": "Respingeți", "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "unbanFromChat": "Revoca interzicerea din chat", "@unbanFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "roomHasBeenUpgraded": "Camera a fost actualizată", "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "setCustomEmotes": "Stabiliți emoji-uri personalizate", "@setCustomEmotes": { - "type": "text", + "type": "String", "placeholders": {} }, "setPermissionsLevel": "Stabiliți nivelul de permisii", "@setPermissionsLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "singlesignon": "Autentificare unică", "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, "startedACall": "{senderName} a început un apel", "@startedACall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "statusExampleMessage": "Ce faceți?", "@statusExampleMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "tooManyRequestsWarning": "Prea multe cereri. Vă rugăm să încercați din nou mai tărziu!", "@tooManyRequestsWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEvent": "Evenimet necunoscut '{type}'", "@unknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "type": {} + "type": { + "type": "String" + } } }, "verified": "Verificat", "@verified": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyStart": "Începeți verificare", "@verifyStart": { - "type": "text", + "type": "String", "placeholders": {} }, "videoCall": "Apel video", "@videoCall": { - "type": "text", + "type": "String", "placeholders": {} }, "visibilityOfTheChatHistory": "Vizibilitatea istoria chatului", "@visibilityOfTheChatHistory": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForAllParticipants": "Vizibil pentru toți participanți", "@visibleForAllParticipants": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerEmoji": "Așteptând pe partenerul să accepte emoji-ul…", "@waitingPartnerEmoji": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerNumbers": "Așteptând pe partenerul să accepte numerele…", "@waitingPartnerNumbers": { - "type": "text", + "type": "String", "placeholders": {} }, "warning": "Avertizment!", "@warning": { - "type": "text", + "type": "String", "placeholders": {} }, "whoCanPerformWhichAction": "Cine poate face care acțiune", "@whoCanPerformWhichAction": { - "type": "text", + "type": "String", "placeholders": {} }, "whoIsAllowedToJoinThisGroup": "Cine se poate alătura la acest grup", "@whoIsAllowedToJoinThisGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "whyDoYouWantToReportThis": "De ce doriți să reportați acest conținut?", "@whyDoYouWantToReportThis": { - "type": "text", + "type": "String", "placeholders": {} }, "wipeChatBackup": "Ștergeți backup-ul vostru de chat să creați o nouă cheie de recuperare?", "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "withTheseAddressesRecoveryDescription": "Cu acestea adrese puteți să vă recuperați parola.", "@withTheseAddressesRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "youHaveBeenBannedFromThisChat": "Ați fost interzis din acest chat", "@youHaveBeenBannedFromThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "messageInfo": "Info mesajului", @@ -1180,9 +1274,11 @@ "@publish": {}, "videoWithSize": "Video ({size})", "@videoWithSize": { - "type": "text", + "type": "String", "placeholders": { - "size": {} + "size": { + "type": "String" + } } }, "unsupportedAndroidVersionLong": "Această funcție are nevoie de o versiune de Android mai nouă. Vă rugăm să verificați dacă sunt actualizări sau suport de la Lineage OS.", @@ -1210,13 +1306,17 @@ "youHaveWithdrawnTheInvitationFor": "Ați retras invitația pentru {user}", "@youHaveWithdrawnTheInvitationFor": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youInvitedBy": "📩Ați fost invitat de {user}", "@youInvitedBy": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "unlockOldMessages": "Deblocați mesajele vechi", @@ -1224,19 +1324,25 @@ "youInvitedUser": "📩Ați invitat pe {user}", "@youInvitedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youKicked": "👞Ați dat afară pe {user}", "@youKicked": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "youUnbannedUser": "Ați ridicat interzicerea lui {user}", "@youUnbannedUser": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "storeInAndroidKeystore": "Stoca în Android KeyStore", @@ -1265,7 +1371,9 @@ "@numChats": { "type": "number", "placeholders": { - "number": {} + "number": { + "type": "String" + } } }, "hideUnimportantStateEvents": "Ascundeți evenimente de stare neimportante", @@ -1284,9 +1392,11 @@ "@noOtherDevicesFound": {}, "fileHasBeenSavedAt": "Fișierul a fost salvat la {path}", "@fileHasBeenSavedAt": { - "type": "text", + "type": "String", "placeholders": { - "path": {} + "path": { + "type": "String" + } } }, "jump": "Săriți", @@ -1297,269 +1407,303 @@ "@jumpToLastReadMessage": {}, "memberChanges": "Schimbări de membri", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "Musafiri pot să se alăture", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "Nume de fișier", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "Mărimea fontului", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "fromJoining": "De la alăturare", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "fromTheInvitation": "De la invitația", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "Mergeți la camera nouă", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "Grup", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "Grupul este public", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsAreForbidden": "Musafiri sunt interziși", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "kickedAndBanned": "🙅{username} a dat afară și a interzis pe {targetName} din cameră", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "dehydrateWarning": "Această actiune nu poate fi anulată. Asigurați-vă că păstrați fișierul backup.", "@dehydrateWarning": {}, "joinRoom": "Alăturați la cameră", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "logInTo": "Conectați-vă la {homeserver}", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "locationDisabledNotice": "Servicile de locație sunt dezactivate. Vă rugăm să le activați să împărțiți locația voastră.", "@locationDisabledNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "noGoogleServicesWarning": "Se pare că nu aveți serviciile google pe dispozitivul vostru. Această decizie este bună pentru confidențialitatea voastră! Să primiți notificari push în FluffyChat vă recomandăm https://microg.org/ sau https://unifiedpush.org/.", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "noMatrixServer": "{server1} nu este server matrix, înlocuiți cu {server2}?", "@noMatrixServer": { - "type": "text", + "type": "String", "placeholders": { - "server1": {}, - "server2": {} + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } } }, "numUsersTyping": "{count} utilizatori tastează…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "offensive": "Ofensiv", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "Confirmați", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "or": "Sau", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "serverRequiresEmail": "Acest server trebuie să valideze emailul vostru pentru înregistrare.", "@serverRequiresEmail": {}, "waitingPartnerAcceptRequest": "Așteptând pe partenerul să accepte cererea…", "@waitingPartnerAcceptRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "Întunecat", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "sharedTheLocation": "{username} sa partajat locația", "@sharedTheLocation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "setInvitationLink": "Stabiliți linkul de invitație", "@setInvitationLink": { - "type": "text", + "type": "String", "placeholders": {} }, "transferFromAnotherDevice": "Transfera de la alt dispozitiv", "@transferFromAnotherDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "synchronizingPleaseWait": "Sincronizează... Vă rugăm să așteptați.", "@synchronizingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "systemTheme": "Sistem", "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleUnread": "Marcați Citit/Necitit", "@toggleUnread": { - "type": "text", + "type": "String", "placeholders": {} }, "tryToSendAgain": "Încercați să trimiteți din nou", "@tryToSendAgain": { - "type": "text", + "type": "String", "placeholders": {} }, "unavailable": "Nedisponibil", "@unavailable": { - "type": "text", + "type": "String", "placeholders": {} }, "userAndUserAreTyping": "{username} și {username2} tastează…", "@userAndUserAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "username2": {} + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } } }, "userLeftTheChat": "🚪{username} a plecat din chat", "@userLeftTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "userAndOthersAreTyping": "{username} și {count} alți tastează…", "@userAndOthersAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "count": {} + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "userSentUnknownEvent": "{username} a trimis un eveniment {type}", "@userSentUnknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "type": {} + "username": { + "type": "String" + }, + "type": { + "type": "String" + } } }, "unverified": "Neverificat", "@unverified": {}, "verifyTitle": "Verificând celălalt cont", "@verifyTitle": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForEveryone": "Vizibil pentru toți", "@visibleForEveryone": { - "type": "text", + "type": "String", "placeholders": {} }, "readUpToHere": "Citit până aici", "@readUpToHere": {}, "changedTheHistoryVisibility": "{username} a schimbat vizibilitatea istoriei chatului", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "copy": "Copiați", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "Displayname a fost schimbat", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUsersOnly": "Numai utilizatori invitați", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "configureChat": "Configurați chat", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "Copiat în clipboard", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "Dispozitiv", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "username": "Nume de utilizator", "@username": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAnAudio": "🎤{username} a trimis audio", "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAFile": "📁{username} a trimis un fișier", "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "indexedDbErrorLong": "Stocarea de mesaje nu este activat implicit în modul privat.\nVă rugăm să vizitați\n- about:config\n- stabiliți dom.indexedDB.privateBrowsing.enabled la true\nAstfel, nu este posibil să folosiți FluffyChat.", @@ -1568,38 +1712,44 @@ "@addWidget": {}, "locationPermissionDeniedNotice": "Permisiunea locației blocată. Vă rugăm să o dezblocați să împărțiți locația voastră.", "@locationPermissionDeniedNotice": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "Chat nou", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "💬 Mesaj nou în FluffyChat", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAPicture": "🖼️ {username} a trimis o poză", "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAVideo": "🎥{username} a trimis un video", "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentASticker": "😊 {username} a trimis un sticker", "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "storeInSecureStorageDescription": "Păstrați cheia de recuperare în stocarea sigură a acestui dispozitiv.", @@ -1609,42 +1759,50 @@ "countFiles": "{count} fișiere", "@countFiles": { "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "hugContent": "{senderName} vă îmbrățișează", "@hugContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "storeInAppleKeyChain": "Stoca în Apple KeyChain", "@storeInAppleKeyChain": {}, "addEmail": "Adăugați email", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "confirmMatrixId": "Vă rugăm să confirmați Matrix ID-ul vostru să ștergeți contul vostru.", "@confirmMatrixId": {}, "cuddleContent": "{senderName} vă îmbrățișează", "@cuddleContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "supposedMxid": "ID-ul ar trebuii să fie {mxid}", "@supposedMxid": { - "type": "text", + "type": "String", "placeholders": { - "mxid": {} + "mxid": { + "type": "String" + } } }, "commandHint_html": "Trimiteți text format ca HTML", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "addToSpace": "Adăugați la spațiu", @@ -1653,257 +1811,287 @@ "@commandHint_hug": {}, "badServerVersionsException": "Homeserver-ul suportă versiunele de Spec următoare:\n{serverVersions}\nDar această aplicație suportă numai {supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "badServerLoginTypesException": "Homeserver-ul suportă următoarele feluri de login:\n{serverVersions}\nDar această aplicație suportă numai:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username} a schimbat regulile pentru acesul musafirilor la: {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username} a schimbat regulile de alăturare la: {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "yourChatBackupHasBeenSetUp": "Backup-ul vostru de chat a fost configurat.", "@yourChatBackupHasBeenSetUp": {}, "cantOpenUri": "Nu se poate deschide URI-ul {uri}", "@cantOpenUri": { - "type": "text", + "type": "String", "placeholders": { - "uri": {} + "uri": { + "type": "String" + } } }, "changedTheDisplaynameTo": "{username} s-a schimbat displayname la: '{displayname}'", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username} a schimbat regulile pentru acesul musafirilor", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changeTheHomeserver": "Schimbați homeserver-ul", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackupDescription": "Mesajele voastre vechi sunt sigurate cu o cheie de recuperare. Vă rugăm să nu o pierdeți.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "Conținutul a fost reportat la administratori serverului", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "Detalii de chat", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_dm": "Porniți un chat direct\nFolosiți --no-encryption să dezactivați criptare", "@commandHint_dm": { - "type": "text", + "type": "String", "description": "Usage hint for the command /dm" }, "commandHint_me": "Descrieți-vă", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "contactHasBeenInvitedToTheGroup": "Contactul a fost invitat la grup", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "Conține nume de utilizator", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "Copiați în clipboard", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "countParticipants": "{count} participanți", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "delete": "Ștergeți", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deactivateAccountWarning": "Această acțiune va dezactiva contul vostru. Nu poate fi anulat! Sunteți sigur?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "Ștergeți contul", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "defaultPermissionLevel": "Nivel de permisiuni implicită", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "Ștergeți mesajul", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "Descărcați fișierul", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "Activați pachet de emote global", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "everythingReady": "Totul e gata!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "Editați servere blocate", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "Shortcode de emote nevalibil!", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "Editați", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "Schimbați pseudonimele camerei", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "Chat gol", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "Activați criptare", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "Criptat", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "Schimbați displayname", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "Schimbați avatarul din cameră", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Emote deja există!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "Pachete de emoturi din cameră", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Configurări Emote", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteShortcode": "Shortcode de emote", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Trebuie să alegeți shortcode pentru emote și o imagine!", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "Criptare", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "enterAnEmailAddress": "Introduceți o adresă email", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "homeserver": "Homeserver", "@homeserver": {}, "errorObtainingLocation": "Obținerea locației a eșuat: {error}", "@errorObtainingLocation": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "ok": "Ok", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "youKickedAndBanned": "🙅Ați dat afară și interzis pe {user}", "@youKickedAndBanned": { "placeholders": { - "user": {} + "user": { + "type": "String" + } } }, "noKeyForThisMessage": "Această chestie poate să se întâmple când mesajul a fost trimis înainte să vă conectați contul cu acest dispozitiv.\n\nO altă explicație ar fi dacă trimițătorul a blocat dispozitivul vostru sau ceva s-a întâmplat cu conexiunea la internet\n\nPuteți să citiți mesajul în o altă seșiune? Atunci puteți să transferați mesajul de acolo! Mergeți la Configurări > Dispozitive și verificați că dispozitivele s-au verificat. Când deschideți camera în viitor și ambele seșiune sunt în foreground, cheile va fi transmise automat. \n\nDoriți să îți păstrați cheile când deconectați sau schimbați dispozitive? Fiți atenți să activați backup de chat în configurări.", "@noKeyForThisMessage": {}, "sendAsText": "Trimiteți ca text", "@sendAsText": { - "type": "text" + "type": "String" }, "reportErrorDescription": "Ceva a eșuat. Vă rugăm să încercați din nou mai tărziu. Dacă doriți, puteți să reportați problema la dezvoltatori.", "@reportErrorDescription": {}, @@ -1911,66 +2099,66 @@ "@openLinkInBrowser": {}, "send": "Trimiteți", "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAMessage": "Trimiteți un mesaj", "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAudio": "Trimiteți audio", "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOriginal": "Trimiteți original", "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "sendVideo": "Trimiteți video", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "sendImage": "Trimiteți imagine", "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendSticker": "Trimiteți sticker", "@sendSticker": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterRecoveryKeyDescription": "Să vă deblocați mesajele vechi, vă rugăm să introduceți cheia de recuperare creată de o seșiune anterioră. Cheia de recuperare NU este parola voastră.", "@pleaseEnterRecoveryKeyDescription": {}, "separateChatTypes": "Afișați chaturi directe și grupuri separat", "@separateChatTypes": { - "type": "text", + "type": "String", "placeholders": {} }, "setAsCanonicalAlias": "Stabiliți ca pseudonimul primar", "@setAsCanonicalAlias": { - "type": "text", + "type": "String", "placeholders": {} }, "writeAMessage": "Scrieți un mesaj…", "@writeAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "yes": "Da", "@yes": { - "type": "text", + "type": "String", "placeholders": {} }, "markAsRead": "Marcați ca citit", "@markAsRead": {}, "oopsPushError": "Ups! Din păcate, o eroare s-a întâmplat cu stabilirea de notificări push.", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "oneClientLoggedOut": "Unul dintre clienților voștri a fost deconectat", @@ -1983,136 +2171,135 @@ "@link": {}, "passphraseOrKey": "frază de acces sau cheie de recuperare", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "Parolă", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "Parola uitată", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "Parola a fost schimbată", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "Recuperare parolei", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "Persoane", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "Alegeți o imagine", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChoose": "Vă rugăm să alegeți", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "Fixați", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChooseAPasscode": "Vă rugăm să alegeți un passcode", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "Vă rugăm să introduceți 4 cifre sau puteți să lăsați gol să dezactivați lacătul aplicației.", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "Vă rugăm să introduceți parola voastră", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "Vă rugăm să introduceți username-ul vostru", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseFollowInstructionsOnWeb": "Vă rugăm să urmați instrucțiunele pe website și apoi să apăsați pe următor.", "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "reason": "Motiv", "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "rejectedTheInvitation": "{username} a respins invitația", "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "redactedAnEvent": "{username} a redactat un eveniment", "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removeAllOtherDevices": "Eliminați toate celelalte dispozitive", "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "removeYourAvatar": "Ștergeți avatarul", "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Reda conținut bogat al mesajelor", - "@renderRichContent": { - "type": "text", + "type": "String", "placeholders": {} }, "replaceRoomWithNewerVersion": "Înlocuiți camera cu versiune mai nouă", "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "reply": "Răspundeți", "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "reportMessage": "Raportați mesajul", "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "requestPermission": "Cereți permisiune", "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "saveFile": "Salvați fișierul", "@saveFile": { - "type": "text", + "type": "String", "placeholders": {} }, "search": "Căutați", "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "recoveryKey": "Cheie de recuperare", @@ -2121,51 +2308,59 @@ "@recoveryKeyLost": {}, "seenByUser": "Văzut de {username}", "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "muteChat": "Amuțați chatul", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "Vă rugăm să fiți conștienți că e nevoie de Pantalaimon să folosiți criptare end-to-end deocamdată.", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "autoplayImages": "Anima automatic stickere și emote animate", "@autoplayImages": { - "type": "text", + "type": "String", "placeholder": {} }, "sendOnEnter": "Trimite cu tasta enter", "@sendOnEnter": {}, "changedTheChatPermissions": "{username} a schimbat permisiunile chatului", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "extremeOffensive": "De foarte mare ofensă", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "ID", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUser": "📩{username} a invitat {targetName}", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "deviceKeys": "Cheile dispozitivului:", @@ -2174,124 +2369,138 @@ "@pleaseEnterRecoveryKey": {}, "newVerificationRequest": "Cerere de verificare nouă!", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "remove": "Eliminați", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "play": "Redați {fileName}", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "channelCorruptedDecryptError": "Criptarea a fost corupată", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "Alegeți o parolă robustă", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_cuddle": "Trimiteți o îmbrățișare", "@commandHint_cuddle": {}, "googlyEyesContent": "{senderName} v-a trimis ochi googly", "@googlyEyesContent": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "areYouSureYouWantToLogout": "Sunteți sigur că doriți să vă deconectați?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheRoomAliases": "{username} a schimbat pseudonimele camerei", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changeYourAvatar": "Schimbați avatarul vostru", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_join": "Alăturați-vă la camera alesă", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "allChats": "Toate Chaturile", "@allChats": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_invite": "Invitați utilizatorul ales la această cameră", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "changeTheNameOfTheGroup": "Schimbați numele grupului", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_googly": "Trimiteți câțiva ochi googly", "@commandHint_googly": {}, "botMessages": "Mesaje Bot", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "Toate", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "Blocat", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheJoinRules": "{username} a schimbat regulile de alăturare", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username} s-a schimbat avatarul", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "appLock": "Lacăt aplicație", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheHistoryVisibilityTo": "{username} a schimbat vizibilitatea istoriei chatului la: {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "close": "Închideți", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "reopenChat": "Deschide din nou chatul", @@ -2299,78 +2508,5 @@ "pleaseTryAgainLaterOrChooseDifferentServer": "Vă rugăm să încercați din nou mai târziu sau să alegeți un server diferit.", "@pleaseTryAgainLaterOrChooseDifferentServer": {}, "signInWithPassword": "Conectați-vă cu parolă", - "@signInWithPassword": {}, - "@setColorTheme": {}, - "@banUserDescription": {}, - "@removeDevicesDescription": {}, - "@tryAgain": {}, - "@unbanUserDescription": {}, - "@messagesStyle": {}, - "@chatDescription": {}, - "@pushNotificationsNotAvailable": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@makeAdminDescription": {}, - "@setChatDescription": {}, - "@importFromZipFile": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@optionalRedactReason": {}, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@redactMessageDescription": {}, - "@invalidInput": {}, - "@addChatDescription": {}, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@invitePrivateChat": {}, - "@importEmojis": {}, - "@noChatDescriptionYet": {}, - "@learnMore": {}, - "@notAnImage": {}, - "@chatDescriptionHasBeenChanged": {}, - "@roomUpgradeDescription": {}, - "@pleaseEnterANumber": {}, - "@profileNotFound": {}, - "@shareInviteLink": {}, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@replace": {}, - "@createGroup": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@invite": {} -} \ No newline at end of file + "@signInWithPassword": {} +} diff --git a/lib/l10n/intl_ru.arb b/lib/l10n/intl_ru.arb new file mode 100644 index 000000000..710b1c2cb --- /dev/null +++ b/lib/l10n/intl_ru.arb @@ -0,0 +1,3057 @@ +{ + "@@locale": "ru", + "@@last_modified": "2021-08-14 12:41:09.903021", + "about": "О проекте", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Принять", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} принял(а) приглашение", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Учётная запись", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} активировал(а) сквозное шифрование", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Добавить электронную почту", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "Администратор", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "псевдоним", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Все", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Все чаты", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} ответил(а) на звонок", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Каждый может присоединиться", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Блокировка приложения", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Архив", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Разрешено ли гостям присоединяться", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Вы уверены?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Вы действительно хотите выйти?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Для подписи ключа другого пользователя, пожалуйста, введите вашу парольную фразу или ключ восстановления.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Принять этот запрос подтверждения от {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Автоматически воспроизводить анимированные стикеры и эмодзи", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "Домашний сервер поддерживает следующие типы входа в систему:\n{serverVersions}\nНо это приложение поддерживает только:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "Домашний сервер поддерживает следующие версии спецификации:\n{serverVersions}\nНо это приложение поддерживает только {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Заблокировать в чате", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Заблокирован(а)", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} заблокировал(а) {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Заблокировать устройство", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Заблокировано", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Сообщения ботов", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Отмена", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Не удается открыть URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Изменить имя устройства", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} изменил(а) аватар чата", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} изменил(а) описание чата на: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} изменил(а) имя чата на '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} изменил(а) права доступа к чату", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} изменил(а) отображаемое имя на '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} изменил(а) правила гостевого доступа", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} изменил(а) правила гостевого доступа на {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} изменил(а) видимость истории", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} изменил(а) видимость истории на {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} изменил(а) правила присоединения", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} изменил(а) правила присоединения на {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} изменил(а) аватар", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} изменил(а) псевдонимы комнаты", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} изменил(а) ссылку для приглашения", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Изменить пароль", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Изменить домашний сервер", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Персонализация", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Изменить название группы", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Изменить свой аватар", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Шифрование было повреждено", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Чат", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Резервное копирование чата", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Ваши сообщения защищены ключом восстановления. Пожалуйста, не потеряйте его.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Детали чата", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "Чаты", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Выберите надёжный пароль", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Очистить архив", + "close": "Закрыть", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Заблокировать данного пользователя в этой комнате", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Отправить текст формата HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Пригласить данного пользователя в эту комнату", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Присоединиться к данной комнате", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Удалить данного пользователя из этой комнаты", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Покинуть эту комнату", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Опишите себя", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Установите свою фотографию для этой комнаты (автор: mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Задайте отображаемое имя для этой комнаты", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Установить уровень прав данного пользователя (по умолчанию: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Отправить неотформатированный текст", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Отправить ответ как реакцию", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Отправить текст", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Разблокировать данного пользователя в этой комнате", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Недопустимая команда", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} не является командой.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Сравните эмодзи", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Сравните числа", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Настроить чат", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Подтвердить", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Присоединиться", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Контакт был приглашен в группу", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Содержит отображаемое имя", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Содержит имя пользователя", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "О контенте было сообщено администраторам сервера", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Скопировано в буфер обмена", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Копировать", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Скопировать в буфер обмена", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Не удалось расшифровать сообщение: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} участника(ов)", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Создать", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} создал(а) чат", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Новое пространство", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "В настоящее время активен(а)", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Тёмная", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{timeOfDay}, {date}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Это деактивирует вашу учётную запись пользователя. Данное действие не может быть отменено! Вы уверены?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Уровень разрешений по умолчанию для новых пользователей", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Удалить", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Удалить аккаунт", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Удалить сообщение", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Устройство", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Идентификатор устройства", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Устройства", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Личные чаты", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Отображаемое имя было изменено", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Скачать файл", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Редактировать", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Редактировать заблокированные серверы", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Отображаемое имя", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Редактировать псевдонимы комнаты", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Изменить аватар комнаты", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Эмодзи уже существует!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Недопустимый код эмодзи!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Наборы эмодзи для комнаты", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Настройки эмодзи", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Код эмодзи", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Вам нужно задать код эмодзи и изображение!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Пустой чат", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Включить набор эмодзи глобально", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Включить шифрование", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Вы больше не сможете отключить шифрование. Вы уверены?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Зашифровано", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Шифрование", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Шифрование не включено", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} завершил(а) звонок", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Введите адрес электронной почты", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Введите адрес вашего домашнего сервера", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Ошибка получения местоположения: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Всё готово!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Крайне оскорбительный", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Имя файла", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Размер шрифта", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Переслать", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "С момента присоединения", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "С момента приглашения", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "В новую комнату", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Группа", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Публичная группа", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Группы", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Группа с {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Гости не могут присоединиться", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Гости могут присоединиться", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} отозвал(а) приглашение для {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Помощь", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Скрыть отредактированные события", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Скрыть неизвестные события", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Насколько оскорбительным является этот контент?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Идентификация", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Игнорировать", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Игнорируемые пользователи", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Я перешёл по ссылке", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Неверный пароль или ключ восстановления", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Безобидный", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Пригласить контакт", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Пригласить контакт в {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Приглашён", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} пригласил(а) {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Только приглашённым пользователям", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Приглашение для меня", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} пригласил(а) вас в FluffyChat. \n1. Посетите https://fluffychat.im и установите приложение \n2. Зарегистрируйтесь или войдите \n3. Откройте ссылку приглашения: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "печатает…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} присоединился(ась) к чату", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Присоединиться к комнате", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} выгнал(а) {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} выгнал(а) и заблокировал(а) {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Выгнать из чата", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Последнее посещение: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Покинуть", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Покинуть чат", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Лицензия", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Светлая", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadingPleaseWait": "Загрузка... Пожалуйста, подождите.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Загрузить больше…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Службы определения местоположения отключены. Включите их, чтобы иметь возможность обмениваться информацией о своем местоположении.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Разрешение на определение местоположения отклонено. Пожалуйста, предоставьте это разрешение, чтобы иметь возможность делиться своим местоположением.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Войти", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Войти в {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Выйти", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Изменения участников", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Упомянуть", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Сообщения", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Модератор", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Отключить уведомления", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Помните, что вам нужен Pantalaimon для использования сквозного шифрования.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Новый чат", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Новое сообщение во FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Новый запрос на подтверждение!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Далее", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Нет", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Нет соединения с сервером", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Эмодзи не найдены 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Вы можете активировать шифрование только тогда, когда комната перестает быть общедоступной.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Похоже, у вас нет служб Google на вашем телефоне. Это хорошее решение для вашей конфиденциальности! Для получения push-уведомлений во FluffyChat мы рекомендуем использовать ntfy. С ntfy или другим провайдером единых уведомлений вы можете получать push-уведомления безопасным способом передачи данных. Скачать ntfy можно из F-Droid или из Play Маркета.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} не является matrix-сервером, использовать {server2} вместо него?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "none": "Ничего", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Вы ещё не добавили способ восстановления пароля.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Нет прав доступа", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Комнаты не найдены…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Уведомления", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Уведомления включены для этой учётной записи", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} пользователей печатают…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Получение местоположения…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Оскорбительный", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Не в сети", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Ок", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "В сети", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Резервное копирование ключей на сервере включено", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Ой! К сожалению, при настройке push-уведомлений произошла ошибка.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Ой, что-то пошло не так…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Откройте приложение для чтения сообщений", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Открыть камеру", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Открыть на картах", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Или", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Участник", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "пароль или ключ восстановления", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Пароль", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Забыли пароль", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Пароль был изменён", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Восстановление пароля", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Люди", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Выбрать изображение", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Закрепить", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Проиграть {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Пожалуйста, выберите", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Пожалуйста, выберите код доступа", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Пожалуйста, нажмите на ссылку в электронной почте, для того чтобы продолжить.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Введите 4 цифры или оставьте поле пустым, чтобы отключить блокировку приложения.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Пожалуйста, введите ваш пароль", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Пожалуйста, введите свой пин-код", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Пожалуйста, введите имя пользователя", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Следуйте инструкциям на веб-сайте и нажмите «Далее».", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Конфиденциальность", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Публичные комнаты", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Правила push", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Причина", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Запись", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} отредактировал(а) событие", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Отредактировать сообщение", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Зарегистрироваться", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Отказать", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} отклонил(а) приглашение", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Зайти повторно", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Удалить", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Удалить все другие устройства", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Удалено пользователем {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Удалить устройство", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Разблокировать в чате", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Удалить свой аватар", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Заменить комнату более новой версией", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Ответить", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Сообщить о сообщении", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Запросить разрешение", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Комната обновлена", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Версия комнаты", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Сохранить файл", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Поиск", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Безопасность", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Просмотрено пользователем {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Прислать", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Отправить сообщение", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Отправить как текст", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Отправить аудио", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Отправить файл", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Отправить изображение", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Отправить сообщения", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Отправить оригинал", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Отправить стикер", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Отправить видео", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} отправил(а) файл", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} отправил(а) аудио", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} отправил(а) изображение", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} отправил(а) стикер", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} отправил(а) видео", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} отправил(а) информацию о звонке", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Установить как основной псевдоним", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Установить пользовательские эмодзи", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Установить ссылку для приглашения", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Установить уровень разрешений", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Задать статус", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Настройки", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Поделиться", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} поделился(ась) местоположением", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Поделиться местоположением", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Показать пароль", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Единая точка входа", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Пропустить", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Исходный код", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Публичное пространство", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Название пространства", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} начал(а) звонок", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Статус", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Как у вас сегодня дела?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Отправить", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Синхронизация… Пожалуйста, подождите.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Системная", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Они не совпадают", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Они совпадают", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Переключить избранное", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Переключить без звука", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Отметить как прочитанное/непрочитанное", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Слишком много запросов. Пожалуйста, повторите попытку позже!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Перенос с другого устройства", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Попробуйте отправить ещё раз", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Недоступен", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} разблокировал(а) {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Разблокировать устройство", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Неизвестное устройство", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Неизвестный алгоритм шифрования", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Неизвестное событие '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Включить уведомления", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Открепить", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "userAndOthersAreTyping": "{username} и еще {count} печатают…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} и {username2} печатают…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} печатает…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} покинул(а) чат", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Имя пользователя", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} отправил(а) событие типа \"{type}\"", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Проверено", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Проверить", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Начать проверку", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Вы успешно проверены!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Проверка другой учётной записи", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Видеозвонок", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Видимость истории чата", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Видима для всех участников", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Видна всем", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Отправить голосовое сообщение", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Жду, когда партнер примет запроc…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Жду, когда партнер примет эмодзи…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "В ожидании партнёра, чтобы принять числа…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Обои:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Предупреждение!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Мы отправили вам электронное письмо", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Кто и какое действие может выполнять", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Кому разрешено вступать в эту группу", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Почему вы хотите сообщить об этом?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Удалить резервную копию чата, чтобы создать новый ключ восстановления?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "По этим адресам вы можете восстановить свой пароль.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Напишите сообщение…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Да", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Вы", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Вы больше не участвуете в этом чате", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Вы были заблокированы в этом чате", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Ваш открытый ключ", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Чат был добавлен в это пространство", + "addToSpace": "Добавить в пространство", + "scanQrCode": "Сканировать QR-код", + "sendOnEnter": "Отправлять по Enter", + "homeserver": "Домашний сервер", + "serverRequiresEmail": "Этот сервер должен подтвердить ваш адрес электронной почты для регистрации.", + "enableMultiAccounts": "(БЕТА) Включить несколько учетных записей на этом устройстве", + "bundleName": "Название пакета", + "removeFromBundle": "Удалить из этого пакета", + "addToBundle": "Добавить в пакет", + "editBundlesForAccount": "Изменить пакеты для этой учетной записи", + "addAccount": "Добавить учетную запись", + "link": "Ссылка", + "oneClientLoggedOut": "Один из ваших клиентов вышел", + "yourChatBackupHasBeenSetUp": "Резервное копирование чата настроено.", + "unverified": "Не проверено", + "commandHint_clearcache": "Очистить кэш", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_discardsession": "Удалить сеанс", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Начните личный чат\nИспользуйте --no-encryption, чтобы отключить шифрование", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "messageInfo": "Информация о сообщении", + "openGallery": "Открыть галерею", + "removeFromSpace": "Удалить из пространства", + "commandHint_create": "Создайте пустой групповой чат\nИспользуйте --no-encryption, чтобы отключить шифрование", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "sender": "Отправитель", + "addToSpaceDescription": "Выберите пространство, чтобы добавить к нему этот чат.", + "start": "Начать", + "time": "Время", + "messageType": "Тип сообщения", + "repeatPassword": "Повторите пароль", + "openVideoCamera": "Открыть камеру для видео", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "videoWithSize": "Видео ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "publish": "Опубликовать", + "dismiss": "Отклонить", + "markAsRead": "Отметить как прочитанное", + "reportUser": "Сообщить о пользователе", + "openChat": "Открыть чат", + "reactedWith": "{sender} реагирует с {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "emojis": "Эмодзи", + "voiceCall": "Голосовой звонок", + "unsupportedAndroidVersion": "Неподдерживаемая версия Android", + "unsupportedAndroidVersionLong": "Для этой функции требуется более новая версия Android. Проверьте наличие обновлений или поддержку Lineage OS.", + "placeCall": "Совершить звонок", + "videoCallsBetaWarning": "Обратите внимание, что видеозвонки в настоящее время находятся в бета-версии. Они могут работать не так, как ожидалось, или вообще не работать на всех платформах.", + "experimentalVideoCalls": "Экспериментальные видеозвонки", + "emailOrUsername": "Адрес электронной почты или имя пользователя", + "pinMessage": "Прикрепить к комнате", + "confirmEventUnpin": "Вы уверены, что хотите навсегда открепить событие?", + "switchToAccount": "Переключиться на учётную запись {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Следующая учётная запись", + "previousAccount": "Предыдущая учётная запись", + "addWidget": "Добавить виджет", + "widgetVideo": "Видео", + "widgetEtherpad": "Текстовая записка", + "widgetCustom": "Пользовательский", + "widgetJitsi": "Совещание Jitsi", + "widgetName": "Имя", + "widgetUrlError": "Этот URL не действителен.", + "widgetNameError": "Пожалуйста, укажите отображаемое имя.", + "errorAddingWidget": "Ошибка при добавлении виджета.", + "separateChatTypes": "Разделять личные чаты и группы", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youRejectedTheInvitation": "Вы отклонили приглашение", + "youAcceptedTheInvitation": "👍 Вы приняли приглашение", + "youUnbannedUser": "Вы разблокировали {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youJoinedTheChat": "Вы присоединились к чату", + "youKickedAndBanned": "🙅 Вы выгнали и заблокировали {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Вы пригласили {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Вы выгнали {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Вы отозвали приглашение для {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youBannedUser": "Вы заблокировали {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Вы были приглашены {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "recoveryKeyLost": "Ключ восстановления утерян?", + "users": "Пользователи", + "unlockOldMessages": "Разблокировать старые сообщения", + "storeInSecureStorageDescription": "Сохраните ключ восстановления в безопасном хранилище этого устройства.", + "storeSecurlyOnThisDevice": "Сохранить на этом устройстве", + "saveKeyManuallyDescription": "Сохраните этот ключ вручную, вызвав диалог общего доступа системы или буфера обмена.", + "recoveryKey": "Ключ восстановления", + "pleaseEnterRecoveryKey": "Введите ключ восстановления:", + "pleaseEnterRecoveryKeyDescription": "Чтобы разблокировать старые сообщения, введите ключ восстановления, сгенерированный в предыдущем сеансе. Ваш ключ восстановления НЕ является вашим паролем.", + "storeInAndroidKeystore": "Сохранить в Android KeyStore", + "storeInAppleKeyChain": "Сохранить в Apple KeyChain", + "user": "Пользователь", + "confirmMatrixId": "Пожалуйста, подтвердите Matrix ID, чтобы удалить свою учётную запись.", + "supposedMxid": "Это должно быть {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "dehydrateTor": "Пользователи TOR: Экспорт сеанса", + "indexedDbErrorLong": "К сожалению, по умолчанию хранилище сообщений не включено в приватном режиме.\nПожалуйста, посетите\n- about:config\n- установите для dom.indexedDB.privateBrowsing.enabled значение true\nВ противном случае запуск FluffyChat будет невозможен.", + "custom": "Пользовательское", + "hydrate": "Восстановить из файла резервной копии", + "hydrateTor": "Пользователи TOR: Импорт экспорта сессии", + "hydrateTorLong": "В прошлый раз вы экспортировали свою сессию в TOR? Быстро импортируйте его и продолжайте общение.", + "dehydrateTorLong": "Для пользователей TOR рекомендуется экспортировать сессию перед закрытием окна.", + "dehydrate": "Экспорт сеанса и очистка устройства", + "dehydrateWarning": "Это действие не может быть отменено. Убедитесь, что вы безопасно сохранили файл резервной копии.", + "indexedDbErrorTitle": "Проблемы с приватным режимом", + "otherCallingPermissions": "Микрофон, камера и другие разрешения FluffyChat", + "enterSpace": "Войти в пространство", + "screenSharingDetail": "Вы делитесь своим экраном в FuffyChat", + "callingAccountDetails": "Позволяет FluffyChat использовать родное android приложение для звонков.", + "newSpace": "Новое пространство", + "appearOnTop": "Появляться сверху", + "commandHint_markasdm": "Пометить как комнату личных сообщений", + "appearOnTopDetails": "Позволяет приложению отображаться сверху (не требуется, если у вас уже настроен Fluffychat как аккаунт для звонков)", + "foregroundServiceRunning": "Это уведомление появляется, когда запущена основная служба.", + "newGroup": "Новая группа", + "enterRoom": "Войти в комнату", + "allSpaces": "Все пространства", + "callingPermissions": "Разрешения на звонки", + "callingAccount": "Аккаунт для звонков", + "commandHint_markasgroup": "Пометить как группу", + "whyIsThisMessageEncrypted": "Почему это сообщение нечитаемо?", + "noKeyForThisMessage": "Это может произойти, если сообщение было отправлено до того, как вы вошли в свою учетную запись на данном устройстве.\n\nТакже возможно, что отправитель заблокировал ваше устройство или что-то пошло не так с интернет-соединением.\n\nВы можете прочитать сообщение на другой сессии? Тогда вы можете перенести сообщение с неё! Перейдите в Настройки > Устройства и убедитесь, что ваши устройства проверили друг друга. Когда вы откроете комнату в следующий раз и обе сессии будут открыты, ключи будут переданы автоматически.\n\nВы не хотите потерять ключи при выходе из системы или переключении устройств? Убедитесь, что вы включили резервное копирование чата в настройках.", + "screenSharingTitle": "общий доступ к экрану", + "numChats": "{number} чатов", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "fileIsTooBigForServer": "Отправка не удалась! Сервер поддерживает только вложения размером до {max}.", + "hideUnimportantStateEvents": "Скрыть необязательные события статуса", + "sorryThatsNotPossible": "Извините... это невозможно", + "openLinkInBrowser": "Открыть ссылку в браузере", + "fileHasBeenSavedAt": "Файл сохранён в {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "commandHint_cuddle": "Отправить улыбку", + "readUpToHere": "Непрочитанное", + "commandHint_hug": "Отправить обнимашки", + "cuddleContent": "{senderName} обнимает вас", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} обнял(а) Вас", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "jump": "Перейти", + "doNotShowAgain": "Не показывать снова", + "newSpaceDescription": "Пространства позволяют объединять Ваши чаты и создавать частные или общедоступные сообщества.", + "disableEncryptionWarning": "В целях безопасности Вы не можете отключить шифрование в чате, где оно было включено.", + "deviceKeys": "Ключи устройств:", + "noBackupWarning": "Внимание! Без резервного копиирования, Вы потеряете доступ к своим зашифрованным сообщениям. Крайне рекомендуется включить резервное копирование перед выходом.", + "noOtherDevicesFound": "Другие устройства не найдены", + "reportErrorDescription": "😭 О, нет. Что-то пошло не так. При желании вы можете сообщить об этой ошибке разработчикам.", + "report": "пожаловаться", + "allRooms": "Все группы", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "startFirstChat": "Начните Ваш первый чат", + "jumpToLastReadMessage": "Последнее прочитанное сообщение", + "wasDirectChatDisplayName": "Пустой чат (был {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "encryptThisChat": "Зашифровать этот чат", + "reopenChat": "Открыть чат заново", + "commandHint_googly": "Отправить выпученные глаза", + "signInWith": "Войти с {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Это не картинка.", + "importNow": "Импортировать сейчас", + "importEmojis": "Импортировать эмодзи", + "importFromZipFile": "Импортировать из ZIP-файла", + "exportEmotePack": "Экспортировать набор эмодзи как ZIP", + "replace": "Заменить", + "googlyEyesContent": "{senderName} выпучил глаза", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "signInWithPassword": "Войти с помощью пароля", + "pleaseTryAgainLaterOrChooseDifferentServer": "Повторите попытку позже или выберите другой сервер.", + "sendTypingNotifications": "Отправлять уведомления о наборе текста", + "createGroup": "Создать группу", + "inviteContactToGroupQuestion": "Вы хотите пригласить {contact} в чат \"{groupName}\"?", + "tryAgain": "Повторите попытку", + "addChatDescription": "Добавить описание чата...", + "chatPermissions": "Права в чате", + "chatDescription": "Описание чата", + "chatDescriptionHasBeenChanged": "Описание чата изменено", + "noChatDescriptionYet": "Описание чата не создано.", + "invalidServerName": "Недопустимое имя сервера", + "optionalRedactReason": "(Необязательно) Причина редактирования...", + "redactMessageDescription": "Сообщение будет отредактировано для всех участников. Это необратимо.", + "messagesStyle": "Сообщения:", + "shareInviteLink": "Поделиться приглашением", + "redactedBy": "{username} отредактировал это событие", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Личный чат", + "profileNotFound": "Пользователь не найден на сервере. Это может быть проблемой подключения или пользователь не существует.", + "setTheme": "Тема:", + "redactedByBecause": "{username} отредактировал это событие. Причина: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "setChatDescription": "Установить описание чата", + "setColorTheme": "Цветовая тема:", + "invite": "Пригласить", + "invitePrivateChat": "📨 Вас пригласили в приватный чат", + "inviteGroupChat": "📨 Вас пригласили в групповой чат", + "invalidInput": "Недопустимый ввод!", + "wrongPinEntered": "Wrong pin entered! Try again in {seconds} seconds...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "emoteKeyboardNoRecents": "Недавно использованные эмодзи появятся здесь...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "banUserDescription": "Заблокированные в чате пользователи не смогут перезайти в чат, пока они не будут разблокированны.", + "removeDevicesDescription": "Вы выйдете с этого устройства и больше не будете получать сообщения.", + "unbanUserDescription": "Пользователь сможет при желании зайти в чат снова.", + "pushNotificationsNotAvailable": "Push-уведомления недоступны", + "makeAdminDescription": "Как только вы назначите этого пользователя администратором, вы не сможете этого отменить, так как их права доступа и ваши будут одинаковы.", + "archiveRoomDescription": "Чат переместится в архив. Другим пользователям будет видно, что вы вышли из чата.", + "hasKnocked": "🚪 {user} постучался", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "learnMore": "Узнать больше", + "roomUpgradeDescription": "Затем чат будет воссоздан с новой версией комнаты. Все участники будут уведомлены о необходимости перейти в новый чат. Вы можете узнать больше о версиях комнат на https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Пожалуйста введите число больше 0", + "kickUserDescription": "Пользователь будет изгнан из чата, но не будет заблокирован. В публичных чатах пользователь может перезайти когда угодно.", + "blockListDescription": "Вы можете заглушить тревожащих вас пользователей. Вы не будете получать сообщения или приглашения в комнату от пользователей из вашего личного чёрного списка.", + "blockedUsers": "Заглушённые пользователи", + "block": "Заглушить", + "blockUsername": "Игнорировать имя пользователя", + "createGroupAndInviteUsers": "Создать и начать приглашать", + "startConversation": "Начать общение", + "groupCanBeFoundViaSearch": "Группа может быть найдена поиском", + "noUsersFoundWithQuery": "К сожалению пользователей с именем \"{query}\" не найдено. Убедитесь, что вы не совершили опечатку.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "yourGlobalUserIdIs": "Ваш глобальный идентификатор - ", + "commandHint_sendraw": "Отправить сырой json", + "wrongRecoveryKey": "Простите... судя по всему это неверный ключ восстановления.", + "groupName": "Название группы", + "databaseMigrationTitle": "База данных оптимизированна", + "searchChatsRooms": "Поиск #чатов, @людей...", + "databaseMigrationBody": "Пожалуйста, подождите. Это может занять некоторое время.", + "publicSpaces": "Публичные пространства", + "passwordIsWrong": "Вы ввели неверный пароль", + "pleaseEnterYourCurrentPassword": "Пожалуйста, введите свой текущий пароль", + "publicLink": "Публичная ссылка", + "nothingFound": "Ничего не найдено...", + "newPassword": "Новый пароль", + "passwordsDoNotMatch": "Пароли не совпадают", + "select": "Выбрать", + "pleaseChooseAStrongPassword": "Пожалуйста, подберите сильный пароль", + "leaveEmptyToClearStatus": "Чтобы очистить статус, оставьте поле пустым.", + "joinSpace": "Присоединиться к пространству", + "searchForUsers": "Поиск @пользователей...", + "thisDevice": "Данное устройство:", + "decline": "Отклонить", + "databaseBuildErrorBody": "Невозможно собрать базу данных SQlite. Приложение пытается использовать старую базу данных. Пожалуйста, сообщите об этой ошибке разработчикам по адресу {url}. Сообщение об ошибке: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "Произошла ошибка при запуске приложения", + "sessionLostBody": "Ваш сеанс утерян. Пожалуйста, сообщите об этой ошибке разработчикам по адресу {url}. Сообщение об ошибке: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Приложение пытается восстановить сеанс из резервной копии. Пожалуйста, сообщите об этой ошибке разработчикам по адресу {url}. Сообщение об ошибке: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "subspace": "Субпространство", + "addChatOrSubSpace": "Добавить чат или субпространство", + "youInvitedToBy": "📩 Вы были приглашены по ссылке на:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "sendReadReceipts": "Отправка квитанций о прочтении", + "verifyOtherUser": "🔐 Подтвердить другого пользователя", + "verifyOtherDevice": "🔐 Подтвердить другое устройство", + "forwardMessageTo": "Переслать сообщение в {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "Другие участники чата могут видеть, когда вы прочитали сообщение.", + "transparent": "Прозрачный", + "verifyOtherUserDescription": "Если вы подтвердите другого пользователя, то вы можете быть уверены зная, кому вы действительно пишете. 💪\n\nКогда вы начинаете подтверждение, вы и другой пользователь увидите всплывающее окно в приложении. Там вы увидите ряд чисел или эмодзи, которые вы должны сравнить друг с другом.\n\nЛучший способ сделать это - встретиться в реальной жизни или по видео звонку. 👭", + "verifyOtherDeviceDescription": "При подтверждении другого устройства эти устройства могут обмениваться ключами, повышая общую безопасность. 💪 При запуске подтверждения в приложении на обоих устройствах появится всплывающее окно. Там вы увидите ряд чисел или эмодзи, которые вы должны сравнить друг с другом. Лучше иметь оба устройства под рукой перед началом проверки. 🤳", + "formattedMessagesDescription": "Отображать содержимое расширенных сообщений, такой как жирный текст, с помощью Markdown.", + "acceptedKeyVerification": "{sender} принял(а) подтверждение ключей", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} отклонил(а) подтверждение ключей", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Другие участники чата могут видеть, когда вы набираете новое сообщение.", + "formattedMessages": "Форматированные сообщения", + "startedKeyVerification": "{sender} начал(а) подтверждение ключей", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} готов(а) к подтверждению ключей", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} запросил(а) подтверждение ключей", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} завершил(а) подтверждение ключей", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "incomingMessages": "Входящие сообщения", + "presencesToggle": "Показывать сообщения в статусах других пользователей", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "Представление:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "hidePresences": "Скрыть список статусов?", + "stickers": "Стикеры", + "discover": "Исследовать", + "globalChatId": "ID глобального чата", + "customEmojisAndStickersBody": "Добавить или поделиться пользовательскими эмодзи или стикерами, которые могут быть применены в любом чате.", + "hideMemberChangesInPublicChatsBody": "Для улучшения читаемости не показывать на временной шкале входы и выходы из чата.", + "knocking": "Стучаться", + "accessAndVisibility": "Доступность и видимость", + "publicChatAddresses": "Адресы публичного чата", + "accessAndVisibilityDescription": "Кому разрешено войти в этот чат и как этот чат может быть обнаружен.", + "userRole": "Роль пользователя", + "noDatabaseEncryption": "Шифрование базы данных не поддерживается на этой платформе", + "appLockDescription": "Заблокировать приложение когда не используется пин код", + "calls": "Звонки", + "customEmojisAndStickers": "Пользовательские эмодзи и стикеры", + "hideRedactedMessages": "Скрыть редактированные сообщения", + "hideInvalidOrUnknownMessageFormats": "Скрыть неправильные или неизвестные форматы сообщения", + "hideRedactedMessagesBody": "Если кто-то редактирует сообщение, оно будет скрыто в чате.", + "hideMemberChangesInPublicChats": "Скрыть изменения участников в публичных чатах", + "overview": "Обзор", + "notifyMeFor": "Уведомлять меня о", + "passwordRecoverySettings": "Настройки восстановления пароля", + "userWouldLikeToChangeTheChat": "{user} желает присоединиться к чату.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "knock": "Постучаться", + "usersMustKnock": "Пользователи должны постучаться", + "noOneCanJoin": "Никто не может присоединиться", + "noPublicLinkHasBeenCreatedYet": "Публичная ссылка еще не была создана", + "chatCanBeDiscoveredViaSearchOnServer": "Чат может быть обнаружен через поиск в {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "createNewAddress": "Создать новый адрес", + "minimumPowerLevel": "{level} является минимальным уровнем.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "commandHint_ignore": "Игнорировать данный matrix ID", + "commandHint_unignore": "Не игнорировать данный matrix ID", + "restricted": "Запрещено", + "knockRestricted": "Стук запрещен", + "searchIn": "Поиск в чате \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Найти еще...", + "gallery": "Галерея", + "files": "Файлы", + "swipeRightToLeftToReply": "Для ответа проведите справа налево", + "userLevel": "{level} - Пользователь", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Модератор", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Администратор", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Изменить общие настройки чата", + "changeTheChatPermissions": "Изменить права доступа к чату", + "changeTheDescriptionOfTheGroup": "Изменить описание чата", + "inviteOtherUsers": "Пригласить других пользователей в этот чат", + "changeTheVisibilityOfChatHistory": "Изменить видимость истории чата", + "unread": "Непрочитанные", + "space": "Пространство", + "spaces": "Пространства", + "markAsUnread": "Отметить как непрочитанное", + "goToSpace": "Перейти к пространству: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "sendCanceled": "Отправка отменена", + "noChatsFoundHere": "Не было найдено ни одного чата. Начать с кем-нибудь новый чат можно, нажав кнопку ниже. ⤵️", + "updateInstalled": "🎉 Обновление {version} успешно установлено!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Список изменений", + "invitedBy": "📩 Приглашен(а) {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "doesNotSeemToBeAValidHomeserver": "Этот домашний сервер выглядит несовместимым. Нет ли в ссылке опечаток?", + "noMoreChatsFound": "Больше чатов не обнаружено...", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "compressVideo": "Сжатие видео...", + "oneOfYourDevicesIsNotVerified": "Одно из ваших устройств не подтверждено", + "chatPermissionsDescription": "Задайте уровень власти, необходимый для совершения определённых действий в этом чате. Уровни власти 0, 50 и 100 обычно означают пользователей, модераторов и администраторов соответственно, но любая градация также возможна.", + "prepareSendingAttachment": "Подготовка к отправке вложения...", + "sendRoomNotifications": "Упоминать @room", + "calculatingFileSize": "Вычисление размера файла...", + "sendingAttachment": "Отправка вложения...", + "generatingVideoThumbnail": "Создание превью видео...", + "noticeChatBackupDeviceVerification": "Примечание: Если вы подключите все свои устройства к резервному копированию чатов, то они автоматически станут подтверждёнными.", + "changeTheCanonicalRoomAlias": "Изменить основной общедоступный адрес чата", + "loginWithMatrixId": "Войти через Matrix ID", + "whatIsAHomeserver": "Для чего нужен домашний сервер?", + "homeserverDescription": "Все ваши данные хранятся на домашнем сервере, прямо как у вашего провайдера электронной почты. Вы можете выбрать, какому серверу вы их доверите, при этом сохраняя возможность общаться со всеми. Узнайте больше на https://matrix.org.", + "discoverHomeservers": "Список домашних серверов", + "joinedChats": "Вступленные чаты", + "serverInformation": "Информация о сервере:", + "sendingAttachmentCountOfCount": "Отправляется вложение {index} из {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "welcomeText": "Привет. Это FluffyChat. Вы можете подписаться на любой сервер, который совместим с https://matrix.org. А потом поболтать с кем нибудь. Это огромная децентрализованная сеть обмена сообщениями!", + "noContactInformationProvided": "Сервер не предоставляет никакой правдивой контактной информации", + "aboutHomeserver": "О сервере {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "boldText": "Жирный шрифт", + "strikeThrough": "Перечёркнутый", + "pleaseFillOut": "Пожалуйста, заполните", + "invalidUrl": "Не верный URL", + "addLink": "Добавить ссылку", + "italicText": "Italic", + "unableToJoinChat": "Невозможно присоединиться к чату. Возможно, другая сторона уже закончила разговор.", + "continueText": "Продолжить", + "blur": "Размытие:", + "opacity": "Прозрачность:", + "setWallpaper": "Установить обои", + "manageAccount": "Управление аккаунтом", + "contactServerAdmin": "Админ сервера", + "contactServerSecurity": "Безопасность контактов сервера", + "supportPage": "Поддержка", + "name": "Имя", + "version": "Версия", + "website": "Сайт", + "sendImages": "Отправить {count} изображение", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Сжатие", + "notificationRuleMessage": "Сообщение", + "appWantsToUseForLoginDescription": "Вы позволяете приложению и веб-сайту делиться информацией о вас.", + "newChatRequest": "📩 Запрос нового чата", + "allDevices": "Все устройства", + "roomNotificationSettings": "Настройки уведомлений комнаты", + "notificationRuleContainsUserName": "Содержит имя пользователя", + "notificationRuleMaster": "Отключить все уведомления", + "notificationRuleSuppressNoticesDescription": "Отключить уведомления от автоматизированных клиентов, таких как боты.", + "notificationRuleInviteForMe": "Приглашение для меня", + "notificationRuleMemberEventDescription": "Отключить уведомления о событиях о членстве.", + "notificationRuleIsRoomMention": "Упоминание комнаты", + "notificationRuleReactionDescription": "Отключить уведомления о реакциях.", + "notificationRuleCall": "Звонок", + "notificationRuleSuppressEditsDescription": "Отключить уведомления о отредактированных сообщениях.", + "notificationRuleEncrypted": "Зашифровано", + "more": "Больше", + "synchronizingPleaseWaitCounter": " Синхронизация… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "appWantsToUseForLogin": "Использовать '{server}' для входа", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "contentNotificationSettings": "Настройки уведомлений по тексту", + "generalNotificationSettings": "Общие настройки уведомлений", + "userSpecificNotificationSettings": "Настроки уведомлений пользователя", + "otherNotificationSettings": "Другие настройки уведомлений", + "notificationRuleContainsUserNameDescription": "Уведомляет пользователя, когда сообщение содержит его имя пользователя.", + "notificationRuleMasterDescription": "Перекрывает все другие правила и отключает все уведомления.", + "notificationRuleSuppressNotices": "Отключить автоматические сообщения", + "notificationRuleIsUserMention": "Упоминание пользователя", + "notificationRuleContainsDisplayName": "Содержит отображаемое имя", + "notificationRuleReaction": "Реакция", + "takeAPhoto": "Снять фото", + "recordAVideo": "Записать видео", + "enterNewChat": "Введите новый чат", + "otherPartyNotLoggedIn": "Другая сторона в настоящее время не вошла в систему и поэтому не может получать сообщения!", + "open": "Открыть", + "waitingForServer": "Ожидание сервера...", + "appIntroduction": "FluffyChat позволяет вам общаться с друзьями с разными мессенджерами. Узнайте больше на https://matrix.org или просто нажмите *Продолжить*.", + "previous": "Предыдущий", + "notificationRuleCallDescription": "Уведомляет пользователя про звонки.", + "notificationRuleEncryptedRoomOneToOne": "Шифрованная комната «Один на один»", + "notificationRuleEncryptedRoomOneToOneDescription": "Уведомляет пользователя про сообщение в зашифрованных комнатах «Один на один».", + "notificationRuleRoomOneToOne": "Комната «Один на один»", + "setCustomPermissionLevel": "Установить уровень пользовательских разрешений", + "setPermissionsLevelDescription": "Выберите одну из стандартных ролей ниже или введите произвольный уровень прав от 0 до 100.", + "ignoreUser": "Заглушить пользователя", + "normalUser": "Обычный пользователь", + "commandHint_roomupgrade": "Обновить комнату до указанной версии", + "notificationRuleInviteForMeDescription": "Уведомляет пользователя, когда его приглашают в комнату.", + "unknownPushRule": "Неизвестное правило оповещения '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "checkList": "Контрольный список", + "changedTheChatDescription": "{username} изменил описание чата", + "changedTheChatName": "{username} изменил(а) имя чата", + "notificationRuleMemberEvent": "Мероприятие участника", + "notificationRuleIsUserMentionDescription": "Уведомляет пользователя, когда он упоминается непосредственно в сообщении.", + "notificationRuleContainsDisplayNameDescription": "Уведомляет пользователя, когда сообщение содержит его имя отображения.", + "notificationRuleIsRoomMentionDescription": "Уведомляет пользователя о наличии упоминания о комнате.", + "notificationRuleRoomnotif": "Уведомление о комнате", + "notificationRuleRoomnotifDescription": "Уведомляет пользователя, когда сообщение содержит '@room'.", + "notificationRuleTombstone": "Надгробный камень", + "notificationRuleTombstoneDescription": "Уведомляет пользователя о сообщениях о деактивации комнаты.", + "notificationRuleRoomServerAcl": "ACL сервера комнаты", + "notificationRuleRoomServerAclDescription": "Удаляет уведомления о списках контроля доступа к серверу комнат (ACL).", + "notificationRuleSuppressEdits": "Подавление правки", + "notificationRuleRoomOneToOneDescription": "Уведомляет пользователя о сообщениях в разделах один на один.", + "notificationRuleMessageDescription": "Уведомляет пользователя об общих сообщениях.", + "notificationRuleEncryptedDescription": "Уведомляет пользователя о сообщениях в зашифрованных комнатах.", + "notificationRuleJitsi": "Джици", + "notificationRuleJitsiDescription": "Уведомляет пользователя о событиях виджета Jitsi.", + "notificationRuleServerAcl": "Запретить события ACL сервера", + "notificationRuleServerAclDescription": "Удаляет уведомления о событиях ACL сервера.", + "sentVoiceMessage": "️🎙️ {duration} - Голосовое сообщение от {sender}", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Если вы удалите эту настройку уведомлений, это невозможно отменить.", + "shareKeysWith": "Поделиться ключами с...", + "shareKeysWithDescription": "Каким устройствам следует доверять, чтобы они могли читать ваши сообщения в зашифрованных чатах?", + "crossVerifiedDevicesIfEnabled": "Кросс-верифицированные устройства, если они включены", + "crossVerifiedDevices": "Кросс-верифицированные устройства", + "verifiedDevicesOnly": "Только проверенные устройства", + "optionalMessage": "(Необязательно) сообщение...", + "notSupportedOnThisDevice": "Не поддерживается на этом устройстве", + "approve": "Утверждать", + "youHaveKnocked": "Вы постучали", + "pleaseWaitUntilInvited": "Пожалуйста, подождите, пока кто-нибудь из комнаты не пригласит вас.", + "commandHint_logout": "Выйти из текущего устройства", + "commandHint_logoutall": "Выйти из всех активных устройств", + "displayNavigationRail": "Показать навигационный рельс на мобильном устройстве", + "customReaction": "Пользовательская реакция", + "moreEvents": "Больше событий", + "declineInvitation": "Отказаться от приглашения", + "noMessagesYet": "Пока нет сообщений", + "longPressToRecordVoiceMessage": "Нажмите длиннее, чтобы записать голосовое сообщение.", + "pause": "Пауза", + "resume": "Продолжить", + "newSubSpace": "Новое подпространство", + "moveToDifferentSpace": "Переместить в другое пространство", + "moveUp": "Переместить вверх", + "moveDown": "Переместить вниз", + "removeFromSpaceDescription": "Чат будет удален из пространства, но все равно появится в вашем списке чатов.", + "countChats": "{chats} чатов", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Участник пространства из {spaces}", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Участник пространства из {spaces} может постучать", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Пожертвовать", + "startedAPoll": "{username} начал опрос.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Опрос", + "startPoll": "Начать опрос", + "endPoll": "Завершить опрос", + "answersVisible": "Ответы видны", + "answersHidden": "Ответы скрыты", + "pollQuestion": "Вопрос по опросу", + "answerOption": "Вариант ответа", + "addAnswerOption": "Добавить вариант ответа", + "allowMultipleAnswers": "Разрешить несколько ответов", + "pollHasBeenEnded": "Опрос завершен", + "answersWillBeVisibleWhenPollHasEnded": "Ответы будут видны после завершения опроса", + "replyInThread": "Ответить в ветке", + "thread": "Ветка", + "backToMainChat": "Вернуться в основной чат", + "saveChanges": "Сохранить изменения", + "createSticker": "Создать стикер или эмоджи", + "useAsSticker": "Использовать как стикер", + "useAsEmoji": "Использовать в качестве эмоджи", + "stickerPackNameAlreadyExists": "Имя набора стикеров уже существует", + "newStickerPack": "Новая упаковка стикеров", + "stickerPackName": "Имя упаковки стикеров", + "attribution": "Атрибуция", + "skipChatBackup": "Пропустить резервную копию чата", + "skipChatBackupWarning": "Вы уверены? Без включения резервного копирования чата вы можете потерять доступ к своим сообщениям, если переключите устройство.", + "loadingMessages": "Загрузка сообщений", + "setupChatBackup": "Настроить резервную копию чата", + "createNewAccount": "Создать новый аккаунт", + "theProcessWasCanceled": "Процесс был отменен.", + "noMoreResultsFound": "Ничего не найдено", + "countChatsAndCountParticipants": "{chats} чатов и {participants} участников", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "countInvited": "{count} приглашенных", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadCountMoreParticipants": "Загрузить ещё {count} участников", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + } +} diff --git a/lib/l10n/intl_sk.arb b/lib/l10n/intl_sk.arb new file mode 100644 index 000000000..4645b3330 --- /dev/null +++ b/lib/l10n/intl_sk.arb @@ -0,0 +1,1457 @@ +{ + "@@locale": "sk", + "@@last_modified": "2021-08-14 12:41:09.879987", + "about": "O aplikácii", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Prijať", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "{username} prijali pozvánku", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Účet", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "{username} aktivovali koncové šifrovanie", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Administrátor", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "anyoneCanJoin": "Ktokoľvek sa môže pripojiť", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "Archivovať", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Môžu sa pripojiť hostia", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Ste si istí?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Na overenie tejto osoby, prosím zadajte prístupovu frázu k \"bezpečému úložisku\" alebo \"klúč na obnovu\".", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Akcepovať žiadosť o verifikáciu od {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banFromChat": "Zabanovať z chatu", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Zabanovaný", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} zabanoval {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Zakázať zariadenie", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "cancel": "Zrušiť", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} si zmenili svôj avatar", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} zmenili popis chatu na: „{description}“", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} zmenili meno chatu na: „{chatname}“", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} zmenili nastavenie oprávnení chatu", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} si zmenili prezývku na: {displayname}", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} zmenili prístupové práva pre hosťov", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} zmenili prístupové práva pro hosťov na: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} zmenili nastavenie viditelnosti histórie chatu", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} zmenili nastavenie viditelnosti histórie chatu na: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} zmenili nastavenie pravidiel pripojenia", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} zmenili nastavenie pravidiel pripojenia na: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} si zmenili profilový obrázok", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} zmenili nastavenie aliasov chatu", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} zmenili odkaz k pozvánke do miestnosti", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeTheHomeserver": "Zmeniť použitý server", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Zmena štýlu", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Zmeniť názov skupiny", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Šifrovanie bolo poškodené", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Podrobnosti o chate", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Vyberte si silné heslo", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Zavrieť", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Porovnajte a uistite sa, že nasledujúce emotikony sa zhodujú na oboch zariadeniach:", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Porovnajte a uistite sa, že nasledujúce čísla sa zhodujú na oboch zariadeniach:", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Potvrdiť", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Pripojiť", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt bol pozvaný do skupiny", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Skopírované do schránky", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopírovať", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Nebolo možné dešifrovať správu: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} účastníkov", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Vytvoriť", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "{username} založili chat", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Momentálne prítomní", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Tmavá", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}.{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}.{month}.{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "delete": "Odstrániť", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Odstrániť správu", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Zariadenie", + "@device": { + "type": "String", + "placeholders": {} + }, + "devices": "Zariadenia", + "@devices": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Prezývka bola zmenená", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Stiahnuť súbor", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Zmeniť prezývku", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emotikon už existuje!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Nesprávné označenie emotikonu!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Nastavenie emotikonov", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Kód emotikonu", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Musíte zvoliť kód emotikonu a obrázok!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Prázdny chat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Šifrovanie už nebude možné vypnúť. Ste si tým istí?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryption": "Šifrovanie", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Šifrovanie nie je aktívne", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Zadajte svoj homeserver", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "fileName": "Názov súboru", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Preposlať", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Od pripojenia", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Od pozvania", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Skupina", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Skupina je verejná", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Skupina s {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Hostia sú zakázaní", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Hostia sa môžu pripojiť", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} vzal späť pozvánku pre {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Pomoc", + "@help": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identita", + "@identity": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Nesprávna prístupová fráza alebo kľúč na obnovenie", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Pozvať kontakt", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Pozvať kontakt do {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Pozvanie", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "{username} pozvali {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Len pozvaní používatelia", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} vás pozval na FluffyChat.\n1. Nainštalujte si FluffyChat: https://fluffychat.im\n2. Zaregistrujte sa alebo sa prihláste\n3. Otvorte odkaz na pozvánku: {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "píše…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "{username} sa pripojili do chatu", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "kicked": "{username} vyhodili {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "{username} vyhodili a zabanovali {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Vyhodiť z chatu", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Naposledy prítomní: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Opustiť", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Opustili chat", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licencia", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Svetlá", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Načítať ďalších {count} účastníkov", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Načítava sa… Čakajte prosím.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Načítať viac…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Prihlásiť sa", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Prihlásenie k {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Odhlásiť sa", + "@logout": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderátor", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Stlmiť chat", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Prosím berte na vedomie, že na koncové šifrovanie zatiaľ potrebujete Pantalaimon.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "Nová správa v FluffyChate", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Nová žiadosť o verifikáciu!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Nenašli sa žiadne emotikony. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Zdá sa, že nemáte žiadne služby Googlu v telefóne. To je dobré rozhodnutie pre vaše súkromie! Ak chcete dostávať push notifikácie vo FluffyChat, odporúčame používať microG: https://microg.org/.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Žiadne", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Chýba povolenie", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Nenašli sa žiadne miestnosti…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "ok": "ok", + "@ok": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Online záloha kľúčov je zapnutá", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Och! Niečo sa pokazilo…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Na prečítanie správy otvorte aplikáciu", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Otvoriť fotoaparát", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "prístupová fráza alebo kľúč na obnovenie", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Heslo", + "@password": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Vybrať obrázok", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "play": "Prehrať {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnterYourPassword": "Prosím zadajte svoje heslo", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Zadajte svoje používateľské meno", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Verejné miestnosti", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "recording": "Nahrávam", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} odstránili udalosť", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Odmietnuť", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} odmietli pozvánku", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Vrátiť sa", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Odstrániť", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Odstráňiť všetky ostatné zariadenia", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Odstánené užívateľom {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Odstráňiť zariadenie", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Odblokovať", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "Odpovedať", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Vyžiadať si povolenie", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Miestnosť bola upgradeovaná", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Videné užívateľom {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Odoslať", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Odoslať správu", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Odoslať súbor", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Odoslať obrázok", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "{username} poslali súbor", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "{username} poslali zvukovú nahrávku", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "{username} poslali obrázok", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "{username} poslali nálepku", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "{username} poslali video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "setInvitationLink": "Nastaviť odkaz pre pozvánku", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Nastaviť status", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Nastavenia", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Zdieľať", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} zdieľa lokáciu", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "skip": "Preskočiť", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Zdrojový kód", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Ako sa dnes máte?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Odoslať", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Systémová farba", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Sa nezhodujú", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Zhodujú sa", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Skúsiť znova odoslať", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} odbanovali {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Odblokovať zariadenie", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Neznáme zariadenie", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Neznámy šifrovací algoritmus", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Neznáma udalosť „{type}“", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Zrušiť stlmenie chatu", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, other{{unreadCount} neprečítaných chatov}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} a {count} dalších píšu…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} a {username2} píšu…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} píše…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "{username} opustili chat", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Užívateľské meno", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} poslali udalosť {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "Overiť", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Spustiť verifikáciu", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Verifikácia bola úspešná!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verifikujem protiľahlý účet", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videohovor", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Viditeľnosť histórie chatu", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Viditeľné pre všetkých účastníkov", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Viditeľné pre každého", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Hlasová správa", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Čaká sa, kým partner prijme požiadavku…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Čaká sa, kým partner prijme emotikon…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Čaká sa na to, kým partner prijme čísla…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Pozadie", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Kto môže vstúpiť do tejto skupiny", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Napísať správu…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Áno", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Vy", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Už sa nezúčastňujete tohto chatu", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Máte zablokovaný prístup k tomuto chatu", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "people": "Ľudia", + "@people": { + "type": "String", + "placeholders": {} + }, + "chats": "Čety", + "@chats": { + "type": "String", + "placeholders": {} + }, + "changePassword": "Zmeniť heslo", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Zmeniť názov zariadenia", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "Domovský server podporuje verzie špecifikácie:\n{serverVersions}\nAle táto aplikácie podporuje iba {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "answeredTheCall": "{senderName} prevzal hovor", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "sendAudio": "Poslať zvuk", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "addEmail": "Pridať email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "appLock": "Uzamknutie aplikácie", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "security": "Bezpečnosť", + "@security": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Nahlásiť správu", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Poslať nálepku", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Verzia miestnosti", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Poslať správy", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "Pripojiť sa k miestnosti", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Nastaviť úroveň oprávnení", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "Server podporuje tieto typy prihlásenia:\n{serverVersions}\nAle táto aplikácia podporuje iba:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "chatBackup": "Záloha chatov", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Pridať do priestoru", + "@addToSpace": {}, + "cantOpenUri": "Nemožno otvoriť identifikátor prostriedku {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "yourChatBackupHasBeenSetUp": "Záloha vašich chatov bola nastavená.", + "@yourChatBackupHasBeenSetUp": {}, + "repeatPassword": "Zopakujte heslo", + "@repeatPassword": {}, + "all": "Všetky", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Všetky chaty", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Ste si istí, že sa chcete odhlásiť?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Odoslať pri vstupe", + "@sendOnEnter": {}, + "ignoredUsers": "Ignorovaní užívatelia", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorovať", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "search": "Hľadať", + "@search": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Poslať ako text", + "@sendAsText": { + "type": "String" + }, + "sendOriginal": "Poslať originál", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Poslať video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "importNow": "Importovať teraz", + "@importNow": {} +} diff --git a/lib/l10n/intl_sl.arb b/lib/l10n/intl_sl.arb new file mode 100644 index 000000000..4bf5f58ae --- /dev/null +++ b/lib/l10n/intl_sl.arb @@ -0,0 +1,659 @@ +{ + "repeatPassword": "Ponovite geslo", + "@repeatPassword": {}, + "about": "O aplikaciji", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Sprejmi", + "@accept": { + "type": "String", + "placeholders": {} + }, + "account": "Račun", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "Uporabnik {username} je aktiviral šifriranje od konca do konca", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Dodajte e-pošto", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Dodajte v prostor", + "@addToSpace": {}, + "alias": "vzdevek", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Vse", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Vsi klepeti", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "Oseba {senderName} je odgovorila na klic", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Pridruži se lahko vsak", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Zaklepanje aplikacije", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Če želite podpisati drugo osebo, vnesite geslo za varno trgovino ali obnovitveni ključ.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Ali želite sprejeti to zahtevo za preverjanje od {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Samodejno predvajajte animirane nalepke in čustva", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "Domači strežnik podpira vrste prijave:\n{serverVersions}\nToda ta aplikacija podpira samo:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendOnEnter": "Pošlji ob vstopu", + "@sendOnEnter": {}, + "banFromChat": "Prepoved klepeta", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Prepovedano", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} je prepovedan v {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blokirana naprava", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Blokirano", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Botova sporočila", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Prekliči", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "URI-ja {uri} ni mogoče odpreti", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changedTheChatAvatar": "{username} je spremenil avatar za klepet", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} je spremenila dovoljenja za klepet", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} je spremenil svoje prikazno ime v: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} je spremenila pravila dostopa za goste", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} je spremenila pravila dostopa za goste v: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} je spremenil vidnost zgodovine v: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} je spremenil pravila za pridružitev", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} je spremenila pravila pridružitve v: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} je spremenil avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} je spremenil vzdevke sobe", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} je spremenil povezavo za povabilo", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Spremeni geslo", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Spremenite domači strežnik", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Spremenite svoj slog", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Spremenite ime skupine", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Spremenite svoj avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "chat": "Klepet", + "@chat": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Varnostna kopija klepeta je nastavljena.", + "@yourChatBackupHasBeenSetUp": {}, + "chatBackup": "Varnostno kopiranje klepeta", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Podrobnosti klepeta", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Klepet je bil dodan v ta prostor", + "@chatHasBeenAddedToThisSpace": {}, + "chats": "Klepeti", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Izberite močno geslo", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Počisti arhiv", + "@clearArchive": {}, + "close": "Zapri", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Izključi določenega uporabnika iz te sobe", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "Pošljite besedilo v obliki HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Povabi danega uporabnika v to sobo", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Pridružite se dani sobi", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Odstranite danega uporabnika iz te sobe", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_me": "Opisi sebe", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Nastavite svojo sliko za to sobo", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_op": "Nastavite raven moči danega uporabnika (privzeto: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_react": "Pošljite odgovor kot reakcijo", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Pošlji besedilo", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Prekliči izključitev določenega uporabnika iz te sobe", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Ukaz ni veljaven", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} is not a command.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Primerjajte in se prepričajte, da se naslednji emoji ujemajo s tistimi iz druge naprave:", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Primerjajte in se prepričajte, da se naslednje številke ujemajo s številkami druge naprave:", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Konfigurirajte klepet", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Potrdi", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Vsebuje prikazno ime", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Vsebuje uporabniško ime", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "archive": "Arhiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Ali si prepričan?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "{username} je sprejel povabilo", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "areYouSureYouWantToLogout": "Ali ste prepričani, da se želite odjaviti?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "changedTheChatDescriptionTo": "{username} je spremenil opis klepeta v: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "areGuestsAllowedToJoin": "Ali se lahko gostujoči uporabniki pridružijo", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "Domači strežnik podpira različice Spec:\n{serverVersions}\nToda ta aplikacija podpira samo {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} je spremenil ime klepeta v: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changeDeviceName": "Spremenite ime naprave", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheHistoryVisibility": "{username} je spremenila vidnost zgodovine", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "channelCorruptedDecryptError": "Šifriranje je poškodovano", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Vsebina je bila prijavljena skrbnikom strežnika", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Varnostna kopija klepeta je zavarovana z varnostnim ključem. Prosimo, pazite, da ga ne izgubite.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "commandHint_myroomnick": "Nastavite prikazno ime za to sobo", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "connect": "Povežite se", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt je bil povabljen v skupino", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "commandHint_leave": "Zapusti to sobo", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_plain": "Pošlji neformatirano besedilo", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "copiedToClipboard": "Kopirano v odložišče", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopiraj", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopiraj v odložišče", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Sporočila ni bilo mogoče dešifrirati: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} udeležencev", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Ustvari", + "@create": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Nov prostor", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Trenutno aktiven", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Temno", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Privzeta raven dovoljenja", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "createdTheChat": "{username} je ustvaril klepet", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "S tem boste deaktivirali vaš uporabniški račun. Tega ni mogoče razveljaviti! Ali si prepričan?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + } +} diff --git a/assets/l10n/intl_be.arb b/lib/l10n/intl_sq.arb similarity index 100% rename from assets/l10n/intl_be.arb rename to lib/l10n/intl_sq.arb diff --git a/assets/l10n/intl_sr.arb b/lib/l10n/intl_sr.arb similarity index 67% rename from assets/l10n/intl_sr.arb rename to lib/l10n/intl_sr.arb index 2b0564d85..126b07a09 100644 --- a/assets/l10n/intl_sr.arb +++ b/lib/l10n/intl_sr.arb @@ -2,2212 +2,1969 @@ "@@last_modified": "2021-08-14 12:41:09.857024", "about": "О програму", "@about": { - "type": "text", + "type": "String", "placeholders": {} }, "accept": "Прихвати", "@accept": { - "type": "text", + "type": "String", "placeholders": {} }, "acceptedTheInvitation": "{username} прихвата позивницу", "@acceptedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "account": "Налог", "@account": { - "type": "text", + "type": "String", "placeholders": {} }, "activatedEndToEndEncryption": "{username} укључи шифровање с краја на крај", "@activatedEndToEndEncryption": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "addEmail": "Додај е-адресу", "@addEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "admin": "Админ", "@admin": { - "type": "text", + "type": "String", "placeholders": {} }, "alias": "алијас", "@alias": { - "type": "text", + "type": "String", "placeholders": {} }, "all": "Сви", "@all": { - "type": "text", + "type": "String", "placeholders": {} }, "answeredTheCall": "{senderName} одговори на позив", "@answeredTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "anyoneCanJoin": "свако може да се придружи", "@anyoneCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "appLock": "Закључавање апликације", "@appLock": { - "type": "text", + "type": "String", "placeholders": {} }, "archive": "Архива", "@archive": { - "type": "text", + "type": "String", "placeholders": {} }, "areGuestsAllowedToJoin": "Да ли је гостима дозвољен приступ", "@areGuestsAllowedToJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSure": "Сигурни сте?", "@areYouSure": { - "type": "text", + "type": "String", "placeholders": {} }, "areYouSureYouWantToLogout": "Заиста желите да се одјавите?", "@areYouSureYouWantToLogout": { - "type": "text", + "type": "String", "placeholders": {} }, "askSSSSSign": "Да бисте могли да пријавите другу особу, унесите своју безбедносну фразу или кључ опоравка.", "@askSSSSSign": { - "type": "text", + "type": "String", "placeholders": {} }, "askVerificationRequest": "Прихватате ли захтев за верификацију од корисника {username}?", "@askVerificationRequest": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "badServerLoginTypesException": "Домаћи сервер подржава начине пријаве:\n{serverVersions}\nали ова апликација подржава само:\n{supportedVersions}", "@badServerLoginTypesException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "badServerVersionsException": "Домаћи сервер подржава верзије:\n{serverVersions}\nали ова апликација подржава само {supportedVersions}", "@badServerVersionsException": { - "type": "text", + "type": "String", "placeholders": { - "serverVersions": {}, - "supportedVersions": {} + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } } }, "banFromChat": "Забрани у ћаскању", "@banFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "banned": "Забрањен", "@banned": { - "type": "text", + "type": "String", "placeholders": {} }, "bannedUser": "{username} забрани корисника {targetName}", "@bannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "blockDevice": "Блокирај уређај", "@blockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "blocked": "Блокиран", "@blocked": { - "type": "text", + "type": "String", "placeholders": {} }, "botMessages": "Поруке Бота", "@botMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "cancel": "Откажи", "@cancel": { - "type": "text", + "type": "String", "placeholders": {} }, "changeDeviceName": "Промени назив уређаја", "@changeDeviceName": { - "type": "text", + "type": "String", "placeholders": {} }, "changedTheChatAvatar": "{username} промени аватар ћаскања", "@changedTheChatAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheChatDescriptionTo": "{username} промени опис ћаскања у: „{description}“", "@changedTheChatDescriptionTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "description": {} + "username": { + "type": "String" + }, + "description": { + "type": "String" + } } }, "changedTheChatNameTo": "{username} промени назив ћаскања у: „{chatname}“", "@changedTheChatNameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "chatname": {} + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } } }, "changedTheChatPermissions": "{username} измени дозволе ћаскања", "@changedTheChatPermissions": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheDisplaynameTo": "{username} промени приказно име на: „{displayname}“", "@changedTheDisplaynameTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "displayname": {} + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } } }, "changedTheGuestAccessRules": "{username} измени правила за приступ гостију", "@changedTheGuestAccessRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheGuestAccessRulesTo": "{username} измени правила за приступ гостију на: {rules}", "@changedTheGuestAccessRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheHistoryVisibility": "{username} измени видљивост историје", "@changedTheHistoryVisibility": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheHistoryVisibilityTo": "{username} измени видљивост историје на: {rules}", "@changedTheHistoryVisibilityTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "rules": {} + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } } }, "changedTheJoinRules": "{username} измени правила приступања", "@changedTheJoinRules": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheJoinRulesTo": "{username} измени правила приступања на: {joinRules}", "@changedTheJoinRulesTo": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "joinRules": {} + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } } }, "changedTheProfileAvatar": "{username} измени свој аватар", "@changedTheProfileAvatar": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomAliases": "{username} измени алијас собе", "@changedTheRoomAliases": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changedTheRoomInvitationLink": "{username} измени везу позивнице", "@changedTheRoomInvitationLink": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "changePassword": "Измени лозинку", "@changePassword": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheHomeserver": "Промени домаћи сервер", "@changeTheHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheme": "Измените изглед", "@changeTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "changeTheNameOfTheGroup": "Измени назив групе", "@changeTheNameOfTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "changeYourAvatar": "Измените свој аватар", "@changeYourAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "channelCorruptedDecryptError": "Шифровање је покварено", "@channelCorruptedDecryptError": { - "type": "text", + "type": "String", "placeholders": {} }, "chat": "Ћаскање", "@chat": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackup": "Копија ћаскања", "@chatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "chatBackupDescription": "Ваша резервна копија ћаскања је обезбеђена кључем. Немојте да га изгубите.", "@chatBackupDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "chatDetails": "Детаљи ћаскања", "@chatDetails": { - "type": "text", + "type": "String", "placeholders": {} }, "chats": "Ћаскања", "@chats": { - "type": "text", + "type": "String", "placeholders": {} }, "chooseAStrongPassword": "Изаберите јаку лозинку", "@chooseAStrongPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "clearArchive": "Очисти архиву", "@clearArchive": {}, "close": "Затвори", "@close": { - "type": "text", + "type": "String", "placeholders": {} }, "commandHint_ban": "Блокирај задатог корисника за ову собу", "@commandHint_ban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /ban" }, "commandHint_html": "Шаљи ХТМЛ обликован текст", "@commandHint_html": { - "type": "text", + "type": "String", "description": "Usage hint for the command /html" }, "commandHint_invite": "Позови задатог корисника у собу", "@commandHint_invite": { - "type": "text", + "type": "String", "description": "Usage hint for the command /invite" }, "commandHint_join": "Придружи се наведеној соби", "@commandHint_join": { - "type": "text", + "type": "String", "description": "Usage hint for the command /join" }, "commandHint_kick": "Уклони задатог корисника из собе", "@commandHint_kick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /kick" }, "commandHint_leave": "Напусти ову собу", "@commandHint_leave": { - "type": "text", + "type": "String", "description": "Usage hint for the command /leave" }, "commandHint_me": "Опишите себе", "@commandHint_me": { - "type": "text", + "type": "String", "description": "Usage hint for the command /me" }, "commandHint_myroomnick": "Поставља ваш надимак за ову собу", "@commandHint_myroomnick": { - "type": "text", + "type": "String", "description": "Usage hint for the command /myroomnick" }, "commandHint_op": "Подеси ниво задатог корисника (подразумевано: 50)", "@commandHint_op": { - "type": "text", + "type": "String", "description": "Usage hint for the command /op" }, "commandHint_plain": "Шаљи неформатиран текст", "@commandHint_plain": { - "type": "text", + "type": "String", "description": "Usage hint for the command /plain" }, "commandHint_react": "Шаљи одговор као реакцију", "@commandHint_react": { - "type": "text", + "type": "String", "description": "Usage hint for the command /react" }, "commandHint_send": "Пошаљи текст", "@commandHint_send": { - "type": "text", + "type": "String", "description": "Usage hint for the command /send" }, "commandHint_unban": "Скини забрану задатом кориснику за ову собу", "@commandHint_unban": { - "type": "text", + "type": "String", "description": "Usage hint for the command /unban" }, "compareEmojiMatch": "Упоредите и проверите да су емоџији идентични као на другом уређају:", "@compareEmojiMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "compareNumbersMatch": "Упоредите и проверите да су следећи бројеви идентични као на другом уређају:", "@compareNumbersMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "configureChat": "Подешавање ћаскања", "@configureChat": { - "type": "text", + "type": "String", "placeholders": {} }, "confirm": "Потврди", "@confirm": { - "type": "text", + "type": "String", "placeholders": {} }, "connect": "Повежи се", "@connect": { - "type": "text", + "type": "String", "placeholders": {} }, "contactHasBeenInvitedToTheGroup": "Особа је позвана у групу", "@contactHasBeenInvitedToTheGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "containsDisplayName": "Садржи приказно име", "@containsDisplayName": { - "type": "text", + "type": "String", "placeholders": {} }, "containsUserName": "Садржи корисничко име", "@containsUserName": { - "type": "text", + "type": "String", "placeholders": {} }, "contentHasBeenReported": "Садржај је пријављен администраторима сервера", "@contentHasBeenReported": { - "type": "text", + "type": "String", "placeholders": {} }, "copiedToClipboard": "Копирано у клипборд", "@copiedToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "copy": "Копирај", "@copy": { - "type": "text", + "type": "String", "placeholders": {} }, "copyToClipboard": "Копирај у клипборд", "@copyToClipboard": { - "type": "text", + "type": "String", "placeholders": {} }, "couldNotDecryptMessage": "Не могу да дешифрујем поруку: {error}", "@couldNotDecryptMessage": { - "type": "text", + "type": "String", "placeholders": { - "error": {} + "error": { + "type": "String" + } } }, "countParticipants": "учесника: {count}", "@countParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "create": "Направи", "@create": { - "type": "text", + "type": "String", "placeholders": {} }, "createdTheChat": "{username} направи ћаскање", "@createdTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "currentlyActive": "Тренутно активно", "@currentlyActive": { - "type": "text", + "type": "String", "placeholders": {} }, "darkTheme": "тамни", "@darkTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "dateAndTimeOfDay": "{date}, {timeOfDay}", "@dateAndTimeOfDay": { - "type": "text", + "type": "String", "placeholders": { - "date": {}, - "timeOfDay": {} + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } } }, "dateWithoutYear": "{day} {month}", "@dateWithoutYear": { - "type": "text", + "type": "String", "placeholders": { - "month": {}, - "day": {} + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "dateWithYear": "{day} {month} {year}", "@dateWithYear": { - "type": "text", + "type": "String", "placeholders": { - "year": {}, - "month": {}, - "day": {} + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } } }, "deactivateAccountWarning": "Ово ће деактивирати ваш кориснички налог. Не може се повратити! Сигурни сте?", "@deactivateAccountWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "defaultPermissionLevel": "Подразумевани ниво приступа", "@defaultPermissionLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "delete": "Обриши", "@delete": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteAccount": "Обриши налог", "@deleteAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "deleteMessage": "Брисање поруке", "@deleteMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "device": "Уређај", "@device": { - "type": "text", + "type": "String", "placeholders": {} }, "deviceId": "ИД уређаја", "@deviceId": { - "type": "text", + "type": "String", "placeholders": {} }, "devices": "Уређаји", "@devices": { - "type": "text", + "type": "String", "placeholders": {} }, "directChats": "Директна ћаскања", "@directChats": { - "type": "text", + "type": "String", "placeholders": {} }, "displaynameHasBeenChanged": "Име за приказ је измењено", "@displaynameHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "downloadFile": "Преузми фајл", "@downloadFile": { - "type": "text", + "type": "String", "placeholders": {} }, "edit": "Уреди", "@edit": { - "type": "text", + "type": "String", "placeholders": {} }, "editBlockedServers": "Уреди блокиране сервере", "@editBlockedServers": { - "type": "text", + "type": "String", "placeholders": {} }, "editDisplayname": "Уреди име за приказ", "@editDisplayname": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAliases": "Уреди алијасе собе", "@editRoomAliases": { - "type": "text", + "type": "String", "placeholders": {} }, "editRoomAvatar": "Уређује аватар собе", "@editRoomAvatar": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteExists": "Емоти већ постоји!", "@emoteExists": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteInvalid": "Неисправна скраћеница за емоти!", "@emoteInvalid": { - "type": "text", + "type": "String", "placeholders": {} }, "emotePacks": "Пакети емотија за собу", "@emotePacks": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteSettings": "Поставке емотија", "@emoteSettings": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteShortcode": "скраћеница", "@emoteShortcode": { - "type": "text", + "type": "String", "placeholders": {} }, "emoteWarnNeedToPick": "Морате да изаберете скраћеницу и слику за емоти!", "@emoteWarnNeedToPick": { - "type": "text", + "type": "String", "placeholders": {} }, "emptyChat": "празно ћаскање", "@emptyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEmotesGlobally": "Глобално укључи пакет емотија", "@enableEmotesGlobally": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryption": "Укључује шифровање", "@enableEncryption": { - "type": "text", + "type": "String", "placeholders": {} }, "enableEncryptionWarning": "Шифровање више нећете моћи да искључите. Сигурни сте?", "@enableEncryptionWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "encrypted": "Шифровано", "@encrypted": { - "type": "text", + "type": "String", "placeholders": {} }, "encryption": "Шифровање", "@encryption": { - "type": "text", + "type": "String", "placeholders": {} }, "encryptionNotEnabled": "Шифровање није укључено", "@encryptionNotEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "endedTheCall": "{senderName} заврши позив", "@endedTheCall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "enterAnEmailAddress": "Унесите адресу е-поште", "@enterAnEmailAddress": { - "type": "text", + "type": "String", "placeholders": {} }, "enterYourHomeserver": "Унесите свој домаћи сервер", "@enterYourHomeserver": { - "type": "text", + "type": "String", "placeholders": {} }, "everythingReady": "Све је спремно!", "@everythingReady": { - "type": "text", + "type": "String", "placeholders": {} }, "extremeOffensive": "Екстремно увредљив", "@extremeOffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "fileName": "Назив фајла", "@fileName": { - "type": "text", + "type": "String", "placeholders": {} }, "fluffychat": "FluffyChat", "@fluffychat": { - "type": "text", + "type": "String", "placeholders": {} }, "fontSize": "Величина фонта", "@fontSize": { - "type": "text", + "type": "String", "placeholders": {} }, "forward": "Напред", "@forward": { - "type": "text", + "type": "String", "placeholders": {} }, "fromJoining": "од приступања", "@fromJoining": { - "type": "text", + "type": "String", "placeholders": {} }, "fromTheInvitation": "од позивања", "@fromTheInvitation": { - "type": "text", + "type": "String", "placeholders": {} }, "goToTheNewRoom": "Иди у нову собу", "@goToTheNewRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "group": "Група", "@group": { - "type": "text", + "type": "String", "placeholders": {} }, "groupIsPublic": "Група је јавна", "@groupIsPublic": { - "type": "text", + "type": "String", "placeholders": {} }, "groups": "Групе", "@groups": { - "type": "text", + "type": "String", "placeholders": {} }, "groupWith": "Група са корисником {displayname}", "@groupWith": { - "type": "text", + "type": "String", "placeholders": { - "displayname": {} + "displayname": { + "type": "String" + } } }, "guestsAreForbidden": "гости су забрањени", "@guestsAreForbidden": { - "type": "text", + "type": "String", "placeholders": {} }, "guestsCanJoin": "гости могу приступити", "@guestsCanJoin": { - "type": "text", + "type": "String", "placeholders": {} }, "hasWithdrawnTheInvitationFor": "{username} поништи позивницу за корисника {targetName}", "@hasWithdrawnTheInvitationFor": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "help": "Помоћ", "@help": { - "type": "text", + "type": "String", "placeholders": {} }, "hideRedactedEvents": "Сакриј редиговане догађаје", "@hideRedactedEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "hideUnknownEvents": "Сакриј непознате догађаје", "@hideUnknownEvents": { - "type": "text", + "type": "String", "placeholders": {} }, "howOffensiveIsThisContent": "Колико је увредљив овај садржај?", "@howOffensiveIsThisContent": { - "type": "text", + "type": "String", "placeholders": {} }, "id": "ИД", "@id": { - "type": "text", + "type": "String", "placeholders": {} }, "identity": "Идентитет", "@identity": { - "type": "text", + "type": "String", "placeholders": {} }, "ignore": "Игнориши", "@ignore": { - "type": "text", + "type": "String", "placeholders": {} }, "ignoredUsers": "Игнорисани корисници", "@ignoredUsers": { - "type": "text", + "type": "String", "placeholders": {} }, "iHaveClickedOnLink": "Кликнуо сам на везу", "@iHaveClickedOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "incorrectPassphraseOrKey": "Неисправна фраза или кључ опоравка", "@incorrectPassphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "inoffensive": "Није увредљив", "@inoffensive": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContact": "Позивање особа", "@inviteContact": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteContactToGroup": "Позови особу у групу {groupName}", "@inviteContactToGroup": { - "type": "text", + "type": "String", "placeholders": { - "groupName": {} + "groupName": { + "type": "String" + } } }, "invited": "Позван", "@invited": { - "type": "text", + "type": "String", "placeholders": {} }, "invitedUser": "{username} позва корисника {targetName}", "@invitedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "invitedUsersOnly": "само позвани корисници", "@invitedUsersOnly": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteForMe": "Позивнице за мене", "@inviteForMe": { - "type": "text", + "type": "String", "placeholders": {} }, "inviteText": "{username} вас позива у FluffyChat. \n1. Инсталирајте FluffyChat: https://fluffychat.im \n2. Региструјте се или пријавите \n3. Отворите везу позивнице: {link}", "@inviteText": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "link": {} + "username": { + "type": "String" + }, + "link": { + "type": "String" + } } }, "isTyping": "куца…", "@isTyping": { - "type": "text", + "type": "String", "placeholders": {} }, "joinedTheChat": "{username} се придружи ћаскању", "@joinedTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "joinRoom": "Придружи се соби", "@joinRoom": { - "type": "text", + "type": "String", "placeholders": {} }, "kicked": "{username} избаци корисника {targetName}", "@kicked": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickedAndBanned": "{username} избаци и забрани корисника {targetName}", "@kickedAndBanned": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "kickFromChat": "Избаци из ћаскања", "@kickFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "lastActiveAgo": "Последња активност: {localizedTimeShort}", "@lastActiveAgo": { - "type": "text", + "type": "String", "placeholders": { - "localizedTimeShort": {} + "localizedTimeShort": { + "type": "String" + } } }, "leave": "Напусти", "@leave": { - "type": "text", + "type": "String", "placeholders": {} }, "leftTheChat": "Напусти ћаскање", "@leftTheChat": { - "type": "text", + "type": "String", "placeholders": {} }, "license": "Лиценца", "@license": { - "type": "text", + "type": "String", "placeholders": {} }, "lightTheme": "светли", "@lightTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "loadCountMoreParticipants": "Учитај још {count} учесника", "@loadCountMoreParticipants": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "loadingPleaseWait": "Учитавам… Сачекајте.", "@loadingPleaseWait": { - "type": "text", + "type": "String", "placeholders": {} }, "loadMore": "Учитај још…", "@loadMore": { - "type": "text", + "type": "String", "placeholders": {} }, "login": "Пријава", "@login": { - "type": "text", + "type": "String", "placeholders": {} }, "logInTo": "Пријава на {homeserver}", "@logInTo": { - "type": "text", + "type": "String", "placeholders": { - "homeserver": {} + "homeserver": { + "type": "String" + } } }, "logout": "Одјава", "@logout": { - "type": "text", + "type": "String", "placeholders": {} }, "memberChanges": "Измене чланова", "@memberChanges": { - "type": "text", + "type": "String", "placeholders": {} }, "mention": "Спомени", "@mention": { - "type": "text", + "type": "String", "placeholders": {} }, "messages": "Поруке", "@messages": { - "type": "text", + "type": "String", "placeholders": {} }, "moderator": "Модератор", "@moderator": { - "type": "text", + "type": "String", "placeholders": {} }, "muteChat": "Ућуткај ћаскање", "@muteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "needPantalaimonWarning": "За сада, потребан је Пантелејмон (Pantalaimon) да бисте користили шифровање с краја на крај.", "@needPantalaimonWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "newChat": "Ново ћаскање", "@newChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newMessageInFluffyChat": "Нова порука — FluffyChat", "@newMessageInFluffyChat": { - "type": "text", + "type": "String", "placeholders": {} }, "newVerificationRequest": "Нови захтев за верификацију!", "@newVerificationRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "next": "Следеће", "@next": { - "type": "text", + "type": "String", "placeholders": {} }, "no": "Не", "@no": { - "type": "text", + "type": "String", "placeholders": {} }, "noConnectionToTheServer": "Нема везе са сервером", "@noConnectionToTheServer": { - "type": "text", + "type": "String", "placeholders": {} }, "noEmotesFound": "Нема емотија. 😕", "@noEmotesFound": { - "type": "text", + "type": "String", "placeholders": {} }, "noEncryptionForPublicRooms": "Шифровање се може активирати након што соба престане да буде јавно доступна.", "@noEncryptionForPublicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "noGoogleServicesWarning": "Чини се да немате Гугл услуге на телефону. То је добра одлука за вашу приватност! Да би се протурале нотификације у FluffyChat, препоручујемо коришћење https://microg.org/ или https://unifiedpush.org/", "@noGoogleServicesWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "none": "Ништа", "@none": { - "type": "text", + "type": "String", "placeholders": {} }, "noPasswordRecoveryDescription": "Још нисте одредили начин за опоравак лозинке.", "@noPasswordRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "noPermission": "Нема дозвола", "@noPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "noRoomsFound": "Нисам нашао собе…", "@noRoomsFound": { - "type": "text", + "type": "String", "placeholders": {} }, "notifications": "Обавештења", "@notifications": { - "type": "text", + "type": "String", "placeholders": {} }, "notificationsEnabledForThisAccount": "Обавештења укључена за овај налог", "@notificationsEnabledForThisAccount": { - "type": "text", + "type": "String", "placeholders": {} }, "numUsersTyping": "{count} корисника куца…", "@numUsersTyping": { - "type": "text", + "type": "String", "placeholders": { - "count": {} + "count": { + "type": "int" + } } }, "offensive": "Увредљив", "@offensive": { - "type": "text", + "type": "String", "placeholders": {} }, "offline": "Ван везе", "@offline": { - "type": "text", + "type": "String", "placeholders": {} }, "ok": "у реду", "@ok": { - "type": "text", + "type": "String", "placeholders": {} }, "online": "На вези", "@online": { - "type": "text", + "type": "String", "placeholders": {} }, "onlineKeyBackupEnabled": "Резерва кључева на мрежи је укључена", "@onlineKeyBackupEnabled": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsPushError": "Нажалост, дошло је до грешке при подешавању дотурања обавештења.", "@oopsPushError": { - "type": "text", + "type": "String", "placeholders": {} }, "oopsSomethingWentWrong": "Нешто је пошло наопако…", "@oopsSomethingWentWrong": { - "type": "text", + "type": "String", "placeholders": {} }, "openAppToReadMessages": "Отворите апликацију да прочитате поруке", "@openAppToReadMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "openCamera": "Отвори камеру", "@openCamera": { - "type": "text", + "type": "String", "placeholders": {} }, "or": "или", "@or": { - "type": "text", + "type": "String", "placeholders": {} }, "participant": "Учесник", "@participant": { - "type": "text", + "type": "String", "placeholders": {} }, "passphraseOrKey": "фраза или кључ опоравка", "@passphraseOrKey": { - "type": "text", + "type": "String", "placeholders": {} }, "password": "Лозинка", "@password": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordForgotten": "Заборављена лозинка", "@passwordForgotten": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordHasBeenChanged": "Лозинка је промењена", "@passwordHasBeenChanged": { - "type": "text", + "type": "String", "placeholders": {} }, "passwordRecovery": "Опоравак лозинке", "@passwordRecovery": { - "type": "text", + "type": "String", "placeholders": {} }, "people": "Људи", "@people": { - "type": "text", + "type": "String", "placeholders": {} }, "pickImage": "Избор слике", "@pickImage": { - "type": "text", + "type": "String", "placeholders": {} }, "pin": "Закачи", "@pin": { - "type": "text", + "type": "String", "placeholders": {} }, "play": "Пусти {fileName}", "@play": { - "type": "text", + "type": "String", "placeholders": { - "fileName": {} + "fileName": { + "type": "String" + } } }, "pleaseChoose": "Изаберите", "@pleaseChoose": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseChooseAPasscode": "Изаберите код за пролаз", "@pleaseChooseAPasscode": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseClickOnLink": "Кликните на везу у примљеној е-пошти па наставите.", "@pleaseClickOnLink": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnter4Digits": "Унесите 4 цифре или оставите празно да не закључавате апликацију.", "@pleaseEnter4Digits": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPassword": "Унесите своју лозинку", "@pleaseEnterYourPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourPin": "Унесите свој пин", "@pleaseEnterYourPin": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseEnterYourUsername": "Унесите своје корисничко име", "@pleaseEnterYourUsername": { - "type": "text", + "type": "String", "placeholders": {} }, "pleaseFollowInstructionsOnWeb": "Испратите упутства на веб сајту и тапните на „Следеће“.", "@pleaseFollowInstructionsOnWeb": { - "type": "text", + "type": "String", "placeholders": {} }, "privacy": "Приватност", "@privacy": { - "type": "text", + "type": "String", "placeholders": {} }, "publicRooms": "Јавне собе", "@publicRooms": { - "type": "text", + "type": "String", "placeholders": {} }, "pushRules": "Правила протурања", "@pushRules": { - "type": "text", + "type": "String", "placeholders": {} }, "reason": "Разлог", "@reason": { - "type": "text", + "type": "String", "placeholders": {} }, "recording": "Снимам", "@recording": { - "type": "text", + "type": "String", "placeholders": {} }, "redactedAnEvent": "{username} редигова догађај", "@redactedAnEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "redactMessage": "Редигуј поруку", "@redactMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "register": "Регистрација", "@register": { - "type": "text", + "type": "String", "placeholders": {} }, "reject": "Одбиј", "@reject": { - "type": "text", + "type": "String", "placeholders": {} }, "rejectedTheInvitation": "{username} одби позивницу", "@rejectedTheInvitation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "rejoin": "Поново се придружи", "@rejoin": { - "type": "text", + "type": "String", "placeholders": {} }, "remove": "Уклони", "@remove": { - "type": "text", + "type": "String", "placeholders": {} }, "removeAllOtherDevices": "Уклони све остале уређаје", "@removeAllOtherDevices": { - "type": "text", + "type": "String", "placeholders": {} }, "removedBy": "Уклонио корисник {username}", "@removedBy": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "removeDevice": "Уклони уређај", "@removeDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unbanFromChat": "Уклони изгнанство", "@unbanFromChat": { - "type": "text", + "type": "String", "placeholders": {} }, "removeYourAvatar": "Уклоните свој аватар", "@removeYourAvatar": { - "type": "text", - "placeholders": {} - }, - "renderRichContent": "Приказуј обогаћен садржај поруке", - "@renderRichContent": { - "type": "text", + "type": "String", "placeholders": {} }, "replaceRoomWithNewerVersion": "Замени собу новијом верзијом", "@replaceRoomWithNewerVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "reply": "Одговори", "@reply": { - "type": "text", + "type": "String", "placeholders": {} }, "reportMessage": "Пријави поруку", "@reportMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "requestPermission": "Затражи дозволу", "@requestPermission": { - "type": "text", + "type": "String", "placeholders": {} }, "roomHasBeenUpgraded": "Соба је надограђена", "@roomHasBeenUpgraded": { - "type": "text", + "type": "String", "placeholders": {} }, "roomVersion": "Верзија собе", "@roomVersion": { - "type": "text", + "type": "String", "placeholders": {} }, "search": "Претражи", "@search": { - "type": "text", + "type": "String", "placeholders": {} }, "security": "Безбедност", "@security": { - "type": "text", + "type": "String", "placeholders": {} }, "seenByUser": "{username} прегледа", "@seenByUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "send": "Пошаљи", "@send": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAMessage": "Пошаљи поруку", "@sendAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendAudio": "Пошаљи аудио", "@sendAudio": { - "type": "text", + "type": "String", "placeholders": {} }, "sendFile": "Пошаљи фајл", "@sendFile": { - "type": "text", + "type": "String", "placeholders": {} }, "sendImage": "Пошаљи слику", "@sendImage": { - "type": "text", + "type": "String", "placeholders": {} }, "sendMessages": "Слање порука", "@sendMessages": { - "type": "text", + "type": "String", "placeholders": {} }, "sendOriginal": "Пошаљи оригинал", "@sendOriginal": { - "type": "text", + "type": "String", "placeholders": {} }, "sendVideo": "Пошаљи видео", "@sendVideo": { - "type": "text", + "type": "String", "placeholders": {} }, "sentAFile": "{username} посла фајл", "@sentAFile": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAnAudio": "{username} посла аудио", "@sentAnAudio": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAPicture": "{username} посла слику", "@sentAPicture": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentASticker": "{username} посла налепницу", "@sentASticker": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentAVideo": "{username} посла видео", "@sentAVideo": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "sentCallInformations": "{senderName} посла податке о позиву", "@sentCallInformations": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "setAsCanonicalAlias": "Постави као главни алијас", "@setAsCanonicalAlias": { - "type": "text", + "type": "String", "placeholders": {} }, "setCustomEmotes": "постави посебне емотије", "@setCustomEmotes": { - "type": "text", + "type": "String", "placeholders": {} }, "setInvitationLink": "Поставља везу позивнице", "@setInvitationLink": { - "type": "text", + "type": "String", "placeholders": {} }, "setPermissionsLevel": "Одреди ниво дозволе", "@setPermissionsLevel": { - "type": "text", + "type": "String", "placeholders": {} }, "setStatus": "Постави статус", "@setStatus": { - "type": "text", + "type": "String", "placeholders": {} }, "settings": "Поставке", "@settings": { - "type": "text", + "type": "String", "placeholders": {} }, "share": "Подели", "@share": { - "type": "text", + "type": "String", "placeholders": {} }, "sharedTheLocation": "{username} подели локацију", "@sharedTheLocation": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "showPassword": "Прикажи лозинку", "@showPassword": { - "type": "text", + "type": "String", "placeholders": {} }, "singlesignon": "Јединствена пријава", "@singlesignon": { - "type": "text", + "type": "String", "placeholders": {} }, "skip": "Прескочи", "@skip": { - "type": "text", + "type": "String", "placeholders": {} }, "sourceCode": "Изворни код", "@sourceCode": { - "type": "text", + "type": "String", "placeholders": {} }, "startedACall": "{senderName} започе позив", "@startedACall": { - "type": "text", + "type": "String", "placeholders": { - "senderName": {} + "senderName": { + "type": "String" + } } }, "status": "Стање", "@status": { - "type": "text", + "type": "String", "placeholders": {} }, "statusExampleMessage": "Како сте данас?", "@statusExampleMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "submit": "Пошаљи", "@submit": { - "type": "text", + "type": "String", "placeholders": {} }, "systemTheme": "системски", "@systemTheme": { - "type": "text", + "type": "String", "placeholders": {} }, "theyDontMatch": "Не поклапају се", "@theyDontMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "theyMatch": "Поклапају се", "@theyMatch": { - "type": "text", + "type": "String", "placeholders": {} }, "title": "FluffyChat", "@title": { "description": "Title for the application", - "type": "text", + "type": "String", "placeholders": {} }, "toggleFavorite": "Мењај омиљеност", "@toggleFavorite": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleMuted": "Мењај ућутканост", "@toggleMuted": { - "type": "text", + "type": "String", "placeholders": {} }, "toggleUnread": "Означи не/прочитано", "@toggleUnread": { - "type": "text", + "type": "String", "placeholders": {} }, "tooManyRequestsWarning": "Превише упита. Покушајте касније!", "@tooManyRequestsWarning": { - "type": "text", + "type": "String", "placeholders": {} }, "transferFromAnotherDevice": "Пренос са другог уређаја", "@transferFromAnotherDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "tryToSendAgain": "Покушај слање поново", "@tryToSendAgain": { - "type": "text", + "type": "String", "placeholders": {} }, "unavailable": "Недоступно", "@unavailable": { - "type": "text", + "type": "String", "placeholders": {} }, "unbannedUser": "{username} одблокира корисника {targetName}", "@unbannedUser": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "targetName": {} + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } } }, "unblockDevice": "Одблокирај уређај", "@unblockDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownDevice": "Непознат уређај", "@unknownDevice": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEncryptionAlgorithm": "Непознат алгоритам шифровања", "@unknownEncryptionAlgorithm": { - "type": "text", + "type": "String", "placeholders": {} }, "unknownEvent": "Непознат догађај „{type}“", "@unknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "type": {} + "type": { + "type": "String" + } } }, "unmuteChat": "Врати обавештења", "@unmuteChat": { - "type": "text", + "type": "String", "placeholders": {} }, "unpin": "Откачи", "@unpin": { - "type": "text", + "type": "String", "placeholders": {} }, "unreadChats": "{unreadCount, plural, other{непрочитаних ћаскања: {unreadCount}}}", "@unreadChats": { - "type": "text", + "type": "String", "placeholders": { - "unreadCount": {} + "unreadCount": { + "type": "int" + } } }, "userAndOthersAreTyping": "{username} и {count} корисника куцају…", "@userAndOthersAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "count": {} + "username": { + "type": "String" + }, + "count": { + "type": "int" + } } }, "userAndUserAreTyping": "{username} и {username2} куцају…", "@userAndUserAreTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "username2": {} + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } } }, "userIsTyping": "{username} куца…", "@userIsTyping": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "userLeftTheChat": "{username} напусти ћаскање", "@userLeftTheChat": { - "type": "text", + "type": "String", "placeholders": { - "username": {} + "username": { + "type": "String" + } } }, "username": "Корисничко име", "@username": { - "type": "text", + "type": "String", "placeholders": {} }, "userSentUnknownEvent": "{username} посла {type} догађај", "@userSentUnknownEvent": { - "type": "text", + "type": "String", "placeholders": { - "username": {}, - "type": {} + "username": { + "type": "String" + }, + "type": { + "type": "String" + } } }, "verified": "Оверен", "@verified": { - "type": "text", + "type": "String", "placeholders": {} }, "verify": "Верификуј", "@verify": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyStart": "Покрени верификацију", "@verifyStart": { - "type": "text", + "type": "String", "placeholders": {} }, "verifySuccess": "Успешно сте верификовали!", "@verifySuccess": { - "type": "text", + "type": "String", "placeholders": {} }, "verifyTitle": "Верификујем други налог", "@verifyTitle": { - "type": "text", + "type": "String", "placeholders": {} }, "videoCall": "Видео позив", "@videoCall": { - "type": "text", + "type": "String", "placeholders": {} }, "visibilityOfTheChatHistory": "Одреди видљивост историје", "@visibilityOfTheChatHistory": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForAllParticipants": "видљиво свим учесницима", "@visibleForAllParticipants": { - "type": "text", + "type": "String", "placeholders": {} }, "visibleForEveryone": "видљиво свима", "@visibleForEveryone": { - "type": "text", + "type": "String", "placeholders": {} }, "voiceMessage": "Гласовна порука", "@voiceMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerAcceptRequest": "Чекам да саговорник прихвати захтев…", "@waitingPartnerAcceptRequest": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerEmoji": "Чекам да саговорник прихвати емоџије…", "@waitingPartnerEmoji": { - "type": "text", + "type": "String", "placeholders": {} }, "waitingPartnerNumbers": "Чекам да саговорник прихвати бројеве…", "@waitingPartnerNumbers": { - "type": "text", + "type": "String", "placeholders": {} }, "wallpaper": "Тапета", "@wallpaper": { - "type": "text", + "type": "String", "placeholders": {} }, "warning": "Упозорење!", "@warning": { - "type": "text", + "type": "String", "placeholders": {} }, "weSentYouAnEmail": "Послали смо вам е-пошту", "@weSentYouAnEmail": { - "type": "text", + "type": "String", "placeholders": {} }, "whoCanPerformWhichAction": "ко може шта да ради", "@whoCanPerformWhichAction": { - "type": "text", + "type": "String", "placeholders": {} }, "whoIsAllowedToJoinThisGroup": "Ко може да се придружи групи", "@whoIsAllowedToJoinThisGroup": { - "type": "text", + "type": "String", "placeholders": {} }, "whyDoYouWantToReportThis": "Зашто желите ово да пријавите?", "@whyDoYouWantToReportThis": { - "type": "text", + "type": "String", "placeholders": {} }, "wipeChatBackup": "Да обришем резервну копију како би направио нови сигурносни кључ?", "@wipeChatBackup": { - "type": "text", + "type": "String", "placeholders": {} }, "withTheseAddressesRecoveryDescription": "Са овим адресама можете опоравити своју лозинку.", "@withTheseAddressesRecoveryDescription": { - "type": "text", + "type": "String", "placeholders": {} }, "writeAMessage": "напишите поруку…", "@writeAMessage": { - "type": "text", + "type": "String", "placeholders": {} }, "yes": "Да", "@yes": { - "type": "text", + "type": "String", "placeholders": {} }, "you": "Ви", "@you": { - "type": "text", + "type": "String", "placeholders": {} }, "youAreNoLongerParticipatingInThisChat": "Више не учествујете у овом ћаскању", "@youAreNoLongerParticipatingInThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "youHaveBeenBannedFromThisChat": "Забрањено вам је ово ћаскање", "@youHaveBeenBannedFromThisChat": { - "type": "text", + "type": "String", "placeholders": {} }, "yourPublicKey": "Ваш јавни кључ", "@yourPublicKey": { - "type": "text", + "type": "String", "placeholders": {} }, - "@hugContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@jumpToLastReadMessage": {}, - "@allRooms": { - "type": "text", - "placeholders": {} - }, - "@obtainingLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_cuddle": {}, - "@widgetVideo": {}, - "@dismiss": {}, - "@reportErrorDescription": {}, - "@addAccount": {}, - "@chatHasBeenAddedToThisSpace": {}, - "@unsupportedAndroidVersion": {}, - "@widgetJitsi": {}, - "@messageType": {}, - "@indexedDbErrorLong": {}, - "@oneClientLoggedOut": {}, - "@startFirstChat": {}, - "@callingAccount": {}, - "@setColorTheme": {}, - "@nextAccount": {}, - "@commandHint_create": { - "type": "text", - "description": "Usage hint for the command /create" - }, - "@allSpaces": {}, - "@supposedMxid": { - "type": "text", - "placeholders": { - "mxid": {} - } - }, - "@user": {}, - "@youAcceptedTheInvitation": {}, - "@noMatrixServer": { - "type": "text", - "placeholders": { - "server1": {}, - "server2": {} - } - }, - "@youInvitedBy": { - "placeholders": { - "user": {} - } - }, - "@banUserDescription": {}, - "@widgetEtherpad": {}, - "@removeDevicesDescription": {}, - "@separateChatTypes": { - "type": "text", - "placeholders": {} - }, - "@tryAgain": {}, - "@youKickedAndBanned": { - "placeholders": { - "user": {} - } - }, - "@unbanUserDescription": {}, - "@saveFile": { - "type": "text", - "placeholders": {} - }, - "@sendOnEnter": {}, - "@youRejectedTheInvitation": {}, - "@otherCallingPermissions": {}, - "@messagesStyle": {}, - "@link": {}, - "@widgetUrlError": {}, - "@emailOrUsername": {}, - "@newSpaceDescription": {}, - "@chatDescription": {}, - "@callingAccountDetails": {}, - "@enterSpace": {}, - "@encryptThisChat": {}, - "@previousAccount": {}, - "@reopenChat": {}, - "@pleaseEnterRecoveryKey": {}, - "@widgetNameError": {}, - "@addToBundle": {}, - "@spaceIsPublic": { - "type": "text", - "placeholders": {} - }, - "@addWidget": {}, - "@countFiles": { - "placeholders": { - "count": {} - } - }, - "@noKeyForThisMessage": {}, - "@shareLocation": { - "type": "text", - "placeholders": {} - }, - "@commandHint_markasgroup": {}, - "@errorObtainingLocation": { - "type": "text", - "placeholders": { - "error": {} - } - }, - "@hydrateTor": {}, - "@pushNotificationsNotAvailable": {}, - "@storeInAppleKeyChain": {}, - "@hydrate": {}, - "@invalidServerName": {}, - "@chatPermissions": {}, - "@cantOpenUri": { - "type": "text", - "placeholders": { - "uri": {} - } - }, - "@sender": {}, - "@storeInAndroidKeystore": {}, - "@signInWithPassword": {}, - "@makeAdminDescription": {}, - "@synchronizingPleaseWait": { - "type": "text", - "placeholders": {} - }, - "@commandHint_clearcache": { - "type": "text", - "description": "Usage hint for the command /clearcache" - }, - "@saveKeyManuallyDescription": {}, - "@editBundlesForAccount": {}, - "@whyIsThisMessageEncrypted": {}, - "@setChatDescription": {}, - "@spaceName": { - "type": "text", - "placeholders": {} - }, - "@importFromZipFile": {}, - "@dehydrateWarning": {}, - "@noOtherDevicesFound": {}, - "@yourChatBackupHasBeenSetUp": {}, - "@redactedBy": { - "type": "text", - "placeholders": { - "username": {} - } - }, - "@videoCallsBetaWarning": {}, - "@autoplayImages": { - "type": "text", - "placeholder": {} - }, - "@signInWith": { - "type": "text", - "placeholders": { - "provider": {} - } - }, - "@fileIsTooBigForServer": {}, - "@homeserver": {}, - "@repeatPassword": {}, - "@callingPermissions": {}, - "@readUpToHere": {}, - "@start": {}, - "@unlockOldMessages": {}, - "@numChats": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@optionalRedactReason": {}, - "@dehydrate": {}, - "@locationPermissionDeniedNotice": { - "type": "text", - "placeholders": {} - }, - "@sendAsText": { - "type": "text" - }, - "@archiveRoomDescription": {}, - "@exportEmotePack": {}, - "@sendSticker": { - "type": "text", - "placeholders": {} - }, - "@switchToAccount": { - "type": "number", - "placeholders": { - "number": {} - } - }, - "@commandInvalid": { - "type": "text" - }, - "@locationDisabledNotice": { - "type": "text", - "placeholders": {} - }, - "@experimentalVideoCalls": {}, - "@pleaseEnterRecoveryKeyDescription": {}, - "@openInMaps": { - "type": "text", - "placeholders": {} - }, - "@inviteContactToGroupQuestion": {}, - "@redactedByBecause": { - "type": "text", - "placeholders": { - "username": {}, - "reason": {} - } - }, - "@youHaveWithdrawnTheInvitationFor": { - "placeholders": { - "user": {} - } - }, - "@appearOnTopDetails": {}, - "@enterRoom": {}, - "@allChats": { - "type": "text", - "placeholders": {} - }, - "@reportUser": {}, - "@confirmEventUnpin": {}, - "@youInvitedUser": { - "placeholders": { - "user": {} - } - }, - "@fileHasBeenSavedAt": { - "type": "text", - "placeholders": { - "path": {} - } - }, - "@addToSpace": {}, - "@commandMissing": { - "type": "text", - "placeholders": { - "command": {} - }, - "description": "State that {command} is not a valid /command." - }, - "@redactMessageDescription": {}, - "@recoveryKey": {}, - "@commandHint_discardsession": { - "type": "text", - "description": "Usage hint for the command /discardsession" - }, - "@invalidInput": {}, - "@dehydrateTorLong": {}, - "@doNotShowAgain": {}, - "@report": {}, - "@unverified": {}, - "@serverRequiresEmail": {}, - "@hideUnimportantStateEvents": {}, - "@screenSharingTitle": {}, - "@widgetCustom": {}, - "@addToSpaceDescription": {}, - "@googlyEyesContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@youBannedUser": { - "placeholders": { - "user": {} - } - }, - "@addChatDescription": {}, - "@commandHint_myroomavatar": { - "type": "text", - "description": "Usage hint for the command /myroomavatar" - }, - "@hasKnocked": { - "placeholders": { - "user": {} - } - }, - "@publish": {}, - "@openLinkInBrowser": {}, - "@messageInfo": {}, - "@disableEncryptionWarning": {}, - "@directChat": {}, - "@wrongPinEntered": { - "type": "text", - "placeholders": { - "seconds": {} - } - }, - "@sendTypingNotifications": {}, - "@inviteGroupChat": {}, - "@appearOnTop": {}, - "@invitePrivateChat": {}, - "@foregroundServiceRunning": {}, - "@voiceCall": {}, - "@createNewSpace": { - "type": "text", - "placeholders": {} - }, - "@importEmojis": {}, - "@wasDirectChatDisplayName": { - "type": "text", - "placeholders": { - "oldDisplayName": {} - } - }, - "@noChatDescriptionYet": {}, - "@removeFromBundle": {}, - "@confirmMatrixId": {}, - "@learnMore": {}, - "@notAnImage": {}, - "@users": {}, - "@openGallery": {}, - "@chatDescriptionHasBeenChanged": {}, - "@newGroup": {}, - "@bundleName": {}, - "@dehydrateTor": {}, - "@removeFromSpace": {}, - "@roomUpgradeDescription": {}, - "@scanQrCode": {}, - "@pleaseEnterANumber": {}, - "@youKicked": { - "placeholders": { - "user": {} - } - }, - "@profileNotFound": {}, - "@jump": {}, - "@reactedWith": { - "type": "text", - "placeholders": { - "sender": {}, - "reaction": {} - } - }, - "@sorryThatsNotPossible": {}, - "@videoWithSize": { - "type": "text", - "placeholders": { - "size": {} - } - }, - "@shareInviteLink": {}, - "@commandHint_markasdm": {}, - "@recoveryKeyLost": {}, - "@cuddleContent": { - "type": "text", - "placeholders": { - "senderName": {} - } - }, - "@deviceKeys": {}, - "@emoteKeyboardNoRecents": { - "type": "text", - "placeholders": {} - }, - "@setTheme": {}, - "@youJoinedTheChat": {}, - "@openVideoCamera": { - "type": "text", - "placeholders": {} - }, - "@markAsRead": {}, - "@widgetName": {}, - "@errorAddingWidget": {}, - "@commandHint_dm": { - "type": "text", - "description": "Usage hint for the command /dm" - }, - "@commandHint_hug": {}, - "@replace": {}, - "@youUnbannedUser": { - "placeholders": { - "user": {} - } - }, - "@newSpace": {}, - "@emojis": {}, - "@commandHint_googly": {}, - "@pleaseTryAgainLaterOrChooseDifferentServer": {}, - "@createGroup": {}, - "@hydrateTorLong": {}, - "@time": {}, - "@custom": {}, - "@noBackupWarning": {}, - "@storeInSecureStorageDescription": {}, - "@openChat": {}, - "@kickUserDescription": {}, - "@importNow": {}, - "@pinMessage": {}, - "@invite": {}, - "@enableMultiAccounts": {}, - "@indexedDbErrorTitle": {}, - "@unsupportedAndroidVersionLong": {}, - "@storeSecurlyOnThisDevice": {}, - "@screenSharingDetail": {}, - "@placeCall": {} -} \ No newline at end of file + "repeatPassword": "Ponovite lozinku", + "@repeatPassword": {}, + "commandHint_cuddle": "Pošalji zagrljaj", + "@commandHint_cuddle": {} +} diff --git a/lib/l10n/intl_sv.arb b/lib/l10n/intl_sv.arb new file mode 100644 index 000000000..1256a6443 --- /dev/null +++ b/lib/l10n/intl_sv.arb @@ -0,0 +1,3001 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.835634", + "about": "Om", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Acceptera", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} accepterade inbjudan", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Konto", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} aktiverade ändpunktskryptering", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "alias", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Alla", + "@all": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} besvarade samtalet", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Vem som helst kan gå med", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "App-lås", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arkiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Får gästanvändare gå med", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Är du säker?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Är du säker på att du vill logga ut?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "För att kunna signera den andra personen, vänligen ange din lösenfras eller återställningsnyckel för säker lagring.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Acceptera denna verifikationsförfrågan från {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerVersionsException": "Hemservern stöjder Spec-versionen:\n{serverVersions}\nMen denna app stödjer enbart {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Bannlys från chatt", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Bannlyst", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} bannlös {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Blockera Enhet", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot meddelanden", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Avbryt", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Ändra enhetsnamn", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} ändrade sin chatt-avatar", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} ändrade chatt-beskrivningen till: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} ändrade sitt chatt-namn till: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} ändrade chatt-rättigheterna", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} ändrade visningsnamnet till: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} ändrade reglerna för gästaccess", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} ändrade reglerna för gästaccess till: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} ändrade historikens synlighet", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} ändrade historikens synlighet till: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} ändrade anslutningsreglerna", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} ändrade anslutningsreglerna till {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} ändrade sin avatar", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} ändrade rummets alias", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} ändrade inbjudningslänken", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Ändra lösenord", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Ändra hemserver", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Ändra din stil", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Ändra namn på gruppen", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Krypteringen har blivit korrupt", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Chatt", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Chatt-detaljer", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Välj ett starkt lösenord", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Stäng", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Vänligen jämför uttryckssymbolerna", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Vänligen jämför siffrorna", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Konfigurera chatt", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Bekräfta", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Anslut", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakten har blivit inbjuden till gruppen", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Innehåller visningsnamn", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Innehåller användarnamn", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Innehållet har rapporterats till server-admins", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Kopierat till urklipp", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopiera", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Kunde ej avkoda meddelande: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} deltagare", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Skapa", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} skapade chatten", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "För närvarande aktiv", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Mörkt", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Detta kommer att avaktivera ditt konto. Det här går inte att ångra! Är du säker?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Standard behörighetsnivå", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Radera", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Ta bort konto", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Ta bort meddelande", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Enhet", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Enhets-ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Enheter", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Direkt chatt", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Visningsnamn har ändrats", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Ladda ner fil", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Ändra", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "redigera blockerade servrar", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Ändra visningsnamn", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "redigera rumsavatar", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Dekalen existerar redan!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Ogiltig dekal-kod!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Dekalpaket för rummet", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emote inställningar", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Dekal kod", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Du måste välja en dekal-kod och en bild!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Tom chatt", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Aktivera dekal-paket globalt", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Aktivera kryptering", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Du kommer inte ha fortsatt möjlighet till att inaktivera krypteringen. Är du säker?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Krypterad", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Kryptering", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Kryptering är ej aktiverad", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} avslutade samtalet", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Ange en e-postaddress", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Ange din hemserver", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Extremt stötande", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Filnamn", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Framåt", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Från att gå med", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Från inbjudan", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Grupp", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Gruppen är publik", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Grupper", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Gruppen med {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Gäster är förbjudna", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Gäster kan ansluta", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} har tagit tillbaka inbjudan för {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Hjälp", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Göm redigerade händelser", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Göm okända händelser", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Hur stötande är detta innehåll?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Identitet", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Ignorera", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Ignorera användare", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Jag har klickat på länken", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Felaktig lösenordsfras eller åsterställningsnyckel", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Oförargligt", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Bjud in kontakt", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Bjud in kontakt till {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Inbjuden", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} bjöd in {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Endast inbjudna användare", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Inbjudning till mig", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} bjöd in dig till FluffyChat.\n1. Besök fluffychat.im och installera appen\n2. Registrera dig eller logga in\n3. Öppna inbjudningslänk:\n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "skriver…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} anslöt till chatten", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Anslut till rum", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} sparkade ut {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} sparkade och bannade {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Sparka från chatt", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Senast aktiv: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Lämna", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Lämnade chatten", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Licens", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Ljust", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Ladda {count} mer deltagare", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Laddar... Var god vänta.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Ladda mer…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Logga in", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Logga in till {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Logga ut", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Medlemsändringar", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Nämn", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Meddelanden", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Tysta chatt", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Var medveten om att du behöver Pantalaimon för att använda ändpunktskryptering tillsvidare.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Ny chatt", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Nya meddelanden i FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Ny verifikationsbegäran!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Nästa", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Nej", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Ingen anslutning till servern", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Hittade inga dekaler. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "De ser ut som att du inte har google-tjänster på din telefon. Det är ett bra beslut för din integritet! För att få aviseringar i FluffyChat rekommenderar vi att använda https://microg.org/ eller https://unifiedpush.org/ .", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Ingen", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Du har inte lagt till något sätt för att återställa ditt lösenord än.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Ingen behörighet", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Hittade inga rum…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Aviseringar", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Aviseringar är påslaget för detta konto", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} användare skriver…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offensive": "Stötande", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Offline", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "OK", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Online", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Online Nyckel-backup är aktiverad", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Hoppsan, något gick fel…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Öppna app för att lästa meddelanden", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Öppna kamera", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "participant": "Deltagare", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "lösenord eller återställningsnyckel", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Lösenord", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Glömt lösenord", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Lösenordet har ändrats", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Återställ lösenord", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Välj en bild", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Nåla fast", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "Spela {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChooseAPasscode": "Ange ett lösenord", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Klicka på länken i e-postmeddelandet för att sedan fortsätta.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Ange 4 siffror eller lämna tom för att inaktivera app-lås.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Ange ditt lösenord", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Ange ditt användarnamn", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Följ instruktionerna på hemsidan och tryck på nästa.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Integritet", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Publika Rum", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Regler", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Anledning", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Spelar in", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} redigerade en händelse", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Redigera meddelande", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "reject": "Avböj", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} avböjde inbjudan", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Återanslut", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Ta bort", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Ta bort alla andra enheter", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Bortagen av {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Ta bort enhet", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Ta bort chatt-blockering", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Ersätt rum med nyare version", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Svara", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Rapportera meddelande", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Begär behörighet", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Rummet har blivit uppgraderat", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "search": "Sök", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Säkerhet", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Sedd av {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Skicka", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Skicka ett meddelande", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Skicka ljud", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Skicka fil", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Skicka bild", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Skickade meddelanden", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Skicka orginal", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Skicka video", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} skickade en fil", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} skickade ett ljudklipp", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} skickade en bild", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} skickade ett klistermärke", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} skickade en video", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} skickade samtalsinformation", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setCustomEmotes": "Ställ in anpassade dekaler", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Ställ in inbjudningslänk", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Ställ in behörighetsnivå", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Ställ in status", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Inställningar", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Dela", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} delade sin position", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "skip": "Hoppa över", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Källkod", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} startade ett samtal", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Status", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Hur mår du i dag?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Skicka in", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "System", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Dom Matchar Inte", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Dom Matchar", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Växla favorit", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Växla tystad", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Markera läst/oläst", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "För många förfrågningar. Vänligen försök senare!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Försök att skicka igen", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Upptagen", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} avbannade {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Avblockera enhet", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Okänd enhet", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Okänd krypteringsalgoritm", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Okänd händelse '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Slå på ljudet för chatten", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Avnåla", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{en oläst chatt} other{{unreadCount} olästa chattar}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} och {count} andra skriver…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} och {username2} skriver…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} skriver…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} lämnade chatten", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Användarnamn", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} skickade en {type} händelse", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "Verifiera", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Starta verifiering", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Du har lyckats verifiera!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Verifiera andra konton", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Videosamtal", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Chatt-historikens synlighet", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Synlig för alla deltagare", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Synlig för alla", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Röstmeddelande", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Väntar på att deltagaren accepterar begäran…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Väntar på att deltagaren accepterar emojien…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Väntar på att deltagaren accepterar nummer…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Bakgrund:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Varning!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Vi skickade dig ett e-postmeddelande", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Vem kan utföra vilken åtgärd", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Vilka som är tilllåtna att ansluta till denna grupp", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Varför vill du rapportera detta?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Med dessa addresser kan du återställa ditt lösenord.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Skriv ett meddelande…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Ja", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Du", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Du deltar inte längre i denna chatt", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Du har blivit bannad från denna chatt", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Din publika nyckel", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "commandHint_html": "Skicka HTML-formatted text", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_ban": "Bannlys användaren från detta rum", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "clearArchive": "Rensa arkiv", + "chats": "Chatter", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Chatt har lagts till i detta utrymme", + "chatBackup": "Chatt backup", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Ändra din avatar", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "Kan inte öppna URL {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "blocked": "Blockerad", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "Hemma servern stödjer följande inloggnings typer :\n {serverVersions}\nMen denna applikation stödjer enbart:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "autoplayImages": "Automatisk spela upp animerade klistermärken och emoji", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "allChats": "Alla chattar", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Lägg till i utrymme", + "addEmail": "Lägg till e-post", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "commandHint_myroomavatar": "Sätt din bild för detta rum (by mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_me": "Beskriv dig själv", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_leave": "Lämna detta rum", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_kick": "Ta bort användare från detta rum", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_join": "Gå med i rum", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_invite": "Bjud in användaren till detta rum", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "locationPermissionDeniedNotice": "Plats åtkomst nekad. Var god godkän detta för att kunna dela din plats.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Platstjänster är inaktiverade. Var god aktivera dom för att kunna dela din plats.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Gå till det nya rummet", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Textstorlek", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Allt är klart!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Fel vid erhållande av plats: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "editRoomAliases": "Redigera rum alias", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Nytt utrymme", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Kopiera till urklipp", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "commandMissing": "{command} är inte ett kommando.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "commandInvalid": "Felaktigt kommando", + "@commandInvalid": { + "type": "String" + }, + "commandHint_unban": "Tillåt användare i rummet", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandHint_send": "Skicka text", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_react": "Skicka svar som reaktion", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_plain": "Skicka oformaterad text", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_op": "Sätt användarens kraft nivå ( standard: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_myroomnick": "Sätt ditt användarnamn för rummet", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "noEncryptionForPublicRooms": "Du kan endast aktivera kryptering när rummet inte längre är publikt tillgängligt.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} är inte en matrix server, använd {server2} istället?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "obtainingLocation": "Erhåller plats…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Var god välj", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "people": "Människor", + "@people": { + "type": "String", + "placeholders": {} + }, + "or": "Eller", + "@or": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Öppna i karta", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Oj! Tyvärr gick inte aviseringar att slå på.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Synkroniserar… Var god vänta.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Utrymmes namn", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Utrymme är publikt", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Visa lösenord", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Dela plats", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Sätt som primärt alias", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Skicka klistermärke", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Skicka som text", + "@sendAsText": { + "type": "String" + }, + "saveFile": "Spara fil", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Rum version", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Ta bort din avatar", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "register": "Registrera", + "@register": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Ange din pin-kod", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Radera din chatt-backup för att skapa en ny återställningsnyckel?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "verified": "Verifierad", + "@verified": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Överför till annan enhet", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Dina meddelanden är skyddad av en säkerhetsnyckel. Se till att du inte förlorar den.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "commandHint_create": "Skapa en tom grupp-chatt\nAnvänd --no-encryption för att inaktivera kryptering", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Kasta bort sessionen", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Starta en direkt-chatt\nAnvänd --no-encryption för att inaktivera kryptering", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "homeserver": "Hemserver", + "oneClientLoggedOut": "En av dina klienter har loggats ut", + "addAccount": "Lägg till konto", + "editBundlesForAccount": "Lägg till paket för detta konto", + "addToBundle": "Utöka paket", + "bundleName": "Paketnamn", + "serverRequiresEmail": "Servern behöver validera din e-postadress för registrering.", + "singlesignon": "Single Sign On", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "unverified": "Ej verifierad", + "messageInfo": "Meddelandeinformation", + "messageType": "Meddelandetyp", + "time": "Tid", + "sender": "Avsändare", + "removeFromSpace": "Ta bort från utrymme", + "addToSpaceDescription": "Välj ett utrymme som chatten skall läggas till i.", + "start": "Starta", + "openGallery": "Öppna galleri", + "repeatPassword": "Upprepa lösenord", + "markAsRead": "Markera som läst", + "commandHint_clearcache": "Rensa cache", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "openVideoCamera": "Aktivera kamera för video", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "link": "Länk", + "publish": "Publicera", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "reportUser": "Rapportera användare", + "openChat": "Öppna Chatt", + "sendOnEnter": "Skicka med Enter", + "scanQrCode": "Skanna QR-kod", + "yourChatBackupHasBeenSetUp": "Din chatt-backup har konfigurerats.", + "removeFromBundle": "Ta bort från paket", + "enableMultiAccounts": "(BETA) Aktivera multi-konton på denna enhet", + "emojis": "Uttryckssymboler", + "placeCall": "Ring", + "voiceCall": "Röstsamtal", + "unsupportedAndroidVersion": "Inget stöd för denna version av Android", + "videoCallsBetaWarning": "Videosamtal är för närvarande under testning. De kanske inte fungerar som det är tänkt eller på alla plattformar.", + "unsupportedAndroidVersionLong": "Denna funktion kräver en senare version av Android.", + "dismiss": "Avfärda", + "reactedWith": "{sender} reagerade med {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Fäst i rum", + "confirmEventUnpin": "Är du säker på att händelsen inte längre skall vara fastnålad?", + "experimentalVideoCalls": "Experimentella videosamtal", + "switchToAccount": "Byt till konto {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Nästa konto", + "previousAccount": "Föregående konto", + "emailOrUsername": "Användarnamn eller e-postadress", + "addWidget": "Lägg till widget", + "widgetVideo": "Video", + "widgetEtherpad": "Anteckning", + "widgetCustom": "Anpassad", + "widgetName": "Namn", + "widgetUrlError": "Detta är inte en giltig URL.", + "errorAddingWidget": "Ett fel uppstod när widgeten skulle läggas till.", + "widgetJitsi": "Jitsi-möte", + "widgetNameError": "Vänligen ange ett visningsnamn.", + "storeSecurlyOnThisDevice": "Lagra säkert på denna enhet", + "youJoinedTheChat": "Du gick med i chatten", + "youAcceptedTheInvitation": "👍 Du accepterade inbjudan", + "youKicked": "👞 Du sparkade ut {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hugContent": "{senderName} kramar dig", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "Märk som grupp", + "recoveryKeyLost": "Borttappad återställningsnyckel?", + "indexedDbErrorTitle": "Problem med privat läge", + "youHaveWithdrawnTheInvitationFor": "Du har återkallat inbjudan till {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Du återkallade förbudet för {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unlockOldMessages": "Lås upp äldre meddelanden", + "newSpace": "Nytt utrymme", + "googlyEyesContent": "{senderName} skickar dig googly ögon", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "dehydrate": "Exportera sessionen och rensa enheten", + "dehydrateWarning": "Denna åtgärd kan inte ångras. Försäkra dig om att backupen är i säkert förvar.", + "dehydrateTor": "TOR-användare: Exportera session", + "hydrateTor": "TOR-användare: Importera session från tidigare export", + "hydrateTorLong": "Exporterade du sessionen när du senast använde TOR? Importera den enkelt och fortsätt chatta.", + "recoveryKey": "Återställningsnyckel", + "separateChatTypes": "Separata direktchattar och grupper", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "startFirstChat": "Starta din första chatt", + "pleaseEnterRecoveryKeyDescription": "Ange din återställningsnyckel från en tidigare session för att låsa upp äldre meddelanden. Din återställningsnyckel är INTE ditt lösenord.", + "encryptThisChat": "Kryptera denna chatt", + "dehydrateTorLong": "TOR-användare rekommenderas att exportera sessionen innan fönstret stängs.", + "noBackupWarning": "Varning! Om du inte aktiverar säkerhetskopiering av chattar så tappar du åtkomst till krypterade meddelanden. Det är rekommenderat att du aktiverar säkerhetskopiering innan du loggar ut.", + "noOtherDevicesFound": "Inga andra enheter hittades", + "disableEncryptionWarning": "Av säkerhetsskäl kan du inte stänga av kryptering i en chatt där det tidigare aktiverats.", + "sorryThatsNotPossible": "Det där är inte möjligt", + "confirmMatrixId": "Bekräfta ditt Matrix-ID för att radera ditt konto.", + "supposedMxid": "Detta bör vara {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "pleaseEnterRecoveryKey": "Ange din återställningsnyckel:", + "commandHint_markasdm": "Märk som rum för direktmeddelanden för det givante Matrix ID", + "user": "Användare", + "indexedDbErrorLong": "Meddelandelagring är tyvärr inte aktiverat i privat läge som standard.\nGå till\n - about:config\n - sätt dom.indexedDB.privateBrowsing.enabled till true\nAnnars går det inte att använda FluffyChat.", + "storeInSecureStorageDescription": "Lagra återställningsnyckeln på säker plats på denna enhet.", + "storeInAppleKeyChain": "Lagra i Apples nyckelkedja (KeyChain)", + "foregroundServiceRunning": "Denna avisering visas när förgrundstjänsten körs.", + "custom": "Anpassad", + "countFiles": "{count} filer", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "screenSharingTitle": "skärmdelning", + "noKeyForThisMessage": "Detta kan hända om meddelandet skickades innan du loggade in på ditt konto i den här enheten.\n\nDet kan också vara så att avsändaren har blockerat din enhet eller att något gick fel med internetanslutningen.\n\nKan du läsa meddelandet i en annan session? I sådana fall kan du överföra meddelandet från den sessionen! Gå till Inställningar > Enhet och säkerställ att dina enheter har verifierat varandra. När du öppnar rummet nästa gång och båda sessionerna är i förgrunden, så kommer nycklarna att överföras automatiskt.\n\nVill du inte förlora nycklarna vid utloggning eller när du byter enhet? Säkerställ att du har aktiverat säkerhetskopiering för chatten i inställningarna.", + "fileIsTooBigForServer": "Gick inte att skicka! Servern stödjer endast bilagor upp till{max}.", + "deviceKeys": "Enhetsnycklar:", + "enterSpace": "Gå till utrymme", + "commandHint_googly": "Skicka några googly ögon", + "commandHint_cuddle": "Skicka en omfamning", + "commandHint_hug": "Skicka en kram", + "users": "Användare", + "cuddleContent": "{senderName} omfamnar dig", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hydrate": "Återställ från säkerhetskopia", + "screenSharingDetail": "Du delar din skärm i FluffyChat", + "youRejectedTheInvitation": "Du avvisade inbjudan", + "youBannedUser": "Du förbjöd {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Du har blivit inbjuden av {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Du bjöd in {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Du sparkade ut och förbjöd {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "saveKeyManuallyDescription": "Spara nyckeln manuellt genom att aktivera dela-funktionen eller urklippshanteraren på enheten.", + "storeInAndroidKeystore": "Lagra i Androids nyckellagring (KeyStore)", + "callingPermissions": "Samtalsbehörighet", + "callingAccount": "Samtalskonto", + "callingAccountDetails": "Tillåt FluffyChat att använda Androids ring-app.", + "appearOnTop": "Visa ovanpå", + "appearOnTopDetails": "Tillåt att appen visas ovanpå (behövs inte om du redan har FluffyChat konfigurerat som ett samtalskonto)", + "otherCallingPermissions": "Mikrofon, kamera och andra behörigheter för FluffyChat", + "whyIsThisMessageEncrypted": "Varför kan inte detta meddelande läsas?", + "newGroup": "Ny grupp", + "enterRoom": "Gå till rummet", + "allSpaces": "Alla utrymmen", + "numChats": "{number} chattar", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Göm oviktiga tillståndshändelser", + "doNotShowAgain": "Visa inte igen", + "wasDirectChatDisplayName": "Tom chatt (var {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "newSpaceDescription": "Utrymmen möjliggör konsolidering av chattar och att bygga privata eller offentliga gemenskaper.", + "reopenChat": "Återöppna chatt", + "jumpToLastReadMessage": "Hoppa till det senast lästa meddelandet", + "readUpToHere": "Läs upp till hit", + "fileHasBeenSavedAt": "Filen har sparats i {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "allRooms": "Alla gruppchattar", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "😭 Åh nej. Något gick fel. Om du vill ian du rapportera denna bugg till utvecklarna.", + "setColorTheme": "Välj färgtema:", + "banUserDescription": "Användaren kommer bannlysas från chatten och kommer inte kunna gå med i chatten igen tills bannlysningen avslutas.", + "removeDevicesDescription": "Du kommer att bli utloggad från den här enheten och kommer inte längre kunna få meddelanden.", + "tryAgain": "Försök igen", + "unbanUserDescription": "Användaren kommer kunna gå med i chatten igen om den försöker.", + "messagesStyle": "Meddelanden:", + "chatDescription": "Chattbeskrivning", + "pushNotificationsNotAvailable": "Aviseringar är inte tillgängligt", + "invalidServerName": "Ogiltigt servernamn", + "chatPermissions": "Chatt-behörigheter", + "signInWithPassword": "Logga in med lösenord", + "makeAdminDescription": "När du gör denna användare till administratör kommer du inte kunna ångra det eftersom de kommer ha samma behörigheter som du.", + "setChatDescription": "Ändra chattens beskrivning", + "importFromZipFile": "Importera från .zip-fil", + "redactedBy": "Borttaget av {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "signInWith": "Logga in med {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "optionalRedactReason": "(Frivilligt) Anledning till att ta bort det här meddelandet…", + "archiveRoomDescription": "Den här chatten kommer flyttas till arkivet. Andra användare kommer kunna se att du har lämnat chatten.", + "exportEmotePack": "Exportera Emote-pack som .zip", + "inviteContactToGroupQuestion": "Vill du bjuda in {contact} till chatten ”{groupName}”?", + "redactedByBecause": "Borttaget av {username} på grund av: ”{reason}”", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactMessageDescription": "Meddelandet kommer tas bort för alla medlemmar i denna konversation. Detta kan inte ångras.", + "invalidInput": "Ogiltig input!", + "report": "rapportera", + "addChatDescription": "Lägg till en chattbeskrivning…", + "hasKnocked": "{user} har knackat", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "openLinkInBrowser": "Öppna länk i webbläsare", + "directChat": "Direktchatt", + "wrongPinEntered": "Fel pin-kod inslagen! Försök igen om {seconds} sekunder…", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "sendTypingNotifications": "Skicka skrivnotifikationer", + "inviteGroupChat": "📨 Gruppchattsinbjudan", + "invitePrivateChat": "📨 Privat chattinbjudan", + "importEmojis": "Importera emojier", + "noChatDescriptionYet": "Ingen chatt-beskrivning än.", + "learnMore": "Lär dig mer", + "notAnImage": "Inte en bildfil.", + "chatDescriptionHasBeenChanged": "Chattbeskrivningen ändrades", + "roomUpgradeDescription": "Chatten kommer då att återskapas med den nya rumversionen. Alla medlemmar kommer bli påminda om att de måste byta till den nya chatten. Du kan läsa mer om rumversioner på https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Vänligen ange ett nummer större än 0", + "profileNotFound": "Användaren kunde onte hittas på servern. Kanske är det ett anslutningsproblem eller så finns inte användaren.", + "jump": "Hoppa", + "shareInviteLink": "Dela inbjudningslänk", + "emoteKeyboardNoRecents": "Nyligen använda emotes kommer dyka upp här…", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "setTheme": "Välj tema:", + "replace": "Ersätt", + "pleaseTryAgainLaterOrChooseDifferentServer": "Vänligen försök igen eller välj en annan server.", + "createGroup": "Skapa grupp", + "kickUserDescription": "Användaren sparkas ut ur chatten men bannlyses inte. I offentliga chattar kan användaren gå med igen när som helst.", + "importNow": "Importera nu", + "invite": "Bjud in", + "databaseBuildErrorBody": "Kan inte bygga SQlite-databasen. Appen försöker använda den gamla databasen för nu. Vänligen rapportera problemet till utvecklarna här: {url}. Felmeddelandet är: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "blockListDescription": "Du kan blockera användare som stör dig. Du kommer inte få några meddelanden eller rum-inbjudningar från användarna på din personliga blocklista.", + "createGroupAndInviteUsers": "Skapa en grupp och bjud in användare", + "initAppError": "Ett problem skedde när appen initierades", + "thisDevice": "Denna enhet:", + "startConversation": "Starta konversation", + "publicSpaces": "Offentliga utrymmen", + "blockedUsers": "Blockerade användare", + "passwordIsWrong": "Det angivna lösenordet är fel", + "pleaseEnterYourCurrentPassword": "Vänligen skriv ditt nuvarande lösenord", + "groupCanBeFoundViaSearch": "Gruppen kan hittas genom sökning", + "publicLink": "Offentlig länk", + "noUsersFoundWithQuery": "Tyvärr kunde ingen användare hittas med ”{query}”. Vänligen kontrollera om du gjort ett stavfel.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "block": "blockera", + "nothingFound": "Inget hittades…", + "yourGlobalUserIdIs": "Ditt globala användar-ID är: ", + "decline": "Neka", + "newPassword": "Nytt lösenord", + "passwordsDoNotMatch": "Lösenorden passar inte", + "commandHint_sendraw": "Skicka rå json", + "wrongRecoveryKey": "Tyvärr verkar detta inte vara den korrekta återställningsnyckeln.", + "subspace": "Underutrymme", + "select": "Ange val", + "sessionLostBody": "Din session är förlorad. Vänligen rapportera detta fel till utvecklarna här: {url}. Felmeddelandet är: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "pleaseChooseAStrongPassword": "Vänligen välj ett starkt lösenord", + "blockUsername": "Ignorera användarnamn", + "addChatOrSubSpace": "Lägg till chatt eller underutrymme", + "groupName": "Gruppnamn", + "leaveEmptyToClearStatus": "Lämna tom för att ta bort din status.", + "joinSpace": "Gå med i utrymme", + "searchForUsers": "Sök efter @användare…", + "restoreSessionBody": "Appen försöker nu få tillbaks din session från backupen. Vänligen rapportera detta problem till utvecklarna här: {url}. Felmeddelandet är: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "databaseMigrationTitle": "Databasen är optimerad", + "searchChatsRooms": "Sök efter #chattar, @användare…", + "databaseMigrationBody": "Var vänlig vänta. Detta kan ta en stund.", + "youInvitedToBy": "📩 Du har blivit inbjuden via länk till:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Andra deltagare i en diskussion kan se när du skriver.", + "formattedMessagesDescription": "Visa formaterat meddelandeinnehåll som fet stil med markdown.", + "verifyOtherUser": "🔐 Verifiera användaren", + "formattedMessages": "Formaterade meddelanden", + "canceledKeyVerification": "{sender} avbröt nyckelverifieringen", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} fullbordade nyckelverifieringen", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} begärde nyckelverifiering", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Transparent", + "startedKeyVerification": "{sender} påbörjade nyckelverifiering", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "presenceStyle": "Närvaro:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Visa statusmeddelanden från andra användare", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "hidePresences": "Dölj statuslista?", + "sendReadReceipts": "Skicka läskvitton", + "verifyOtherDevice": "🔐 Verifiera enhet", + "acceptedKeyVerification": "{sender} accepterade nyckelverifieringen", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "incomingMessages": "Inkommande meddelanden", + "forwardMessageTo": "Vidarebefordra meddelandet till {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "verifyOtherUserDescription": "Om du verifierar en användare så kan du vara säker på vem du verkligen skriver till. 💪\n\nNär du påbörjar en verifiering så ser du och den andra användaren en popup-ruta i appen. I den rutan ser du ett antal tecken som du jämför med vad den andra användaren ser.\n\nDet bästa sättet att göra detta är att träffas fysiskt, eller genom att starta ett videosamtal. 👭", + "verifyOtherDeviceDescription": "När du verifierar en enhet så kan era enheter utväxla nycklar, vilket förbättrar säkerheten. 💪 När du påbörjar en verifiering så ser du en popup-ruta på båda enheterna. I den rutan ser du ett antal tecken som du jämför med det som visas på den andra enheten. Det är bäst att ha båda enheterna till hands innan du påbörjar verifieringen. 🤳", + "isReadyForKeyVerification": "{sender} är redo för nyckelverifiering", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "Andra deltagare i en diskussion kan se när du läst ett meddelande.", + "stickers": "Klistermärken", + "discover": "Upptäck", + "ignoreUser": "Ignorera användare", + "normalUser": "Normal användare", + "aboutHomeserver": "Om{homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "commandHint_roomupgrade": "Uppgradera detta rum till den givna rumsversionen", + "appLockDescription": "Lås appen när den inte används med en pin-kod", + "swipeRightToLeftToReply": "Svep från höger till vänster för att svara", + "countChatsAndCountParticipants": "{chats} chattar och {participants} deltagare", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Inga fler chattar hittades...", + "noChatsFoundHere": "Inga chattar kunde hittas här ännu. Starta en ny chatt med någon genom att använda knappen nedan. ⤵️", + "unread": "Olästa", + "space": "Utrymme", + "spaces": "Utrymmen", + "changedTheChatDescription": "{username} ändrade chattens beskrivning", + "changedTheChatName": "{username} ändrade chattens namn", + "checkList": "Att-göra lista", + "countInvited": "{count} inbjudna", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "globalChatId": "Globalt chat-ID", + "accessAndVisibility": "Tillgänglighet och synlighet", + "accessAndVisibilityDescription": "Vem som är tillåten att gå med i chatten och hur chatten kan upptäckas.", + "calls": "Samtal", + "customEmojisAndStickers": "Egna emojis och klistermärken", + "customEmojisAndStickersBody": "Lägg till eller dela egna emojis eller klistermärken som kan användas i alla chattar.", + "setCustomPermissionLevel": "Ställ in särskild behörighetsnivå", + "alwaysUse24HourFormat": "falskt", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "setPermissionsLevelDescription": "Välj en fördefinierad roll nedan eller skriv in en särskild behörighetsnivå mellan 0 och 100.", + "joinedChats": "Anslutna chattar", + "hideRedactedMessages": "Dölj tillbakatagna meddelanden", + "hideRedactedMessagesBody": "Om någon tar tillbaka ett meddelande, kommer meddelandet inte längre vara synligt i chatten.", + "hideInvalidOrUnknownMessageFormats": "Dölj ogiltiga eller okända meddelande-format", + "hideMemberChangesInPublicChats": "Dölj användarändringar i offentliga chattar", + "hideMemberChangesInPublicChatsBody": "Visar inte om någon går med eller lämnar ett offentligt rum i chattens tidslinje för att öka läsbarheten.", + "overview": "Översikt", + "notifyMeFor": "Avisera mig för", + "passwordRecoverySettings": "Lösenordsåterställnings-inställningar", + "sendImages": "Skicka {count} bild", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "synchronizingPleaseWaitCounter": " Synkroniserar… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "invitedBy": "📩Inbjuden av{user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "usersMustKnock": "Användare måste knacka", + "noOneCanJoin": "Ingen kan gå med", + "userWouldLikeToChangeTheChat": "{user}vill gå med i chatten.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Ingen offentlig länk har skapats ännu", + "knock": "Knacka", + "knocking": "Knackar", + "chatCanBeDiscoveredViaSearchOnServer": "Chatten kan upptäckas via sökfunktionen på {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "publicChatAddresses": "Offentlig chatt-adress", + "createNewAddress": "Skapa ny adress", + "userRole": "Användarroll", + "searchIn": "Sök i chatten \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Sök mer...", + "gallery": "Galleri", + "files": "Filer", + "commandHint_ignore": "Ignorera det givna matrix-ID:et", + "commandHint_unignore": "Sluta ignorera det givna matrix-ID:et", + "unreadChatsInApp": "{appname}: {unread} olästa chattar", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "noDatabaseEncryption": "Databaskryptering stöds inte på denna platform", + "thereAreCountUsersBlocked": "Just nu är {count} användare blockade.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "Begränsad", + "knockRestricted": "Knacka begränsade", + "goToSpace": "Gå till utrymme:{space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Markera oläst", + "userLevel": "{level} - Användare", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Admin", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Ändra allmäna chatt-inställningar", + "inviteOtherUsers": "Bjud in andra användare till chatten", + "changeTheChatPermissions": "Ändra chattbehörigheterna", + "changeTheVisibilityOfChatHistory": "Ändra synligheten på chatt-historiken", + "changeTheCanonicalRoomAlias": "Ändra den huvudsakliga offenliga chatt-adressen", + "sendRoomNotifications": "Skicka en @rum notis", + "changeTheDescriptionOfTheGroup": "Ändra beskrivningen på chatten", + "chatPermissionsDescription": "Definiera vilket tillståndsnivå som krävs för vissa handlingar i chatten. Tillståndsnivåerna 0, 50 och 100 representerar ofta användare, moderatorer och admins, men vilken gradering som helst fungerar.", + "updateInstalled": "🎉 Uppdatering {version} installerad!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Ändringslogg", + "sendCanceled": "Skickande avbröts", + "loginWithMatrixId": "Logga in med Matrix-ID", + "discoverHomeservers": "Upptäck hemservrar", + "whatIsAHomeserver": "Vad är en hemserver?", + "homeserverDescription": "All din data lagras på hemservern, precis som en mailtjänst. Du kan välja vilken hemserver du vill använda, medans du fortfarande kan kommunicera med vemsomhelst. Lär dig met på https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Verkar inte vara en kompatibel hemserver. Fel URL?", + "calculatingFileSize": "Beräknar filstorlek...", + "prepareSendingAttachment": "Förbered skickar bilaga...", + "sendingAttachment": "Skickar bilaga...", + "generatingVideoThumbnail": "Genererar förhandsvisning...", + "compressVideo": "Komprimerar video...", + "sendingAttachmentCountOfCount": "Skickar bilaga {index} om {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Servergräns nådd! Väntar {seconds} sekunder...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "En av dina enheter är inte verifierade", + "noticeChatBackupDeviceVerification": "Notis: När du ansluter alla dina enheter till chatt-backupen, är de automatiskt verifierade.", + "continueText": "Fortsätt", + "welcomeText": "Hej Hej 👋 Det här är FluffyChat. Du kan logga in på vilken hemserver du vill, som är kompatibel med https://matrix.org. Och sen chatta med vemsomhelst. Det är ett enormt decentraliserat chatt-nätverk!", + "blur": "Blurra:", + "opacity": "Opacitet:", + "setWallpaper": "Ställ in bakgrundsbild", + "manageAccount": "Hantera konto", + "noContactInformationProvided": "Servern bistår inte med någon giltig kontaktinformation", + "contactServerAdmin": "Kontakta server-admin", + "contactServerSecurity": "Kontakta server-säkerheten", + "supportPage": "Stödsida", + "serverInformation": "Serverinformation:", + "name": "Namn", + "version": "Version", + "website": "Hemsida", + "compress": "Komprimera", + "boldText": "Fetstilt", + "italicText": "Kursiv", + "strikeThrough": "Genomstryk", + "pleaseFillOut": "Fyll i", + "invalidUrl": "Ogiltig url", + "addLink": "Lägg till länk", + "unableToJoinChat": "Kunde inte gå med i chatten. Kanske har den andra parten redan stängt konversationen.", + "previous": "Föregående", + "otherPartyNotLoggedIn": "Den andra parten är för närvarande inte inloggad, och kan därför inte ta emot meddelanden!", + "appWantsToUseForLogin": "Använd '{server}' för att logga in", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Du tillåter härmed appen och hemsidan att dela information om dig.", + "open": "Öppna", + "waitingForServer": "Väntar på server...", + "appIntroduction": "FluffyChat låter dig chatta med vänner över olika tjänster. Lär dig mer på https://matrix.org eller tryck *Fortsätt*.", + "newChatRequest": "📩 Ny chatt förfrågan", + "contentNotificationSettings": "Innehållsnotis-inställningar", + "generalNotificationSettings": "Allmänna notis-inställningar", + "roomNotificationSettings": "rumsnotis-inställningar", + "userSpecificNotificationSettings": "Användarspecifika notis-inställningar", + "otherNotificationSettings": "Andra notis-inställningar", + "notificationRuleContainsUserName": "Innehåller Användarnamn", + "notificationRuleContainsUserNameDescription": "Avisera användaren när ett meddelande innehåller deras användarnamn.", + "notificationRuleMaster": "Tysta alla notiser", + "notificationRuleMasterDescription": "Åsidosätter alla andra regler och tystar alla notiser.", + "notificationRuleMemberEvent": "Medlemshändelse", + "notificationRuleContainsDisplayName": "Innehåller visningsnamn", + "notificationRuleReaction": "Reaktion", + "notificationRuleCall": "Samtal", + "notificationRuleJitsi": "Jitsi", + "takeAPhoto": "Ta ett foto", + "recordAVideo": "Spela in en video", + "more": "Mer", + "allDevices": "Alla enheter", + "optionalMessage": "(Valfritt) meddelande ...", + "enterNewChat": "Gå med i ny chatt", + "approve": "Godkänn", + "customReaction": "Anpassad reaktion", + "moreEvents": "Fler händelser", + "noMessagesYet": "Inga meddelanden än", + "pause": "Pausa", + "resume": "Fortsätt", + "countChats": "{chats} chattar", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "donate": "Donera", + "answerOption": "Svarsalternativ", + "addAnswerOption": "Lägg till svarsalternativ", + "allowMultipleAnswers": "Tillåt flera svar", + "countVotes": "{count, plural, =1{En röst} other{{count} röster}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "replyInThread": "Svara i tråd", + "thread": "Tråd", + "countReplies": "{count, plural, =1{Ett svar} other{{count} svar}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "saveChanges": "Spara ändringar", + "loadingMessages": "Läser in meddelanden", + "noMoreResultsFound": "Inga fler resultat hittades", + "versionWithNumber": "Version: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Loggar", + "signIn": "Logga in", + "createNewAccount": "Skapa nytt konto" +} diff --git a/lib/l10n/intl_ta.arb b/lib/l10n/intl_ta.arb new file mode 100644 index 000000000..3484d7bc6 --- /dev/null +++ b/lib/l10n/intl_ta.arb @@ -0,0 +1,3380 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.826673", + "acceptedTheInvitation": "👍 {username} அழைப்பை ஏற்றுக்கொண்டது", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "accept": "ஏற்றுக்கொள்", + "@accept": { + "type": "String", + "placeholders": {} + }, + "about": "பற்றி", + "@about": { + "type": "String", + "placeholders": {} + }, + "sendCanceled": "அனுப்பப்பட்டது ரத்து செய்யப்பட்டது", + "@sendCanceled": {}, + "chatDetails": "அரட்டை விவரங்கள்", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "உலகளாவிய அரட்டை ஐடி", + "@globalChatId": {}, + "accessAndVisibility": "அணுகல் மற்றும் தெரிவுநிலை", + "@accessAndVisibility": {}, + "enterYourHomeserver": "உங்கள் ஓம்சர்வரை உள்ளிடவும்", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "நிகழ்நிலை விசை காப்புப்பிரதி இயக்கப்பட்டது", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "மீட்பு விசை", + "@recoveryKey": {}, + "setStatus": "நிலையை அமைக்கவும்", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "title": "பஞ்சுபோன்ற", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "verify": "சரிபார்க்கவும்", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "சரிபார்ப்பைத் தொடங்கவும்", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "unsupportedAndroidVersion": "ஆதரிக்கப்படாத ஆண்ட்ராய்டு பதிப்பு", + "@unsupportedAndroidVersion": {}, + "invitedBy": "{user} அழைத்தார்", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "startConversation": "உரையாடலைத் தொடங்குங்கள்", + "@startConversation": {}, + "commandHint_sendraw": "மூல சாதொபொகு ஐ அனுப்புங்கள்", + "@commandHint_sendraw": {}, + "passwordIsWrong": "நீங்கள் உள்ளிட்ட கடவுச்சொல் தவறு", + "@passwordIsWrong": {}, + "publicLink": "பொது இணைப்பு", + "@publicLink": {}, + "forwardMessageTo": "செய்தியை {roomName}க்கு அனுப்பவா?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} நிறைவு செய்யப்பட்ட விசை சரிபார்ப்பு", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "incomingMessages": "உள்வரும் செய்திகள்", + "@incomingMessages": {}, + "password": "கடவுச்சொல்", + "@password": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "வெற்று அரட்டை", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "encrypted": "குறியாக்கப்பட்டது", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "reject": "நிராகரிக்கவும்", + "@reject": { + "type": "String", + "placeholders": {} + }, + "importNow": "இப்போது இறக்குமதி செய்யுங்கள்", + "@importNow": {}, + "changedTheChatAvatar": "{username} அரட்டை அவதாரத்தை மாற்றியது", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "widgetName": "பெயர்", + "@widgetName": {}, + "chooseAStrongPassword": "வலுவான கடவுச்சொல்லைத் தேர்வுசெய்க", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "commandHint_me": "உங்களை விவரிக்கவும்", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_unban": "இந்த அறையிலிருந்து கொடுக்கப்பட்ட பயனரைத் தடுக்கிறது", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "countParticipants": "{count} பங்கேற்பாளர்கள்", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "editDisplayname": "காட்சி பெயர் திருத்து", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "fileName": "கோப்பு பெயர்", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{targetName} க்கான அழைப்பை {username} திரும்பப் பெற்றுள்ளார்", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "identity": "முற்றொருமை", + "@identity": { + "type": "String", + "placeholders": {} + }, + "removedBy": "{username} ஆல் அகற்றப்பட்டது", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "requestPermission": "இசைவு கோருங்கள்", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "user": "பயனர்", + "@user": {}, + "optionalRedactReason": "(விரும்பினால்) இந்த செய்தியை மாற்றியமைப்பதற்கான காரணம் ...", + "@optionalRedactReason": {}, + "device": "சாதனம்", + "@device": { + "type": "String", + "placeholders": {} + }, + "license": "உரிமம்", + "@license": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "குழுவிற்கு தொடர்பு அழைக்கப்பட்டுள்ளது", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "கடவுச்சொல் அல்லது மீட்பு விசை", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "widgetNameError": "காட்சி பெயரை வழங்கவும்.", + "@widgetNameError": {}, + "select": "தேர்ந்தெடு", + "@select": {}, + "compareEmojiMatch": "தயவுசெய்து ஈமோசிகளை ஒப்பிடுக", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "fromTheInvitation": "அழைப்பிலிருந்து", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "help": "உதவி", + "@help": { + "type": "String", + "placeholders": {} + }, + "invited": "அழைக்கப்பட்டார்", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUsersOnly": "பயனர்களை மட்டுமே அழைத்தது", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "kickedAndBanned": "🙅 {username} உதைத்து {targetName} ஐத் தடை செய்தார்", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "mention": "குறிப்பு", + "@mention": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "புதிய சரிபார்ப்பு கோரிக்கை!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "shareInviteLink": "இணைப்பைப் பகிரவும்", + "@shareInviteLink": {}, + "pickImage": "ஒரு படத்தைத் தேர்ந்தெடுக்கவும்", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "முள்", + "@pin": { + "type": "String", + "placeholders": {} + }, + "unavailable": "கிடைக்கவில்லை", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "voiceCall": "குரல் அழைப்பு", + "@voiceCall": {}, + "youKickedAndBanned": "🙅 நீங்கள் உதைத்து தடைசெய்துள்ளீர்கள் {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 {user}ஐ உதைத்துள்ளீர்கள்", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "storeInAppleKeyChain": "ஆப்பிள் கீச்சினில் சேமிக்கவும்", + "@storeInAppleKeyChain": {}, + "searchForUsers": "@Users ஐத் தேடுங்கள் ...", + "@searchForUsers": {}, + "pleaseEnterYourCurrentPassword": "உங்கள் தற்போதைய கடவுச்சொல்லை உள்ளிடவும்", + "@pleaseEnterYourCurrentPassword": {}, + "anyoneCanJoin": "யார் வேண்டுமானாலும் சேரலாம்", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "காப்பகம்", + "@archive": { + "type": "String", + "placeholders": {} + }, + "banFromChat": "அரட்டையிலிருந்து தடை", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "cancel": "ரத்துசெய்", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "edit": "தொகு", + "@edit": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "நான் இணைப்பைக் சொடுக்கு செய்துள்ளேன்", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "மின்னஞ்சலில் உள்ள இணைப்பைக் சொடுக்கு செய்து தொடரவும்.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "உங்கள் பாணியை மாற்றவும்", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "fontSize": "எழுத்துரு அளவு", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "யூரி {uri} வேலை ஐ திறக்க முடியாது", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "repeatPassword": "கடவுச்சொல்லை மீண்டும் செய்யவும்", + "@repeatPassword": {}, + "youRejectedTheInvitation": "நீங்கள் அழைப்பை நிராகரித்தீர்கள்", + "@youRejectedTheInvitation": {}, + "confirmMatrixId": "உங்கள் கணக்கை நீக்க உங்கள் மேட்ரிக்ச் ஐடியை உறுதிப்படுத்தவும்.", + "@confirmMatrixId": {}, + "supposedMxid": "இது {mxid} be ஆக இருக்க வேண்டும்", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_googly": "சில கூகிள் கண்களை அனுப்பவும்", + "@commandHint_googly": {}, + "commandHint_cuddle": "ஒரு கசப்பு அனுப்பவும்", + "@commandHint_cuddle": {}, + "startFirstChat": "உங்கள் முதல் அரட்டையைத் தொடங்கவும்", + "@startFirstChat": {}, + "importEmojis": "ஈமோசிகளை இறக்குமதி செய்யுங்கள்", + "@importEmojis": {}, + "exportEmotePack": "எமோட் பேக் .zip என ஏற்றுமதி செய்யுங்கள்", + "@exportEmotePack": {}, + "replace": "மாற்றவும்", + "@replace": {}, + "tryAgain": "மீண்டும் முயற்சிக்கவும்", + "@tryAgain": {}, + "pushNotificationsNotAvailable": "புச் அறிவிப்புகள் கிடைக்கவில்லை", + "@pushNotificationsNotAvailable": {}, + "blockUsername": "பயனர்பெயரை புறக்கணிக்கவும்", + "@blockUsername": {}, + "start": "தொடங்கு", + "@start": {}, + "chatBackup": "அரட்டை காப்புப்பிரதி", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "send": "அனுப்பு", + "@send": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "அவர்கள் பொருந்தவில்லை", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "செய்திகளை அனுப்பவும்", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "பஞ்சுபோன்ற", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "கோப்பைப் பதிவிறக்கவும்", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "புதிய இடம்", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "ஒத்திசைத்தல்… தயவுசெய்து காத்திருங்கள்.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "அறியப்படாத குறியாக்க வழிமுறை", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unverified": "சரிபார்க்கப்படாதது", + "@unverified": {}, + "unmuteChat": "மாறுதல் அரட்டை", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 unread chat} other{{unreadCount} unread chats}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "verifyTitle": "பிற கணக்கை சரிபார்க்கிறது", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "வீடியோ அழைப்பு", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "பங்கேற்பாளர்கள் அனைவருக்கும் தெரியும்", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "குரல் செய்தி", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "reopenChat": "அரட்டையை மீண்டும் திறக்கவும்", + "@reopenChat": {}, + "formattedMessages": "வடிவமைக்கப்பட்ட செய்திகள்", + "@formattedMessages": {}, + "darkTheme": "இருண்ட", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "guestsAreForbidden": "விருந்தினர்கள் தடைசெய்யப்பட்டுள்ளனர்", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "விருந்தினர்கள் சேரலாம்", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "widgetUrlError": "இது சரியான முகவரி அல்ல.", + "@widgetUrlError": {}, + "commandHint_invite": "கொடுக்கப்பட்ட பயனரை இந்த அறைக்கு அழைக்கவும்", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_op": "கொடுக்கப்பட்ட பயனரின் ஆற்றல் மட்டத்தை அமைக்கவும் (இயல்புநிலை: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "வடிவமைக்கப்படாத உரையை அனுப்பவும்", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandMissing": "{command} என்பது கட்டளை அல்ல.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "inviteForMe": "எனக்கு அழைக்கவும்", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "moderator": "மதிப்பீட்டாளர்", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "இருப்பிடத்தைப் பகிரவும்", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "addEmail": "மின்னஞ்சல் சேர்க்கவும்", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "all": "அனைத்தும்", + "@all": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "ஒளி", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "allChats": "அனைத்து அரட்டைகளும்", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Enter ஐ அனுப்பவும்", + "@sendOnEnter": {}, + "pleaseEnterRecoveryKey": "உங்கள் மீட்பு விசையை உள்ளிடவும்:", + "@pleaseEnterRecoveryKey": {}, + "dehydrate": "ஏற்றுமதி அமர்வு மற்றும் சாதனத்தை துடைக்கவும்", + "@dehydrate": {}, + "ok": "சரி", + "@ok": { + "type": "String", + "placeholders": {} + }, + "configureChat": "அரட்டையை உள்ளமைக்கவும்", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "deviceId": "சாதன ஐடி", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "isTyping": "தட்டச்சு செய்கிறது…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} அரட்டையில் சேர்ந்தார்", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "noConnectionToTheServer": "சேவையகத்துடன் எந்த தொடர்பும் இல்லை", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "உணர்ச்சிகள் எதுவும் காணப்படவில்லை. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "அறிவிப்புகள்", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "அச்சச்சோ! துரதிர்ச்டவசமாக, புச் அறிவிப்புகளை அமைக்கும் போது பிழை ஏற்பட்டது.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "அச்சச்சோ, ஏதோ தவறு நடந்தது…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "bundleName": "மூட்டை பெயர்", + "@bundleName": {}, + "enableMultiAccounts": "(பீட்டா) இந்த சாதனத்தில் பல கணக்குகளை இயக்கவும்", + "@enableMultiAccounts": {}, + "remove": "அகற்று", + "@remove": { + "type": "String", + "placeholders": {} + }, + "recoveryKeyLost": "மீட்பு விசை இழந்ததா?", + "@recoveryKeyLost": {}, + "sendAMessage": "ஒரு செய்தியை அனுப்பவும்", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "இடம் பொது", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "மற்றொரு சாதனத்திலிருந்து மாற்றவும்", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "அனைவருக்கும் தெரியும்", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "நாங்கள் உங்களுக்கு ஒரு மின்னஞ்சல் அனுப்பினோம்", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "enterRoom": "அறையை உள்ளிடவும்", + "@enterRoom": {}, + "report": "அறிக்கை", + "@report": {}, + "verifyOtherDevice": "Sevice பிற சாதனத்தை சரிபார்க்கவும்", + "@verifyOtherDevice": {}, + "startedACall": "{senderName} அழைப்பைத் தொடங்கினார்", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "toggleFavorite": "பிடித்ததை மாற்றவும்", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} ஒரு {type} நிகழ்வை அனுப்பியது", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "சரிபார்க்கப்பட்டது", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "நீங்கள் வெற்றிகரமாக சரிபார்த்தீர்கள்!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "பங்குதாரர் எண்களை ஏற்றுக்கொள்வதற்காக காத்திருக்கிறார்…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "warning": "எச்சரிக்கை!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "pinMessage": "அறைக்கு முள்", + "@pinMessage": {}, + "addWidget": "விட்செட்டைச் சேர்க்கவும்", + "@addWidget": {}, + "widgetEtherpad": "உரை குறிப்பு", + "@widgetEtherpad": {}, + "widgetCustom": "தனிப்பயன்", + "@widgetCustom": {}, + "unlockOldMessages": "பழைய செய்திகளைத் திறக்கவும்", + "@unlockOldMessages": {}, + "appearOnTop": "மேலே தோன்றும்", + "@appearOnTop": {}, + "serverLimitReached": "சேவையக வரம்பு அடைந்தது! {seconds} விநாடிகள் காத்திருக்கிறது ...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "acceptedKeyVerification": "{sender} ஏற்றுக்கொள்ளப்பட்ட விசை சரிபார்ப்பு", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "copyToClipboard": "இடைநிலைப்பலகைக்கு நகலெடுக்கவும்", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "createGroup": "குழுவை உருவாக்கவும்", + "@createGroup": {}, + "editBundlesForAccount": "இந்த கணக்கிற்கான மூட்டைகளைத் திருத்தவும்", + "@editBundlesForAccount": {}, + "seenByUser": "{username} ஆல் பார்த்தது", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "unpin": "மூள்நீக்கு", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "emojis": "ஈமோசிகள்", + "@emojis": {}, + "indexedDbErrorTitle": "தனியார் பயன்முறை சிக்கல்கள்", + "@indexedDbErrorTitle": {}, + "jumpToLastReadMessage": "கடைசி வாசிப்பு செய்திக்கு செல்லவும்", + "@jumpToLastReadMessage": {}, + "commandHint_markasgroup": "குழுவாக குறி", + "@commandHint_markasgroup": {}, + "commandHint_html": "உஉகுமொ வடிவமைக்கப்பட்ட உரையை அனுப்பவும்", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_kick": "இந்த அறையிலிருந்து கொடுக்கப்பட்ட பயனரை அகற்றவும்", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "deleteMessage": "செய்தியை நீக்கு", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "செய்தி தகவல்", + "@messageInfo": {}, + "sentAFile": "📁 {username} கோப்பை அனுப்பியுள்ளார்", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "videoWithSize": "வீடியோ ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "readUpToHere": "இங்கே படிக்கவும்", + "@readUpToHere": {}, + "chatDescriptionHasBeenChanged": "அரட்டை விளக்கம் மாற்றப்பட்டது", + "@chatDescriptionHasBeenChanged": {}, + "reportMessage": "செய்தி அறிக்கை", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "kickFromChat": "அரட்டையிலிருந்து கிக்", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "widgetVideo": "ஒளிதோற்றம்", + "@widgetVideo": {}, + "redactedAnEvent": "{username} ஒரு நிகழ்வை மறுவடிவமைத்தது", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "opacity": "ஒளிபுகாநிலை:", + "@opacity": {}, + "blur": "மங்கலானது:", + "@blur": {}, + "setWallpaper": "வால்பேப்பரை அமைக்கவும்", + "@setWallpaper": {}, + "statusExampleMessage": "இன்று நீங்கள் எப்படி இருக்கிறீர்கள்?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "மார்க் படிக்க/படிக்கவில்லை", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "பல கோரிக்கைகள். தயவுசெய்து பின்னர் மீண்டும் முயற்சிக்கவும்!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "unblockDevice": "சாதனத்தைத் தடைசெய்க", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "தெரியாத சாதனம்", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "addToSpaceDescription": "இந்த அரட்டையைச் சேர்க்க ஒரு இடத்தைத் தேர்ந்தெடுக்கவும்.", + "@addToSpaceDescription": {}, + "errorAddingWidget": "விட்செட்டைச் சேர்ப்பதில் பிழை.", + "@errorAddingWidget": {}, + "youInvitedToBy": "In இணைப்பு வழியாக நீங்கள் அழைக்கப்பட்டுள்ளீர்கள்:\n {alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "storeSecurlyOnThisDevice": "இந்த சாதனத்தில் பாதுகாப்பாக சேமிக்கவும்", + "@storeSecurlyOnThisDevice": {}, + "screenSharingTitle": "திரை பகிர்வு", + "@screenSharingTitle": {}, + "appearOnTopDetails": "பயன்பாடு மேலே தோன்ற அனுமதிக்கிறது (நீங்கள் ஏற்கனவே ஒரு அழைப்பு கணக்காக பஞ்சுபோன்ற அமைப்பைக் கொண்டிருந்தால் தேவையில்லை)", + "@appearOnTopDetails": {}, + "newGroup": "புதிய குழு", + "@newGroup": {}, + "noOtherDevicesFound": "வேறு சாதனங்கள் எதுவும் கிடைக்கவில்லை", + "@noOtherDevicesFound": {}, + "sendRoomNotifications": "ஒரு @ROOM அறிவிப்புகளை அனுப்பவும்", + "@sendRoomNotifications": {}, + "generatingVideoThumbnail": "வீடியோ சிறு உருவத்தை உருவாக்குதல் ...", + "@generatingVideoThumbnail": {}, + "reply": "பதில்", + "@reply": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "மற்ற நபரில் கையெழுத்திட, தயவுசெய்து உங்கள் பாதுகாப்பான கடை பாச்ஃபிரேச் அல்லது மீட்பு விசையை உள்ளிடவும்.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "விருந்தினர் பயனர்கள் சேர அனுமதிக்கப்படுகிறார்களா", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "நீங்கள் நிச்சயமாக வெளியேற விரும்புகிறீர்களா?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "aboutHomeserver": "{homeserver} பற்றி", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "swipeRightToLeftToReply": "பதிலளிக்க வலமிருந்து இடமாக ச்வைப் செய்யவும்", + "@swipeRightToLeftToReply": {}, + "unread": "படிக்காதது", + "@unread": {}, + "changedTheChatDescriptionTo": "{username} பயனர்பெயர் the அரட்டை விளக்கத்தை மாற்றியது: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "deleteAccount": "கணக்கை நீக்கு", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deviceKeys": "சாதன விசைகள்:", + "@deviceKeys": {}, + "noUsersFoundWithQuery": "துரதிர்ச்டவசமாக \"{query}\" உடன் எந்த பயனரையும் காண முடியவில்லை. நீங்கள் ஒரு எழுத்துப்பிழை செய்தீர்களா என்பதை சரிபார்க்கவும்.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "jump": "தாவு", + "@jump": {}, + "yourGlobalUserIdIs": "உங்கள் உலகளாவிய பயனர் ஐடி: ", + "@yourGlobalUserIdIs": {}, + "publicSpaces": "பொது இடங்கள்", + "@publicSpaces": {}, + "discover": "கண்டுபிடி", + "@discover": {}, + "commandHint_unignore": "கொடுக்கப்பட்ட மேட்ரிக்ச் ஐடியை இணைக்கவும்", + "@commandHint_unignore": {}, + "prepareSendingAttachment": "அனுப்பும் இணைப்பைத் தயாரிக்கவும் ...", + "@prepareSendingAttachment": {}, + "sendingAttachment": "இணைப்பை அனுப்புகிறது ...", + "@sendingAttachment": {}, + "continueText": "தொடரவும்", + "@continueText": {}, + "welcomeText": "ஏய் ஏய் 👋 இது பஞ்சுபோன்றது. Https://matrix.org உடன் இணக்கமான எந்த ஓம்சர்வரில் நீங்கள் உள்நுழையலாம். பின்னர் யாருடனும் அரட்டையடிக்கவும். இது ஒரு பெரிய பரவலாக்கப்பட்ட செய்தியிடல் நெட்வொர்க்!", + "@welcomeText": {}, + "name": "பெயர்", + "@name": {}, + "username": "பயனர்பெயர்", + "@username": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "எந்த செயலைச் செய்ய முடியும்", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "இந்த குழுவில் சேர யார் அனுமதிக்கப்படுகிறார்கள்", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "இந்த அரட்டையில் நீங்கள் இனி பங்கேற்கவில்லை", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "உங்கள் பொது விசை", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "time": "நேரம்", + "@time": {}, + "publish": "வெளியிடுங்கள்", + "@publish": {}, + "openChat": "திறந்த அரட்டை", + "@openChat": {}, + "markAsRead": "படித்தபடி குறி", + "@markAsRead": {}, + "reportUser": "பயனர் புகாரளிக்கவும்", + "@reportUser": {}, + "dismiss": "தள்ளுபடி", + "@dismiss": {}, + "reactedWith": "{sender} {reaction} உடன் பதிலளித்தார்", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "placeCall": "அழைப்பு இடு", + "@placeCall": {}, + "videoCallsBetaWarning": "வீடியோ அழைப்புகள் தற்போது பீட்டாவில் உள்ளன என்பதை நினைவில் கொள்க. அவர்கள் எதிர்பார்த்தபடி வேலை செய்யக்கூடாது அல்லது எல்லா தளங்களிலும் வேலை செய்யக்கூடாது.", + "@videoCallsBetaWarning": {}, + "experimentalVideoCalls": "சோதனை வீடியோ அழைப்புகள்", + "@experimentalVideoCalls": {}, + "emailOrUsername": "மின்னஞ்சல் அல்லது பயனர்பெயர்", + "@emailOrUsername": {}, + "previousAccount": "முந்தைய கணக்கு", + "@previousAccount": {}, + "noOneCanJoin": "யாரும் சேர முடியாது", + "@noOneCanJoin": {}, + "userWouldLikeToChangeTheChat": "{user} அரட்டையில் சேர விரும்புகிறார்.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "newSpace": "புதிய இடம்", + "@newSpace": {}, + "enterSpace": "இடத்தை உள்ளிடவும்", + "@enterSpace": {}, + "wasDirectChatDisplayName": "வெற்று அரட்டை ({oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "openLinkInBrowser": "உலாவியில் திறந்த இணைப்பை திறக்கவும்", + "@openLinkInBrowser": {}, + "reportErrorDescription": "😭 ஓ இல்லை. ஏதோ தவறு நடந்தது. நீங்கள் விரும்பினால், இந்த பிழையை டெவலப்பர்களிடம் புகாரளிக்கலாம்.", + "@reportErrorDescription": {}, + "setTheme": "கருப்பொருள் அமைக்கவும்:", + "@setTheme": {}, + "invite": "அழைக்கவும்", + "@invite": {}, + "wrongPinEntered": "தவறான முள் நுழைந்தது! {seconds} விநாடிகளில் மீண்டும் முயற்சிக்கவும் ...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pleaseEnterANumber": "தயவுசெய்து 0 ஐ விட அதிகமான எண்ணை உள்ளிடவும்", + "@pleaseEnterANumber": {}, + "kickUserDescription": "பயனர் அரட்டையிலிருந்து வெளியேற்றப்படுகிறார், ஆனால் தடை செய்யப்படவில்லை. பொது அரட்டைகளில், பயனர் எந்த நேரத்திலும் மீண்டும் சேரலாம்.", + "@kickUserDescription": {}, + "learnMore": "மேலும் அறிக", + "@learnMore": {}, + "chatCanBeDiscoveredViaSearchOnServer": "{server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "knockRestricted": "நாக் தடை", + "@knockRestricted": {}, + "bannedUser": "{username} தடைசெய்யப்பட்ட {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "தொகுதி சாதனம்", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "தடுக்கப்பட்டது", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "சாதனத்தின் பெயரை மாற்றவும்", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheDisplaynameTo": "{username} அவற்றின் காட்சி பெயர்: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} விருந்தினர் அணுகல் விதிகளை மாற்றியது", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} அவர்களின் அவதாரத்தை மாற்றியது", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} அறை மாற்றுப்பெயர்களை மாற்றியது", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeTheNameOfTheGroup": "குழுவின் பெயரை மாற்றவும்", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "chats": "அரட்டைகள்", + "@chats": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "தெளிவான காப்பகம்", + "@clearArchive": {}, + "close": "மூடு", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_create": "வெற்று குழு அரட்டையை உருவாக்கவும்\n குறியாக்கத்தை முடக்க-இல்லை-குறியாக்கத்தைப் பயன்படுத்தவும்", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "compareNumbersMatch": "எண்களை ஒப்பிடுக", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "connect": "இணை", + "@connect": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "பயனர்பெயர் உள்ளது", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "இடைநிலைப்பலகைக்கு நகலெடுக்கப்பட்டது", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "நகலெடு", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "செய்தியை மறைகுறியாக்க முடியவில்லை: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "create": "உருவாக்கு", + "@create": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "அரட்டை அனுமதிகள்", + "@chatPermissions": {}, + "editRoomAliases": "அறை மாற்றுப்பெயர்களைத் திருத்து", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "அறை அவதார் திருத்து", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "forward": "முன்னோக்கி", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "சேருவதிலிருந்து", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "groupWith": "{displayname} உடன் குழு", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "hideRedactedMessages": "சரிசெய்யப்பட்ட செய்திகளை மறைக்கவும்", + "@hideRedactedMessages": {}, + "hideRedactedMessagesBody": "யாராவது ஒரு செய்தியை மாற்றியமைத்தால், இந்த செய்தி இனி அரட்டையில் காணப்படாது.", + "@hideRedactedMessagesBody": {}, + "howOffensiveIsThisContent": "இந்த உள்ளடக்கம் எவ்வளவு ஆபத்தானது?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "செயலற்றது", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "தொடர்பை அழைக்கவும்", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} {targetName} ஐ உதைத்தார்", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "lastActiveAgo": "கடைசியாக செயலில்: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leftTheChat": "அரட்டையை விட்டு வெளியேறினார்", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "ஏற்றவும் {count} மேலும் பங்கேற்பாளர்கள்", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrateWarning": "இந்த செயலை செயல்தவிர்க்க முடியாது. காப்புப்பிரதி கோப்பை பாதுகாப்பாக சேமித்து வைக்கவும்.", + "@dehydrateWarning": {}, + "dehydrateTor": "டோர் பயனர்கள்: ஏற்றுமதி அமர்வு", + "@dehydrateTor": {}, + "hydrateTor": "டோர் பயனர்கள்: இறக்குமதி அமர்வு ஏற்றுமதி", + "@hydrateTor": {}, + "loadMore": "மேலும் ஏற்றவும்…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "logout": "வெளியேற்றம்", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "உறுப்பினர் மாற்றங்கள்", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "messagesStyle": "செய்திகள்:", + "@messagesStyle": {}, + "needPantalaimonWarning": "இப்போதைக்கு இறுதி முதல் இறுதி குறியாக்கத்தைப் பயன்படுத்த உங்களுக்கு பாண்டலாயமன் தேவை என்பதை நினைவில் கொள்க.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "Fuf பஞ்சுபோன்ற புதிய செய்தி", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "அறை இனி பகிரங்கமாக அணுக முடியாதவுடன் மட்டுமே நீங்கள் குறியாக்கத்தை செயல்படுத்த முடியும்.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} என்பது மேட்ரிக்ஸ் சர்வர் இல்லை, அதற்கு பதிலாக {server2} ஐ பயன்படுத்தவா?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "noPermission": "இசைவு இல்லை", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "அறைகள் எதுவும் கிடைக்கவில்லை…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "இந்த கணக்கிற்கு அறிவிப்புகள் இயக்கப்பட்டன", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} பயனர்கள் தட்டச்சு செய்கிறார்கள்…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offensive": "தாக்குதல்", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "openCamera": "திறந்த கேமரா", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "வீடியோவுக்கு கேமரா திறக்கவும்", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "addAccount": "கணக்கைச் சேர்க்கவும்", + "@addAccount": {}, + "openInMaps": "வரைபடங்களில் திறந்திருக்கும்", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "link": "இணைப்பு", + "@link": {}, + "serverRequiresEmail": "இந்த சேவையகம் பதிவுக்கு உங்கள் மின்னஞ்சல் முகவரியை சரிபார்க்க வேண்டும்.", + "@serverRequiresEmail": {}, + "passwordForgotten": "கடவுச்சொல் மறந்துவிட்டது", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "கடவுச்சொல் மாற்றப்பட்டுள்ளது", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "பாச் குறியீட்டைத் தேர்வுசெய்க", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "பொது அறைகள்", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "மற்ற எல்லா சாதனங்களையும் அகற்றவும்", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "அறை மேம்படுத்தப்பட்டுள்ளது", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "அறை பதிப்பு", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "கோப்பை சேமி", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "sentAnAudio": "🎤 {username} ஆடியோவை அனுப்பியுள்ளார்", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} படத்தை அனுப்பியுள்ளார்", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} ஒரு வீடியோவை அனுப்பியுள்ளார்", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "setPermissionsLevel": "இசைவு அளவை அமைக்கவும்", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "settings": "அமைப்புகள்", + "@settings": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} அவற்றின் இருப்பிடத்தைப் பகிர்ந்து கொண்டது", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "showPassword": "கடவுச்சொல்லைக் காட்டு", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "submit": "சமர்ப்பிக்கவும்", + "@submit": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "மீண்டும் அனுப்ப முயற்சிக்கவும்", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "sendTypingNotifications": "தட்டச்சு அறிவிப்புகளை அனுப்பவும்", + "@sendTypingNotifications": {}, + "enterAnEmailAddress": "மின்னஞ்சல் முகவரியை உள்ளிடவும்", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "blockListDescription": "உங்களை தொந்தரவு செய்யும் பயனர்களைத் தடுக்கலாம். உங்கள் தனிப்பட்ட தொகுதி பட்டியலில் பயனர்களிடமிருந்து எந்த செய்திகளையும் அல்லது அறை அழைப்புகளையும் நீங்கள் பெற முடியாது.", + "@blockListDescription": {}, + "incorrectPassphraseOrKey": "தவறான கடவுச்சொல் அல்லது மீட்பு விசை", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "loadingPleaseWait": "ஏற்றுகிறது… தயவுசெய்து காத்திருங்கள்.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "no": "இல்லை", + "@no": { + "type": "String", + "placeholders": {} + }, + "people": "மக்கள்", + "@people": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "இந்த அரட்டையிலிருந்து உங்களுக்கு தடை விதிக்கப்பட்டுள்ளது", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "messageType": "செய்தி வகை", + "@messageType": {}, + "databaseMigrationTitle": "தரவுத்தளம் உகந்ததாக உள்ளது", + "@databaseMigrationTitle": {}, + "usersMustKnock": "பயனர்கள் தட்ட வேண்டும்", + "@usersMustKnock": {}, + "allSpaces": "அனைத்து இடங்களும்", + "@allSpaces": {}, + "importFromZipFile": ".Zip கோப்பிலிருந்து இறக்குமதி செய்யுங்கள்", + "@importFromZipFile": {}, + "activatedEndToEndEncryption": "{username} இறுதி குறியாக்கத்திற்கு செயல்படுத்தப்பட்ட முடிவு", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addChatDescription": "அரட்டை விளக்கத்தைச் சேர்க்கவும் ...", + "@addChatDescription": {}, + "addToSpace": "விண்வெளியில் சேர்க்கவும்", + "@addToSpace": {}, + "commandHint_hug": "கட்டிப்பிடிக்கவும்", + "@commandHint_hug": {}, + "cuddleContent": "{senderName} பெயர் you உங்களை கசக்குகிறது", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} உங்களை அணைத்துக்கொள்கிறது", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "appLock": "பயன்பாட்டு பூட்டு", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "முள் குறியீட்டைக் கொண்டு பயன்படுத்தாதபோது பயன்பாட்டைப் பூட்டவும்", + "@appLockDescription": {}, + "googlyEyesContent": "{senderName} உங்களுக்கு கூகிள் கண்களை அனுப்புகிறது", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "areYouSure": "நீங்கள் உறுதியாக இருக்கிறீர்களா?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "{username}பயனர்பெயர் இருந்து இலிருந்து இந்த சரிபார்ப்பு கோரிக்கையை ஏற்றுக்கொள்ளவா?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "அனிமேசன் செய்யப்பட்ட ச்டிக்கர்கள் மற்றும் உணர்ச்சிகளை தானாக இயக்கவும்", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "உள்நாட்டு வகைகளை ஓம்சர்வர் ஆதரிக்கிறது:\n {serverVersions}\n ஆனால் இந்த பயன்பாடு மட்டுமே ஆதரிக்கிறது:\n {supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "ஓம்சர்வர் ச்பெக் பதிப்புகளை ஆதரிக்கிறது:\n {serverVersions}\n ஆனால் இந்த பயன்பாடு {supportedVersions} மட்டுமே ஆதரிக்கிறது", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "noChatsFoundHere": "இங்கே அரட்டைகள் எதுவும் காணப்படவில்லை. கீழே உள்ள பொத்தானைப் பயன்படுத்தி ஒருவருடன் புதிய அரட்டையைத் தொடங்கவும். ⤵️", + "@noChatsFoundHere": {}, + "space": "இடைவெளி", + "@space": {}, + "banned": "தடைசெய்யப்பட்டது", + "@banned": { + "type": "String", + "placeholders": {} + }, + "botMessages": "போட் செய்திகள்", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "changedTheChatNameTo": "{username} அரட்டை பெயரை மாற்றியது: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} வரலாற்று தெரிவுநிலையை மாற்றியது: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} சேர விதிகளை மாற்றியது", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} சேர விதிகளை மாற்றியது: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} அழைப்பிதழ் இணைப்பை மாற்றியது", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "கடவுச்சொல்லை மாற்றவும்", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "ஓம்சர்வரை மாற்றவும்", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "உங்கள் அவதாரத்தை மாற்றவும்", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "குறியாக்கம் சிதைந்துள்ளது", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "அரட்டை", + "@chat": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "உங்கள் அரட்டை காப்புப்பிரதி அமைக்கப்பட்டுள்ளது.", + "@yourChatBackupHasBeenSetUp": {}, + "chatBackupDescription": "உங்கள் பழைய செய்திகள் மீட்பு விசையுடன் பாதுகாக்கப்படுகின்றன. நீங்கள் அதை இழக்கவில்லை என்பதை உறுதிப்படுத்திக் கொள்ளுங்கள்.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "இந்த இடத்தில் அரட்டை சேர்க்கப்பட்டுள்ளது", + "@chatHasBeenAddedToThisSpace": {}, + "commandHint_markasdm": "கொடுக்கப்பட்ட மேட்ரிக்சிற்கான நேரடி செய்தி அறையாக குறிக்கவும்", + "@commandHint_markasdm": {}, + "commandHint_ban": "கொடுக்கப்பட்ட பயனரை இந்த அறையிலிருந்து தடை செய்யுங்கள்", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "தெளிவான தற்காலிக சேமிப்பு", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_discardsession": "அமர்வை நிராகரிக்கவும்", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_myroomavatar": "இந்த அறைக்கு உங்கள் படத்தை அமைக்கவும் (MXC-URI எழுதியது)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "இந்த அறைக்கு உங்கள் காட்சி பெயரை அமைக்கவும்", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandInvalid": "கட்டளை தவறானது", + "@commandInvalid": { + "type": "String" + }, + "confirm": "உறுதிப்படுத்தவும்", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "உள்ளடக்கம் சேவையக நிர்வாகிகளுக்கு தெரிவிக்கப்பட்டுள்ளது", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} அரட்டையை உருவாக்கினார்", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "தற்போது செயலில் உள்ளது", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "இது உங்கள் பயனர் கணக்கை செயலிழக்கச் செய்யும். இதை செயல்தவிர்க்க முடியாது! நீங்கள் உறுதியாக இருக்கிறீர்களா?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "புதிய பயனர்களுக்கான இயல்புநிலை இசைவு நிலை", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "நீக்கு", + "@delete": { + "type": "String", + "placeholders": {} + }, + "devices": "சாதனங்கள்", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "நேரடி அரட்டைகள்", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "allRooms": "அனைத்து குழு அரட்டைகளும்", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "காட்சி பெயர் மாற்றப்பட்டுள்ளது", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "தடுக்கப்பட்ட சேவையகங்களைத் திருத்து", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "எமோட் ஏற்கனவே உள்ளது!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "தவறான எமோட் சார்ட்கோட்!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteKeyboardNoRecents": "அண்மைக் காலத்தில் பயன்படுத்தப்பட்ட உணர்ச்சிகள் இங்கே தோன்றும் ...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "அறைக்கு எமோட் பொதிகள்", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "எமோட் அமைப்புகள்", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "accessAndVisibilityDescription": "இந்த அரட்டையில் யார் சேர அனுமதிக்கப்படுகிறார்கள், அரட்டையை எவ்வாறு கண்டுபிடிப்பது.", + "@accessAndVisibilityDescription": {}, + "calls": "அழைப்புகள்", + "@calls": {}, + "customEmojisAndStickers": "தனிப்பயன் ஈமோசிகள் மற்றும் ச்டிக்கர்கள்", + "@customEmojisAndStickers": {}, + "customEmojisAndStickersBody": "எந்தவொரு அரட்டையிலும் பயன்படுத்தக்கூடிய தனிப்பயன் ஈமோசிகள் அல்லது ச்டிக்கர்களைச் சேர்க்கவும் அல்லது பகிரவும்.", + "@customEmojisAndStickersBody": {}, + "emoteShortcode": "சார்ட்கோட் எமோட்", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "நீங்கள் ஒரு எமோட் சார்ட்கோட் மற்றும் ஒரு படத்தை எடுக்க வேண்டும்!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "உலகளவில் எமோட் பேக்கை இயக்கவும்", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "குறியாக்கத்தை இயக்கவும்", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "நீங்கள் இனி குறியாக்கத்தை முடக்க முடியாது. நீங்கள் உறுதியாக இருக்கிறீர்களா?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "குறியாக்கம் இயக்கப்படவில்லை", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "encryption": "குறியாக்கம்", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} அழைப்பை முடித்தார்", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "homeserver": "ஓம்சர்வர்", + "@homeserver": {}, + "errorObtainingLocation": "இருப்பிடத்தைப் பெறுவதில் பிழை: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "எல்லாம் தயாராக!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "மிகவும் தாக்குதல்", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "புதிய அறைக்குச் செல்லுங்கள்", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "குழு", + "@group": { + "type": "String", + "placeholders": {} + }, + "chatDescription": "அரட்டை விளக்கம்", + "@chatDescription": {}, + "groupIsPublic": "குழு பொது", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "திருத்தப்பட்ட நிகழ்வுகளை மறைக்கவும்", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideInvalidOrUnknownMessageFormats": "தவறான அல்லது அறியப்படாத செய்தி வடிவங்களை மறைக்கவும்", + "@hideInvalidOrUnknownMessageFormats": {}, + "id": "ஐடி", + "@id": { + "type": "String", + "placeholders": {} + }, + "block": "தொகுதி", + "@block": {}, + "inviteContactToGroupQuestion": "\"{groupName}\" அரட்டைக்கு {contact} ஐ அழைக்க விரும்புகிறீர்களா?", + "@inviteContactToGroupQuestion": {}, + "inviteContactToGroup": "{groupName} க்கு தொடர்பை அழை", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "அரட்டை விளக்கம் இதுவரை உருவாக்கப்படவில்லை.", + "@noChatDescriptionYet": {}, + "invalidServerName": "தவறான சேவையக பெயர்", + "@invalidServerName": {}, + "redactMessageDescription": "இந்த உரையாடலில் பங்கேற்பாளர்கள் அனைவருக்கும் செய்தி திருத்தப்படும். இதை செயல்தவிர்க்க முடியாது.", + "@redactMessageDescription": {}, + "invitedUser": "📩 {username} {targetName} அழைக்கப்பட்டார்", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "inviteText": "{username} உங்களை பஞ்சுபோன்றதாக அழைத்தது.\n 1. FulufyChat.im ஐப் பார்வையிட்டு பயன்பாட்டை நிறுவவும்\n 2. பதிவு செய்யுங்கள் அல்லது உள்நுழைக\n 3. அழைப்பிதழ் இணைப்பைத் திறக்கவும்:\n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "joinRoom": "அறையில் சேரவும்", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "leave": "விடுப்பு", + "@leave": { + "type": "String", + "placeholders": {} + }, + "dehydrateTorLong": "TOR பயனர்களுக்கு, சாளரத்தை மூடுவதற்கு முன் அமர்வை ஏற்றுமதி செய்ய பரிந்துரைக்கப்படுகிறது.", + "@dehydrateTorLong": {}, + "hydrateTorLong": "உங்கள் அமர்வை கடைசியாக டோரில் ஏற்றுமதி செய்தீர்களா? விரைவாக அதை இறக்குமதி செய்து அரட்டையடிக்கவும்.", + "@hydrateTorLong": {}, + "hydrate": "காப்பு கோப்பிலிருந்து மீட்டமைக்கவும்", + "@hydrate": {}, + "locationDisabledNotice": "இருப்பிட சேவைகள் முடக்கப்பட்டுள்ளன. தயவுசெய்து உங்கள் இருப்பிடத்தைப் பகிர்ந்து கொள்ள அவர்களுக்கு உதவவும்.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "இருப்பிட இசைவு மறுக்கப்பட்டது. உங்கள் இருப்பிடத்தைப் பகிர்ந்து கொள்ள தயவுசெய்து அவர்களுக்கு வழங்குங்கள்.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "புகுபதிவு", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "{homeserver} இல் உள்நுழைக", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "messages": "செய்திகள்", + "@messages": { + "type": "String", + "placeholders": {} + }, + "muteChat": "முடக்கு அரட்டை", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "newChat": "புதிய அரட்டை", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "next": "அடுத்தது", + "@next": { + "type": "String", + "placeholders": {} + }, + "none": "எதுவுமில்லை", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "உங்கள் கடவுச்சொல்லை மீட்டெடுப்பதற்கான வழியை நீங்கள் இன்னும் சேர்க்கவில்லை.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "செய்திகளைப் படிக்க பயன்பாட்டைத் திறக்கவும்", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "உங்கள் வாடிக்கையாளர்களில் ஒருவர் உள்நுழைந்துள்ளார்", + "@oneClientLoggedOut": {}, + "addToBundle": "மூட்டையில் சேர்க்கவும்", + "@addToBundle": {}, + "or": "அல்லது", + "@or": { + "type": "String", + "placeholders": {} + }, + "hideMemberChangesInPublicChats": "பொது அரட்டைகளில் உறுப்பினர் மாற்றங்களை மறைக்கவும்", + "@hideMemberChangesInPublicChats": {}, + "hideMemberChangesInPublicChatsBody": "வாசிப்புத்திறனை மேம்படுத்த யாராவது ஒரு பொது அரட்டையில் சேர்ந்தால் அல்லது விட்டுவிட்டால் அரட்டை காலவரிசையில் காட்ட வேண்டாம்.", + "@hideMemberChangesInPublicChatsBody": {}, + "overview": "கண்ணோட்டம்", + "@overview": {}, + "notifyMeFor": "எனக்கு அறிவிக்கவும்", + "@notifyMeFor": {}, + "passwordRecoverySettings": "கடவுச்சொல் மீட்பு அமைப்புகள்", + "@passwordRecoverySettings": {}, + "passwordRecovery": "கடவுச்சொல் மீட்பு", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "தயவுசெய்து தேர்வு செய்யவும்", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "play": "{fileName} இயக்கு", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnter4Digits": "பயன்பாட்டு பூட்டை முடக்க 4 இலக்கங்களை உள்ளிடவும் அல்லது காலியாக விடவும்.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "உங்கள் கடவுச்சொல்லை உள்ளிடவும்", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "உங்கள் முள் உள்ளிடவும்", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "உங்கள் பயனர்பெயரை உள்ளிடவும்", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "வலைத்தளத்தின் வழிமுறைகளைப் பின்பற்றி அடுத்து தட்டவும்.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "தனியுரிமை", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "reason": "காரணம்", + "@reason": { + "type": "String", + "placeholders": {} + }, + "redactedByBecause": "{username} ஆல் திருத்தப்பட்டது ஏனெனில்: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "register": "பதிவு செய்யுங்கள்", + "@register": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} அழைப்பை நிராகரித்தது", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "மீண்டும் சேரவும்", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "அரட்டையிலிருந்து தடையின்றி", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "உங்கள் அவதாரத்தை அகற்று", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "புதிய பதிப்போடு அறையை மாற்றவும்", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "உரையாக அனுப்பவும்", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "ஆடியோ அனுப்பவும்", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendImage": "படத்தை அனுப்பு", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendImages": "{count} படத்தை அனுப்பு", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendOriginal": "அசல் அனுப்பு", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "ச்டிக்கரை அனுப்பவும்", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "வீடியோ அனுப்பவும்", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentASticker": "😊 {username} ஒரு ச்டிக்கரை அனுப்பியது", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} அனுப்பப்பட்ட அழைப்பு செய்தி", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "separateChatTypes": "நேரடி அரட்டைகள் மற்றும் குழுக்களை பிரிக்கவும்", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "முதன்மையான மாற்றுப்பெயராக அமைக்கவும்", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "தனிப்பயன் உணர்ச்சிகளை அமைக்கவும்", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setChatDescription": "அரட்டை விளக்கத்தை அமைக்கவும்", + "@setChatDescription": {}, + "setInvitationLink": "அழைப்பிதழ் இணைப்பை அமைக்கவும்", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "share": "பங்கு", + "@share": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "இருப்பு:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "பிற பயனர்களிடமிருந்து நிலை செய்திகளைக் காட்டு", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "ஒற்றை அடையாளம்", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "தவிர்", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "மூலக் குறியீடு", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceName": "விண்வெளி பெயர்", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "status": "நிலை", + "@status": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "மண்டலம்", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "அவர்கள் பொருந்துகிறார்கள்", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} தடைசெய்யப்படாத {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unknownEvent": "அறியப்படாத நிகழ்வு '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "userAndOthersAreTyping": "{username} மற்றும் {count} மற்றவர்கள் தட்டச்சு செய்கிறார்கள்…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userIsTyping": "{username} தட்டச்சு செய்கிறது…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "waitingPartnerAcceptRequest": "கூட்டாளர் கோரிக்கையை ஏற்றுக்கொள்வதற்காக காத்திருக்கிறார்…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "பங்குதாரர் ஈமோசியை ஏற்றுக்கொள்வதற்காக காத்திருக்கிறார்…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "sender": "அனுப்புநர்", + "@sender": {}, + "openGallery": "திறந்த கேலரி", + "@openGallery": {}, + "wallpaper": "வால்பேப்பர்:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "இதை ஏன் புகாரளிக்க விரும்புகிறீர்கள்?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "புதிய மீட்பு விசையை உருவாக்க உங்கள் அரட்டை காப்புப்பிரதியைத் துடைக்கவா?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "இந்த முகவரிகள் மூலம் உங்கள் கடவுச்சொல்லை மீட்டெடுக்கலாம்.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "ஒரு செய்தியை எழுதுங்கள்…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "ஆம்", + "@yes": { + "type": "String", + "placeholders": {} + }, + "removeFromSpace": "இடத்திலிருந்து அகற்று", + "@removeFromSpace": {}, + "pleaseEnterRecoveryKeyDescription": "உங்கள் பழைய செய்திகளைத் திறக்க, முந்தைய அமர்வில் உருவாக்கப்பட்ட உங்கள் மீட்பு விசையை உள்ளிடவும். உங்கள் மீட்பு விசை உங்கள் கடவுச்சொல் அல்ல.", + "@pleaseEnterRecoveryKeyDescription": {}, + "confirmEventUnpin": "நிகழ்வை நிரந்தரமாக அவிழ்ப்பது உறுதி?", + "@confirmEventUnpin": {}, + "switchToAccount": "கணக்குக்கு மாறவும் {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "அடுத்த கணக்கு", + "@nextAccount": {}, + "youJoinedTheChat": "நீங்கள் அரட்டையில் சேர்ந்தீர்கள்", + "@youJoinedTheChat": {}, + "indexedDbErrorLong": "செய்தி சேமிப்பு துரதிர்ச்டவசமாக இயல்புநிலையாக தனிப்பட்ட பயன்முறையில் இயக்கப்படவில்லை.\n தயவுசெய்து பார்வையிடவும்\n - பற்றி: கட்டமைப்பு\n - கணம் dom.indexedDB.privateBrowsing.enabled பெறுநர் true\n இல்லையெனில், பஞ்சுபோன்றவை இயக்க முடியாது.", + "@indexedDbErrorLong": {}, + "youAcceptedTheInvitation": "👍 நீங்கள் அழைப்பை ஏற்றுக்கொண்டீர்கள்", + "@youAcceptedTheInvitation": {}, + "youBannedUser": "நீங்கள் {user} தடை செய்தீர்கள்", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "{user}க்கான அழைப்பை திரும்பப் பெற்றுவிட்டீர்கள்", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 நீங்கள் {user} ஆல் அழைக்கப்பட்டுள்ளீர்கள்", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 {user} ஐ அழைத்தீர்கள்", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "நீங்கள் {user} தடைசெய்யவில்லை", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hasKnocked": "🚪 {user} தட்டியது", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "பொது இணைப்பு இதுவரை உருவாக்கப்படவில்லை", + "@noPublicLinkHasBeenCreatedYet": {}, + "knock": "தட்டவும்", + "@knock": {}, + "users": "பயனர்கள்", + "@users": {}, + "storeInSecureStorageDescription": "மீட்பு விசையை இந்த சாதனத்தின் பாதுகாப்பான சேமிப்பகத்தில் சேமிக்கவும்.", + "@storeInSecureStorageDescription": {}, + "saveKeyManuallyDescription": "கணினி பகிர்வு உரையாடல் அல்லது கிளிப்போர்டைத் தூண்டுவதன் மூலம் இந்த விசையை கைமுறையாக சேமிக்கவும்.", + "@saveKeyManuallyDescription": {}, + "storeInAndroidKeystore": "ஆண்ட்ராய்டு கீச்டோரில் சேமிக்கவும்", + "@storeInAndroidKeystore": {}, + "countFiles": "{count} கோப்புகள்", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "custom": "தனிப்பயன்", + "@custom": {}, + "foregroundServiceRunning": "முன்புற பணி இயங்கும்போது இந்த அறிவிப்பு தோன்றும்.", + "@foregroundServiceRunning": {}, + "screenSharingDetail": "உங்கள் திரையை FUFFYCHAT இல் பகிர்கிறீர்கள்", + "@screenSharingDetail": {}, + "callingPermissions": "அழைப்பு அனுமதிகள்", + "@callingPermissions": {}, + "callingAccount": "அழைப்பு கணக்கு", + "@callingAccount": {}, + "callingAccountDetails": "சொந்த ஆண்ட்ராய்டு டயலர் பயன்பாட்டைப் பயன்படுத்த பஞ்சுபோன்றது அனுமதிக்கிறது.", + "@callingAccountDetails": {}, + "otherCallingPermissions": "மைக்ரோஃபோன், கேமரா மற்றும் பிற பஞ்சுபோன்ற அனுமதிகள்", + "@otherCallingPermissions": {}, + "numChats": "{number} அரட்டைகள்", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "முக்கியமற்ற மாநில நிகழ்வுகளை மறைக்கவும்", + "@hideUnimportantStateEvents": {}, + "whyIsThisMessageEncrypted": "இந்த செய்தி ஏன் படிக்க முடியாதது?", + "@whyIsThisMessageEncrypted": {}, + "noKeyForThisMessage": "இந்த சாதனத்தில் உங்கள் கணக்கில் கையொப்பமிடுவதற்கு முன்பு செய்தி அனுப்பப்பட்டால் இது நிகழலாம்.\n\n அனுப்புநர் உங்கள் சாதனத்தைத் தடுத்துள்ளார் அல்லது இணைய இணைப்பில் ஏதேனும் தவறு ஏற்பட்டுள்ளது.\n\n மற்றொரு அமர்வில் செய்தியைப் படிக்க முடியுமா? அதிலிருந்து செய்தியை மாற்றலாம்! அமைப்புகள்> சாதனங்களுக்குச் சென்று, உங்கள் சாதனங்கள் ஒருவருக்கொருவர் சரிபார்த்துள்ளன என்பதை உறுதிப்படுத்தவும். அடுத்த முறை நீங்கள் அறையைத் திறக்கும்போது, இரண்டு அமர்வுகளும் முன்னணியில் இருக்கும்போது, விசைகள் தானாகவே அனுப்பப்படும்.\n\n வெளியேறும்போது அல்லது சாதனங்களை மாற்றும்போது விசைகளை இழக்க நீங்கள் விரும்பவில்லையா? அமைப்புகளில் அரட்டை காப்புப்பிரதியை நீங்கள் இயக்கியுள்ளீர்கள் என்பதை உறுதிப்படுத்திக் கொள்ளுங்கள்.", + "@noKeyForThisMessage": {}, + "hidePresences": "நிலை பட்டியலை மறைக்கவா?", + "@hidePresences": {}, + "doNotShowAgain": "மீண்டும் காட்ட வேண்டாம்", + "@doNotShowAgain": {}, + "newSpaceDescription": "உங்கள் அரட்டைகளை ஒருங்கிணைத்து தனியார் அல்லது பொது சமூகங்களை உருவாக்க இடைவெளிகள் உங்களை அனுமதிக்கிறது.", + "@newSpaceDescription": {}, + "disableEncryptionWarning": "பாதுகாப்பு காரணங்களுக்காக நீங்கள் ஒரு அரட்டையில் குறியாக்கத்தை முடக்க முடியாது, அது இதற்கு முன்பு இயக்கப்பட்டிருக்கிறது.", + "@disableEncryptionWarning": {}, + "sorryThatsNotPossible": "மன்னிக்கவும் ... அது சாத்தியமில்லை", + "@sorryThatsNotPossible": {}, + "noBackupWarning": "எச்சரிக்கை! அரட்டை காப்புப்பிரதியை இயக்காமல், உங்கள் மறைகுறியாக்கப்பட்ட செய்திகளுக்கான அணுகலை இழப்பீர்கள். வெளியேறுவதற்கு முன் முதலில் அரட்டை காப்புப்பிரதியை இயக்க மிகவும் பரிந்துரைக்கப்படுகிறது.", + "@noBackupWarning": {}, + "fileIsTooBigForServer": "அனுப்ப முடியவில்லை! சேவையகம் {max} வரை இணைப்புகளை மட்டுமே ஆதரிக்கிறது.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "கோப்பு {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "pleaseTryAgainLaterOrChooseDifferentServer": "தயவுசெய்து பின்னர் மீண்டும் முயற்சிக்கவும் அல்லது வேறு சேவையகத்தைத் தேர்வுசெய்க.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "signInWith": "{provider} மூலம் உள்நுழையவும்", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "profileNotFound": "பயனரை சேவையகத்தில் காண முடியவில்லை. ஒரு இணைப்பு சிக்கல் இருக்கலாம் அல்லது பயனர் இல்லை.", + "@profileNotFound": {}, + "inviteGroupChat": "📨 குழு அரட்டை அழைப்பு", + "@inviteGroupChat": {}, + "invitePrivateChat": "Sative தனியார் அரட்டை அழைப்பு", + "@invitePrivateChat": {}, + "invalidInput": "தவறான உள்ளீடு!", + "@invalidInput": {}, + "archiveRoomDescription": "அரட்டை காப்பகத்திற்கு நகர்த்தப்படும். மற்ற பயனர்கள் நீங்கள் அரட்டையை விட்டுவிட்டீர்கள் என்பதைக் காண முடியும்.", + "@archiveRoomDescription": {}, + "removeDevicesDescription": "நீங்கள் இந்த சாதனத்திலிருந்து வெளியேறுவீர்கள், இனி செய்திகளைப் பெற முடியாது.", + "@removeDevicesDescription": {}, + "banUserDescription": "பயனர் அரட்டையிலிருந்து தடைசெய்யப்படுவார், மேலும் அவை தடைசெய்யப்படாத வரை மீண்டும் அரட்டையில் நுழைய முடியாது.", + "@banUserDescription": {}, + "makeAdminDescription": "இந்த பயனர் நிர்வாகியை நீங்கள் செய்தவுடன், இதை நீங்கள் செயல்தவிர்க்க முடியாமல் போகலாம், ஏனெனில் அவை உங்களைப் போன்ற அதே அனுமதிகளைக் கொண்டிருக்கும்.", + "@makeAdminDescription": {}, + "knocking": "தட்டுதல்", + "@knocking": {}, + "searchChatsRooms": "#Chats, Us பயனர்களைத் தேடுங்கள் ...", + "@searchChatsRooms": {}, + "nothingFound": "எதுவும் கிடைக்கவில்லை ...", + "@nothingFound": {}, + "groupName": "குழு பெயர்", + "@groupName": {}, + "createGroupAndInviteUsers": "ஒரு குழுவை உருவாக்கி பயனர்களை அழைக்கவும்", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "தேடல் வழியாக குழுவை காணலாம்", + "@groupCanBeFoundViaSearch": {}, + "wrongRecoveryKey": "மன்னிக்கவும் ... இது சரியான மீட்பு விசையாகத் தெரியவில்லை.", + "@wrongRecoveryKey": {}, + "databaseMigrationBody": "தயவுசெய்து காத்திருங்கள். இது ஒரு கணம் ஆகலாம்.", + "@databaseMigrationBody": {}, + "newPassword": "புதிய கடவுச்சொல்", + "@newPassword": {}, + "pleaseChooseAStrongPassword": "வலுவான கடவுச்சொல்லைத் தேர்வுசெய்க", + "@pleaseChooseAStrongPassword": {}, + "passwordsDoNotMatch": "கடவுச்சொற்கள் பொருந்தவில்லை", + "@passwordsDoNotMatch": {}, + "joinSpace": "விண்வெளியில் சேரவும்", + "@joinSpace": {}, + "addChatOrSubSpace": "அரட்டை அல்லது துணை இடத்தைச் சேர்க்கவும்", + "@addChatOrSubSpace": {}, + "initAppError": "பயன்பாட்டைத் தொடங்கும்போது பிழை ஏற்பட்டது", + "@initAppError": {}, + "databaseBuildErrorBody": "SQlite தரவுத்தளத்தை உருவாக்க முடியவில்லை. ஆப்ஸ் தற்போதைக்கு மரபு தரவுத்தளத்தைப் பயன்படுத்த முயற்சிக்கிறது. {url} இல் டெவலப்பர்களிடம் இந்தப் பிழையைப் புகாரளிக்கவும். பிழை செய்தி: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "உங்கள் அமர்வு தொலைந்துவிட்டது. {url} இல் டெவலப்பர்களிடம் இந்தப் பிழையைப் புகாரளிக்கவும். பிழை செய்தி: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "அரட்டையில் பங்கேற்பாளர்கள் நீங்கள் ஒரு புதிய செய்தியைத் தட்டச்சு செய்யும் போது காணலாம்.", + "@sendTypingNotificationsDescription": {}, + "sendReadReceiptsDescription": "அரட்டையில் பங்கேற்பாளர்கள் நீங்கள் ஒரு செய்தியைப் படிக்கும்போது பார்க்கலாம்.", + "@sendReadReceiptsDescription": {}, + "formattedMessagesDescription": "மார்க் டவுனைப் பயன்படுத்தி தைரியமான உரை போன்ற பணக்கார செய்தி உள்ளடக்கத்தைக் காண்பி.", + "@formattedMessagesDescription": {}, + "verifyOtherUser": "Poser மற்ற பயனரை சரிபார்க்கவும்", + "@verifyOtherUser": {}, + "verifyOtherUserDescription": "நீங்கள் மற்றொரு பயனரைச் சரிபார்த்தால், நீங்கள் உண்மையில் யாருக்கு எழுதுகிறீர்கள் என்பது உங்களுக்குத் தெரியும் என்பதை நீங்கள் உறுதியாக நம்பலாம். 💪\n\nநீங்கள் ஒரு சரிபார்ப்பைத் தொடங்கும்போது, நீங்களும் மற்ற பயனரும் பயன்பாட்டில் ஒரு பாப்அப்பைக் காண்பீர்கள். நீங்கள் ஒருவருக்கொருவர் ஒப்பிட வேண்டிய தொடர்ச்சியான ஈமோசிகள் அல்லது எண்களைக் காண்பீர்கள்.\n\nஇதைச் செய்வதற்கான சிறந்த வழி வீடியோ அழைப்பைச் சந்திப்பது அல்லது தொடங்குவது. 👭", + "@verifyOtherUserDescription": {}, + "verifyOtherDeviceDescription": "நீங்கள் மற்றொரு சாதனத்தைச் சரிபார்க்கும்போது, அந்தச் சாதனங்கள் விசைகளைப் பரிமாறிக்கொள்ளலாம், உங்கள் ஒட்டுமொத்த பாதுகாப்பை அதிகரிக்கும். 💪 நீங்கள் ஒரு சரிபார்ப்பைத் தொடங்கும்போது, இரண்டு சாதனங்களிலும் பயன்பாட்டில் ஒரு பாப்அப் தோன்றும். நீங்கள் ஒருவருக்கொருவர் ஒப்பிட வேண்டிய தொடர்ச்சியான ஈமோசிகள் அல்லது எண்களைக் காண்பீர்கள். நீங்கள் சரிபார்ப்பைத் தொடங்குவதற்கு முன்பு இரண்டு சாதனங்களையும் எளிதில் வைத்திருப்பது நல்லது. 🤳", + "@verifyOtherDeviceDescription": {}, + "canceledKeyVerification": "{sender} ரத்து செய்யப்பட்ட விசை சரிபார்ப்பு", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "விசை சரிபார்ப்பிற்கு {sender} தயாராக உள்ளார்", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} கோரப்பட்ட விசை சரிபார்ப்பு", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "வெளிப்படையானது", + "@transparent": {}, + "stickers": "ச்டிக்கர்கள்", + "@stickers": {}, + "commandHint_ignore": "கொடுக்கப்பட்ட மேட்ரிக்ச் ஐடியை புறக்கணிக்கவும்", + "@commandHint_ignore": {}, + "unreadChatsInApp": "{appname}: {unread} படிக்காத அரட்டைகள்", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "இப்போது {count} பயனர்கள் தடுக்கப்பட்டுள்ளனர்.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "தடைசெய்யப்பட்டது", + "@restricted": {}, + "moderatorLevel": "{level} - மதிப்பீட்டாளர்", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - நிர்வாகி", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "பொது அரட்டை அமைப்புகளை மாற்றவும்", + "@changeGeneralChatSettings": {}, + "inviteOtherUsers": "இந்த அரட்டைக்கு மற்ற பயனர்களை அழைக்கவும்", + "@inviteOtherUsers": {}, + "changeTheChatPermissions": "அரட்டை அனுமதிகளை மாற்றவும்", + "@changeTheChatPermissions": {}, + "changeTheVisibilityOfChatHistory": "அரட்டை வரலாற்றின் தெரிவுநிலையை மாற்றவும்", + "@changeTheVisibilityOfChatHistory": {}, + "changeTheCanonicalRoomAlias": "முக்கிய பொது அரட்டை முகவரியை மாற்றவும்", + "@changeTheCanonicalRoomAlias": {}, + "changeTheDescriptionOfTheGroup": "அரட்டையின் விளக்கத்தை மாற்றவும்", + "@changeTheDescriptionOfTheGroup": {}, + "chatPermissionsDescription": "இந்த அரட்டையில் சில செயல்களுக்கு எந்த ஆற்றல் நிலை தேவை என்பதை வரையறுக்கவும். 0, 50 மற்றும் 100 ஆற்றல் நிலைகள் பொதுவாக பயனர்கள், மதிப்பீட்டாளர்கள் மற்றும் நிர்வாகிகளைக் குறிக்கின்றன, ஆனால் எந்த தரமும் சாத்தியமாகும்.", + "@chatPermissionsDescription": {}, + "updateInstalled": "🎉 புதுப்பிப்பு {version} நிறுவப்பட்டது!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "மாற்றபதிவு", + "@changelog": {}, + "homeserverDescription": "உங்கள் எல்லா தரவுகளும் ஒரு மின்னஞ்சல் வழங்குநரைப் போலவே ஓம்சர்வரில் சேமிக்கப்படுகின்றன. நீங்கள் எந்த ஓம்சர்வரை பயன்படுத்த விரும்புகிறீர்கள் என்பதை நீங்கள் தேர்வு செய்யலாம், அதே நேரத்தில் நீங்கள் எல்லோரிடமும் தொடர்பு கொள்ளலாம். Https://matrix.org இல் மேலும் அறிக.", + "@homeserverDescription": {}, + "calculatingFileSize": "கோப்பு அளவைக் கணக்கிடுகிறது ...", + "@calculatingFileSize": {}, + "compressVideo": "அமைக்கும் வீடியோ ...", + "@compressVideo": {}, + "sendingAttachmentCountOfCount": "{length} இன் இணைப்பு {index}ஐ அனுப்புகிறது...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "உங்கள் சாதனங்களில் ஒன்று சரிபார்க்கப்படவில்லை", + "@oneOfYourDevicesIsNotVerified": {}, + "noticeChatBackupDeviceVerification": "குறிப்பு: உங்கள் எல்லா சாதனங்களையும் அரட்டை காப்புப்பிரதியுடன் இணைக்கும்போது, அவை தானாகவே சரிபார்க்கப்படும்.", + "@noticeChatBackupDeviceVerification": {}, + "manageAccount": "கணக்கை நிர்வகிக்கவும்", + "@manageAccount": {}, + "noContactInformationProvided": "சேவையகம் எந்த சரியான தொடர்பு தகவலையும் வழங்காது", + "@noContactInformationProvided": {}, + "contactServerAdmin": "சேவையக நிர்வாகி தொடர்பு", + "@contactServerAdmin": {}, + "contactServerSecurity": "சேவையக பாதுகாப்பைத் தொடர்பு கொள்ளுங்கள்", + "@contactServerSecurity": {}, + "supportPage": "உதவி பக்கம்", + "@supportPage": {}, + "serverInformation": "சேவையக தகவல்:", + "@serverInformation": {}, + "version": "பதிப்பு", + "@version": {}, + "website": "வலைத்தளம்", + "@website": {}, + "compress": "சுருக்க", + "@compress": {}, + "alwaysUse24HourFormat": "தவறு", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "admin": "நிர்வாகி", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "மாற்றுப்பெயர்", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} அழைப்புக்கு பதிலளித்தார்", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_react": "ஒரு எதிர்வினையாக பதிலை அனுப்பவும்", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "உரையை அனுப்பவும்", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "containsDisplayName": "காட்சி பெயரைக் கொண்டுள்ளது", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "removeFromBundle": "இந்த மூட்டையிலிருந்து அகற்றவும்", + "@removeFromBundle": {}, + "pushRules": "தள்ளி விதிகள்", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "recording": "பதிவு", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedBy": "{username} ஆல் திருத்தப்பட்டது", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "நேரடி அரட்டை", + "@directChat": {}, + "redactMessage": "திருத்தும் செய்தி", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "userAndUserAreTyping": "{username} மற்றும் {username2} தட்டச்சு செய்கின்றன…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} அரட்டையை விட்டு வெளியேறினார்", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "visibilityOfTheChatHistory": "அரட்டை வரலாற்றின் தெரிவுநிலை", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "you": "நீங்கள்", + "@you": { + "type": "String", + "placeholders": {} + }, + "unsupportedAndroidVersionLong": "இந்த அம்சத்திற்கு புதிய ஆண்ட்ராய்டு பதிப்பு தேவைப்படுகிறது. புதுப்பிப்புகள் அல்லது பரம்பரை OS ஆதரவை சரிபார்க்கவும்.", + "@unsupportedAndroidVersionLong": {}, + "widgetJitsi": "சிட்சி சந்திக்கிறார்", + "@widgetJitsi": {}, + "signInWithPassword": "கடவுச்சொல்லுடன் உள்நுழைக", + "@signInWithPassword": {}, + "setColorTheme": "வண்ண கருப்பொருள் அமைக்கவும்:", + "@setColorTheme": {}, + "roomUpgradeDescription": "அரட்டை பின்னர் புதிய அறை பதிப்பில் மீண்டும் உருவாக்கப்படும். பங்கேற்பாளர்கள் அனைவருக்கும் புதிய அரட்டைக்கு மாற வேண்டும் என்று அறிவிக்கப்படும். அறை பதிப்புகள் பற்றி மேலும் அறிய https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "account": "கணக்கு", + "@account": { + "type": "String", + "placeholders": {} + }, + "groups": "குழுக்கள்", + "@groups": { + "type": "String", + "placeholders": {} + }, + "blockedUsers": "தடுக்கப்பட்ட பயனர்கள்", + "@blockedUsers": {}, + "leaveEmptyToClearStatus": "உங்கள் நிலையை அழிக்க காலியாக விடவும்.", + "@leaveEmptyToClearStatus": {}, + "subspace": "துணை", + "@subspace": {}, + "decline": "வீழ்ச்சி", + "@decline": {}, + "thisDevice": "இந்த சாதனம்:", + "@thisDevice": {}, + "minimumPowerLevel": "{level} என்பது குறைந்தபட்ச ஆற்றல் நிலை.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "gallery": "கேலரி", + "@gallery": {}, + "files": "கோப்புகள்", + "@files": {}, + "noDatabaseEncryption": "இந்த மேடையில் தரவுத்தள குறியாக்கம் ஆதரிக்கப்படவில்லை", + "@noDatabaseEncryption": {}, + "goToSpace": "விண்வெளிக்குச் செல்லுங்கள்: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "படிக்காத எனக் குறிக்கவும்", + "@markAsUnread": {}, + "userLevel": "{level} - பயனர்", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "notAnImage": "படக் கோப்பு அல்ல.", + "@notAnImage": {}, + "encryptThisChat": "இந்த அரட்டையை குறியாக்கவும்", + "@encryptThisChat": {}, + "userRole": "பயனர் பங்கு", + "@userRole": {}, + "publicChatAddresses": "பொது அரட்டை முகவரிகள்", + "@publicChatAddresses": {}, + "createNewAddress": "புதிய முகவரியை உருவாக்கவும்", + "@createNewAddress": {}, + "boldText": "தைரியமான உரை", + "@boldText": {}, + "italicText": "சாய்வு உரை", + "@italicText": {}, + "strikeThrough": "ச்ட்ரைகெத்ரோ", + "@strikeThrough": {}, + "pleaseFillOut": "தயவுசெய்து நிரப்பவும்", + "@pleaseFillOut": {}, + "invalidUrl": "தவறான முகவரி", + "@invalidUrl": {}, + "addLink": "இணைப்பைச் சேர்க்கவும்", + "@addLink": {}, + "searchIn": "அரட்டையில் தேடு \"{chat}\" ...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "மேலும் தேடுங்கள் ...", + "@searchMore": {}, + "startedKeyVerification": "{sender} விசை சரிபார்ப்பைத் தொடங்கினார்", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "loginWithMatrixId": "மேட்ரிக்ச்-ஐடியுடன் உள்நுழைக", + "@loginWithMatrixId": {}, + "discoverHomeservers": "ஓம்சர்சர்களைக் கண்டறியவும்", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "ஓம்சர்வர் என்றால் என்ன?", + "@whatIsAHomeserver": {}, + "doesNotSeemToBeAValidHomeserver": "இணக்கமான ஓம்சர்வர் என்று தெரியவில்லை. தவறான URL?", + "@doesNotSeemToBeAValidHomeserver": {}, + "countChatsAndCountParticipants": "{chats} அரட்டைகள் மற்றும் {participants} பங்கேற்பாளர்கள்", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "இனி அரட்டைகள் கிடைக்கவில்லை ...", + "@noMoreChatsFound": {}, + "joinedChats": "இணைந்த அரட்டைகள்", + "@joinedChats": {}, + "spaces": "இடங்கள்", + "@spaces": {}, + "changedTheChatPermissions": "{username} அரட்டை அனுமதிகளை மாற்றியுள்ளார்", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} விருந்தினர் அணுகல் விதிகளை மாற்றியது: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} வரலாற்று தெரிவுநிலையை மாற்றியது", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "commandHint_join": "கொடுக்கப்பட்ட அறையில் சேரவும்", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_dm": "நேரடி அரட்டையைத் தொடங்கவும்\n குறியாக்கத்தை முடக்க-இல்லை-குறியாக்கத்தைப் பயன்படுத்தவும்", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_leave": "இந்த அறையை விட்டு விடுங்கள்", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "toggleMuted": "முடக்கியது", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "unbanUserDescription": "அவர்கள் முயற்சித்தால் பயனர் மீண்டும் அரட்டையை உள்ளிட முடியும்.", + "@unbanUserDescription": {}, + "restoreSessionBody": "ஆப்ஸ் இப்போது உங்கள் அமர்வை காப்புப்பிரதியிலிருந்து மீட்டெடுக்க முயற்சிக்கிறது. {url} இல் டெவலப்பர்களிடம் இந்தப் பிழையைப் புகாரளிக்கவும். பிழை செய்தி: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceipts": "வாசிப்பு ரசீதுகளை அனுப்பவும்", + "@sendReadReceipts": {}, + "unableToJoinChat": "அரட்டையில் சேர முடியவில்லை. ஒருவேளை மற்ற கட்சி ஏற்கனவே உரையாடலை மூடியிருக்கலாம்.", + "@unableToJoinChat": {}, + "noGoogleServicesWarning": "ஃபயர்பேச் முகில் செய்தி உங்கள் சாதனத்தில் கிடைக்கவில்லை. இன்னும் புச் அறிவிப்புகளைப் பெற, NTFY ஐ நிறுவ பரிந்துரைக்கிறோம். NTFY அல்லது மற்றொரு ஒருங்கிணைந்த புச் வழங்குநருடன் நீங்கள் தரவு பாதுகாப்பான வழியில் புச் அறிவிப்புகளைப் பெறலாம். நீங்கள் பிளேச்டோரிலிருந்து அல்லது எஃப்-டிராய்டிலிருந்து NTFY ஐ பதிவிறக்கம் செய்யலாம்.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "QR குறியீட்டை ச்கேன் செய்யுங்கள்", + "@scanQrCode": {}, + "obtainingLocation": "இருப்பிடத்தைப் பெறுதல்…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offline": "இணையமில்லாமல்", + "@offline": { + "type": "String", + "placeholders": {} + }, + "online": "ஆன்லைனில்", + "@online": { + "type": "String", + "placeholders": {} + }, + "participant": "பங்கேற்பாளர்", + "@participant": { + "type": "String", + "placeholders": {} + }, + "removeDevice": "சாதனத்தை அகற்று", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "search": "தேடல்", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "பாதுகாப்பு", + "@security": { + "type": "String", + "placeholders": {} + }, + "sendFile": "கோப்பு அனுப்பவும்", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "setCustomPermissionLevel": "தனிப்பயன் இசைவு அளவை அமைக்கவும்", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "தயவுசெய்து கீழே ஒரு முன் வரையறுக்கப்பட்ட பாத்திரத்தைத் தேர்வுசெய்க அல்லது 0 மற்றும் 100 க்கு இடையில் தனிப்பயன் இசைவு நிலையை உள்ளிடவும்.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "பயனரை புறக்கணிக்கவும்", + "@ignoreUser": {}, + "normalUser": "சாதாரண பயனர்", + "@normalUser": {}, + "commandHint_roomupgrade": "கொடுக்கப்பட்ட அறை பதிப்பிற்கு இந்த அறையை மேம்படுத்தவும்", + "@commandHint_roomupgrade": {}, + "checkList": "சரிபார்ப்பு பட்டியல்", + "@checkList": {}, + "countInvited": "{count} அழைக்கப்பட்டது", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "synchronizingPleaseWaitCounter": " ஒத்திசைத்தல்… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "previous": "முந்தைய", + "@previous": {}, + "otherPartyNotLoggedIn": "மற்ற கட்சி தற்போது உள்நுழைந்திருக்கவில்லை, எனவே செய்திகளைப் பெற முடியாது!", + "@otherPartyNotLoggedIn": {}, + "appWantsToUseForLogin": "உள்நுழைய '{server}' ஐப் பயன்படுத்தவும்", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "உங்களைப் பற்றிய தகவல்களைப் பகிர பயன்பாடு மற்றும் வலைத்தளத்தை இதன்மூலம் அனுமதிக்கிறீர்கள்.", + "@appWantsToUseForLoginDescription": {}, + "open": "திற", + "@open": {}, + "waitingForServer": "சேவையகத்திற்காக காத்திருக்கிறது ...", + "@waitingForServer": {}, + "appIntroduction": "வெவ்வேறு தூதர்களில் உங்கள் நண்பர்களுடன் அரட்டையடிக்க உங்களை பஞ்சுபோன்றது உங்களை அனுமதிக்கிறது. Https://matrix.org இல் மேலும் அறிக அல்லது *தொடரவும் *தட்டவும்.", + "@appIntroduction": {}, + "newChatRequest": "அரட்டை கோரிக்கை", + "@newChatRequest": {}, + "contentNotificationSettings": "உள்ளடக்க அறிவிப்பு அமைப்புகள்", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "பொது அறிவிப்பு அமைப்புகள்", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "அறை அறிவிப்பு அமைப்புகள்", + "@roomNotificationSettings": {}, + "userSpecificNotificationSettings": "பயனர் குறிப்பிட்ட அறிவிப்பு அமைப்புகள்", + "@userSpecificNotificationSettings": {}, + "otherNotificationSettings": "பிற அறிவிப்பு அமைப்புகள்", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "பயனர் பெயரைக் கொண்டுள்ளது", + "@notificationRuleContainsUserName": {}, + "notificationRuleContainsUserNameDescription": "ஒரு செய்தியில் அவற்றின் பயனர்பெயர் இருக்கும்போது பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleMaster": "அனைத்து அறிவிப்புகளையும் முடக்குகிறது", + "@notificationRuleMaster": {}, + "notificationRuleMasterDescription": "மற்ற எல்லா விதிகளையும் மீறி அனைத்து அறிவிப்புகளையும் முடக்குகிறது.", + "@notificationRuleMasterDescription": {}, + "notificationRuleSuppressNotices": "தானியங்கு செய்திகளை அடக்கவும்", + "@notificationRuleSuppressNotices": {}, + "notificationRuleSuppressNoticesDescription": "போட்ச் போன்ற தானியங்கி வாடிக்கையாளர்களிடமிருந்து அறிவிப்புகளை அடக்குகிறது.", + "@notificationRuleSuppressNoticesDescription": {}, + "notificationRuleInviteForMe": "எனக்கு அழைக்கவும்", + "@notificationRuleInviteForMe": {}, + "notificationRuleInviteForMeDescription": "ஒரு அறைக்கு அழைக்கப்படும்போது பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleInviteForMeDescription": {}, + "notificationRuleMemberEvent": "உறுப்பினர் நிகழ்வு", + "@notificationRuleMemberEvent": {}, + "notificationRuleMemberEventDescription": "உறுப்பினர் நிகழ்வுகளுக்கான அறிவிப்புகளை அடக்குகிறது.", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleIsUserMention": "பயனர் குறிப்பு", + "@notificationRuleIsUserMention": {}, + "notificationRuleIsUserMentionDescription": "ஒரு செய்தியில் நேரடியாக குறிப்பிடப்படும்போது பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleIsUserMentionDescription": {}, + "notificationRuleContainsDisplayName": "காட்சி பெயரைக் கொண்டுள்ளது", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleContainsDisplayNameDescription": "ஒரு செய்தியில் அவற்றின் காட்சி பெயர் இருக்கும்போது பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleIsRoomMention": "அறை குறிப்பு", + "@notificationRuleIsRoomMention": {}, + "notificationRuleIsRoomMentionDescription": "ஒரு அறை குறிப்பு இருக்கும்போது பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleRoomnotif": "அறை அறிவிப்பு", + "@notificationRuleRoomnotif": {}, + "notificationRuleRoomnotifDescription": "ஒரு செய்தியில் '@ROOM' இருக்கும்போது பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleRoomnotifDescription": {}, + "notificationRuleTombstone": "கல்லறை", + "@notificationRuleTombstone": {}, + "notificationRuleTombstoneDescription": "அறை செயலிழக்கச் செய்திகளைப் பற்றி பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleReaction": "எதிர்வினை", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "எதிர்வினைகளுக்கான அறிவிப்புகளை அடக்குகிறது.", + "@notificationRuleReactionDescription": {}, + "notificationRuleRoomServerAcl": "அறை சேவையகம் ACL", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleRoomServerAclDescription": "அறை சேவையக அணுகல் கட்டுப்பாட்டு பட்டியல்களுக்கான (ACL) அறிவிப்புகளை அடக்குகிறது.", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleSuppressEdits": "திருத்தங்களை அடக்கவும்", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "திருத்தப்பட்ட செய்திகளுக்கான அறிவிப்புகளை அடக்குகிறது.", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleCall": "அழை", + "@notificationRuleCall": {}, + "notificationRuleCallDescription": "அழைப்புகள் பற்றி பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleCallDescription": {}, + "notificationRuleEncryptedRoomOneToOne": "மறைகுறியாக்கப்பட்ட அறை ஒன்றுக்கு ஒன்று", + "@notificationRuleEncryptedRoomOneToOne": {}, + "notificationRuleEncryptedRoomOneToOneDescription": "மறைகுறியாக்கப்பட்ட ஒன்றுக்கு ஒன்று அறைகளில் செய்திகளைப் பற்றி பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleEncryptedRoomOneToOneDescription": {}, + "notificationRuleRoomOneToOne": "அறை ஒன்று", + "@notificationRuleRoomOneToOne": {}, + "notificationRuleRoomOneToOneDescription": "ஒருவருக்கு ஒன்று அறைகளில் செய்திகளைப் பற்றி பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleRoomOneToOneDescription": {}, + "notificationRuleMessage": "செய்தி", + "@notificationRuleMessage": {}, + "notificationRuleMessageDescription": "பொதுவான செய்திகளைப் பற்றி பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleMessageDescription": {}, + "notificationRuleEncrypted": "குறியாக்கப்பட்டது", + "@notificationRuleEncrypted": {}, + "notificationRuleEncryptedDescription": "மறைகுறியாக்கப்பட்ட அறைகளில் செய்திகளைப் பற்றி பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleEncryptedDescription": {}, + "notificationRuleJitsi": "சியோட்ச்", + "@notificationRuleJitsi": {}, + "notificationRuleJitsiDescription": "சிட்சி விட்செட் நிகழ்வுகளைப் பற்றி பயனருக்கு அறிவிக்கிறது.", + "@notificationRuleJitsiDescription": {}, + "notificationRuleServerAcl": "சேவையக ACL நிகழ்வுகளை அடக்கவும்", + "@notificationRuleServerAcl": {}, + "notificationRuleServerAclDescription": "சேவையக ACL நிகழ்வுகளுக்கான அறிவிப்புகளை அடக்குகிறது.", + "@notificationRuleServerAclDescription": {}, + "unknownPushRule": "அறியப்படாத புச் விதி '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "🎙️{duration} - {sender} இலிருந்து குரல் செய்தி", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "இந்த அறிவிப்பு அமைப்பை நீங்கள் நீக்கினால், இதை செயல்தவிர்க்க முடியாது.", + "@deletePushRuleCanNotBeUndone": {}, + "more": "மேலும்", + "@more": {}, + "shareKeysWith": "விசைகளைப் பகிரவும் ...", + "@shareKeysWith": {}, + "shareKeysWithDescription": "மறைகுறியாக்கப்பட்ட அரட்டைகளில் உங்கள் செய்திகளுடன் படிக்க எந்த சாதனங்களை நம்ப வேண்டும்?", + "@shareKeysWithDescription": {}, + "allDevices": "அனைத்து சாதனங்களும்", + "@allDevices": {}, + "crossVerifiedDevicesIfEnabled": "இயக்கப்பட்டால் சரிபார்க்கப்பட்ட சாதனங்களை குறுக்கு", + "@crossVerifiedDevicesIfEnabled": {}, + "crossVerifiedDevices": "குறுக்கு சரிபார்க்கப்பட்ட சாதனங்கள்", + "@crossVerifiedDevices": {}, + "verifiedDevicesOnly": "சரிபார்க்கப்பட்ட சாதனங்கள் மட்டுமே", + "@verifiedDevicesOnly": {}, + "takeAPhoto": "புகைப்படம் எடுக்கவும்", + "@takeAPhoto": {}, + "recordAVideo": "வீடியோவைப் பதிவுசெய்க", + "@recordAVideo": {}, + "optionalMessage": "(விரும்பினால்) செய்தி ...", + "@optionalMessage": {}, + "notSupportedOnThisDevice": "இந்த சாதனத்தில் ஆதரிக்கப்படவில்லை", + "@notSupportedOnThisDevice": {}, + "enterNewChat": "புதிய அரட்டையை உள்ளிடவும்", + "@enterNewChat": {}, + "approve": "ஒப்புதல்", + "@approve": {}, + "youHaveKnocked": "நீங்கள் தட்டிவிட்டீர்கள்", + "@youHaveKnocked": {}, + "pleaseWaitUntilInvited": "அறையில் இருந்து யாராவது உங்களை அழைக்கும் வரை தயவுசெய்து இப்போது காத்திருங்கள்.", + "@pleaseWaitUntilInvited": {}, + "commandHint_logout": "உங்கள் தற்போதைய சாதனத்தை பதிவு செய்க", + "@commandHint_logout": {}, + "commandHint_logoutall": "அனைத்து செயலில் உள்ள சாதனங்களையும் அனுப்புகிறது", + "@commandHint_logoutall": {}, + "displayNavigationRail": "மொபைலில் வழிசெலுத்தல் ரெயிலைக் காட்டு", + "@displayNavigationRail": {}, + "customReaction": "தனிப்பயன் எதிர்வினை", + "@customReaction": {}, + "moreEvents": "மேலும் நிகழ்வுகள்", + "@moreEvents": {}, + "declineInvitation": "அழைப்பை நிராகரிக்கவும்", + "@declineInvitation": {} +} diff --git a/lib/l10n/intl_te.arb b/lib/l10n/intl_te.arb new file mode 100644 index 000000000..21289814e --- /dev/null +++ b/lib/l10n/intl_te.arb @@ -0,0 +1,15 @@ +{ + "alwaysUse24HourFormat": "", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "notAnImage": "ఇమేజ్ ఫైల్ కాదు.", + "@notAnImage": {}, + "repeatPassword": "పాస్‌వర్డ్‌ను పునరావృతం చేయండి", + "@repeatPassword": {}, + "remove": "తొలగించు", + "@remove": { + "type": "String", + "placeholders": {} + } +} diff --git a/lib/l10n/intl_th.arb b/lib/l10n/intl_th.arb new file mode 100644 index 000000000..1d4371f24 --- /dev/null +++ b/lib/l10n/intl_th.arb @@ -0,0 +1,2152 @@ +{ + "hugContent": "{senderName} กอดคุณ", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_cuddle": "ส่งเคล้าเคลียให้", + "@commandHint_cuddle": {}, + "admin": "แอดมิน", + "@admin": { + "type": "String", + "placeholders": {} + }, + "supposedMxid": "อันนี้ควรเป็น {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "askSSSSSign": "เพื่อให้สามารถลงนามบุคคลอื่นได้ โปรดป้อนรหัสผ่านร้านค้าที่ปลอดภัยหรือรหัสกู้คืนของคุณ", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "remove": "ลบออก", + "@remove": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "ผู้ใช้ทั่วไปได้รับอนุญาตให้เข้าร่วมหรือไม่", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "ส่งเมื่อกด enter", + "@sendOnEnter": {}, + "answeredTheCall": "{senderName} รับสายแล้ว", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "alias": "นามแฝง", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "ทั้งหมด", + "@all": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "โฮมเซิร์ฟเวอร์รองรับประเภทการเข้าสู่ระบบ:\n{serverVersions}\nแต่แอปนี้รองรับเฉพาะ:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "edit": "แก้ไข", + "@edit": { + "type": "String", + "placeholders": {} + }, + "copy": "คัดลอก", + "@copy": { + "type": "String", + "placeholders": {} + }, + "importFromZipFile": "นำเข้าจากไฟล์ .zip", + "@importFromZipFile": {}, + "autoplayImages": "เล่นสติ๊กเกอร์และอิโมจิแบบเคลื่อนไหวโดยอัตโนมัติ", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "help": "ช่วยเหลือ", + "@help": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "รายละเอียดแชท", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "ใส่รหัสผ่านอีกรอบ", + "@repeatPassword": {}, + "delete": "ลบออก", + "@delete": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} ได้รับการชวนแล้ว", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "ส่ง", + "@send": { + "type": "String", + "placeholders": {} + }, + "exportEmotePack": "ส่งอิโมจิแพ็คออกเป็นไฟล์ .zip", + "@exportEmotePack": {}, + "account": "บัญชี", + "@account": { + "type": "String", + "placeholders": {} + }, + "chat": "แชท", + "@chat": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "คุณแน่ใจไหม?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "allChats": "แชททั้งหมด", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "เพิ่มไปที่ space", + "@addToSpace": {}, + "about": "เกี่ยวกับ", + "@about": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} เปิดใช้งาน end to end encryption", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "googlyEyesContent": "{senderName} ส่งตากวนๆให้คุณ", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "addChatDescription": "เพิ่มคำอธิบายการแชท", + "@addChatDescription": {}, + "appLock": "ล็อคแอป", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "sendTypingNotifications": "ส่งการแจ้งเตือนการพิมพ์", + "@sendTypingNotifications": {}, + "importEmojis": "นำเข้าอ๊โมจิ", + "@importEmojis": {}, + "confirmMatrixId": "กรุณายืนยัน Matrix ID ของคุณเพื่อลบบัญชีของคุณ", + "@confirmMatrixId": {}, + "notAnImage": "ไม่ใช่ไฟล์รูปภาพ", + "@notAnImage": {}, + "areYouSureYouWantToLogout": "คุณแน่ใจว่าคุณต้องการที่จะออกจากระบบ?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "cuddleContent": "{senderName} เคล้าเคลียคุณ", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "askVerificationRequest": "ยอมรับคำขอยืนยันนี้จาก {username} หรือไม่", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "เพิ่มอีเมล", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "commandHint_hug": "ส่งกอดให้", + "@commandHint_hug": {}, + "replace": "แทนที่", + "@replace": {}, + "archive": "คลังเก็บ", + "@archive": { + "type": "String", + "placeholders": {} + }, + "accept": "ยอมรับ", + "@accept": { + "type": "String", + "placeholders": {} + }, + "commandHint_googly": "ส่งสายตากวนๆ มาให้หน่อย", + "@commandHint_googly": {}, + "pin": "ปักหมุด", + "@pin": { + "type": "String", + "placeholders": {} + }, + "importNow": "นำเข้าเลย", + "@importNow": {}, + "anyoneCanJoin": "ใครๆ ก็สามารถเข้าร่วมได้", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "@connect": { + "type": "String", + "placeholders": {} + }, + "@jumpToLastReadMessage": {}, + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "@chats": { + "type": "String", + "placeholders": {} + }, + "@widgetVideo": {}, + "@dismiss": {}, + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "@reportErrorDescription": {}, + "@directChats": { + "type": "String", + "placeholders": {} + }, + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "@addAccount": {}, + "@close": { + "type": "String", + "placeholders": {} + }, + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "@chatHasBeenAddedToThisSpace": {}, + "@reply": { + "type": "String", + "placeholders": {} + }, + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "@unsupportedAndroidVersion": {}, + "@device": { + "type": "String", + "placeholders": {} + }, + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "@widgetJitsi": {}, + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "@encryption": { + "type": "String", + "placeholders": {} + }, + "@messageType": {}, + "@indexedDbErrorLong": {}, + "@oneClientLoggedOut": {}, + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "@unsupportedAndroidVersionLong": {}, + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "@startFirstChat": {}, + "@callingAccount": {}, + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@invited": { + "type": "String", + "placeholders": {} + }, + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "@setColorTheme": {}, + "@nextAccount": {}, + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "@warning": { + "type": "String", + "placeholders": {} + }, + "@password": { + "type": "String", + "placeholders": {} + }, + "@allSpaces": {}, + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "@user": {}, + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "@youAcceptedTheInvitation": {}, + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@banUserDescription": {}, + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "@widgetEtherpad": {}, + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "@id": { + "type": "String", + "placeholders": {} + }, + "@removeDevicesDescription": {}, + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "@tryAgain": {}, + "@blocked": { + "type": "String", + "placeholders": {} + }, + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "@unbanUserDescription": {}, + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "@youRejectedTheInvitation": {}, + "@otherCallingPermissions": {}, + "@messagesStyle": {}, + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "@link": {}, + "@widgetUrlError": {}, + "@emailOrUsername": {}, + "@newSpaceDescription": {}, + "@chatDescription": {}, + "@callingAccountDetails": {}, + "@next": { + "type": "String", + "placeholders": {} + }, + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "@enterSpace": {}, + "@encryptThisChat": {}, + "@fileName": { + "type": "String", + "placeholders": {} + }, + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "@previousAccount": {}, + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "@reopenChat": {}, + "@pleaseEnterRecoveryKey": {}, + "@create": { + "type": "String", + "placeholders": {} + }, + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "@no": { + "type": "String", + "placeholders": {} + }, + "@widgetNameError": {}, + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "@unpin": { + "type": "String", + "placeholders": {} + }, + "@addToBundle": {}, + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "@addWidget": {}, + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "@noKeyForThisMessage": {}, + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "@reason": { + "type": "String", + "placeholders": {} + }, + "@commandHint_markasgroup": {}, + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "@hydrateTor": {}, + "@pushNotificationsNotAvailable": {}, + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "@storeInAppleKeyChain": {}, + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "@hydrate": {}, + "@invalidServerName": {}, + "@chatPermissions": {}, + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "@sender": {}, + "@storeInAndroidKeystore": {}, + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "@online": { + "type": "String", + "placeholders": {} + }, + "@signInWithPassword": {}, + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "@offensive": { + "type": "String", + "placeholders": {} + }, + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "@makeAdminDescription": {}, + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "@saveKeyManuallyDescription": {}, + "@none": { + "type": "String", + "placeholders": {} + }, + "@editBundlesForAccount": {}, + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "@whyIsThisMessageEncrypted": {}, + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@setChatDescription": {}, + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "@or": { + "type": "String", + "placeholders": {} + }, + "@dehydrateWarning": {}, + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "@noOtherDevicesFound": {}, + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@storeSecurlyOnThisDevice": {}, + "@yourChatBackupHasBeenSetUp": {}, + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@submit": { + "type": "String", + "placeholders": {} + }, + "@videoCallsBetaWarning": {}, + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "@participant": { + "type": "String", + "placeholders": {} + }, + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "@yes": { + "type": "String", + "placeholders": {} + }, + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "@username": { + "type": "String", + "placeholders": {} + }, + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@fileIsTooBigForServer": {}, + "@homeserver": {}, + "@people": { + "type": "String", + "placeholders": {} + }, + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "@verified": { + "type": "String", + "placeholders": {} + }, + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "@callingPermissions": {}, + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "@readUpToHere": {}, + "@start": {}, + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "@register": { + "type": "String", + "placeholders": {} + }, + "@unlockOldMessages": {}, + "@identity": { + "type": "String", + "placeholders": {} + }, + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "@ignore": { + "type": "String", + "placeholders": {} + }, + "@recording": { + "type": "String", + "placeholders": {} + }, + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@moderator": { + "type": "String", + "placeholders": {} + }, + "@optionalRedactReason": {}, + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "@ok": { + "type": "String", + "placeholders": {} + }, + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "@dehydrate": {}, + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "@banned": { + "type": "String", + "placeholders": {} + }, + "@sendAsText": { + "type": "String" + }, + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "@archiveRoomDescription": {}, + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "@commandInvalid": { + "type": "String" + }, + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "@placeCall": {}, + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@newChat": { + "type": "String", + "placeholders": {} + }, + "@notifications": { + "type": "String", + "placeholders": {} + }, + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "@experimentalVideoCalls": {}, + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "@pleaseEnterRecoveryKeyDescription": {}, + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "@mention": { + "type": "String", + "placeholders": {} + }, + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "@inviteContactToGroupQuestion": {}, + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@group": { + "type": "String", + "placeholders": {} + }, + "@leave": { + "type": "String", + "placeholders": {} + }, + "@skip": { + "type": "String", + "placeholders": {} + }, + "@appearOnTopDetails": {}, + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "@enterRoom": {}, + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@reportUser": {}, + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@confirmEventUnpin": {}, + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "@license": { + "type": "String", + "placeholders": {} + }, + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "@redactMessageDescription": {}, + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "@recoveryKey": {}, + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "@forward": { + "type": "String", + "placeholders": {} + }, + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "@invalidInput": {}, + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "@dehydrateTorLong": {}, + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "@offline": { + "type": "String", + "placeholders": {} + }, + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "@doNotShowAgain": {}, + "@report": {}, + "@status": { + "type": "String", + "placeholders": {} + }, + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "@unverified": {}, + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "@serverRequiresEmail": {}, + "@hideUnimportantStateEvents": {}, + "@screenSharingTitle": {}, + "@widgetCustom": {}, + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "@addToSpaceDescription": {}, + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "@cancel": { + "type": "String", + "placeholders": {} + }, + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@publish": {}, + "@openLinkInBrowser": {}, + "@clearArchive": {}, + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "@messageInfo": {}, + "@disableEncryptionWarning": {}, + "@directChat": {}, + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "@inviteGroupChat": {}, + "@appearOnTop": {}, + "@invitePrivateChat": {}, + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "@foregroundServiceRunning": {}, + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "@voiceCall": {}, + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "@confirm": { + "type": "String", + "placeholders": {} + }, + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "@noChatDescriptionYet": {}, + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "@removeFromBundle": {}, + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "@learnMore": {}, + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "@you": { + "type": "String", + "placeholders": {} + }, + "@users": {}, + "@openGallery": {}, + "@chatDescriptionHasBeenChanged": {}, + "@search": { + "type": "String", + "placeholders": {} + }, + "@newGroup": {}, + "@bundleName": {}, + "@dehydrateTor": {}, + "@removeFromSpace": {}, + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "@roomUpgradeDescription": {}, + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "@scanQrCode": {}, + "@logout": { + "type": "String", + "placeholders": {} + }, + "@pleaseEnterANumber": {}, + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@profileNotFound": {}, + "@jump": {}, + "@groups": { + "type": "String", + "placeholders": {} + }, + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "@sorryThatsNotPossible": {}, + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "@shareInviteLink": {}, + "@commandHint_markasdm": {}, + "@recoveryKeyLost": {}, + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "@messages": { + "type": "String", + "placeholders": {} + }, + "@login": { + "type": "String", + "placeholders": {} + }, + "@deviceKeys": {}, + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "@settings": { + "type": "String", + "placeholders": {} + }, + "@setTheme": {}, + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "@youJoinedTheChat": {}, + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "@security": { + "type": "String", + "placeholders": {} + }, + "@markAsRead": {}, + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "@widgetName": {}, + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@errorAddingWidget": {}, + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "@reject": { + "type": "String", + "placeholders": {} + }, + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "@newSpace": {}, + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "@devices": { + "type": "String", + "placeholders": {} + }, + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "@emojis": {}, + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "@share": { + "type": "String", + "placeholders": {} + }, + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "@createGroup": {}, + "@privacy": { + "type": "String", + "placeholders": {} + }, + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "@hydrateTorLong": {}, + "@time": {}, + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "@custom": {}, + "@noBackupWarning": {}, + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "@verify": { + "type": "String", + "placeholders": {} + }, + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "@storeInSecureStorageDescription": {}, + "@openChat": {}, + "@kickUserDescription": {}, + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "@pinMessage": {}, + "@screenSharingDetail": {}, + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "@invite": {}, + "@enableMultiAccounts": {}, + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "@indexedDbErrorTitle": {}, + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + } +} diff --git a/lib/l10n/intl_tr.arb b/lib/l10n/intl_tr.arb new file mode 100644 index 000000000..a59752e08 --- /dev/null +++ b/lib/l10n/intl_tr.arb @@ -0,0 +1,3211 @@ +{ + "@@locale": "tr", + "@@last_modified": "2021-08-14 12:41:09.803728", + "about": "Hakkında", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Kabul et", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} katılma davetini kabul etti", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Hesap", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} uçtan uca şifrelemeyi etkinleştirdi", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "E-posta ekle", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Alana ekle", + "@addToSpace": {}, + "admin": "Yönetici", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "takma ad", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Tümü", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Tüm sohbetler", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} aramayı yanıtladı", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Herkes katılabilir", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Uygulama kilidi", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "Arşiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Misafir kullanıcıların katılmasına izin veriliyor mu", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Emin misiniz?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Oturumu açmak istediğinizden emin misiniz?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Diğer kişiyi imzalayabilmek için lütfen güvenli depolama parolanızı veya kurtarma anahtarınızı girin.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "{username} kişisinden gelen bu doğrulama isteği kabul edilsin mi?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Canlandırmalı çıkartmaları ve ifadeleri otomatik olarak oynat", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "badServerLoginTypesException": "Ana sunucu aşağıdaki oturum açma türlerini destekliyor:\n{serverVersions}\nAncak bu uygulama yalnızca aşağıdakileri destekliyor:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "Ana sunucu aşağıdaki Spec sürümlerini destekliyor:\n{serverVersions}\nAncak bu uygulama yalnızca {supportedVersions} destekliyor", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "Sohbetten engelle", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Engellendi", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username}, {targetName} kişisini engelledi", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Aygıtı Engelle", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Engellendi", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot mesajları", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "İptal", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "{uri} URI'si açılamıyor", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Aygıt adını değiştir", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} sohbet avatarını değiştirdi", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} sohbet açıklamasını değiştirdi: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} sohbet adını değiştirdi: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} sohbet izinlerini değiştirdi", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} görünen adını '{displayname}' olarak değiştirdi", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} misafir erişim kurallarını değiştirdi", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} misafir erişim kurallarını değiştirdi: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} geçmiş görünürlüğünü değiştirdi", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} geçmiş görünürlüğünü değiştirdi: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} katılım kurallarını değiştirdi", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} katılım kurallarını değiştirdi: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} avatarını değiştirdi", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} oda takma adlarını değiştirdi", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} davet bağlantısını değiştirdi", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Parolayı değiştir", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Ana sunucuyu değiştir", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Tarzınızı değiştirin", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Grubun adını değiştir", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Avatarınızı değiştirin", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Şifreleme bozuldu", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Sohbet", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Sohbet yedekleme", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Eski mesajlarınız bir kurtarma anahtarı ile güvence altına alındı. Lütfen kaybetmediğinizden emin olun.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Sohbet ayrıntıları", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Sohbet bu alana eklendi", + "@chatHasBeenAddedToThisSpace": {}, + "chats": "Sohbetler", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Güçlü bir parola seçin", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Arşivi temizle", + "@clearArchive": {}, + "close": "Kapat", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "Verilen kullanıcıyı bu odadan yasaklayın", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "HTML biçimli metin gönderin", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Verilen kullanıcıyı bu odaya davet edin", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Verilen odaya katılın", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Verilen kullanıcıyı bu odadan kaldırın", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Bu odadan ayrılın", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Kendinizi tanımlayın", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Bu oda için resminizi ayarlayın (mxc-uri ile)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Bu oda için görünen adınızı ayarlayın", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Verilen kullanıcının güç seviyesini ayarlayın (öntanımlı: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Biçimlendirilmemiş metin gönderin", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Tepki olarak yanıt gönderin", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Metin gönderin", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Verilen kullanıcının bu odadaki yasağını kaldırın", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Komut geçersiz", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} bir komut değil.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Lütfen emojileri karşılaştırın", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Lütfen sayıları karşılaştırın", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Sohbeti yapılandır", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Onayla", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Bağlan", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kişi gruba davet edildi", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Görünen ad içerir", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Kullanıcı adı içerir", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "İçerik, sunucu yöneticilerine bildirildi", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Panoya kopyalandı", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Kopyala", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Panoya kopyala", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Mesajın şifresi çözülemedi: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} katılımcı", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Oluştur", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} sohbeti oluşturdu", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createNewSpace": "Yeni alan", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Şu anda etkin", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Koyu", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day} {month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}/{month}/{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Bu, kullanıcı hesabınızı devre dışı bırakacak. Bu geri alınamaz! Emin misiniz?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Yeni kullanıcılar içi öntanımlı izin seviyesi", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Sil", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Hesabı sil", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Mesajı sil", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Aygıt", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Aygıt kimliği", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Aygıtlar", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Doğrudan Sohbetler", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Görünen ad değiştirildi", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Dosyayı indir", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Düzenle", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Engellenen sunucuları düzenle", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Görünen adı düzenle", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Oda takma adlarını düzenle", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Oda avatarını düzenle", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "İfade zaten var!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Geçersiz ifade kısa kodu!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Oda için ifade paketleri", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "İfade Ayarları", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "İfade kısa kodu", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Bir ifade kısa kodu ve bir resim seçmeniz gerekiyor!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Boş sohbet", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "İfade paketini küresel olarak etkinleştir", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Şifrelemeyi etkinleştir", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Artık şifrelemeyi devre dışı bırakamayacaksınız. Emin misiniz?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Şifreli", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Şifreleme", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Şifreleme etkinleştirilmedi", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} aramayı sonlandırdı", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Bir e-posta adresi girin", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "Ana sunucunuzu girin", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Konum alınırken hata oluştu: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Herşey hazır!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "Aşırı rahatsız edici", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Dosya adı", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Yazı tipi boyutu", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "İlet", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Katılmadan", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Davetten", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Yeni odaya git", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Grup", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Grup herkese açık", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Gruplar", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "{displayname} ile grup", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Misafirlere izin verilmiyor", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Misafirler katılabilir", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username}, {targetName} için daveti geri çekti", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Yardım", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Düzenlenmiş etkinlikleri gizle", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "Bilinmeyen etkinlikleri gizle", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Bu içerik ne kadar rahatsız edici?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "Kimlik", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Kimlik", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "Yok say", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Yok sayılan kullanıcılar", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Bağlantıya tıkladım", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Yanlış parola veya kurtarma anahtarı", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Rahatsız edici değil", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Kişi davet et", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Kişiyi {groupName} grubuna davet et", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Davet edildi", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username}, {targetName} kişisini davet etti", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Sadece davet edilen kullanıcılar", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Benim için davet et", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} sizi FluffyChat'e davet etti.\n1. fluffychat.im adresini ziyaret edin ve uygulamayı kurun \n2. Kaydolun veya oturum açın \n3. Davet bağlantısını açın: \n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "yazıyor…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} sohbete katıldı", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Odaya katıl", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username}, {targetName} kişisini attı", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username}, {targetName} kişisini attı ve engelledi", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Sohbetten at", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Son görülen: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Ayrıl", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Sohbetten ayrıldı", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Lisans", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Açık", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "{count} katılımcı daha yükle", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Yükleniyor… Lütfen bekleyin.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Daha fazla yükle…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Konum hizmetleri devre dışı. Lütfen konumunuzu paylaşabilmek için etkinleştirin.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Konum izni reddedildi. Lütfen konumunuzu paylaşabilmek için izin verin.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Oturum aç", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "{homeserver} üzerinde oturum aç", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Oturumu kapat", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Üye değişiklikleri", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Bahset", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Mesajlar", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "Moderatör", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Sohbeti sessize al", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Uçtan uca şifreleme kullanmak için şimdilik Pantalaimon'a ihtiyacınız olduğunu lütfen unutmayın.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Yeni sohbet", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 FluffyChat'te yeni mesaj", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Yeni doğrulama isteği!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "İleri", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Hayır", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Sunucuyla bağlantı yok", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "İfade bulunamadı. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Şifrelemeyi yalnızca oda artık herkese açık olmadığında etkinleştirebilirsiniz.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Görünüşe göre cihazınızda Firebase Cloud Messaging yok. Buna rağmen bildirim almaya devam etmek için ntfy yüklemenizi öneriyoruz. ntfy veya başka bir Unified Push sağlayıcısı ile anlık bildirimlerinizi güvenli bir şekilde alabilirsiniz. ntfy'ı PlayStore veya F-Droid'den indirebilirsiniz.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} matrix sunucusu değil, onun yerine {server2} kullanılsın mı?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "none": "Yok", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Henüz parolanızı kurtarmak için bir yol eklemediniz.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "İzin yok", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Oda bulunamadı…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Bildirimler", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Bu hesap için bildirimler etkinleştirildi", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} kullanıcı yazıyor…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Konum alınıyor…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Rahatsız edici", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Çevrim dışı", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Tamam", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Çevrim içi", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Çevrim içi anahtar yedekleme etkinleştirildi", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Tüh! Maalesef anlık bildirimlerini ayarlarken bir hata oluştu.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Tüh, bir şeyler yanlış gitti…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Mesajları okumak için uygulamayı aç", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Kamerayı aç", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "Haritalarda aç", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "or": "Veya", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Katılımcı", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "parola veya kurtarma anahtarı", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Parola", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Parola unutuldu", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Parola değiştirildi", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Parola kurtarma", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "İnsanlar", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Bir resim seç", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Sabitle", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "{fileName} dosyasını oynat", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Lütfen seçin", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Lütfen bir geçiş kodu seçin", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Lütfen e-postadaki bağlantıya tıklayın ve devam edin.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Lütfen 4 basamak girin veya uygulama kilidini devre dışı bırakmak için boş bırakın.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "Lütfen parolanızı girin", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Lütfen PIN kodunuzu girin", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Lütfen kullanıcı adınızı girin", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Lütfen web sitesindeki talimatları izleyin ve \"İleri\" düğmesine dokunun.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Gizlilik", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Herkese Açık Odalar", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Gönderme kuralları", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Neden", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Kaydediliyor", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} bir etkinliği düzenledi", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Mesajı düzenle", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Kaydol", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Reddet", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} daveti reddetti", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Yeniden katıl", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Kaldır", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Diğer tüm aygıtları kaldır", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "{username} tarafından kaldırıldı", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Aygıtı kaldır", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Sohbet engelini kaldır", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Avatarınızı kaldırın", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Odayı yeni sürümle değiştir", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Yanıtla", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Mesajı bildir", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "İzin iste", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Oda yükseltildi", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Oda sürümü", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Dosyayı kaydet", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Ara", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Güvenlik", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "{username} tarafından görüldü", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Gönder", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Bir mesaj gönder", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Metin olarak gönder", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Ses gönder", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Dosya gönder", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Resim gönder", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Mesajları gönder", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Orijinali gönder", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Çıkartma gönder", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Video gönder", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} bir dosya gönderdi", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} bir ses gönderdi", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} bir resim gönderdi", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} bir çıkartma gönderdi", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} bir video gönderdi", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} arama bilgilerini gönderdi", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "Ana takma ad olarak ayarla", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Özel ifadeler ayarla", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "Davet bağlantısı ayarla", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "İzin seviyesini ayarla", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Durumu ayarla", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Ayarlar", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Paylaş", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} konumunu paylaştı", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Konumu paylaş", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Parolayı göster", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Tek oturum açma", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Atla", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Kaynak kodları", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Alan herkese açık", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Alan adı", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} bir arama başlattı", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "Durum", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Bugün nasılsınız?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Gönder", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Eşzamanlanıyor… Lütfen bekleyin.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Sistem", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Eşleşmediler", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Eşleştiler", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Sık Kullanılanlara Ekle/Çıkar", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "Sessize Al/Sessizden Çıkar", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Okundu/Okunmadı Olarak İşaretle", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Çok fazla istek. Lütfen daha sonra tekrar deneyin!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Başka bir aygıttan aktar", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Tekrar göndermeyi deneyin", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Yok", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username}, {targetName} kişisinin engelini kaldırdı", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Aygıtın Engellemesini Kaldır", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Bilinmeyen aygıt", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Bilinmeyen şifreleme algoritması", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Bilinmeyen etkinlik '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Sohbeti sessizden çıkar", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Sabitlemeyi kaldır", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 okunmamış sohbet} other{{unreadCount} okunmamış sohbet}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} ve {count} diğer kişi yazıyor…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} ve {username2} yazıyor…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} yazıyor…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} sohbetten ayrıldı", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Kullanıcı adı", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} bir {type} etkinliği gönderdi", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "Doğrulandı", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Doğrula", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Doğrulamayı Başlat", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Başarıyla doğrulandı!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Diğer hesap doğrulanıyor", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Görüntülü arama", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Sohbet geçmişi görünürlüğü", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Tüm katılımcılar için görünür", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Herkes için görünür", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Sesli mesaj", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Ortağın isteği kabul etmesi bekleniyor…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Ortağın emojiyi kabul etmesi bekleniyor…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Ortağın numaraları kabul etmesi bekleniyor…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Duvar kağıdı:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Uyarı!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Size bir e-posta gönderdik", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Kim hangi eylemi gerçekleştirebilir", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Bu gruba kimler katılabilir", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Bunu neden bildirmek istiyorsunuz?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Yeni bir kurtarma anahtarı oluşturmak için sohbet yedeğiniz silinsin mi?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Bu adresler ile parolanızı kurtarabilirsiniz.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Bir mesaj yaz…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Evet", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Sen", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Artık bu sohbette katılımcı değilsiniz", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Bu sohbetten engellendiniz", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Ortak anahtarınız", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "QR kodunu tarayın", + "@scanQrCode": {}, + "sendOnEnter": "Enter tuşu ile gönder", + "@sendOnEnter": {}, + "homeserver": "Ana sunucu", + "@homeserver": {}, + "serverRequiresEmail": "Bu sunucunun kayıt için e-posta adresinizi doğrulaması gerekiyor.", + "@serverRequiresEmail": {}, + "enableMultiAccounts": "(BETA) Bu aygıtta çoklu hesapları etkinleştir", + "@enableMultiAccounts": {}, + "bundleName": "Paket adı", + "@bundleName": {}, + "removeFromBundle": "Bu paketten kaldır", + "@removeFromBundle": {}, + "addToBundle": "Pakete ekle", + "@addToBundle": {}, + "editBundlesForAccount": "Bu hesap için paketleri düzenle", + "@editBundlesForAccount": {}, + "addAccount": "Hesap ekle", + "@addAccount": {}, + "oneClientLoggedOut": "İstemcilerinizden birinin oturumu kapatıldı", + "@oneClientLoggedOut": {}, + "link": "Bağlantı", + "@link": {}, + "yourChatBackupHasBeenSetUp": "Sohbet yedeklemeniz ayarlandı.", + "@yourChatBackupHasBeenSetUp": {}, + "unverified": "Doğrulanmadı", + "@unverified": {}, + "repeatPassword": "Parolayı tekrarlayın", + "@repeatPassword": {}, + "messageInfo": "Mesaj bilgileri", + "@messageInfo": {}, + "time": "Zaman", + "@time": {}, + "messageType": "Mesaj Türü", + "@messageType": {}, + "sender": "Gönderen", + "@sender": {}, + "openGallery": "Galeriyi aç", + "@openGallery": {}, + "removeFromSpace": "Alandan kaldır", + "@removeFromSpace": {}, + "addToSpaceDescription": "Bu sohbeti eklemek için bir alan seçin.", + "@addToSpaceDescription": {}, + "start": "Başla", + "@start": {}, + "commandHint_clearcache": "Önbelleği temizleyin", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_dm": "Doğrudan sohbet başlatın\nŞifrelemeyi devre dışı bırakmak için --no-encryption kullanın", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_create": "Boş bir grup sohbeti oluşturun\nŞifrelemeyi devre dışı bırakmak için --no-encryption kullanın", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Oturumu silin", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "openVideoCamera": "Bir video için kamerayı aç", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "publish": "Yayınla", + "@publish": {}, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "dismiss": "Kapat", + "@dismiss": {}, + "markAsRead": "Okundu olarak işaretle", + "@markAsRead": {}, + "reportUser": "Kullanıcıyı bildir", + "@reportUser": {}, + "openChat": "Sohbeti Aç", + "@openChat": {}, + "reactedWith": "{sender}, {reaction} ile tepki verdi", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "emojis": "Emojiler", + "@emojis": {}, + "placeCall": "Arama yap", + "@placeCall": {}, + "voiceCall": "Sesli arama", + "@voiceCall": {}, + "unsupportedAndroidVersion": "Desteklenmeyen Android sürümü", + "@unsupportedAndroidVersion": {}, + "unsupportedAndroidVersionLong": "Bu özellik daha yeni bir Android sürümü gerektiriyor. Lütfen güncellemelere veya LineageOS desteğine bakın.", + "@unsupportedAndroidVersionLong": {}, + "pinMessage": "Odaya sabitle", + "@pinMessage": {}, + "confirmEventUnpin": "Etkinliğin sabitlemesini kalıcı olarak kaldırmak istediğinizden emin misiniz?", + "@confirmEventUnpin": {}, + "videoCallsBetaWarning": "Görüntülü aramaların şu anda beta aşamasında olduğunu lütfen unutmayın. Tüm platformlarda beklendiği gibi veya hiç çalışmayabilirler.", + "@videoCallsBetaWarning": {}, + "experimentalVideoCalls": "Deneysel görüntülü aramalar", + "@experimentalVideoCalls": {}, + "emailOrUsername": "E-posta veya kullanıcı adı", + "@emailOrUsername": {}, + "switchToAccount": "{number}. hesaba geç", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Sonraki hesap", + "@nextAccount": {}, + "previousAccount": "Önceki hesap", + "@previousAccount": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "widgetCustom": "Özel", + "@widgetCustom": {}, + "widgetUrlError": "Bu geçerli bir URL değil.", + "@widgetUrlError": {}, + "widgetNameError": "Lütfen görünecek bir ad girin.", + "@widgetNameError": {}, + "errorAddingWidget": "Widget eklenirken hata oluştu.", + "@errorAddingWidget": {}, + "widgetVideo": "Video", + "@widgetVideo": {}, + "addWidget": "Widget ekle", + "@addWidget": {}, + "widgetEtherpad": "Metin notu", + "@widgetEtherpad": {}, + "widgetName": "Ad", + "@widgetName": {}, + "separateChatTypes": "Doğrudan Sohbetleri ve Grupları Ayır", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youJoinedTheChat": "Sohbete katıldınız", + "@youJoinedTheChat": {}, + "youAcceptedTheInvitation": "👍 Daveti kabul ettiniz", + "@youAcceptedTheInvitation": {}, + "youKickedAndBanned": "🙅 {user} kullanıcısını attınız ve yasakladınız", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "{user} kullanıcısının yasağını kaldırdınız", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 {user} kullanıcısını attınız", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youRejectedTheInvitation": "Daveti reddettiniz", + "@youRejectedTheInvitation": {}, + "youHaveWithdrawnTheInvitationFor": "{user} için daveti geri çektiniz", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 {user} tarafından davet edildiniz", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 {user} kullanıcısını davet ettiniz", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youBannedUser": "{user} kullanıcısını yasakladınız", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "storeInAppleKeyChain": "Apple KeyChain'de sakla", + "@storeInAppleKeyChain": {}, + "pleaseEnterRecoveryKey": "Lütfen kurtarma anahtarınızı girin:", + "@pleaseEnterRecoveryKey": {}, + "recoveryKeyLost": "Kurtarma anahtarı kayıp mı?", + "@recoveryKeyLost": {}, + "pleaseEnterRecoveryKeyDescription": "Eski mesajlarınızın kilidini açmak için lütfen önceki bir oturumda oluşturulan kurtarma anahtarınızı girin. Kurtarma anahtarınız parolanız DEĞİLDİR.", + "@pleaseEnterRecoveryKeyDescription": {}, + "users": "Kullanıcılar", + "@users": {}, + "storeInSecureStorageDescription": "Kurtarma anahtarını bu aygıtın güvenli deposunda saklayın.", + "@storeInSecureStorageDescription": {}, + "recoveryKey": "Kurtarma anahtarı", + "@recoveryKey": {}, + "storeInAndroidKeystore": "Android KeyStore'da sakla", + "@storeInAndroidKeystore": {}, + "unlockOldMessages": "Eski mesajların kilidini aç", + "@unlockOldMessages": {}, + "saveKeyManuallyDescription": "Sistem paylaşımı iletişim kutusunu veya panoyu tetikleyerek bu anahtarı elle kaydedin.", + "@saveKeyManuallyDescription": {}, + "storeSecurlyOnThisDevice": "Bu aygıtta güvenli bir şekilde sakla", + "@storeSecurlyOnThisDevice": {}, + "countFiles": "{count} dosya", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrate": "Oturumu dışa aktar ve aygıtı sil", + "@dehydrate": {}, + "dehydrateTorLong": "TOR kullanıcıları için, pencereyi kapatmadan önce oturumu dışa aktarmaları tavsiye edilir.", + "@dehydrateTorLong": {}, + "dehydrateTor": "TOR Kullanıcıları: Oturumu dışa aktar", + "@dehydrateTor": {}, + "hydrateTor": "TOR Kullanıcıları: Dışa aktarılan oturumu içe aktar", + "@hydrateTor": {}, + "hydrate": "Yedekleme dosyasından geri yükle", + "@hydrate": {}, + "indexedDbErrorTitle": "Gizli mod sorunları", + "@indexedDbErrorTitle": {}, + "dehydrateWarning": "Bu eylem geri alınamaz. Yedekleme dosyasını güvenli bir şekilde sakladığınızdan emin olun.", + "@dehydrateWarning": {}, + "hydrateTorLong": "TOR'da en son oturumunuzu dışa aktardınız mı? Hızlıca içe aktarın ve sohbete devam edin.", + "@hydrateTorLong": {}, + "indexedDbErrorLong": "Mesaj saklama özelliği ne yazık ki öntanımlı olarak gizli modda etkin değildir.\nLütfen\n - about:config sayfasına gidin ve\n - dom.indexedDB.privateBrowsing.enabled seçeneğini true olarak ayarlayın\nAksi takdirde FluffyChat çalıştırılamaz.", + "@indexedDbErrorLong": {}, + "user": "Kullanıcı", + "@user": {}, + "custom": "Özel", + "@custom": {}, + "confirmMatrixId": "Hesabınızı silmek için lütfen Matrix kimliğinizi doğrulayın.", + "@confirmMatrixId": {}, + "supposedMxid": "Bu {mxid} olmalıdır", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "Grup olarak işaretle", + "@commandHint_markasgroup": {}, + "commandHint_markasdm": "Verilen Matrix kimliği için doğrudan mesaj odası olarak işaretle", + "@commandHint_markasdm": {}, + "whyIsThisMessageEncrypted": "Bu mesaj neden okunamıyor?", + "@whyIsThisMessageEncrypted": {}, + "noKeyForThisMessage": "Bu durum, mesaj siz bu aygıtta hesabınızda oturum açmadan önce gönderildiyse meydana gelebilir.\n\nGönderenin aygıtınızı engellemiş olması veya internet bağlantısında bir sorun olması da mümkündür.\n\nMesajı başka bir oturumda okuyabiliyor musunuz? O zaman mesajı oradan aktarabilirsiniz! Ayarlar > Aygıtlar bölümüne gidin ve aygıtlarınızın birbirini doğruladığından emin olun. Odayı bir sonraki sefer açtığınızda ve her iki oturum da ön planda olduğunda, anahtarlar otomatik olarak iletilecektir.\n\nOturumu kapatırken veya aygıt değiştirirken anahtarları kaybetmek istemiyor musunuz? Ayarlarda sohbet yedeklemesini etkinleştirdiğinizden emin olun.", + "@noKeyForThisMessage": {}, + "screenSharingTitle": "ekran paylaşımı", + "@screenSharingTitle": {}, + "callingPermissions": "Arama izinleri", + "@callingPermissions": {}, + "callingAccountDetails": "FluffyChat'in yerel android telefon uygulamasını kullanmasına izin verir.", + "@callingAccountDetails": {}, + "appearOnTop": "Üstte görün", + "@appearOnTop": {}, + "enterSpace": "Alana gir", + "@enterSpace": {}, + "enterRoom": "Odaya gir", + "@enterRoom": {}, + "allSpaces": "Tüm alanlar", + "@allSpaces": {}, + "otherCallingPermissions": "Mikrofon, kamera ve diğer FluffyChat izinleri", + "@otherCallingPermissions": {}, + "foregroundServiceRunning": "Bu bildirim, ön plan hizmeti çalışırken görünür.", + "@foregroundServiceRunning": {}, + "callingAccount": "Arama hesabı", + "@callingAccount": {}, + "appearOnTopDetails": "Uygulamanın üstte görünmesine izin verir (Fluffychat'ı zaten bir arama hesabı olarak ayarladıysanız gerekli değildir)", + "@appearOnTopDetails": {}, + "newGroup": "Yeni grup", + "@newGroup": {}, + "newSpace": "Yeni alan", + "@newSpace": {}, + "screenSharingDetail": "Ekranınızı FuffyChat'te paylaşıyorsunuz", + "@screenSharingDetail": {}, + "numChats": "{number} sohbet", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Önemsiz durum etkinliklerini gizle", + "@hideUnimportantStateEvents": {}, + "doNotShowAgain": "Tekrar gösterme", + "@doNotShowAgain": {}, + "googlyEyesContent": "{senderName} size şaşkın gözler gönderiyor", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_cuddle": "Kucaklama gönder", + "@commandHint_cuddle": {}, + "commandHint_googly": "Şaşkın gözler gönder", + "@commandHint_googly": {}, + "commandHint_hug": "Sarılma gönder", + "@commandHint_hug": {}, + "cuddleContent": "{senderName} sizi kucaklıyor", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} size sarılıyor", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "wasDirectChatDisplayName": "Boş sohbet ({oldDisplayName} idi)", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "startFirstChat": "İlk sohbetinizi başlatın", + "@startFirstChat": {}, + "newSpaceDescription": "Alanlar, sohbetlerinizi birleştirmenize ve özel veya genel topluluklar oluşturmanıza olanak tanır.", + "@newSpaceDescription": {}, + "encryptThisChat": "Bu sohbeti şifrele", + "@encryptThisChat": {}, + "disableEncryptionWarning": "Güvenlik nedeniyle, daha önce etkinleştirildiği bir sohbette şifrelemeyi devre dışı bırakamazsınız.", + "@disableEncryptionWarning": {}, + "sorryThatsNotPossible": "Üzgünüm... bu mümkün değil", + "@sorryThatsNotPossible": {}, + "deviceKeys": "Aygıt anahtarları:", + "@deviceKeys": {}, + "reopenChat": "Sohbeti yeniden aç", + "@reopenChat": {}, + "noBackupWarning": "Uyarı! Sohbet yedeklemesini etkinleştirmezseniz, şifrelenen mesajlarınıza erişiminizi kaybedersiniz. Oturumu kapatmadan önce sohbet yedeklemesini etkinleştirmeniz önemle tavsiye edilir.", + "@noBackupWarning": {}, + "noOtherDevicesFound": "Başka aygıt bulunamadı", + "@noOtherDevicesFound": {}, + "fileIsTooBigForServer": "Gönderilemiyor! Sunucu yalnızca {max} değerine kadar olan ekleri destekliyor.", + "@fileIsTooBigForServer": {}, + "fileHasBeenSavedAt": "Dosya {path} konumuna kaydedildi", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Son okunan mesaja atla", + "@jumpToLastReadMessage": {}, + "readUpToHere": "Buraya kadar oku", + "@readUpToHere": {}, + "jump": "Atla", + "@jump": {}, + "openLinkInBrowser": "Bağlantıyı tarayıcıda aç", + "@openLinkInBrowser": {}, + "allRooms": "Tüm Grup Sohbetleri", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "😭 Olamaz. Bir şeyler yanlış gitti. İsterseniz bu hatayı geliştiricilere bildirebilirsiniz.", + "@reportErrorDescription": {}, + "report": "bildir", + "@report": {}, + "signInWithPassword": "Parola ile oturum aç", + "@signInWithPassword": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "Lütfen daha sonra tekrar deneyin veya farklı bir sunucu seçin.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "signInWith": "{provider} ile oturum aç", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Bir resim dosyası değil.", + "@notAnImage": {}, + "importNow": "Şimdi içe aktar", + "@importNow": {}, + "importEmojis": "İfadeleri İçe Aktar", + "@importEmojis": {}, + "importFromZipFile": ".zip dosyasından içe aktar", + "@importFromZipFile": {}, + "exportEmotePack": "İfade paketini .zip olarak dışa aktar", + "@exportEmotePack": {}, + "replace": "Değiştir", + "@replace": {}, + "sendTypingNotifications": "Yazma bildirimleri gönder", + "@sendTypingNotifications": {}, + "messagesStyle": "Mesajlar:", + "@messagesStyle": {}, + "createGroup": "Grup oluştur", + "@createGroup": {}, + "shareInviteLink": "Davet bağlantısını paylaş", + "@shareInviteLink": {}, + "profileNotFound": "Kullanıcı sunucuda bulunamadı. Belki bir bağlantı sorunu vardır veya kullanıcı mevcut değildir.", + "@profileNotFound": {}, + "setTheme": "Temayı ayarla:", + "@setTheme": {}, + "setColorTheme": "Renk temasını ayarla:", + "@setColorTheme": {}, + "inviteContactToGroupQuestion": "{contact} kişisini \"{groupName}\" sohbetine davet etmek istiyor musunuz?", + "@inviteContactToGroupQuestion": {}, + "tryAgain": "Tekrar deneyin", + "@tryAgain": {}, + "redactMessageDescription": "Bu mesaj bu görüşmedeki herkes için düzenlenecek. Bu işlem geri alınamaz.", + "@redactMessageDescription": {}, + "optionalRedactReason": "(İsteğe bağlı) Bu mesajı düzenleme nedeni…", + "@optionalRedactReason": {}, + "invite": "Davet et", + "@invite": {}, + "addChatDescription": "Sohbet açıklaması ekle...", + "@addChatDescription": {}, + "chatPermissions": "Sohbet izinleri", + "@chatPermissions": {}, + "chatDescription": "Sohbet açıklaması", + "@chatDescription": {}, + "noChatDescriptionYet": "Daha sohbet açıklaması oluşturulmadı.", + "@noChatDescriptionYet": {}, + "invalidServerName": "Geçersiz sunucu adı", + "@invalidServerName": {}, + "redactedBy": "{username} tarafından düzenlendi", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactedByBecause": "{username} tarafından \"{reason}\" nedeniyle düzenlendi", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "setChatDescription": "Sohbet açıklamasını ayarla", + "@setChatDescription": {}, + "chatDescriptionHasBeenChanged": "Sohbet açıklaması değişti", + "@chatDescriptionHasBeenChanged": {}, + "directChat": "Doğrudan sohbet", + "@directChat": {}, + "inviteGroupChat": "📨 Grup sohbetine davet et", + "@inviteGroupChat": {}, + "invitePrivateChat": "📨 Gizli sohbete davet et", + "@invitePrivateChat": {}, + "emoteKeyboardNoRecents": "Son kullanılan ifadeler burada görünecek...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "invalidInput": "Geçersiz giriş!", + "@invalidInput": {}, + "wrongPinEntered": "Yanlış PIN girildi! {seconds} saniye sonra tekrar deneyin...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "banUserDescription": "Kullanıcı sohbetten yasaklanacak ve yasağı kaldırılana kadar sohbete tekrar giremeyecek.", + "@banUserDescription": {}, + "removeDevicesDescription": "Bu aygıttan çıkış yapacaksınız ve artık mesaj alamayacaksınız.", + "@removeDevicesDescription": {}, + "unbanUserDescription": "Kullanıcı denerse sohbete tekrar girebilecektir.", + "@unbanUserDescription": {}, + "pushNotificationsNotAvailable": "Anlık bildirimler kullanılamıyor", + "@pushNotificationsNotAvailable": {}, + "makeAdminDescription": "Bu kullanıcıyı yönetici yaptıktan sonra, sizinle aynı izinlere sahip olacağı için bunu geri alamayabilirsiniz.", + "@makeAdminDescription": {}, + "archiveRoomDescription": "Sohbet arşive taşınacak. Diğer kullanıcıları sohbeti terk ettiğinizi görebilecek.", + "@archiveRoomDescription": {}, + "hasKnocked": "🚪 {user} tıklattı", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "learnMore": "Daha fazla bilgi", + "@learnMore": {}, + "roomUpgradeDescription": "Sohbet daha sonra yeni oda sürümüyle yeniden oluşturulacaktır. Tüm katılımcılara yeni sohbete geçmeleri gerektiği bildirilecektir. Oda sürümleri hakkında daha fazla bilgiyi https://spec.matrix.org/latest/rooms/ adresinde bulabilirsiniz.", + "@roomUpgradeDescription": {}, + "pleaseEnterANumber": "Lütfen 0'dan büyük bir sayı girin", + "@pleaseEnterANumber": {}, + "kickUserDescription": "Kullanıcı sohbetten atılır ancak yasaklanmaz. Herkese açık sohbetlerde kullanıcı istediği zaman yeniden katılabilir.", + "@kickUserDescription": {}, + "createGroupAndInviteUsers": "Bir grup oluşturun ve kullanıcıları davet edin", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "Grup, arama ile bulunabilir", + "@groupCanBeFoundViaSearch": {}, + "noUsersFoundWithQuery": "Ne yazık ki \"{query}\" ile kullanıcı bulunamadı. Lütfen bir yazım hatası yapıp yapmadığınızı kontrol edin.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "yourGlobalUserIdIs": "Genel kullanıcı kimliğiniz: ", + "@yourGlobalUserIdIs": {}, + "groupName": "Grup ismi", + "@groupName": {}, + "searchChatsRooms": "#sohbetler, @kullanıcılar... için arama yapın", + "@searchChatsRooms": {}, + "blockListDescription": "Sizi rahatsız eden kullanıcıları engelleyebilirsiniz. Kişisel engelleme listenizdeki kullanıcılardan herhangi bir mesaj veya oda daveti alamazsınız.", + "@blockListDescription": {}, + "startConversation": "Görüşme başlat", + "@startConversation": {}, + "blockedUsers": "Engellenen kullanıcılar", + "@blockedUsers": {}, + "block": "Engelle", + "@block": {}, + "commandHint_sendraw": "Ham JSON gönder", + "@commandHint_sendraw": {}, + "wrongRecoveryKey": "Üzgünüm... bu doğru kurtarma anahtarı gibi görünmüyor.", + "@wrongRecoveryKey": {}, + "blockUsername": "Kullanıcı adını görmezden gel", + "@blockUsername": {}, + "databaseMigrationTitle": "Veri tabanı iyileştirildi", + "@databaseMigrationTitle": {}, + "databaseMigrationBody": "Lütfen bekleyin. Bu biraz zaman alabilir.", + "@databaseMigrationBody": {}, + "youInvitedToBy": "📩 Bağlantı aracılığıyla davet edildiniz:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "pleaseEnterYourCurrentPassword": "Lütfen geçerli parolanızı girin", + "@pleaseEnterYourCurrentPassword": {}, + "pleaseChooseAStrongPassword": "Lütfen güçlü bir parola seçin", + "@pleaseChooseAStrongPassword": {}, + "addChatOrSubSpace": "Sohbet veya alt alan ekle", + "@addChatOrSubSpace": {}, + "canceledKeyVerification": "{sender} anahtar doğrulamayı iptal etti", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "publicLink": "Herkese açık bağlantı", + "@publicLink": {}, + "joinSpace": "Alana katıl", + "@joinSpace": {}, + "newPassword": "Yeni parola", + "@newPassword": {}, + "databaseBuildErrorBody": "SQlite veri tabanı oluşturulamadı. Uygulama şimdilik eski veri tabanını kullanmaya çalışıyor. Lütfen bu hatayı {url} adresinde geliştiricilere bildirin. Hata mesajı: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Oturumunuz kayboldu. Lütfen bu hatayı {url} adresinde geliştiricilere bildirin. Hata mesajı: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "subspace": "Alt alan", + "@subspace": {}, + "thisDevice": "Bu aygıt:", + "@thisDevice": {}, + "formattedMessagesDescription": "Markdown kullanarak kalın metin gibi zengin mesaj içeriğini görüntüle.", + "@formattedMessagesDescription": {}, + "verifyOtherDevice": "🔐 Diğer aygıtı doğrula", + "@verifyOtherDevice": {}, + "presencesToggle": "Diğer kullanıcıların durum mesajlarını göster", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "Bulunma:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "searchForUsers": "@kullanıcıları ara...", + "@searchForUsers": {}, + "commandHint_ignore": "Verilen matrix kimliğini görmezden gel", + "@commandHint_ignore": {}, + "commandHint_unignore": "Verilen matrix kimliğini görmezden gelmeyi iptal et", + "@commandHint_unignore": {}, + "appLockDescription": "Kullanılmadığında PIN kodu ile uygulamayı kilitle", + "@appLockDescription": {}, + "globalChatId": "Genel sohbet kimliği", + "@globalChatId": {}, + "accessAndVisibility": "Erişim ve görünürlük", + "@accessAndVisibility": {}, + "accessAndVisibilityDescription": "Bu sohbete kimlerin katılmasına izin verilir ve sohbet nasıl keşfedilebilir.", + "@accessAndVisibilityDescription": {}, + "calls": "Aramalar", + "@calls": {}, + "customEmojisAndStickers": "Özel emojiler ve çıkartmalar", + "@customEmojisAndStickers": {}, + "customEmojisAndStickersBody": "Herhangi bir sohbette kullanılabilecek özel emojiler veya çıkartmalar ekleyin veya paylaşın.", + "@customEmojisAndStickersBody": {}, + "hideRedactedMessages": "Düzenlenen mesajları gizle", + "@hideRedactedMessages": {}, + "hideRedactedMessagesBody": "Birisi bir mesajı düzenlerse, bu mesaj artık sohbette görünmeyecektir.", + "@hideRedactedMessagesBody": {}, + "hideMemberChangesInPublicChats": "Herkese açık sohbetlerde üye değişikliklerini gizle", + "@hideMemberChangesInPublicChats": {}, + "hideMemberChangesInPublicChatsBody": "Okunabilirliği artırmak için birisi herkese açık bir sohbete katıldığında veya sohbetten ayrıldığında sohbet zaman çizelgesinde gösterme.", + "@hideMemberChangesInPublicChatsBody": {}, + "passwordRecoverySettings": "Parola kurtarma ayarları", + "@passwordRecoverySettings": {}, + "userWouldLikeToChangeTheChat": "{user} sohbete katılmak istiyor.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Henüz herkese açık bir bağlantı oluşturulmadı", + "@noPublicLinkHasBeenCreatedYet": {}, + "knock": "Tıklat", + "@knock": {}, + "knocking": "Tıklat", + "@knocking": {}, + "usersMustKnock": "Kullanıcılar tıklatmalı", + "@usersMustKnock": {}, + "noOneCanJoin": "Kimse katılamaz", + "@noOneCanJoin": {}, + "nothingFound": "Hiçbir şey bulunamadı...", + "@nothingFound": {}, + "sendReadReceiptsDescription": "Sohbetteki diğer katılımcılar bir mesajı okuduğunuzu görebilir.", + "@sendReadReceiptsDescription": {}, + "verifyOtherDeviceDescription": "Başka bir aygıtı doğruladığınızda, bu aygıtlar anahtarları değiş tokuş ederek genel güvenliğinizi artırır. 💪 Bir doğrulama başlattığınızda, her iki aygıttaki uygulamada bir açılır pencere görünecektir. Orada birbirleriyle karşılaştırmanız gereken bir dizi emoji veya sayı göreceksiniz. Doğrulamaya başlamadan önce her iki aygıtın da elinizin altında olması en iyisidir. 🤳", + "@verifyOtherDeviceDescription": {}, + "noDatabaseEncryption": "Veri tabanı şifrelemesi bu platformda desteklenmiyor", + "@noDatabaseEncryption": {}, + "thereAreCountUsersBlocked": "Şu anda {count} engellenen kullanıcı var.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "publicSpaces": "Herkese açık alanlar", + "@publicSpaces": {}, + "initAppError": "Uygulama başlatılırken bir hata oluştu", + "@initAppError": {}, + "userRole": "Kullanıcı rolü", + "@userRole": {}, + "hideInvalidOrUnknownMessageFormats": "Geçersiz veya bilinmeyen mesaj biçimlerini gizle", + "@hideInvalidOrUnknownMessageFormats": {}, + "hidePresences": "Durum listesi gizlensin mi?", + "@hidePresences": {}, + "overview": "Genel görünüm", + "@overview": {}, + "decline": "Reddet", + "@decline": {}, + "notifyMeFor": "Beni bilgilendir", + "@notifyMeFor": {}, + "chatCanBeDiscoveredViaSearchOnServer": "Sohbet {server} üzerinde aranarak keşfedilebilir", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "leaveEmptyToClearStatus": "Durumunuzu temizlemek için boş bırakın.", + "@leaveEmptyToClearStatus": {}, + "select": "Seç", + "@select": {}, + "minimumPowerLevel": "{level} en düşük güç seviyesidir.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "passwordsDoNotMatch": "Parolalar eşleşmiyor", + "@passwordsDoNotMatch": {}, + "passwordIsWrong": "Girdiğiniz parola yanlış", + "@passwordIsWrong": {}, + "publicChatAddresses": "Herkese açık sohbet adresleri", + "@publicChatAddresses": {}, + "createNewAddress": "Yeni adres oluştur", + "@createNewAddress": {}, + "forwardMessageTo": "Mesajlar {roomName} kişisine iletilsin mi?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "acceptedKeyVerification": "{sender} anahtar doğrulamayı kabul etti", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "restoreSessionBody": "Uygulama şimdi oturumunuzu yedekten geri yüklemeye çalışıyor. Lütfen bu hatayı {url} adresinde geliştiricilere bildirin. Hata mesajı: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceipts": "Okundu bilgisi gönder", + "@sendReadReceipts": {}, + "completedKeyVerification": "{sender} anahtar doğrulamayı tamamladı", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Sohbetteki diğer katılımcılar yeni bir mesaj yazdığınızı görebilir.", + "@sendTypingNotificationsDescription": {}, + "isReadyForKeyVerification": "{sender} anahtar doğrulama için hazır", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "formattedMessages": "Biçimlendirilen mesajlar", + "@formattedMessages": {}, + "requestedKeyVerification": "{sender} anahtar doğrulama istedi", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "verifyOtherUser": "🔐 Diğer kullanıcıyı doğrula", + "@verifyOtherUser": {}, + "startedKeyVerification": "{sender} anahtar doğrulama başlattı", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Şeffaf", + "@transparent": {}, + "discover": "Keşfet", + "@discover": {}, + "incomingMessages": "Gelen mesajlar", + "@incomingMessages": {}, + "verifyOtherUserDescription": "Başka bir kullanıcıyı doğrularsanız, gerçekten kime yazdığınızı bildiğinizden emin olabilirsiniz. 💪\n\nBir doğrulama başlattığınızda, siz ve diğer kullanıcı uygulamada bir açılır pencere görecektir. Orada birbirinizle karşılaştırmanız gereken bir dizi emoji veya sayı göreceksiniz.\n\nBunu yapmanın en iyi yolu buluşmak veya bir görüntülü arama başlatmaktır. 👭", + "@verifyOtherUserDescription": {}, + "stickers": "Çıkartmalar", + "@stickers": {}, + "unreadChatsInApp": "{appname}: {unread} okunmayan sohbet", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "searchIn": "\"{chat}\" sohbeti içinde ara...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "Daha fazla ara...", + "@searchMore": {}, + "gallery": "Galeri", + "@gallery": {}, + "files": "Dosyalar", + "@files": {}, + "knockRestricted": "Tıklatma kısıtlı", + "@knockRestricted": {}, + "restricted": "Kısıtlı", + "@restricted": {}, + "swipeRightToLeftToReply": "Yanıtlamak için sağdan sola kaydır", + "@swipeRightToLeftToReply": {}, + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "countChatsAndCountParticipants": "{chats} sohbet ve {participants} katılımcı", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Başka sohbet bulunamadı...", + "@noMoreChatsFound": {}, + "goToSpace": "Alana git: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "joinedChats": "Katılınan sohbetler", + "@joinedChats": {}, + "unread": "Okunmadı", + "@unread": {}, + "markAsUnread": "Okunmadı olarak işaretle", + "@markAsUnread": {}, + "space": "Alan", + "@space": {}, + "spaces": "Alanlar", + "@spaces": {}, + "inviteOtherUsers": "Diğer kullanıcıları bu sohbete davet et", + "@inviteOtherUsers": {}, + "changeTheChatPermissions": "Sohbet izinlerini değiştir", + "@changeTheChatPermissions": {}, + "changeTheCanonicalRoomAlias": "Ana herkese açık sohbet adresini değiştir", + "@changeTheCanonicalRoomAlias": {}, + "sendRoomNotifications": "@oda bildirimleri gönder", + "@sendRoomNotifications": {}, + "changeTheDescriptionOfTheGroup": "Sohbetin açıklamasını değiştir", + "@changeTheDescriptionOfTheGroup": {}, + "userLevel": "{level} - Kullanıcı", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderatör", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Yönetici", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Genel sohbet ayarlarını değiştir", + "@changeGeneralChatSettings": {}, + "changeTheVisibilityOfChatHistory": "Sohbet geçmişinin görünürlüğünü değiştir", + "@changeTheVisibilityOfChatHistory": {}, + "invitedBy": "📩 {user} davet etti", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "chatPermissionsDescription": "Bu sohbette belirli eylemler için hangi güç düzeyinin gerekli olduğunu tanımlayın. 0, 50 ve 100 güç düzeyleri genellikle kullanıcıları, moderatörleri ve yöneticileri temsil eder, ancak herhangi bir derecelendirme mümkündür.", + "@chatPermissionsDescription": {}, + "changelog": "Değişiklik günlüğü", + "@changelog": {}, + "updateInstalled": "🎉 Güncelleme {version} kuruldu!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "sendCanceled": "Gönderme iptal edildi", + "@sendCanceled": {}, + "noChatsFoundHere": "Burada henüz sohbet bulunamadı. Aşağıdaki düğmeyi kullanarak biriyle yeni bir sohbet başlatın. ⤵️", + "@noChatsFoundHere": {}, + "loginWithMatrixId": "Matrix kimliği ile oturum aç", + "@loginWithMatrixId": {}, + "discoverHomeservers": "Ana sunucuları keşfet", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "Ana sunucu nedir?", + "@whatIsAHomeserver": {}, + "homeserverDescription": "Tüm verileriniz tıpkı bir e-posta sağlayıcısı gibi ana sunucuda saklanır. Hangi ana sunucuyu kullanmak istediğinizi seçebilir ve herkesle iletişim kurmaya devam edebilirsiniz. https://matrix.org adresinden daha fazla bilgi edinin.", + "@homeserverDescription": {}, + "doesNotSeemToBeAValidHomeserver": "Uyumlu bir ana sunucu gibi görünmüyor. Yanlış URL mi?", + "@doesNotSeemToBeAValidHomeserver": {}, + "prepareSendingAttachment": "Ek gönderilmeye hazırlanıyor...", + "@prepareSendingAttachment": {}, + "serverLimitReached": "Sunucu sınırına ulaşıldı! {seconds} saniye bekleniyor...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "calculatingFileSize": "Dosya boyutu hesaplanıyor...", + "@calculatingFileSize": {}, + "sendingAttachmentCountOfCount": "Ek {index} / {length} gönderiliyor...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "sendingAttachment": "Ek gönderiliyor...", + "@sendingAttachment": {}, + "generatingVideoThumbnail": "Video küçük resmi oluşturuluyor...", + "@generatingVideoThumbnail": {}, + "compressVideo": "Video sıkıştırılıyor...", + "@compressVideo": {}, + "oneOfYourDevicesIsNotVerified": "Aygıtlarınızdan biri doğrulanmadı", + "@oneOfYourDevicesIsNotVerified": {}, + "noticeChatBackupDeviceVerification": "Not: Tüm aygıtlarınızı sohbet yedeklemesine bağladığınızda, otomatik olarak doğrulanırlar.", + "@noticeChatBackupDeviceVerification": {}, + "blur": "Blur:", + "@blur": {}, + "opacity": "Şeffaflık:", + "@opacity": {}, + "setWallpaper": "Duvar kağıdı seç", + "@setWallpaper": {}, + "manageAccount": "Hesabı yönet", + "@manageAccount": {}, + "noContactInformationProvided": "Sunucu geçerli bir iletişim bilgisi sunmadı", + "@noContactInformationProvided": {}, + "contactServerAdmin": "Sunucu yöneticisiyle iletişime geçin", + "@contactServerAdmin": {}, + "contactServerSecurity": "Sunucu güvenliğiyle iletişime geçin", + "@contactServerSecurity": {}, + "supportPage": "Destek sayfası", + "@supportPage": {}, + "name": "İsim", + "@name": {}, + "version": "Versiyon", + "@version": {}, + "serverInformation": "Sunucu bilgisi:", + "@serverInformation": {}, + "website": "Web sitesi", + "@website": {}, + "compress": "Sıkıştırma", + "@compress": {}, + "boldText": "Kalın metin", + "@boldText": {}, + "italicText": "İtalik metin", + "@italicText": {}, + "strikeThrough": "Üstü çizili", + "@strikeThrough": {}, + "pleaseFillOut": "Lütfen doldurun", + "@pleaseFillOut": {}, + "aboutHomeserver": "{homeserver} Hakkında", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "invalidUrl": "Geçersiz url", + "@invalidUrl": {}, + "addLink": "Link ekle", + "@addLink": {}, + "unableToJoinChat": "Sohbete girilemiyor. Belki başka birileri konuşmayı kapatmış olabilir.", + "@unableToJoinChat": {}, + "continueText": "Devam et", + "@continueText": {}, + "sendImages": "{count} görsel gönder", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "welcomeText": "Hey Hey 👋 Karşınızda FluffyChat. https://matrix.org ile uyumlu herhangi bir homeserver'a giriş yapabilirsiniz. Ve herkesle konuşabilirsiniz. Bu koca bir merkeziyetsiz mesajlaşma ağı!", + "@welcomeText": {}, + "setCustomPermissionLevel": "Özel izin düzeyi ayarla", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Lütfen aşağıdan önceden tanımlanmış bir rol seçin veya 0 ile 100 arasında bir özel izin seviyesi girin.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Kullanıcıyı yok say", + "@ignoreUser": {}, + "normalUser": "Normal kullanıcı", + "@normalUser": {}, + "commandHint_roomupgrade": "Bu odayı belirtilen oda sürümüne yükseltin", + "@commandHint_roomupgrade": {}, + "checkList": "Kontrol listesi", + "@checkList": {}, + "countInvited": "{count} davet edildi", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "synchronizingPleaseWaitCounter": " Senkronize ediliyor… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + } +} diff --git a/lib/l10n/intl_uk.arb b/lib/l10n/intl_uk.arb new file mode 100644 index 000000000..fee0cf011 --- /dev/null +++ b/lib/l10n/intl_uk.arb @@ -0,0 +1,3148 @@ +{ + "@@locale": "uk", + "@@last_modified": "2021-08-14 12:41:09.790615", + "about": "Про застосунок", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Прийняти", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} приймає запрошення", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Обліковий запис", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} активує наскрізне шифрування", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Адміністратор", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "псевдонім", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} відповідає на виклик", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Будь-хто може приєднатись", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "Архів", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Чи дозволено гостям приєднуватись", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Ви впевнені?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Для підпису ключа іншого користувача введіть свою парольну фразу або ключ відновлення.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "Прийняти цей запит на підтвердження від {username}?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "banFromChat": "Заблокувати в бесіді", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Заблоковано", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} блокує {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Заблокувати пристрій", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "cancel": "Скасувати", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} змінює аватар бесіди", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} змінює опис бесіди на: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} змінює назву бесіди на: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} змінює права доступу бесіди", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} змінює показуване ім'я на: '{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} змінює правила гостьового доступу", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} змінює правила гостьового доступу на: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} змінює видимість історії", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} змінює видимість історії на: {rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} змінює правила приєднання", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} змінює правила приєднання на: {joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} змінює аватар", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} змінює псевдоніми кімнати", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} змінює посилання для запрошення", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeTheHomeserver": "Змінити домашній сервер", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Змінити стиль", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Змінити назву групи", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Шифрування було пошкоджено", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Бесіда", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Подробиці бесіди", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Виберіть надійний пароль", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "Закрити", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "Порівняйте емодзі", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Порівняйте цифри", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "confirm": "Підтвердити", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Під'єднатись", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Контакт був запрошений в групу", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Скопійовано в буфер обміну", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Копіювати", + "@copy": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Помилка розшифрування повідомлення: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "Учасників: {count}", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Створити", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} створює бесіду", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "Зараз у мережі", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Темний", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{timeOfDay}, {date}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}-{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{day}-{month}-{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "delete": "Видалити", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Видалити повідомлення", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Пристрій", + "@device": { + "type": "String", + "placeholders": {} + }, + "devices": "Пристрої", + "@devices": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Показуване ім'я було змінено", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Завантажити файл", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Змінити показуване ім'я", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Емодзі вже існує!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Неприпустимий короткий код емодзі!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Налаштування емодзі", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "Короткий код для емодзі", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Укажіть короткий код емодзі та зображення!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Порожня бесіда", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Ви більше не зможете вимкнути шифрування. Ви впевнені?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encryption": "Шифрування", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Шифрування вимкнено", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} завершує виклик", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterYourHomeserver": "Введіть адресу домашнього сервера", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "fileName": "Назва файлу", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "forward": "Переслати", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "З моменту приєднання", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "З моменту запрошення", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "Група", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "Загальнодоступна група", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groupWith": "Група з {displayname}", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Гості не можуть приєднуватись", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Гості можуть приєднуватись", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} відкликає запрошення для {targetName}", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Довідка", + "@help": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "Ідентифікація", + "@identity": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Неправильна парольна фраза або ключ відновлення", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Запросити контакт", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "Запросити контакт до {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "Запрошено", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} запрошує {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Лише запрошені користувачі", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} запрошує вас у FluffyChat. \n1. Перейдіть на fluffychat.im й установіть застосунок \n2. Зареєструйтесь або ввійдіть \n3. Відкрийте запрошувальне посилання:\n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "пише…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} приєднується до бесіди", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "kicked": "👞 {username} вилучає {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} вилучає та блокує {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Вилучити з бесіди", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Остання активність: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Вийти", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Виходить з бесіди", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Ліцензія", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Світлий", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Завантажити ще {count} учасників", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "Завантаження… Будь ласка, зачекайте.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Завантажити ще…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "Увійти", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "Увійти до {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Вийти", + "@logout": { + "type": "String", + "placeholders": {} + }, + "moderator": "Модератор", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Вимкнути сповіщення", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Майте на увазі, що на цей час вам потрібен Pantalaimon, щоб використовувати наскрізне шифрування.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 Нове повідомлення у FluffyChat", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Новий запит перевірки!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Емодзі не знайдено. 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Схоже, Firebase Cloud Messaging недоступна на вашому пристрої. Щоб отримувати push-сповіщення, радимо встановити ntfy. За допомогою ntfy або іншого постачальника Unified Push ви можете отримувати push-сповіщення у безпечний спосіб. Ви можете завантажити ntfy з PlayStore або з F-Droid.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "Нічого", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Немає прав доступу", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Кімнат не знайдено…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "ok": "Гаразд", + "@ok": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Резервне онлайн-копіювання ключів увімкнено", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Халепа, щось пішло не так…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Відкрийте застосунок читання повідомлень", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Відкрити камеру", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "парольна фраза або ключ відновлення", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Пароль", + "@password": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Вибрати зображення", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "play": "Відтворити {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseEnterYourPassword": "Введіть свій пароль", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Введіть своє ім'я користувача", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Загальнодоступні кімнати", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "recording": "Запис", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} змінює подію", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "reject": "Відхилити", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} відхиляє запрошення", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Приєднатися знову", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "Вилучити", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Вилучити всі інші пристрої", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "Вилучено користувачем {username}", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Вилучити пристрій", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Розблокувати у бесіді", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "reply": "Відповісти", + "@reply": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Запит дозволу", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Кімнату було оновлено", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "Переглянуто {username}", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Надіслати", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Надіслати повідомлення", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Надіслати файл", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Надіслати зображення", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} надсилає файл", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} надсилає аудіо", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} надсилає зображення", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} надсилає наліпку", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} надсилає відео", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "setInvitationLink": "Указати посилання для запрошення", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Указати статус", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Налаштування", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Поділитися", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} ділиться своїм місцеперебуванням", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "skip": "Пропустити", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Джерельний код", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Як справи сьогодні?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Надіслати", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "Системна", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Вони відрізняються", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Вони збігаються", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Спробуйте надіслати ще раз", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} розблоковує {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Розблокувати пристрій", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Невідомий пристрій", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Невідомий алгоритм шифрування", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Невідома подія '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Увімкнути сповіщення", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "userAndOthersAreTyping": "{username} та {count} інших пишуть…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} і {username2} пишуть…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} пише…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} виходить з бесіди", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Ім'я користувача", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} надсилає подію {type}", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verify": "Перевірити", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Почати перевірку", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Ви успішно перевірені!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Перевірка іншого облікового запису", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Відеовиклик", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Видимість історії бесіди", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Видима для всіх учасників", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Видима для всіх", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Голосове повідомлення", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Очікування прийняття запиту партнером…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Очікування прийняття емодзі партнером…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Очікування прийняття чисел партнером…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Шпалери:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Кому дозволено приєднуватися до цієї групи", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Написати повідомлення…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Так", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Ви", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Ви більше не берете участь у цій бесіді", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Ви були заблоковані у цій бесіді", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Правила сповіщень", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Сповіщення ввімкнені для цього облікового запису", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "notifications": "Сповіщення", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Зміни учасників", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Запрошення для мене", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "enterAnEmailAddress": "Введіть адресу е-пошти", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Зашифровано", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Увімкнути набір емодзі глобально", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Набори емодзі для кімнати", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "edit": "Редагувати", + "@edit": { + "type": "String", + "placeholders": {} + }, + "directChats": "Особисті бесіди", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "deviceId": "ID пристрою", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Видалити обліковий запис", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deactivateAccountWarning": "Це деактивує ваш обліковий запис. Це неможливо скасувати! Ви впевнені?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Містить ім’я користувача", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Містить показуване ім’я", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "changePassword": "Змінити пароль", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "Змінити назву пристрою", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Повідомлення ботів", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "or": "Або", + "@or": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Установити основним псевдонімом", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "verified": "Перевірений", + "@verified": { + "type": "String", + "placeholders": {} + }, + "blocked": "Заблоковано", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "no": "Ні", + "@no": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "Надсилати натисканням Enter", + "commandHint_ban": "Заблокувати цього користувача кімнати", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_kick": "Вилучити цього користувача з цієї кімнати", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_myroomavatar": "Встановіть зображення для цієї кімнати (від mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Укажіть показуване ім'я для цієї кімнати", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandMissing": "{command} не є командою.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "copyToClipboard": "Копіювати до буфера обміну", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "createNewSpace": "Новий простір", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Увімкнути шифрування", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "joinRoom": "Приєднатися до кімнати", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "mention": "Згадати", + "@mention": { + "type": "String", + "placeholders": {} + }, + "next": "Далі", + "@next": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Немає з'єднання з сервером", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "scanQrCode": "Сканувати QR-код", + "noPasswordRecoveryDescription": "Ви ще не додали спосіб відновлення пароля.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} користувачів пишуть…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "online": "Онлайн", + "@online": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Дідько! На жаль, сталася помилка під час налаштування push-сповіщень.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Забули пароль", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "pleaseChoose": "Виберіть", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Введіть 4 цифри або залиште порожнім, щоб вимкнути блокування застосунку.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "redactMessage": "Редагувати повідомлення", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Зареєструватися", + "@register": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Поскаржитися на повідомлення", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Замінити кімнату новішою версією", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "Надіслати аудіо", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Встановити власні емодзі", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Ми надіслали вам електронний лист", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Стерти резервну копію бесіди, щоб створити новий ключ відновлення?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "Додати простір", + "roomVersion": "Версія кімнати", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "Мною виконано перехід за посиланням", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} розпочинає виклик", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "appLock": "Блокування застосунку", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "commandInvalid": "Неприпустима команда", + "@commandInvalid": { + "type": "String" + }, + "extremeOffensive": "Украй образливий", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "Наскільки образливий цей вміст?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "participant": "Учасник", + "@participant": { + "type": "String", + "placeholders": {} + }, + "addEmail": "Додати е-пошту", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "ignore": "Нехтувати", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Розмір шрифту", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "Домашній сервер підтримує такі версії специфікацій:\n{serverVersions}\nАле цей застосунок підтримує лише {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "areYouSureYouWantToLogout": "Ви впевнені, що хочете вийти?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "Домашній сервер підтримує такі типи входу:\n{serverVersions}\nАле цей застосунок підтримує лише:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "all": "Усі", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Усі бесіди", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_join": "Приєднатися до цієї кімнати", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "chats": "Бесіди", + "@chats": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Змінити аватар", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "link": "Посилання", + "security": "Безпека", + "@security": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Надіслати наліпку", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Помилка під час отримання розташування: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "hideRedactedEvents": "Сховати змінені події", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Синхронізація… Будь ласка, зачекайте.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} не є сервером matrix, використовувати {server2} натомість?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "reason": "Причина", + "@reason": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Типовий рівень дозволів для нових користувачів", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Надіслати як текст", + "@sendAsText": { + "type": "String" + }, + "saveFile": "Зберегти файл", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "Автоматично відтворювати анімовані наліпки та емодзі", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "pleaseChooseAPasscode": "Виберіть код доступу", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Натисніть на посилання в електронному листі, а потім продовжуйте.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "Позначити прочитаним/непрочитаним", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Перенесення з іншого пристрою", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "Надсилати повідомлення", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Надіслати оригінал", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Хто і яку дію може виконувати", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Чому ви хочете поскаржитися?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "messages": "Повідомлення", + "@messages": { + "type": "String", + "placeholders": {} + }, + "newChat": "Нова бесіда", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Усе готово!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Домашній сервер", + "goToTheNewRoom": "Перейти до нової кімнати", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "groups": "Групи", + "@groups": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Необразливий", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Активувати шифрування можна лише тоді, коли кімната більше не буде загальнодоступною.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Бесіду додано до цього простору", + "chatBackupDescription": "Ваші повідомлення захищені ключем відновлення. Переконайтеся, що ви не втратите його.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Резервне копіювання бесіди", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Рез. копію чату налаштовано.", + "clearArchive": "Очистити архів", + "commandHint_html": "Надіслати текст у форматі HTML", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Запросіть цього користувача до цієї кімнати", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_leave": "Вийти з цієї кімнати", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Опишіть себе", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "hideUnknownEvents": "Сховати невідомі події", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "Нехтувані користувачі", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "obtainingLocation": "Отримання розташування…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Образливий", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Офлайн", + "@offline": { + "type": "String", + "placeholders": {} + }, + "addAccount": "Додати обліковий запис", + "enableMultiAccounts": "(БЕТА) Увімкнути кілька облікових записів на цьому пристрої", + "openInMaps": "Відкрити в картах", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "Цей сервер потребує перевірки вашої адресу е-пошти для реєстрації.", + "pleaseFollowInstructionsOnWeb": "Виконайте вказівки вебсайту та торкніться далі.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Надіслати відео", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Вилучити свій аватар", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "unpin": "Відкріпити", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Указати рівні дозволів", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "Поділитися місцеперебуванням", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Єдиний вхід", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Забагато запитів. Спробуйте пізніше!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Недоступний", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 непрочитана бесіда} few{{unreadCount} непрочитані бесіди} many{{unreadCount} непрочитаних бесід} other{{unreadCount} непрочитані бесіди}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "withTheseAddressesRecoveryDescription": "За допомогою цих адрес ви можете відновити свій пароль.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "privacy": "Приватність", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "search": "Пошук", + "@search": { + "type": "String", + "placeholders": {} + }, + "sentCallInformations": "{senderName} надсилає відомості про виклик", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cantOpenUri": "Не вдалося відкрити URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "contentHasBeenReported": "Скаргу на вміст надіслано адміністраторам сервера", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "commandHint_op": "Укажіть рівень повноважень цього користувача (типово: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Надіслати неформатований текст", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Надіслати відповідь як реакцію", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Надіслати текст", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Розблокувати цього користувача у цій кімнаті", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "configureChat": "Налаштувати бесіду", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Редагувати заблоковані сервери", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Показати пароль", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Змінити псевдоніми кімнати", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Змінити аватар кімнати", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Пароль змінено", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "Відновлення пароля", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Люди", + "@people": { + "type": "String", + "placeholders": {} + }, + "pin": "Закріпити", + "@pin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Введіть свій PIN-код", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Назва простору", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "warning": "Попередження!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Ваш відкритий ключ", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Простір загальнодоступний", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "status": "Статус", + "@status": { + "type": "String", + "placeholders": {} + }, + "unverified": "Неперевірений", + "locationDisabledNotice": "Служби визначення розташування вимкнені. Увімкніть їх, щоб мати змогу ділитися своїм розташуванням.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Дозвіл на розташування відхилено. Надайте можливість ділитися своїм розташуванням.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "На одному з ваших клієнтів виконано вихід із системи", + "bundleName": "Назва вузла", + "toggleFavorite": "Перемикнути вибране", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "removeFromBundle": "Вилучити з цього вузла", + "toggleMuted": "Увімкнути/вимкнути звук", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "editBundlesForAccount": "Змінити вузол для цього облікового запису", + "addToBundle": "Додати до вузлів", + "repeatPassword": "Повторіть пароль", + "messageInfo": "Відомості про повідомлення", + "time": "Час", + "messageType": "Тип повідомлення", + "openGallery": "Відкрити галерею", + "sender": "Відправник", + "addToSpaceDescription": "Виберіть простір, щоб додати до нього цю бесіду.", + "removeFromSpace": "Вилучити з простору", + "start": "Почати", + "commandHint_discardsession": "Відкинути сеанс", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_clearcache": "Очистити кеш", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Створіть порожню групову бесіду\nВикористовуйте --no-encryption, щоб вимкнути шифрування", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_dm": "Початок особистої бесіди\nВикористовуйте --no-encryption, що вимкнути шифрування", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "openVideoCamera": "Відкрити камеру для відео", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "publish": "Опублікувати", + "videoWithSize": "Відео ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "dismiss": "Відхилити", + "markAsRead": "Позначити прочитаним", + "reportUser": "Поскаржився на користувача", + "openChat": "Відкрити бесіду", + "reactedWith": "{sender} реагує з {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "emojis": "Емодзі", + "pinMessage": "Прикріпити в кімнаті", + "confirmEventUnpin": "Ви впевнені, що бажаєте назавжди відкріпити подію?", + "placeCall": "Здійснити виклик", + "unsupportedAndroidVersion": "Непідтримувана версія Android", + "voiceCall": "Голосовий виклик", + "unsupportedAndroidVersionLong": "Для цієї функції потрібна новіша версія Android. Перевірте наявність оновлень або підтримку Lineage OS.", + "videoCallsBetaWarning": "Зауважте, що відеовиклики на ранньому етапі розробки. Вони можуть працювати не так, як очікувалося, або взагалі не працювати на всіх платформах.", + "emailOrUsername": "Електронна адреса або ім’я користувача", + "experimentalVideoCalls": "Експериментальні відеовиклики", + "switchToAccount": "Перемкнутися на обліковий запис {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Наступний обліковий запис", + "previousAccount": "Попередній обліковий запис", + "addWidget": "Додати віджет", + "widgetVideo": "Відео", + "widgetCustom": "Користувацький", + "widgetName": "Назва", + "widgetNameError": "Укажіть коротку назву.", + "widgetEtherpad": "Текстова примітка", + "widgetJitsi": "Jitsi Meet", + "widgetUrlError": "Це недійсна URL-адреса.", + "errorAddingWidget": "Помилка додавання віджета.", + "separateChatTypes": "Розділіть особисті бесіди та групи", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youInvitedBy": "📩 Ви були запрошені {user}", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youAcceptedTheInvitation": "👍 Ви погодилися на запрошення", + "youRejectedTheInvitation": "Ви відхилили запрошення", + "youHaveWithdrawnTheInvitationFor": "Ви відкликали запрошення для {user}", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youBannedUser": "Ви заблокували {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Ви вилучили й заблокували {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youJoinedTheChat": "Ви приєдналися до бесіди", + "youKicked": "👞 Ви вилучили {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "Ви розблокували {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Ви запросили {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "saveKeyManuallyDescription": "Збережіть цей ключ вручну, запустивши діалогове вікно спільного доступу до системи або буфер обміну.", + "storeInAndroidKeystore": "Зберегти в Android KeyStore", + "storeInAppleKeyChain": "Зберегти в Apple KeyChain", + "storeSecurlyOnThisDevice": "Зберегти безпечно на цей пристрій", + "pleaseEnterRecoveryKeyDescription": "Щоб розблокувати старі повідомлення, введіть ключ відновлення, згенерований у попередньому сеансі. Ваш ключ відновлення це НЕ ваш пароль.", + "pleaseEnterRecoveryKey": "Введіть ключ відновлення:", + "recoveryKey": "Ключ відновлення", + "recoveryKeyLost": "Ключ відновлення втрачено?", + "users": "Користувачі", + "unlockOldMessages": "Розблокувати старі повідомлення", + "storeInSecureStorageDescription": "Збережіть ключ відновлення в безпечному сховищі цього пристрою.", + "countFiles": "{count} файлів", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "hydrate": "Відновлення з файлу резервної копії", + "hydrateTorLong": "Минулого разу ви експортували свій сеанс із TOR? Швидко імпортуйте його та продовжуйте спілкування.", + "indexedDbErrorTitle": "Проблеми приватного режиму", + "indexedDbErrorLong": "На жаль, сховище повідомлень не ввімкнуто у приватному режимі типово.\nВідкрийте\n - about:config\n - установіть для dom.indexedDB.privateBrowsing.enabled значення true\nІнакше запустити FluffyChat буде неможливо.", + "dehydrate": "Експортувати сеанс та очистити пристрій", + "dehydrateWarning": "Цю дію не можна скасувати. Переконайтеся, що ви безпечно зберігаєте файл резервної копії.", + "dehydrateTor": "Користувачі TOR: експорт сеансу", + "dehydrateTorLong": "Для користувачів TOR рекомендується експортувати сеанс перед закриттям вікна.", + "hydrateTor": "Користувачі TOR: імпорт експортованого сеансу", + "user": "Користувач", + "custom": "Користувацький", + "supposedMxid": "Це має бути {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "confirmMatrixId": "Підтвердьте свій Matrix ID, щоб видалити свій обліковий запис.", + "commandHint_markasgroup": "Позначити групою", + "commandHint_markasdm": "Позначити кімнатою особистого спілкування для надання Matrix ID", + "whyIsThisMessageEncrypted": "Чому це повідомлення нечитабельне?", + "noKeyForThisMessage": "Це може статися, якщо повідомлення було надіслано до того, як ви ввійшли у свій обліковий запис на цьому пристрої.\n\nТакож можливо, що відправник заблокував ваш пристрій або щось пішло не так з під'єднанням до інтернету.\n\nЧи можете ви прочитати повідомлення на іншому сеансі? Тоді ви зможете перенести повідомлення з нього! Перейдіть до Налаштування > Пристрої та переконайтеся, що ваші пристрої перевірили один одного. Коли ви відкриєте кімнату наступного разу й обидва сеанси будуть на активні, ключі будуть передані автоматично.\n\nВи ж не хочете втрачати ключі після виходу або зміни пристроїв? Переконайтеся, що ви ввімкнули резервне копіювання бесід у налаштуваннях.", + "foregroundServiceRunning": "Це сповіщення з'являється під час роботи основної служби.", + "screenSharingTitle": "спільний доступ до екрана", + "callingPermissions": "Дозволи на виклик", + "callingAccount": "Обліковий запис для виклику", + "callingAccountDetails": "Дозволяє FluffyChat використовувати основний застосунок Android для набору номера.", + "appearOnTop": "З'являтися зверху", + "appearOnTopDetails": "Дозволяє застосунку показуватися зверху (не потрібно, якщо Fluffychat вже налаштований обліковим записом для викликів)", + "newGroup": "Нова група", + "newSpace": "Новий простір", + "enterSpace": "Увійти в простір", + "enterRoom": "Увійти в кімнату", + "otherCallingPermissions": "Мікрофон, камера та інші дозволи FluffyChat", + "allSpaces": "Усі простори", + "screenSharingDetail": "Ви ділитеся своїм екраном FuffyChat", + "numChats": "{number} бесід", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Сховати неважливі державні свята", + "doNotShowAgain": "Не показувати знову", + "commandHint_cuddle": "Надіслати пригортайку", + "googlyEyesContent": "{senderName} надсилає вам гугл-очі", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_googly": "Надіслати кілька гугл-очей", + "commandHint_hug": "Надіслати обійми", + "cuddleContent": "{senderName} пригортається до вас", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} обіймає вас", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "wasDirectChatDisplayName": "Порожня бесіда (раніше {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "startFirstChat": "Розпочніть свою першу бесіду", + "newSpaceDescription": "Простори дозволяють об'єднувати ваші бесіди та створювати приватні або загальнодоступні спільноти.", + "encryptThisChat": "Зашифрувати цю бесіду", + "disableEncryptionWarning": "З міркувань безпеки ви не можете вимкнути шифрування в бесіді, ув якій воно було ввімкнене раніше.", + "sorryThatsNotPossible": "Вибачте... це неможливо", + "deviceKeys": "Ключі пристрою:", + "reopenChat": "Відновити бесіду", + "noOtherDevicesFound": "Інших пристроїв не знайдено", + "noBackupWarning": "Увага! Якщо ви не ввімкнете резервне копіювання бесіди, ви втратите доступ до своїх зашифрованих повідомлень. Наполегливо радимо ввімкнути резервне копіювання бесіди перед виходом.", + "fileIsTooBigForServer": "Не вдалося надіслати! Сервер підтримує вкладення розміром до {max}.", + "fileHasBeenSavedAt": "Файл збережено в {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Перейти до останнього прочитаного повідомлення", + "readUpToHere": "Читати тут", + "jump": "Перейти", + "openLinkInBrowser": "Відкрити посилання у браузері", + "allRooms": "Усі групові бесіди", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "reportErrorDescription": "О, ні. Щось пішло не так. Якщо хочете, можете повідомити про помилку розробникам.", + "report": "повідомити", + "pleaseTryAgainLaterOrChooseDifferentServer": "Спробуйте пізніше або виберіть інший сервер.", + "signInWithPassword": "Увійти за допомогою пароля", + "signInWith": "Увійти через {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Не файл зображення.", + "importNow": "Імпортувати зараз", + "importEmojis": "Імпорт емодзі", + "importFromZipFile": "Імпорт з файлу .zip", + "replace": "Замінити", + "exportEmotePack": "Експортувати набір смайликів у форматі .zip", + "sendTypingNotifications": "Надсилати сповіщення про ввід тексту", + "createGroup": "Створити групу", + "inviteContactToGroupQuestion": "Хочете запросити {contact} до бесіди \"{groupName}\"?", + "messagesStyle": "Повідомлення:", + "shareInviteLink": "Надіслати запрошувальне посилання", + "tryAgain": "Повторіть спробу", + "setTheme": "Налаштувати тему:", + "setColorTheme": "Налаштувати колірну тему:", + "addChatDescription": "Додати опис бесіди...", + "chatPermissions": "Дозволи бесіди", + "chatDescription": "Опис бесіди", + "chatDescriptionHasBeenChanged": "Опис бесіди змінено", + "noChatDescriptionYet": "Опис бесіди ще не створено.", + "invalidServerName": "Недійсна назва сервера", + "optionalRedactReason": "(Необов'язково) Причина редагування цього повідомлення...", + "redactedBy": "Відредаговано {username}", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Особисте повідомлення", + "redactedByBecause": "Відредаговано {username}, тому що: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "profileNotFound": "Не вдалося знайти користувача на сервері. Можливо, проблема зі з'єднанням або користувач не існує.", + "invite": "Запросити", + "redactMessageDescription": "Повідомлення буде відредаговано для всіх учасників цієї розмови. Це не можна скасувати.", + "setChatDescription": "Налаштувати опис бесіди", + "inviteGroupChat": "📨 Запрошення до групової бесіди", + "invitePrivateChat": "📨 Запрошення до приватної бесіди", + "emoteKeyboardNoRecents": "Тут з'являться нещодавно використані смайлики...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "invalidInput": "Недійсний ввід!", + "wrongPinEntered": "Введено неправильний PIN! Повторіть спробу за {seconds} секунд...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "banUserDescription": "Користувача буде заблоковано в бесіді, і він не зможе знову увійти в неї, поки його не буде розблоковано.", + "removeDevicesDescription": "Ви вийдете з цього пристрою і більше не зможете отримувати повідомлення.", + "unbanUserDescription": "Користувач зможе знову увійти в бесіду, якщо спробує.", + "pushNotificationsNotAvailable": "Push-сповіщення недоступні", + "makeAdminDescription": "Після того, як ви зробите цього користувача адміністратором, ви, можливо, не зможете це скасувати, оскільки він матиме ті самі права, що й ви.", + "archiveRoomDescription": "Бесіду буде переміщено до архіву. Інші користувачі зможуть побачити, що ви вийшли з неї.", + "hasKnocked": "🚪{user} стукає до вас", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "learnMore": "Докладніше", + "roomUpgradeDescription": "Після цього бесіду буде відтворено з новою версією кімнати. Усі учасники отримають сповіщення, що їм потрібно перейти до нової бесіди. Ви можете дізнатися більше про версії кімнат на https://spec.matrix.org/latest/rooms/", + "pleaseEnterANumber": "Введіть число більше ніж 0", + "kickUserDescription": "Користувача вигнали з бесіди, але не заблокували. До загальнодоступних бесід користувач може приєднатися будь-коли.", + "blockListDescription": "Ви можете заблокувати користувачів, які вас турбують. Ви не зможете отримувати жодних повідомлень або запрошень до кімнати від користувачів з вашого персонального списку блокування.", + "createGroupAndInviteUsers": "Створити групу та запросити користувачів", + "startConversation": "Розпочати розмову", + "blockedUsers": "Заблоковані користувачі", + "groupCanBeFoundViaSearch": "Групу можна знайти через пошук", + "noUsersFoundWithQuery": "На жаль, не знайдено жодного користувача з запитом \"{query}\".Перевірте, чи не було допущено помилки.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "block": "Заблокувати", + "yourGlobalUserIdIs": "Ваш глобальний ID користувача: ", + "commandHint_sendraw": "Надіслати необроблений json", + "wrongRecoveryKey": "Вибачте... схоже, це неправильний ключ відновлення.", + "blockUsername": "Ігнорувати ім'я користувача", + "groupName": "Назва групи", + "databaseMigrationTitle": "Базу даних оптимізовано", + "searchChatsRooms": "Пошук для #chats, @users...", + "databaseMigrationBody": "Зачекайте, будь ласка. Це може тривати деякий час.", + "thisDevice": "Цей пристрій:", + "publicSpaces": "Загальнодоступний простір", + "passwordIsWrong": "Введений пароль неправильний", + "pleaseEnterYourCurrentPassword": "Введіть поточний пароль", + "publicLink": "Загальнодоступне посилання", + "nothingFound": "Нічого не знайдено...", + "decline": "Відхилити", + "newPassword": "Новий пароль", + "passwordsDoNotMatch": "Паролі відрізняються", + "subspace": "Підпростір", + "select": "Вибрати", + "pleaseChooseAStrongPassword": "Виберіть надійний пароль", + "addChatOrSubSpace": "Додати бесіду або підпростір", + "leaveEmptyToClearStatus": "Лишіть порожнім, щоб оновити статус.", + "joinSpace": "Приєднатися до простору", + "searchForUsers": "Пошук @користувачів...", + "sessionLostBody": "Ваш сеанс втрачено. Будь ласка, повідомте про цю помилку розробникам за адресою {url}. Текст помилки: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "databaseBuildErrorBody": "Не вдалося створити базу даних SQlite. Застосунок намагається використовувати стару базу даних. Будь ласка, повідомте про цю помилку розробникам за адресою {url}. Текст помилки: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "Виникла помилка під час запуску застосунку", + "restoreSessionBody": "Наразі застосунок намагається відновити ваш сеанс з резервної копії. Будь ласка, повідомте про цю помилку розробникам за адресою {url}. Текст помилки: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Вас запрошено за посиланням на:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "acceptedKeyVerification": "{sender} погоджується звірити ключі", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "canceledKeyVerification": "{sender} скасовує звірення ключів", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} просить звірити ключі", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Прозорий", + "sendReadReceiptsDescription": "Інші учасники бесіди бачитимуть, що ви прочитали повідомлення.", + "formattedMessages": "Форматовані повідомлення", + "forwardMessageTo": "Переслати повідомлення до {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Надіслати підтвердження прочитання", + "sendTypingNotificationsDescription": "Інші учасники бесіди бачитимуть, коли ви набираєте нове повідомлення.", + "formattedMessagesDescription": "Показувати розширений вміст повідомлень, наприклад, жирний текст, використовуючи markdown.", + "verifyOtherUser": "🔐 Звірити іншого користувача", + "verifyOtherUserDescription": "Якщо ви звіряєте іншого користувача, ви можете бути впевнені, що знаєте, кому ви насправді пишете. 💪\n\nКоли ви почнете звірення, ви та інший користувач побачите спливне вікно в застосунку. Там ви побачите набір смайликів або чисел, які вам потрібно буде порівняти між собою.\n\nНайкращий спосіб зробити це — зустрітися або розпочати відеовиклик. 👭", + "verifyOtherDeviceDescription": "Коли ви звіряєте інший пристрій, ці пристрої можуть обмінюватися ключами, підвищуючи вашу загальну безпеку. 💪 Коли ви розпочнете звірення, в застосунку на обох пристроях з'явиться спливне вікно. Там ви побачите набір смайликів або чисел, які вам потрібно буде порівняти між собою. Найкраще мати обидва пристрої під рукою перед початком звірення. 🤳", + "verifyOtherDevice": "🔐 Звірити інший пристрій", + "completedKeyVerification": "{sender} завершує звірення ключів", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} готовий до звірення ключів", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} розпочинає звірення ключів", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "presenceStyle": "Присутність:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Показувати повідомлення про стан від інших користувачів", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "hidePresences": "Сховати список станів?", + "incomingMessages": "Вхідні повідомлення", + "discover": "Огляд", + "stickers": "Наліпки", + "searchIn": "Пошук у бесіді \"{chat}\"...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "commandHint_ignore": "Ігнорувати цей Matrix ID", + "restricted": "Обмежено", + "swipeRightToLeftToReply": "Посунути праворуч або ліворуч, щоб відповісти", + "globalChatId": "Глобальний ID бесіди", + "accessAndVisibility": "Доступ і видимість", + "accessAndVisibilityDescription": "Хто може приєднатися до цієї бесіди і як її можна знайти.", + "calls": "Виклики", + "customEmojisAndStickers": "Власні емодзі та наліпки", + "customEmojisAndStickersBody": "Додавайте або діліться власними емодзі або наліпками, які можна використовувати в будь-якій бесіді.", + "createNewAddress": "Створити нову адресу", + "userRole": "Роль користувача", + "minimumPowerLevel": "{level} — це найнижчий рівень повноважень.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "commandHint_unignore": "Не ігнорувати цей Matrix ID", + "knockRestricted": "Стук обмежено", + "appLockDescription": "Блокувати застосунок, коли не використовується ПІН-код", + "hideRedactedMessages": "Сховати змінені повідомлення", + "hideRedactedMessagesBody": "Якщо хтось змінить повідомлення, його більше не буде видно в бесіді.", + "hideInvalidOrUnknownMessageFormats": "Сховати недійсні або невідомі формати повідомлень", + "hideMemberChangesInPublicChats": "Сховати зміни користувачів у загальнодоступних бесідах", + "hideMemberChangesInPublicChatsBody": "Не показувати в хронології бесіди, якщо хтось приєднується до загальнодоступної бесіди або виходить з неї, щоб покращити її читабельність.", + "overview": "Огляд", + "notifyMeFor": "Сповіщати мене про", + "passwordRecoverySettings": "Налаштування відновлення пароля", + "userWouldLikeToChangeTheChat": "{user} хоче приєднатися до бесіди.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Загальнодоступне посилання ще не створено", + "knock": "Постукатись", + "knocking": "Стукаються", + "noDatabaseEncryption": "Шифрування бази даних не підтримується на цій платформі", + "usersMustKnock": "Користувачі повинні постукатись", + "noOneCanJoin": "Ніхто не може приєднатись", + "chatCanBeDiscoveredViaSearchOnServer": "Бесіду можна знайти за допомогою пошуку на {server}", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "publicChatAddresses": "Адреси загальнодоступної бесіди", + "searchMore": "Шукати ще...", + "gallery": "Галерея", + "files": "Файли", + "unreadChatsInApp": "{appname}: {unread} непрочитаних бесід", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "Наразі заблоковано {count} користувачів.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "moderatorLevel": "{level} - Модератор", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Адміністратор", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "userLevel": "{level} - Користувач", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "changeGeneralChatSettings": "Змінити загальні налаштування чату", + "inviteOtherUsers": "Запросити інших користувачів до цього чату", + "changeTheChatPermissions": "Змінити права доступу до чату", + "changeTheVisibilityOfChatHistory": "Змінити видимість історії чату", + "changeTheCanonicalRoomAlias": "Змінити основну адресу загальнодоступного чату", + "sendRoomNotifications": "Надсилати сповіщення @room", + "space": "Простір", + "spaces": "Простори", + "goToSpace": "Перейти до простору: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Позначити непрочитаним", + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "invitedBy": "📩 Запрошений {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "changeTheDescriptionOfTheGroup": "Змінити опис чату", + "updateInstalled": "🎉 Оновлення {version} встановлено!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "Зміни", + "chatPermissionsDescription": "Визначте, який рівень повноважень необхідний для певних дій у цьому чаті. Рівні повноважень 0, 50 і 100 зазвичай представляють користувачів, модераторів та адміністраторів, але можливі будь-які градації.", + "countChatsAndCountParticipants": "{chats} чати та {participants} учасників", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Більше чатів не знайдено...", + "joinedChats": "Приєднані чати", + "unread": "Непрочитані", + "sendCanceled": "Надсилання скасовано", + "noChatsFoundHere": "Бесід ще немає. Розпочніть спілкування натиснувши кнопку нижче. ⤵️", + "loginWithMatrixId": "Увійти за допомогою Matrix-ID", + "discoverHomeservers": "Знайти домашні сервери", + "whatIsAHomeserver": "Що таке домашній сервер?", + "homeserverDescription": "Усі ваші дані зберігаються на домашньому сервері, так само як у постачальника послуг електронної пошти. Ви можете вибрати, який домашній сервер ви хочете використовувати, водночас ви можете спілкуватися з усіма. Докладніше на https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Здається, це несумісний домашній сервер. Неправильна URL-адреса?", + "calculatingFileSize": "Обчислення розміру файлу...", + "prepareSendingAttachment": "Підготовка до надсилання вкладення...", + "sendingAttachment": "Надсилання вкладення...", + "generatingVideoThumbnail": "Генерування мініатюри відео...", + "compressVideo": "Стиснення відео...", + "sendingAttachmentCountOfCount": "Надсилання вкладення {index} з {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Досягнуто ліміту сервера! Очікування {seconds} секунд...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Один із ваших пристроїв не верифікований", + "noticeChatBackupDeviceVerification": "Примітка: Коли ви під'єднуєте всі свої пристрої до резервної копії бесіди, вони автоматично верифікуються.", + "continueText": "Продовжити", + "manageAccount": "Керувати обліковим записом", + "welcomeText": "Привіт-привіт 👋 Це FluffyChat. Ви можете увійти на будь-який сервер, сумісний із https://matrix.org. А потім спілкуватися з будь-ким. Це величезна децентралізована мережа для обміну повідомленнями!", + "blur": "Розмиття:", + "opacity": "Прозорість:", + "setWallpaper": "Встановити шпалери", + "aboutHomeserver": "Про {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "noContactInformationProvided": "Сервер не надає жодної дійсної контактної інформації", + "contactServerSecurity": "Зв’язатися з відділом безпеки сервера", + "supportPage": "Сторінка підтримки", + "serverInformation": "Інформація про сервер:", + "contactServerAdmin": "Зв’язатися з адміністратором сервера", + "name": "Ім'я", + "version": "Версія", + "website": "Вебсайт", + "boldText": "Жирний текст", + "italicText": "Курсивний текст", + "strikeThrough": "Перекреслений текст", + "pleaseFillOut": "Будь ласка, заповніть", + "invalidUrl": "Недійсний URL", + "addLink": "Додати посилання", + "unableToJoinChat": "Неможливо приєднатися до бесіди. Можливо, інша сторона вже закрила розмову.", + "sendImages": "Надіслати {count} зображення", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "Стиснути", + "otherPartyNotLoggedIn": "Інша сторона наразі не увійшла в систему, тому не може отримувати повідомлення!", + "previous": "Попередній", + "synchronizingPleaseWaitCounter": " Синхронізація… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "newChatRequest": "📩 Новий запит на спілкування", + "allDevices": "Усім пристроям", + "crossVerifiedDevicesIfEnabled": "З перехресною верифікацією пристроїв, якщо ввімкнено", + "crossVerifiedDevices": "З перехресною верифікацією пристроїв", + "appWantsToUseForLogin": "Використати '{server}', щоб увійти", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Цим ви дозволяєте застосунку та вебсайту ділитися інформацією про вас.", + "open": "Відкрити", + "waitingForServer": "Очікування сервера...", + "appIntroduction": "FluffyChat дає змогу спілкуватися з друзями у різних месенджерах. Дізнайтеся більше на https://matrix.org або просто натисніть *Продовжити*.", + "shareKeysWithDescription": "Яким пристроям довіряти, щоб вони могли читати ваші повідомлення в зашифрованих бесідах?", + "verifiedDevicesOnly": "Лише верифіковані пристрої", + "contentNotificationSettings": "Налаштування сповіщень про вміст", + "generalNotificationSettings": "Загальні налаштування сповіщень", + "roomNotificationSettings": "Налаштування сповіщень кімнати", + "userSpecificNotificationSettings": "Налаштування сповіщень для користувача", + "otherNotificationSettings": "Інші налаштування сповіщень", + "notificationRuleContainsUserName": "Містить ім'я користувача", + "notificationRuleContainsUserNameDescription": "Сповіщає користувача, коли повідомлення містить його ім'я користувача.", + "notificationRuleMaster": "Вимкнути всі сповіщення", + "notificationRuleMasterDescription": "Перевизначає всі інші правила і вимикає всі сповіщення.", + "notificationRuleSuppressNotices": "Заборонити автоматичні повідомлення", + "notificationRuleInviteForMe": "Запрошення мене", + "notificationRuleInviteForMeDescription": "Сповіщає користувача, коли його запрошують до кімнати.", + "notificationRuleMemberEvent": "Події участі", + "notificationRuleMemberEventDescription": "Забороняє сповіщення про події учасників.", + "notificationRuleSuppressNoticesDescription": "Забороняє сповіщення від автоматизованих клієнтів, як-от боти.", + "notificationRuleIsUserMention": "Згадки користувачів", + "commandHint_roomupgrade": "Оновити цю кімнату до версії даної кімнати", + "notificationRuleIsUserMentionDescription": "Сповіщає користувачів, коли безпосередньо їх згадують у повідомленні.", + "notificationRuleContainsDisplayName": "Містить показуване ім’я", + "notificationRuleIsRoomMentionDescription": "Сповіщає користувача, коли є згадка всієї кімнати.", + "notificationRuleRoomnotif": "Сповіщення кімнати", + "notificationRuleRoomnotifDescription": "Сповіщає користувача, коли повідомлення містить '@room'.", + "notificationRuleContainsDisplayNameDescription": "Сповіщає користувача, коли повідомлення містить показуване ім'я.", + "notificationRuleIsRoomMention": "Згадки кімнати", + "notificationRuleTombstone": "Могильний камінь", + "notificationRuleTombstoneDescription": "Повідомляє користувача про повідомлення деактивації кімнати.", + "notificationRuleReactionDescription": "Приховує сповіщення про реакції.", + "notificationRuleRoomOneToOneDescription": "Повідомляє користувача про повідомлення в кімнатах \"Один на один\".", + "notificationRuleSuppressEdits": "Приховує редагування", + "notificationRuleSuppressEditsDescription": "Приховує сповіщення про відредаговані повідомлення.", + "notificationRuleCall": "Виклик", + "notificationRuleRoomServerAcl": "ACL сервера кімнати", + "notificationRuleMessageDescription": "Повідомляє користувача про загальні повідомлення.", + "notificationRuleEncrypted": "Зашифровано", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Повідомляє користувача про події віджетів Jitsi.", + "notificationRuleServerAcl": "Приховує події сервера ACL", + "notificationRuleServerAclDescription": "Приховує сповіщення про події Server ACL.", + "more": "Більше", + "takeAPhoto": "Зробити фото", + "recordAVideo": "Записати відео", + "optionalMessage": "(Необов'язково) повідомлення...", + "enterNewChat": "Створити новий чат", + "shareKeysWith": "Поділитися ключами з...", + "notSupportedOnThisDevice": "Не підтримується на цьому пристрої", + "notificationRuleMessage": "Повідомлення", + "unknownPushRule": "Невідоме правило сповіщення '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "pleaseWaitUntilInvited": "Будь ласка, зачекайте, поки хтось з кімнати запросить вас.", + "notificationRuleEncryptedRoomOneToOne": "Зашифрована кімната \"Один на один\"", + "deletePushRuleCanNotBeUndone": "Якщо ви видалите це налаштування сповіщень, відновити його буде неможливо.", + "ignoreUser": "Ігнорувати користувача", + "setCustomPermissionLevel": "Встановити рівень користувацьких прав", + "normalUser": "Звичайний користувач", + "notificationRuleEncryptedDescription": "Повідомляє користувача про повідомлення в зашифрованих кімнатах.", + "setPermissionsLevelDescription": "Будь ласка, виберіть заздалегідь визначену роль нижче або введіть користувацький рівень прав від 0 до 100.", + "notificationRuleRoomServerAclDescription": "Приховує сповіщення про списки контролю доступу (ACL) сервера кімнати.", + "notificationRuleReaction": "Реакція", + "notificationRuleCallDescription": "Повідомляє користувача про виклики.", + "notificationRuleEncryptedRoomOneToOneDescription": "Повідомляє користувача про повідомлення в зашифрованих кімнатах \"Один на один\".", + "notificationRuleRoomOneToOne": "Кімната \"Один на один\"", + "approve": "Схвалити", + "youHaveKnocked": "Ви постукали", + "sentVoiceMessage": "🎙️Голосове повідомлення від {sender} ({duration})", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "countInvited": "Запрошено {count}", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "checkList": "Контрольний список", + "commandHint_logout": "Вийти на цьому пристрої", + "commandHint_logoutall": "Вийти на всіх активних пристроях", + "displayNavigationRail": "Показати навігаційну карту на мобільному", + "customReaction": "Власні реакції", + "moreEvents": "Інші події", + "declineInvitation": "Відхилити запрошення", + "noMessagesYet": "Поки немає повідомлень", + "longPressToRecordVoiceMessage": "Затисніть, щоб записати голосове повідомлення.", + "pause": "Призупинити", + "resume": "Продовжити", + "newSubSpace": "Новий вкладений простір", + "moveToDifferentSpace": "Перемістити в інший простір", + "moveUp": "Перемістити вище", + "moveDown": "Переместити нижче", + "removeFromSpaceDescription": "Бесіду буде видалено з простору, та вона залишиться у вашому списку бесід.", + "countChats": "{chats} бесід", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "Учасник {spaces} просторів", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "Учасник просторів {spaces} може постукати", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Задонатити", + "startedAPoll": "Нове опитування від {username}.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "Опитування", + "startPoll": "Розпочати опитування", + "endPoll": "Завершити опитування", + "answersVisible": "Відповіді видимі", + "answersHidden": "Відповіді сховано", + "pollQuestion": "Питання опитування", + "answerOption": "Варіант відповіді", + "addAnswerOption": "Додати варіант відповіді", + "allowMultipleAnswers": "Дозволити декілька варіантів відповіді", + "pollHasBeenEnded": "Опитування завершилось", + "skipChatBackupWarning": "Ви впевнені? Без резервного копіювання бесід ви можете втратити доступ до повідомлень, якщо ви зміните пристрій.", + "loadingMessages": "Завантажуються повідомлення", + "setupChatBackup": "Налаштувати резервне копіювання бесід", + "replyInThread": "Відповісти у вітці", + "saveChanges": "Зберегти зміни", + "createSticker": "Створити наліпку чи емодзі", + "useAsSticker": "Використати як наліпку", + "useAsEmoji": "Використати як емодзі", + "stickerPackNameAlreadyExists": "Набір наліпок з такою назвою вже є", + "newStickerPack": "Новий набір наліпок", + "stickerPackName": "Назва набору наліпок", + "attribution": "Атрибуція", + "skipChatBackup": "Пропустити резервне копіювання бесід", + "thread": "Вітка", + "backToMainChat": "Повернутись до основної бесіди", + "answersWillBeVisibleWhenPollHasEnded": "Відповіді стануть публічними після завершення опитування", + "countVotes": "{count, plural, =1{Один голос} other{{count} голосів}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "countReplies": "{count, plural, =1{Одна відповідь} other{{count} відповідей}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "changedTheChatDescription": "{username} змінює опис бесіди", + "changedTheChatName": "{username} змінює назву бесіди", + "noMoreResultsFound": "Нічого не знайдено", + "chatSearchedUntil": "Пошук в бесіді по {time}", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "versionWithNumber": "Версія: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Журнали", + "advancedConfigs": "Розширені налаштування", + "advancedConfigurations": "Розширені налаштування", + "signInWithLabel": "Увійти через:", + "identityServer": "Сервер профілів:", + "clientWellKnownInformation": "Дані клієнту із .well-known:", + "federationBaseUrl": "Основний URL федерації", + "baseUrl": "Основний URL", + "signIn": "Увійти", + "createNewAccount": "Створити новий обліковий запис", + "signUpGreeting": "FluffyChat децентралізований! Виберіть сервер, на якому ви хочете створити свій обліковий запис, і почнімо!", + "signInGreeting": "Ви вже маєте обліковий запис у Matrix? Ласкаво просимо! Виберіть свій домашній сервер і ввійдіть.", + "appIntro": "За допомогою FluffyChat ви можете спілкуватися зі своїми друзями. Це безпечний децентралізований месенджер [matrix]! Дізнайтеся більше на сайті https://matrix.org або просто зареєструйтеся.", + "theProcessWasCanceled": "Процес скасовано." +} diff --git a/lib/l10n/intl_uz.arb b/lib/l10n/intl_uz.arb new file mode 100644 index 000000000..a4df28983 --- /dev/null +++ b/lib/l10n/intl_uz.arb @@ -0,0 +1,3129 @@ +{ + "repeatPassword": "Parolni takrorlang", + "normalUser": "Oddiy foydalanuvchi", + "alwaysUse24HourFormat": "true", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "notAnImage": "Rasm fayli emas.", + "setCustomPermissionLevel": "Maxsus ruxsatlar darajasini sozlash", + "setPermissionsLevelDescription": "Quyidagi oldindan belgilangan rolni tanlang yoki 0-100 orasidagi maxsus ruxsatlar darajasini kiriting.", + "ignoreUser": "Foydalanuvchini e’tiborsiz qoldirish", + "remove": "O‘chirish", + "@remove": { + "type": "String", + "placeholders": {} + }, + "importNow": "Hozir import qilish", + "importEmojis": "Emojilarni import qilish", + "importFromZipFile": ".zip faylidan import qilish", + "exportEmotePack": "Emotsiyalar to‘plamini .zip fayl ko‘rinishida eksport qilish", + "replace": "Almashtirmoq", + "about": "Biz haqimizda", + "aboutHomeserver": "{homeserver} haqida", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "accept": "Qabul qilmoq", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} taklifni qabul qildi", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Hisob", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} shifrlashni yakunlash uchun faollashtirdi", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "Email qo‘shish", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "confirmMatrixId": "Hisobingizni o‘chirish uchun Matrix ID hisobingizni tasdiqlang.", + "supposedMxid": "Bu {mxid} bo‘lishi kerak", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "Suhbat tavsifini kiriting...", + "addToSpace": "Maydonga qo‘shish", + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "taxallus", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "Hammasi", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "Hamma suhbatlar", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_roomupgrade": "Bu guruhni berilgan guruh versiyasiga yangilang", + "commandHint_googly": "G‘ilay ko‘zlarini yuboring", + "commandHint_cuddle": "Erkalash yuborish", + "commandHint_hug": "Quchoqlash yuborish", + "googlyEyesContent": "{senderName} sizga gʻilay ko‘zlarini yubormoqda", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} sizni erkalamoqda", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} sizni quchoqlamoqda", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "answeredTheCall": "{senderName} chaqiruvga javob berdi", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Har kim qo‘shilishi mumkin", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "Ilova qulfi", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "PIN kod ishlatilmayotganida ilovani qulflash", + "archive": "Arxiv", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Mehmon foydalanuvchilarga qo‘shilishga ruxsat berilganmi", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Ishonchingiz komilmi?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "Haqiqatan ham hisobingizdan chiqamoqchimisiz?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "Narigi foydalanuvchini imzolash uchun xavfsiz do‘kon parol iborasi yoki tiklash kalitini kiriting.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "{username}dan ushbu tasdiqlash so‘rovi qabul qilinsinmi?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "Animatsiyali stikerlar va emojilarni avtomatik ijro etish", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendTypingNotifications": "Yozish bildirishnomalarini yuborish", + "swipeRightToLeftToReply": "Javob berish uchun o‘ngdan chapga suring", + "badServerLoginTypesException": "Homeserver quyidagi kirish turlarini qo'llab-quvvatlaydi:\n{serverVersions}\nLekin bu ilova faqat quyidagi turlarni qo'llab-quvvatlaydi:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "sendOnEnter": "Enterda yuborish", + "badServerVersionsException": "Homeserver quyidagi Spec versiyalarini qo'llab-quvvatlaydi:\n{serverVersions}\nLekin bu ilova faqat {supportedVersions} versiyalarini qo'llab-quvvatlaydi", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "countChatsAndCountParticipants": "{chats} suhbatlar va {participants} ishtirokchilar", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "Boshqa chatlar topilmadi...", + "noChatsFoundHere": "Bu yerda hali chat topilmadi. Quyidagi tugmadan foydalanib, kimdir bilan yangi suhbat boshlang. ⤵️", + "joinedChats": "Qo'shilgan suhbatlar", + "unread": "Oʻqilmagan", + "space": "Boʻshliq", + "spaces": "Boʻshliqlar", + "banFromChat": "Suhbatdan taqiqlash", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "Taqiqlangan", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} taqiqladi {targetName}(ni)", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "Qurilmani bloklash", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Bloklandi", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "Bot xabarlari", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "Bekor qilish", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "{uri} URIni ochib boʻlmadi", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "changeDeviceName": "Qurilma nomini oʻzgartirish", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} suhbat avatarini oʻzgartirdi", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} suhbat tavsifini '{description}'ga oʻzgartirdi", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} suhbat nomini: '{chatname}'ga oʻzgartirdi", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} suhbat ruxsatnomalarini oʻzgartirdi", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} oʻzining nomini '{displayname}'ga oʻzgartirdi", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} mehmon kirish qoidalarini oʻzgartirdi", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} mehmon kirish qoidalarini: {rules}ga oʻzgartirdi", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} tarix koʻrinishini oʻzgartirdi", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} tarix koʻrinishini: {rules}ga oʻzgartirdi", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} qoʻshilish qoidalarini oʻzgartirdi", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} qoʻshilish qoidalarini: {joinRules}ga oʻzgartirdi", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} avatarini oʻzgartirdi", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} taklif havolasini oʻzgartirdi", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "Parolni o‘zgartirish", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Homeserverni almashtirish", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "Uslubingizni o‘zgartiring", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Guruh nomini o‘zgartirish", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "Avataringizni almashtiring", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "Shifrlash buzilgan", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "Suhbat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "yourChatBackupHasBeenSetUp": "Suhbat zaxirangiz sozlandi.", + "chatBackup": "Suhbat zaxirasi", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Eski xabarlaringiz tiklash kaliti bilan himoyalangan. Uni yo‘qotib qo‘ymasligingizga ishonch hosil qiling.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Suhbat tafsilotlari", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "Suhbat bu maydonga kiritildi", + "changedTheRoomAliases": "{username} xona taxalluslarini oʻzgartirdi", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "chooseAStrongPassword": "Kuchli parol tanlang", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "Arxivni tozalash", + "close": "Yopish", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasdm": "Matrix identifikatorini berish uchun shaxsiy xabar guruhi sifatida belgilang", + "commandHint_markasgroup": "Guruh sifatida belgilash", + "commandHint_ban": "Bu guruhdan berilgan foydalanuvchini bloklash", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "Kesh tozalash", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "Boʻsh guruh suhbati yarating\nShifrlashni oʻchirish uchun --no-encryption dan foydalaning", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "Seansni bekor qilish", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "Jonli suhbatni boshlash\nShifrlashni o‘chirish uchun --no-encryption dan foydalaning", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_html": "HTML formatidagi matnni yuborish", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "Berilgan foydalanuvchini ushbu guruhga taklif qiling", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "Berilgan guruhga qoʻshilish", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "Berilgan foydalanuvchini guruhdan oʻchirish", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "Guruhni tark etish", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "Oʻzingizni tariflang", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "Bu guruh uchun rasmingizni sozlang (mxc-uri tomonidan)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "Bu guruh uchun displey nomini sozlang", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "Berilgan foydalanuvchi quvvat darajasini oʻrnating (standart: 50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "Formatlanmagan matnni yuboring", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "Javobni reaksiya sifatida yuboring", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "Matn yuborish", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "Berilgan foydalanuvchini bu guruhdan blokdan chiqazish", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "Buyruq yaroqsiz", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} komanda emas.", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "Iltimos emojilarni taqqoslang", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "Iltimos raqamlarni taqqoslang", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "Suhbatni sozlash", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "Tasdiqlash", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "Ulanish", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Kontakt guruhga taklif qilindi", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "Displey nomni oʻz ichiga oladi", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "Foydalanuvchi nomini oʻz ichiga oladi", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "Kontent server administratorlariga xabar qilindi", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "chats": "Suhbatlar", + "@chats": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "Buferga nusxalandi", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "Nusxalash", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "Buferga nusxalash", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "Xabarni shifrlab boʻlmadi: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "checkList": "Tekshirish roʻyxati", + "countParticipants": "{count} qatnashuvchilar", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "countInvited": "{count} taklif qilindi", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "Yaratish", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} suhbat yaratdi", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "createGroup": "Guruh yaratish", + "createNewSpace": "Yangi maydon", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "currentlyActive": "Hozirda faol", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "Qorongʻi", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "Bu sizning foydalanuvchi hisobingizni oʻchirib qoʻyadi. Buni qaytarib boʻlmaydi! Ishonchingiz komilmi?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "Yangi foydalanuvchilar uchun standart ruxsat darajasi", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "Oʻchirish", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Hisobni oʻchirish", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Xabarni oʻchirish", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "Qurilma", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Qurilma ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "Qurilmalar", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "Shaxsiy suhbatlar", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "allRooms": "Barcha guruh suhbatlar", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "Guruh uchun Emote toʻplamlar", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Emote Sozlamalari", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "globalChatId": "Ommaviy suhbat IDʼsi", + "accessAndVisibility": "Kirish va koʻrinish", + "accessAndVisibilityDescription": "Bu suhbatga kim qoʻshilishi mumkin va suhbatni qanday topish mumkin.", + "calls": "Qoʻngʻiroqlar", + "customEmojisAndStickers": "Maxsus emojilar va stikerlar", + "customEmojisAndStickersBody": "Istalgan suhbatda ishlatilishi mumkin boʻlgan maxsus emojilar yoki stikerlarni qoʻshing yoki ulashing.", + "emoteShortcode": "Emote qisqa kodi", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "Siz emote qisqa kodi va rasmni tanlashingiz kerak!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "Boʻsh suhbat", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "Emote paketini global miqyosda yoqish", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "Shifrlashni yoqish", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "Siz endi shifrlashni oʻchira olmaysiz. Ishonchingiz komilmi?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "Shifrlangan", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "Shifrlash", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "Shrift oʻlchami", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "Yuborvorish", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "Qoʻshilishdan", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "Taklifnomadan", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "Yangi guruhga oʻtish", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "Guruh", + "@group": { + "type": "String", + "placeholders": {} + }, + "chatDescription": "Suhbat tavsifi", + "chatDescriptionHasBeenChanged": "Suhbat tavsifi oʻzgartirildi", + "groupIsPublic": "Guruh ommaviy", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "Guruhlar", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "{displayname} bilan guruh", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "Mehmonlarga kirish taqiqlangan", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "Mehmonlar qoʻshila oladi", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} {targetName} uchun taklifnomani qaytarib oldi", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "Yordam", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "Tahrirlangan tadbirlarni yashirish", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideRedactedMessages": "Oʻchirilgan xabarlarni yashirish", + "hideRedactedMessagesBody": "Agar kimdir xabarni oʻchirsa, bu xabar endi suhbatda koʻrinmaydi.", + "hideInvalidOrUnknownMessageFormats": "Notoʻgʻri yoki nomaʼlum xabar formatlarini yashirish", + "howOffensiveIsThisContent": "Bu kontent qanchalik haqoratli?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "block": "Bloklash", + "blockedUsers": "Bloklangan foydalanuvchilar", + "blockListDescription": "Sizni bezovta qilayotgan foydalanuvchilarni bloklashingiz mumkin. Shaxsiy bloklash roʻyxatingizdagi foydalanuvchilardan hech qanday xabar yoki guruhga taklifnomalarni qabul qila olmaysiz.", + "blockUsername": "Foydalanuvchi nomini eʻtiborsiz qoldirish", + "iHaveClickedOnLink": "Men havolani bosdim", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "Notoʻgʻri parol yoki tiklash kaliti", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "Zararsiz", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "Kontaktni taklif qilish", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroupQuestion": "{contact} ni \"{groupName}\" suhbatiga taklif qilishni istaysizmi?", + "inviteContactToGroup": "Kontaktni {groupName} ga taklif qiling", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "noChatDescriptionYet": "Hali suhbat tavsifi yaratilmagan.", + "tryAgain": "Qayta urinib koʻrish", + "invalidServerName": "Server nomi notoʻgʻri", + "invited": "Taklif qilindi", + "@invited": { + "type": "String", + "placeholders": {} + }, + "redactMessageDescription": "Xabar ushbu suhbatdagi barcha ishtirokchilar uchun oʻchiriladi. Buni bekor qilib boʻlmaydi.", + "optionalRedactReason": "(Ixtiyoriy) Ushbu xabarni oʻchirish sababi...", + "invitedUser": "📩 {username} {targetName}ni taklif qildi", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "Faqat taklif qilingan foydalanuvchilar", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "Men uchun taklif qilish", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} sizni FluffyChat’ga taklif qildi.\n1. fluffychat.im saytiga tashrif buyuring va ilovani oʻrnating.\n2. Roʻyxatdan oʻting yoki tizimga kiring.\n3. Taklif havolasini oching:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "yozmoqda…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Displey nomi o‘zgartirildi", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Faylni yuklab olish", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "Tahrirlash", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "Bloklangan serverlarni tahrirlash", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "Suhbat ruxsatlari", + "editDisplayname": "Displey nomini tahrirlash", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "Xona taxalluslarini tahrirlash", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "Xona avatarini tahrirlash", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "Emotsiya allaqachon mavjud!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "Noto‘g‘ri emotsiya kodi!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emoteKeyboardNoRecents": "Yaqinda ishlatilgan emotsiyalar shu yerda chiqadi...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "Shifrlash yoqilmagan", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} chaqiruvni tugatdi", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "Email manzilini kiriting", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "homeserver": "Uy serveri", + "enterYourHomeserver": "Uy serveriga kiring", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "Joylashuv axboroti olinmadi: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "everythingReady": "Hammasi tayyor!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "O‘ta haqoratomuz", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "Fayl nomi", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} suhbatga qoʻshildi", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "Guruhga qoʻshilish", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} {targetName}ni tepdi", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} {targetName}ni tepdi va blokladi", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "Suhbatdan tepish", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "Oxirgi faol: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "Chiqish", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "Suhbatni tark etdi", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "Litsenziya", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "Yorugʻlik", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "Yana {count} ishtirokchini yuklang", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrate": "Sessiyani eksport qilish va qurilmani oʻchirish", + "dehydrateWarning": "Bu amalni bekor qilib boʻlmaydi. Zaxira faylini xavfsiz saqlang.", + "dehydrateTor": "TOR foydalanuvchilari: Seansni eksport qilish", + "dehydrateTorLong": "TOR foydalanuvchilari uchun oynani yopishdan oldin seansni eksport qilish tavsiya etiladi.", + "hydrateTor": "TOR foydalanuvchilari: Seans eksportini import qilish", + "hydrateTorLong": "Seansingizni oxirgi marta TOR’da eksport qildingizmi? Uni tezda import qiling va suhbatni davom ettiring.", + "hydrate": "Zaxira faylidan tiklash", + "loadingPleaseWait": "Yuklanmoqda… Iltimos, kuting.", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "Koʻproq yuklash…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "Joylashuv xizmatlari oʻchirib qoʻyilgan. Joylashuvingizni ulashish uchun ularni yoqing.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "locationPermissionDeniedNotice": "Joylashuvga ruxsat berilmadi. Iltimos, ularga joylashuvingizni ulashishga ruxsat bering.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "login": "Kirish", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "{homeserver} ga kirish", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "Chiqish", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "Aʼzo oʻzgarishlari", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "Qayd etmoq", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "Xabarlar", + "@messages": { + "type": "String", + "placeholders": {} + }, + "messagesStyle": "Xabarlar:", + "moderator": "Moderator", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "Suhbatni ovozsizlantirish", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "Iltimos, hozircha Pantalaimon boshdan-oyoq shifrlashdan foydalanishi kerakligini yodda tuting.", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "Yangi suhbat", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 FluffyChat yangi xabarlar", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "Yangi tasdiqlash so'rovi!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "Keyingi", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "Yoʻq", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "Serverga ulanish yoʻq", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "Hech qanday emoteʼlar topilmadi 😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Shifrlashni faqat guruh endi hamma uchun ochiq bo'lmay qolgandan keyingina faollashtirishingiz mumkin.", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "Firebase Cloud Messaging qurilmangizda mavjud emasga o'xshaydi. Push-bildirishnomalarni olishda davom etish uchun ntfy-ni o'rnatishingizni tavsiya qilamiz. NTFY yoki boshqa Unified Push provayderi yordamida siz ma'lumotlar xavfsizligini ta'minlash orqali push-bildirishnomalarni olishingiz mumkin. Siz ntfy-ni PlayStore yoki F-Droid-dan yuklab olishingiz mumkin.", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} matrix serveri emas, buning o'rniga {server2} dan foydalanilsinmi?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "shareInviteLink": "Taklifnoma havolasini ulashish", + "scanQrCode": "QR kodini skanerlang", + "none": "Hech biri", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "Siz hali parolingizni tiklash usulini qoʻshmadingiz.", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "Ruxsat yoʻq", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "Hech qanday guruhlar topilmadi…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "Bildirishnomalar", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "Ushbu hisob uchun bildirishnomalar yoqildi", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} foydalanuvchilar yozmoqda…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "obtainingLocation": "Joylashuv aniqlanmoqda…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "offensive": "Haqoratomuz", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "Oflayn", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "Hop", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "Onlayn", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "Onlayn kalit zaxira nusxasi yoqilgan", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "Afsuski, push-bildirishnomalarni sozlashda xatolik yuz berdi.", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "Voy, nimadir notoʻgʻri ketdi…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "Xabarlarni oʻqish uchun ilovani oching", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "Kamerani ochish", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "openVideoCamera": "Video uchun kamerani oching", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "Mijozlaringizdan biri tizimdan chiqdi", + "addAccount": "Hisob qoʻshish", + "editBundlesForAccount": "Bu hisob uchun toʻplamlarni tahrirlash", + "addToBundle": "Toʻplamga qoʻshish", + "removeFromBundle": "Bu toʻplamdan oʻchirish", + "bundleName": "Toʻplam nomi", + "enableMultiAccounts": "(BETA) Ushbu qurilmada bir nechta hisoblarni yoqish", + "openInMaps": "Xaritalarda ochish", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "link": "Havola", + "serverRequiresEmail": "Ushbu server roʻyxatdan oʻtish uchun elektron pochta manzilingizni tasdiqlashi kerak.", + "or": "Yoki", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "Qatnashuvchi", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "parol yoki tiklash kaliti", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "Parol", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "Parol unitilgan", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "Parol oʻzgartirildi", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "hideMemberChangesInPublicChats": "Ommaviy suhbatlarda aʼzolarga oʻzgartirishlarni yashirish", + "hideMemberChangesInPublicChatsBody": "Oʻqish qulayligini oshirish uchun kimdir ochiq suhbatga qoʻshilsa yoki undan chiqsa, suhbat vaqt jadvalida koʻrsatilmasin.", + "overview": "Umumiy ma'lumot", + "notifyMeFor": "Menga bildirishnoma yuborish", + "passwordRecoverySettings": "Parolni qayta tiklash sozlamalari", + "passwordRecovery": "Parolni qayta tiklash", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "Odamlar", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "Rasm tanlash", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "Toʻgʻnash", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "{fileName}ni oʻynash", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "Iltimos tanlang", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "Iltimos, kirish kodini tanlang", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "Iltimos, elektron pochtadagi havolani bosing va keyin davom eting.", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "Ilova qulfini oʻchirish uchun 4 ta raqamni kiriting yoki boʻsh qoldiring.", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterRecoveryKey": "Iltimos, tiklash kalitingizni kiriting:", + "pleaseEnterYourPassword": "Iltimos parolingizni kiriting", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "Iltimos PIN kodingizni kiriting", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "Iltimos foydalanuvchi nomini kiriting", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Iltimos, veb-saytdagi koʻrsatmalarga amal qiling va keyingisini bosing.", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "Maxfiylik", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "Ommaviy guruhlar", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "Push qoidalari", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "Sabab", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "Yozilmoqda", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedBy": "{username} tomonidan tahrirlangan", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "Shaxsiy suhbat", + "redactedByBecause": "{username} tomonidan tahrirlandi, sababi: \"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "redactedAnEvent": "{username} tadbirni oʻchirib tashladi", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "Xabarni tahrirlash", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "Roʻyxatdan oʻtish", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "Rad qilish", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} taklifni rad qildi", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "Qayta qoʻshilish", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "Qolgan barcha qurilmalarni oʻchirish", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "{username} tomonidan oʻchirildi", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "Qurilmani oʻchirish", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "Suhbat blokidan chiqazish", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "Avatarni oʻchirish", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "Guruhni yangiroq versiya bilan almashtirish", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "Javob yozish", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "Xabar berish", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "Ruxsat soʻrash", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "Xona takomillashtirildi", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "Guruh versiyasi", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "Fayl saqlash", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "Qidiruv", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "Xavfsizlik", + "@security": { + "type": "String", + "placeholders": {} + }, + "recoveryKey": "Tiklash kaliti", + "recoveryKeyLost": "Tiklash kaliti yo‘qolib qoldimi?", + "seenByUser": "{username} ko‘rgan", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "Yuborish", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "Xabar yuborish", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "Matn sifatida yuborish", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "Audio yuborish", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "Faylni yuborish", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "Rasm yuborish", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendImages": "{count} ta rasm yuborish", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "sendMessages": "Xabarlar yuborish", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "Asl nusxani yuborish", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Stiker yuborish", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "Video yuborish", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁 {username} fayl yubordi", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤 {username} audio yubordi", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "️ 🖼️ {username} rasm yubordi", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} stiker yubordi", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} video yubordi", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} chaqiruv axborotini yubordi", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "separateChatTypes": "To‘g‘ridan-to‘g‘ri suhbatlar va guruhlarni alohida ajratish", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "Asosiy taxallus sifatida belgilash", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "Maxsus hissiyotlarni sozlash", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setChatDescription": "Suhbat tavsifini sozlash", + "setInvitationLink": "Taklif havolasini sozlash", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "Ruxsatlar darajasini belgilash", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "Holatni sozlash", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "Sozlamalar", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "Bo‘lishmoq", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} joylashuvini ulashdi", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "shareLocation": "Joylashuvni ulashish", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Parolni ko‘rsatish", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "Mavjudlik:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "Boshqa foydalanuvchilarning holat xabarlarini ko‘rsatish", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "Yagona kirish", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "Tashlab ketish", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "Manba kodi", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "Guruh ochiq", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "spaceName": "Guruh nomi", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} chaqiruv boshladi", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "startFirstChat": "Birinchi suhbatni boshlash", + "status": "Holati", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "Bugun ahvolingiz qalay?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "Yuborish", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "Sinxronlanmoqda... Iltimos, kuting.", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWaitCounter": " Sinxronlanmoqda... ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "systemTheme": "Tizim", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "Mos emas", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "Mos keladi", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "Saralanganni almashtirish", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "O‘chirib qo‘yish", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "O‘qilgan/O‘qilmaganni belgilash", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "Talablar soni oshib ketdi. Keyinroq qayta urining!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Boshqa qurilmadan uzatish", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "Qayta yuborishga urining", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "Mavjud emas", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} {targetName}ni blokdan chiqardi", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "Qurilmani blokdan chiqarish", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "Notanish qurilma", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "Noma’lum shifrlash algoritmi", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "Noma’lum hodisa {type}", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "Suhbatni ovozli qilish", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "Olib tashlash", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 ta oʻqilmagan suhbat} other{{unreadCount} ta o‘qilmagan chat}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} va yana {count} kishi yozmoqda…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} va {username2} yozmoqda…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} yozmoqda…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪 {username} suhbatni tark etdi", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "Foydalanuvchi nomi", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} {type} tadbirini yubordi", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "unverified": "Tasdiqlanmagan", + "verified": "Tasdiqlangan", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "Tasdiqlash", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "Tasdiqlashni boshlash", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "Siz tasdiqladingiz!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "Boshqa hisob tasdiqlanmoqda", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "Video chaqiruv", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "Suhbat tarixining ko‘rinishi", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "Barcha ishtirokchilarga ko‘rinadi", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "Hammaga ko‘rinadigan", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "Ovozli xabar", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "Hamkor so‘rovni qabul qilishi kutilmoqda…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "Hamkor emoji qabul qilishini kutmoqda…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "Hamkor raqamlarni qabul qilishi kutilmoqda…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "Fon rasmi:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "Ogohlantirish!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "Sizga xat yubordik", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "Kim qaysi amalni bajarishi mumkin", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "Bu guruhga kim qo‘shilishi mumkin", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "Nima uchun bu haqda xabar bermoqchisiz?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "Yangi tiklash kalitini yaratish uchun suhbat zaxirasi tozalansinmi?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "Ushbu manzillar yordamida parolingizni tiklashingiz mumkin.", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "Xabar yozish…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "Ha", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "Siz", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "Siz ortiq bu suhbatda qatnashmayapsiz", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "Bu suhbatdan bloklandingiz", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "Ochiq kalitingiz", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "Xabar axboroti", + "time": "Vaqt", + "messageType": "Xabar turi", + "sender": "Yuboruvchi", + "openGallery": "Galereyani ochish", + "removeFromSpace": "Guruhdan olib tashlash", + "addToSpaceDescription": "Bu suhbatni unga kiritish uchun guruhni tanlang.", + "start": "Boshlash", + "usersMustKnock": "Foydalanuvchilar taqillatishi kerak", + "noOneCanJoin": "Hech kim qoʻshila olmaydi", + "userWouldLikeToChangeTheChat": "{user} suhbatga qoʻshilmoqchi.", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "Hech qanday ochiq havola yaratilmagan", + "knock": "Taqillating", + "users": "Foydalanuvchilar", + "unlockOldMessages": "Eski xabarlarni qulfdan chiqaring", + "storeInSecureStorageDescription": "Qayta tiklash kalitini ushbu qurilmaning xavfsiz xotirasida saqlang.", + "saveKeyManuallyDescription": "Tizim ulashish dialog oynasi yoki buferni ishga tushirish orqali ushbu kalitni qoʻlda saqlang.", + "storeInAndroidKeystore": "Android KeyStoreʼda saqlang", + "storeInAppleKeyChain": "Apple KeyChainʼda saqlang", + "storeSecurlyOnThisDevice": "Ushbu qurilmada xavfsiz saqlang", + "countFiles": "{count} fayllar", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "user": "Foydalanuvchi", + "custom": "Maxsus", + "foregroundServiceRunning": "Bu bildirishnoma old plan xizmati ishlab turgan paytda paydo bo‘ladi.", + "screenSharingTitle": "Ekranni ulashish", + "screenSharingDetail": "Siz ekraningizni FuffyChat’da ulashmoqdasiz", + "callingPermissions": "Qoʻngʻiroq qilish ruxsatlar", + "callingAccount": "Qoʻngʻiroq qilishi hisobi", + "callingAccountDetails": "FluffyChat’ga mahalliy android terish ilovasidan foydalanishga ruxsat beradi.", + "appearOnTop": "Teppada paydo boʻladi", + "appearOnTopDetails": "Ilovaning yuqori qismida koʻrinishiga ruxsat beradi (agar sizda Fluffychat qoʻngʻiroq qiluvchi hisobi sifatida oʻrnatilgan boʻlsa, kerak emas)", + "otherCallingPermissions": "Mikrofon, kamera va boshqa FluffyChat ruxsatnomalari", + "whyIsThisMessageEncrypted": "Nima uchun bu xabarni oʻqib boʻlmaydi?", + "noKeyForThisMessage": "Bu xabar siz ushbu qurilmada hisobingizga kirishdan oldin yuborilgan boʻlsa sodir boʻlishi mumkin.\n\nShuningdek, joʻnatuvchi qurilmangizni bloklagan yoki internet ulanishida biron bir muammo yuzaga kelgan boʻlishi mumkin.\n\nXabarni boshqa sessiyada oʻqiy olasizmi? Keyin xabarni undan uzatishingiz mumkin! Sozlamalar > Qurilmalar boʻlimiga oʻting va qurilmalaringiz bir-birini tasdiqlaganligiga ishonch hosil qiling. Keyingi safar xonani ochganingizda va ikkala sessiya ham oldinda boʻlganda, kalitlar avtomatik ravishda uzatiladi.\n\nTizimdan chiqishda yoki qurilmalarni almashtirishda kalitlarni yoʻqotishni xohlamaysizmi? Sozlamalarda suhbatning zaxira nusxasini yoqganingizga ishonch hosil qiling.", + "newGroup": "Yangi guruh", + "newSpace": "Yangi maydon", + "enterSpace": "Maydonga kirish", + "enterRoom": "Guruhga kirish", + "allSpaces": "Barcha maydonlar", + "numChats": "{number} suhbatlar", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "Muhim boʻlmagan shtat tadbirlarini yashirish", + "hidePresences": "Holat roʻyxati yashirilsinmi?", + "doNotShowAgain": "Qaytib koʻrsatilmasin", + "wasDirectChatDisplayName": "Boʻsh suhbat ({oldDisplayName} edi)", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "newSpaceDescription": "Maydonlar sizga suhbatlaringizni birlashtirish va shaxsiy yoki ommaviy hamjamiyatlarni yaratish imkonini beradi.", + "openChat": "Suhbatni ochish", + "indexedDbErrorLong": "Xabarlarni saqlash, afsuski, sukut bo'yicha maxfiy rejimda yoqilmagan.\nIltimos, tashrif buyuring\n- about:config\n- dom.indexedDB.privateBrowsing.enabled ga true berilgan\nAks holda, FluffyChat ni ishga tushirish mumkin emas.", + "youJoinedTheChat": "Siz suhbatga qoʻshildingiz", + "encryptThisChat": "Bu suhbatni shifrlash", + "disableEncryptionWarning": "Xavfsizlik nuqtai nazaridan, agar u ilgari yoqilgan boʻlsa, suhbatda shifrlashni oʻchirib qoʻyolmaysiz.", + "reopenChat": "Suhbatni qayta ochish", + "noBackupWarning": "Diqqat! Suhbatni zaxiralashni yoqmasangiz, shifrlangan xabarlaringizga kirish huquqini yoʻqotasiz. Tizimdan chiqishdan oldin chatni zaxiralashni yoqishingiz tavsiya etiladi.", + "inviteGroupChat": "📨 Guruh suhbatiga taklif", + "invitePrivateChat": "📨 Shaxsiy suhbatga taklif", + "archiveRoomDescription": "Suhbat arxivga koʻchiriladi. Boshqa foydalanuvchilar sizning suhbatdan chiqqaningizni koʻra oladilar.", + "roomUpgradeDescription": "Keyin suhbat yangi guruh versiyasi bilan qayta yaratiladi. Barcha ishtirokchilarga yangi suhbatga oʻtishlari kerakligi haqida xabar beriladi. Guruh versiyalari haqida koʻproq maʼlumotni https://spec.matrix.org/latest/rooms/ manzilida topishingiz mumkin", + "banUserDescription": "Foydalanuvchi suhbatdan bloklanadi va blokdan chiqarilmaguncha suhbatga qayta kira olmaydi.", + "unbanUserDescription": "Foydalanuvchi qayta suhbatga kira oladi agar ular urinib koʻrishsa.", + "kickUserDescription": "Foydalanuvchi suhbatdan chiqarib yuboriladi, ammo taqiqlanmaydi. Ommaviy chatlarda foydalanuvchi istalgan vaqtda qayta qoʻshilishi mumkin.", + "chatCanBeDiscoveredViaSearchOnServer": "Suhbatni {server} saytidagi qidiruv orqali topish mumkin", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "searchChatsRooms": "Qidiruv #chats, @users...", + "publicChatAddresses": "Ommaviy suhbat manzillari", + "addChatOrSubSpace": "Suhbat yoki sub-maydon qoʻshing", + "searchIn": "Suhbat \"{chat}\"da qidiring...", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "Suhbatdagi boshqa ishtirokchilar siz yangi xabar yozayotganingizni koʻrishlari mumkin.", + "sendReadReceiptsDescription": "Suhbatdagi boshqa ishtirokchilar sizning xabarni qachon oʻqiganingizni koʻrishlari mumkin.", + "unreadChatsInApp": "{appname}: {unread} ta oʻqilmagan suhbatlar", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "changeGeneralChatSettings": "Umumiy suhbat sozlamalarini oʻzgartirish", + "inviteOtherUsers": "Boshqa foydalanuvchilarni bu suhbatga taklif qilish", + "changeTheChatPermissions": "Suhbat ruxsatnomalarini oʻzgartirish", + "changeTheVisibilityOfChatHistory": "Suhbat tarix koʻrinishini oʻzgartirish", + "changeTheCanonicalRoomAlias": "Asosiy umumiy suhbat manzilini oʻzgartirish", + "changeTheDescriptionOfTheGroup": "Suhbat tavsifini oʻzgartirish", + "chatPermissionsDescription": "Ushbu suhbatda muayyan harakatlar uchun qaysi quvvat darajasi zarurligini aniqlang. 0, 50 va 100 quvvat darajalari odatda foydalanuvchilar, moderatorlar va administratorlarni ifodalaydi, ammo har qanday gradatsiya mumkin.", + "noticeChatBackupDeviceVerification": "Eslatma: Barcha qurilmalaringizni suhbat zaxira nusxasiga ulaganingizda, ular avtomatik ravishda tasdiqlanadi.", + "welcomeText": "Hey Hey 👋 Bu FluffyChat. Siz https://matrix.org bilan mos keladigan istalgan uy serveriga kirishingiz mumkin. Va keyin istalgan kishi bilan suhbatlashishingiz mumkin. Bu ulkan markazlashtirilmagan xabar almashish tarmog'i!", + "unableToJoinChat": "Chatga qoʻshilib boʻlmadi. Ehtimol, boshqa tomon suhbatni allaqachon yopib qoʻygan.", + "appIntroduction": "FluffyChat sizga turli messenjerlar orqali doʻstlaringiz bilan suhbatlashish imkonini beradi. Batafsil maʼlumotni https://matrix.org saytidan oling yoki shunchaki *Davom etish* tugmasini bosing.", + "newChatRequest": "📩 Yangi suhbat uchun soʻrov", + "shareKeysWithDescription": "Shifrlangan suhbatlarda xabarlaringizni oʻqishlari uchun qaysi qurilmalarga ishonish kerak?", + "enterNewChat": "Yangi suhbatga kirish", + "removeFromSpaceDescription": "Suhbat maydondan olib tashlanadi, lekin hali ham suhbatlarlar ro‘yxatida chiqadi.", + "countChats": "{chats} suhbatlar", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "backToMainChat": "Asosiy suhbatga qaytish", + "pleaseEnterRecoveryKeyDescription": "Eski xabarlaringizni qulfdan chiqarish uchun, iltimos, avvalgi seansdan yaratilgan tiklash kalitingizni kiriting. Sizning tiklash kalitingiz parolingiz EMAS.", + "publish": "Nashr qilish", + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "markAsRead": "Oʻqilgan sifatida belgilash", + "reportUser": "Foydalanuvchi haqida xabar berish", + "dismiss": "Rad qilmoq", + "reactedWith": "{sender} {reaction} bilan reaksiya bildirdi", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Xonaga mahkamlash", + "confirmEventUnpin": "Tadbirni butunlay olib tashlashga ishonchingiz komilmi?", + "placeCall": "Qoʻngʻiroq qilish", + "voiceCall": "Ovozli qoʻngʻiroq", + "unsupportedAndroidVersion": "Qoʻllab-quvvatlanmaydigan Android versiyasi", + "unsupportedAndroidVersionLong": "Bu funksiya Androidning yangi versiyasini talab qiladi. Iltimos, yangilanishlar yoki Lineage OS qoʻllab-quvvatlashini tekshiring.", + "videoCallsBetaWarning": "Iltimos, video qoʻngʻiroqlar hozirda beta-versiyada ekanligini unutmang. Ular kutilganidek ishlamasligi yoki barcha platformalarda umuman ishlamasligi mumkin.", + "experimentalVideoCalls": "Tajriba video qoʻngʻiroqlar", + "emailOrUsername": "Elektron pochta yoki foydalanuvchi nomi", + "indexedDbErrorTitle": "Shaxsiy rejim bilan bogʻliq muammolar", + "switchToAccount": "{number} hisobiga oʻtish", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "Keyingi hisob", + "previousAccount": "Oldingi hisob", + "addWidget": "Vidjet qoʻshish", + "widgetVideo": "Video", + "sorryThatsNotPossible": "Kechirasiz... bu mumkin emas", + "deviceKeys": "Qurilma kalitlari:", + "noOtherDevicesFound": "Boshqa qurilma topilmadi", + "fileIsTooBigForServer": "Yuborish imkonsiz! Server faqat {max} hajmgacha bo‘lgan ilovalarni qo‘llab-quvvatlaydi.", + "@fileIsTooBigForServer": { + "type": "String", + "placeholders": { + "max": { + "type": "String" + } + } + }, + "fileHasBeenSavedAt": "Fayl {path}da saqlandi", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "Oxirgi o‘qilgan xabarga o‘tish", + "readUpToHere": "Bu yerga qadar o‘qish", + "jump": "Sakrash", + "openLinkInBrowser": "Havolani brauzerda ochish", + "reportErrorDescription": "😭 Voy yo‘q. Nimadir xato ketdi. Agar xohlasangiz, bu xato haqida dasturchilarga xabar berishingiz mumkin.", + "report": "hisobot", + "signInWithPassword": "Parol bilan kirish", + "pleaseTryAgainLaterOrChooseDifferentServer": "Keyinroq qayta urining yoki boshqa serverni tanlang.", + "signInWith": "{provider} bilan kiring", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "profileNotFound": "Foydalanuvchi serverda topilmadi. Ehtimol, ulanishda muammo bor yoki foydalanuvchi mavjud emas.", + "setTheme": "Mavzu tanlash:", + "setColorTheme": "Rang mavzusini sozlash:", + "invite": "Taklif qilish", + "invalidInput": "Xato kiritildi!", + "wrongPinEntered": "PIN noto‘g‘ri kiritildi! {seconds} soniyadan keyin qayta urining...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "pleaseEnterANumber": "0 dan katta son kiriting", + "removeDevicesDescription": "Bu qurilmadan chiqarilasiz va ortiq xabarlarni qabul qila olmaysiz.", + "noUsersFoundWithQuery": "Afsuski, \"{query}\" soʻrovi bilan foydalanuvchi topilmadi. Iltimos, xato qilganingizni tekshiring.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "knocking": "Taqillatmoqda", + "nothingFound": "Hech nima topilmadi...", + "groupName": "Guruh nomi", + "createGroupAndInviteUsers": "Guruh yaratish va foydalanuvchilarni taklif qilish", + "groupCanBeFoundViaSearch": "Guruh qidiruv orqali topilishi mumkin", + "wrongRecoveryKey": "Kechirasiz... bu toʻgʻri tiklash kaliti emasga oʻxshaydi.", + "startConversation": "Suhbat boshlash", + "commandHint_sendraw": "Xom jsonni yuborish", + "databaseMigrationTitle": "Maʼlumotlar bazasi optimallashtirilgan", + "databaseMigrationBody": "Iltimos, kuting. Bu biroz vaqt olishi mumkin.", + "leaveEmptyToClearStatus": "Holatingizni tozalash uchun boʻsh qoldiring.", + "select": "Tanlash", + "searchForUsers": "@users ni qidiring...", + "pleaseEnterYourCurrentPassword": "Iltimos, joriy maxfiy soʻzingizni kiriting", + "newPassword": "Yangi maxfiy soʻz", + "pleaseChooseAStrongPassword": "Iltimos kuchli maxfiy soʻz tanlang", + "passwordsDoNotMatch": "Maxfiy soʻzlar mos kelmadi", + "passwordIsWrong": "Siz kiritgan maxfiy soʻz xato", + "publicLink": "Ommaviy havola", + "createNewAddress": "Yangi manzil yarating", + "joinSpace": "Maydonga qoʻshiling", + "publicSpaces": "Ommaviy maydonlar", + "subspace": "Sub-maydonlar", + "decline": "Rad qilish", + "thisDevice": "Ushbu qurilma:", + "initAppError": "Ilovani ishga tushirishda xatolik yuz berdi", + "userRole": "Foydalanuvchi roli", + "minimumPowerLevel": "{level} minimal quvvat darajasidir.", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "searchMore": "Koʻproq qidirish...", + "gallery": "Galereya", + "files": "Fayllar", + "databaseBuildErrorBody": "SQlite maʼlumotlar bazasini yaratib boʻlmadi. Ilova hozircha eski maʼlumotlar bazasidan foydalanishga harakat qilmoqda. Iltimos, ushbu xato haqida {url} manzilidagi dasturchilarga xabar bering. Xato xabari: {error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sessionLostBody": "Seansingiz yoʻqoldi. Iltimos, ushbu xato haqida {url} manzilidagi dasturchilarga xabar bering. Xato xabari: {error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "Ilova endi seansingizni zaxira nusxasidan tiklashga harakat qiladi. Iltimos, ushbu xato haqida {url} manzilidagi dasturchilarga xabar bering. Xato xabari: {error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "forwardMessageTo": "Xabarni {roomName}ga yoʻnaltirilsinmi?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceipts": "Oʻqilganlik haqida xabarnomalarni yuborish", + "formattedMessages": "Formatlangan xabarlar", + "formattedMessagesDescription": "Markdown yordamida qalin matn kabi boy xabar mazmunini koʻrsating.", + "verifyOtherUser": "🔐 Boshqa foydalanuvchini tasdiqlang", + "verifyOtherUserDescription": "Agar siz boshqa foydalanuvchini tasdiqlasangiz, aslida kimga yozayotganingizni bilishingizga amin boʻlishingiz mumkin. 💪\n\nTekshiruvni boshlaganingizda, siz va boshqa foydalanuvchi ilovada qalqib chiquvchi oynani koʻrasiz. Keyin u yerda siz bir-biringiz bilan taqqoslashingiz kerak boʻlgan bir qator emojilar yoki raqamlarni koʻrasiz.\n\nBuning eng yaxshi usuli - uchrashish yoki video qoʻngʻiroqni boshlash. 👭", + "verifyOtherDevice": "🔐 Boshqa qurilmani tasdiqlang", + "verifyOtherDeviceDescription": "Boshqa qurilmani tasdiqlaganingizda, bu qurilmalar kalitlarni almashishi mumkin, bu umumiy xavfsizligingizni oshiradi. 💪 Tasdiqlashni boshlaganingizda, ikkala qurilmada ham ilovada qalqib chiquvchi oyna paydo bo‘ladi. U yerda siz bir-biri bilan taqqoslashingiz kerak bo‘lgan emojilar yoki raqamlar qatorini ko‘rasiz. Tasdiqlashni boshlashdan oldin ikkala qurilma ham yoningizda bo‘lgani ma’qul. ✓", + "acceptedKeyVerification": "{sender} kalit tekshiruvini qabul qildi", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "contentNotificationSettings": "Kontent bildirishnomasi sozlamalari", + "generalNotificationSettings": "Umumiy bildirishnoma sozlamalari", + "roomNotificationSettings": "Xona bildirishnomasi sozlamalari", + "userSpecificNotificationSettings": "Foydalanuvchiga xos bildirishnoma sozlamalari", + "otherNotificationSettings": "Boshqa bildirishnoma sozlamalari", + "notificationRuleContainsUserName": "Foydalanuvchi nomini ichiga oladi", + "notificationRuleContainsUserNameDescription": "Xabarda foydalanuvchi nomi mavjud bo‘lsa, foydalanuvchiga xabar beradi.", + "notificationRuleMaster": "Barcha bildirishnomalarni ovozsiz qilish", + "notificationRuleMasterDescription": "Boshqa barcha qoidalarni bekor qiladi va barcha bildirishnomalarni faolsizlantiradi.", + "notificationRuleSuppressNotices": "Avtomatlashtirilgan xabarlarni o‘chirish", + "notificationRuleInviteForMe": "Men uchun taklif qilish", + "notificationRuleInviteForMeDescription": "Foydalanuvchi xonaga taklif qilinganda unga xabar beradi.", + "notificationRuleMemberEvent": "A’zo tadbirlari", + "notificationRuleMemberEventDescription": "Obuna tadbirlari uchun bildirishnomalarni o‘chiradi.", + "notificationRuleIsUserMention": "Foydalanuvchi zikri", + "notificationRuleIsUserMentionDescription": "Foydalanuvchi xabarida to‘g‘ridan-to‘g‘ri tilga olinganida unga xabar beradi.", + "notificationRuleContainsDisplayName": "Tarkibida displey nomi bor", + "notificationRuleContainsDisplayNameDescription": "Xabarda foydalanuvchining displey nomi mavjudligi haqida foydalanuvchiga xabar beradi.", + "notificationRuleSuppressNoticesDescription": "Botlar kabi avtomatlashtirilgan mijozlardan kelgan bildirishnomalarni to‘xtatadi.", + "notificationRuleIsRoomMention": "Xonaga eslatma", + "notificationRuleIsRoomMentionDescription": "Xona zikri mavjudligida foydalanuvchiga xabar beradi.", + "notificationRuleRoomnotif": "Xona bildirishnomasi", + "notificationRuleRoomnotifDescription": "Xabar tarkibida @room bo‘lsa, foydalanuvchiga xabar beradi.", + "notificationRuleReaction": "Reaksiya", + "notificationRuleReactionDescription": "Munosabat bildirishnomalarini o‘chiradi.", + "canceledKeyVerification": "{sender} kalit tekshiruvini bekor qildi", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} kalitni tasdiqlashni yakunladi", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} kalitni tasdiqlash uchun tayyor", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} kalitni tasdiqlash talabini yubordi", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} kalit tekshiruvini so‘radi", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "Shaffof", + "incomingMessages": "Kiruvchi xabarlar", + "stickers": "Stikerlar", + "discover": "Kashf etish", + "commandHint_ignore": "Berilgan matriks ID e’tiborga olinmasin", + "commandHint_unignore": "Berilgan matriks IDni e’tiborsiz qoldirish", + "noDatabaseEncryption": "Bu platformada ma’lumotlar bazasini shifrlash ishlamaydi", + "thereAreCountUsersBlocked": "Hozirda {count} ta foydalanuvchi bloklangan.", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "restricted": "Cheklangan", + "knockRestricted": "Taqillatish cheklangan", + "goToSpace": "Maydonga o‘tish: {space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "Ochilmagan deb belgilash", + "userLevel": "{level} - Foydalanuvchi", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - Moderator", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - Admin", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "sendRoomNotifications": "@room bildirishnomalarini yuborish", + "updateInstalled": "🎉 {version} versiyasiga yangilandi!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "changelog": "O‘zgarishlar jurnali", + "sendCanceled": "Yuborish bekor qilindi", + "loginWithMatrixId": "Matriks-ID bilan kirish", + "discoverHomeservers": "Uy serverlarini kashf eting", + "whatIsAHomeserver": "Uy serveri nima?", + "homeserverDescription": "Barcha ma’lumotlaringiz xuddi elektron pochta provayderi kabi uy serverda saqlanadi. Siz qaysi uy serveridan foydalanishni tanlashingiz mumkin, shu bilan birga siz hamma bilan muloqot qilishingiz mumkin. Batafsil: https://matrix.org.", + "doesNotSeemToBeAValidHomeserver": "Uy serveri mos emasga o‘xshaydi. URL xato kiritilganmi?", + "calculatingFileSize": "Fayl hajmi hisoblanmoqda...", + "prepareSendingAttachment": "Yuborish uchun biriktirmani tayyorlang...", + "sendingAttachment": "Biriktirish yuborilmoqda...", + "generatingVideoThumbnail": "Video eskizi yaratilmoqda...", + "compressVideo": "Video siqilmoqda...", + "sendingAttachmentCountOfCount": "Biriktirma yuborilmoqda: {index} of {length}...", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "Server limiti tugadi! {seconds} soniya kutilmoqda...", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "Qurilmalaringizdan biri tasdiqlanmagan", + "continueText": "Davom etish", + "blur": "Xiralashtirish:", + "opacity": "Noaniqlik:", + "setWallpaper": "Fon rasmini sozlash", + "manageAccount": "Hisobni boshqarish", + "noContactInformationProvided": "Server hech qanday yaroqli kontakt axborotini taqdim etmaydi", + "contactServerAdmin": "Server administratori bilan bog‘lanish", + "contactServerSecurity": "Aloqa serveri xavfsizligi", + "supportPage": "Yordam sahifasi", + "serverInformation": "Server haqida ma’lumot:", + "name": "Nomi", + "version": "Versiya", + "website": "Sayt", + "compress": "Siqmoq", + "boldText": "Qalin matn", + "italicText": "Qiya matn", + "strikeThrough": "O‘tish joyi", + "pleaseFillOut": "Iltimos, to‘ldiring", + "invalidUrl": "Yaroqsiz url", + "addLink": "Havola kiritish", + "previous": "Avvalgi", + "otherPartyNotLoggedIn": "Narigi tomon hozirda hisobingizga kirmagan va shuning uchun xabarlarni qabul qila olmaydi!", + "appWantsToUseForLogin": "Hisobga kirish '{server}' ishlating", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "appWantsToUseForLoginDescription": "Siz bu bilan ilova va veb-saytga siz haqingizdagi axborotni ulashishga ruxsat berasiz.", + "open": "Ochish", + "waitingForServer": "Server kutilmoqda...", + "notificationRuleRoomServerAcl": "Guruh serveri ACL", + "notificationRuleRoomServerAclDescription": "Guruh serveriga kirishni boshqarish ro‘yxatlari (ACL) uchun bildirishnomalarni bostiradi.", + "notificationRuleSuppressEdits": "Tahrirlarni bostirish", + "notificationRuleSuppressEditsDescription": "Tahrirlangan xabarlar uchun bildirishnomalarni o‘chiradi.", + "notificationRuleCall": "Chaqiruv", + "notificationRuleCallDescription": "Chaqiruvlar haqida foydalanuvchiga xabar beradi.", + "notificationRuleEncryptedRoomOneToOne": "Shifrlangan birga-bir guruh", + "notificationRuleEncryptedRoomOneToOneDescription": "Shifrlangan birga-bir guruhlardagi xabarlar haqida foydalanuvchiga xabar beradi.", + "notificationRuleTombstoneDescription": "Xonani faolsizlantirish xabarlari haqida foydalanuvchiga xabar beradi.", + "notificationRuleRoomOneToOne": "Birga-bir guruh", + "notificationRuleRoomOneToOneDescription": "Birga-bir guruhlardagidagi xabarlar haqida foydalanuvchiga xabar beradi.", + "notificationRuleMessage": "Xabar", + "notificationRuleMessageDescription": "Foydalanuvchiga umumiy xabarlar haqida xabar beradi.", + "notificationRuleEncrypted": "Shifrlangan", + "notificationRuleEncryptedDescription": "Shifrlangan guruhlardagi xabarlar haqida foydalanuvchiga xabar beradi.", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "Jitsi vidjet hodisalari haqida foydalanuvchiga xabar beradi.", + "notificationRuleServerAcl": "Server ACL hodisalarini bostirish", + "notificationRuleServerAclDescription": "Server ACL hodisalari uchun bildirishnomalarni o‘chiradi.", + "unknownPushRule": "Noma’lum push qoidasi '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "sentVoiceMessage": "️ 🎙️{duration} - {sender}dan ovozli xabar", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "deletePushRuleCanNotBeUndone": "Agar ushbu bildirishnoma sozlamasini o‘chirib tashlasangiz, buni bekor qilib bo‘lmaydi.", + "more": "Yana", + "shareKeysWith": "Kalitlarni ulashish...", + "allDevices": "Barcha qurilmalar", + "crossVerifiedDevicesIfEnabled": "Agar yoqilgan bo‘lsa, tasdiqlangan qurilmalarni kesib o‘tish", + "crossVerifiedDevices": "O‘zaro tekshirilgan qurilmalar", + "verifiedDevicesOnly": "Faqat tasdiqlangan qurilmalar", + "takeAPhoto": "Suratga olish", + "recordAVideo": "Video yozib olish", + "optionalMessage": "(Ixtiyoriy) xabar...", + "notSupportedOnThisDevice": "Bu qurilmada ishlamaydi", + "approve": "Tasdiqlash", + "youHaveKnocked": "Siz taqillatdingiz", + "pleaseWaitUntilInvited": "Iltimos, hozir kutib turing, xonadan kimdir sizni taklif qilguncha.", + "commandHint_logout": "Joriy qurilmadan chiqish", + "commandHint_logoutall": "Barcha faol qurilmalardan chiqish", + "displayNavigationRail": "Mobilda navigatsiya temir yo‘lini ko‘rsatish", + "customReaction": "Maxsus reaksiya", + "moreEvents": "Boshqa hodisalar", + "declineInvitation": "Taklifni rad etish", + "noMessagesYet": "Hozircha xabarlar yo‘q", + "longPressToRecordVoiceMessage": "Ovozli xabarni yozib olish uchun uzoq bosing.", + "pause": "Pauza", + "resume": "Davom etish", + "newSubSpace": "Yangi quyi maydon", + "moveToDifferentSpace": "Boshqa maydonga o‘tish", + "moveUp": "Yuqoriga surish", + "moveDown": "Pastga surish", + "spaceMemberOf": "{spaces} maydoni a’zosi", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "{spaces} maydoni a’zosi eshikni taqillatishi mumkin", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "Xayriya qilmoq", + "startedAPoll": "{username} so‘rovnoma boshladi.", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "So‘rov", + "startPoll": "So‘rovni boshlash", + "endPoll": "So‘rovnomani yakunlash", + "answersVisible": "Javoblar ko‘rinadi", + "answersHidden": "Javoblar berkitildi", + "pollQuestion": "So‘rovnoma savoli", + "answerOption": "Javob varianti", + "addAnswerOption": "Javob variantini kiritish", + "allowMultipleAnswers": "Bir nechta javobga ruxsat berish", + "pollHasBeenEnded": "So‘rovnoma yakunlandi", + "countVotes": "{count, plural, =1{Bir ovoz} other{{count} ta ovoz}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "So‘rovnoma tugaganida javoblar chiqadi", + "replyInThread": "Sahifada javob berish", + "countReplies": "{count, plural, =1{Bitta javob} other{{count} ta javob}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "thread": "Sahifa", + "widgetEtherpad": "Matnli qayd", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "Maxsus", + "widgetName": "Nomi", + "widgetUrlError": "Bu yaroqli URL emas.", + "widgetNameError": "Iltimos, displey nomini kiriting.", + "errorAddingWidget": "Vidjet kiritilmadi.", + "youRejectedTheInvitation": "Taklifni rad etdingiz", + "youAcceptedTheInvitation": "👍 Taklifni qabul qildingiz", + "youBannedUser": "Siz {user}ni blokladingiz", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "Siz {user} uchun taklifnomani bekor qildingiz", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 Sizni quyidagi havola orqali taklif qilishdi:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 Sizni {user} taklif qildi", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "invitedBy": "📩 {user} taklif qilgan", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 Siz {user}ni taklif qildingiz", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 Siz {user}ni chiqarib yubordingiz", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 Siz {user}ni chiqardingiz va blokladingiz", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "{user}ni blokdan chiqardingiz", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "hasKnocked": "🚪 {user} taqillatdi", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "makeAdminDescription": "Bu foydalanuvchini admini qilsangiz, uni bekor qila olmasligingiz mumkin, chunki u siz bilan bir xil ruxsatlarga ega bo‘ladi.", + "pushNotificationsNotAvailable": "Push-bildirishnomalar mavjud emas", + "learnMore": "Batafsil", + "yourGlobalUserIdIs": "Global foydalanuvchi ID raqamingiz: ", + "notificationRuleTombstone": "Qabrtosh", + "identity": "Shaxs", + "@identity": { + "type": "String", + "placeholders": {} + }, + "emojis": "Emojilar", + "changedTheChatDescription": "{username} chat tavsifini o‘zgartirdi", + "changedTheChatName": "{username} chat nomini o‘zgartirdi", + "saveChanges": "O‘zgarishlarni saqlash", + "createSticker": "Stiker yoki emoji yaratish", + "useAsSticker": "Stiker sifatida ishlatish", + "useAsEmoji": "Emoji sifatida ishlatish", + "stickerPackNameAlreadyExists": "Stiker paketi nomi allaqachon mavjud", + "newStickerPack": "Yangi stikerlar paketi", + "stickerPackName": "Stiker paketi nomi", + "attribution": "Atributsiya", + "skipChatBackup": "Chat zaxirasini tashlab ketish", + "skipChatBackupWarning": "Ishonchingiz komilmi? Chat zaxirasini yoqmasdan qurilmangizni almashtirsangiz, xabarlaringizga kira olmay qolishingiz mumkin.", + "loadingMessages": "Xabarlar yuklanmoqda", + "setupChatBackup": "Chat zaxirasini sozlash", + "noMoreResultsFound": "Boshqa natijalar topilmadi", + "chatSearchedUntil": "Chat {time} gacha qidirildi", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "Federatsiya bazasi URL manzili", + "clientWellKnownInformation": "Mijozlarga yaxshi tanish ma’lumotlar:", + "baseUrl": "Asosiy URL", + "identityServer": "Identifikatsiya serveri:", + "versionWithNumber": "Versiya: {version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "Jurnallar", + "advancedConfigs": "Kengaytirilgan konfiguratsiyalar", + "advancedConfigurations": "Kengaytirilgan sozlamalar", + "signInWithLabel": "Kirish:" +} diff --git a/lib/l10n/intl_vi.arb b/lib/l10n/intl_vi.arb new file mode 100644 index 000000000..584c2990c --- /dev/null +++ b/lib/l10n/intl_vi.arb @@ -0,0 +1,814 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.781172", + "about": "Giới thiệu", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "Đồng ý", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "{username} đã đồng ý lời mời", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Tài khoản", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "{username} đã kích hoạt mã hóa đầu cuối 2 chiều", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "admin": "Quản trị viên", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "bí danh", + "@alias": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} đã trả lời cuộc gọi", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "Mọi người đều có thể gia nhập", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "archive": "Lưu trữ", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "Khách vãng lai có được tham gia không", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "Bạn chắc chứ?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "Thiết bị bị chặn", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "verified": "Đã xác thực", + "@verified": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "Chuyển từ thiết bị khác", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "showPassword": "Hiển thị mật khẩu", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "Vui lòng làm theo hướng dẫn trên trang web và bấm tiếp", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "Bạn chỉ có thể kích hoạt mã hoá khi phòng này không mở", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "next": "Tiếp", + "@next": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "Mọi thứ đã sẵn sàng!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "Cài đặt biểu tượng cảm xúc", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "Sửa tên hiển thị", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "Tải ảnh xuống", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "Tên hiển thị đã được thay đổi", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "devices": "Các thiết bị", + "@devices": { + "type": "String", + "placeholders": {} + }, + "deviceId": "Mã xác định thiết bị", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "device": "Thiết bị", + "@device": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "Xoá tin nhắn", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "Xoá tài khoản", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "delete": "Xoá", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deactivateAccountWarning": "Việc này sẽ vô hiệu hoá tài khoản của bạn. Điều này không thể đảo ngược được! Bạn chắc là vẫn muốn tiếp tục chứ?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "dateWithYear": "{day}/{month}/{year}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithoutYear": "{day}/{month}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "currentlyActive": "Đang hoạt động", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "{username} đã tạo cuộc trò chuyện", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "create": "Tạo", + "@create": { + "type": "String", + "placeholders": {} + }, + "countParticipants": "{count} thành viên", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "couldNotDecryptMessage": "Không thể giải mã tin nhắn: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "copy": "Sao chép", + "@copy": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "Liên hệ đã được mời vào nhóm", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "connect": "Kết nối", + "@connect": { + "type": "String", + "placeholders": {} + }, + "confirm": "Xác nhận", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "So sánh và đảm bảo các số sau đây giống trên máy còn lại", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "So sánh và đảm bảo các biểu tượng cảm xúc sau đây giống với các biểu tượng trên máy còn lại", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "close": "Đóng", + "@close": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "Chọn một mật khẩu mạnh", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "Chi tiết cuộc trò chuyện", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "Bản sao lưu cuộc trò chuyện của bạn được bảo mật bằng một khoá bảo mật. Bạn đừng làm mất nó.", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "Sao lưu cuộc trò chuyện", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chat": "Chat", + "@chat": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "Thay đổi tên nhóm", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "Thay đổi máy chủ nhà", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changePassword": "Thay đổi mật khẩu", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changedTheRoomInvitationLink": "{username} đã thay đổi đường dẫn mời", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} đã đổi địa chỉ phòng chat", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} đã thay đổi ảnh đại diện của mình", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} đã thay đổi quy tắc truy cập đối với khách thành: {rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} đã thay đổi quy tắc truy cập đối với khách", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} đã thay đổi quyền trong phòng chat", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} đã thay đổi tên phòng chat thành: '{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} đã thay đổi mô tả phòng chat thành: '{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatAvatar": "{username} đã thay đổi ảnh phòng chat", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changeDeviceName": "Thay đổi tên thiết bị", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "cancel": "Hủy", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "blocked": "Đã chặn", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} đã cấm {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "banned": "Đã bị cấm", + "@banned": { + "type": "String", + "placeholders": {} + }, + "banFromChat": "Cấm khỏi cuộc trò chuyện", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "badServerVersionsException": "Máy chủ hỗ trợ Spec phiên bản:\n{serverVerions}\nNhưng ứng dụng này chỉ hỗ trợ {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "Máy chủ nhà hỗ trợ kiểu đăng nhập:\n{serverVersions}\nNhưng ứng dụng này chỉ hỗ trợ:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "askVerificationRequest": "Bạn có đồng ý yêu cầu chứng thực từ {username} không?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "areYouSureYouWantToLogout": "Bạn có chắc bạn muốn đăng xuất không?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "addEmail": "Thêm email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "notifications": "Thông báo", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "newGroup": "Nhóm mới", + "@newGroup": {}, + "pleaseEnterANumber": "Hãy nhập số lớn hơn 0", + "@pleaseEnterANumber": {}, + "newSpaceDescription": "Không gian cho phép bạn hợp nhất các cuộc trò chuyện của mình và xây dựng cộng đồng riêng tư hoặc công khai.", + "@newSpaceDescription": {}, + "disableEncryptionWarning": "Vì lý do bảo mật, bạn không thể tắt tính năng mã hóa trong cuộc trò chuyện đã được bật tính năng này trước đó.", + "@disableEncryptionWarning": {}, + "makeAdminDescription": "Khi bạn đặt người dùng này làm quản trị viên, bạn không thể hoàn tác việc này vì khi đó họ sẽ có quyền ngang bạn.", + "@makeAdminDescription": {}, + "setColorTheme": "Chọn màu giao diện:", + "@setColorTheme": {}, + "callingAccount": "Gọi tài khoản", + "@callingAccount": {}, + "openLinkInBrowser": "Mở đường dẫn trong trình duyệt", + "@openLinkInBrowser": {}, + "setTheme": "Chọn giao diện:", + "@setTheme": {}, + "invitePrivateChat": "📨 Mời trò chuyện riêng tư", + "@invitePrivateChat": {}, + "inviteGroupChat": "📨 Mời nhóm trò chuyện", + "@inviteGroupChat": {}, + "addToSpace": "Thêm vào không gian", + "@addToSpace": {}, + "importEmojis": "Nhập Biểu cảm", + "@importEmojis": {}, + "importFromZipFile": "Nhập vào từ tệp .zip", + "@importFromZipFile": {}, + "exportEmotePack": "Xuất gói biểu cảm bằng tệp .zip", + "@exportEmotePack": {}, + "hideUnimportantStateEvents": "Ẩn các sự kiện không quan trọng", + "@hideUnimportantStateEvents": {}, + "replace": "Thay thế", + "@replace": {}, + "addChatDescription": "Thêm mô tả hội thoại...", + "@addChatDescription": {}, + "report": "báo cáo", + "@report": {}, + "remove": "Loại bỏ", + "@remove": { + "type": "String", + "placeholders": {} + }, + "restricted": "Bị hạn chế", + "@restricted": {}, + "newSpace": "Không gian mới", + "@newSpace": {}, + "enterRoom": "Nhập phòng", + "@enterRoom": {}, + "signInWithPassword": "Đăng nhập với mật khẩu", + "@signInWithPassword": {}, + "all": "Tất cả", + "@all": { + "type": "String", + "placeholders": {} + }, + "appLock": "Khoá ứng dụng", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "allChats": "Tất cả hội thoại", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "Nhập lại mật khẩu", + "@repeatPassword": {}, + "confirmMatrixId": "Hãy xác nhận Matrix ID để xoá tài khoản.", + "@confirmMatrixId": {}, + "supposedMxid": "Đây nên là {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "noBackupWarning": "Cẩn thận! Nếu không bật sao lưu trò chuyện, bạn sẽ mất quyền truy cập vào tin nhắn được mã hóa của mình. Chúng tôi khuyên bạn nên bật sao lưu trò chuyện trước khi đăng xuất.", + "@noBackupWarning": {}, + "doNotShowAgain": "Không hiện lại nữa", + "@doNotShowAgain": {}, + "wasDirectChatDisplayName": "Hội thoại trống (từng là {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "reportErrorDescription": "😭 Ôi. Có lỗi xảy ra. Bạn có thể báo cáo lỗi tới nhà phát triển nếu muốn.", + "@reportErrorDescription": {}, + "profileNotFound": "Không tìm thấy người dùng này tại máy chủ. Có thể do lỗi kết nối hoặc người dùng không tồn tại.", + "@profileNotFound": {}, + "banUserDescription": "Người dùng sẽ bị cấm khỏi cuộc trò chuyện và không thể tham gia lại cho tới khi được gỡ cấm.", + "@banUserDescription": {}, + "learnMore": "Tìm hiểu thêm", + "@learnMore": {}, + "incomingMessages": "Tin nhắn đến", + "@incomingMessages": {}, + "encryptThisChat": "Mã hóa cuộc trò chuyện này", + "@encryptThisChat": {}, + "noOtherDevicesFound": "Không tìm thấy thiết bị khác", + "@noOtherDevicesFound": {}, + "fileIsTooBigForServer": "Máy chủ báo cáo rằng tệp tin quá lớn để gửi.", + "@fileIsTooBigForServer": {}, + "signInWith": "Đăng nhập với {provider}", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "notAnImage": "Không phải tệp ảnh.", + "@notAnImage": {}, + "importNow": "Nhập vào", + "@importNow": {}, + "allSpaces": "Tất cả không gian", + "@allSpaces": {}, + "enterSpace": "Nhập không gian", + "@enterSpace": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "Hãy thử lại sau hoặc chọn 1 máy chủ khác.", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "jumpToLastReadMessage": "Đi tới tin nhắn đã đọc mới nhất", + "@jumpToLastReadMessage": {}, + "commandHint_ignore": "Phớt lờ matrix ID này", + "@commandHint_ignore": {}, + "appLockDescription": "Khoá ứng dụng khi không dùng bằng mã pin", + "@appLockDescription": {}, + "notifyMeFor": "Bật thông báo cho", + "@notifyMeFor": {}, + "settings": "Cài đặt", + "@settings": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "Gửi nhãn dán", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "fileHasBeenSavedAt": "Tệp đã được lưu tại {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "readUpToHere": "Đọc tới đây", + "@readUpToHere": {}, + "jump": "Đi tới", + "@jump": {}, + "callingPermissions": "Quyền gọi điện", + "@callingPermissions": {}, + "numChats": "{number} cuộc hội thoại", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hidePresences": "Ẩn danh sách trạng thái?", + "@hidePresences": {}, + "sorryThatsNotPossible": "Xin lỗi... không khả dụng", + "@sorryThatsNotPossible": {}, + "reopenChat": "Mở lại cuộc trò chuyện", + "@reopenChat": {}, + "wrongPinEntered": "Nhập sai mã pin! Thử lại sau {seconds} giây...", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "archiveRoomDescription": "Cuộc trò chuyện sẽ được chuyển tới mục lưu trữ. Người dùng khác sẽ thấy được bạn đã rời khỏi cuộc trò chuyện.", + "@archiveRoomDescription": {}, + "kickUserDescription": "Người dùng bị đuổi khỏi cuộc trò chuyện nhưng không bị cấm. Trong các cuộc trò chuyện công khai, người dùng có thể vào lại bất cứ lúc nào.", + "@kickUserDescription": {}, + "unbanUserDescription": "Người dùng sẽ có thể vào lại cuộc trò chuyện nếu họ thử.", + "@unbanUserDescription": {}, + "pushNotificationsNotAvailable": "Thông báo đẩy không khả dụng", + "@pushNotificationsNotAvailable": {}, + "invite": "Mời", + "@invite": {}, + "invalidInput": "Dữ liệu nhập không hợp lệ!", + "@invalidInput": {}, + "removeDevicesDescription": "Bạn sẽ đăng xuất khỏi thiết bị này và không nhận được tin nhắn nữa.", + "@removeDevicesDescription": {}, + "noUsersFoundWithQuery": "Không tìm thấy người dùng nào với \"{query}\". Hãy kiểm tra xem bạn có nhập nhầm không.", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "commandHint_unignore": "Bỏ phớt lờ matrix ID này", + "@commandHint_unignore": {}, + "discover": "Khám phá", + "@discover": {}, + "stickers": "Nhãn dán", + "@stickers": {}, + "roomUpgradeDescription": "Cuộc trò chuyện sẽ được tạo lại với phiên bản phòng mới. Tất cả những người tham gia sẽ được thông báo rằng họ cần chuyển sang cuộc trò chuyện mới. Bạn có thể tìm hiểu thêm về các phiên bản phòng tại https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "commandHint_hug": "Gửi một cái ôm", + "@commandHint_hug": {}, + "aboutHomeserver": "Về {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "alwaysUse24HourFormat": "không", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "hugContent": "{senderName} ôm bạn", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setCustomPermissionLevel": "Cài mức phân quyền", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "Vui lòng chọn vai trò được xác định trước bên dưới hoặc nhập mức quyền tùy chỉnh từ 0 đến 100.", + "@setPermissionsLevelDescription": {}, + "ignoreUser": "Chặn người dùng", + "@ignoreUser": {}, + "normalUser": "Người dùng thường", + "@normalUser": {}, + "commandHint_roomupgrade": "Nâng cấp phòng lên phiên bản mặc định", + "@commandHint_roomupgrade": {}, + "commandHint_cuddle": "Gửi cái ôm", + "@commandHint_cuddle": {}, + "googlyEyesContent": "{senderName} gửi nháy mắt", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} ôm nào", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "askSSSSSign": "Để có thể ký tên cho người khác, vui lòng nhập mật khẩu lưu trữ an toàn hoặc khóa khôi phục của bạn.", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "autoplayImages": "Tự động chạy nhãn dán hình động và biểu tượng cảm xúc", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendTypingNotifications": "Gửi thông báo đang nhập", + "@sendTypingNotifications": {}, + "swipeRightToLeftToReply": "Gạt từ phải sang trái để trả lời", + "@swipeRightToLeftToReply": {}, + "sendOnEnter": "Gửi bằng Enter", + "@sendOnEnter": {}, + "continueText": "Tiếp", + "@continueText": {}, + "videoWithSize": "Video ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "markAsRead": "Đánh dấu đã đọc", + "@markAsRead": {}, + "reportUser": "Báo cáo người dùng", + "@reportUser": {}, + "dismiss": "Bỏ", + "@dismiss": {}, + "reactedWith": "{sender} bày tỏ {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "pinMessage": "Ghim phòng", + "@pinMessage": {}, + "confirmEventUnpin": "Bạn có muốn bỏ ghim sự kiện?", + "@confirmEventUnpin": {} +} diff --git a/lib/l10n/intl_yue_Hant.arb b/lib/l10n/intl_yue_Hant.arb new file mode 100644 index 000000000..cce50f372 --- /dev/null +++ b/lib/l10n/intl_yue_Hant.arb @@ -0,0 +1,337 @@ +{ + "@@locale": "yue", + "normalUser": "正常用家", + "@normalUser": {}, + "areYouSureYouWantToLogout": "係咪確定要 log out?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "畀唔畀陌生人 Join", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "要向其他人簽名,請輸入你 Keep 好咗嘅密碼或者恢復密鑰。", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "badServerLoginTypesException": "呢個 Homeserver 支持嘅登錄類型有:\n{serverVersions}\n但係呢個 App 淨係支援:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "cantOpenUri": "打唔開嘅 URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "badServerVersionsException": "呢個 Homeserver 支持以下 Spec 版本:\n{serverVersions}\n但係個 App 淨係支持 {supoortedVersions} 版本", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "喺傾偈入面 Ban 咗佢", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "noChatsFoundHere": "暫時未有偈傾。撳下面粒掣同人開始傾偈 ⤵️", + "@noChatsFoundHere": {}, + "bannedUser": "{username} Ban 咗 {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} 改咗呢個偈嘅介紹: 「'{description}'」", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "addEmail": "加 Email", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "importEmojis": "導入 Emoji", + "@importEmojis": {}, + "hugContent": "{senderName} 抱咗你", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_hug": "Send 個 Hug", + "@commandHint_hug": {}, + "anyoneCanJoin": "任何人都可以 Join", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "repeatPassword": "輸入多一次密碼", + "@repeatPassword": {}, + "notAnImage": "唔係圖檔。", + "@notAnImage": {}, + "remove": "刪走", + "@remove": { + "type": "String", + "placeholders": {} + }, + "importNow": "即刻導入", + "@importNow": {}, + "exportEmotePack": "將表情符號導出成 .zip 檔案", + "@exportEmotePack": {}, + "replace": "換走", + "@replace": {}, + "about": "關於", + "@about": {}, + "aboutHomeserver": "關於{homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "accept": "同意", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} 同意咗邀请", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "Account", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} 開咗點對點加密", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "supposedMxid": "呢度應該係 {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "addChatDescription": "講下關於呢個偈係傾嘅乜嘢……", + "@addChatDescription": {}, + "addToSpace": "加落去空間嗰度", + "@addToSpace": {}, + "admin": "Admin", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "花名", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "全部", + "@all": { + "type": "String", + "placeholders": {} + }, + "allChats": "所有傾嘅偈仔", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_roomupgrade": "將呢間房升級到指定版本", + "@commandHint_roomupgrade": {}, + "commandHint_googly": "送啲古靈精怪表情過去", + "@commandHint_googly": {}, + "commandHint_cuddle": "Send 個攬攬", + "@commandHint_cuddle": {}, + "googlyEyesContent": "{senderName} Send 咗你一個咕嚕眼", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "cuddleContent": "{senderName} 攬咗你", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "answeredTheCall": "{senderName} 聽咗你嘅電話", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "appLock": "App 鎖", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "appLockDescription": "無人用嘅時候用密碼鎖住個App", + "@appLockDescription": {}, + "archive": "存檔", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "咪住先?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "係咪要 Accept 來自 {username} 嘅驗證申請?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "autoplayImages": "自動播放動畫貼紙同表情", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendTypingNotifications": "通知人地打緊字", + "@sendTypingNotifications": {}, + "swipeRightToLeftToReply": "向左滑嚟回覆", + "@swipeRightToLeftToReply": {}, + "sendOnEnter": "撳 Enter 即 Send", + "@sendOnEnter": {}, + "countChatsAndCountParticipants": "{chats} 間房同 {participants} 條友", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "noMoreChatsFound": "搵唔到更多偈傾啦…", + "@noMoreChatsFound": {}, + "joinedChats": "入咗嘅房間", + "@joinedChats": {}, + "unread": "未讀", + "@unread": {}, + "space": "空間", + "@space": {}, + "spaces": "空間", + "@spaces": {}, + "banned": "Block 咗", + "@banned": { + "type": "String", + "placeholders": {} + }, + "blockDevice": "Block 咗嘅裝置", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "Block 咗", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "機械人訊息", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "取消", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "改裝置名", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username}轉咗個大頭貼", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "confirmMatrixId": "Confirm 你嘅 Matrix ID ,我哋先至可以刪除你嘅 Account。", + "@confirmMatrixId": {}, + "setCustomPermissionLevel": "自訂權限級別", + "@setCustomPermissionLevel": {}, + "importFromZipFile": "喺 .zip 檔案導入", + "@importFromZipFile": {}, + "setPermissionsLevelDescription": "請喺下面選擇一個預定義嘅角色,或輸入介乎0同100之間嘅自定義權限級別。", + "@setPermissionsLevelDescription": {} +} diff --git a/lib/l10n/intl_zh.arb b/lib/l10n/intl_zh.arb new file mode 100644 index 000000000..748fb2318 --- /dev/null +++ b/lib/l10n/intl_zh.arb @@ -0,0 +1,3159 @@ +{ + "@@locale": "zh", + "@@last_modified": "2021-08-14 12:41:09.767805", + "about": "关于", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "接受", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} 接受了邀请", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "账户", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} 激活了端到端加密", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "添加电子邮件", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "管理员", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "别名", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "全部", + "@all": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "{senderName} 接听了通话", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "任何人都可以加入", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "应用锁", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "存档", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "允许访客加入吗?", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "你确定吗?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "你确定要退出登录吗?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "请输入你的安全存储的密码短语或恢复密钥,以向对方签名。", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "是否接受来自 {username} 的验证请求?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "主服务器支持的登录方式:\n{serverVersions}\n但此应用仅支持:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "主服务器支持的 Spec 版本:\n{serverVersions}\n但此应用仅支持 {supportedVersions} 版本", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "从聊天中封禁", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "已封禁", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} 封禁了 {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "屏蔽设备", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "已屏蔽", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "机器人消息", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "取消", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "更改设备名称", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} 更改了聊天头像", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} 将聊天描述更改为:'{description}'", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} 将聊天名称更改为:'{chatname}'", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} 更改了聊天权限", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} 将昵称更改为:'{displayname}'", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} 更改了访客访问规则", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} 更改了访客访问规则为:{rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} 更改了历史记录可见性", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} 更改了历史记录可见性为:{rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} 更改了加入的规则", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} 更改了加入的规则为:{joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} 更改了头像", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} 更改了聊天室别名", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} 更改了邀请链接", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "更改密码", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "更改主服务器", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "改变风格", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "更改群组名称", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "changeYourAvatar": "更改你的头像", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "加密已被破坏", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "聊天", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "聊天记录备份", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "你的消息受恢复密钥保护。请确保你不会丢失它。", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "聊天详情", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chats": "聊天", + "@chats": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "输入一个强密码", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "clearArchive": "清除存档", + "close": "关闭", + "@close": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "在此聊天室封禁指定用户", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_html": "发送 HTML 格式化文本", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_invite": "邀请指定用户加入此聊天室", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "加入指定聊天室", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "在此聊天室移除指定用户", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "退出此聊天室", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_me": "介绍自己", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_myroomavatar": "设置你在此聊天室的头像(通过 mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_myroomnick": "设置你在此聊天室的昵称", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "commandHint_op": "设置指定用户的权限等级(默认:50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "commandHint_plain": "发送纯文本", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "将回复作为回应发送", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "commandHint_send": "发送文本", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "commandHint_unban": "在此聊天室解封指定用户", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "commandInvalid": "指令无效", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} 不是指令。", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "compareEmojiMatch": "请比较表情符号", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "请比较以下数字", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "配置聊天", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "确认", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "连接", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "联系人已被邀请至群组", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "包含昵称", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "包含用户名", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "此内容已被报告至服务器管理员处", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "已复制到剪贴板", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "复制", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "复制到剪贴板", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "不能解密消息: {error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} 名参与者", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "创建", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} 创建了聊天", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "目前活跃", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "深色", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date}, {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month}-{day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year}-{month}-{day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "这将停用你的用户账户。这不能被撤销!你确定吗?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "新用户默认权限级别", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "删除", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "删除账户", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "删除消息", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "设备", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "设备 ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "设备", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "私聊", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "昵称已更改", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "下载文件", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "编辑", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "编辑被屏蔽的服务器", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "编辑昵称", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAliases": "编辑聊天室别名", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "编辑聊天室头像", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "表情已存在!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "无效的表情快捷码!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "聊天室的表情包", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "表情设置", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "表情快捷码", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "你需要选择一个表情快捷码和一张图片!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "空聊天", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "在全局启用表情包", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "启用加密", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "你之后将无法停用加密,确定吗?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "已加密", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "加密", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "加密未启用", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} 结束了通话", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "输入一个电子邮件地址", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "输入你的主服务器地址", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "一切就绪!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "令人极度反感", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "文件名", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "字体大小", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "转发", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "自加入起", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "自邀请起", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "goToTheNewRoom": "前往新的聊天室", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "group": "群组", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "群组是公开的", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "群组", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "名称为 {displayname} 的群组", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "访客禁止加入", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "访客可以加入", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} 撤回了对 {targetName} 的邀请", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "帮助", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "隐藏已删除的事件", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "隐藏未知的事件", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "这些内容有多令人反感?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "身份", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "忽略", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "已忽略的用户", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "我已经点击了链接", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "不正确的密码短语或恢复密钥", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "不令人反感", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "邀请联系人", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "邀请联系人到 {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "已邀请", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} 邀请了 {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "仅被邀请用户", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "发给我的邀请", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} 邀请你使用 FluffyChat。 \n1. 安装 FluffyChat:https://fluffychat.im \n2. 注册或登录 \n3. 打开邀请链接:\n {link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "正在输入…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} 加入了聊天", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "加入聊天室", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} 踢出了 {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} 踢出并封禁了 {targetName}", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "从聊天室踢出", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "上次活跃: {localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "离开", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "离开了聊天", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "许可证", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "浅色", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "加载 {count} 个更多的参与者", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "加载中…请等待。", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "加载更多…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "登录", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "登录 {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "退出登录", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "成员变更", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "提及", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "消息", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "协管员", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "静音聊天", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "请注意当前你需要 Pantalaimon 以使用端到端加密功能。", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "新的聊天", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 FluffyChat 新消息", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "新的验证请求!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "下一步", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "否", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "无法连接服务器", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "未找到表情。😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "你只能在聊天室不可被公众访问时才能启用加密。", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "看起来你手机上没有 Firebase Cloud Messaging。如果仍希望接收 FluffyChat 的推送通知,推荐安装 ntfy。借助 ntfy 或另一个 Unified Push 程序,你可以以一种数据安全的方式接收推送通知。你可以从 PlayStore 或 F-Droid 商店下载 ntfy。", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "无", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "你尚未添加恢复密码的方法。", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "没有权限", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "未找到聊天室…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "通知", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "已为此账户启用通知", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} 人正在输入…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offensive": "令人反感", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "离线", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "确认", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "在线", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "在线密钥备份已启用", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "哎呀!十分不幸,配置推送通知时发生了错误。", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "哎呀,出了点差错…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "打开应用以查看消息", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "打开相机", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "or": "或", + "@or": { + "type": "String", + "placeholders": {} + }, + "participant": "参与者", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "密码短语或恢复密钥", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "密码", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "忘记密码", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "密码已被更改", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "密码恢复", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "people": "联系人", + "@people": { + "type": "String", + "placeholders": {} + }, + "pickImage": "选择图像", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "置顶", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "播放 {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChoose": "请选择", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "pleaseChooseAPasscode": "请选择一个密码", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "请点击电子邮件中的链接,然后继续。", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "请输入 4 位数字或留空以停用应用锁。", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "请输入你的密码", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPin": "请输入你的 PIN", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "请输入你的用户名", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "请按照网站上的提示,点击下一步。", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "隐私", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "公开聊天室", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "推送规则", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "原因", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "录制", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} 删除了一个事件", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "删除消息", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "register": "注册", + "@register": { + "type": "String", + "placeholders": {} + }, + "reject": "拒绝", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} 拒绝了邀请", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "重新加入", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "移除", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "移除所有其它设备", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "被 {username} 移除", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "移除设备", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "从聊天中解封", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "移除你的头像", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "更新聊天室至新版本", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "回复", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "举报信息", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "请求权限", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "聊天室已升级", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "聊天室版本", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "saveFile": "保存文件", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "search": "搜索", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "安全", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "被 {username} 看见", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "发送", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "发送一条消息", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAsText": "以文本发送", + "@sendAsText": { + "type": "String" + }, + "sendAudio": "发送音频", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "发送文件", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "发送图像", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "发送消息", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "发送原图", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendSticker": "发送贴纸", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "发送视频", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "📁{username} 发送了文件", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤{username} 发送了音频", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️ {username} 发送了图片", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊 {username} 发送了贴纸", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥 {username} 发送了视频", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} 发送了通话信息", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setAsCanonicalAlias": "设为主要别名", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setCustomEmotes": "设置自定义表情", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "设置邀请链接", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "设置权限级别", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "设置状态", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "设置", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "分享", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} 分享了位置", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "showPassword": "显示密码", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "单点登录", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "skip": "跳过", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "源代码", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} 开始了通话", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "状态", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "你今天怎么样?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "提交", + "@submit": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "同步中…请等待。", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "系统", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "它们不匹配", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "它们匹配", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "切换收藏", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "切换静音", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "标记已读/未读", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "请求过多。请稍后再试!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "从其它设备传输", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "尝试重新发送", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "不可用", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} 解封了 {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "解除屏蔽设备", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "未知设备", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "未知加密算法", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "未知事件 '{type}'", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "取消静音聊天", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "取消置顶", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1{1 个未读聊天} other{{unreadCount} 个未读聊天}}", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} 和其他 {count} 人正在输入…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} 和 {username2} 正在输入…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} 正在输入…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "🚪{username} 离开了聊天", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "用户名", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} 发送了一个 {type} 事件", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "已验证", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "验证", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "开始验证", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "你已成功验证!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "验证其它账户", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "视频通话", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "聊天记录的可见性", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "对所有参与者可见", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "对所有人可见", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "语音消息", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "等待对方接受请求…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "等待对方接受 emoji…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "等待对方接受数字…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "壁纸:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "警告!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "我们向你发送了一封电子邮件", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "谁可以执行哪些操作", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "谁可以加入此群组", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "你举报的理由是什么?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "确定要清除你的聊天记录备份以创建新的恢复密钥吗?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "通过这些地址,你可以恢复密码。", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "写一条消息…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "是", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "你", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "你已不再参与此聊天", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "你已被此聊天封禁", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "你的公钥", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "allChats": "所有聊天", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "添加到空间", + "obtainingLocation": "获取位置中…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} 不是一个 Matrix 服务器,试试 {server2}?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "locationPermissionDeniedNotice": "位置权限被拒绝。请授予此权限以分享你的位置.", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "locationDisabledNotice": "位置服务已禁用。请启用此服务以分享你的位置.", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "errorObtainingLocation": "取得地址错误: {error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "createNewSpace": "创建新空间", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "cantOpenUri": "无法打开 URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "autoplayImages": "自动播放动态贴纸和表情", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "spaceName": "空间名称", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "空间是公开的", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "shareLocation": "分享位置", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "openInMaps": "在地图中打开", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "sendOnEnter": "按 Enter 键发送", + "yourChatBackupHasBeenSetUp": "你的聊天记录备份已设置。", + "scanQrCode": "扫描二维码", + "chatHasBeenAddedToThisSpace": "聊天已添加到此空间", + "homeserver": "服务器", + "oneClientLoggedOut": "你的一个客户端已登出", + "removeFromBundle": "从此集合中移除", + "unverified": "未经验证", + "repeatPassword": "重复输入密码", + "addAccount": "添加账户", + "editBundlesForAccount": "编辑此账户的集合", + "enableMultiAccounts": "(测试功能)在此设备上添加多个账户", + "addToBundle": "添加到集合", + "bundleName": "集合名称", + "link": "链接", + "serverRequiresEmail": "此服务器需要验证你的电子邮件地址以进行注册。", + "messageType": "消息类型", + "sender": "发送者", + "openGallery": "打开图库", + "messageInfo": "消息信息", + "time": "时间", + "addToSpaceDescription": "选择一个空间以添加此聊天。", + "removeFromSpace": "从此空间中移除", + "start": "开始", + "commandHint_discardsession": "丢弃会话", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "创建私聊\n使用 --no-encryption 选项来禁用加密", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_clearcache": "清除缓存", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "创建空的群聊\n使用 --no-encryption 选项来禁用加密", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "openVideoCamera": "打开相机拍摄视频", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "publish": "发布", + "videoWithSize": "视频 ({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "dismiss": "忽略", + "markAsRead": "标为已读", + "reportUser": "举报用户", + "openChat": "打开聊天", + "reactedWith": "{sender} 回应了 {reaction}", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "confirmEventUnpin": "你确定要永久性取消置顶此事件吗?", + "pinMessage": "置顶到聊天室", + "emojis": "表情符号", + "unsupportedAndroidVersionLong": "这个功能需要较新版本的 Android 系统。请检查更新或 Lineage OS 支持。", + "unsupportedAndroidVersion": "不受支持的 Android 版本", + "voiceCall": "语音通话", + "placeCall": "发起通话", + "videoCallsBetaWarning": "请注意,视频通话目前处于测试阶段。它们可能不能像预期的那样工作,或者在所有平台上都不能工作。", + "experimentalVideoCalls": "实验性的视频通话", + "emailOrUsername": "电子邮箱或用户名", + "switchToAccount": "切换到账户 {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "nextAccount": "下个账户", + "previousAccount": "上个账户", + "widgetVideo": "视频", + "widgetJitsi": "Jitsi Meet", + "widgetCustom": "自定义", + "widgetNameError": "请提供昵称。", + "errorAddingWidget": "添加小部件出错。", + "addWidget": "添加小部件", + "widgetEtherpad": "文本笔记", + "widgetName": "名称", + "widgetUrlError": "这不是有效的 URL。", + "separateChatTypes": "分开私聊和群组", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "youRejectedTheInvitation": "你拒绝了邀请", + "youJoinedTheChat": "你加入了聊天", + "youBannedUser": "你封禁了 {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 你受到了 {user} 的邀请", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedUser": "📩 你邀请了 {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKicked": "👞 你踢出了 {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "你解除了对 {user} 的封禁", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youAcceptedTheInvitation": "👍 你接受了邀请", + "youHaveWithdrawnTheInvitationFor": "你撤回了对 {user} 的邀请", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youKickedAndBanned": "🙅 你踢出并封禁了 {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "storeInSecureStorageDescription": "将恢复密钥存储在此设备的安全存储中。", + "storeInAppleKeyChain": "存储在 Apple KeyChain 中", + "unlockOldMessages": "解锁旧消息", + "pleaseEnterRecoveryKey": "请输入你的恢复密钥:", + "recoveryKey": "恢复密钥", + "recoveryKeyLost": "丢失了恢复密钥?", + "pleaseEnterRecoveryKeyDescription": "要解锁你的旧邮件,请输入你在之前会话中生成的恢复密钥。 你的恢复密钥不是你的密码。", + "saveKeyManuallyDescription": "通过触发系统共享对话框或剪贴板手动保存此密钥。", + "storeInAndroidKeystore": "存储在 Android KeyStore 中", + "storeSecurlyOnThisDevice": "安全地存储在此设备上", + "users": "用户", + "countFiles": "{count} 个文件", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "dehydrateTor": "TOR 用户:导出会话", + "dehydrateTorLong": "建议 TOR 用户在关闭窗口之前导出会话。", + "hydrateTor": "TOR 用户:导入会话导出", + "hydrate": "从备份文件恢复", + "dehydrate": "导出会话并擦除设备", + "dehydrateWarning": "此操作无法撤消。 确保你安全地存储备份文件。", + "indexedDbErrorTitle": "私有模式问题", + "indexedDbErrorLong": "遗憾的是,默认情况下未在私有模式下启用消息存储。\n请访问\n - about:config\n - 将 dom.indexedDB.privateBrowsing.enabled 设置为 true\n否则,无法运行 FluffyChat。", + "hydrateTorLong": "你上次是否导出 TOR 会话? 快速导入它并继续聊天。", + "user": "用户", + "custom": "自定义", + "confirmMatrixId": "请确认你的 Matrix ID 以删除账户。", + "supposedMxid": "应为 {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "commandHint_markasgroup": "标记为群组", + "commandHint_markasdm": "将给定的 Matrix ID 标为私信聊天室", + "whyIsThisMessageEncrypted": "为什么此消息不可读?", + "noKeyForThisMessage": "如果消息是在你在此设备上登录账户前发送的,就可能发生这种情况。\n\n也有可能是发送者屏蔽了你的设备或网络连接出了问题。\n\n你能在另一个会话中读取消息吗?如果是的话,你可以从它那里传递信息!点击设置 > 设备,并确保你的设备已经相互验证。当你下次打开聊天室,且两个会话都在前台,密钥就会自动传输。\n\n你不想在退出登录或切换设备时丢失密钥?请确保在设置中启用了聊天备份。", + "newGroup": "新群组", + "newSpace": "新的空间", + "enterSpace": "进入空间", + "enterRoom": "进入聊天室", + "allSpaces": "所有空间", + "appearOnTop": "显示在其它应用上方", + "appearOnTopDetails": "允许应用显示在顶部(如果你已经将 Fluffychat 设置为呼叫账户,则不需要授予此权限)", + "otherCallingPermissions": "麦克风、摄像头和其它 FluffyChat 权限", + "callingPermissions": "呼叫权限", + "callingAccountDetails": "允许 FluffyChat 使用本机 android 拨号器应用。", + "foregroundServiceRunning": "此通知在前台服务运行时出现。", + "screenSharingTitle": "屏幕共享", + "callingAccount": "呼叫账户", + "screenSharingDetail": "你正在 FluffyChat 中共享屏幕", + "numChats": "{number} 个聊天", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "隐藏不重要的状态事件", + "doNotShowAgain": "不再显示", + "googlyEyesContent": "{senderName} 向你发送了“大眼”表情", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_googly": "发送“大眼”表情", + "commandHint_cuddle": "发送“搂抱”", + "commandHint_hug": "发送“拥抱”", + "cuddleContent": "{senderName} 搂抱了你", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "hugContent": "{senderName} 拥抱了你", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "wasDirectChatDisplayName": "空聊天(曾是 {oldDisplayName})", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "startFirstChat": "发起你的第一个聊天", + "newSpaceDescription": "空间让你可以整合聊天并建立私人或公共社区。", + "encryptThisChat": "加密此聊天", + "disableEncryptionWarning": "出于安全考虑 ,你不能在之前已启用加密的聊天中禁用加密。", + "sorryThatsNotPossible": "非常抱歉……这是做不到的", + "deviceKeys": "设备密钥:", + "report": "报错", + "fileIsTooBigForServer": "无法发送!服务器只支持最大 {max} 的文件。", + "noOtherDevicesFound": "未找到其它设备", + "jumpToLastReadMessage": "跳转到上次已读的消息", + "readUpToHere": "读到此处", + "jump": "跳转", + "openLinkInBrowser": "在浏览器中打开链接", + "signInWith": "使用 {provider} 登录", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "allRooms": "所有群聊", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "fileHasBeenSavedAt": "文件已保存在 {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "reportErrorDescription": "😭 哦不。出了点差错。如果你愿意,可以向开发人员报告此错误。", + "noBackupWarning": "警告!如果不启用聊天备份,你将无法访问加密消息。强烈建议在退出登录前先启用聊天备份。", + "signInWithPassword": "使用密码登录", + "pleaseTryAgainLaterOrChooseDifferentServer": "请稍后再试或选择其它服务器。", + "reopenChat": "重新打开聊天", + "importEmojis": "导入表情包", + "notAnImage": "不是图像文件。", + "importNow": "立即导入", + "importFromZipFile": "从 .zip 文件导入", + "replace": "替换", + "exportEmotePack": "以 .zip 格式导出表情包", + "sendTypingNotifications": "发送正在输入通知", + "createGroup": "创建群组", + "shareInviteLink": "分享邀请链接", + "profileNotFound": "服务器上找不到此用户。可能是连接有问题或者用户不存在。", + "inviteContactToGroupQuestion": "你是否要邀请 {contact} 参与聊天 \"{groupName}\"?", + "tryAgain": "重试", + "addChatDescription": "添加聊天说明…", + "chatPermissions": "聊天权限", + "chatDescription": "聊天描述", + "chatDescriptionHasBeenChanged": "聊天描述已被更改", + "noChatDescriptionYet": "尚未创建聊天描述。", + "invalidServerName": "服务器名称无效", + "redactMessageDescription": "消息将为此对话中所有参与者删除。此操作无法撤销。", + "optionalRedactReason": "(可选)删除此消息的原因...", + "setChatDescription": "设置聊天描述", + "setTheme": "设置主题:", + "setColorTheme": "设置主题颜色:", + "invite": "邀请", + "messagesStyle": "消息:", + "redactedBy": "已被 {username} 删除", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "directChat": "私聊", + "redactedByBecause": "已被 {username} 删除,原因:\"{reason}\"", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "inviteGroupChat": "📨 群聊邀请", + "invitePrivateChat": "📨 私聊邀请", + "emoteKeyboardNoRecents": "最近使用过的表情会出现在这里...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "invalidInput": "无效的输入!", + "wrongPinEntered": "输入的 PIN 码不正确!请 {seconds} 秒后重试…", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "hasKnocked": "{user} 请求了加入聊天室的邀请", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "pleaseEnterANumber": "请输入大于 0 的数", + "banUserDescription": "该用户将被禁止进入聊天室,在解除封禁之前将不能再进入聊天室。", + "removeDevicesDescription": "你将从此设备登出,无法再接收消息。", + "unbanUserDescription": "如果用户尝试加入则可以再次进入聊天。", + "pushNotificationsNotAvailable": "通知推送不可用", + "makeAdminDescription": "一旦你将该用户设为管理员,你可能无法撤销,因为他们将拥有与你相同的权限。", + "archiveRoomDescription": "聊天将被移至存档。其他用户将能看到你已离开聊天。", + "learnMore": "了解更多", + "roomUpgradeDescription": "将使用新版聊天室来重新创建当前聊天室。所有参与者都会收到通知以切换到新的聊天室。有关聊天室版本的更多信息,请访问 https://spec.matrix.org/latest/rooms/", + "kickUserDescription": "该用户会被踢出聊天但没被封禁。在公开聊天中,该用户可以随时重新加入。", + "blockListDescription": "你可以屏蔽打扰你的用户。你将不会收到来自屏蔽列表中用户的任何消息或聊天室邀请。", + "createGroupAndInviteUsers": "创建群组并邀请用户", + "startConversation": "开始对话", + "blockedUsers": "已屏蔽的用户", + "groupCanBeFoundViaSearch": "可通过搜索找到该群组", + "noUsersFoundWithQuery": "很遗憾,没有找到有关\"{query}\"的用户。请检查是否输入错误。", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "block": "屏蔽", + "yourGlobalUserIdIs": "你的全局用户 ID 是: ", + "commandHint_sendraw": "发送原始 json", + "wrongRecoveryKey": "抱歉…这似乎不是正确的恢复密钥。", + "blockUsername": "忽略用户名", + "groupName": "群组名称", + "databaseMigrationTitle": "数据库已优化", + "searchChatsRooms": "搜索 #聊天,@用户…", + "databaseMigrationBody": "请稍候。可能需要稍等片刻。", + "thisDevice": "此设备:", + "publicSpaces": "公开空间", + "passwordIsWrong": "你输入的密码有误", + "pleaseEnterYourCurrentPassword": "请输入你当前的密码", + "publicLink": "公开链接", + "nothingFound": "未找到任何内容…", + "decline": "拒绝", + "newPassword": "新的密码", + "passwordsDoNotMatch": "密码不匹配", + "subspace": "子空间", + "select": "选择", + "pleaseChooseAStrongPassword": "请选择一个强密码", + "addChatOrSubSpace": "添加聊天或子空间", + "leaveEmptyToClearStatus": "留空以清除你的状态。", + "joinSpace": "加入空间", + "searchForUsers": "搜索 @用户…", + "databaseBuildErrorBody": "无法构建 SQLite 数据库。目前应用尝试使用旧数据库。请将此错误报告给开发者,网址为 {url}。错误消息为:{error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "initAppError": "在初始化应用时发生错误", + "sessionLostBody": "你的会话已丢失。请将此错误报告给开发者,网址为 {url}。错误消息为:{error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "restoreSessionBody": "应用现在尝试从备份中恢复你的会话。请将此错误报告给开发者,网址为 {url}。错误消息为:{error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "聊天中的其他参与者可以看到你正在输入新消息。", + "formattedMessagesDescription": "使用 Markdown 显示富文本内容,例如加粗文本。", + "verifyOtherUserDescription": "如果你验证了其他用户,就可以确保你清楚自己正在与谁进行通信。💪\n\n当你开始验证时,你和其他用户将在应用中看到一个弹出窗口。然后你会看到一系列表情符号或数字,你和其他用户需要比较它们是否一致。\n\n最好的方式是线下会面或开始视频通话。👭", + "verifyOtherDeviceDescription": "当你验证另一个设备时,这些设备可以交换密钥,从而提高整体安全性。 💪 当你开始验证时,两个设备上的应用都将显示一个弹出窗口。然后你会看到一系列表情符号或数字,你需要比较两个设备上显示的内容。在开始验证之前,最好将两个设备都放在手边。🤳", + "canceledKeyVerification": "{sender} 取消了密钥验证", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "sendReadReceipts": "发送已读回执", + "formattedMessages": "格式化的消息", + "verifyOtherDevice": "🔐 验证其它设备", + "verifyOtherUser": "🔐 验证其他用户", + "forwardMessageTo": "转发消息至 {roomName} ?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "聊天中的其他参与者可以看到你是否读过消息。", + "acceptedKeyVerification": "{sender} 接受了密钥验证", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} 已准备好进行密钥验证", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} 完成了密钥验证", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "requestedKeyVerification": "{sender} 请求了密钥验证", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} 开始了密钥验证", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "透明", + "youInvitedToBy": "📩 你已通过链接被邀请到:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "presencesToggle": "显示其他用户的状态消息", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "是否在线:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "hidePresences": "隐藏状态列表?", + "incomingMessages": "传入消息", + "stickers": "贴纸", + "discover": "发现", + "commandHint_ignore": "忽略给定的 matrix ID", + "commandHint_unignore": "取消忽略给定的 matrix ID", + "unreadChatsInApp": "{appname}: {unread} 未读聊天", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "appLockDescription": "用 pin 码在不用 FluffyChat 时锁定它", + "globalChatId": "全局聊天 ID", + "accessAndVisibility": "访问和可见性", + "accessAndVisibilityDescription": "谁可以加入此聊天以及怎样发现该聊天。", + "calls": "通话", + "customEmojisAndStickers": "自定义表情符号和贴纸", + "hideRedactedMessages": "隐藏被涂黑的消息", + "overview": "概览", + "notifyMeFor": "提示内容", + "passwordRecoverySettings": "密码发现设置", + "noPublicLinkHasBeenCreatedYet": "尚未创建公开链接", + "knock": "请求", + "noOneCanJoin": "无人可以加入", + "knocking": "正在请求", + "chatCanBeDiscoveredViaSearchOnServer": "可通过搜索 {server} 发现聊天", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "目前有 {count} 名用户被封禁。", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "hideRedactedMessagesBody": "如果某人涂黑了一条消息,那么在聊天中再也看不到这条消息。", + "hideInvalidOrUnknownMessageFormats": "隐藏无效或未知的消息格式", + "hideMemberChangesInPublicChats": "在公开聊天中隐藏成员变化", + "hideMemberChangesInPublicChatsBody": "不在聊天时间线中显示某人是否加入或离开了公开聊天来改进可读性。", + "userWouldLikeToChangeTheChat": "{user} 想加入聊天。", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "customEmojisAndStickersBody": "添加或分享可用于任何聊天的表情符号或贴纸。", + "usersMustKnock": "用户必须请求加入", + "noDatabaseEncryption": "数据库加密在此平台上不受支持", + "userRole": "用户角色", + "minimumPowerLevel": "{level} 是最低权限等级。", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "publicChatAddresses": "公开聊天的地址", + "createNewAddress": "新建地址", + "searchMore": "搜索更多…", + "gallery": "图库", + "files": "文件", + "searchIn": "在 “{chat}” 聊天中搜索…", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "knockRestricted": "“请求加入”请求受限", + "restricted": "受限", + "swipeRightToLeftToReply": "从右向左滑动进行回复", + "alwaysUse24HourFormat": "否", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "noMoreChatsFound": "找不到更多聊天…", + "joinedChats": "已加入的聊天", + "space": "空间", + "spaces": "空间", + "goToSpace": "转到空间:{space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "标为未读", + "countChatsAndCountParticipants": "{chats} 个聊天和 {participants} 名参与者", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "unread": "未读", + "userLevel": "{level} - 用户", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - 主持人", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "adminLevel": "{level} - 管理员", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "inviteOtherUsers": "邀请其他用户到这个聊天", + "changeTheChatPermissions": "更改聊天权限", + "changeTheVisibilityOfChatHistory": "更改聊天历史的可见性", + "changeTheCanonicalRoomAlias": "更改主公共聊天地址", + "sendRoomNotifications": "发送通知聊天室所有人的通知", + "changeTheDescriptionOfTheGroup": "更改聊天描述", + "changeGeneralChatSettings": "更改常规聊天设置", + "invitedBy": "📩 邀请人 {user}", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "chatPermissionsDescription": "定义此聊天中哪个权限等级对特定操作是必需的。权限等级 0、50 和 100 通常代表用户、主持人和管理员,但你可以自定义任何等级。", + "changelog": "更新记录", + "updateInstalled": "🎉 已安装更新 {version} !", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "sendCanceled": "发送被取消", + "noChatsFoundHere": "此处尚未找到聊天。使用下方按钮 ⤵️ 开始和某人的新聊天", + "loginWithMatrixId": "使用 Matrix-ID 登录", + "discoverHomeservers": "发现主服务器", + "whatIsAHomeserver": "什么是主服务器?", + "homeserverDescription": "主服务器上就像电子邮件提供商,你的所有数据都存储在上面。你可以选择你想使用哪个主服务器。在 https://matrix.org 上了解更多信息。", + "doesNotSeemToBeAValidHomeserver": "似乎不是兼容的主服务器。URL 不正确?", + "prepareSendingAttachment": "准备发送附件…", + "sendingAttachment": "发送附件中…", + "calculatingFileSize": "计算文件尺寸中…", + "generatingVideoThumbnail": "生成视频缩略图中…", + "compressVideo": "压缩视频中…", + "sendingAttachmentCountOfCount": "正在发送附件 {index},共 {length} 个附件…", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "达到了服务器限制!等待 {seconds} 秒…", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "oneOfYourDevicesIsNotVerified": "您设备中的一台未验证", + "noticeChatBackupDeviceVerification": "注意:当你连接所有设备到聊天备份时,这些设备将被自动验证。", + "welcomeText": "你好呀 👋 欢迎来到 FluffyChat。你可以登录任意兼容 https://matrix.org 的 homeserver,然后和任何人聊天。这是个巨大的去中心化消息网络!", + "continueText": "继续", + "blur": "模糊:", + "opacity": "不透明:", + "setWallpaper": "设置壁纸", + "manageAccount": "管理账户", + "aboutHomeserver": "关于 {homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "version": "版本", + "noContactInformationProvided": "服务器未提供任何有效的联系信息", + "contactServerAdmin": "联系服务器管理员", + "name": "名称", + "contactServerSecurity": "联系服务器安全管理", + "supportPage": "支持页面", + "serverInformation": "服务器信息:", + "website": "网站", + "italicText": "文件倾斜", + "strikeThrough": "删除线", + "pleaseFillOut": "请填写", + "addLink": "添加链接", + "boldText": "文本加粗", + "invalidUrl": "无效 url", + "unableToJoinChat": "无法加入聊天。可能其他方面已经关闭了对话。", + "sendImages": "发送 {count} 张图片", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "compress": "压缩", + "previous": "前一个", + "otherPartyNotLoggedIn": "另一方当前未登录,因而无法接收消息!", + "appWantsToUseForLoginDescription": "您特此允许本应用和网站分享关于您的信息。", + "open": "打开", + "appWantsToUseForLogin": "使用 '{server}'服务器登录", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "waitingForServer": "正在等待服务器…", + "synchronizingPleaseWaitCounter": " 同步中… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "appIntroduction": "FluffyChat 让使用不同即时通信工具的你和你的好友得以聊天。 访问 https://matrix.org 了解详情或轻按 *继续*。", + "newChatRequest": "📩 新的聊天请求", + "generalNotificationSettings": "常规通知设置", + "userSpecificNotificationSettings": "使用特定通知设置", + "notificationRuleMaster": "静音所有通知", + "notificationRuleSuppressNotices": "隐藏自动消息", + "notificationRuleInviteForMe": "给我的邀请", + "notificationRuleInviteForMeDescription": "当用户被邀请加入聊天室时提醒用户。", + "notificationRuleMemberEvent": "成员事件", + "notificationRuleMemberEventDescription": "隐藏成员身份事件通知。", + "notificationRuleIsUserMention": "用户提及", + "notificationRuleIsUserMentionDescription": "当消息中直接提到用户名时通知使用该用户名的用户。", + "notificationRuleContainsDisplayName": "包含展示名称", + "notificationRuleIsRoomMention": "聊天室提及", + "notificationRuleRoomnotifDescription": "消息包含 「@room」 时提醒用户。", + "notificationRuleTombstone": "墓碑", + "notificationRuleRoomServerAcl": "聊天室服务器 ACL", + "notificationRuleSuppressEdits": "隐藏编辑", + "notificationRuleCall": "通话", + "notificationRuleRoomOneToOne": "一对一聊天室", + "notificationRuleRoomOneToOneDescription": "在一对一聊天室中提醒用户消息。", + "notificationRuleEncrypted": "已加密", + "notificationRuleEncryptedDescription": "在已加密聊天室中提醒用户消息。", + "notificationRuleJitsi": "Jitsi", + "notificationRuleJitsiDescription": "提醒用户 Jitsi 小部件的事件。", + "notificationRuleServerAcl": "隐藏服务器 ACL 事件", + "notificationRuleServerAclDescription": "隐藏服务器 ACL 事件的通知。", + "deletePushRuleCanNotBeUndone": "删除这个通知设置的操作无法撤销。", + "more": "更多", + "notificationRuleReactionDescription": "隐藏回应通知。", + "notificationRuleMessageDescription": "提醒用户常规消息。", + "notificationRuleContainsUserName": "包含用户名", + "otherNotificationSettings": "其他通知设置", + "notificationRuleContainsUserNameDescription": "当消息包含用户名时通知使用该用户名的用户。", + "notificationRuleIsRoomMentionDescription": "有聊天室提及时通知用户。", + "contentNotificationSettings": "内容通知设置", + "notificationRuleMasterDescription": "覆盖所有其他规则并禁用所有通知。", + "notificationRuleSuppressNoticesDescription": "隐藏来自 bot 等自动客户端的通知。", + "roomNotificationSettings": "聊天室通知设置", + "notificationRuleRoomServerAclDescription": "隐藏聊天室服务器访问控制列表(ACL)通知。", + "notificationRuleContainsDisplayNameDescription": "当消息包含用户的展示名时提醒使用该展示名的用户。", + "notificationRuleRoomnotif": "聊天室通知", + "notificationRuleTombstoneDescription": "提醒用户聊天室解散的消息。", + "notificationRuleReaction": "回应", + "notificationRuleSuppressEditsDescription": "隐藏消息编辑通知。", + "notificationRuleCallDescription": "提醒用户通话的消息。", + "notificationRuleEncryptedRoomOneToOne": "已加密一对一聊天室", + "notificationRuleEncryptedRoomOneToOneDescription": "在已加密一对一聊天室中提醒用户消息。", + "notificationRuleMessage": "消息", + "unknownPushRule": "未知推送规则 '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "crossVerifiedDevices": "交叉验证设备", + "shareKeysWithDescription": "选择应当信任哪些设备允许它们读取你在加密聊天中的消息?", + "shareKeysWith": "与哪些设备分享密钥…", + "allDevices": "所有设备", + "crossVerifiedDevicesIfEnabled": "交叉验证设备(如启用)", + "verifiedDevicesOnly": "仅已验证设备", + "optionalMessage": "(可选)消息…", + "takeAPhoto": "拍照", + "recordAVideo": "录像", + "notSupportedOnThisDevice": "此设备上不受支持", + "enterNewChat": "进入新聊天", + "commandHint_roomupgrade": "将此聊天室升级到给定的聊天室版本", + "setCustomPermissionLevel": "设置自定义权限等级", + "setPermissionsLevelDescription": "请在下方选择预定义的角色或输入 0 到 100 间的自定义权限等级。", + "ignoreUser": "忽略用户", + "normalUser": "正常用户", + "approve": "批准", + "youHaveKnocked": "你已请求加入", + "pleaseWaitUntilInvited": "在来自该聊天室的某人邀请你之前请等待。", + "countInvited": "邀请了 {count}", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "checkList": "清单", + "sentVoiceMessage": "🎙️ {duration} - 来自 {sender} 的语音消息", + "@sentVoiceMessage": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "duration": { + "type": "String" + } + } + }, + "commandHint_logout": "注销当前设备", + "commandHint_logoutall": "注销所有活动设备", + "displayNavigationRail": "在移动设备上显示导航栏", + "customReaction": "自定义回应", + "moreEvents": "更多事件", + "declineInvitation": "拒绝邀请", + "noMessagesYet": "尚无消息", + "longPressToRecordVoiceMessage": "长按录制语音消息。", + "pause": "暂停", + "resume": "继续", + "newSubSpace": "新建子空间", + "moveToDifferentSpace": "移动到别的空间", + "moveUp": "上移", + "moveDown": "下移", + "removeFromSpaceDescription": "将从空间移除该聊天,但仍出现在聊天列表中。", + "countChats": "{chats} 个聊天", + "@countChats": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + } + } + }, + "spaceMemberOf": "{spaces} 的空间成员", + "@spaceMemberOf": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "spaceMemberOfCanKnock": "{spaces} 的空间成员可以敲门", + "@spaceMemberOfCanKnock": { + "type": "String", + "placeholders": { + "spaces": { + "type": "String" + } + } + }, + "donate": "捐赠", + "startedAPoll": "{username} 启动了投票。", + "@startedAPoll": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "poll": "投票", + "startPoll": "启动投票", + "endPoll": "结束投票", + "answersVisible": "结果可见", + "answersHidden": "结果隐藏", + "pollQuestion": "投票问题", + "answerOption": "结果选项", + "addAnswerOption": "添加结果选项", + "allowMultipleAnswers": "允许多个结果", + "pollHasBeenEnded": "投票已结束", + "countVotes": "{count, plural, =1{票} other{{count} 票}}", + "@countVotes": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "answersWillBeVisibleWhenPollHasEnded": "投票结束后将显示结果", + "thread": "嘟文串", + "replyInThread": "在嘟文串中回复", + "countReplies": "{count, plural, =1{则回复} other{{count} 则回复}}", + "@countReplies": { + "type": "int", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "backToMainChat": "返回主聊天", + "saveChanges": "保存更改", + "createSticker": "创建贴纸或表情图片", + "useAsSticker": "用作贴纸", + "useAsEmoji": "用作表情图片", + "stickerPackNameAlreadyExists": "贴纸包名已存在", + "newStickerPack": "新建贴纸包", + "stickerPackName": "贴纸包名", + "attribution": "作者", + "skipChatBackup": "跳过聊天备份", + "skipChatBackupWarning": "确定吗?不开启聊天备份,如果切换设备可能无法访问消息。", + "loadingMessages": "加载消息中", + "setupChatBackup": "设置聊天备份", + "changedTheChatDescription": "{username} 更改了聊天描述", + "changedTheChatName": "{username} 更改了聊天名", + "noMoreResultsFound": "未找到更多结果", + "chatSearchedUntil": "搜索了截至 {time} 的聊天记录", + "@chatSearchedUntil": { + "type": "String", + "placeholders": { + "time": { + "type": "String" + } + } + }, + "federationBaseUrl": "联邦基础 URL", + "clientWellKnownInformation": "Client-Well-Known 信息:", + "baseUrl": "基础 URL", + "identityServer": "身份服务器:", + "versionWithNumber": "版本:{version}", + "@versionWithNumber": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "logs": "日志", + "advancedConfigs": "高级配置", + "advancedConfigurations": "高级配置", + "signInWithLabel": "登录方式:", + "signIn": "登录", + "createNewAccount": "创建新账户", + "signUpGreeting": "FluffyChat 是去中心化的!选择您希望创建账户的服务器!", + "signInGreeting": "已经有 Matrix 账户了?欢迎回来!选择 homeserver 登录。", + "appIntro": "借助 FluffyChat,您可以和好友聊天。它是安全的去中心化 [matrix] 消息收发应用!如果愿意,可以在 https://matrix.org 了解更多信息,也可直接注册账户。", + "theProcessWasCanceled": "过程被取消。", + "join": "加入", + "searchOrEnterHomeserverAddress": "搜索或输入 homeserver 地址", + "matrixId": "Matrix ID", + "setPowerLevel": "设置权限级别", + "makeModerator": "协管员", + "makeAdmin": "管理员", + "removeModeratorRights": "删除协管员权限", + "removeAdminRights": "删除管理员权限", + "powerLevel": "权限级别", + "setPowerLevelDescription": "权限级别定义群成员在这个聊天室中可以做什么,取值范围 0 到 100。", + "owner": "所有者" +} diff --git a/lib/l10n/intl_zh_Hant.arb b/lib/l10n/intl_zh_Hant.arb new file mode 100644 index 000000000..ea0cd6bf9 --- /dev/null +++ b/lib/l10n/intl_zh_Hant.arb @@ -0,0 +1,3362 @@ +{ + "@@last_modified": "2021-08-14 12:41:09.708353", + "about": "關於", + "@about": { + "type": "String", + "placeholders": {} + }, + "accept": "同意", + "@accept": { + "type": "String", + "placeholders": {} + }, + "acceptedTheInvitation": "👍 {username} 已接受邀請", + "@acceptedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "account": "帳號", + "@account": { + "type": "String", + "placeholders": {} + }, + "activatedEndToEndEncryption": "🔐 {username} 已啟用點對點加密", + "@activatedEndToEndEncryption": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "addEmail": "新增電子郵件", + "@addEmail": { + "type": "String", + "placeholders": {} + }, + "admin": "管理員", + "@admin": { + "type": "String", + "placeholders": {} + }, + "alias": "別稱", + "@alias": { + "type": "String", + "placeholders": {} + }, + "all": "全部", + "@all": { + "type": "String", + "placeholders": {} + }, + "answeredTheCall": "已開始與 {senderName} 通話", + "@answeredTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "anyoneCanJoin": "任何人可以加入", + "@anyoneCanJoin": { + "type": "String", + "placeholders": {} + }, + "appLock": "密碼鎖定", + "@appLock": { + "type": "String", + "placeholders": {} + }, + "archive": "封存", + "@archive": { + "type": "String", + "placeholders": {} + }, + "areGuestsAllowedToJoin": "是否允許訪客加入", + "@areGuestsAllowedToJoin": { + "type": "String", + "placeholders": {} + }, + "areYouSure": "您確定嗎?", + "@areYouSure": { + "type": "String", + "placeholders": {} + }, + "areYouSureYouWantToLogout": "您確定要登出嗎?", + "@areYouSureYouWantToLogout": { + "type": "String", + "placeholders": {} + }, + "askSSSSSign": "請輸入您安全儲存的密碼短語或恢復金鑰,以向對方簽名。", + "@askSSSSSign": { + "type": "String", + "placeholders": {} + }, + "askVerificationRequest": "是否接受來自 {username} 的驗證申請?", + "@askVerificationRequest": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "badServerLoginTypesException": "目前伺服器支援的登入類型:\n{serverVersions}\n但本應用程式僅支援:\n{supportedVersions}", + "@badServerLoginTypesException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "badServerVersionsException": "目前伺服器支援的協議版本:\n{serverVersions}\n但本應用程式僅支援 {supportedVersions}", + "@badServerVersionsException": { + "type": "String", + "placeholders": { + "serverVersions": { + "type": "String" + }, + "supportedVersions": { + "type": "String" + } + } + }, + "banFromChat": "已從聊天室中封鎖", + "@banFromChat": { + "type": "String", + "placeholders": {} + }, + "banned": "已被封鎖", + "@banned": { + "type": "String", + "placeholders": {} + }, + "bannedUser": "{username} 封鎖了 {targetName}", + "@bannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "blockDevice": "封鎖裝置", + "@blockDevice": { + "type": "String", + "placeholders": {} + }, + "blocked": "已封鎖", + "@blocked": { + "type": "String", + "placeholders": {} + }, + "botMessages": "機器人訊息", + "@botMessages": { + "type": "String", + "placeholders": {} + }, + "cancel": "取消", + "@cancel": { + "type": "String", + "placeholders": {} + }, + "changeDeviceName": "變更裝置名稱", + "@changeDeviceName": { + "type": "String", + "placeholders": {} + }, + "changedTheChatAvatar": "{username} 變更了對話頭貼", + "@changedTheChatAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheChatDescriptionTo": "{username} 變更了聊天室介紹為:「{description}」", + "@changedTheChatDescriptionTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "description": { + "type": "String" + } + } + }, + "changedTheChatNameTo": "{username} 把聊天室名稱變更為:「{chatname}」", + "@changedTheChatNameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "chatname": { + "type": "String" + } + } + }, + "changedTheChatPermissions": "{username} 變更了對話權限", + "@changedTheChatPermissions": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheDisplaynameTo": "{username} 變更了顯示名稱為:「{displayname}」", + "@changedTheDisplaynameTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "displayname": { + "type": "String" + } + } + }, + "changedTheGuestAccessRules": "{username} 變更了訪客訪問規則", + "@changedTheGuestAccessRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheGuestAccessRulesTo": "{username} 變更了訪客訪問規則為:{rules}", + "@changedTheGuestAccessRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheHistoryVisibility": "{username} 變更了歷史記錄觀察狀態", + "@changedTheHistoryVisibility": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheHistoryVisibilityTo": "{username} 變更了歷史紀錄觀察狀態到:{rules}", + "@changedTheHistoryVisibilityTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "rules": { + "type": "String" + } + } + }, + "changedTheJoinRules": "{username} 變更了加入的規則", + "@changedTheJoinRules": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheJoinRulesTo": "{username} 變更了加入的規則為:{joinRules}", + "@changedTheJoinRulesTo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "joinRules": { + "type": "String" + } + } + }, + "changedTheProfileAvatar": "{username} 變更了頭貼", + "@changedTheProfileAvatar": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomAliases": "{username} 變更了聊天室名", + "@changedTheRoomAliases": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changedTheRoomInvitationLink": "{username} 變更了邀請連結", + "@changedTheRoomInvitationLink": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "changePassword": "變更密碼", + "@changePassword": { + "type": "String", + "placeholders": {} + }, + "changeTheHomeserver": "變更主機位址", + "@changeTheHomeserver": { + "type": "String", + "placeholders": {} + }, + "changeTheme": "變更主題", + "@changeTheme": { + "type": "String", + "placeholders": {} + }, + "changeTheNameOfTheGroup": "變更了群組名稱", + "@changeTheNameOfTheGroup": { + "type": "String", + "placeholders": {} + }, + "channelCorruptedDecryptError": "加密已被破壞", + "@channelCorruptedDecryptError": { + "type": "String", + "placeholders": {} + }, + "chat": "聊天室", + "@chat": { + "type": "String", + "placeholders": {} + }, + "chatBackup": "備份聊天室", + "@chatBackup": { + "type": "String", + "placeholders": {} + }, + "chatBackupDescription": "您的過往聊天室記錄已被恢復金鑰加密。請您確保不會弄丟它。", + "@chatBackupDescription": { + "type": "String", + "placeholders": {} + }, + "chatDetails": "對話詳細", + "@chatDetails": { + "type": "String", + "placeholders": {} + }, + "chooseAStrongPassword": "輸入一個較強的密碼", + "@chooseAStrongPassword": { + "type": "String", + "placeholders": {} + }, + "close": "關閉", + "@close": { + "type": "String", + "placeholders": {} + }, + "compareEmojiMatch": "請對比這些表情", + "@compareEmojiMatch": { + "type": "String", + "placeholders": {} + }, + "compareNumbersMatch": "請對比這些數字", + "@compareNumbersMatch": { + "type": "String", + "placeholders": {} + }, + "configureChat": "設定聊天室", + "@configureChat": { + "type": "String", + "placeholders": {} + }, + "confirm": "確認", + "@confirm": { + "type": "String", + "placeholders": {} + }, + "connect": "連接", + "@connect": { + "type": "String", + "placeholders": {} + }, + "contactHasBeenInvitedToTheGroup": "聯絡人已被邀請至群組", + "@contactHasBeenInvitedToTheGroup": { + "type": "String", + "placeholders": {} + }, + "containsDisplayName": "包含顯示名稱", + "@containsDisplayName": { + "type": "String", + "placeholders": {} + }, + "containsUserName": "包含使用者名稱", + "@containsUserName": { + "type": "String", + "placeholders": {} + }, + "contentHasBeenReported": "此內容已被回報給伺服器管理員們", + "@contentHasBeenReported": { + "type": "String", + "placeholders": {} + }, + "copiedToClipboard": "已複製到剪貼簿", + "@copiedToClipboard": { + "type": "String", + "placeholders": {} + }, + "copy": "複製", + "@copy": { + "type": "String", + "placeholders": {} + }, + "copyToClipboard": "複製到剪貼簿", + "@copyToClipboard": { + "type": "String", + "placeholders": {} + }, + "couldNotDecryptMessage": "不能解密訊息:{error}", + "@couldNotDecryptMessage": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "countParticipants": "{count} 個參與者", + "@countParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "create": "建立", + "@create": { + "type": "String", + "placeholders": {} + }, + "createdTheChat": "💬 {username} 建立了聊天室", + "@createdTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "currentlyActive": "目前活躍", + "@currentlyActive": { + "type": "String", + "placeholders": {} + }, + "darkTheme": "夜間模式", + "@darkTheme": { + "type": "String", + "placeholders": {} + }, + "dateAndTimeOfDay": "{date} , {timeOfDay}", + "@dateAndTimeOfDay": { + "type": "String", + "placeholders": { + "date": { + "type": "String" + }, + "timeOfDay": { + "type": "String" + } + } + }, + "dateWithoutYear": "{month} - {day}", + "@dateWithoutYear": { + "type": "String", + "placeholders": { + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "dateWithYear": "{year} - {month} - {day}", + "@dateWithYear": { + "type": "String", + "placeholders": { + "year": { + "type": "String" + }, + "month": { + "type": "String" + }, + "day": { + "type": "String" + } + } + }, + "deactivateAccountWarning": "這將停用您的帳號。這個決定是不能挽回的!您確定嗎?", + "@deactivateAccountWarning": { + "type": "String", + "placeholders": {} + }, + "defaultPermissionLevel": "預設權限等級", + "@defaultPermissionLevel": { + "type": "String", + "placeholders": {} + }, + "delete": "刪除", + "@delete": { + "type": "String", + "placeholders": {} + }, + "deleteAccount": "刪除帳號", + "@deleteAccount": { + "type": "String", + "placeholders": {} + }, + "deleteMessage": "刪除訊息", + "@deleteMessage": { + "type": "String", + "placeholders": {} + }, + "device": "裝置", + "@device": { + "type": "String", + "placeholders": {} + }, + "deviceId": "裝置ID", + "@deviceId": { + "type": "String", + "placeholders": {} + }, + "devices": "裝置", + "@devices": { + "type": "String", + "placeholders": {} + }, + "directChats": "直接傳訊", + "@directChats": { + "type": "String", + "placeholders": {} + }, + "displaynameHasBeenChanged": "顯示名稱已被變更", + "@displaynameHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "downloadFile": "下載文件", + "@downloadFile": { + "type": "String", + "placeholders": {} + }, + "edit": "編輯", + "@edit": { + "type": "String", + "placeholders": {} + }, + "editBlockedServers": "編輯被封鎖的伺服器", + "@editBlockedServers": { + "type": "String", + "placeholders": {} + }, + "editDisplayname": "編輯顯示名稱", + "@editDisplayname": { + "type": "String", + "placeholders": {} + }, + "editRoomAvatar": "編輯聊天室頭貼", + "@editRoomAvatar": { + "type": "String", + "placeholders": {} + }, + "emoteExists": "表情已存在!", + "@emoteExists": { + "type": "String", + "placeholders": {} + }, + "emoteInvalid": "無效的表情快捷鍵!", + "@emoteInvalid": { + "type": "String", + "placeholders": {} + }, + "emotePacks": "聊天室的表情符號", + "@emotePacks": { + "type": "String", + "placeholders": {} + }, + "emoteSettings": "表情設定", + "@emoteSettings": { + "type": "String", + "placeholders": {} + }, + "emoteShortcode": "表情快捷鍵", + "@emoteShortcode": { + "type": "String", + "placeholders": {} + }, + "emoteWarnNeedToPick": "您需要選取一個表情快捷鍵和一張圖片!", + "@emoteWarnNeedToPick": { + "type": "String", + "placeholders": {} + }, + "emptyChat": "空的聊天室", + "@emptyChat": { + "type": "String", + "placeholders": {} + }, + "enableEmotesGlobally": "在全域啟用表情符號", + "@enableEmotesGlobally": { + "type": "String", + "placeholders": {} + }, + "enableEncryption": "啟用加密", + "@enableEncryption": { + "type": "String", + "placeholders": {} + }, + "enableEncryptionWarning": "您將不能再停用加密,確定嗎?", + "@enableEncryptionWarning": { + "type": "String", + "placeholders": {} + }, + "encrypted": "已加密的", + "@encrypted": { + "type": "String", + "placeholders": {} + }, + "encryption": "加密", + "@encryption": { + "type": "String", + "placeholders": {} + }, + "encryptionNotEnabled": "加密未啟用", + "@encryptionNotEnabled": { + "type": "String", + "placeholders": {} + }, + "endedTheCall": "{senderName} 結束了通話", + "@endedTheCall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "enterAnEmailAddress": "輸入一個電子郵件位址", + "@enterAnEmailAddress": { + "type": "String", + "placeholders": {} + }, + "enterYourHomeserver": "輸入伺服器位址", + "@enterYourHomeserver": { + "type": "String", + "placeholders": {} + }, + "everythingReady": "一切就緒!", + "@everythingReady": { + "type": "String", + "placeholders": {} + }, + "extremeOffensive": "極端令人反感", + "@extremeOffensive": { + "type": "String", + "placeholders": {} + }, + "fileName": "檔案名稱", + "@fileName": { + "type": "String", + "placeholders": {} + }, + "fluffychat": "FluffyChat", + "@fluffychat": { + "type": "String", + "placeholders": {} + }, + "fontSize": "字體大小", + "@fontSize": { + "type": "String", + "placeholders": {} + }, + "forward": "轉發", + "@forward": { + "type": "String", + "placeholders": {} + }, + "fromJoining": "自加入起", + "@fromJoining": { + "type": "String", + "placeholders": {} + }, + "fromTheInvitation": "自邀請起", + "@fromTheInvitation": { + "type": "String", + "placeholders": {} + }, + "group": "群組", + "@group": { + "type": "String", + "placeholders": {} + }, + "groupIsPublic": "群組是公開的", + "@groupIsPublic": { + "type": "String", + "placeholders": {} + }, + "groups": "群組", + "@groups": { + "type": "String", + "placeholders": {} + }, + "groupWith": "名稱為 {displayname} 的群組", + "@groupWith": { + "type": "String", + "placeholders": { + "displayname": { + "type": "String" + } + } + }, + "guestsAreForbidden": "訪客已被禁止", + "@guestsAreForbidden": { + "type": "String", + "placeholders": {} + }, + "guestsCanJoin": "訪客可以加入", + "@guestsCanJoin": { + "type": "String", + "placeholders": {} + }, + "hasWithdrawnTheInvitationFor": "{username} 收回了對 {targetName} 的邀請", + "@hasWithdrawnTheInvitationFor": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "help": "幫助", + "@help": { + "type": "String", + "placeholders": {} + }, + "hideRedactedEvents": "隱藏編輯過的事件", + "@hideRedactedEvents": { + "type": "String", + "placeholders": {} + }, + "hideUnknownEvents": "隱藏未知事件", + "@hideUnknownEvents": { + "type": "String", + "placeholders": {} + }, + "howOffensiveIsThisContent": "這個內容有多令人反感?", + "@howOffensiveIsThisContent": { + "type": "String", + "placeholders": {} + }, + "id": "ID", + "@id": { + "type": "String", + "placeholders": {} + }, + "identity": "身份", + "@identity": { + "type": "String", + "placeholders": {} + }, + "ignore": "無視", + "@ignore": { + "type": "String", + "placeholders": {} + }, + "ignoredUsers": "已無視的使用者", + "@ignoredUsers": { + "type": "String", + "placeholders": {} + }, + "iHaveClickedOnLink": "我已經點擊了網址", + "@iHaveClickedOnLink": { + "type": "String", + "placeholders": {} + }, + "incorrectPassphraseOrKey": "錯誤的密碼短語或恢復金鑰", + "@incorrectPassphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "inoffensive": "不令人反感", + "@inoffensive": { + "type": "String", + "placeholders": {} + }, + "inviteContact": "邀請聯絡人", + "@inviteContact": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroup": "邀請聯絡人到 {groupName}", + "@inviteContactToGroup": { + "type": "String", + "placeholders": { + "groupName": { + "type": "String" + } + } + }, + "invited": "已邀請", + "@invited": { + "type": "String", + "placeholders": {} + }, + "invitedUser": "📩 {username} 邀請了 {targetName}", + "@invitedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "invitedUsersOnly": "只有被邀請的使用者", + "@invitedUsersOnly": { + "type": "String", + "placeholders": {} + }, + "inviteForMe": "來自我的邀請", + "@inviteForMe": { + "type": "String", + "placeholders": {} + }, + "inviteText": "{username} 邀請您使用 FluffyChat\n1. 安裝 FluffyChat:https://fluffychat.im\n2. 登入或註冊\n3. 打開該邀請網址:\n{link}", + "@inviteText": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "link": { + "type": "String" + } + } + }, + "isTyping": "正在輸入...…", + "@isTyping": { + "type": "String", + "placeholders": {} + }, + "joinedTheChat": "👋 {username} 加入了聊天室", + "@joinedTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "joinRoom": "加入聊天室", + "@joinRoom": { + "type": "String", + "placeholders": {} + }, + "kicked": "👞 {username} 踢了 {targetName}", + "@kicked": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickedAndBanned": "🙅 {username} 踢了 {targetName} 並將其封鎖", + "@kickedAndBanned": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "kickFromChat": "從聊天室踢出", + "@kickFromChat": { + "type": "String", + "placeholders": {} + }, + "lastActiveAgo": "最後活動時間:{localizedTimeShort}", + "@lastActiveAgo": { + "type": "String", + "placeholders": { + "localizedTimeShort": { + "type": "String" + } + } + }, + "leave": "離開", + "@leave": { + "type": "String", + "placeholders": {} + }, + "leftTheChat": "離開了聊天室", + "@leftTheChat": { + "type": "String", + "placeholders": {} + }, + "license": "授權", + "@license": { + "type": "String", + "placeholders": {} + }, + "lightTheme": "日間模式", + "@lightTheme": { + "type": "String", + "placeholders": {} + }, + "loadCountMoreParticipants": "載入 {count} 個更多的參與者", + "@loadCountMoreParticipants": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loadingPleaseWait": "載入中...... 請稍候。", + "@loadingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "loadMore": "載入更多...…", + "@loadMore": { + "type": "String", + "placeholders": {} + }, + "login": "登入", + "@login": { + "type": "String", + "placeholders": {} + }, + "logInTo": "登入 {homeserver}", + "@logInTo": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "logout": "登出", + "@logout": { + "type": "String", + "placeholders": {} + }, + "memberChanges": "變更成員", + "@memberChanges": { + "type": "String", + "placeholders": {} + }, + "mention": "提及", + "@mention": { + "type": "String", + "placeholders": {} + }, + "messages": "訊息", + "@messages": { + "type": "String", + "placeholders": {} + }, + "moderator": "版主", + "@moderator": { + "type": "String", + "placeholders": {} + }, + "muteChat": "將該聊天室靜音", + "@muteChat": { + "type": "String", + "placeholders": {} + }, + "needPantalaimonWarning": "請注意您需要 Pantalaimon 才能使用點對點加密功能。", + "@needPantalaimonWarning": { + "type": "String", + "placeholders": {} + }, + "newChat": "新聊天", + "@newChat": { + "type": "String", + "placeholders": {} + }, + "newMessageInFluffyChat": "💬 來自 FluffyChat 的新訊息", + "@newMessageInFluffyChat": { + "type": "String", + "placeholders": {} + }, + "newVerificationRequest": "新的驗證請求!", + "@newVerificationRequest": { + "type": "String", + "placeholders": {} + }, + "next": "下一個", + "@next": { + "type": "String", + "placeholders": {} + }, + "no": "否", + "@no": { + "type": "String", + "placeholders": {} + }, + "noConnectionToTheServer": "無法連接到伺服器", + "@noConnectionToTheServer": { + "type": "String", + "placeholders": {} + }, + "noEmotesFound": "表情符號不存在。😕", + "@noEmotesFound": { + "type": "String", + "placeholders": {} + }, + "noEncryptionForPublicRooms": "您只能在這個聊天室不再被允許公開訪問後,才能啟用加密。", + "@noEncryptionForPublicRooms": { + "type": "String", + "placeholders": {} + }, + "noGoogleServicesWarning": "未能在你的裝置找到 Firebase Cloud Messaging(FCM). 如果想要收到通知消息的推送,我們建議安裝 ntfy。在有 ntfy 或其他 Unified Push 應用,便能在資料安全的情況下收到通知的推送。你可以在 Play store 或 F-Droid 下載並安裝 ntfy。", + "@noGoogleServicesWarning": { + "type": "String", + "placeholders": {} + }, + "none": "無", + "@none": { + "type": "String", + "placeholders": {} + }, + "noPasswordRecoveryDescription": "您尚未新增恢復密碼的方法。", + "@noPasswordRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "noPermission": "沒有權限", + "@noPermission": { + "type": "String", + "placeholders": {} + }, + "noRoomsFound": "找不到聊天室...…", + "@noRoomsFound": { + "type": "String", + "placeholders": {} + }, + "notifications": "通知", + "@notifications": { + "type": "String", + "placeholders": {} + }, + "notificationsEnabledForThisAccount": "已為此帳號啟用通知", + "@notificationsEnabledForThisAccount": { + "type": "String", + "placeholders": {} + }, + "numUsersTyping": "{count} 個人正在輸入...…", + "@numUsersTyping": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "offensive": "令人反感", + "@offensive": { + "type": "String", + "placeholders": {} + }, + "offline": "離線", + "@offline": { + "type": "String", + "placeholders": {} + }, + "ok": "OK", + "@ok": { + "type": "String", + "placeholders": {} + }, + "online": "線上", + "@online": { + "type": "String", + "placeholders": {} + }, + "onlineKeyBackupEnabled": "線上金鑰備份已啟用", + "@onlineKeyBackupEnabled": { + "type": "String", + "placeholders": {} + }, + "oopsSomethingWentWrong": "哎呀!出了一點差錯...…", + "@oopsSomethingWentWrong": { + "type": "String", + "placeholders": {} + }, + "openAppToReadMessages": "打開應用程式以讀取訊息", + "@openAppToReadMessages": { + "type": "String", + "placeholders": {} + }, + "openCamera": "開啟相機", + "@openCamera": { + "type": "String", + "placeholders": {} + }, + "participant": "參與者", + "@participant": { + "type": "String", + "placeholders": {} + }, + "passphraseOrKey": "密碼短語或恢復金鑰", + "@passphraseOrKey": { + "type": "String", + "placeholders": {} + }, + "password": "密碼", + "@password": { + "type": "String", + "placeholders": {} + }, + "passwordForgotten": "忘記密碼", + "@passwordForgotten": { + "type": "String", + "placeholders": {} + }, + "passwordHasBeenChanged": "密碼已被變更", + "@passwordHasBeenChanged": { + "type": "String", + "placeholders": {} + }, + "passwordRecovery": "恢復密碼", + "@passwordRecovery": { + "type": "String", + "placeholders": {} + }, + "pickImage": "選擇圖片", + "@pickImage": { + "type": "String", + "placeholders": {} + }, + "pin": "釘選", + "@pin": { + "type": "String", + "placeholders": {} + }, + "play": "播放 {fileName}", + "@play": { + "type": "String", + "placeholders": { + "fileName": { + "type": "String" + } + } + }, + "pleaseChooseAPasscode": "請選擇一個密碼", + "@pleaseChooseAPasscode": { + "type": "String", + "placeholders": {} + }, + "pleaseClickOnLink": "請點擊電子郵件中的網址,然後繼續。", + "@pleaseClickOnLink": { + "type": "String", + "placeholders": {} + }, + "pleaseEnter4Digits": "請輸入4位數字,或留空以停用密碼鎖定。", + "@pleaseEnter4Digits": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourPassword": "請輸入您的密碼", + "@pleaseEnterYourPassword": { + "type": "String", + "placeholders": {} + }, + "pleaseEnterYourUsername": "請輸入您的使用者名稱", + "@pleaseEnterYourUsername": { + "type": "String", + "placeholders": {} + }, + "pleaseFollowInstructionsOnWeb": "請按照網站上的說明進行操作,然後點擊下一步。", + "@pleaseFollowInstructionsOnWeb": { + "type": "String", + "placeholders": {} + }, + "privacy": "隱私", + "@privacy": { + "type": "String", + "placeholders": {} + }, + "publicRooms": "公開的聊天室", + "@publicRooms": { + "type": "String", + "placeholders": {} + }, + "pushRules": "推播規則", + "@pushRules": { + "type": "String", + "placeholders": {} + }, + "reason": "原因", + "@reason": { + "type": "String", + "placeholders": {} + }, + "recording": "錄音中", + "@recording": { + "type": "String", + "placeholders": {} + }, + "redactedAnEvent": "{username} 編輯了一個事件", + "@redactedAnEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "redactMessage": "重新編輯訊息", + "@redactMessage": { + "type": "String", + "placeholders": {} + }, + "reject": "拒絕", + "@reject": { + "type": "String", + "placeholders": {} + }, + "rejectedTheInvitation": "{username} 拒絕了邀請", + "@rejectedTheInvitation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "rejoin": "重新加入", + "@rejoin": { + "type": "String", + "placeholders": {} + }, + "remove": "移除", + "@remove": { + "type": "String", + "placeholders": {} + }, + "removeAllOtherDevices": "移除所有其他裝置", + "@removeAllOtherDevices": { + "type": "String", + "placeholders": {} + }, + "removedBy": "被 {username} 移除", + "@removedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "removeDevice": "移除裝置", + "@removeDevice": { + "type": "String", + "placeholders": {} + }, + "unbanFromChat": "解封聊天室", + "@unbanFromChat": { + "type": "String", + "placeholders": {} + }, + "replaceRoomWithNewerVersion": "用較新的版本取代聊天室", + "@replaceRoomWithNewerVersion": { + "type": "String", + "placeholders": {} + }, + "reply": "回覆", + "@reply": { + "type": "String", + "placeholders": {} + }, + "reportMessage": "檢舉訊息", + "@reportMessage": { + "type": "String", + "placeholders": {} + }, + "requestPermission": "請求權限", + "@requestPermission": { + "type": "String", + "placeholders": {} + }, + "roomHasBeenUpgraded": "聊天室已更新", + "@roomHasBeenUpgraded": { + "type": "String", + "placeholders": {} + }, + "search": "搜尋", + "@search": { + "type": "String", + "placeholders": {} + }, + "security": "安全", + "@security": { + "type": "String", + "placeholders": {} + }, + "seenByUser": "{username} 已讀", + "@seenByUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "send": "傳送", + "@send": { + "type": "String", + "placeholders": {} + }, + "sendAMessage": "傳送訊息", + "@sendAMessage": { + "type": "String", + "placeholders": {} + }, + "sendAudio": "傳送音訊", + "@sendAudio": { + "type": "String", + "placeholders": {} + }, + "sendFile": "傳送文件", + "@sendFile": { + "type": "String", + "placeholders": {} + }, + "sendImage": "傳送圖片", + "@sendImage": { + "type": "String", + "placeholders": {} + }, + "sendMessages": "傳送訊息", + "@sendMessages": { + "type": "String", + "placeholders": {} + }, + "sendOriginal": "傳送原始內容", + "@sendOriginal": { + "type": "String", + "placeholders": {} + }, + "sendVideo": "傳送影片", + "@sendVideo": { + "type": "String", + "placeholders": {} + }, + "sentAFile": "{username} 傳送了一個文件", + "@sentAFile": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAnAudio": "🎤{username} 傳送了一個音訊", + "@sentAnAudio": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAPicture": "🖼️{username} 傳送了一張圖片", + "@sentAPicture": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentASticker": "😊{username} 傳送了貼圖", + "@sentASticker": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentAVideo": "🎥{username} 傳送了影片", + "@sentAVideo": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "sentCallInformations": "{senderName} 傳送了通話資訊", + "@sentCallInformations": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "setCustomEmotes": "自訂表情符號", + "@setCustomEmotes": { + "type": "String", + "placeholders": {} + }, + "setInvitationLink": "設定邀請連結", + "@setInvitationLink": { + "type": "String", + "placeholders": {} + }, + "setPermissionsLevel": "設定權限等級", + "@setPermissionsLevel": { + "type": "String", + "placeholders": {} + }, + "setStatus": "設定狀態", + "@setStatus": { + "type": "String", + "placeholders": {} + }, + "settings": "設定", + "@settings": { + "type": "String", + "placeholders": {} + }, + "share": "分享", + "@share": { + "type": "String", + "placeholders": {} + }, + "sharedTheLocation": "{username} 分享了位置", + "@sharedTheLocation": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "showPassword": "顯示密碼", + "@showPassword": { + "type": "String", + "placeholders": {} + }, + "skip": "跳過", + "@skip": { + "type": "String", + "placeholders": {} + }, + "sourceCode": "原始碼", + "@sourceCode": { + "type": "String", + "placeholders": {} + }, + "startedACall": "{senderName} 開始了通話", + "@startedACall": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "status": "狀態", + "@status": { + "type": "String", + "placeholders": {} + }, + "statusExampleMessage": "今天過得如何?", + "@statusExampleMessage": { + "type": "String", + "placeholders": {} + }, + "submit": "送出", + "@submit": { + "type": "String", + "placeholders": {} + }, + "systemTheme": "自動", + "@systemTheme": { + "type": "String", + "placeholders": {} + }, + "theyDontMatch": "它們不相符", + "@theyDontMatch": { + "type": "String", + "placeholders": {} + }, + "theyMatch": "它們相符", + "@theyMatch": { + "type": "String", + "placeholders": {} + }, + "title": "FluffyChat", + "@title": { + "description": "Title for the application", + "type": "String", + "placeholders": {} + }, + "toggleFavorite": "切換收藏夾", + "@toggleFavorite": { + "type": "String", + "placeholders": {} + }, + "toggleMuted": "切換靜音", + "@toggleMuted": { + "type": "String", + "placeholders": {} + }, + "toggleUnread": "標示為已讀/未讀", + "@toggleUnread": { + "type": "String", + "placeholders": {} + }, + "tooManyRequestsWarning": "太多請求了。請稍候再試!", + "@tooManyRequestsWarning": { + "type": "String", + "placeholders": {} + }, + "transferFromAnotherDevice": "從其他裝置傳輸", + "@transferFromAnotherDevice": { + "type": "String", + "placeholders": {} + }, + "tryToSendAgain": "再次嘗試傳送", + "@tryToSendAgain": { + "type": "String", + "placeholders": {} + }, + "unavailable": "無法取得", + "@unavailable": { + "type": "String", + "placeholders": {} + }, + "unbannedUser": "{username} 解除封鎖了 {targetName}", + "@unbannedUser": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "targetName": { + "type": "String" + } + } + }, + "unblockDevice": "解除鎖定裝置", + "@unblockDevice": { + "type": "String", + "placeholders": {} + }, + "unknownDevice": "未知裝置", + "@unknownDevice": { + "type": "String", + "placeholders": {} + }, + "unknownEncryptionAlgorithm": "未知的加密演算法", + "@unknownEncryptionAlgorithm": { + "type": "String", + "placeholders": {} + }, + "unknownEvent": "未知事件「{type}」", + "@unknownEvent": { + "type": "String", + "placeholders": { + "type": { + "type": "String" + } + } + }, + "unmuteChat": "取消靜音聊天室", + "@unmuteChat": { + "type": "String", + "placeholders": {} + }, + "unpin": "取消釘選", + "@unpin": { + "type": "String", + "placeholders": {} + }, + "unreadChats": "{unreadCount, plural, =1 {1 unread chat} other { {unreadCount} 個未讀聊天室} }", + "@unreadChats": { + "type": "String", + "placeholders": { + "unreadCount": { + "type": "int" + } + } + }, + "userAndOthersAreTyping": "{username} 和其他 {count} 個人正在輸入...…", + "@userAndOthersAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "count": { + "type": "int" + } + } + }, + "userAndUserAreTyping": "{username} 和 {username2} 正在輸入...…", + "@userAndUserAreTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "username2": { + "type": "String" + } + } + }, + "userIsTyping": "{username} 正在輸入...…", + "@userIsTyping": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "userLeftTheChat": "{username} 離開了聊天室", + "@userLeftTheChat": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "username": "使用者名稱", + "@username": { + "type": "String", + "placeholders": {} + }, + "userSentUnknownEvent": "{username} 傳送了一個 {type} 事件", + "@userSentUnknownEvent": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "type": { + "type": "String" + } + } + }, + "verified": "已驗證", + "@verified": { + "type": "String", + "placeholders": {} + }, + "verify": "驗證", + "@verify": { + "type": "String", + "placeholders": {} + }, + "verifyStart": "開始驗證", + "@verifyStart": { + "type": "String", + "placeholders": {} + }, + "verifySuccess": "您成功驗證了!", + "@verifySuccess": { + "type": "String", + "placeholders": {} + }, + "verifyTitle": "正在驗證其他帳號", + "@verifyTitle": { + "type": "String", + "placeholders": {} + }, + "videoCall": "視訊通話", + "@videoCall": { + "type": "String", + "placeholders": {} + }, + "visibilityOfTheChatHistory": "聊天室記錄的可見性", + "@visibilityOfTheChatHistory": { + "type": "String", + "placeholders": {} + }, + "visibleForAllParticipants": "對所有參與者可見", + "@visibleForAllParticipants": { + "type": "String", + "placeholders": {} + }, + "visibleForEveryone": "對所有人可見", + "@visibleForEveryone": { + "type": "String", + "placeholders": {} + }, + "voiceMessage": "語音訊息", + "@voiceMessage": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerAcceptRequest": "正在等待夥伴接受請求...…", + "@waitingPartnerAcceptRequest": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerEmoji": "正在等待夥伴接受表情符號...…", + "@waitingPartnerEmoji": { + "type": "String", + "placeholders": {} + }, + "waitingPartnerNumbers": "正在等待夥伴接受數字...…", + "@waitingPartnerNumbers": { + "type": "String", + "placeholders": {} + }, + "wallpaper": "桌布:", + "@wallpaper": { + "type": "String", + "placeholders": {} + }, + "warning": "警告!", + "@warning": { + "type": "String", + "placeholders": {} + }, + "weSentYouAnEmail": "我們向您傳送了一封電子郵件", + "@weSentYouAnEmail": { + "type": "String", + "placeholders": {} + }, + "whoCanPerformWhichAction": "誰可以執行這個動作", + "@whoCanPerformWhichAction": { + "type": "String", + "placeholders": {} + }, + "whoIsAllowedToJoinThisGroup": "誰可以加入這個群組", + "@whoIsAllowedToJoinThisGroup": { + "type": "String", + "placeholders": {} + }, + "whyDoYouWantToReportThis": "您檢舉的原因是什麼?", + "@whyDoYouWantToReportThis": { + "type": "String", + "placeholders": {} + }, + "wipeChatBackup": "是否清除您的聊天室記錄備份以建立新的安全金鑰嗎?", + "@wipeChatBackup": { + "type": "String", + "placeholders": {} + }, + "withTheseAddressesRecoveryDescription": "有了這些位址,您就可以恢復密碼。", + "@withTheseAddressesRecoveryDescription": { + "type": "String", + "placeholders": {} + }, + "writeAMessage": "輸入訊息...…", + "@writeAMessage": { + "type": "String", + "placeholders": {} + }, + "yes": "是", + "@yes": { + "type": "String", + "placeholders": {} + }, + "you": "您", + "@you": { + "type": "String", + "placeholders": {} + }, + "youAreNoLongerParticipatingInThisChat": "您不再參與這個聊天室了", + "@youAreNoLongerParticipatingInThisChat": { + "type": "String", + "placeholders": {} + }, + "youHaveBeenBannedFromThisChat": "您已經被這個聊天室封鎖", + "@youHaveBeenBannedFromThisChat": { + "type": "String", + "placeholders": {} + }, + "yourPublicKey": "您的公鑰", + "@yourPublicKey": { + "type": "String", + "placeholders": {} + }, + "people": "人", + "@people": { + "type": "String", + "placeholders": {} + }, + "chats": "聊天室", + "@chats": { + "type": "String", + "placeholders": {} + }, + "allChats": "所有會話", + "@allChats": { + "type": "String", + "placeholders": {} + }, + "commandHint_ban": "在此聊天室封鎖該使用者", + "@commandHint_ban": { + "type": "String", + "description": "Usage hint for the command /ban" + }, + "commandHint_clearcache": "清除快取", + "@commandHint_clearcache": { + "type": "String", + "description": "Usage hint for the command /clearcache" + }, + "commandHint_create": "建立一個空的群聊\n使用 --no-encryption 選項來停用加密", + "@commandHint_create": { + "type": "String", + "description": "Usage hint for the command /create" + }, + "commandHint_discardsession": "丟棄工作階段", + "@commandHint_discardsession": { + "type": "String", + "description": "Usage hint for the command /discardsession" + }, + "commandHint_dm": "啟動一對一聊天室\n使用 --no-encryption 選項來停用加密", + "@commandHint_dm": { + "type": "String", + "description": "Usage hint for the command /dm" + }, + "commandHint_invite": "邀請該使用者加入此聊天室", + "@commandHint_invite": { + "type": "String", + "description": "Usage hint for the command /invite" + }, + "commandHint_join": "加入此聊天室", + "@commandHint_join": { + "type": "String", + "description": "Usage hint for the command /join" + }, + "commandHint_kick": "將這個使用者移出此聊天室", + "@commandHint_kick": { + "type": "String", + "description": "Usage hint for the command /kick" + }, + "commandHint_leave": "退出此聊天室", + "@commandHint_leave": { + "type": "String", + "description": "Usage hint for the command /leave" + }, + "commandHint_myroomnick": "設定您的聊天室暱稱", + "@commandHint_myroomnick": { + "type": "String", + "description": "Usage hint for the command /myroomnick" + }, + "editRoomAliases": "編輯聊天室名", + "@editRoomAliases": { + "type": "String", + "placeholders": {} + }, + "roomVersion": "聊天室的版本", + "@roomVersion": { + "type": "String", + "placeholders": {} + }, + "addToSpace": "加入空間", + "@addToSpace": {}, + "cantOpenUri": "無法打開 URI {uri}", + "@cantOpenUri": { + "type": "String", + "placeholders": { + "uri": { + "type": "String" + } + } + }, + "repeatPassword": "再次輸入密碼", + "@repeatPassword": {}, + "yourChatBackupHasBeenSetUp": "您的聊天室記錄備份已設定。", + "@yourChatBackupHasBeenSetUp": {}, + "goToTheNewRoom": "前往新聊天室", + "@goToTheNewRoom": { + "type": "String", + "placeholders": {} + }, + "commandHint_myroomavatar": "設定您的聊天室頭貼(通過 mxc-uri)", + "@commandHint_myroomavatar": { + "type": "String", + "description": "Usage hint for the command /myroomavatar" + }, + "commandHint_unban": "在此聊天室解除封鎖該使用者", + "@commandHint_unban": { + "type": "String", + "description": "Usage hint for the command /unban" + }, + "autoplayImages": "自動播放動態貼圖和表情", + "@autoplayImages": { + "type": "String", + "placeholder": {} + }, + "sendOnEnter": "按 Enter 鍵傳送", + "@sendOnEnter": {}, + "changeYourAvatar": "更改您的大頭貼", + "@changeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "chatHasBeenAddedToThisSpace": "聊天室已新增到此空間", + "@chatHasBeenAddedToThisSpace": {}, + "clearArchive": "清除存檔", + "@clearArchive": {}, + "hugContent": "{senderName} 擁抱您", + "@hugContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_cuddle": "傳送一個摟抱表情", + "@commandHint_cuddle": {}, + "supposedMxid": "此處應爲 {mxid}", + "@supposedMxid": { + "type": "String", + "placeholders": { + "mxid": { + "type": "String" + } + } + }, + "invalidServerName": "伺服器名稱錯誤", + "@invalidServerName": {}, + "importFromZipFile": "從 .zip 檔案匯入", + "@importFromZipFile": {}, + "homeserver": "伺服器", + "@homeserver": {}, + "exportEmotePack": "將表情包匯出成 .zip 檔案", + "@exportEmotePack": {}, + "commandInvalid": "命令無效", + "@commandInvalid": { + "type": "String" + }, + "commandMissing": "{command} 不是正確的命令。", + "@commandMissing": { + "type": "String", + "placeholders": { + "command": { + "type": "String" + } + }, + "description": "State that {command} is not a valid /command." + }, + "googlyEyesContent": "{senderName} 向您傳送了瞪眼表情", + "@googlyEyesContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "addChatDescription": "新增聊天室描述......", + "@addChatDescription": {}, + "sendTypingNotifications": "傳送「輸入中」通知", + "@sendTypingNotifications": {}, + "importEmojis": "匯入表情包", + "@importEmojis": {}, + "confirmMatrixId": "如需刪除你的帳戶,請確認你的 Matrix ID。", + "@confirmMatrixId": {}, + "notAnImage": "不是圖片檔案。", + "@notAnImage": {}, + "cuddleContent": "{senderName} 摟抱您", + "@cuddleContent": { + "type": "String", + "placeholders": { + "senderName": { + "type": "String" + } + } + }, + "commandHint_hug": "傳送一個擁抱表情", + "@commandHint_hug": {}, + "replace": "取代", + "@replace": {}, + "commandHint_googly": "傳送一些瞪眼表情", + "@commandHint_googly": {}, + "importNow": "立即匯入", + "@importNow": {}, + "blockListDescription": "你可以封鎖打擾你的使用者。你不會再收到任何從已封鎖使用者發來的訊息或聊天室邀請。", + "@blockListDescription": {}, + "blockedUsers": "已封鎖的使用者", + "@blockedUsers": {}, + "block": "封鎖", + "@block": {}, + "discover": "發現", + "@discover": {}, + "alwaysUse24HourFormat": "false", + "@alwaysUse24HourFormat": { + "description": "Set to true to always display time of day in 24 hour format." + }, + "sender": "傳送者", + "@sender": {}, + "voiceCall": "語音通話", + "@voiceCall": {}, + "blockUsername": "無視使用者名稱", + "@blockUsername": {}, + "noBackupWarning": "警告!如果不啟用聊天室備份,您將失去對加密訊息的訪問。強烈建議在登出前先啟用聊天室備份。", + "@noBackupWarning": {}, + "addChatOrSubSpace": "新增聊天室或子空間", + "@addChatOrSubSpace": {}, + "thisDevice": "這個裝置:", + "@thisDevice": {}, + "separateChatTypes": "分開私訊和群組", + "@separateChatTypes": { + "type": "String", + "placeholders": {} + }, + "commandHint_markasdm": "將給定的 Matrix ID 標示為直接訊息房間", + "@commandHint_markasdm": {}, + "commandHint_html": "傳送 HTML 格式的文字", + "@commandHint_html": { + "type": "String", + "description": "Usage hint for the command /html" + }, + "commandHint_send": "傳送文字", + "@commandHint_send": { + "type": "String", + "description": "Usage hint for the command /send" + }, + "emoteKeyboardNoRecents": "最近使用的表情將顯示在這裡...", + "@emoteKeyboardNoRecents": { + "type": "String", + "placeholders": {} + }, + "noChatDescriptionYet": "尚未建立聊天室描述。", + "@noChatDescriptionYet": {}, + "optionalRedactReason": "(非必填)收回此訊息的原因...", + "@optionalRedactReason": {}, + "dehydrateWarning": "此操作不能反悔。請確保安全地存儲備份文件。", + "@dehydrateWarning": {}, + "hydrateTorLong": "上次在 TOR 上匯出會話了嗎?快速匯入它已繼續使用聊天室。", + "@hydrateTorLong": {}, + "hydrate": "從備份文件恢復", + "@hydrate": {}, + "locationDisabledNotice": "位置服務被停用。請啟用它們以能夠分享您的位置。", + "@locationDisabledNotice": { + "type": "String", + "placeholders": {} + }, + "noMatrixServer": "{server1} 不是 Matrix 服務器,改用 {server2} 嗎?", + "@noMatrixServer": { + "type": "String", + "placeholders": { + "server1": { + "type": "String" + }, + "server2": { + "type": "String" + } + } + }, + "addToBundle": "新增到套組", + "@addToBundle": {}, + "bundleName": "套組名稱", + "@bundleName": {}, + "pleaseEnterYourPin": "請輸入您的密碼", + "@pleaseEnterYourPin": { + "type": "String", + "placeholders": {} + }, + "redactedByBecause": "由 {username} 編輯,原因:「{reason}」", + "@redactedByBecause": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + }, + "reason": { + "type": "String" + } + } + }, + "saveFile": "儲存檔案", + "@saveFile": { + "type": "String", + "placeholders": {} + }, + "publish": "發布", + "@publish": {}, + "hasKnocked": "🚪 {user} 敲門了", + "@hasKnocked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "unlockOldMessages": "解鎖舊消息", + "@unlockOldMessages": {}, + "callingAccountDetails": "允許 FluffyChat 使用原生 Android 撥號應用程式。", + "@callingAccountDetails": {}, + "noOtherDevicesFound": "未找到其他裝置", + "@noOtherDevicesFound": {}, + "noUsersFoundWithQuery": "很遺憾,找不到與「{query}」相符的使用者。請檢查是否有打錯字。", + "@noUsersFoundWithQuery": { + "type": "String", + "placeholders": { + "query": { + "type": "String" + } + } + }, + "publicLink": "公開網址", + "@publicLink": {}, + "dehydrate": "匯出會話並清除裝置", + "@dehydrate": {}, + "dehydrateTor": "TOR 使用者:匯出會話", + "@dehydrateTor": {}, + "reopenChat": "重新開啟聊天室", + "@reopenChat": {}, + "widgetNameError": "請提供一個顯示名稱。", + "@widgetNameError": {}, + "yourGlobalUserIdIs": "您的全域使用者ID是: ", + "@yourGlobalUserIdIs": {}, + "startFirstChat": "開始您的第一次聊天室", + "@startFirstChat": {}, + "experimentalVideoCalls": "實驗性視訊通話", + "@experimentalVideoCalls": {}, + "youAcceptedTheInvitation": "👍 您接受了邀請", + "@youAcceptedTheInvitation": {}, + "storeSecurlyOnThisDevice": "在此裝置上安全存儲", + "@storeSecurlyOnThisDevice": {}, + "countFiles": "{count} 個文件", + "@countFiles": { + "placeholders": { + "count": { + "type": "int" + } + } + }, + "screenSharingDetail": "您正在 FuffyChat 中分享您的螢幕", + "@screenSharingDetail": {}, + "wrongPinEntered": "輸入的密碼錯誤! {seconds} 秒後再試一次......", + "@wrongPinEntered": { + "type": "String", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "archiveRoomDescription": "聊天室將被移動到存檔中。其他使用者將能看到您已離開聊天室。", + "@archiveRoomDescription": {}, + "banUserDescription": "該使用者將被禁止進入聊天室,直到他們被解封之前都無法再次進入聊天室。", + "@banUserDescription": {}, + "searchChatsRooms": "搜尋 #chats, @users...", + "@searchChatsRooms": {}, + "decline": "拒絕", + "@decline": {}, + "sendReadReceipts": "傳送已讀回條", + "@sendReadReceipts": {}, + "formattedMessagesDescription": "使用 markdown 顯示豐富的訊息內容,如粗體文字。", + "@formattedMessagesDescription": {}, + "verifyOtherDevice": "🔐 驗證其他裝置", + "@verifyOtherDevice": {}, + "youInvitedUser": "📩 您邀請了 {user}", + "@youInvitedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "pinMessage": "釘選到房間", + "@pinMessage": {}, + "youKicked": "👞 您踢出了 {user}", + "@youKicked": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "users": "使用者", + "@users": {}, + "pleaseChoose": "請選擇", + "@pleaseChoose": { + "type": "String", + "placeholders": {} + }, + "youRejectedTheInvitation": "您拒絕了邀請", + "@youRejectedTheInvitation": {}, + "enterRoom": "進入房間", + "@enterRoom": {}, + "allSpaces": "所有空間", + "@allSpaces": {}, + "indexedDbErrorLong": "預設情況下,私密模式不啟用消息存儲。\n請訪問\n - about:config\n - 將 dom.indexedDB.privateBrowsing.enabled 設定為 true\n否則,無法運行 FluffyChat。", + "@indexedDbErrorLong": {}, + "youKickedAndBanned": "🙅 您踢出並封鎖了 {user}", + "@youKickedAndBanned": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "user": "使用者", + "@user": {}, + "custom": "自訂", + "@custom": {}, + "hidePresences": "隱藏狀態列表?", + "@hidePresences": {}, + "signInWithPassword": "使用密碼登入", + "@signInWithPassword": {}, + "setColorTheme": "設定主題顏色:", + "@setColorTheme": {}, + "makeAdminDescription": "一旦您讓這個使用者成為管理員,您可能無法撤銷此操作,因為他們將擁有與您相同的權限。", + "@makeAdminDescription": {}, + "createGroupAndInviteUsers": "建立群組並邀請使用者", + "@createGroupAndInviteUsers": {}, + "groupCanBeFoundViaSearch": "可以透過搜尋找到群組", + "@groupCanBeFoundViaSearch": {}, + "pleaseEnterYourCurrentPassword": "請輸入您當前的密碼", + "@pleaseEnterYourCurrentPassword": {}, + "widgetCustom": "自訂", + "@widgetCustom": {}, + "createGroup": "建立群組", + "@createGroup": {}, + "enterSpace": "進入空間", + "@enterSpace": {}, + "shareLocation": "分享位置", + "@shareLocation": { + "type": "String", + "placeholders": {} + }, + "widgetVideo": "影片", + "@widgetVideo": {}, + "redactMessageDescription": "該訊息將對此對話中的所有參與者收回。這不能被反悔。", + "@redactMessageDescription": {}, + "removeFromBundle": "從此套組中移除", + "@removeFromBundle": {}, + "widgetName": "名稱", + "@widgetName": {}, + "jump": "跳轉", + "@jump": {}, + "commandHint_unignore": "取消無視已提供的 Matrix ID", + "@commandHint_unignore": {}, + "commandHint_markasgroup": "標示為群組", + "@commandHint_markasgroup": {}, + "commandHint_me": "描述自己", + "@commandHint_me": { + "type": "String", + "description": "Usage hint for the command /me" + }, + "commandHint_plain": "傳送未格式化的文字", + "@commandHint_plain": { + "type": "String", + "description": "Usage hint for the command /plain" + }, + "commandHint_react": "以反應的形式傳送回覆", + "@commandHint_react": { + "type": "String", + "description": "Usage hint for the command /react" + }, + "createNewSpace": "新建空間", + "@createNewSpace": { + "type": "String", + "placeholders": {} + }, + "allRooms": "所有群組聊天室", + "@allRooms": { + "type": "String", + "placeholders": {} + }, + "chatPermissions": "聊天室權限", + "@chatPermissions": {}, + "customEmojisAndStickersBody": "新增或分享可在任何聊天室中使用的自訂表情符號或貼圖。", + "@customEmojisAndStickersBody": {}, + "errorObtainingLocation": "取得位置錯誤:{error}", + "@errorObtainingLocation": { + "type": "String", + "placeholders": { + "error": { + "type": "String" + } + } + }, + "hideRedactedMessages": "隱藏被刪除的訊息", + "@hideRedactedMessages": {}, + "hideInvalidOrUnknownMessageFormats": "隱藏無效或未知的訊息格式", + "@hideInvalidOrUnknownMessageFormats": {}, + "dehydrateTorLong": "對 TOR 使用者,建議在關閉窗口前匯出會話。", + "@dehydrateTorLong": {}, + "hydrateTor": "TOR 使用者:匯入會話", + "@hydrateTor": {}, + "messagesStyle": "訊息樣式:", + "@messagesStyle": {}, + "shareInviteLink": "分享邀請網址", + "@shareInviteLink": {}, + "scanQrCode": "掃描 QR 碼", + "@scanQrCode": {}, + "openVideoCamera": "打開錄影", + "@openVideoCamera": { + "type": "String", + "placeholders": {} + }, + "oneClientLoggedOut": "您的一個客戶端已登出", + "@oneClientLoggedOut": {}, + "addAccount": "新增帳號", + "@addAccount": {}, + "editBundlesForAccount": "為此帳號編輯套組", + "@editBundlesForAccount": {}, + "openInMaps": "在地圖中打開", + "@openInMaps": { + "type": "String", + "placeholders": {} + }, + "serverRequiresEmail": "該伺服器需要驗證您的註冊電子郵件地址。", + "@serverRequiresEmail": {}, + "or": "或", + "@or": { + "type": "String", + "placeholders": {} + }, + "hideMemberChangesInPublicChatsBody": "若有人加入或離開公開聊天室,將不在聊天室時間軸顯示,以提升資訊可讀性。", + "@hideMemberChangesInPublicChatsBody": {}, + "overview": "概觀", + "@overview": {}, + "notifyMeFor": "通知我", + "@notifyMeFor": {}, + "passwordRecoverySettings": "恢復密碼設定", + "@passwordRecoverySettings": {}, + "redactedBy": "由 {username} 編輯", + "@redactedBy": { + "type": "String", + "placeholders": { + "username": { + "type": "String" + } + } + }, + "recoveryKey": "恢復金鑰", + "@recoveryKey": {}, + "spaceName": "空間名稱", + "@spaceName": { + "type": "String", + "placeholders": {} + }, + "synchronizingPleaseWait": "正在同步... 請稍候。", + "@synchronizingPleaseWait": { + "type": "String", + "placeholders": {} + }, + "messageInfo": "訊息資訊", + "@messageInfo": {}, + "removeFromSpace": "從空間中移除", + "@removeFromSpace": {}, + "addToSpaceDescription": "選擇一個空間將此聊天室加入。", + "@addToSpaceDescription": {}, + "pleaseEnterRecoveryKeyDescription": "要解鎖您的舊訊息,請輸入在之前的會話中生成的恢復密鑰。您的恢復密鑰不是您的密碼。", + "@pleaseEnterRecoveryKeyDescription": {}, + "videoWithSize": "影片({size})", + "@videoWithSize": { + "type": "String", + "placeholders": { + "size": { + "type": "String" + } + } + }, + "emojis": "表情符號", + "@emojis": {}, + "placeCall": "發起通話", + "@placeCall": {}, + "unsupportedAndroidVersion": "不支持的Android版本", + "@unsupportedAndroidVersion": {}, + "videoCallsBetaWarning": "請注意,視訊通話目前處於測試階段。它們可能不會按預期工作,或者在所有平台上都不工作。", + "@videoCallsBetaWarning": {}, + "widgetUrlError": "這不是一個有效的URL。", + "@widgetUrlError": {}, + "nextAccount": "下一個帳戶", + "@nextAccount": {}, + "previousAccount": "上一個帳戶", + "@previousAccount": {}, + "addWidget": "新增小工具", + "@addWidget": {}, + "errorAddingWidget": "新增小工具時發生錯誤。", + "@errorAddingWidget": {}, + "youJoinedTheChat": "您加入了聊天室", + "@youJoinedTheChat": {}, + "youBannedUser": "您封鎖了 {user}", + "@youBannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youHaveWithdrawnTheInvitationFor": "您已收回對 {user} 的邀請", + "@youHaveWithdrawnTheInvitationFor": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedBy": "📩 您被 {user} 邀請", + "@youInvitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youUnbannedUser": "您解除封鎖了 {user}", + "@youUnbannedUser": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "youInvitedToBy": "📩 您通過網址被邀請至:\n{alias}", + "@youInvitedToBy": { + "placeholders": { + "alias": { + "type": "String" + } + } + }, + "callingPermissions": "通話權限", + "@callingPermissions": {}, + "callingAccount": "通話帳戶", + "@callingAccount": {}, + "appearOnTop": "顯示在最上層", + "@appearOnTop": {}, + "newGroup": "新群組", + "@newGroup": {}, + "newSpace": "新空間", + "@newSpace": {}, + "numChats": "{number} 個聊天室", + "@numChats": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "hideUnimportantStateEvents": "隱藏不重要的狀態事件", + "@hideUnimportantStateEvents": {}, + "doNotShowAgain": "不再顯示", + "@doNotShowAgain": {}, + "encryptThisChat": "加密此聊天室", + "@encryptThisChat": {}, + "sorryThatsNotPossible": "抱歉......這是不可能的", + "@sorryThatsNotPossible": {}, + "profileNotFound": "在伺服器上找不到該使用者。可能是連接問題或該使用者不存在。", + "@profileNotFound": {}, + "invite": "邀請", + "@invite": {}, + "invitePrivateChat": "📨 邀請私人聊天室", + "@invitePrivateChat": {}, + "removeDevicesDescription": "您將從這個裝置登出,並將不再能夠接收消息。", + "@removeDevicesDescription": {}, + "unbanUserDescription": "如果該使用者嘗試,他們將能夠再次進入聊天室。", + "@unbanUserDescription": {}, + "kickUserDescription": "該使用者被踢出聊天室,但未被禁止。在公開聊天室中,該使用者可以隨時重新加入。", + "@kickUserDescription": {}, + "pushNotificationsNotAvailable": "推送通知不可用", + "@pushNotificationsNotAvailable": {}, + "learnMore": "了解更多", + "@learnMore": {}, + "nothingFound": "什麼都沒找到......", + "@nothingFound": {}, + "startConversation": "開始對話", + "@startConversation": {}, + "databaseMigrationBody": "請稍候。這可能需要一點時間。", + "@databaseMigrationBody": {}, + "pleaseChooseAStrongPassword": "請選擇一個強密碼", + "@pleaseChooseAStrongPassword": {}, + "passwordIsWrong": "您輸入的密碼錯誤", + "@passwordIsWrong": {}, + "publicChatAddresses": "公開聊天室地址", + "@publicChatAddresses": {}, + "userRole": "使用者角色", + "@userRole": {}, + "minimumPowerLevel": "{level} 是最低權限等級。", + "@minimumPowerLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "String" + } + } + }, + "leaveEmptyToClearStatus": "留空以清除您的狀態。", + "@leaveEmptyToClearStatus": {}, + "select": "選擇", + "@select": {}, + "files": "文件", + "@files": {}, + "forwardMessageTo": "將訊息轉發至 {roomName}?", + "@forwardMessageTo": { + "type": "String", + "placeholders": { + "roomName": { + "type": "String" + } + } + }, + "sendTypingNotificationsDescription": "聊天室中的其他參與者可以看到您正在輸入新訊息。", + "@sendTypingNotificationsDescription": {}, + "verifyOtherDeviceDescription": "當您驗證另一個裝置時,這些裝置可以交換密鑰,提升您的整體安全性。💪 當您開始驗證時,一個彈出視窗將在兩個裝置上的應用程式中出現。在那裡,您將看到一系列的表情符號或數字,您需要相互比較。在開始驗證之前最好有兩個裝置在手邊。🤳", + "@verifyOtherDeviceDescription": {}, + "acceptedKeyVerification": "{sender} 接受了密鑰驗證", + "@acceptedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "completedKeyVerification": "{sender} 完成了密鑰驗證", + "@completedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "isReadyForKeyVerification": "{sender} 已準備好進行密鑰驗證", + "@isReadyForKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "thereAreCountUsersBlocked": "目前有 {count} 名使用者被封鎖。", + "@thereAreCountUsersBlocked": { + "type": "String", + "count": {} + }, + "knockRestricted": "敲門受限", + "@knockRestricted": {}, + "appLockDescription": "未使用時以密碼鎖定應用程式", + "@appLockDescription": {}, + "globalChatId": "全球聊天室 ID", + "@globalChatId": {}, + "accessAndVisibility": "訪問權限和可見性", + "@accessAndVisibility": {}, + "accessAndVisibilityDescription": "誰被允許加入此聊天室以及如何發現聊天室。", + "@accessAndVisibilityDescription": {}, + "calls": "通話", + "@calls": {}, + "chatDescription": "聊天室描述", + "@chatDescription": {}, + "chatDescriptionHasBeenChanged": "聊天室描述已變更", + "@chatDescriptionHasBeenChanged": {}, + "tryAgain": "再試一次", + "@tryAgain": {}, + "pleaseEnterRecoveryKey": "請輸入您的恢復金鑰:", + "@pleaseEnterRecoveryKey": {}, + "directChat": "私訊", + "@directChat": {}, + "register": "註冊", + "@register": { + "type": "String", + "placeholders": {} + }, + "setAsCanonicalAlias": "設為主要別名", + "@setAsCanonicalAlias": { + "type": "String", + "placeholders": {} + }, + "setChatDescription": "設定聊天室描述", + "@setChatDescription": {}, + "groupName": "群組名稱", + "@groupName": {}, + "searchForUsers": "搜尋 @users...", + "@searchForUsers": {}, + "inviteGroupChat": "📨 邀請群組聊天室", + "@inviteGroupChat": {}, + "setTheme": "設定主題:", + "@setTheme": {}, + "knocking": "敲門", + "@knocking": {}, + "sessionLostBody": "您的會話已丟失。請將此錯誤報告給開發人員,網址為 {url}。錯誤訊息為:{error}", + "@sessionLostBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "swipeRightToLeftToReply": "向右滑至左以回覆", + "@swipeRightToLeftToReply": {}, + "hideRedactedMessagesBody": "如果有人收回一條訊息,該訊息將不再在聊天室中顯示。", + "@hideRedactedMessagesBody": {}, + "link": "網址", + "@link": {}, + "obtainingLocation": "正在取得位置…", + "@obtainingLocation": { + "type": "String", + "placeholders": {} + }, + "oopsPushError": "哎呀!設定推送通知時不幸發生錯誤。", + "@oopsPushError": { + "type": "String", + "placeholders": {} + }, + "removeYourAvatar": "移除您的頭像", + "@removeYourAvatar": { + "type": "String", + "placeholders": {} + }, + "singlesignon": "單一登入", + "@singlesignon": { + "type": "String", + "placeholders": {} + }, + "presenceStyle": "目前狀態:", + "@presenceStyle": { + "type": "String", + "placeholders": {} + }, + "presencesToggle": "顯示其他使用者的狀態訊息", + "@presencesToggle": { + "type": "String", + "placeholders": {} + }, + "spaceIsPublic": "空間是公開的", + "@spaceIsPublic": { + "type": "String", + "placeholders": {} + }, + "dismiss": "解散", + "@dismiss": {}, + "reactedWith": "{sender} 以 {reaction} 回應", + "@reactedWith": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + }, + "reaction": { + "type": "String" + } + } + }, + "confirmEventUnpin": "您確定要永久取消釘選該事件嗎?", + "@confirmEventUnpin": {}, + "switchToAccount": "切換到帳戶 {number}", + "@switchToAccount": { + "type": "number", + "placeholders": { + "number": { + "type": "String" + } + } + }, + "widgetEtherpad": "文字筆記", + "@widgetEtherpad": {}, + "noOneCanJoin": "沒有人可以加入", + "@noOneCanJoin": {}, + "userWouldLikeToChangeTheChat": "{user} 想要加入聊天室。", + "@userWouldLikeToChangeTheChat": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "noPublicLinkHasBeenCreatedYet": "尚未建立公開網址", + "@noPublicLinkHasBeenCreatedYet": {}, + "saveKeyManuallyDescription": "通過觸發系統分享對話框或剪貼板手動保存此密鑰。", + "@saveKeyManuallyDescription": {}, + "storeInAndroidKeystore": "存儲在 Android KeyStore", + "@storeInAndroidKeystore": {}, + "storeInAppleKeyChain": "存儲在 Apple KeyChain", + "@storeInAppleKeyChain": {}, + "foregroundServiceRunning": "當前景服務正在運行時會顯示此通知。", + "@foregroundServiceRunning": {}, + "screenSharingTitle": "螢幕分享", + "@screenSharingTitle": {}, + "wasDirectChatDisplayName": "空的聊天室(原名稱為 {oldDisplayName} )", + "@wasDirectChatDisplayName": { + "type": "String", + "placeholders": { + "oldDisplayName": { + "type": "String" + } + } + }, + "otherCallingPermissions": "麥克風、相機和其他 FluffyChat 權限", + "@otherCallingPermissions": {}, + "disableEncryptionWarning": "出於安全原因,您不能在之前已加密的聊天室中停用加密。", + "@disableEncryptionWarning": {}, + "deviceKeys": "裝置密鑰:", + "@deviceKeys": {}, + "fileIsTooBigForServer": "無法發送!該伺服器僅支援最大到 {max} 的附件。", + "@fileIsTooBigForServer": {}, + "fileHasBeenSavedAt": "文件已保存在 {path}", + "@fileHasBeenSavedAt": { + "type": "String", + "placeholders": { + "path": { + "type": "String" + } + } + }, + "jumpToLastReadMessage": "跳至最後讀取的訊息", + "@jumpToLastReadMessage": {}, + "openLinkInBrowser": "在瀏覽器中開啟連結", + "@openLinkInBrowser": {}, + "reportErrorDescription": "😭 哦不。出了些問題。如果您願意,可以將此錯誤報告給開發者。", + "@reportErrorDescription": {}, + "readUpToHere": "讀到這裡", + "@readUpToHere": {}, + "report": "報告", + "@report": {}, + "pleaseEnterANumber": "請輸入大於 0 的數字", + "@pleaseEnterANumber": {}, + "roomUpgradeDescription": "將使用新版本聊天室來重新建立聊天室。所有本聊天室的參與者都會收到通知,他們都需要換到新的聊天室裡。若您想知道有關新版本的更多資訊,請前往 https://spec.matrix.org/latest/rooms/", + "@roomUpgradeDescription": {}, + "wrongRecoveryKey": "抱歉......這似乎不是正確的恢復密鑰。", + "@wrongRecoveryKey": {}, + "passwordsDoNotMatch": "密碼不匹配", + "@passwordsDoNotMatch": {}, + "publicSpaces": "公共空間", + "@publicSpaces": {}, + "subspace": "子空間", + "@subspace": {}, + "initAppError": "初始化應用時發生錯誤", + "@initAppError": {}, + "canceledKeyVerification": "{sender} 取消了密鑰驗證", + "@canceledKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "startedKeyVerification": "{sender} 開始了密鑰驗證", + "@startedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "transparent": "透明", + "@transparent": {}, + "incomingMessages": "收到的訊息", + "@incomingMessages": {}, + "databaseMigrationTitle": "資料庫已最佳化", + "@databaseMigrationTitle": {}, + "restoreSessionBody": "應用程式現在嘗試從備份中恢復您的會話。請將此錯誤報告給開發人員,網址為 {url}。錯誤訊息為:{error}", + "@restoreSessionBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "stickers": "貼圖", + "@stickers": {}, + "joinSpace": "加入空間", + "@joinSpace": {}, + "noMoreChatsFound": "沒有更多聊天室了...", + "@noMoreChatsFound": {}, + "commandHint_op": "設定給定使用者的權限等級(預設:50)", + "@commandHint_op": { + "type": "String", + "description": "Usage hint for the command /op" + }, + "customEmojisAndStickers": "自訂表情符號和貼圖", + "@customEmojisAndStickers": {}, + "locationPermissionDeniedNotice": "位置權限被拒絕。請授予它們以能夠分享您的位置。", + "@locationPermissionDeniedNotice": { + "type": "String", + "placeholders": {} + }, + "inviteContactToGroupQuestion": "您想邀請 {contact} 加入 「{groupName}」 聊天室嗎?", + "@inviteContactToGroupQuestion": {}, + "enableMultiAccounts": "(實驗性功能)在此裝置上啟用多個帳號", + "@enableMultiAccounts": {}, + "hideMemberChangesInPublicChats": "在公開聊天室中隱藏成員變動", + "@hideMemberChangesInPublicChats": {}, + "recoveryKeyLost": "遺失恢復金鑰?", + "@recoveryKeyLost": {}, + "sendAsText": "以文字傳送", + "@sendAsText": { + "type": "String" + }, + "sendSticker": "傳送貼圖", + "@sendSticker": { + "type": "String", + "placeholders": {} + }, + "unverified": "尚未驗證", + "@unverified": {}, + "time": "時間", + "@time": {}, + "chatCanBeDiscoveredViaSearchOnServer": "可以透過在 {server} 上的搜尋發現聊天室", + "@chatCanBeDiscoveredViaSearchOnServer": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "commandHint_sendraw": "傳送原始 json", + "@commandHint_sendraw": {}, + "newPassword": "新密碼", + "@newPassword": {}, + "createNewAddress": "建立新地址", + "@createNewAddress": {}, + "searchIn": "在聊天室「{chat}」中搜尋......", + "@searchIn": { + "type": "String", + "placeholders": { + "chat": { + "type": "String" + } + } + }, + "searchMore": "搜尋更多......", + "@searchMore": {}, + "gallery": "畫廊", + "@gallery": {}, + "databaseBuildErrorBody": "無法建立 SQLite 資料庫。應用程式目前嘗試使用遺留資料庫。請將此錯誤報告給開發人員,網址為 {url}。錯誤訊息為:{error}", + "@databaseBuildErrorBody": { + "type": "String", + "placeholders": { + "url": { + "type": "String" + }, + "error": { + "type": "String" + } + } + }, + "sendReadReceiptsDescription": "聊天室中的其他參與者可以看到您已讀取一條訊息。", + "@sendReadReceiptsDescription": {}, + "formattedMessages": "格式化訊息", + "@formattedMessages": {}, + "restricted": "受限", + "@restricted": {}, + "goToSpace": "前往空間:{space}", + "@goToSpace": { + "type": "String", + "space": {} + }, + "markAsUnread": "標示為未讀", + "@markAsUnread": {}, + "noDatabaseEncryption": "此平台不支援資料庫加密", + "@noDatabaseEncryption": {}, + "messageType": "訊息類型", + "@messageType": {}, + "openGallery": "開啟畫廊", + "@openGallery": {}, + "markAsRead": "標示為已讀", + "@markAsRead": {}, + "reportUser": "舉報使用者", + "@reportUser": {}, + "unsupportedAndroidVersionLong": "此功能需要較新的 Android 版本。請檢查更新或 Lineage OS 支持。", + "@unsupportedAndroidVersionLong": {}, + "emailOrUsername": "電子郵件或使用者名", + "@emailOrUsername": {}, + "indexedDbErrorTitle": "私密模式問題", + "@indexedDbErrorTitle": {}, + "widgetJitsi": "Jitsi Meet", + "@widgetJitsi": {}, + "usersMustKnock": "使用者必須敲門", + "@usersMustKnock": {}, + "knock": "敲門", + "@knock": {}, + "storeInSecureStorageDescription": "將恢復密鑰存儲在此裝置的安全存儲中。", + "@storeInSecureStorageDescription": {}, + "appearOnTopDetails": "允許應用程式顯示在最上層(如果您已將 Fluffychat 設定為通話帳戶則不需要)", + "@appearOnTopDetails": {}, + "whyIsThisMessageEncrypted": "為什麼這條訊息無法讀取?", + "@whyIsThisMessageEncrypted": {}, + "noKeyForThisMessage": "如果訊息是在您登入此裝置之前傳送的,就可能會發生這種情況。\n\n也有可能是傳送者已經封鎖了您的裝置,或者網絡連接出了問題。\n\n如果您能在另一個會話中讀取該訊息,那麼您可以從中轉移訊息!前往設定 > 裝置,並確保您的裝置已相互驗證。當您下次打開房間且兩個會話都在前景時,密鑰將自動傳輸。\n\n不想在登出或切換裝置時丟失密鑰?請確保您已在設定中啟用了聊天室備份。", + "@noKeyForThisMessage": {}, + "newSpaceDescription": "空間允許您整合您的聊天室並建立私人或公開社群。", + "@newSpaceDescription": {}, + "pleaseTryAgainLaterOrChooseDifferentServer": "請稍後再試,或選擇不同的伺服器。", + "@pleaseTryAgainLaterOrChooseDifferentServer": {}, + "signInWith": "使用 {provider} 登入", + "@signInWith": { + "type": "String", + "placeholders": { + "provider": { + "type": "String" + } + } + }, + "invalidInput": "無效的輸入!", + "@invalidInput": {}, + "verifyOtherUser": "🔐 驗證其他使用者", + "@verifyOtherUser": {}, + "verifyOtherUserDescription": "如果您驗證了另一個使用者,您可以確定您真正與誰通信。💪\n\n當您開始驗證時,您和另一個使用者將在應用程式中看到一個彈出視窗。在那裡,您將看到一系列的表情符號或數字,您需要相互比較。\n\n最好的方式是見面或開始視訊通話。👭", + "@verifyOtherUserDescription": {}, + "requestedKeyVerification": "{sender} 請求了密鑰驗證", + "@requestedKeyVerification": { + "type": "String", + "placeholders": { + "sender": { + "type": "String" + } + } + }, + "commandHint_ignore": "無視已提供的 Matrix ID", + "@commandHint_ignore": {}, + "countChatsAndCountParticipants": "{chats} 個聊天室和 {participants} 位參與者", + "@countChatsAndCountParticipants": { + "type": "String", + "placeholders": { + "chats": { + "type": "int" + }, + "participants": { + "type": "int" + } + } + }, + "joinedChats": "已加入的聊天室", + "@joinedChats": {}, + "unread": "未讀", + "@unread": {}, + "space": "空間", + "@space": {}, + "spaces": "空間", + "@spaces": {}, + "start": "開始", + "@start": {}, + "openChat": "開啟聊天室", + "@openChat": {}, + "unreadChatsInApp": "{appname}:{unread} 未讀聊天室", + "@unreadChatsInApp": { + "type": "String", + "placeholders": { + "appname": { + "type": "String" + }, + "unread": { + "type": "String" + } + } + }, + "adminLevel": "{level} - 管理員", + "@adminLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "userLevel": "{level} - 用戶", + "@userLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "moderatorLevel": "{level} - 管理員", + "@moderatorLevel": { + "type": "String", + "placeholders": { + "level": { + "type": "int" + } + } + }, + "invitedBy": "📩 由 {user} 邀請", + "@invitedBy": { + "placeholders": { + "user": { + "type": "String" + } + } + }, + "doesNotSeemToBeAValidHomeserver": "似乎不是能匹配的歸屬伺服器。伺服器域名打錯了嗎?", + "@doesNotSeemToBeAValidHomeserver": {}, + "noticeChatBackupDeviceVerification": "注意:當您將所有裝置連線到聊天備份時,它們會自動驗證。", + "@noticeChatBackupDeviceVerification": {}, + "sendCanceled": "傳送取消", + "@sendCanceled": {}, + "changelog": "變更日誌", + "@changelog": {}, + "changeTheCanonicalRoomAlias": "變更公開聊天室的主要地址", + "@changeTheCanonicalRoomAlias": {}, + "sendImages": "傳送{count}張圖片", + "@sendImages": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + }, + "loginWithMatrixId": "以Matrix-ID登入", + "@loginWithMatrixId": {}, + "inviteOtherUsers": "邀請其他用戶進入本聊天", + "@inviteOtherUsers": {}, + "sendRoomNotifications": "傳送一條 @room 群提醒", + "@sendRoomNotifications": {}, + "updateInstalled": "🎉已成功安裝{version}版本!", + "@updateInstalled": { + "type": "String", + "placeholders": { + "version": { + "type": "String" + } + } + }, + "oneOfYourDevicesIsNotVerified": "你的其中一個裝置尚未驗證", + "@oneOfYourDevicesIsNotVerified": {}, + "chatPermissionsDescription": "定義此聊天中某些操作需要哪個權限等級。 權限等級0、50和100通常代表使用者、版主和管理員,但任何分級都是可能的。", + "@chatPermissionsDescription": {}, + "changeGeneralChatSettings": "變更一般聊天設定", + "@changeGeneralChatSettings": {}, + "manageAccount": "帳號管理", + "@manageAccount": {}, + "changeTheChatPermissions": "變更聊天室權限", + "@changeTheChatPermissions": {}, + "changeTheVisibilityOfChatHistory": "變更過往聊天記錄可見度", + "@changeTheVisibilityOfChatHistory": {}, + "homeserverDescription": "您的所有資料都儲存在歸屬伺服器上,就像電子郵件提供商一樣。 您可以選擇要使用的歸屬伺服器,同時您仍然可以與每個人溝通。 請訪問https://matrix.org瞭解更多資訊。", + "@homeserverDescription": {}, + "sendingAttachment": "附件傳送中…", + "@sendingAttachment": {}, + "compressVideo": "影片壓縮中…", + "@compressVideo": {}, + "opacity": "不透明度:", + "@opacity": {}, + "aboutHomeserver": "關於{homeserver}", + "@aboutHomeserver": { + "type": "String", + "placeholders": { + "homeserver": { + "type": "String" + } + } + }, + "noChatsFoundHere": "還沒開始聊天嗎?點擊下方按鈕找個人聊聊吧⤵", + "@noChatsFoundHere": {}, + "changeTheDescriptionOfTheGroup": "變更聊天室說明", + "@changeTheDescriptionOfTheGroup": {}, + "discoverHomeservers": "探索歸屬伺服器", + "@discoverHomeservers": {}, + "whatIsAHomeserver": "什麼是歸屬伺服器?", + "@whatIsAHomeserver": {}, + "calculatingFileSize": "正在計算檔案大小…", + "@calculatingFileSize": {}, + "prepareSendingAttachment": "準備傳送附件…", + "@prepareSendingAttachment": {}, + "generatingVideoThumbnail": "生成影片縮圖中…", + "@generatingVideoThumbnail": {}, + "sendingAttachmentCountOfCount": "附件傳送中 {index}/{length}…", + "@sendingAttachmentCountOfCount": { + "type": "integer", + "placeholders": { + "index": { + "type": "int" + }, + "length": { + "type": "int" + } + } + }, + "serverLimitReached": "已達伺服器上限! 請稍等{seconds}秒…", + "@serverLimitReached": { + "type": "integer", + "placeholders": { + "seconds": { + "type": "int" + } + } + }, + "welcomeText": "嘿,嘿👋這是FluffyChat。 您可以登入任何與https://matrix.org相容的歸屬伺服器後和任何人聊天。 這是一個巨大的去中心化訊息網路!", + "@welcomeText": {}, + "setWallpaper": "設定背景樣式", + "@setWallpaper": {}, + "noContactInformationProvided": "伺服器沒有提供任何有效的聯絡資訊", + "@noContactInformationProvided": {}, + "contactServerAdmin": "聯繫伺服器管理員", + "@contactServerAdmin": {}, + "contactServerSecurity": "聯繫伺服器安管", + "@contactServerSecurity": {}, + "continueText": "繼續", + "@continueText": {}, + "blur": "模糊:", + "@blur": {}, + "synchronizingPleaseWaitCounter": " 同步中… ({percentage}%)", + "@synchronizingPleaseWaitCounter": { + "type": "String", + "placeholders": { + "percentage": { + "type": "String" + } + } + }, + "contentNotificationSettings": "內容通知設定", + "@contentNotificationSettings": {}, + "generalNotificationSettings": "常規通知設定", + "@generalNotificationSettings": {}, + "roomNotificationSettings": "聊天室通知設定", + "@roomNotificationSettings": {}, + "userSpecificNotificationSettings": "用戶特定通知設定", + "@userSpecificNotificationSettings": {}, + "otherNotificationSettings": "其他通知設定", + "@otherNotificationSettings": {}, + "notificationRuleContainsUserName": "包含用户名稱", + "@notificationRuleContainsUserName": {}, + "notificationRuleContainsUserNameDescription": "當訊息帶有用户名稱時通知用戶。", + "@notificationRuleContainsUserNameDescription": {}, + "notificationRuleMaster": "靜音所有通知", + "@notificationRuleMaster": {}, + "notificationRuleMasterDescription": "覆蓋所有其他規則並禁止所有通知。", + "@notificationRuleMasterDescription": {}, + "notificationRuleInviteForMe": "邀請我", + "@notificationRuleInviteForMe": {}, + "notificationRuleSuppressNoticesDescription": "隱藏來自bot等的自動化消息。", + "@notificationRuleSuppressNoticesDescription": {}, + "notificationRuleSuppressNotices": "隱藏自動化消息", + "@notificationRuleSuppressNotices": {}, + "notificationRuleMemberEvent": "成員事件", + "@notificationRuleMemberEvent": {}, + "notificationRuleMemberEventDescription": "隱藏成員事件的通知。", + "@notificationRuleMemberEventDescription": {}, + "notificationRuleIsUserMention": "用户提及", + "@notificationRuleIsUserMention": {}, + "notificationRuleInviteForMeDescription": "當用户被邀請到聊天室時,通知他們。", + "@notificationRuleInviteForMeDescription": {}, + "commandHint_roomupgrade": "升級此聊天室至指定版本", + "@commandHint_roomupgrade": {}, + "serverInformation": "伺服器資訊 :", + "@serverInformation": {}, + "name": "名稱", + "@name": {}, + "website": "網站", + "@website": {}, + "compress": "壓縮", + "@compress": {}, + "newChatRequest": "📩 新的聊天邀請", + "@newChatRequest": {}, + "enterNewChat": "進入新聊天室", + "@enterNewChat": {}, + "version": "版本", + "@version": {}, + "unableToJoinChat": "無法加入聊天室。對話可能以被其他方結束。", + "@unableToJoinChat": {}, + "appWantsToUseForLogin": "使用「{server} 」伺服器登入", + "@appWantsToUseForLogin": { + "type": "String", + "placeholders": { + "server": { + "type": "String" + } + } + }, + "italicText": "斜體", + "@italicText": {}, + "boldText": "粗體", + "@boldText": {}, + "strikeThrough": "刪除線", + "@strikeThrough": {}, + "pleaseFillOut": "請填充", + "@pleaseFillOut": {}, + "invalidUrl": "無效 url", + "@invalidUrl": {}, + "appWantsToUseForLoginDescription": "你特此允許該應用程式和網站分享關於你的信息。", + "@appWantsToUseForLoginDescription": {}, + "open": "打開", + "@open": {}, + "waitingForServer": "等待伺服器中...", + "@waitingForServer": {}, + "appIntroduction": "FluffyChat 讓你和你的朋友跨越工具聊天。在 https://matrix.org 了解更多或*繼續*。", + "@appIntroduction": {}, + "previous": "上一個", + "@previous": {}, + "otherPartyNotLoggedIn": "對方現未登入,未能接收訊息 !", + "@otherPartyNotLoggedIn": {}, + "supportPage": "幫助頁面", + "@supportPage": {}, + "addLink": "插入連結", + "@addLink": {}, + "notificationRuleContainsDisplayName": "包含顯示名稱", + "@notificationRuleContainsDisplayName": {}, + "notificationRuleRoomnotif": "聊天室通知", + "@notificationRuleRoomnotif": {}, + "notificationRuleIsRoomMentionDescription": "當有聊天室提及時通知用户。", + "@notificationRuleIsRoomMentionDescription": {}, + "notificationRuleRoomOneToOneDescription": "在一對一聊天室中通知用户收到訊息。", + "@notificationRuleRoomOneToOneDescription": {}, + "notificationRuleServerAcl": "隱藏伺服器 ACL 事件", + "@notificationRuleServerAcl": {}, + "notificationRuleContainsDisplayNameDescription": "當訊息包含用户的顯示名稱時通知用户。", + "@notificationRuleContainsDisplayNameDescription": {}, + "notificationRuleIsRoomMention": "聊天室提及", + "@notificationRuleIsRoomMention": {}, + "notificationRuleRoomnotifDescription": "當訊息包含 \"@room\" 時通知用户。", + "@notificationRuleRoomnotifDescription": {}, + "notificationRuleTombstone": "墓碑", + "@notificationRuleTombstone": {}, + "notificationRuleCallDescription": "通知用户有來電。", + "@notificationRuleCallDescription": {}, + "notificationRuleEncryptedRoomOneToOne": "一對一加密聊天室", + "@notificationRuleEncryptedRoomOneToOne": {}, + "notificationRuleEncryptedRoomOneToOneDescription": "通知用户一對一加密聊天室的訊息。", + "@notificationRuleEncryptedRoomOneToOneDescription": {}, + "notificationRuleRoomOneToOne": "一對一聊天室", + "@notificationRuleRoomOneToOne": {}, + "notificationRuleMessage": "訊息", + "@notificationRuleMessage": {}, + "notificationRuleServerAclDescription": "隱藏伺服器 ACL 事件的通知。", + "@notificationRuleServerAclDescription": {}, + "notificationRuleMessageDescription": "通知用户一般訊息。", + "@notificationRuleMessageDescription": {}, + "notificationRuleEncrypted": "已加密", + "@notificationRuleEncrypted": {}, + "notificationRuleEncryptedDescription": "在已加密房間內通知用户訊息。", + "@notificationRuleEncryptedDescription": {}, + "notificationRuleJitsi": "Jitsi", + "@notificationRuleJitsi": {}, + "notificationRuleJitsiDescription": "通知用户 Jitsi 小部件事件。", + "@notificationRuleJitsiDescription": {}, + "unknownPushRule": "未知推送規則 '{rule}'", + "@unknownPushRule": { + "type": "String", + "placeholders": { + "rule": { + "type": "String" + } + } + }, + "more": "更多", + "@more": {}, + "deletePushRuleCanNotBeUndone": "刪除此通知設定的操作無法復原。", + "@deletePushRuleCanNotBeUndone": {}, + "shareKeysWith": "與哪些設備共享金鑰…", + "@shareKeysWith": {}, + "shareKeysWithDescription": "選擇應該信任的裝置,並允許它們在加密聊天中讀取您的訊息?", + "@shareKeysWithDescription": {}, + "allDevices": "所有裝置", + "@allDevices": {}, + "crossVerifiedDevices": "經交叉驗證的裝置", + "@crossVerifiedDevices": {}, + "crossVerifiedDevicesIfEnabled": "交叉驗證裝置(如啟用)", + "@crossVerifiedDevicesIfEnabled": {}, + "setCustomPermissionLevel": "設置自定義權限等級", + "@setCustomPermissionLevel": {}, + "setPermissionsLevelDescription": "請在下方選擇預先定義的角色,或輸入在 0 到 100 之間的自訂權限等級。", + "@setPermissionsLevelDescription": {}, + "recordAVideo": "錄製影像", + "@recordAVideo": {}, + "takeAPhoto": "拍攝照片", + "@takeAPhoto": {}, + "optionalMessage": "(可選)訊息...", + "@optionalMessage": {}, + "notSupportedOnThisDevice": "此裝置不受支援", + "@notSupportedOnThisDevice": {}, + "ignoreUser": "忽略用户", + "@ignoreUser": {}, + "normalUser": "正常用户", + "@normalUser": {}, + "notificationRuleTombstoneDescription": "通知用户有關房間解散的訊息。", + "@notificationRuleTombstoneDescription": {}, + "notificationRuleReaction": "心情回應", + "@notificationRuleReaction": {}, + "notificationRuleReactionDescription": "關閉心情回應通知。", + "@notificationRuleReactionDescription": {}, + "notificationRuleRoomServerAcl": "聊天室伺服器 ACL", + "@notificationRuleRoomServerAcl": {}, + "notificationRuleRoomServerAclDescription": "關閉聊天室伺服器存取控制清單 (ACL) 的通知。", + "@notificationRuleRoomServerAclDescription": {}, + "notificationRuleSuppressEdits": "隱藏編輯", + "@notificationRuleSuppressEdits": {}, + "notificationRuleSuppressEditsDescription": "隱藏已編輯訊息通知。", + "@notificationRuleSuppressEditsDescription": {}, + "notificationRuleCall": "來電", + "@notificationRuleCall": {}, + "verifiedDevicesOnly": "僅限已驗證的裝置", + "@verifiedDevicesOnly": {}, + "approve": "核准", + "@approve": {}, + "youHaveKnocked": "您已請求加入", + "@youHaveKnocked": {}, + "pleaseWaitUntilInvited": "直到聊天室裡有人邀請您前,請等候。", + "@pleaseWaitUntilInvited": {}, + "notificationRuleIsUserMentionDescription": "被@時通知他們。", + "@notificationRuleIsUserMentionDescription": {}, + "countInvited": "已邀請{count}位", + "@countInvited": { + "type": "String", + "placeholders": { + "count": { + "type": "int" + } + } + } +} diff --git a/lib/main.dart b/lib/main.dart index d9ac10b4c..12bd01e1e 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -1,28 +1,57 @@ +import 'dart:isolate'; +import 'dart:ui'; + +import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; +import 'package:flutter/semantics.dart'; import 'package:collection/collection.dart'; import 'package:flutter_secure_storage/flutter_secure_storage.dart'; +import 'package:flutter_vodozemac/flutter_vodozemac.dart' as vod; import 'package:matrix/matrix.dart'; import 'package:shared_preferences/shared_preferences.dart'; +import 'package:universal_html/universal_html.dart' as web; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/utils/client_manager.dart'; +import 'package:fluffychat/utils/notification_background_handler.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/widgets/error_widget.dart'; import 'config/setting_keys.dart'; import 'utils/background_push.dart'; import 'widgets/fluffy_chat_app.dart'; +ReceivePort? mainIsolateReceivePort; + void main() async { - Logs().i('Welcome to ${AppConfig.applicationName} <3'); + if (PlatformInfos.isAndroid) { + final port = mainIsolateReceivePort = ReceivePort(); + IsolateNameServer.removePortNameMapping(AppConfig.mainIsolatePortName); + IsolateNameServer.registerPortWithName( + port.sendPort, + AppConfig.mainIsolatePortName, + ); + await waitForPushIsolateDone(); + } + + // Sanitize hash for OIDC: + if (kIsWeb) { + final hash = web.window.location.hash; + if (hash.isNotEmpty && !hash.startsWith('/')) { + web.window.location.hash = hash.replaceFirst('#', '#?'); + } + } // Our background push shared isolate accesses flutter-internal things very early in the startup proccess // To make sure that the parts of flutter needed are started up already, we need to ensure that the // widget bindings are initialized already. WidgetsFlutterBinding.ensureInitialized(); + final store = await AppSettings.init(); + Logs().i('Welcome to ${AppSettings.applicationName.value} <3'); + + await vod.init(wasmPath: './assets/assets/vodozemac/'); + Logs().nativeColors = !PlatformInfos.isIOS; - final store = await SharedPreferences.getInstance(); final clients = await ClientManager.getClients(store: store); // If the app starts in detached mode, we assume that it is in @@ -42,14 +71,14 @@ void main() async { // To start the flutter engine afterwards we add an custom observer. WidgetsBinding.instance.addObserver(AppStarter(clients, store)); Logs().i( - '${AppConfig.applicationName} started in background-fetch mode. No GUI will be created unless the app is no longer detached.', + '${AppSettings.applicationName.value} started in background-fetch mode. No GUI will be created unless the app is no longer detached.', ); return; } // Started in foreground mode. Logs().i( - '${AppConfig.applicationName} started in foreground mode. Rendering GUI...', + '${AppSettings.applicationName.value} started in foreground mode. Rendering GUI...', ); await startGui(clients, store); } @@ -60,8 +89,9 @@ Future startGui(List clients, SharedPreferences store) async { String? pin; if (PlatformInfos.isMobile) { try { - pin = - await const FlutterSecureStorage().read(key: SettingKeys.appLockKey); + pin = await const FlutterSecureStorage().read( + key: 'chat.fluffy.app_lock', + ); } catch (e, s) { Logs().d('Unable to read PIN from Secure storage', e, s); } @@ -72,8 +102,10 @@ Future startGui(List clients, SharedPreferences store) async { await firstClient?.roomsLoading; await firstClient?.accountDataLoading; - ErrorWidget.builder = (details) => FluffyChatErrorWidget(details); runApp(FluffyChatApp(clients: clients, pincode: pin, store: store)); + if (const String.fromEnvironment('WITH_SEMANTICS') == 'true') { + SemanticsBinding.instance.ensureSemantics(); + } } /// Watches the lifecycle changes to start the application when it @@ -91,7 +123,7 @@ class AppStarter with WidgetsBindingObserver { if (state == AppLifecycleState.detached) return; Logs().i( - '${AppConfig.applicationName} switches from the detached background-fetch mode to ${state.name} mode. Rendering GUI...', + '${AppSettings.applicationName.value} switches from the detached background-fetch mode to ${state.name} mode. Rendering GUI...', ); // Switching to foreground mode needs to reenable send online sync presence. for (final client in clients) { diff --git a/lib/pages/archive/archive.dart b/lib/pages/archive/archive.dart index a3c35c347..2481dfdde 100644 --- a/lib/pages/archive/archive.dart +++ b/lib/pages/archive/archive.dart @@ -1,11 +1,11 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/archive/archive_view.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; class Archive extends StatefulWidget { @@ -23,7 +23,7 @@ class ArchiveController extends State { return archive = await Matrix.of(context).client.loadArchive(); } - void forgetRoomAction(int i) async { + Future forgetRoomAction(int i) async { await showFutureLoadingDialog( context: context, future: () async { @@ -35,25 +35,27 @@ class ArchiveController extends State { setState(() {}); } - void forgetAllAction() async { + Future forgetAllAction() async { final archive = this.archive; final client = Matrix.of(context).client; if (archive.isEmpty) return; if (await showOkCancelAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.cancel, - message: L10n.of(context)!.clearArchive, + title: L10n.of(context).areYouSure, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).cancel, + message: L10n.of(context).clearArchive, ) != OkCancelResult.ok) { return; } await showFutureLoadingDialog( context: context, - future: () async { + futureWithProgress: (onProgress) async { + final count = archive.length; while (archive.isNotEmpty) { + onProgress(1 - (archive.length / count)); Logs().v('Forget room ${archive.last.getLocalizedDisplayname()}'); await archive.last.forget(); archive.removeLast(); diff --git a/lib/pages/archive/archive_view.dart b/lib/pages/archive/archive_view.dart index dc73addb9..5ef4176f2 100644 --- a/lib/pages/archive/archive_view.dart +++ b/lib/pages/archive/archive_view.dart @@ -1,9 +1,9 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/archive/archive.dart'; import 'package:fluffychat/pages/chat_list/chat_list_item.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; @@ -20,14 +20,14 @@ class ArchiveView extends StatelessWidget { builder: (BuildContext context, snapshot) => Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.archive), + title: Text(L10n.of(context).archive), actions: [ if (snapshot.data?.isNotEmpty ?? false) Padding( padding: const EdgeInsets.all(8.0), child: TextButton.icon( onPressed: controller.forgetAllAction, - label: Text(L10n.of(context)!.clearArchive), + label: Text(L10n.of(context).clearArchive), icon: const Icon(Icons.cleaning_services_outlined), ), ), @@ -40,7 +40,7 @@ class ArchiveView extends StatelessWidget { if (snapshot.hasError) { return Center( child: Text( - L10n.of(context)!.oopsSomethingWentWrong, + L10n.of(context).oopsSomethingWentWrong, textAlign: TextAlign.center, ), ); @@ -60,8 +60,9 @@ class ArchiveView extends StatelessWidget { itemBuilder: (BuildContext context, int i) => ChatListItem( controller.archive[i], onForget: () => controller.forgetRoomAction(i), - onTap: () => context - .go('/rooms/archive/${controller.archive[i].id}'), + onTap: () => context.go( + '/rooms/archive/${controller.archive[i].id}', + ), ), ); } diff --git a/lib/pages/bootstrap/bootstrap_dialog.dart b/lib/pages/bootstrap/bootstrap_dialog.dart index e1c4cde71..88d30813f 100644 --- a/lib/pages/bootstrap/bootstrap_dialog.dart +++ b/lib/pages/bootstrap/bootstrap_dialog.dart @@ -1,34 +1,27 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_secure_storage/flutter_secure_storage.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; +import 'package:go_router/go_router.dart'; import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/error_reporter.dart'; import 'package:fluffychat/utils/fluffy_share.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import '../../utils/adaptive_bottom_sheet.dart'; +import 'package:fluffychat/utils/sync_status_localization.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; +import 'package:fluffychat/widgets/layouts/login_scaffold.dart'; +import 'package:fluffychat/widgets/matrix.dart'; import '../key_verification/key_verification_dialog.dart'; class BootstrapDialog extends StatefulWidget { final bool wipe; - final Client client; - const BootstrapDialog({ - super.key, - this.wipe = false, - required this.client, - }); - Future show(BuildContext context) => showAdaptiveBottomSheet( - context: context, - builder: (context) => this, - maxHeight: 600, - ); + const BootstrapDialog({super.key, this.wipe = false}); @override BootstrapDialogState createState() => BootstrapDialogState(); @@ -38,7 +31,7 @@ class BootstrapDialogState extends State { final TextEditingController _recoveryKeyTextEditingController = TextEditingController(); - late Bootstrap bootstrap; + Bootstrap? bootstrap; String? _recoveryKeyInputError; @@ -54,33 +47,81 @@ class BootstrapDialogState extends State { bool? _wipe; String get _secureStorageKey => - 'ssss_recovery_key_${bootstrap.client.userID}'; + 'ssss_recovery_key_${bootstrap!.client.userID}'; bool get _supportsSecureStorage => PlatformInfos.isMobile || PlatformInfos.isDesktop; String _getSecureStorageLocalizedName() { if (PlatformInfos.isAndroid) { - return L10n.of(context)!.storeInAndroidKeystore; + return L10n.of(context).storeInAndroidKeystore; } if (PlatformInfos.isIOS || PlatformInfos.isMacOS) { - return L10n.of(context)!.storeInAppleKeyChain; + return L10n.of(context).storeInAppleKeyChain; } - return L10n.of(context)!.storeSecurlyOnThisDevice; + return L10n.of(context).storeSecurlyOnThisDevice; } + late final Client client; + @override void initState() { - _createBootstrap(widget.wipe); super.initState(); + client = Matrix.of(context).client; + _createBootstrap(widget.wipe); } - void _createBootstrap(bool wipe) async { + Future _cancelAction() async { + final consent = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).skipChatBackup, + message: L10n.of(context).skipChatBackupWarning, + okLabel: L10n.of(context).skip, + isDestructive: true, + ); + if (consent != OkCancelResult.ok) return; + if (!mounted) return; + _goBackAction(false); + } + + void _goBackAction(bool success) { + if (success) _decryptLastEvents(); + + context.canPop() ? context.pop(success) : context.go('/rooms'); + } + + void _decryptLastEvents() { + for (final room in client.rooms) { + final event = room.lastEvent; + if (event != null && + event.type == EventTypes.Encrypted && + event.messageType == MessageTypes.BadEncrypted && + event.content['can_request_session'] == true) { + final sessionId = event.content.tryGet('session_id'); + final senderKey = event.content.tryGet('sender_key'); + if (sessionId != null && senderKey != null) { + room.client.encryption?.keyManager.maybeAutoRequest( + room.id, + sessionId, + senderKey, + ); + } + } + } + } + + Future _createBootstrap(bool wipe) async { + await client.roomsLoading; + await client.accountDataLoading; + await client.userDeviceKeysLoading; + while (client.prevBatch == null) { + await client.onSyncStatus.stream.first; + } + await client.updateUserDeviceKeys(); _wipe = wipe; titleText = null; _recoveryKeyStored = false; - bootstrap = - widget.client.encryption!.bootstrap(onUpdate: (_) => setState(() {})); + bootstrap = client.encryption!.bootstrap(onUpdate: (_) => setState(() {})); final key = await const FlutterSecureStorage().read(key: _secureStorageKey); if (key == null) return; _recoveryKeyTextEditingController.text = key; @@ -88,28 +129,53 @@ class BootstrapDialogState extends State { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final bootstrap = this.bootstrap; + if (bootstrap == null) { + return LoginScaffold( + appBar: AppBar( + centerTitle: true, + leading: CloseButton(onPressed: _cancelAction), + title: Text(L10n.of(context).loadingMessages), + ), + body: Center( + child: StreamBuilder( + stream: client.onSyncStatus.stream, + builder: (context, snapshot) { + final status = snapshot.data; + return Column( + mainAxisAlignment: .center, + children: [ + CircularProgressIndicator.adaptive(value: status?.progress), + if (status != null) Text(status.calcLocalizedString(context)), + ], + ); + }, + ), + ), + ); + } + _wipe ??= widget.wipe; final buttons = []; - Widget body = const CircularProgressIndicator.adaptive(); - titleText = L10n.of(context)!.loadingPleaseWait; + Widget body = const Center(child: CircularProgressIndicator.adaptive()); + titleText = L10n.of(context).loadingPleaseWait; if (bootstrap.newSsssKey?.recoveryKey != null && _recoveryKeyStored == false) { final key = bootstrap.newSsssKey!.recoveryKey; - titleText = L10n.of(context)!.recoveryKey; - return Scaffold( + titleText = L10n.of(context).recoveryKey; + return LoginScaffold( appBar: AppBar( centerTitle: true, - leading: IconButton( - icon: const Icon(Icons.close), - onPressed: Navigator.of(context).pop, - ), - title: Text(L10n.of(context)!.recoveryKey), + leading: CloseButton(onPressed: _cancelAction), + title: Text(L10n.of(context).recoveryKey), ), body: Center( child: ConstrainedBox( - constraints: - const BoxConstraints(maxWidth: FluffyThemes.columnWidth * 1.5), + constraints: const BoxConstraints( + maxWidth: FluffyThemes.columnWidth * 1.5, + ), child: ListView( padding: const EdgeInsets.all(16.0), children: [ @@ -119,15 +185,12 @@ class BootstrapDialogState extends State { backgroundColor: Colors.transparent, child: Icon( Icons.info_outlined, - color: Theme.of(context).colorScheme.primary, + color: theme.colorScheme.primary, ), ), - subtitle: Text(L10n.of(context)!.chatBackupDescription), - ), - const Divider( - height: 32, - thickness: 1, + subtitle: Text(L10n.of(context).chatBackupDescription), ), + const Divider(height: 32, thickness: 1), TextField( minLines: 2, maxLines: 4, @@ -141,47 +204,56 @@ class BootstrapDialogState extends State { ), const SizedBox(height: 16), if (_supportsSecureStorage) - CheckboxListTile.adaptive( - contentPadding: const EdgeInsets.symmetric(horizontal: 8.0), - value: _storeInSecureStorage, - activeColor: Theme.of(context).colorScheme.primary, - onChanged: (b) { - setState(() { - _storeInSecureStorage = b; - }); - }, - title: Text(_getSecureStorageLocalizedName()), - subtitle: - Text(L10n.of(context)!.storeInSecureStorageDescription), + Semantics( + identifier: 'store_in_secure_storage', + child: CheckboxListTile.adaptive( + contentPadding: const EdgeInsets.symmetric( + horizontal: 8.0, + ), + value: _storeInSecureStorage, + activeColor: theme.colorScheme.primary, + onChanged: (b) { + setState(() { + _storeInSecureStorage = b; + }); + }, + title: Text(_getSecureStorageLocalizedName()), + subtitle: Text( + L10n.of(context).storeInSecureStorageDescription, + ), + ), ), const SizedBox(height: 16), - CheckboxListTile.adaptive( - contentPadding: const EdgeInsets.symmetric(horizontal: 8.0), - value: _recoveryKeyCopied, - activeColor: Theme.of(context).colorScheme.primary, - onChanged: (b) { - FluffyShare.share(key!, context); - setState(() => _recoveryKeyCopied = true); - }, - title: Text(L10n.of(context)!.copyToClipboard), - subtitle: Text(L10n.of(context)!.saveKeyManuallyDescription), + Semantics( + identifier: 'copy_to_clipboard', + child: CheckboxListTile.adaptive( + contentPadding: const EdgeInsets.symmetric(horizontal: 8.0), + value: _recoveryKeyCopied, + activeColor: theme.colorScheme.primary, + onChanged: (b) { + FluffyShare.share(key!, context); + setState(() => _recoveryKeyCopied = true); + }, + title: Text(L10n.of(context).copyToClipboard), + subtitle: Text(L10n.of(context).saveKeyManuallyDescription), + ), ), const SizedBox(height: 16), ElevatedButton.icon( icon: const Icon(Icons.check_outlined), - label: Text(L10n.of(context)!.next), + label: Text(L10n.of(context).next), onPressed: (_recoveryKeyCopied || _storeInSecureStorage == true) - ? () { - if (_storeInSecureStorage == true) { - const FlutterSecureStorage().write( - key: _secureStorageKey, - value: key, - ); - } - setState(() => _recoveryKeyStored = true); - } - : null, + ? () { + if (_storeInSecureStorage == true) { + const FlutterSecureStorage().write( + key: _secureStorageKey, + value: key, + ); + } + setState(() => _recoveryKeyStored = true); + } + : null, ), ], ), @@ -219,14 +291,11 @@ class BootstrapDialogState extends State { break; case BootstrapState.openExistingSsss: _recoveryKeyStored = true; - return Scaffold( + return LoginScaffold( appBar: AppBar( centerTitle: true, - leading: IconButton( - icon: const Icon(Icons.close), - onPressed: Navigator.of(context).pop, - ), - title: Text(L10n.of(context)!.chatBackup), + leading: CloseButton(onPressed: _cancelAction), + title: Text(L10n.of(context).setupChatBackup), ), body: Center( child: ConstrainedBox( @@ -237,14 +306,15 @@ class BootstrapDialogState extends State { padding: const EdgeInsets.all(16.0), children: [ ListTile( - contentPadding: - const EdgeInsets.symmetric(horizontal: 8.0), + contentPadding: const EdgeInsets.symmetric( + horizontal: 8.0, + ), trailing: Icon( Icons.info_outlined, - color: Theme.of(context).colorScheme.primary, + color: theme.colorScheme.primary, ), subtitle: Text( - L10n.of(context)!.pleaseEnterRecoveryKeyDescription, + L10n.of(context).pleaseEnterRecoveryKeyDescription, ), ), const Divider(height: 32), @@ -261,10 +331,11 @@ class BootstrapDialogState extends State { decoration: InputDecoration( contentPadding: const EdgeInsets.all(16), hintStyle: TextStyle( - fontFamily: - Theme.of(context).textTheme.bodyLarge?.fontFamily, + fontFamily: theme.textTheme.bodyLarge?.fontFamily, ), - hintText: L10n.of(context)!.recoveryKey, + prefixIcon: const Icon(Icons.key_outlined), + labelText: L10n.of(context).recoveryKey, + hintText: 'Es** **** **** ****', errorText: _recoveryKeyInputError, errorMaxLines: 2, ), @@ -272,14 +343,14 @@ class BootstrapDialogState extends State { const SizedBox(height: 16), ElevatedButton.icon( style: ElevatedButton.styleFrom( - foregroundColor: - Theme.of(context).colorScheme.onPrimary, - backgroundColor: Theme.of(context).colorScheme.primary, + foregroundColor: theme.colorScheme.onPrimary, + iconColor: theme.colorScheme.onPrimary, + backgroundColor: theme.colorScheme.primary, ), icon: _recoveryKeyInputLoading ? const CircularProgressIndicator.adaptive() : const Icon(Icons.lock_open_outlined), - label: Text(L10n.of(context)!.unlockOldMessages), + label: Text(L10n.of(context).unlockOldMessages), onPressed: _recoveryKeyInputLoading ? null : () async { @@ -301,28 +372,23 @@ class BootstrapDialogState extends State { Logs().v( 'Cross signing is already enabled. Try to self-sign', ); - try { - await bootstrap - .client.encryption!.crossSigning - .selfSign(recoveryKey: key); - Logs().d('Successful selfsigned'); - } catch (e, s) { - Logs().e( - 'Unable to self sign with recovery key after successfully open existing SSSS', - e, - s, - ); - } + await bootstrap + .client + .encryption! + .crossSigning + .selfSign(recoveryKey: key); + Logs().d('Successful selfsigned'); } } on InvalidPassphraseException catch (e) { setState( - () => _recoveryKeyInputError = - e.toLocalizedString(context), + () => _recoveryKeyInputError = e + .toLocalizedString(context), ); } on FormatException catch (_) { setState( - () => _recoveryKeyInputError = - L10n.of(context)!.wrongRecoveryKey, + () => _recoveryKeyInputError = L10n.of( + context, + ).wrongRecoveryKey, ); } catch (e, s) { ErrorReporter( @@ -330,8 +396,8 @@ class BootstrapDialogState extends State { 'Unable to open SSSS with recovery key', ).onErrorCallback(e, s); setState( - () => _recoveryKeyInputError = - e.toLocalizedString(context), + () => _recoveryKeyInputError = e + .toLocalizedString(context), ); } finally { setState( @@ -346,7 +412,7 @@ class BootstrapDialogState extends State { const Expanded(child: Divider()), Padding( padding: const EdgeInsets.all(12.0), - child: Text(L10n.of(context)!.or), + child: Text(L10n.of(context).or), ), const Expanded(child: Divider()), ], @@ -354,45 +420,68 @@ class BootstrapDialogState extends State { const SizedBox(height: 16), ElevatedButton.icon( icon: const Icon(Icons.cast_connected_outlined), - label: Text(L10n.of(context)!.transferFromAnotherDevice), + label: Text(L10n.of(context).transferFromAnotherDevice), onPressed: _recoveryKeyInputLoading ? null : () async { final consent = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.verifyOtherDevice, - message: L10n.of(context)! - .verifyOtherDeviceDescription, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - fullyCapitalizedForMaterial: false, + title: L10n.of(context).verifyOtherDevice, + message: L10n.of( + context, + ).verifyOtherDeviceDescription, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, ); if (consent != OkCancelResult.ok) return; final req = await showFutureLoadingDialog( context: context, + delay: false, future: () async { - await widget.client.updateUserDeviceKeys(); - return widget.client - .userDeviceKeys[widget.client.userID!]! + await client.updateUserDeviceKeys(); + return client.userDeviceKeys[client.userID!]! .startVerification(); }, ); if (req.error != null) return; - await KeyVerificationDialog(request: req.result!) - .show(context); - Navigator.of(context, rootNavigator: false).pop(); + final success = await KeyVerificationDialog( + request: req.result!, + ).show(context); + if (success != true) return; + if (!mounted) return; + + final result = await showFutureLoadingDialog( + context: context, + future: () async { + final allCached = + await client.encryption!.keyManager + .isCached() && + await client.encryption!.crossSigning + .isCached(); + if (!allCached) { + await client + .encryption! + .ssss + .onSecretStored + .stream + .first; + } + return; + }, + ); + if (!mounted) return; + if (!result.isError) _goBackAction(true); }, ), const SizedBox(height: 16), ElevatedButton.icon( style: ElevatedButton.styleFrom( - backgroundColor: - Theme.of(context).colorScheme.errorContainer, - foregroundColor: - Theme.of(context).colorScheme.onErrorContainer, + backgroundColor: theme.colorScheme.errorContainer, + foregroundColor: theme.colorScheme.onErrorContainer, + iconColor: theme.colorScheme.onErrorContainer, ), icon: const Icon(Icons.delete_outlined), - label: Text(L10n.of(context)!.recoveryKeyLost), + label: Text(L10n.of(context).recoveryKeyLost), onPressed: _recoveryKeyInputLoading ? null : () async { @@ -400,11 +489,11 @@ class BootstrapDialogState extends State { await showOkCancelAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.recoveryKeyLost, - message: L10n.of(context)!.wipeChatBackup, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - isDestructiveAction: true, + title: L10n.of(context).recoveryKeyLost, + message: L10n.of(context).wipeChatBackup, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + isDestructive: true, )) { setState(() => _createBootstrap(true)); } @@ -441,20 +530,19 @@ class BootstrapDialogState extends State { ); break; case BootstrapState.error: - titleText = L10n.of(context)!.oopsSomethingWentWrong; + titleText = L10n.of(context).oopsSomethingWentWrong; body = const Icon(Icons.error_outline, color: Colors.red, size: 80); buttons.add( - OutlinedButton( - onPressed: () => - Navigator.of(context, rootNavigator: false).pop(false), - child: Text(L10n.of(context)!.close), + ElevatedButton( + onPressed: () => _goBackAction(false), + child: Text(L10n.of(context).close), ), ); break; case BootstrapState.done: - titleText = L10n.of(context)!.everythingReady; + titleText = L10n.of(context).everythingReady; body = Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ const Icon( Icons.check_circle_rounded, @@ -463,41 +551,35 @@ class BootstrapDialogState extends State { ), const SizedBox(height: 16), Text( - L10n.of(context)!.yourChatBackupHasBeenSetUp, + L10n.of(context).yourChatBackupHasBeenSetUp, style: const TextStyle(fontSize: 20), ), const SizedBox(height: 16), ], ); buttons.add( - OutlinedButton( - onPressed: () => - Navigator.of(context, rootNavigator: false).pop(false), - child: Text(L10n.of(context)!.close), + ElevatedButton( + onPressed: () => _goBackAction(true), + child: Text(L10n.of(context).close), ), ); break; } } - return Scaffold( + return LoginScaffold( appBar: AppBar( - leading: Center( - child: CloseButton( - onPressed: () => - Navigator.of(context, rootNavigator: false).pop(true), - ), - ), - title: Text(titleText ?? L10n.of(context)!.loadingPleaseWait), + leading: CloseButton(onPressed: _cancelAction), + title: Text(titleText ?? L10n.of(context).loadingPleaseWait), ), body: Center( - child: Column( - mainAxisSize: MainAxisSize.min, - children: [ - body, - const SizedBox(height: 8), - ...buttons, - ], + child: Padding( + padding: const EdgeInsets.all(20.0), + child: Column( + mainAxisSize: .min, + crossAxisAlignment: .stretch, + children: [body, const SizedBox(height: 8), ...buttons], + ), ), ), ); diff --git a/lib/pages/chat/add_widget_tile.dart b/lib/pages/chat/add_widget_tile.dart deleted file mode 100644 index 11e3cce5d..000000000 --- a/lib/pages/chat/add_widget_tile.dart +++ /dev/null @@ -1,85 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/pages/chat/add_widget_tile_view.dart'; - -class AddWidgetTile extends StatefulWidget { - final Room room; - - const AddWidgetTile({super.key, required this.room}); - - @override - State createState() => AddWidgetTileState(); -} - -class AddWidgetTileState extends State { - final TextEditingController urlController = TextEditingController(); - final TextEditingController nameController = TextEditingController(); - String widgetType = 'm.etherpad'; - - late final bool initiallyExpanded; - - String? nameError; - String? urlError; - - @override - void initState() { - initiallyExpanded = widget.room.widgets.isEmpty; - super.initState(); - } - - void setWidgetType(String value) => setState(() => widgetType = value); - - void addWidget() { - try { - nameError = null; - urlError = null; - - final room = widget.room; - final name = nameController.text; - final uri = Uri.tryParse(urlController.text); - - if (name.length < 3) { - setState(() { - nameError = L10n.of(context)!.widgetNameError; - }); - return; - } - - if (uri == null || uri.scheme != 'https') { - setState(() { - urlError = L10n.of(context)!.widgetUrlError; - }); - return; - } - setState(() {}); - - late MatrixWidget matrixWidget; - switch (widgetType) { - case 'm.etherpad': - matrixWidget = MatrixWidget.etherpad(room, name, uri); - break; - case 'm.jitsi': - matrixWidget = MatrixWidget.jitsi(room, name, uri); - break; - case 'm.video': - matrixWidget = MatrixWidget.video(room, name, uri); - break; - default: - matrixWidget = MatrixWidget.custom(room, name, uri); - break; - } - widget.room.addWidget(matrixWidget); - Navigator.of(context).pop(); - } catch (e) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.errorAddingWidget)), - ); - } - } - - @override - Widget build(BuildContext context) => AddWidgetTileView(controller: this); -} diff --git a/lib/pages/chat/add_widget_tile_view.dart b/lib/pages/chat/add_widget_tile_view.dart deleted file mode 100644 index d7ac53ef2..000000000 --- a/lib/pages/chat/add_widget_tile_view.dart +++ /dev/null @@ -1,73 +0,0 @@ -import 'package:flutter/cupertino.dart'; -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; - -import 'package:fluffychat/pages/chat/add_widget_tile.dart'; - -class AddWidgetTileView extends StatelessWidget { - final AddWidgetTileState controller; - - const AddWidgetTileView({super.key, required this.controller}); - - @override - Widget build(BuildContext context) { - return ExpansionTile( - title: Text(L10n.of(context)!.addWidget), - leading: const Icon(Icons.add), - initiallyExpanded: controller.initiallyExpanded, - children: [ - CupertinoSegmentedControl( - groupValue: controller.widgetType, - padding: const EdgeInsets.all(8), - children: { - 'm.etherpad': Text(L10n.of(context)!.widgetEtherpad), - 'm.jitsi': Text(L10n.of(context)!.widgetJitsi), - 'm.video': Text(L10n.of(context)!.widgetVideo), - 'm.custom': Text(L10n.of(context)!.widgetCustom), - }.map( - (key, value) => MapEntry( - key, - Padding( - padding: const EdgeInsets.symmetric(horizontal: 4.0), - child: value, - ), - ), - ), - onValueChanged: controller.setWidgetType, - ), - Padding( - padding: const EdgeInsets.all(8.0), - child: TextField( - controller: controller.nameController, - autofocus: true, - decoration: InputDecoration( - prefixIcon: const Icon(Icons.label), - label: Text(L10n.of(context)!.widgetName), - errorText: controller.nameError, - ), - ), - ), - Padding( - padding: const EdgeInsets.all(8.0), - child: TextField( - controller: controller.urlController, - decoration: InputDecoration( - prefixIcon: const Icon(Icons.add_link), - label: Text(L10n.of(context)!.link), - errorText: controller.urlError, - ), - ), - ), - ButtonBar( - children: [ - TextButton( - onPressed: controller.addWidget, - child: Text(L10n.of(context)!.addWidget), - ), - ], - ), - ], - ); - } -} diff --git a/lib/pages/chat/chat.dart b/lib/pages/chat/chat.dart index 2592f560c..afe579207 100644 --- a/lib/pages/chat/chat.dart +++ b/lib/pages/chat/chat.dart @@ -5,50 +5,53 @@ import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; +import 'package:collection/collection.dart'; import 'package:desktop_drop/desktop_drop.dart'; import 'package:device_info_plus/device_info_plus.dart'; import 'package:emoji_picker_flutter/emoji_picker_flutter.dart'; import 'package:file_picker/file_picker.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:go_router/go_router.dart'; import 'package:image_picker/image_picker.dart'; import 'package:matrix/matrix.dart'; -import 'package:record/record.dart'; import 'package:scroll_to_index/scroll_to_index.dart'; -import 'package:shared_preferences/shared_preferences.dart'; -import 'package:universal_html/html.dart' as html; -import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat/chat_view.dart'; import 'package:fluffychat/pages/chat/event_info_dialog.dart'; -import 'package:fluffychat/pages/chat/recording_dialog.dart'; +import 'package:fluffychat/pages/chat/start_poll_bottom_sheet.dart'; import 'package:fluffychat/pages/chat_details/chat_details.dart'; +import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/error_reporter.dart'; +import 'package:fluffychat/utils/file_selector.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/event_extension.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/filtered_timeline_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/utils/other_party_can_receive.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/widgets/app_lock.dart'; +import 'package:fluffychat/utils/show_scaffold_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import 'package:fluffychat/widgets/share_scaffold_dialog.dart'; import '../../utils/account_bundles.dart'; import '../../utils/localized_exception_extension.dart'; -import '../../utils/matrix_sdk_extensions/matrix_file_extension.dart'; import 'send_file_dialog.dart'; import 'send_location_dialog.dart'; class ChatPage extends StatelessWidget { final String roomId; - final String? shareText; + final List? shareItems; final String? eventId; const ChatPage({ super.key, required this.roomId, this.eventId, - this.shareText, + this.shareItems, }); @override @@ -56,12 +59,11 @@ class ChatPage extends StatelessWidget { final room = Matrix.of(context).client.getRoomById(roomId); if (room == null) { return Scaffold( - appBar: AppBar(title: Text(L10n.of(context)!.oopsSomethingWentWrong)), + appBar: AppBar(title: Text(L10n.of(context).oopsSomethingWentWrong)), body: Center( child: Padding( padding: const EdgeInsets.all(16), - child: - Text(L10n.of(context)!.youAreNoLongerParticipatingInThisChat), + child: Text(L10n.of(context).youAreNoLongerParticipatingInThisChat), ), ), ); @@ -70,7 +72,7 @@ class ChatPage extends StatelessWidget { return ChatPageWithRoom( key: Key('chat_page_${roomId}_$eventId'), room: room, - shareText: shareText, + shareItems: shareItems, eventId: eventId, ); } @@ -78,13 +80,13 @@ class ChatPage extends StatelessWidget { class ChatPageWithRoom extends StatefulWidget { final Room room; - final String? shareText; + final List? shareItems; final String? eventId; const ChatPageWithRoom({ super.key, required this.room, - this.shareText, + this.shareItems, this.eventId, }); @@ -100,14 +102,17 @@ class ChatController extends State Timeline? timeline; - String? readMarkerEventId; + String? activeThreadId; + + late final Set bigEmojis; + + late final String readMarkerEventId; String get roomId => widget.room.id; final AutoScrollController scrollController = AutoScrollController(); - FocusNode inputFocus = FocusNode(); - StreamSubscription? onFocusSub; + late final FocusNode inputFocus; Timer? typingCoolDown; Timer? typingTimeout; @@ -118,40 +123,18 @@ class ChatController extends State void onDragExited(_) => setState(() => dragging = false); - void onDragDone(DropDoneDetails details) async { + Future onDragDone(DropDoneDetails details) async { setState(() => dragging = false); if (details.files.isEmpty) return; - final result = await showFutureLoadingDialog( - context: context, - future: () async { - final clientConfig = await room.client.getConfig(); - final maxUploadSize = clientConfig.mUploadSize ?? 100 * 1024 * 1024; - final matrixFiles = await Future.wait( - details.files.map( - (xfile) async { - final length = await xfile.length(); - if (length > maxUploadSize) { - throw FileTooBigMatrixException(length, maxUploadSize); - } - return MatrixFile( - bytes: await xfile.readAsBytes(), - name: xfile.name, - mimeType: xfile.mimeType, - ).detectFileType; - }, - ), - ); - return matrixFiles; - }, - ); - final matrixFiles = result.result; - if (matrixFiles == null || matrixFiles.isEmpty) return; await showAdaptiveDialog( context: context, builder: (c) => SendFileDialog( - files: matrixFiles, + files: details.files, room: room, + outerContext: context, + threadRootEventId: activeThreadId, + threadLastEventId: threadLastEventId, ), ); } @@ -166,7 +149,8 @@ class ChatController extends State MessageTypes.File, }.contains(selectedEvents.single.messageType); - void saveSelectedEvent(context) => selectedEvents.single.saveFile(context); + void saveSelectedEvent(BuildContext context) => + selectedEvents.single.saveFile(context); List selectedEvents = []; @@ -189,7 +173,26 @@ class ChatController extends State bool showEmojiPicker = false; - void recreateChat() async { + String? get threadLastEventId { + final threadId = activeThreadId; + if (threadId == null) return null; + return timeline?.events + .filterByVisibleInGui(threadId: threadId) + .firstOrNull + ?.eventId; + } + + void enterThread(String eventId) => setState(() { + activeThreadId = eventId; + selectedEvents.clear(); + }); + + void closeThread() => setState(() { + activeThreadId = null; + selectedEvents.clear(); + }); + + Future recreateChat() async { final room = this.room; final userId = room.directChatMatrixID; if (userId == null) { @@ -203,7 +206,7 @@ class ChatController extends State ); } - void leaveChat() async { + Future leaveChat() async { final success = await showFutureLoadingDialog( context: context, future: room.leave, @@ -212,22 +215,34 @@ class ChatController extends State context.go('/rooms'); } - EmojiPickerType emojiPickerType = EmojiPickerType.keyboard; - - void requestHistory([_]) async { - if (!timeline!.canRequestHistory) return; + Future requestHistory([_]) async { Logs().v('Requesting history...'); - await timeline!.requestHistory(historyCount: _loadHistoryCount); + await timeline?.requestHistory(historyCount: _loadHistoryCount); } - void requestFuture() async { + Future requestFuture() async { final timeline = this.timeline; if (timeline == null) return; - if (!timeline.canRequestFuture) return; Logs().v('Requesting future...'); - final mostRecentEventId = timeline.events.first.eventId; + + final mostRecentEvent = timeline.events.filterByVisibleInGui().firstOrNull; + await timeline.requestFuture(historyCount: _loadHistoryCount); - setReadMarker(eventId: mostRecentEventId); + + if (mostRecentEvent != null) { + setReadMarker(eventId: mostRecentEvent.eventId); + WidgetsBinding.instance.addPostFrameCallback((_) { + final index = timeline.events.filterByVisibleInGui().indexOf( + mostRecentEvent, + ); + if (index >= 0) { + scrollController.scrollToIndex( + index, + preferPosition: AutoScrollPosition.begin, + ); + } + }); + } } void _updateScrollController() { @@ -242,61 +257,195 @@ class ChatController extends State setState(() => _scrolledUp = false); setReadMarker(); } - - if (scrollController.position.pixels == 0 || - scrollController.position.pixels == 64) { - requestFuture(); - } } - void _loadDraft() async { - final prefs = await SharedPreferences.getInstance(); - final draft = widget.shareText ?? prefs.getString('draft_$roomId'); + void _loadDraft() { + final prefs = Matrix.of(context).store; + final draft = prefs.getString('draft_$roomId'); if (draft != null && draft.isNotEmpty) { sendController.text = draft; } } + void _shareItems([_]) { + final shareItems = widget.shareItems; + if (shareItems == null || shareItems.isEmpty) return; + if (!room.otherPartyCanReceiveMessages) { + final theme = Theme.of(context); + ScaffoldMessenger.of(context).showSnackBar( + SnackBar( + backgroundColor: theme.colorScheme.errorContainer, + closeIconColor: theme.colorScheme.onErrorContainer, + content: Text( + L10n.of(context).otherPartyNotLoggedIn, + style: TextStyle(color: theme.colorScheme.onErrorContainer), + ), + showCloseIcon: true, + ), + ); + return; + } + for (final item in shareItems) { + if (item is FileShareItem) continue; + if (item is TextShareItem) room.sendTextEvent(item.value); + if (item is ContentShareItem) room.sendEvent(item.value); + } + final files = shareItems + .whereType() + .map((item) => item.value) + .toList(); + if (files.isEmpty) return; + showAdaptiveDialog( + context: context, + builder: (c) => SendFileDialog( + files: files, + room: room, + outerContext: context, + threadRootEventId: activeThreadId, + threadLastEventId: threadLastEventId, + ), + ); + } + + KeyEventResult _customEnterKeyHandling(FocusNode node, KeyEvent evt) { + if (!HardwareKeyboard.instance.isShiftPressed && + evt.logicalKey.keyLabel == 'Enter' && + AppSettings.sendOnEnter.value) { + if (evt is KeyDownEvent) { + send(); + } + return KeyEventResult.handled; + } else if (evt.logicalKey.keyLabel == 'Enter' && evt is KeyDownEvent) { + final currentLineNum = + sendController.text + .substring(0, sendController.selection.baseOffset) + .split('\n') + .length - + 1; + final currentLine = sendController.text.split('\n')[currentLineNum]; + + for (final pattern in [ + '- [ ] ', + '- [x] ', + '* [ ] ', + '* [x] ', + '- ', + '* ', + '+ ', + ]) { + if (currentLine.startsWith(pattern)) { + if (currentLine == pattern) { + return KeyEventResult.ignored; + } + sendController.text += '\n$pattern'; + return KeyEventResult.handled; + } + } + + return KeyEventResult.ignored; + } else { + return KeyEventResult.ignored; + } + } + @override void initState() { + inputFocus = FocusNode(onKeyEvent: _customEnterKeyHandling); + scrollController.addListener(_updateScrollController); inputFocus.addListener(_inputFocusListener); _loadDraft(); + WidgetsBinding.instance.addPostFrameCallback(_shareItems); super.initState(); _displayChatDetailsColumn = ValueNotifier( - Matrix.of(context).store.getBool(SettingKeys.displayChatDetailsColumn) ?? - false, + AppSettings.displayChatDetailsColumn.value, + ); + + bigEmojis = defaultEmojiSet.fold( + {}, + (emojis, category) => { + ...emojis, + ...(category.emoji.map((emoji) => emoji.emoji)), + }, ); sendingClient = Matrix.of(context).client; + final lastEventThreadId = + room.lastEvent?.relationshipType == RelationshipTypes.thread + ? room.lastEvent?.relationshipEventId + : null; + readMarkerEventId = room.hasNewMessages + ? lastEventThreadId ?? room.fullyRead + : ''; WidgetsBinding.instance.addObserver(this); _tryLoadTimeline(); - if (kIsWeb) { - onFocusSub = html.window.onFocus.listen((_) => setReadMarker()); - } } - void _tryLoadTimeline() async { + final Set expandedEventIds = {}; + + void expandEventsFrom(Event event, bool expand) { + final events = timeline!.events.filterByVisibleInGui( + threadId: activeThreadId, + ); + final start = events.indexOf(event); + setState(() { + for (var i = start; i < events.length; i++) { + final event = events[i]; + if (!event.isCollapsedState) return; + if (expand) { + expandedEventIds.add(event.eventId); + } else { + expandedEventIds.remove(event.eventId); + } + } + }); + } + + Future _tryLoadTimeline() async { final initialEventId = widget.eventId; loadTimelineFuture = _getTimeline(); try { await loadTimelineFuture; - if (initialEventId != null) scrollToEventId(initialEventId); + // We launched the chat with a given initial event ID: + if (initialEventId != null) { + scrollToEventId(initialEventId); + return; + } - final fullyRead = room.fullyRead; - if (fullyRead.isEmpty) { - setReadMarker(); - return; + var readMarkerEventIndex = readMarkerEventId.isEmpty + ? -1 + : timeline!.events + .filterByVisibleInGui( + exceptionEventId: readMarkerEventId, + threadId: activeThreadId, + ) + .indexWhere((e) => e.eventId == readMarkerEventId); + + // Read marker is existing but not found in first events. Try a single + // requestHistory call before opening timeline on event context: + if (readMarkerEventId.isNotEmpty && readMarkerEventIndex == -1) { + await timeline?.requestHistory(historyCount: _loadHistoryCount); + readMarkerEventIndex = timeline!.events + .filterByVisibleInGui( + exceptionEventId: readMarkerEventId, + threadId: activeThreadId, + ) + .indexWhere((e) => e.eventId == readMarkerEventId); } - if (timeline?.events.any((event) => event.eventId == fullyRead) ?? - false) { - Logs().v('Scroll up to visible event', fullyRead); - setReadMarker(); + + if (readMarkerEventIndex > 1) { + Logs().v('Scroll up to visible event', readMarkerEventId); + scrollToEventId(readMarkerEventId, highlightEvent: false); return; + } else if (readMarkerEventId.isNotEmpty && readMarkerEventIndex == -1) { + _showScrollUpMaterialBanner(readMarkerEventId); } + + // Mark room as read on first visit if requirements are fulfilled + setReadMarker(); + if (!mounted) return; - _showScrollUpMaterialBanner(fullyRead); } catch (e, s) { ErrorReporter(context, 'Unable to load timeline').onErrorCallback(e, s); rethrow; @@ -306,15 +455,16 @@ class ChatController extends State String? scrollUpBannerEventId; void discardScrollUpBannerEventId() => setState(() { - scrollUpBannerEventId = null; - }); + scrollUpBannerEventId = null; + }); void _showScrollUpMaterialBanner(String eventId) => setState(() { - scrollUpBannerEventId = eventId; - }); + scrollUpBannerEventId = eventId; + }); void updateView() { if (!mounted) return; + setReadMarker(); setState(() {}); } @@ -323,18 +473,11 @@ class ChatController extends State int? animateInEventIndex; void onInsert(int i) { - if (timeline?.events[i].status == EventStatus.synced) { - final index = timeline!.events.firstIndexWhereNotError; - if (i == index) setReadMarker(eventId: timeline?.events[i].eventId); - } - // setState will be called by updateView() anyway - animateInEventIndex = i; + if (timeline?.allowNewEvent == true) animateInEventIndex = i; } - Future _getTimeline({ - String? eventContextId, - }) async { + Future _getTimeline({String? eventContextId}) async { await Matrix.of(context).client.roomsLoading; await Matrix.of(context).client.accountDataLoading; if (eventContextId != null && @@ -342,6 +485,7 @@ class ChatController extends State eventContextId = null; } try { + timeline?.cancelSubscriptions(); timeline = await room.getTimeline( onUpdate: updateView, eventContextId: eventContextId, @@ -370,15 +514,18 @@ class ChatController extends State @override void didChangeAppLifecycleState(AppLifecycleState state) { if (state != AppLifecycleState.resumed) return; + if (!mounted) return; setReadMarker(); } Future? _setReadMarkerFuture; void setReadMarker({String? eventId}) { + if (eventId?.isValidMatrixId == false) return; if (_setReadMarkerFuture != null) return; if (_scrolledUp) return; if (scrollUpBannerEventId != null) return; + if (eventId == null && !room.hasNewMessages && room.notificationCount == 0) { @@ -386,9 +533,7 @@ class ChatController extends State } // Do not send read markers when app is not in foreground - if (kIsWeb && !Matrix.of(context).webHasFocus) return; - if (!kIsWeb && - WidgetsBinding.instance.lifecycleState != AppLifecycleState.resumed) { + if (WidgetsBinding.instance.lifecycleState != AppLifecycleState.resumed) { return; } @@ -399,12 +544,12 @@ class ChatController extends State // ignore: unawaited_futures _setReadMarkerFuture = timeline .setReadMarker( - eventId: eventId, - public: AppConfig.sendPublicReadReceipts, - ) + eventId: eventId, + public: AppSettings.sendPublicReadReceipts.value, + ) .then((_) { - _setReadMarkerFuture = null; - }); + _setReadMarkerFuture = null; + }); if (eventId == null || eventId == timeline.room.lastEvent?.eventId) { Matrix.of(context).backgroundPush?.cancelNotification(roomId); } @@ -415,7 +560,6 @@ class ChatController extends State timeline?.cancelSubscriptions(); timeline = null; inputFocus.removeListener(_inputFocusListener); - onFocusSub?.cancel(); super.dispose(); } @@ -444,20 +588,20 @@ class ChatController extends State } void setActiveClient(Client c) => setState(() { - Matrix.of(context).setActiveClient(c); - }); + Matrix.of(context).setActiveClient(c); + }); Future send() async { if (sendController.text.trim().isEmpty) return; _storeInputTimeoutTimer?.cancel(); - final prefs = await SharedPreferences.getInstance(); + final prefs = Matrix.of(context).store; prefs.remove('draft_$roomId'); var parseCommands = true; final commandMatch = RegExp(r'^\/(\w+)').firstMatch(sendController.text); if (commandMatch != null && !sendingClient.commands.keys.contains(commandMatch[1]!.toLowerCase())) { - final l10n = L10n.of(context)!; + final l10n = L10n.of(context); final dialogResult = await showOkCancelAlertDialog( context: context, title: l10n.commandInvalid, @@ -475,6 +619,7 @@ class ChatController extends State inReplyTo: replyEvent, editEventId: editEvent?.eventId, parseCommands: parseCommands, + threadRootEventId: activeThreadId, ); sendController.value = TextEditingValue( text: pendingText, @@ -490,92 +635,54 @@ class ChatController extends State }); } - void sendFileAction() async { - final result = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles( - allowMultiple: false, - withData: true, - ), - ); - if (result == null || result.files.isEmpty) return; + Future sendFileAction({FileType type = FileType.any}) async { + final files = await selectFiles(context, allowMultiple: true, type: type); + if (files.isEmpty) return; await showAdaptiveDialog( context: context, builder: (c) => SendFileDialog( - files: result.files - .map( - (xfile) => MatrixFile( - bytes: xfile.bytes!, - name: xfile.name, - ).detectFileType, - ) - .toList(), + files: files, room: room, + outerContext: context, + threadRootEventId: activeThreadId, + threadLastEventId: threadLastEventId, ), ); } - void sendImageFromClipBoard(Uint8List? image) async { + Future sendImageFromClipBoard(Uint8List? image) async { + if (image == null) return; await showAdaptiveDialog( context: context, builder: (c) => SendFileDialog( - files: [ - MatrixFile( - bytes: image!, - name: "image from Clipboard", - ).detectFileType, - ], + files: [XFile.fromData(image)], room: room, + outerContext: context, + threadRootEventId: activeThreadId, + threadLastEventId: threadLastEventId, ), ); } - void sendImageAction() async { - final result = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles( - type: FileType.image, - withData: true, - allowMultiple: false, - ), - ); - if (result == null || result.files.isEmpty) return; - - await showAdaptiveDialog( - context: context, - builder: (c) => SendFileDialog( - files: result.files - .map( - (xfile) => MatrixFile( - bytes: xfile.bytes!, - name: xfile.name, - ).detectFileType, - ) - .toList(), - room: room, - ), - ); - } - - void openCameraAction() async { + Future openCameraAction() async { // Make sure the textfield is unfocused before opening the camera FocusScope.of(context).requestFocus(FocusNode()); final file = await ImagePicker().pickImage(source: ImageSource.camera); if (file == null) return; - final bytes = await file.readAsBytes(); + await showAdaptiveDialog( context: context, builder: (c) => SendFileDialog( - files: [ - MatrixImageFile( - bytes: bytes, - name: file.path, - ), - ], + files: [file], room: room, + outerContext: context, + threadRootEventId: activeThreadId, + threadLastEventId: threadLastEventId, ), ); } - void openVideoCameraAction() async { + Future openVideoCameraAction() async { // Make sure the textfield is unfocused before opening the camera FocusScope.of(context).requestFocus(FocusNode()); final file = await ImagePicker().pickVideo( @@ -583,75 +690,64 @@ class ChatController extends State maxDuration: const Duration(minutes: 1), ); if (file == null) return; - final bytes = await file.readAsBytes(); + await showAdaptiveDialog( context: context, builder: (c) => SendFileDialog( - files: [ - MatrixVideoFile( - bytes: bytes, - name: file.path, - ), - ], + files: [file], room: room, + outerContext: context, + threadRootEventId: activeThreadId, + threadLastEventId: threadLastEventId, ), ); } - void voiceMessageAction() async { + Future onVoiceMessageSend( + String path, + int duration, + List waveform, + String? fileName, + ) async { final scaffoldMessenger = ScaffoldMessenger.of(context); - if (PlatformInfos.isAndroid) { - final info = await DeviceInfoPlugin().androidInfo; - if (info.version.sdkInt < 19) { - showOkAlertDialog( - context: context, - title: L10n.of(context)!.unsupportedAndroidVersion, - message: L10n.of(context)!.unsupportedAndroidVersionLong, - okLabel: L10n.of(context)!.close, - ); - return; - } - } + final audioFile = XFile(path); - if (await AudioRecorder().hasPermission() == false) return; - final result = await showDialog( + final bytesResult = await showFutureLoadingDialog( context: context, - barrierDismissible: false, - builder: (c) => const RecordingDialog(), + future: audioFile.readAsBytes, ); - if (result == null) return; - final audioFile = File(result.path); + final bytes = bytesResult.result; + if (bytes == null) return; + final file = MatrixAudioFile( - bytes: audioFile.readAsBytesSync(), - name: audioFile.path, + bytes: bytes, + name: fileName ?? audioFile.path, ); - await room.sendFileEvent( - file, - inReplyTo: replyEvent, - extraContent: { - 'info': { - ...file.info, - 'duration': result.duration, - }, - 'org.matrix.msc3245.voice': {}, - 'org.matrix.msc1767.audio': { - 'duration': result.duration, - 'waveform': result.waveform, - }, - }, - ).catchError((e) { - scaffoldMessenger.showSnackBar( - SnackBar( - content: Text( - (e as Object).toLocalizedString(context), - ), - ), - ); - return null; - }); + + room + .sendFileEvent( + file, + inReplyTo: replyEvent, + threadRootEventId: activeThreadId, + extraContent: { + 'info': {...file.info, 'duration': duration}, + 'org.matrix.msc3245.voice': {}, + 'org.matrix.msc1767.audio': { + 'duration': duration, + 'waveform': waveform, + }, + }, + ) + .catchError((e) { + scaffoldMessenger.showSnackBar( + SnackBar(content: Text((e as Object).toLocalizedString(context))), + ); + return null; + }); setState(() { replyEvent = null; }); + return; } void hideEmojiPicker() { @@ -664,18 +760,16 @@ class ChatController extends State } else { inputFocus.unfocus(); } - emojiPickerType = EmojiPickerType.keyboard; setState(() => showEmojiPicker = !showEmojiPicker); } void _inputFocusListener() { if (showEmojiPicker && inputFocus.hasFocus) { - emojiPickerType = EmojiPickerType.keyboard; setState(() => showEmojiPicker = false); } } - void sendLocationAction() async { + Future sendLocationAction() async { await showAdaptiveDialog( context: context, builder: (c) => SendLocationDialog(room: room), @@ -687,12 +781,14 @@ class ChatController extends State if (selectedEvents.length == 1) { return selectedEvents.first .getDisplayEvent(timeline!) - .calcLocalizedBodyFallback(MatrixLocals(L10n.of(context)!)); + .calcLocalizedBodyFallback(MatrixLocals(L10n.of(context))); } for (final event in selectedEvents) { if (copyString.isNotEmpty) copyString += '\n\n'; - copyString += event.getDisplayEvent(timeline!).calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), + copyString += event + .getDisplayEvent(timeline!) + .calcLocalizedBodyFallback( + MatrixLocals(L10n.of(context)), withSenderNamePrefix: true, ); } @@ -707,46 +803,39 @@ class ChatController extends State }); } - void reportEventAction() async { + Future reportEventAction() async { final event = selectedEvents.single; - final score = await showConfirmationDialog( + final score = await showModalActionPopup( context: context, - title: L10n.of(context)!.reportMessage, - message: L10n.of(context)!.howOffensiveIsThisContent, - cancelLabel: L10n.of(context)!.cancel, - okLabel: L10n.of(context)!.ok, + title: L10n.of(context).reportMessage, + message: L10n.of(context).howOffensiveIsThisContent, + cancelLabel: L10n.of(context).cancel, actions: [ - AlertDialogAction( - key: -100, - label: L10n.of(context)!.extremeOffensive, - ), - AlertDialogAction( - key: -50, - label: L10n.of(context)!.offensive, - ), - AlertDialogAction( - key: 0, - label: L10n.of(context)!.inoffensive, + AdaptiveModalAction( + value: -100, + label: L10n.of(context).extremeOffensive, ), + AdaptiveModalAction(value: -50, label: L10n.of(context).offensive), + AdaptiveModalAction(value: 0, label: L10n.of(context).inoffensive), ], ); if (score == null) return; final reason = await showTextInputDialog( context: context, - title: L10n.of(context)!.whyDoYouWantToReportThis, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [DialogTextField(hintText: L10n.of(context)!.reason)], + title: L10n.of(context).whyDoYouWantToReportThis, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + hintText: L10n.of(context).reason, ); - if (reason == null || reason.single.isEmpty) return; + if (reason == null || reason.isEmpty) return; final result = await showFutureLoadingDialog( context: context, - future: () => Matrix.of(context).client.reportContent( - event.roomId!, - event.eventId, - reason: reason.single, - score: score, - ), + future: () => Matrix.of(context).client.reportEvent( + event.roomId!, + event.eventId, + reason: reason, + score: score, + ), ); if (result.error != null) return; setState(() { @@ -754,11 +843,11 @@ class ChatController extends State selectedEvents.clear(); }); ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.contentHasBeenReported)), + SnackBar(content: Text(L10n.of(context).contentHasBeenReported)), ); } - void deleteErrorEventsAction() async { + Future deleteErrorEventsAction() async { try { if (selectedEvents.any((event) => event.status != EventStatus.error)) { throw Exception( @@ -777,28 +866,29 @@ class ChatController extends State } } - void redactEventsAction() async { + Future redactEventsAction() async { final reasonInput = selectedEvents.any((event) => event.status.isSent) ? await showTextInputDialog( context: context, - title: L10n.of(context)!.redactMessage, - message: L10n.of(context)!.redactMessageDescription, - isDestructiveAction: true, - textFields: [ - DialogTextField( - hintText: L10n.of(context)!.optionalRedactReason, - ), - ], - okLabel: L10n.of(context)!.remove, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).redactMessage, + message: L10n.of(context).redactMessageDescription, + isDestructive: true, + hintText: L10n.of(context).optionalRedactReason, + maxLength: 255, + maxLines: 3, + minLines: 1, + okLabel: L10n.of(context).remove, + cancelLabel: L10n.of(context).cancel, ) - : []; + : null; if (reasonInput == null) return; - final reason = reasonInput.single.isEmpty ? null : reasonInput.single; - for (final event in selectedEvents) { - await showFutureLoadingDialog( - context: context, - future: () async { + final reason = reasonInput.isEmpty ? null : reasonInput; + await showFutureLoadingDialog( + context: context, + futureWithProgress: (onProgress) async { + final count = selectedEvents.length; + for (final (i, event) in selectedEvents.indexed) { + onProgress(i / count); if (event.status.isSent) { if (event.canRedact) { await event.redactEvent(reason: reason); @@ -811,16 +901,17 @@ class ChatController extends State return; } final room = client.getRoomById(roomId)!; - await Event.fromJson(event.toJson(), room).redactEvent( - reason: reason, - ); + await Event.fromJson( + event.toJson(), + room, + ).redactEvent(reason: reason); } } else { await event.cancelSend(); } - }, - ); - } + } + }, + ); setState(() { showEmojiPicker = false; selectedEvents.clear(); @@ -839,7 +930,9 @@ class ChatController extends State for (final event in selectedEvents) { if (!event.status.isSent) return false; if (event.canRedact == false && - !(clients!.any((cl) => event.senderId == cl!.userID))) return false; + !(clients!.any((cl) => event.senderId == cl!.userID))) { + return false; + } } return true; } @@ -848,7 +941,8 @@ class ChatController extends State if (isArchived || !room.canChangeStateEvent(EventTypes.RoomPinnedEvents) || selectedEvents.length != 1 || - !selectedEvents.single.status.isSent) { + !selectedEvents.single.status.isSent || + activeThreadId != null) { return false; } return true; @@ -860,22 +954,30 @@ class ChatController extends State !selectedEvents.first.status.isSent) { return false; } - return currentRoomBundle - .any((cl) => selectedEvents.first.senderId == cl!.userID); + return currentRoomBundle.any( + (cl) => selectedEvents.first.senderId == cl!.userID, + ); } - void forwardEventsAction() async { - if (selectedEvents.length == 1) { - Matrix.of(context).shareContent = - selectedEvents.first.getDisplayEvent(timeline!).content; - } else { - Matrix.of(context).shareContent = { - 'msgtype': 'm.text', - 'body': _getSelectedEventString(), - }; - } + Future forwardEventsAction() async { + if (selectedEvents.isEmpty) return; + final timeline = this.timeline; + if (timeline == null) return; + + final forwardEvents = List.from( + selectedEvents, + ).map((event) => event.getDisplayEvent(timeline)).toList(); + + await showScaffoldDialog( + context: context, + builder: (context) => ShareScaffoldDialog( + items: forwardEvents + .map((event) => ContentShareItem(event.content)) + .toList(), + ), + ); + if (!mounted) return; setState(() => selectedEvents.clear()); - context.go('/rooms'); } void sendAgainAction() { @@ -900,15 +1002,32 @@ class ChatController extends State inputFocus.requestFocus(); } - void scrollToEventId(String eventId) async { - final eventIndex = timeline!.events.indexWhere((e) => e.eventId == eventId); + Future scrollToEventId( + String eventId, { + bool highlightEvent = true, + }) async { + final foundEvent = timeline!.events.firstWhereOrNull( + (event) => event.eventId == eventId, + ); + + final eventIndex = foundEvent == null + ? -1 + : timeline!.events + .filterByVisibleInGui( + exceptionEventId: eventId, + threadId: activeThreadId, + ) + .indexOf(foundEvent); + if (eventIndex == -1) { setState(() { timeline = null; _scrolledUp = false; loadTimelineFuture = _getTimeline(eventContextId: eventId).onError( - ErrorReporter(context, 'Unable to load timeline after scroll to ID') - .onErrorCallback, + ErrorReporter( + context, + 'Unable to load timeline after scroll to ID', + ).onErrorCallback, ); }); await loadTimelineFuture; @@ -917,24 +1036,29 @@ class ChatController extends State }); return; } - setState(() { - scrollToEventIdMarker = eventId; - }); + if (highlightEvent) { + setState(() { + scrollToEventIdMarker = eventId; + }); + } await scrollController.scrollToIndex( - eventIndex, + eventIndex + 1, + duration: FluffyThemes.animationDuration, preferPosition: AutoScrollPosition.middle, ); _updateScrollController(); } - void scrollDown() async { + Future scrollDown() async { if (!timeline!.allowNewEvent) { setState(() { timeline = null; _scrolledUp = false; loadTimelineFuture = _getTimeline().onError( - ErrorReporter(context, 'Unable to load timeline after scroll down') - .onErrorCallback, + ErrorReporter( + context, + 'Unable to load timeline after scroll down', + ).onErrorCallback, ); }); await loadTimelineFuture; @@ -943,27 +1067,8 @@ class ChatController extends State } void onEmojiSelected(_, Emoji? emoji) { - switch (emojiPickerType) { - case EmojiPickerType.reaction: - senEmojiReaction(emoji); - break; - case EmojiPickerType.keyboard: - typeEmoji(emoji); - onInputBarChanged(sendController.text); - break; - } - } - - void senEmojiReaction(Emoji? emoji) { - setState(() => showEmojiPicker = false); - if (emoji == null) return; - // make sure we don't send the same emoji twice - if (_allReactionEvents.any( - (e) => e.content.tryGetMap('m.relates_to')?['key'] == emoji.emoji, - )) { - return; - } - return sendEmojiAction(emoji.emoji); + typeEmoji(emoji); + onInputBarChanged(sendController.text); } void typeEmoji(Emoji? emoji) { @@ -982,44 +1087,18 @@ class ChatController extends State ); } - late Iterable _allReactionEvents; - void emojiPickerBackspace() { - switch (emojiPickerType) { - case EmojiPickerType.reaction: - setState(() => showEmojiPicker = false); - break; - case EmojiPickerType.keyboard: - sendController - ..text = sendController.text.characters.skipLast(1).toString() - ..selection = TextSelection.fromPosition( - TextPosition(offset: sendController.text.length), - ); - break; - } - } - - void pickEmojiReactionAction(Iterable allReactionEvents) async { - _allReactionEvents = allReactionEvents; - emojiPickerType = EmojiPickerType.reaction; - setState(() => showEmojiPicker = true); - } - - void sendEmojiAction(String? emoji) async { - final events = List.from(selectedEvents); - setState(() => selectedEvents.clear()); - for (final event in events) { - await room.sendReaction( - event.eventId, - emoji!, + sendController + ..text = sendController.text.characters.skipLast(1).toString() + ..selection = TextSelection.fromPosition( + TextPosition(offset: sendController.text.length), ); - } } void clearSelectedEvents() => setState(() { - selectedEvents.clear(); - showEmojiPicker = false; - }); + selectedEvents.clear(); + showEmojiPicker = false; + }); void clearSingleSelectedEvent() { if (selectedEvents.length <= 1) { @@ -1039,59 +1118,56 @@ class ChatController extends State setState(() { pendingText = sendController.text; editEvent = selectedEvents.first; - sendController.text = - editEvent!.getDisplayEvent(timeline!).calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), - withSenderNamePrefix: false, - hideReply: true, - ); + sendController.text = editEvent! + .getDisplayEvent(timeline!) + .calcLocalizedBodyFallback( + MatrixLocals(L10n.of(context)), + withSenderNamePrefix: false, + hideReply: true, + ); selectedEvents.clear(); }); inputFocus.requestFocus(); } - void goToNewRoomAction() async { - if (OkCancelResult.ok != - await showOkCancelAlertDialog( - context: context, - title: L10n.of(context)!.goToTheNewRoom, - message: room - .getState(EventTypes.RoomTombstone)! - .parsedTombstoneContent - .body, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - )) { - return; - } + Future goToNewRoomAction() async { final result = await showFutureLoadingDialog( context: context, - future: () => room.client.joinRoom( - room - .getState(EventTypes.RoomTombstone)! - .parsedTombstoneContent - .replacementRoom, - ), + future: () async { + final users = await room.requestParticipants( + [Membership.join, Membership.leave], + true, + false, + ); + users.sort((a, b) => a.powerLevel.compareTo(b.powerLevel)); + final via = users + .map((user) => user.id.domain) + .whereType() + .toSet() + .take(10) + .toList(); + return room.client.joinRoom( + room + .getState(EventTypes.RoomTombstone)! + .parsedTombstoneContent + .replacementRoom, + via: via, + ); + }, ); - await showFutureLoadingDialog( - context: context, - future: room.leave, - ); - if (result.error == null) { - context.go('/rooms/${result.result!}'); - } + if (result.error != null) return; + if (!mounted) return; + context.go('/rooms/${result.result!}'); + + await showFutureLoadingDialog(context: context, future: room.leave); } void onSelectMessage(Event event) { if (!event.redacted) { if (selectedEvents.contains(event)) { - setState( - () => selectedEvents.remove(event), - ); + setState(() => selectedEvents.remove(event)); } else { - setState( - () => selectedEvents.add(event), - ); + setState(() => selectedEvents.add(event)); } selectedEvents.sort( (a, b) => a.originServerTs.compareTo(b.originServerTs), @@ -1117,36 +1193,49 @@ class ChatController extends State return index + 1; } - void onInputBarSubmitted(_) { + void onInputBarSubmitted(String _) { send(); FocusScope.of(context).requestFocus(inputFocus); } - void onAddPopupMenuButtonSelected(String choice) { - if (choice == 'file') { - sendFileAction(); - } - if (choice == 'image') { - sendImageAction(); - } - if (choice == 'camera') { - openCameraAction(); - } - if (choice == 'camera-video') { - openVideoCameraAction(); - } - if (choice == 'location') { - sendLocationAction(); + void onAddPopupMenuButtonSelected(AddPopupMenuActions choice) { + room.client.getConfig(); + + switch (choice) { + case AddPopupMenuActions.image: + sendFileAction(type: FileType.image); + return; + case AddPopupMenuActions.video: + sendFileAction(type: FileType.video); + return; + case AddPopupMenuActions.file: + sendFileAction(); + return; + case AddPopupMenuActions.poll: + showAdaptiveBottomSheet( + context: context, + builder: (context) => StartPollBottomSheet(room: room), + ); + return; + case AddPopupMenuActions.photoCamera: + openCameraAction(); + return; + case AddPopupMenuActions.videoCamera: + openVideoCameraAction(); + return; + case AddPopupMenuActions.location: + sendLocationAction(); + return; } } - unpinEvent(String eventId) async { + Future unpinEvent(String eventId) async { final response = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.unpin, - message: L10n.of(context)!.confirmEventUnpin, - okLabel: L10n.of(context)!.unpin, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).unpin, + message: L10n.of(context).confirmEventUnpin, + okLabel: L10n.of(context).unpin, + cancelLabel: L10n.of(context).cancel, ); if (response == OkCancelResult.ok) { final events = room.pinnedEventIds @@ -1161,7 +1250,8 @@ class ChatController extends State void pinEvent() { final pinnedEventIds = room.pinnedEventIds; final selectedEventIds = selectedEvents.map((e) => e.eventId).toSet(); - final unpin = selectedEventIds.length == 1 && + final unpin = + selectedEventIds.length == 1 && pinnedEventIds.contains(selectedEventIds.single); if (unpin) { pinnedEventIds.removeWhere(selectedEventIds.contains); @@ -1186,7 +1276,7 @@ class ChatController extends State _storeInputTimeoutTimer?.cancel(); _storeInputTimeoutTimer = Timer(_storeInputTimeout, () async { - final prefs = await SharedPreferences.getInstance(); + final prefs = Matrix.of(context).store; await prefs.setString('draft_$roomId', text); }); if (text.endsWith(' ') && Matrix.of(context).hasComplexBundles) { @@ -1203,7 +1293,7 @@ class ChatController extends State } } } - if (AppConfig.sendTypingNotifications) { + if (AppSettings.sendTypingNotifications.value) { typingCoolDown?.cancel(); typingCoolDown = Timer(const Duration(seconds: 2), () { typingCoolDown = null; @@ -1232,7 +1322,7 @@ class ChatController extends State void showEventInfo([Event? event]) => (event ?? selectedEvents.single).showInfoDialog(context); - void onPhoneButtonTap() async { + Future onPhoneButtonTap() async { // VoIP required Android SDK 21 if (PlatformInfos.isAndroid) { DeviceInfoPlugin().androidInfo.then((value) { @@ -1240,28 +1330,28 @@ class ChatController extends State Navigator.pop(context); showOkAlertDialog( context: context, - title: L10n.of(context)!.unsupportedAndroidVersion, - message: L10n.of(context)!.unsupportedAndroidVersionLong, - okLabel: L10n.of(context)!.close, + title: L10n.of(context).unsupportedAndroidVersion, + message: L10n.of(context).unsupportedAndroidVersionLong, + okLabel: L10n.of(context).close, ); } }); } - final callType = await showModalActionSheet( + final callType = await showModalActionPopup( context: context, - title: L10n.of(context)!.warning, - message: L10n.of(context)!.videoCallsBetaWarning, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).warning, + message: L10n.of(context).videoCallsBetaWarning, + cancelLabel: L10n.of(context).cancel, actions: [ - SheetAction( - label: L10n.of(context)!.voiceCall, - icon: Icons.phone_outlined, - key: CallType.kVoice, + AdaptiveModalAction( + label: L10n.of(context).voiceCall, + icon: const Icon(Icons.phone_outlined), + value: CallType.kVoice, ), - SheetAction( - label: L10n.of(context)!.videoCall, - icon: Icons.video_call_outlined, - key: CallType.kVideo, + AdaptiveModalAction( + label: L10n.of(context).videoCall, + icon: const Icon(Icons.video_call_outlined), + value: CallType.kVideo, ), ], ); @@ -1271,60 +1361,49 @@ class ChatController extends State try { await voipPlugin!.voip.inviteToCall(room, callType); } catch (e) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(e.toLocalizedString(context))), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); } } void cancelReplyEventAction() => setState(() { - if (editEvent != null) { - sendController.text = pendingText; - pendingText = ''; - } - replyEvent = null; - editEvent = null; - }); + if (editEvent != null) { + sendController.text = pendingText; + pendingText = ''; + } + replyEvent = null; + editEvent = null; + }); late final ValueNotifier _displayChatDetailsColumn; - void toggleDisplayChatDetailsColumn() async { - await Matrix.of(context).store.setBool( - SettingKeys.displayChatDetailsColumn, - !_displayChatDetailsColumn.value, - ); + Future toggleDisplayChatDetailsColumn() async { + await AppSettings.displayChatDetailsColumn.setItem( + !_displayChatDetailsColumn.value, + ); _displayChatDetailsColumn.value = !_displayChatDetailsColumn.value; } @override - Widget build(BuildContext context) => Row( - children: [ - Expanded( - child: ChatView(this), - ), - AnimatedSize( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - child: ValueListenableBuilder( - valueListenable: _displayChatDetailsColumn, - builder: (context, displayChatDetailsColumn, _) { - if (!FluffyThemes.isThreeColumnMode(context) || - room.membership != Membership.join || - !displayChatDetailsColumn) { - return const SizedBox( - height: double.infinity, - width: 0, - ); - } - return Container( + Widget build(BuildContext context) { + final theme = Theme.of(context); + return Row( + children: [ + Expanded(child: ChatView(this)), + ValueListenableBuilder( + valueListenable: _displayChatDetailsColumn, + builder: (context, displayChatDetailsColumn, _) => + !FluffyThemes.isThreeColumnMode(context) || + room.membership != Membership.join || + !displayChatDetailsColumn + ? const SizedBox(height: double.infinity, width: 0) + : Container( width: FluffyThemes.columnWidth, clipBehavior: Clip.hardEdge, decoration: BoxDecoration( border: Border( - left: BorderSide( - width: 1, - color: Theme.of(context).dividerColor, - ), + left: BorderSide(width: 1, color: theme.dividerColor), ), ), child: ChatDetails( @@ -1334,21 +1413,19 @@ class ChatController extends State onPressed: toggleDisplayChatDetailsColumn, ), ), - ); - }, - ), - ), - ], - ); -} - -enum EmojiPickerType { reaction, keyboard } - -extension on List { - int get firstIndexWhereNotError { - if (isEmpty) return 0; - final index = indexWhere((event) => !event.status.isError); - if (index == -1) return length; - return index; + ), + ), + ], + ); } } + +enum AddPopupMenuActions { + image, + video, + file, + poll, + photoCamera, + videoCamera, + location, +} diff --git a/lib/pages/chat/chat_app_bar_list_tile.dart b/lib/pages/chat/chat_app_bar_list_tile.dart index 1e0ec8259..0f038a89e 100644 --- a/lib/pages/chat/chat_app_bar_list_tile.dart +++ b/lib/pages/chat/chat_app_bar_list_tile.dart @@ -2,7 +2,6 @@ import 'package:flutter/material.dart'; import 'package:flutter_linkify/flutter_linkify.dart'; -import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/utils/url_launcher.dart'; class ChatAppBarListTile extends StatelessWidget { @@ -11,6 +10,8 @@ class ChatAppBarListTile extends StatelessWidget { final Widget? trailing; final void Function()? onTap; + static const double fixedHeight = 40.0; + const ChatAppBarListTile({ super.key, this.leading, @@ -21,40 +22,43 @@ class ChatAppBarListTile extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); final leading = this.leading; final trailing = this.trailing; - final fontSize = AppConfig.messageFontSize * AppConfig.fontSizeFactor; - return InkWell( - onTap: onTap, - child: Row( - children: [ - if (leading != null) leading, - Expanded( - child: Padding( - padding: const EdgeInsets.symmetric(horizontal: 4.0), - child: Linkify( - text: title, - options: const LinkifyOptions(humanize: false), - maxLines: 1, - overflow: TextOverflow.ellipsis, - style: TextStyle( - color: Theme.of(context).colorScheme.onSurfaceVariant, + return SizedBox( + height: fixedHeight, + child: InkWell( + onTap: onTap, + child: Row( + children: [ + ?leading, + Expanded( + child: Padding( + padding: const EdgeInsets.symmetric(horizontal: 4.0), + child: Linkify( + text: title, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + options: const LinkifyOptions(humanize: false), + maxLines: 1, overflow: TextOverflow.ellipsis, - fontSize: fontSize, + style: TextStyle( + color: theme.colorScheme.onSurfaceVariant, + overflow: TextOverflow.ellipsis, + fontSize: 14, + ), + linkStyle: TextStyle( + color: theme.colorScheme.onSurfaceVariant, + fontSize: 14, + decoration: TextDecoration.underline, + decorationColor: theme.colorScheme.onSurfaceVariant, + ), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), ), - linkStyle: TextStyle( - color: Theme.of(context).colorScheme.onSurfaceVariant, - fontSize: fontSize, - decoration: TextDecoration.underline, - decorationColor: - Theme.of(context).colorScheme.onSurfaceVariant, - ), - onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), ), ), - ), - if (trailing != null) trailing, - ], + ?trailing, + ], + ), ), ); } diff --git a/lib/pages/chat/chat_app_bar_title.dart b/lib/pages/chat/chat_app_bar_title.dart index 5d3f34457..cbda4bc3d 100644 --- a/lib/pages/chat/chat_app_bar_title.dart +++ b/lib/pages/chat/chat_app_bar_title.dart @@ -1,12 +1,14 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat/chat.dart'; import 'package:fluffychat/utils/date_time_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/utils/sync_status_localization.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/presence_builder.dart'; @@ -18,7 +20,12 @@ class ChatAppBarTitle extends StatelessWidget { Widget build(BuildContext context) { final room = controller.room; if (controller.selectedEvents.isNotEmpty) { - return Text(controller.selectedEvents.length.toString()); + return Text( + controller.selectedEvents.length.toString(), + style: TextStyle( + color: Theme.of(context).colorScheme.onTertiaryContainer, + ), + ); } return InkWell( hoverColor: Colors.transparent, @@ -27,8 +34,8 @@ class ChatAppBarTitle extends StatelessWidget { onTap: controller.isArchived ? null : () => FluffyThemes.isThreeColumnMode(context) - ? controller.toggleDisplayChatDetailsColumn() - : context.go('/rooms/${room.id}/details'), + ? controller.toggleDisplayChatDetailsColumn() + : context.go('/rooms/${room.id}/details'), child: Row( children: [ Hero( @@ -36,7 +43,7 @@ class ChatAppBarTitle extends StatelessWidget { child: Avatar( mxContent: room.avatar, name: room.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), ), size: 32, ), @@ -44,40 +51,73 @@ class ChatAppBarTitle extends StatelessWidget { const SizedBox(width: 12), Expanded( child: Column( - crossAxisAlignment: CrossAxisAlignment.start, + crossAxisAlignment: .start, children: [ Text( - room.getLocalizedDisplayname(MatrixLocals(L10n.of(context)!)), + room.getLocalizedDisplayname(MatrixLocals(L10n.of(context))), maxLines: 1, overflow: TextOverflow.ellipsis, - style: const TextStyle( - fontSize: 16, - ), + style: const TextStyle(fontSize: 16), ), - AnimatedSize( - duration: FluffyThemes.animationDuration, - child: PresenceBuilder( - userId: room.directChatMatrixID, - builder: (context, presence) { - final lastActiveTimestamp = presence?.lastActiveTimestamp; - final style = Theme.of(context).textTheme.bodySmall; - if (presence?.currentlyActive == true) { - return Text( - L10n.of(context)!.currentlyActive, - style: style, - ); - } - if (lastActiveTimestamp != null) { - return Text( - L10n.of(context)!.lastActiveAgo( - lastActiveTimestamp.localizedTimeShort(context), - ), - style: style, - ); - } - return const SizedBox.shrink(); - }, - ), + StreamBuilder( + stream: room.client.onSyncStatus.stream, + builder: (context, snapshot) { + final status = + room.client.onSyncStatus.value ?? + const SyncStatusUpdate(SyncStatus.waitingForResponse); + final hide = + FluffyThemes.isColumnMode(context) || + (room.client.onSync.value != null && + status.status != SyncStatus.error && + room.client.prevBatch != null); + return AnimatedSize( + duration: FluffyThemes.animationDuration, + child: hide + ? PresenceBuilder( + userId: room.directChatMatrixID, + builder: (context, presence) { + final lastActiveTimestamp = + presence?.lastActiveTimestamp; + final style = TextStyle(fontSize: 11); + if (presence?.currentlyActive == true) { + return Text( + L10n.of(context).currentlyActive, + style: style, + ); + } + if (lastActiveTimestamp != null) { + return Text( + L10n.of(context).lastActiveAgo( + lastActiveTimestamp.localizedTimeShort( + context, + ), + ), + style: style, + ); + } + return const SizedBox.shrink(); + }, + ) + : Row( + children: [ + SizedBox.square( + dimension: 10, + child: CircularProgressIndicator.adaptive( + strokeWidth: 1, + value: status.progress, + ), + ), + const SizedBox(width: 4), + Expanded( + child: Text( + status.calcLocalizedString(context), + style: TextStyle(fontSize: 12), + ), + ), + ], + ), + ); + }, ), ], ), diff --git a/lib/pages/chat/chat_emoji_picker.dart b/lib/pages/chat/chat_emoji_picker.dart index 153abad67..be845bddd 100644 --- a/lib/pages/chat/chat_emoji_picker.dart +++ b/lib/pages/chat/chat_emoji_picker.dart @@ -1,10 +1,10 @@ import 'package:flutter/material.dart'; import 'package:emoji_picker_flutter/emoji_picker_flutter.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat/sticker_picker_dialog.dart'; import 'chat.dart'; @@ -14,14 +14,14 @@ class ChatEmojiPicker extends StatelessWidget { @override Widget build(BuildContext context) { - final ThemeData theme = Theme.of(context); + final theme = Theme.of(context); return AnimatedContainer( duration: FluffyThemes.animationDuration, curve: FluffyThemes.animationCurve, clipBehavior: Clip.hardEdge, decoration: const BoxDecoration(), height: controller.showEmojiPicker - ? MediaQuery.of(context).size.height / 2 + ? MediaQuery.sizeOf(context).height / 2 : 0, child: controller.showEmojiPicker ? DefaultTabController( @@ -30,8 +30,8 @@ class ChatEmojiPicker extends StatelessWidget { children: [ TabBar( tabs: [ - Tab(text: L10n.of(context)!.emojis), - Tab(text: L10n.of(context)!.stickers), + Tab(text: L10n.of(context).emojis), + Tab(text: L10n.of(context).stickers), ], ), Expanded( @@ -41,21 +41,23 @@ class ChatEmojiPicker extends StatelessWidget { onEmojiSelected: controller.onEmojiSelected, onBackspacePressed: controller.emojiPickerBackspace, config: Config( + locale: Localizations.localeOf(context), emojiViewConfig: EmojiViewConfig( noRecents: const NoRecent(), - backgroundColor: Theme.of(context) - .colorScheme - .onInverseSurface, + backgroundColor: + theme.colorScheme.onInverseSurface, ), bottomActionBarConfig: const BottomActionBarConfig( enabled: false, ), categoryViewConfig: CategoryViewConfig( backspaceColor: theme.colorScheme.primary, - iconColor: - theme.colorScheme.primary.withOpacity(0.5), + iconColor: theme.colorScheme.primary.withAlpha( + 128, + ), iconColorSelected: theme.colorScheme.primary, indicatorColor: theme.colorScheme.primary, + backgroundColor: theme.colorScheme.surface, ), skinToneConfig: SkinToneConfig( dialogBackgroundColor: Color.lerp( @@ -77,6 +79,8 @@ class ChatEmojiPicker extends StatelessWidget { 'url': sticker.url.toString(), }, type: EventTypes.Sticker, + threadRootEventId: controller.activeThreadId, + threadLastEventId: controller.threadLastEventId, ); controller.hideEmojiPicker(); }, @@ -97,9 +101,15 @@ class NoRecent extends StatelessWidget { @override Widget build(BuildContext context) { - return Text( - L10n.of(context)!.emoteKeyboardNoRecents, - style: Theme.of(context).textTheme.bodyLarge, + return Center( + child: Padding( + padding: const EdgeInsets.all(16.0), + child: Text( + L10n.of(context).emoteKeyboardNoRecents, + style: Theme.of(context).textTheme.bodyLarge, + textAlign: TextAlign.center, + ), + ), ); } } diff --git a/lib/pages/chat/chat_event_list.dart b/lib/pages/chat/chat_event_list.dart index 2d56aa5c0..600d0af41 100644 --- a/lib/pages/chat/chat_event_list.dart +++ b/lib/pages/chat/chat_event_list.dart @@ -1,33 +1,40 @@ +import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; -import 'package:matrix/matrix.dart'; +import 'package:collection/collection.dart'; import 'package:scroll_to_index/scroll_to_index.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat/chat.dart'; import 'package:fluffychat/pages/chat/events/message.dart'; import 'package:fluffychat/pages/chat/seen_by_row.dart'; import 'package:fluffychat/pages/chat/typing_indicators.dart'; -import 'package:fluffychat/pages/user_bottom_sheet/user_bottom_sheet.dart'; import 'package:fluffychat/utils/account_config.dart'; -import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/filtered_timeline_extension.dart'; import 'package:fluffychat/utils/platform_infos.dart'; class ChatEventList extends StatelessWidget { final ChatController controller; - const ChatEventList({ - super.key, - required this.controller, - }); + + const ChatEventList({super.key, required this.controller}); @override Widget build(BuildContext context) { + final timeline = controller.timeline; + + if (timeline == null) { + return const Center(child: CupertinoActivityIndicator()); + } + final theme = Theme.of(context); + + final colors = [theme.secondaryBubbleColor, theme.bubbleColor]; + final horizontalPadding = FluffyThemes.isColumnMode(context) ? 8.0 : 0.0; - final events = controller.timeline!.events - .where((event) => event.isVisibleInGui) - .toList(); + final events = timeline.events.filterByVisibleInGui( + threadId: controller.activeThreadId, + ); final animateInEventIndex = controller.animateInEventIndex; // create a map of eventId --> index to greatly improve performance of @@ -57,23 +64,23 @@ class ChatEventList extends StatelessWidget { (BuildContext context, int i) { // Footer to display typing indicator and read receipts: if (i == 0) { - if (controller.timeline!.isRequestingFuture) { - return const Center( - child: CircularProgressIndicator.adaptive(strokeWidth: 2), - ); - } - if (controller.timeline!.canRequestFuture) { + if (timeline.canRequestFuture) { return Center( - child: IconButton( - onPressed: controller.requestFuture, - icon: const Icon(Icons.refresh_outlined), + child: TextButton.icon( + onPressed: timeline.isRequestingFuture + ? null + : controller.requestFuture, + icon: timeline.isRequestingFuture + ? CircularProgressIndicator.adaptive(strokeWidth: 2) + : const Icon(Icons.arrow_downward_outlined), + label: Text(L10n.of(context).loadMore), ), ); } return Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ - SeenByRow(controller), + SeenByRow(event: events.first), TypingIndicators(controller), ], ); @@ -81,34 +88,55 @@ class ChatEventList extends StatelessWidget { // Request history button or progress indicator: if (i == events.length + 1) { - if (controller.timeline!.isRequestingHistory) { - return const Center( - child: CircularProgressIndicator.adaptive(strokeWidth: 2), - ); + if (controller.activeThreadId != null || + !timeline.canRequestHistory) { + return const SizedBox.shrink(); } - if (controller.timeline!.canRequestHistory) { - return Builder( - builder: (context) { - WidgetsBinding.instance - .addPostFrameCallback(controller.requestHistory); - return Center( - child: IconButton( - onPressed: controller.requestHistory, - icon: const Icon(Icons.refresh_outlined), - ), + return Builder( + builder: (context) { + final visibleIndex = timeline.events.lastIndexWhere( + (event) => !event.isCollapsedState && event.isVisibleInGui, + ); + if (visibleIndex > timeline.events.length - 50) { + WidgetsBinding.instance.addPostFrameCallback( + controller.requestHistory, ); - }, - ); - } - return const SizedBox.shrink(); + } + return Center( + child: TextButton.icon( + onPressed: timeline.isRequestingHistory + ? null + : controller.requestHistory, + icon: timeline.isRequestingHistory + ? CircularProgressIndicator.adaptive(strokeWidth: 2) + : const Icon(Icons.arrow_upward_outlined), + label: Text(L10n.of(context).loadMore), + ), + ); + }, + ); } i--; // The message at this index: final event = events[i]; - final animateIn = animateInEventIndex != null && - controller.timeline!.events.length > animateInEventIndex && - event == controller.timeline!.events[animateInEventIndex]; + final animateIn = + animateInEventIndex != null && + timeline.events.length > animateInEventIndex && + event == timeline.events[animateInEventIndex]; + + final nextEvent = i + 1 < events.length ? events[i + 1] : null; + final previousEvent = i > 0 ? events[i - 1] : null; + + // Collapsed state event + final canExpand = + event.isCollapsedState && + nextEvent?.isCollapsedState == true && + previousEvent?.isCollapsedState != true; + final isCollapsed = + event.isCollapsedState && + previousEvent?.isCollapsedState == true && + !controller.expandedEventIds.contains(event.eventId); return AutoScrollTag( key: ValueKey(event.eventId), @@ -116,37 +144,45 @@ class ChatEventList extends StatelessWidget { controller: controller.scrollController, child: Message( event, + bigEmojis: controller.bigEmojis, animateIn: animateIn, resetAnimateIn: () { controller.animateInEventIndex = null; }, onSwipe: () => controller.replyAction(replyTo: event), onInfoTab: controller.showEventInfo, - onAvatarTab: (Event event) => showAdaptiveBottomSheet( - context: context, - builder: (c) => UserBottomSheet( - user: event.senderFromMemoryOrFallback, - outerContext: context, - onMention: () => controller.sendController.text += - '${event.senderFromMemoryOrFallback.mention} ', - ), - ), + onMention: () => controller.sendController.text += + '${event.senderFromMemoryOrFallback.mention} ', highlightMarker: controller.scrollToEventIdMarker == event.eventId, onSelect: controller.onSelectMessage, - scrollToEventId: (String eventId) => - controller.scrollToEventId(eventId), + scrollToEventId: controller.scrollToEventId, longPressSelect: controller.selectedEvents.isNotEmpty, - selected: controller.selectedEvents - .any((e) => e.eventId == event.eventId), - timeline: controller.timeline!, + selected: controller.selectedEvents.any( + (e) => e.eventId == event.eventId, + ), + singleSelected: + controller.selectedEvents.singleOrNull?.eventId == + event.eventId, + onEdit: controller.editSelectedEventAction, + timeline: timeline, displayReadMarker: - controller.readMarkerEventId == event.eventId && - controller.timeline?.allowNewEvent == false, - nextEvent: i + 1 < events.length ? events[i + 1] : null, - previousEvent: i > 0 ? events[i - 1] : null, - avatarPresenceBackgroundColor: - hasWallpaper ? Colors.transparent : null, + i > 0 && controller.readMarkerEventId == event.eventId, + nextEvent: nextEvent, + previousEvent: previousEvent, + wallpaperMode: hasWallpaper, + scrollController: controller.scrollController, + colors: colors, + isCollapsed: isCollapsed, + enterThread: controller.activeThreadId == null + ? controller.enterThread + : null, + onExpand: canExpand + ? () => controller.expandEventsFrom( + event, + !controller.expandedEventIds.contains(event.eventId), + ) + : null, ), ); }, diff --git a/lib/pages/chat/chat_input_row.dart b/lib/pages/chat/chat_input_row.dart index b548c606b..eb92c55c1 100644 --- a/lib/pages/chat/chat_input_row.dart +++ b/lib/pages/chat/chat_input_row.dart @@ -1,14 +1,17 @@ import 'package:flutter/material.dart'; -import 'package:flutter/services.dart'; import 'package:animations/animations.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:keyboard_shortcuts/keyboard_shortcuts.dart'; +import 'package:emoji_picker_flutter/locales/default_emoji_set_locale.dart'; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat/recording_input_row.dart'; +import 'package:fluffychat/pages/chat/recording_view_model.dart'; +import 'package:fluffychat/utils/other_party_can_receive.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/hover_builder.dart'; import 'package:fluffychat/widgets/matrix.dart'; import '../../config/themes.dart'; import 'chat.dart'; @@ -17,288 +20,397 @@ import 'input_bar.dart'; class ChatInputRow extends StatelessWidget { final ChatController controller; + static const double height = 56.0; + const ChatInputRow(this.controller, {super.key}); @override Widget build(BuildContext context) { - if (controller.showEmojiPicker && - controller.emojiPickerType == EmojiPickerType.reaction) { - return const SizedBox.shrink(); + final theme = Theme.of(context); + final textMessageOnly = + controller.sendController.text.isNotEmpty || + controller.replyEvent != null || + controller.editEvent != null; + + if (!controller.room.otherPartyCanReceiveMessages) { + return Center( + child: Padding( + padding: const EdgeInsets.all(12.0), + child: Text( + L10n.of(context).otherPartyNotLoggedIn, + style: theme.textTheme.bodySmall, + textAlign: TextAlign.center, + ), + ), + ); } - const height = 48.0; - return Row( - crossAxisAlignment: CrossAxisAlignment.end, - mainAxisAlignment: MainAxisAlignment.spaceBetween, - children: controller.selectMode - ? [ - if (controller.selectedEvents - .every((event) => event.status == EventStatus.error)) - SizedBox( - height: height, - child: TextButton( - style: TextButton.styleFrom( - foregroundColor: Theme.of(context).colorScheme.error, + + final selectedTextButtonStyle = TextButton.styleFrom( + foregroundColor: theme.colorScheme.onTertiaryContainer, + ); + + return RecordingViewModel( + builder: (context, recordingViewModel) { + if (recordingViewModel.isRecording) { + return RecordingInputRow( + state: recordingViewModel, + onSend: controller.onVoiceMessageSend, + ); + } + return Row( + crossAxisAlignment: .end, + mainAxisAlignment: .spaceBetween, + children: controller.selectMode + ? [ + if (controller.selectedEvents.every( + (event) => event.status == EventStatus.error, + )) + SizedBox( + height: height, + child: TextButton( + style: TextButton.styleFrom( + foregroundColor: theme.colorScheme.error, + ), + onPressed: controller.deleteErrorEventsAction, + child: Row( + children: [ + const Icon(Icons.delete_forever_outlined), + Text(L10n.of(context).delete), + ], + ), + ), + ) + else + SizedBox( + height: height, + child: TextButton( + style: selectedTextButtonStyle, + onPressed: controller.forwardEventsAction, + child: Row( + children: [ + const Icon(Icons.keyboard_arrow_left_outlined), + Text(L10n.of(context).forward), + ], + ), + ), ), - onPressed: controller.deleteErrorEventsAction, - child: Row( - children: [ - const Icon(Icons.delete), - Text(L10n.of(context)!.delete), + controller.selectedEvents.length == 1 + ? controller.selectedEvents.first + .getDisplayEvent(controller.timeline!) + .status + .isSent + ? SizedBox( + height: height, + child: TextButton( + style: selectedTextButtonStyle, + onPressed: controller.replyAction, + child: Row( + children: [ + Text(L10n.of(context).reply), + const Icon(Icons.keyboard_arrow_right), + ], + ), + ), + ) + : SizedBox( + height: height, + child: TextButton( + style: selectedTextButtonStyle, + onPressed: controller.sendAgainAction, + child: Row( + children: [ + Text(L10n.of(context).tryToSendAgain), + const SizedBox(width: 4), + const Icon(Icons.send_outlined, size: 16), + ], + ), + ), + ) + : const SizedBox.shrink(), + ] + : [ + const SizedBox(width: 8), + AnimatedContainer( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + width: textMessageOnly ? 0 : 48, + height: height, + alignment: Alignment.center, + decoration: const BoxDecoration(), + clipBehavior: Clip.hardEdge, + child: PopupMenuButton( + useRootNavigator: true, + icon: const Icon(Icons.add_circle_outline), + iconColor: theme.colorScheme.onPrimaryContainer, + onSelected: controller.onAddPopupMenuButtonSelected, + itemBuilder: (BuildContext context) => [ + if (PlatformInfos.isMobile) + PopupMenuItem( + value: AddPopupMenuActions.location, + child: ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.onPrimaryContainer, + foregroundColor: + theme.colorScheme.primaryContainer, + child: const Icon(Icons.gps_fixed_outlined), + ), + title: Text(L10n.of(context).shareLocation), + contentPadding: const EdgeInsets.all(0), + ), + ), + PopupMenuItem( + value: AddPopupMenuActions.poll, + child: ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.onPrimaryContainer, + foregroundColor: + theme.colorScheme.primaryContainer, + child: const Icon(Icons.poll_outlined), + ), + title: Text(L10n.of(context).startPoll), + contentPadding: const EdgeInsets.all(0), + ), + ), + PopupMenuItem( + value: AddPopupMenuActions.image, + child: ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.onPrimaryContainer, + foregroundColor: + theme.colorScheme.primaryContainer, + child: const Icon(Icons.photo_outlined), + ), + title: Text(L10n.of(context).sendImage), + contentPadding: const EdgeInsets.all(0), + ), + ), + PopupMenuItem( + value: AddPopupMenuActions.video, + child: ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.onPrimaryContainer, + foregroundColor: + theme.colorScheme.primaryContainer, + child: const Icon( + Icons.video_camera_back_outlined, + ), + ), + title: Text(L10n.of(context).sendVideo), + contentPadding: const EdgeInsets.all(0), + ), + ), + PopupMenuItem( + value: AddPopupMenuActions.file, + child: ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.onPrimaryContainer, + foregroundColor: + theme.colorScheme.primaryContainer, + child: const Icon(Icons.attachment_outlined), + ), + title: Text(L10n.of(context).sendFile), + contentPadding: const EdgeInsets.all(0), + ), + ), ], ), ), - ) - else - SizedBox( - height: height, - child: TextButton( - onPressed: controller.forwardEventsAction, - child: Row( - children: [ - const Icon(Icons.keyboard_arrow_left_outlined), - Text(L10n.of(context)!.forward), - ], - ), - ), - ), - controller.selectedEvents.length == 1 - ? controller.selectedEvents.first - .getDisplayEvent(controller.timeline!) - .status - .isSent - ? SizedBox( - height: height, - child: TextButton( - onPressed: controller.replyAction, - child: Row( - children: [ - Text(L10n.of(context)!.reply), - const Icon(Icons.keyboard_arrow_right), - ], + if (PlatformInfos.isMobile) + AnimatedContainer( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + width: textMessageOnly ? 0 : 48, + height: height, + alignment: Alignment.center, + decoration: const BoxDecoration(), + clipBehavior: Clip.hardEdge, + child: PopupMenuButton( + useRootNavigator: true, + icon: const Icon(Icons.camera_alt_outlined), + onSelected: controller.onAddPopupMenuButtonSelected, + iconColor: theme.colorScheme.onPrimaryContainer, + itemBuilder: (context) => [ + PopupMenuItem( + value: AddPopupMenuActions.videoCamera, + child: ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.onPrimaryContainer, + foregroundColor: + theme.colorScheme.primaryContainer, + child: const Icon(Icons.videocam_outlined), + ), + title: Text(L10n.of(context).recordAVideo), + contentPadding: const EdgeInsets.all(0), ), ), - ) - : SizedBox( - height: height, - child: TextButton( - onPressed: controller.sendAgainAction, - child: Row( - children: [ - Text(L10n.of(context)!.tryToSendAgain), - const SizedBox(width: 4), - const Icon(Icons.send_outlined, size: 16), - ], + PopupMenuItem( + value: AddPopupMenuActions.photoCamera, + child: ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.onPrimaryContainer, + foregroundColor: + theme.colorScheme.primaryContainer, + child: const Icon(Icons.camera_alt_outlined), + ), + title: Text(L10n.of(context).takeAPhoto), + contentPadding: const EdgeInsets.all(0), ), ), - ) - : const SizedBox.shrink(), - ] - : [ - const SizedBox(width: 4), - KeyBoardShortcuts( - keysToPress: { - LogicalKeyboardKey.altLeft, - LogicalKeyboardKey.keyA, - }, - onKeysPressed: () => - controller.onAddPopupMenuButtonSelected('file'), - helpLabel: L10n.of(context)!.sendFile, - child: AnimatedContainer( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - height: height, - width: controller.sendController.text.isEmpty ? height : 0, - alignment: Alignment.center, - clipBehavior: Clip.hardEdge, - decoration: const BoxDecoration(), - child: PopupMenuButton( - icon: const Icon(Icons.add_outlined), - onSelected: controller.onAddPopupMenuButtonSelected, - itemBuilder: (BuildContext context) => - >[ - PopupMenuItem( - value: 'file', - child: ListTile( - leading: const CircleAvatar( - backgroundColor: Colors.green, - foregroundColor: Colors.white, - child: Icon(Icons.attachment_outlined), - ), - title: Text(L10n.of(context)!.sendFile), - contentPadding: const EdgeInsets.all(0), - ), - ), - PopupMenuItem( - value: 'image', - child: ListTile( - leading: const CircleAvatar( - backgroundColor: Colors.blue, - foregroundColor: Colors.white, - child: Icon(Icons.image_outlined), - ), - title: Text(L10n.of(context)!.sendImage), - contentPadding: const EdgeInsets.all(0), - ), - ), - if (PlatformInfos.isMobile) - PopupMenuItem( - value: 'camera', - child: ListTile( - leading: const CircleAvatar( - backgroundColor: Colors.purple, - foregroundColor: Colors.white, - child: Icon(Icons.camera_alt_outlined), - ), - title: Text(L10n.of(context)!.openCamera), - contentPadding: const EdgeInsets.all(0), - ), - ), - if (PlatformInfos.isMobile) - PopupMenuItem( - value: 'camera-video', - child: ListTile( - leading: const CircleAvatar( - backgroundColor: Colors.red, - foregroundColor: Colors.white, - child: Icon(Icons.videocam_outlined), - ), - title: Text(L10n.of(context)!.openVideoCamera), - contentPadding: const EdgeInsets.all(0), - ), - ), - if (PlatformInfos.isMobile) - PopupMenuItem( - value: 'location', - child: ListTile( - leading: const CircleAvatar( - backgroundColor: Colors.brown, - foregroundColor: Colors.white, - child: Icon(Icons.gps_fixed_outlined), - ), - title: Text(L10n.of(context)!.shareLocation), - contentPadding: const EdgeInsets.all(0), - ), - ), - ], - ), - ), - ), - Container( - height: height, - width: height, - alignment: Alignment.center, - child: KeyBoardShortcuts( - keysToPress: { - LogicalKeyboardKey.altLeft, - LogicalKeyboardKey.keyE, - }, - onKeysPressed: controller.emojiPickerAction, - helpLabel: L10n.of(context)!.emojis, - child: IconButton( - tooltip: L10n.of(context)!.emojis, - icon: PageTransitionSwitcher( - transitionBuilder: ( - Widget child, - Animation primaryAnimation, - Animation secondaryAnimation, - ) { - return SharedAxisTransition( - animation: primaryAnimation, - secondaryAnimation: secondaryAnimation, - transitionType: SharedAxisTransitionType.scaled, - fillColor: Colors.transparent, - child: child, - ); - }, - child: Icon( - controller.showEmojiPicker - ? Icons.keyboard - : Icons.add_reaction_outlined, - key: ValueKey(controller.showEmojiPicker), + ], ), ), - onPressed: controller.emojiPickerAction, + Container( + height: height, + width: 48, + alignment: Alignment.center, + child: IconButton( + tooltip: L10n.of(context).emojis, + color: theme.colorScheme.onPrimaryContainer, + icon: PageTransitionSwitcher( + transitionBuilder: + ( + Widget child, + Animation primaryAnimation, + Animation secondaryAnimation, + ) { + return SharedAxisTransition( + animation: primaryAnimation, + secondaryAnimation: secondaryAnimation, + transitionType: SharedAxisTransitionType.scaled, + fillColor: Colors.transparent, + child: child, + ); + }, + child: Icon( + controller.showEmojiPicker + ? Icons.keyboard + : Icons.add_reaction_outlined, + key: ValueKey(controller.showEmojiPicker), + ), + ), + onPressed: controller.emojiPickerAction, + ), ), - ), - ), - if (Matrix.of(context).isMultiAccount && - Matrix.of(context).hasComplexBundles && - Matrix.of(context).currentBundle!.length > 1) - Container( - width: height, - height: height, - alignment: Alignment.center, - child: _ChatAccountPicker(controller), - ), - Expanded( - child: Padding( - padding: const EdgeInsets.symmetric(vertical: 0.0), - child: InputBar( - room: controller.room, - minLines: 1, - maxLines: 8, - autofocus: !PlatformInfos.isMobile, - keyboardType: TextInputType.multiline, - textInputAction: - AppConfig.sendOnEnter == true && PlatformInfos.isMobile + if (Matrix.of(context).isMultiAccount && + Matrix.of(context).hasComplexBundles && + Matrix.of(context).currentBundle!.length > 1) + Container( + height: height, + width: 48, + alignment: Alignment.center, + child: _ChatAccountPicker(controller), + ), + Expanded( + child: Padding( + padding: const EdgeInsets.symmetric(vertical: 2.0), + child: InputBar( + room: controller.room, + minLines: 1, + maxLines: 8, + autofocus: !PlatformInfos.isMobile, + keyboardType: TextInputType.multiline, + textInputAction: + AppSettings.sendOnEnter.value == true && + PlatformInfos.isMobile ? TextInputAction.send : null, - onSubmitted: controller.onInputBarSubmitted, - onSubmitImage: controller.sendImageFromClipBoard, - focusNode: controller.inputFocus, - controller: controller.sendController, - decoration: InputDecoration( - contentPadding: const EdgeInsets.only( - left: 6.0, - right: 6.0, - bottom: 6.0, - top: 3.0, + onSubmitted: controller.onInputBarSubmitted, + onSubmitImage: controller.sendImageFromClipBoard, + focusNode: controller.inputFocus, + controller: controller.sendController, + decoration: InputDecoration( + contentPadding: const EdgeInsets.only( + left: 6.0, + right: 6.0, + bottom: 6.0, + top: 3.0, + ), + counter: const SizedBox.shrink(), + hintText: L10n.of(context).writeAMessage, + hintMaxLines: 1, + border: InputBorder.none, + enabledBorder: InputBorder.none, + filled: false, + ), + onChanged: controller.onInputBarChanged, + suggestionEmojis: + getDefaultEmojiLocale( + AppSettings.emojiSuggestionLocale.value.isNotEmpty + ? Locale( + AppSettings.emojiSuggestionLocale.value, + ) + : Localizations.localeOf(context), + ).fold( + [], + (emojis, category) => + emojis..addAll(category.emoji), + ), ), - hintText: L10n.of(context)!.writeAMessage, - hintMaxLines: 1, - border: InputBorder.none, - enabledBorder: InputBorder.none, - filled: false, ), - onChanged: controller.onInputBarChanged, ), - ), - ), - Container( - height: height, - width: height, - alignment: Alignment.center, - child: PlatformInfos.platformCanRecord && - controller.sendController.text.isEmpty - ? FloatingActionButton.small( - tooltip: L10n.of(context)!.voiceMessage, - onPressed: controller.voiceMessageAction, - elevation: 0, - heroTag: null, - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(height), - ), - backgroundColor: Theme.of(context).colorScheme.primary, - foregroundColor: - Theme.of(context).colorScheme.onPrimary, - child: const Icon(Icons.mic_none_outlined), - ) - : FloatingActionButton.small( - tooltip: L10n.of(context)!.send, - onPressed: controller.send, - elevation: 0, - heroTag: null, - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(height), - ), - backgroundColor: - Theme.of(context).colorScheme.onPrimaryContainer, - foregroundColor: - Theme.of(context).colorScheme.onPrimary, - child: const Icon(Icons.send_outlined), - ), - ), - ], + Container( + height: height, + width: height, + alignment: Alignment.center, + child: + PlatformInfos.platformCanRecord && + !controller.sendController.text.isNotEmpty && + controller.editEvent == null + ? HoverBuilder( + builder: (context, hovered) => IconButton( + tooltip: L10n.of(context).voiceMessage, + onPressed: hovered + ? () => recordingViewModel.startRecording( + controller.room, + ) + : () => ScaffoldMessenger.of(context) + .showSnackBar( + SnackBar( + margin: EdgeInsets.only( + bottom: height + 16, + left: 16, + right: 16, + top: 16, + ), + showCloseIcon: true, + content: Text( + L10n.of( + context, + ).longPressToRecordVoiceMessage, + ), + ), + ), + onLongPress: () => recordingViewModel + .startRecording(controller.room), + style: IconButton.styleFrom( + backgroundColor: theme.bubbleColor, + foregroundColor: theme.onBubbleColor, + ), + icon: Icon( + hovered ? Icons.mic : Icons.mic_none_outlined, + ), + ), + ) + : IconButton( + tooltip: L10n.of(context).send, + onPressed: controller.send, + style: IconButton.styleFrom( + backgroundColor: theme.bubbleColor, + foregroundColor: theme.onBubbleColor, + ), + icon: const Icon(Icons.send_outlined), + ), + ), + ], + ); + }, ); } } @@ -309,9 +421,9 @@ class _ChatAccountPicker extends StatelessWidget { const _ChatAccountPicker(this.controller); void _popupMenuButtonSelected(String mxid, BuildContext context) { - final client = Matrix.of(context) - .currentBundle! - .firstWhere((cl) => cl!.userID == mxid, orElse: () => null); + final client = Matrix.of( + context, + ).currentBundle!.firstWhere((cl) => cl!.userID == mxid, orElse: () => null); if (client == null) { Logs().w('Attempted to switch to a non-existing client $mxid'); return; @@ -327,17 +439,19 @@ class _ChatAccountPicker extends StatelessWidget { child: FutureBuilder( future: controller.sendingClient.fetchOwnProfile(), builder: (context, snapshot) => PopupMenuButton( + useRootNavigator: true, onSelected: (mxid) => _popupMenuButtonSelected(mxid, context), itemBuilder: (BuildContext context) => clients .map( - (client) => PopupMenuItem( + (client) => PopupMenuItem( value: client!.userID, child: FutureBuilder( future: client.fetchOwnProfile(), builder: (context, snapshot) => ListTile( leading: Avatar( mxContent: snapshot.data?.avatarUrl, - name: snapshot.data?.displayName ?? + name: + snapshot.data?.displayName ?? client.userID!.localpart, size: 20, ), @@ -350,7 +464,8 @@ class _ChatAccountPicker extends StatelessWidget { .toList(), child: Avatar( mxContent: snapshot.data?.avatarUrl, - name: snapshot.data?.displayName ?? + name: + snapshot.data?.displayName ?? Matrix.of(context).client.userID!.localpart, size: 20, ), diff --git a/lib/pages/chat/chat_view.dart b/lib/pages/chat/chat_view.dart index 9974a9e70..2c19524b7 100644 --- a/lib/pages/chat/chat_view.dart +++ b/lib/pages/chat/chat_view.dart @@ -1,23 +1,25 @@ +import 'dart:ui' as ui; + import 'package:flutter/material.dart'; import 'package:badges/badges.dart'; import 'package:desktop_drop/desktop_drop.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat/chat.dart'; import 'package:fluffychat/pages/chat/chat_app_bar_list_tile.dart'; import 'package:fluffychat/pages/chat/chat_app_bar_title.dart'; import 'package:fluffychat/pages/chat/chat_event_list.dart'; import 'package:fluffychat/pages/chat/encryption_button.dart'; import 'package:fluffychat/pages/chat/pinned_events.dart'; -import 'package:fluffychat/pages/chat/reactions_picker.dart'; import 'package:fluffychat/pages/chat/reply_display.dart'; import 'package:fluffychat/utils/account_config.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; import 'package:fluffychat/widgets/chat_settings_popup_menu.dart'; -import 'package:fluffychat/widgets/connection_status_header.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; import 'package:fluffychat/widgets/unread_rooms_badge.dart'; @@ -32,106 +34,14 @@ class ChatView extends StatelessWidget { const ChatView(this.controller, {super.key}); - List _appBarActions(BuildContext context) { - if (controller.selectMode) { - return [ - if (controller.canEditSelectedEvents) - IconButton( - icon: const Icon(Icons.edit_outlined), - tooltip: L10n.of(context)!.edit, - onPressed: controller.editSelectedEventAction, - ), - IconButton( - icon: const Icon(Icons.copy_outlined), - tooltip: L10n.of(context)!.copy, - onPressed: controller.copyEventsAction, - ), - if (controller.canSaveSelectedEvent) - // Use builder context to correctly position the share dialog on iPad - Builder( - builder: (context) => IconButton( - icon: Icon(Icons.adaptive.share), - tooltip: L10n.of(context)!.share, - onPressed: () => controller.saveSelectedEvent(context), - ), - ), - if (controller.canPinSelectedEvents) - IconButton( - icon: const Icon(Icons.push_pin_outlined), - onPressed: controller.pinEvent, - tooltip: L10n.of(context)!.pinMessage, - ), - if (controller.canRedactSelectedEvents) - IconButton( - icon: const Icon(Icons.delete_outlined), - tooltip: L10n.of(context)!.redactMessage, - onPressed: controller.redactEventsAction, - ), - if (controller.selectedEvents.length == 1) - PopupMenuButton<_EventContextAction>( - onSelected: (action) { - switch (action) { - case _EventContextAction.info: - controller.showEventInfo(); - controller.clearSelectedEvents(); - break; - case _EventContextAction.report: - controller.reportEventAction(); - break; - } - }, - itemBuilder: (context) => [ - PopupMenuItem( - value: _EventContextAction.info, - child: Row( - mainAxisSize: MainAxisSize.min, - children: [ - const Icon(Icons.info_outlined), - const SizedBox(width: 12), - Text(L10n.of(context)!.messageInfo), - ], - ), - ), - if (controller.selectedEvents.single.status.isSent) - PopupMenuItem( - value: _EventContextAction.report, - child: Row( - mainAxisSize: MainAxisSize.min, - children: [ - const Icon( - Icons.shield_outlined, - color: Colors.red, - ), - const SizedBox(width: 12), - Text(L10n.of(context)!.reportMessage), - ], - ), - ), - ], - ), - ]; - } else if (!controller.room.isArchived) { - return [ - if (Matrix.of(context).voipPlugin != null && - controller.room.isDirectChat) - IconButton( - onPressed: controller.onPhoneButtonTap, - icon: const Icon(Icons.call_outlined), - tooltip: L10n.of(context)!.placeCall, - ), - EncryptionButton(controller.room), - ChatSettingsPopupMenu(controller.room, true), - ]; - } - return []; - } - @override Widget build(BuildContext context) { + final theme = Theme.of(context); if (controller.room.membership == Membership.invite) { showFutureLoadingDialog( context: context, future: () => controller.room.join(), + exceptionContext: ExceptionContext.joinRoom, ); } final bottomSheetPadding = FluffyThemes.isColumnMode(context) ? 16.0 : 8.0; @@ -140,13 +50,18 @@ class ChatView extends StatelessWidget { final accountConfig = Matrix.of(context).client.applicationAccountConfig; return PopScope( - canPop: controller.selectedEvents.isEmpty && !controller.showEmojiPicker, - onPopInvoked: (pop) async { + canPop: + controller.selectedEvents.isEmpty && + !controller.showEmojiPicker && + controller.activeThreadId == null, + onPopInvokedWithResult: (pop, _) async { if (pop) return; if (controller.selectedEvents.isNotEmpty) { controller.clearSelectedEvents(); } else if (controller.showEmojiPicker) { controller.emojiPickerAction(); + } else if (controller.activeThreadId != null) { + controller.closeThread(); } }, child: StreamBuilder( @@ -157,85 +72,222 @@ class ChatView extends StatelessWidget { future: controller.loadTimelineFuture, builder: (BuildContext context, snapshot) { var appbarBottomHeight = 0.0; - if (controller.room.pinnedEventIds.isNotEmpty) { - appbarBottomHeight += 42; + final activeThreadId = controller.activeThreadId; + if (activeThreadId != null) { + appbarBottomHeight += ChatAppBarListTile.fixedHeight; } - if (scrollUpBannerEventId != null) { - appbarBottomHeight += 42; + if (controller.room.pinnedEventIds.isNotEmpty && + activeThreadId == null) { + appbarBottomHeight += ChatAppBarListTile.fixedHeight; } - final tombstoneEvent = - controller.room.getState(EventTypes.RoomTombstone); - if (tombstoneEvent != null) { - appbarBottomHeight += 42; + if (scrollUpBannerEventId != null && activeThreadId == null) { + appbarBottomHeight += ChatAppBarListTile.fixedHeight; } return Scaffold( appBar: AppBar( actionsIconTheme: IconThemeData( color: controller.selectedEvents.isEmpty ? null - : Theme.of(context).colorScheme.primary, + : theme.colorScheme.onTertiaryContainer, ), + backgroundColor: controller.selectedEvents.isEmpty + ? controller.activeThreadId != null + ? theme.colorScheme.secondaryContainer + : null + : theme.colorScheme.tertiaryContainer, + automaticallyImplyLeading: false, leading: controller.selectMode ? IconButton( icon: const Icon(Icons.close), onPressed: controller.clearSelectedEvents, - tooltip: L10n.of(context)!.close, - color: Theme.of(context).colorScheme.primary, + tooltip: L10n.of(context).close, + color: theme.colorScheme.onTertiaryContainer, ) - : UnreadRoomsBadge( - filter: (r) => r.id != controller.roomId, - badgePosition: BadgePosition.topEnd(end: 8, top: 4), - child: const Center(child: BackButton()), + : activeThreadId != null + ? IconButton( + icon: const Icon(Icons.close), + onPressed: controller.closeThread, + tooltip: L10n.of(context).backToMainChat, + color: theme.colorScheme.onSecondaryContainer, + ) + : FluffyThemes.isColumnMode(context) + ? null + : StreamBuilder( + stream: Matrix.of(context).client.onSync.stream.where( + (syncUpdate) => syncUpdate.hasRoomUpdate, + ), + builder: (context, _) => UnreadRoomsBadge( + filter: (r) => r.id != controller.roomId, + badgePosition: BadgePosition.topEnd(end: 8, top: 4), + child: const Center(child: BackButton()), + ), ), - titleSpacing: 0, + titleSpacing: FluffyThemes.isColumnMode(context) ? 24 : 0, title: ChatAppBarTitle(controller), - actions: _appBarActions(context), + actions: [ + if (controller.selectMode) ...[ + if (controller.canEditSelectedEvents) + IconButton( + icon: const Icon(Icons.edit_outlined), + tooltip: L10n.of(context).edit, + onPressed: controller.editSelectedEventAction, + ), + if (controller.selectedEvents.length == 1 && + controller.activeThreadId == null && + controller.room.canSendDefaultMessages) + IconButton( + icon: const Icon(Icons.message_outlined), + tooltip: L10n.of(context).replyInThread, + onPressed: () => controller.enterThread( + controller.selectedEvents.single.eventId, + ), + ), + IconButton( + icon: const Icon(Icons.copy_outlined), + tooltip: L10n.of(context).copyToClipboard, + onPressed: controller.copyEventsAction, + ), + if (controller.canRedactSelectedEvents) + IconButton( + icon: const Icon(Icons.delete_outlined), + tooltip: L10n.of(context).redactMessage, + onPressed: controller.redactEventsAction, + ), + if (controller.selectedEvents.length == 1) + PopupMenuButton<_EventContextAction>( + useRootNavigator: true, + onSelected: (action) { + switch (action) { + case _EventContextAction.info: + controller.showEventInfo(); + controller.clearSelectedEvents(); + break; + case _EventContextAction.report: + controller.reportEventAction(); + break; + } + }, + itemBuilder: (context) => [ + if (controller.canPinSelectedEvents) + PopupMenuItem( + onTap: controller.pinEvent, + value: null, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.push_pin_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).pinMessage), + ], + ), + ), + if (controller.canSaveSelectedEvent) + PopupMenuItem( + onTap: () => + controller.saveSelectedEvent(context), + value: null, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.download_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).downloadFile), + ], + ), + ), + PopupMenuItem( + value: _EventContextAction.info, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.info_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).messageInfo), + ], + ), + ), + if (controller.selectedEvents.single.status.isSent) + PopupMenuItem( + value: _EventContextAction.report, + child: Row( + mainAxisSize: .min, + children: [ + const Icon( + Icons.shield_outlined, + color: Colors.red, + ), + const SizedBox(width: 12), + Text(L10n.of(context).reportMessage), + ], + ), + ), + ], + ), + ] else if (!controller.room.isArchived) ...[ + if (AppSettings.experimentalVoip.value && + Matrix.of(context).voipPlugin != null && + controller.room.isDirectChat) + IconButton( + onPressed: controller.onPhoneButtonTap, + icon: const Icon(Icons.call_outlined), + tooltip: L10n.of(context).placeCall, + ), + EncryptionButton(controller.room), + ChatSettingsPopupMenu(controller.room, true), + ], + ], bottom: PreferredSize( preferredSize: Size.fromHeight(appbarBottomHeight), child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ PinnedEvents(controller), - if (tombstoneEvent != null) - ChatAppBarListTile( - title: tombstoneEvent.parsedTombstoneContent.body, - leading: const Padding( - padding: EdgeInsets.all(8.0), - child: Icon(Icons.upgrade_outlined), - ), - trailing: TextButton( - onPressed: controller.goToNewRoomAction, - child: Text(L10n.of(context)!.goToTheNewRoom), + if (activeThreadId != null) + SizedBox( + height: ChatAppBarListTile.fixedHeight, + child: Center( + child: TextButton.icon( + onPressed: () => + controller.scrollToEventId(activeThreadId), + icon: const Icon(Icons.message), + label: Text(L10n.of(context).replyInThread), + style: TextButton.styleFrom( + foregroundColor: + theme.colorScheme.onSecondaryContainer, + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular(4), + ), + ), + ), ), ), - if (scrollUpBannerEventId != null) + if (scrollUpBannerEventId != null && + activeThreadId == null) ChatAppBarListTile( leading: IconButton( - color: - Theme.of(context).colorScheme.onSurfaceVariant, + color: theme.colorScheme.onSurfaceVariant, icon: const Icon(Icons.close), - tooltip: L10n.of(context)!.close, + tooltip: L10n.of(context).close, onPressed: () { controller.discardScrollUpBannerEventId(); controller.setReadMarker(); }, ), - title: L10n.of(context)!.jumpToLastReadMessage, + title: L10n.of(context).jumpToLastReadMessage, trailing: TextButton( onPressed: () { - controller.scrollToEventId( - scrollUpBannerEventId, - ); + controller.scrollToEventId(scrollUpBannerEventId); controller.discardScrollUpBannerEventId(); }, - child: Text(L10n.of(context)!.jump), + child: Text(L10n.of(context).jump), ), ), ], ), ), ), - floatingActionButton: controller.showScrollDownButton && + floatingActionButton: + controller.showScrollDownButton && controller.selectedEvents.isEmpty ? Padding( padding: const EdgeInsets.only(bottom: 56.0), @@ -243,6 +295,8 @@ class ChatView extends StatelessWidget { onPressed: controller.scrollDown, heroTag: null, mini: true, + backgroundColor: theme.colorScheme.surface, + foregroundColor: theme.colorScheme.onSurface, child: const Icon(Icons.arrow_downward_outlined), ), ) @@ -255,14 +309,21 @@ class ChatView extends StatelessWidget { children: [ if (accountConfig.wallpaperUrl != null) Opacity( - opacity: accountConfig.wallpaperOpacity ?? 1, - child: MxcImage( - uri: accountConfig.wallpaperUrl, - fit: BoxFit.cover, - isThumbnail: true, - width: FluffyThemes.columnWidth * 4, - height: FluffyThemes.columnWidth * 4, - placeholder: (_) => Container(), + opacity: accountConfig.wallpaperOpacity ?? 0.5, + child: ImageFiltered( + imageFilter: ui.ImageFilter.blur( + sigmaX: accountConfig.wallpaperBlur ?? 0.0, + sigmaY: accountConfig.wallpaperBlur ?? 0.0, + ), + child: MxcImage( + cacheKey: accountConfig.wallpaperUrl.toString(), + uri: accountConfig.wallpaperUrl, + fit: BoxFit.cover, + height: MediaQuery.sizeOf(context).height, + width: MediaQuery.sizeOf(context).width, + isThumbnail: false, + placeholder: (_) => Container(), + ), ), ), SafeArea( @@ -271,86 +332,68 @@ class ChatView extends StatelessWidget { Expanded( child: GestureDetector( onTap: controller.clearSingleSelectedEvent, - child: Builder( - builder: (context) { - if (controller.timeline == null) { - return const Center( - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, - ), - ); - } - return ChatEventList( - controller: controller, - ); - }, - ), + child: ChatEventList(controller: controller), ), ), - if (controller.room.canSendDefaultMessages && + if (controller.showScrollDownButton) + Divider(height: 1, color: theme.dividerColor), + if (controller.room.isExtinct) + Container( + margin: EdgeInsets.all(bottomSheetPadding), + width: double.infinity, + child: ElevatedButton.icon( + icon: const Icon(Icons.chevron_right), + label: Text(L10n.of(context).enterNewChat), + onPressed: controller.goToNewRoomAction, + ), + ) + else if (controller.room.canSendDefaultMessages && controller.room.membership == Membership.join) Container( - margin: EdgeInsets.only( - bottom: bottomSheetPadding, - left: bottomSheetPadding, - right: bottomSheetPadding, - ), + margin: EdgeInsets.all(bottomSheetPadding), constraints: const BoxConstraints( - maxWidth: FluffyThemes.columnWidth * 2.5, + maxWidth: FluffyThemes.maxTimelineWidth, ), alignment: Alignment.center, child: Material( clipBehavior: Clip.hardEdge, - color: Theme.of(context) - .colorScheme - // ignore: deprecated_member_use - .surfaceVariant, - borderRadius: const BorderRadius.all( - Radius.circular(24), - ), + color: controller.selectedEvents.isNotEmpty + ? theme.colorScheme.tertiaryContainer + : theme.colorScheme.surfaceContainerHigh, + borderRadius: BorderRadius.circular(32), child: controller.room.isAbandonedDMRoom == true ? Row( - mainAxisAlignment: - MainAxisAlignment.spaceEvenly, + mainAxisAlignment: .spaceEvenly, children: [ TextButton.icon( style: TextButton.styleFrom( - padding: const EdgeInsets.all( - 16, - ), - foregroundColor: Theme.of(context) - .colorScheme - .error, + padding: const EdgeInsets.all(16), + foregroundColor: + theme.colorScheme.error, ), icon: const Icon( Icons.archive_outlined, ), onPressed: controller.leaveChat, - label: Text( - L10n.of(context)!.leave, - ), + label: Text(L10n.of(context).leave), ), TextButton.icon( style: TextButton.styleFrom( - padding: const EdgeInsets.all( - 16, - ), + padding: const EdgeInsets.all(16), ), icon: const Icon( Icons.forum_outlined, ), onPressed: controller.recreateChat, label: Text( - L10n.of(context)!.reopenChat, + L10n.of(context).reopenChat, ), ), ], ) : Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ - const ConnectionStatusHeader(), - ReactionsPicker(controller), ReplyDisplay(controller), ChatInputRow(controller), ChatEmojiPicker(controller), @@ -363,14 +406,9 @@ class ChatView extends StatelessWidget { ), if (controller.dragging) Container( - color: Theme.of(context) - .scaffoldBackgroundColor - .withOpacity(0.9), + color: theme.scaffoldBackgroundColor.withAlpha(230), alignment: Alignment.center, - child: const Icon( - Icons.upload_outlined, - size: 100, - ), + child: const Icon(Icons.upload_outlined, size: 100), ), ], ), diff --git a/lib/pages/chat/command_hints.dart b/lib/pages/chat/command_hints.dart index ccc405aa5..75bc14003 100644 --- a/lib/pages/chat/command_hints.dart +++ b/lib/pages/chat/command_hints.dart @@ -1,6 +1,6 @@ // This file is auto-generated using scripts/generate_command_hints_glue.sh. -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:fluffychat/l10n/l10n.dart'; String commandExample(String command) { switch (command) { @@ -26,41 +26,41 @@ String commandExample(String command) { String commandHint(L10n l10n, String command) { switch (command) { - case "ban": + case 'ban': return l10n.commandHint_ban; - case "clearcache": + case 'clearcache': return l10n.commandHint_clearcache; - case "create": + case 'create': return l10n.commandHint_create; - case "discardsession": + case 'discardsession': return l10n.commandHint_discardsession; - case "dm": + case 'dm': return l10n.commandHint_dm; - case "html": + case 'html': return l10n.commandHint_html; - case "invite": + case 'invite': return l10n.commandHint_invite; - case "join": + case 'join': return l10n.commandHint_join; - case "kick": + case 'kick': return l10n.commandHint_kick; - case "leave": + case 'leave': return l10n.commandHint_leave; - case "me": + case 'me': return l10n.commandHint_me; - case "myroomavatar": + case 'myroomavatar': return l10n.commandHint_myroomavatar; - case "myroomnick": + case 'myroomnick': return l10n.commandHint_myroomnick; - case "op": + case 'op': return l10n.commandHint_op; - case "plain": + case 'plain': return l10n.commandHint_plain; - case "react": + case 'react': return l10n.commandHint_react; - case "send": + case 'send': return l10n.commandHint_send; - case "unban": + case 'unban': return l10n.commandHint_unban; case 'markasdm': return l10n.commandHint_markasdm; @@ -78,7 +78,13 @@ String commandHint(L10n l10n, String command) { return l10n.commandHint_ignore; case 'unignore': return l10n.commandHint_unignore; + case 'roomupgrade': + return l10n.commandHint_roomupgrade; + case 'logout': + return l10n.commandHint_logout; + case 'logoutall': + return l10n.commandHint_logoutall; default: - return ""; + return ''; } } diff --git a/lib/pages/chat/encryption_button.dart b/lib/pages/chat/encryption_button.dart index c68a1c976..594ec4e4b 100644 --- a/lib/pages/chat/encryption_button.dart +++ b/lib/pages/chat/encryption_button.dart @@ -1,9 +1,10 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:badges/badges.dart' as b; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import '../../widgets/matrix.dart'; class EncryptionButton extends StatelessWidget { @@ -12,31 +13,46 @@ class EncryptionButton extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); return StreamBuilder( - stream: Matrix.of(context) - .client - .onSync - .stream - .where((s) => s.deviceLists != null), + stream: Matrix.of( + context, + ).client.onSync.stream.where((s) => s.deviceLists != null), builder: (context, snapshot) { + final shouldBeEncrypted = room.joinRules != JoinRules.public; return FutureBuilder( future: room.encrypted ? room.calcEncryptionHealthState() : Future.value(EncryptionHealthState.allVerified), builder: (BuildContext context, snapshot) => IconButton( tooltip: room.encrypted - ? L10n.of(context)!.encrypted - : L10n.of(context)!.encryptionNotEnabled, - icon: Icon( - room.encrypted ? Icons.lock_outlined : Icons.lock_open_outlined, - size: 20, - color: room.joinRules != JoinRules.public && !room.encrypted - ? Colors.red - : room.joinRules != JoinRules.public && - snapshot.data == - EncryptionHealthState.unverifiedDevices - ? Colors.orange - : null, + ? L10n.of(context).encrypted + : L10n.of(context).encryptionNotEnabled, + icon: b.Badge( + badgeAnimation: const b.BadgeAnimation.fade(), + showBadge: + snapshot.data == EncryptionHealthState.unverifiedDevices, + badgeStyle: b.BadgeStyle( + badgeColor: theme.colorScheme.error, + elevation: 4, + ), + badgeContent: Text( + '!', + style: TextStyle( + fontSize: 9, + color: theme.colorScheme.onError, + fontWeight: FontWeight.bold, + ), + ), + child: Icon( + room.encrypted + ? Icons.lock_outlined + : Icons.no_encryption_outlined, + size: 20, + color: (shouldBeEncrypted && !room.encrypted) + ? theme.colorScheme.error + : theme.colorScheme.onSurface, + ), ), onPressed: () => context.go('/rooms/${room.id}/encryption'), ), diff --git a/lib/pages/chat/event_info_dialog.dart b/lib/pages/chat/event_info_dialog.dart index 38acdc84c..9dd0e7bb5 100644 --- a/lib/pages/chat/event_info_dialog.dart +++ b/lib/pages/chat/event_info_dialog.dart @@ -2,47 +2,43 @@ import 'dart:convert'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/date_time_extension.dart'; import 'package:fluffychat/widgets/avatar.dart'; extension EventInfoDialogExtension on Event { void showInfoDialog(BuildContext context) => showAdaptiveBottomSheet( - context: context, - builder: (context) => - EventInfoDialog(l10n: L10n.of(context)!, event: this), - ); + context: context, + builder: (context) => EventInfoDialog(l10n: L10n.of(context), event: this), + ); } class EventInfoDialog extends StatelessWidget { final Event event; final L10n l10n; - const EventInfoDialog({ - required this.event, - required this.l10n, - super.key, - }); - String get prettyJson { - const JsonDecoder decoder = JsonDecoder(); - const JsonEncoder encoder = JsonEncoder.withIndent(' '); + const EventInfoDialog({required this.event, required this.l10n, super.key}); + + String prettyJson(MatrixEvent event) { + const decoder = JsonDecoder(); + const encoder = JsonEncoder.withIndent(' '); final object = decoder.convert(jsonEncode(event.toJson())); return encoder.convert(object); } @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final originalSource = event.originalSource; return Scaffold( appBar: AppBar( - title: Text(L10n.of(context)!.messageInfo), - leading: IconButton( - icon: const Icon(Icons.arrow_downward_outlined), + title: Text(L10n.of(context).messageInfo), + leading: CloseButton( onPressed: Navigator.of(context, rootNavigator: false).pop, - tooltip: L10n.of(context)!.close, ), ), body: ListView( @@ -54,54 +50,55 @@ class EventInfoDialog extends StatelessWidget { client: event.room.client, presenceUserId: event.senderId, ), - title: Text(L10n.of(context)!.sender), + title: Text(L10n.of(context).sender), subtitle: Text( '${event.senderFromMemoryOrFallback.calcDisplayname()} [${event.senderId}]', ), ), ListTile( - title: Text(L10n.of(context)!.time), + title: Text('${L10n.of(context).time}:'), subtitle: Text(event.originServerTs.localizedTime(context)), ), ListTile( - title: Text(L10n.of(context)!.messageType), - subtitle: Text(event.humanreadableType), + title: Text('${L10n.of(context).status}:'), + subtitle: Text(event.status.name), ), - ListTile(title: Text('${L10n.of(context)!.sourceCode}:')), + ListTile(title: Text('${L10n.of(context).sourceCode}:')), Padding( padding: const EdgeInsets.all(12.0), child: Material( borderRadius: BorderRadius.circular(AppConfig.borderRadius), - color: Theme.of(context).colorScheme.inverseSurface, + color: theme.colorScheme.surfaceContainer, child: SingleChildScrollView( - padding: const EdgeInsets.all(8), + padding: const EdgeInsets.all(16), scrollDirection: Axis.horizontal, child: SelectableText( - prettyJson, - style: TextStyle( - color: Theme.of(context).colorScheme.onInverseSurface, - ), + prettyJson(MatrixEvent.fromJson(event.toJson())), + style: TextStyle(color: theme.colorScheme.onSurface), ), ), ), ), + if (originalSource != null) ...[ + ListTile(title: Text('${L10n.of(context).encrypted}:')), + Padding( + padding: const EdgeInsets.all(12.0), + child: Material( + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + color: theme.colorScheme.surfaceContainer, + child: SingleChildScrollView( + padding: const EdgeInsets.all(16), + scrollDirection: Axis.horizontal, + child: SelectableText( + prettyJson(originalSource), + style: TextStyle(color: theme.colorScheme.onSurface), + ), + ), + ), + ), + ], ], ), ); } } - -extension on Event { - String get humanreadableType { - if (type == EventTypes.Message) { - return messageType.split('m.').last; - } - if (type.startsWith('m.room.')) { - return type.split('m.room.').last; - } - if (type.startsWith('m.')) { - return type.split('m.').last; - } - return type; - } -} diff --git a/lib/pages/chat/events/audio_player.dart b/lib/pages/chat/events/audio_player.dart index 40d4cf29f..e79980832 100644 --- a/lib/pages/chat/events/audio_player.dart +++ b/lib/pages/chat/events/audio_player.dart @@ -4,23 +4,39 @@ import 'dart:io'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; +import 'package:async/async.dart'; +import 'package:flutter_linkify/flutter_linkify.dart'; import 'package:just_audio/just_audio.dart'; import 'package:matrix/matrix.dart'; +import 'package:opus_caf_converter_dart/opus_caf_converter_dart.dart'; import 'package:path_provider/path_provider.dart'; +import 'package:universal_html/html.dart' as html; +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; import 'package:fluffychat/utils/error_reporter.dart'; +import 'package:fluffychat/utils/file_description.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; import '../../../utils/matrix_sdk_extensions/event_extension.dart'; +import '../../../widgets/fluffy_chat_app.dart'; +import '../../../widgets/matrix.dart'; class AudioPlayerWidget extends StatefulWidget { final Color color; + final Color linkColor; + final double fontSize; final Event event; - static String? currentId; - static const int wavesCount = 40; - const AudioPlayerWidget(this.event, {this.color = Colors.black, super.key}); + const AudioPlayerWidget( + this.event, { + required this.color, + required this.linkColor, + required this.fontSize, + super.key, + }); @override AudioPlayerState createState() => AudioPlayerState(); @@ -29,40 +45,126 @@ class AudioPlayerWidget extends StatefulWidget { enum AudioPlayerStatus { notDownloaded, downloading, downloaded } class AudioPlayerState extends State { + static const double buttonSize = 36; + AudioPlayerStatus status = AudioPlayerStatus.notDownloaded; - AudioPlayer? audioPlayer; + double? _downloadProgress; - StreamSubscription? onAudioPositionChanged; - StreamSubscription? onDurationChanged; - StreamSubscription? onPlayerStateChanged; - StreamSubscription? onPlayerError; - - String? statusText; - int currentPosition = 0; - double maxPosition = 0; - - MatrixFile? matrixFile; - File? audioFile; + late final MatrixState matrix; + List? _waveform; + String? _durationString; @override void dispose() { - if (audioPlayer?.playerState.playing == true) { - audioPlayer?.stop(); - } - onAudioPositionChanged?.cancel(); - onDurationChanged?.cancel(); - onPlayerStateChanged?.cancel(); - onPlayerError?.cancel(); - super.dispose(); + final audioPlayer = matrix.voiceMessageEventId.value != widget.event.eventId + ? null + : matrix.audioPlayer; + if (audioPlayer != null) { + if (audioPlayer.playing && !audioPlayer.isAtEndPosition) { + WidgetsBinding.instance.addPostFrameCallback((_) { + ScaffoldMessenger.of(matrix.context).showMaterialBanner( + MaterialBanner( + padding: EdgeInsets.zero, + leading: StreamBuilder( + stream: audioPlayer.playerStateStream.asBroadcastStream(), + builder: (context, _) => IconButton( + onPressed: () { + if (audioPlayer.isAtEndPosition) { + audioPlayer.seek(Duration.zero); + } else if (audioPlayer.playing) { + audioPlayer.pause(); + } else { + audioPlayer.play(); + } + }, + icon: audioPlayer.playing && !audioPlayer.isAtEndPosition + ? const Icon(Icons.pause_outlined) + : const Icon(Icons.play_arrow_outlined), + ), + ), + content: StreamBuilder( + stream: audioPlayer.positionStream.asBroadcastStream(), + builder: (context, _) => GestureDetector( + onTap: () => FluffyChatApp.router.go( + '/rooms/${widget.event.room.id}?event=${widget.event.eventId}', + ), + child: Text( + '🎙️ ${audioPlayer.position.minuteSecondString} / ${audioPlayer.duration?.minuteSecondString} - ${widget.event.senderFromMemoryOrFallback.calcDisplayname()}', + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + ), + ), + actions: [ + IconButton( + onPressed: () { + audioPlayer.pause(); + audioPlayer.dispose(); + matrix.voiceMessageEventId.value = matrix.audioPlayer = + null; + + WidgetsBinding.instance.addPostFrameCallback((_) { + ScaffoldMessenger.of( + matrix.context, + ).clearMaterialBanners(); + }); + }, + icon: const Icon(Icons.close_outlined), + ), + ], + ), + ); + }); + return; + } + audioPlayer.pause(); + audioPlayer.dispose(); + matrix.voiceMessageEventId.value = matrix.audioPlayer = null; + } } - Future _downloadAction() async { - if (status != AudioPlayerStatus.notDownloaded) return; + Future _onButtonTap() async { + WidgetsBinding.instance.addPostFrameCallback((_) { + ScaffoldMessenger.of(matrix.context).clearMaterialBanners(); + }); + final currentPlayer = + matrix.voiceMessageEventId.value != widget.event.eventId + ? null + : matrix.audioPlayer; + if (currentPlayer != null && !currentPlayer.isAtEndPosition) { + if (currentPlayer.playing) { + currentPlayer.pause(); + } else { + currentPlayer.play(); + } + return; + } + + matrix.voiceMessageEventId.value = widget.event.eventId; + matrix.audioPlayer + ?..stop() + ..dispose(); + File? file; + MatrixFile? matrixFile; + setState(() => status = AudioPlayerStatus.downloading); try { - final matrixFile = await widget.event.downloadAndDecryptAttachment(); - File? file; + final fileSize = widget.event.content + .tryGetMap('info') + ?.tryGet('size'); + matrixFile = await widget.event.downloadAndDecryptAttachment( + onDownloadProgress: fileSize != null && fileSize > 0 + ? (progress) { + final progressPercentage = progress / fileSize; + setState(() { + _downloadProgress = progressPercentage < 1 + ? progressPercentage + : null; + }); + } + : null, + ); if (!kIsWeb) { final tempDir = await getTemporaryDirectory(); @@ -70,112 +172,52 @@ class AudioPlayerState extends State { widget.event.attachmentOrThumbnailMxcUrl()!.pathSegments.last, ); file = File('${tempDir.path}/${fileName}_${matrixFile.name}'); + await file.writeAsBytes(matrixFile.bytes); - } - setState(() { - audioFile = file; - this.matrixFile = matrixFile; - status = AudioPlayerStatus.downloaded; - }); - _playAction(); - } catch (e, s) { - Logs().v('Could not download audio file', e, s); - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text(e.toLocalizedString(context)), - ), - ); - } - } - - void _playAction() async { - final audioPlayer = this.audioPlayer ??= AudioPlayer(); - if (AudioPlayerWidget.currentId != widget.event.eventId) { - if (AudioPlayerWidget.currentId != null) { - if (audioPlayer.playerState.playing) { - await audioPlayer.stop(); - setState(() {}); + if (Platform.isIOS && + matrixFile.mimeType.toLowerCase() == 'audio/ogg') { + Logs().v('Convert ogg audio file for iOS...'); + final convertedFile = File('${file.path}.caf'); + if (await convertedFile.exists() == false) { + OpusCaf().convertOpusToCaf(file.path, convertedFile.path); + } + file = convertedFile; } } - AudioPlayerWidget.currentId = widget.event.eventId; - } - if (audioPlayer.playerState.playing) { - await audioPlayer.pause(); - return; - } else if (audioPlayer.position != Duration.zero) { - await audioPlayer.play(); - return; - } - onAudioPositionChanged ??= audioPlayer.positionStream.listen((state) { - if (maxPosition <= 0) return; setState(() { - statusText = - '${state.inMinutes.toString().padLeft(2, '0')}:${(state.inSeconds % 60).toString().padLeft(2, '0')}'; - currentPosition = ((state.inMilliseconds.toDouble() / maxPosition) * - AudioPlayerWidget.wavesCount) - .round(); + status = AudioPlayerStatus.downloaded; }); - if (state.inMilliseconds.toDouble() == maxPosition) { - audioPlayer.stop(); - audioPlayer.seek(null); - } - }); - onDurationChanged ??= audioPlayer.durationStream.listen((max) { - if (max == null || max == Duration.zero) return; - setState(() => maxPosition = max.inMilliseconds.toDouble()); - }); - onPlayerStateChanged ??= - audioPlayer.playingStream.listen((_) => setState(() {})); - final audioFile = this.audioFile; - if (audioFile != null) { - audioPlayer.setFilePath(audioFile.path); + } catch (e, s) { + Logs().v('Could not download audio file', e, s); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); + rethrow; + } + if (!context.mounted) return; + if (matrix.voiceMessageEventId.value != widget.event.eventId) return; + + final audioPlayer = matrix.audioPlayer = AudioPlayer(); + + if (file != null) { + audioPlayer.setFilePath(file.path); + } else if (kIsWeb) { + final blob = html.Blob([matrixFile.bytes], 'audio/mpeg'); + final url = html.Url.createObjectUrlFromBlob(blob); + await audioPlayer.setAudioSource(AudioSource.uri(Uri.parse(url))); } else { - await audioPlayer.setAudioSource(MatrixFileAudioSource(matrixFile!)); + throw Exception('No audio file provided!'); } + audioPlayer.play().onError( - ErrorReporter(context, 'Unable to play audio message') - .onErrorCallback, - ); + ErrorReporter(context, 'Unable to play audio message').onErrorCallback, + ); } - static const double buttonSize = 36; - - String? get _durationString { - final durationInt = widget.event.content - .tryGetMap('info') - ?.tryGet('duration'); - if (durationInt == null) return null; - final duration = Duration(milliseconds: durationInt); - return '${duration.inMinutes.toString().padLeft(2, '0')}:${(duration.inSeconds % 60).toString().padLeft(2, '0')}'; - } - - List _getWaveform() { - final eventWaveForm = widget.event.content - .tryGetMap('org.matrix.msc1767.audio') - ?.tryGetList('waveform'); - if (eventWaveForm == null || eventWaveForm.isEmpty) { - return List.filled(AudioPlayerWidget.wavesCount, 500); - } - while (eventWaveForm.length < AudioPlayerWidget.wavesCount) { - for (var i = 0; i < eventWaveForm.length; i = i + 2) { - eventWaveForm.insert(i, eventWaveForm[i]); - } - } - var i = 0; - final step = (eventWaveForm.length / AudioPlayerWidget.wavesCount).round(); - while (eventWaveForm.length > AudioPlayerWidget.wavesCount) { - eventWaveForm.removeAt(i); - i = (i + step) % AudioPlayerWidget.wavesCount; - } - return eventWaveForm.map((i) => i > 1024 ? 1024 : i).toList(); - } - - late final List waveform; - - void _toggleSpeed() async { - final audioPlayer = this.audioPlayer; + Future _toggleSpeed() async { + final audioPlayer = matrix.audioPlayer; if (audioPlayer == null) return; switch (audioPlayer.speed) { case 1.0: @@ -198,134 +240,291 @@ class AudioPlayerState extends State { setState(() {}); } + List? _getWaveform() { + final eventWaveForm = widget.event.content + .tryGetMap('org.matrix.msc1767.audio') + ?.tryGetList('waveform'); + if (eventWaveForm == null || eventWaveForm.isEmpty) { + return null; + } + while (eventWaveForm.length < AudioPlayerWidget.wavesCount) { + for (var i = 0; i < eventWaveForm.length; i = i + 2) { + eventWaveForm.insert(i, eventWaveForm[i]); + } + } + var i = 0; + final step = (eventWaveForm.length / AudioPlayerWidget.wavesCount).round(); + while (eventWaveForm.length > AudioPlayerWidget.wavesCount) { + eventWaveForm.removeAt(i); + i = (i + step) % AudioPlayerWidget.wavesCount; + } + return eventWaveForm.map((i) => i > 1024 ? 1024 : i).toList(); + } + @override void initState() { super.initState(); - waveform = _getWaveform(); + matrix = Matrix.of(context); + _waveform = _getWaveform(); + + if (matrix.voiceMessageEventId.value == widget.event.eventId && + matrix.audioPlayer != null) { + WidgetsBinding.instance.addPostFrameCallback((_) { + ScaffoldMessenger.of(matrix.context).clearMaterialBanners(); + }); + } + + final durationInt = widget.event.content + .tryGetMap('info') + ?.tryGet('duration'); + if (durationInt != null) { + final duration = Duration(milliseconds: durationInt); + _durationString = duration.minuteSecondString; + } } @override Widget build(BuildContext context) { - final statusText = this.statusText ??= _durationString ?? '00:00'; - final audioPlayer = this.audioPlayer; - return Padding( - padding: const EdgeInsets.all(12.0), - child: Row( - mainAxisSize: MainAxisSize.min, - children: [ - SizedBox( - width: buttonSize, - height: buttonSize, - child: status == AudioPlayerStatus.downloading - ? CircularProgressIndicator(strokeWidth: 2, color: widget.color) - : InkWell( - borderRadius: BorderRadius.circular(64), - child: Material( - color: widget.color.withAlpha(64), - borderRadius: BorderRadius.circular(64), - child: Icon( - audioPlayer?.playerState.playing == true - ? Icons.pause_outlined - : Icons.play_arrow_outlined, - color: widget.color, - ), + final theme = Theme.of(context); + final waveform = _waveform; + + return ValueListenableBuilder( + valueListenable: matrix.voiceMessageEventId, + builder: (context, eventId, _) { + final audioPlayer = eventId != widget.event.eventId + ? null + : matrix.audioPlayer; + + final fileDescription = widget.event.fileDescription; + + return StreamBuilder( + stream: audioPlayer == null + ? null + : StreamGroup.merge([ + audioPlayer.positionStream.asBroadcastStream(), + audioPlayer.playerStateStream.asBroadcastStream(), + ]), + builder: (context, _) { + final maxPosition = + audioPlayer?.duration?.inMilliseconds.toDouble() ?? 1.0; + var currentPosition = + audioPlayer?.position.inMilliseconds.toDouble() ?? 0.0; + if (currentPosition > maxPosition) currentPosition = maxPosition; + + final wavePosition = + (currentPosition / maxPosition) * AudioPlayerWidget.wavesCount; + + final statusText = audioPlayer == null + ? _durationString ?? '00:00' + : audioPlayer.position.minuteSecondString; + return Padding( + padding: const EdgeInsets.all(12.0), + child: Column( + mainAxisSize: .min, + crossAxisAlignment: .start, + children: [ + ConstrainedBox( + constraints: const BoxConstraints( + maxWidth: FluffyThemes.columnWidth, ), - onLongPress: () => widget.event.saveFile(context), - onTap: () { - if (status == AudioPlayerStatus.downloaded) { - _playAction(); - } else { - _downloadAction(); - } - }, - ), - ), - const SizedBox(width: 8), - Row( - mainAxisSize: MainAxisSize.min, - children: [ - for (var i = 0; i < AudioPlayerWidget.wavesCount; i++) - GestureDetector( - onTapDown: (_) => audioPlayer?.seek( - Duration( - milliseconds: - (maxPosition / AudioPlayerWidget.wavesCount).round() * - i, - ), - ), - child: Container( - height: 32, - color: widget.color.withAlpha(0), - alignment: Alignment.center, - child: Opacity( - opacity: currentPosition > i ? 1 : 0.5, - child: Container( - margin: const EdgeInsets.symmetric(horizontal: 1), - decoration: BoxDecoration( - color: widget.color, - borderRadius: BorderRadius.circular(2), + child: Row( + mainAxisSize: .min, + children: [ + SizedBox( + width: buttonSize, + height: buttonSize, + child: status == AudioPlayerStatus.downloading + ? CircularProgressIndicator( + strokeWidth: 2, + color: widget.color, + value: _downloadProgress, + ) + : InkWell( + borderRadius: BorderRadius.circular(64), + onLongPress: () => + widget.event.saveFile(context), + onTap: _onButtonTap, + child: Material( + color: widget.color.withAlpha(64), + borderRadius: BorderRadius.circular(64), + child: Icon( + audioPlayer?.playing == true && + audioPlayer?.isAtEndPosition == + false + ? Icons.pause_outlined + : Icons.play_arrow_outlined, + color: widget.color, + ), + ), + ), ), - width: 2, - height: 32 * (waveform[i] / 1024), - ), + const SizedBox(width: 8), + Expanded( + child: Stack( + children: [ + if (waveform != null) + Padding( + padding: const EdgeInsets.symmetric( + horizontal: 16.0, + ), + child: Row( + children: [ + for ( + var i = 0; + i < AudioPlayerWidget.wavesCount; + i++ + ) + Expanded( + child: Container( + height: 32, + alignment: Alignment.center, + child: Container( + margin: + const EdgeInsets.symmetric( + horizontal: 1, + ), + decoration: BoxDecoration( + color: i < wavePosition + ? widget.color + : widget.color.withAlpha( + 128, + ), + borderRadius: + BorderRadius.circular(64), + ), + height: 32 * (waveform[i] / 1024), + ), + ), + ), + ], + ), + ), + SizedBox( + height: 32, + child: Slider( + thumbColor: + widget.event.senderId == + widget.event.room.client.userID + ? theme.colorScheme.onPrimary + : theme.colorScheme.primary, + activeColor: waveform == null + ? widget.color + : Colors.transparent, + inactiveColor: waveform == null + ? widget.color.withAlpha(128) + : Colors.transparent, + max: maxPosition, + value: currentPosition, + onChanged: (position) => audioPlayer == null + ? _onButtonTap() + : audioPlayer.seek( + Duration( + milliseconds: position.round(), + ), + ), + ), + ), + ], + ), + ), + const SizedBox(width: 8), + SizedBox( + width: 36, + child: Text( + statusText, + style: TextStyle(color: widget.color, fontSize: 12), + ), + ), + const SizedBox(width: 8), + AnimatedCrossFade( + firstChild: Padding( + padding: const EdgeInsets.only(right: 8.0), + child: Icon( + Icons.mic_none_outlined, + color: widget.color, + ), + ), + secondChild: Material( + color: widget.color.withAlpha(64), + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + child: InkWell( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + onTap: _toggleSpeed, + child: SizedBox( + width: 32, + height: 20, + child: Center( + child: Text( + '${audioPlayer?.speed}x', + style: TextStyle( + color: widget.color, + fontSize: 9, + ), + ), + ), + ), + ), + ), + alignment: Alignment.center, + crossFadeState: audioPlayer == null + ? CrossFadeState.showFirst + : CrossFadeState.showSecond, + duration: FluffyThemes.animationDuration, + ), + ], ), ), - ), - ], - ), - const SizedBox(width: 8), - SizedBox( - width: 36, - child: Text( - statusText, - style: TextStyle( - color: widget.color, - fontSize: 12, + if (fileDescription != null) ...[ + const SizedBox(height: 8), + Padding( + padding: const EdgeInsets.symmetric( + horizontal: 16, + vertical: 8, + ), + child: Linkify( + text: fileDescription, + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + style: TextStyle( + color: widget.color, + fontSize: widget.fontSize, + ), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: widget.linkColor, + fontSize: widget.fontSize, + decoration: TextDecoration.underline, + decorationColor: widget.linkColor, + ), + onOpen: (url) => + UrlLauncher(context, url.url).launchUrl(), + ), + ), + ], + ], ), - ), - ), - const SizedBox(width: 8), - Badge( - isLabelVisible: audioPlayer != null, - label: audioPlayer == null - ? null - : Text( - '${audioPlayer.speed.toString()}x', - ), - backgroundColor: Theme.of(context).colorScheme.secondary, - textColor: Theme.of(context).colorScheme.onSecondary, - child: InkWell( - splashColor: widget.color.withAlpha(128), - borderRadius: BorderRadius.circular(64), - onTap: audioPlayer == null ? null : _toggleSpeed, - child: Icon( - Icons.mic_none_outlined, - color: widget.color, - ), - ), - ), - const SizedBox(width: 8), - ], - ), + ); + }, + ); + }, ); } } -/// To use a MatrixFile as an AudioSource for the just_audio package -class MatrixFileAudioSource extends StreamAudioSource { - final MatrixFile file; - MatrixFileAudioSource(this.file); - - @override - Future request([int? start, int? end]) async { - start ??= 0; - end ??= file.bytes.length; - return StreamAudioResponse( - sourceLength: file.bytes.length, - contentLength: end - start, - offset: start, - stream: Stream.value(file.bytes.sublist(start, end)), - contentType: file.mimeType, - ); +extension on AudioPlayer { + bool get isAtEndPosition { + final duration = this.duration; + if (duration == null) return true; + return position >= duration; } } + +extension on Duration { + String get minuteSecondString => + '${inMinutes.toString().padLeft(2, '0')}:${(inSeconds % 60).toString().padLeft(2, '0')}'; +} diff --git a/lib/pages/chat/events/cute_events.dart b/lib/pages/chat/events/cute_events.dart index 6a9424818..604537711 100644 --- a/lib/pages/chat/events/cute_events.dart +++ b/lib/pages/chat/events/cute_events.dart @@ -2,10 +2,10 @@ import 'dart:math'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; class CuteContent extends StatefulWidget { final Event event; @@ -21,7 +21,7 @@ class _CuteContentState extends State { @override void initState() { - if (AppConfig.autoplayImages && !_isOverlayShown) { + if (AppSettings.autoplayImages.value && !_isOverlayShown) { addOverlay(); } super.initState(); @@ -37,13 +37,10 @@ class _CuteContentState extends State { return GestureDetector( onTap: addOverlay, child: Column( - mainAxisSize: MainAxisSize.min, - mainAxisAlignment: MainAxisAlignment.center, + mainAxisSize: .min, + mainAxisAlignment: .center, children: [ - Text( - widget.event.text, - style: const TextStyle(fontSize: 150), - ), + Text(widget.event.text, style: const TextStyle(fontSize: 150)), if (label != null) Text(label), ], ), @@ -69,27 +66,28 @@ class _CuteContentState extends State { Overlay.of(context).insert(overlay); } - generateLabel(User? user) { + String? generateLabel(User? user) { switch (widget.event.content['cute_type']) { case 'googly_eyes': - return L10n.of(context)?.googlyEyesContent( + return L10n.of(context).googlyEyesContent( user?.displayName ?? widget.event.senderFromMemoryOrFallback.displayName ?? '', ); case 'cuddle': - return L10n.of(context)?.cuddleContent( + return L10n.of(context).cuddleContent( user?.displayName ?? widget.event.senderFromMemoryOrFallback.displayName ?? '', ); case 'hug': - return L10n.of(context)?.hugContent( + return L10n.of(context).hugContent( user?.displayName ?? widget.event.senderFromMemoryOrFallback.displayName ?? '', ); } + return null; } } @@ -111,10 +109,7 @@ class _CuteEventOverlayState extends State with TickerProviderStateMixin { final List items = List.generate( 50, - (index) => Size( - Random().nextDouble(), - 4 + (Random().nextDouble() * 4), - ), + (index) => Size(Random().nextDouble(), 4 + (Random().nextDouble() * 4)), ); AnimationController? controller; @@ -149,14 +144,13 @@ class _CuteEventOverlayState extends State .map( (position) => Positioned( left: position.width * width, - bottom: (height * + bottom: + (height * .25 * position.height * (controller?.value ?? 0)) - _CuteOverlayContent.size, - child: _CuteOverlayContent( - emoji: widget.emoji, - ), + child: _CuteOverlayContent(emoji: widget.emoji), ), ) .toList(), @@ -185,10 +179,7 @@ class _CuteOverlayContent extends StatelessWidget { Widget build(BuildContext context) { return SizedBox.square( dimension: size, - child: Text( - emoji, - style: const TextStyle(fontSize: 48), - ), + child: Text(emoji, style: const TextStyle(fontSize: 48)), ); } } diff --git a/lib/pages/chat/events/html_message.dart b/lib/pages/chat/events/html_message.dart index d6e6cbc44..906c6c242 100644 --- a/lib/pages/chat/events/html_message.dart +++ b/lib/pages/chat/events/html_message.dart @@ -1,17 +1,17 @@ +import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:collection/collection.dart'; -import 'package:flutter_highlighter/flutter_highlighter.dart'; -import 'package:flutter_highlighter/themes/shades-of-purple.dart'; -import 'package:flutter_html/flutter_html.dart'; -import 'package:flutter_html_table/flutter_html_table.dart'; -import 'package:flutter_math_fork/flutter_math.dart'; +import 'package:flutter_linkify/flutter_linkify.dart'; +import 'package:highlight/highlight.dart' show highlight; import 'package:html/dom.dart' as dom; -import 'package:linkify/linkify.dart'; +import 'package:html/parser.dart' as parser; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/utils/code_highlight_theme.dart'; +import 'package:fluffychat/utils/event_checkbox_extension.dart'; import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; import '../../../utils/url_launcher.dart'; @@ -19,150 +19,31 @@ class HtmlMessage extends StatelessWidget { final String html; final Room room; final Color textColor; + final double fontSize; + final TextStyle linkStyle; + final void Function(LinkableElement) onOpen; + final String? eventId; + final Set? checkboxCheckedEvents; + final bool limitHeight; const HtmlMessage({ super.key, required this.html, required this.room, + required this.fontSize, + required this.linkStyle, this.textColor = Colors.black, + required this.onOpen, + this.eventId, + this.checkboxCheckedEvents, + this.limitHeight = true, }); - dom.Node _linkifyHtml(dom.Node element) { - for (final node in element.nodes) { - if (node is! dom.Text || - (element is dom.Element && element.localName == 'code')) { - node.replaceWith(_linkifyHtml(node)); - continue; - } - - final parts = linkify( - node.text, - options: const LinkifyOptions(humanize: false), - ); - - if (!parts.any((part) => part is UrlElement)) { - continue; - } - - final newHtml = parts - .map( - (linkifyElement) => linkifyElement is! UrlElement - ? linkifyElement.text.replaceAll('<', '<') - : '${linkifyElement.text}', - ) - .join(' '); - - node.replaceWith(dom.Element.html('

$newHtml

')); - } - return element; - } - - @override - Widget build(BuildContext context) { - final fontSize = AppConfig.messageFontSize * AppConfig.fontSizeFactor; - - final linkColor = textColor.withAlpha(150); - - final blockquoteStyle = Style( - border: Border( - left: BorderSide( - width: 3, - color: textColor, - ), - ), - padding: HtmlPaddings.only(left: 6, bottom: 0), - ); - - final element = _linkifyHtml(HtmlParser.parseHTML(html)); - - // there is no need to pre-validate the html, as we validate it while rendering - return Html.fromElement( - documentElement: element as dom.Element, - style: { - '*': Style( - color: textColor, - margin: Margins.all(0), - fontSize: FontSize(fontSize), - ), - 'a': Style(color: linkColor, textDecorationColor: linkColor), - 'h1': Style( - fontSize: FontSize(fontSize * 2), - lineHeight: LineHeight.number(1.5), - fontWeight: FontWeight.w600, - ), - 'h2': Style( - fontSize: FontSize(fontSize * 1.75), - lineHeight: LineHeight.number(1.5), - fontWeight: FontWeight.w500, - ), - 'h3': Style( - fontSize: FontSize(fontSize * 1.5), - lineHeight: LineHeight.number(1.5), - ), - 'h4': Style( - fontSize: FontSize(fontSize * 1.25), - lineHeight: LineHeight.number(1.5), - ), - 'h5': Style( - fontSize: FontSize(fontSize * 1.25), - lineHeight: LineHeight.number(1.5), - ), - 'h6': Style( - fontSize: FontSize(fontSize), - lineHeight: LineHeight.number(1.5), - ), - 'blockquote': blockquoteStyle, - 'tg-forward': blockquoteStyle, - 'hr': Style( - border: Border.all(color: textColor, width: 0.5), - ), - 'table': Style( - border: Border.all(color: textColor, width: 0.5), - ), - 'tr': Style( - border: Border.all(color: textColor, width: 0.5), - ), - 'td': Style( - border: Border.all(color: textColor, width: 0.5), - padding: HtmlPaddings.all(2), - ), - 'th': Style( - border: Border.all(color: textColor, width: 0.5), - ), - }, - extensions: [ - RoomPillExtension(context, room, fontSize, linkColor), - CodeExtension(fontSize: fontSize), - MatrixMathExtension( - style: TextStyle(fontSize: fontSize, color: textColor), - ), - const TableHtmlExtension(), - SpoilerExtension(textColor: textColor), - const ImageExtension(), - FontColorExtension(), - FallbackTextExtension(fontSize: fontSize), - ], - onLinkTap: (url, _, element) => UrlLauncher( - context, - url, - element?.text, - ).launchUrl(), - onlyRenderTheseTags: const { - ...allowedHtmlTags, - // Needed to make it work properly - 'body', - 'html', - }, - shrinkWrap: true, - ); - } - - static const Set fallbackTextTags = {'tg-forward'}; - - /// Keep in sync with: https://spec.matrix.org/v1.6/client-server-api/#mroommessage-msgtypes + /// Keep in sync with: https://spec.matrix.org/latest/client-server-api/#mroommessage-msgtypes static const Set allowedHtmlTags = { 'font', 'del', + 's', 'h1', 'h2', 'h3', @@ -203,284 +84,439 @@ class HtmlMessage extends StatelessWidget { 'ruby', 'rp', 'rt', - // Workaround for https://github.com/krille-chan/fluffychat/issues/507 - ...fallbackTextTags, + 'html', + 'body', }; -} -class FontColorExtension extends HtmlExtension { - static const String colorAttribute = 'color'; - static const String mxColorAttribute = 'data-mx-color'; - static const String bgColorAttribute = 'data-mx-bg-color'; + static const Set ignoredHtmlTags = {'mx-reply'}; - @override - Set get supportedTags => {'font', 'span'}; + /// We add line breaks before these tags: + static const Set blockHtmlTags = { + 'p', + 'ul', + 'ol', + 'pre', + 'div', + 'table', + 'details', + 'blockquote', + }; - @override - bool matches(ExtensionContext context) { - if (!supportedTags.contains(context.elementName)) return false; - return context.element?.attributes.keys.any( - { - colorAttribute, - mxColorAttribute, - bgColorAttribute, - }.contains, - ) ?? - false; + /// We add line breaks before these tags: + static const Set fullLineHtmlTag = { + 'h1', + 'h2', + 'h3', + 'h4', + 'h5', + 'h6', + 'li', + }; + + /// Adding line breaks before block elements. + List _renderWithLineBreaks( + dom.NodeList nodes, + BuildContext context, { + int depth = 1, + }) { + final onlyElements = nodes.whereType().toList(); + return [ + for (var i = 0; i < nodes.length; i++) ...[ + // Actually render the node child: + _renderHtml(nodes[i], context, depth: depth + 1), + // Add linebreaks between blocks: + if (nodes[i] is dom.Element && + onlyElements.indexOf(nodes[i] as dom.Element) < + onlyElements.length - 1) ...[ + if (blockHtmlTags.contains((nodes[i] as dom.Element).localName)) + const TextSpan(text: '\n\n'), + if (fullLineHtmlTag.contains((nodes[i] as dom.Element).localName)) + const TextSpan(text: '\n'), + ], + ], + ]; } - Color? hexToColor(String? hexCode) { - if (hexCode == null) return null; - if (hexCode.startsWith('#')) hexCode = hexCode.substring(1); - if (hexCode.length == 6) hexCode = 'FF$hexCode'; - final colorValue = int.tryParse(hexCode, radix: 16); - return colorValue == null ? null : Color(colorValue); - } + InlineSpan _renderCodeBlockNode(dom.Node node) { + if (node is! dom.Element) { + return TextSpan(text: node.text); + } + final style = + atomOneDarkTheme[node.className.split('-').last] ?? + atomOneDarkTheme['root']; - @override - InlineSpan build( - ExtensionContext context, - ) { - final colorText = context.element?.attributes[colorAttribute] ?? - context.element?.attributes[mxColorAttribute]; - final bgColor = context.element?.attributes[bgColorAttribute]; return TextSpan( - style: TextStyle( - color: hexToColor(colorText), - backgroundColor: hexToColor(bgColor), - ), - text: context.innerHtml, + children: node.nodes.map(_renderCodeBlockNode).toList(), + style: style, ); } -} -class ImageExtension extends HtmlExtension { - final double defaultDimension; + /// Transforms a Node to an InlineSpan. + InlineSpan _renderHtml(dom.Node node, BuildContext context, {int depth = 1}) { + // We must not render elements nested more than 100 elements deep: + if (depth >= 100) return const TextSpan(); - const ImageExtension({this.defaultDimension = 64}); - - @override - Set get supportedTags => {'img'}; - - @override - InlineSpan build(ExtensionContext context) { - final mxcUrl = Uri.tryParse(context.attributes['src'] ?? ''); - if (mxcUrl == null || mxcUrl.scheme != 'mxc') { - return TextSpan(text: context.attributes['alt']); + if (node is dom.Element && + ignoredHtmlTags.contains(node.localName?.toLowerCase())) { + return const TextSpan(); } - final width = double.tryParse(context.attributes['width'] ?? ''); - final height = double.tryParse(context.attributes['height'] ?? ''); + // This is a text node or not permitted node, so we render it as text: + if (node is! dom.Element || !allowedHtmlTags.contains(node.localName)) { + var text = node.text ?? ''; + // Single linebreak nodes between Elements are ignored: + if (text == '\n') text = ''; - return WidgetSpan( - child: SizedBox( - width: width ?? height ?? defaultDimension, - height: height ?? width ?? defaultDimension, - child: MxcImage( - uri: mxcUrl, - width: width ?? height ?? defaultDimension, - height: height ?? width ?? defaultDimension, - cacheKey: mxcUrl.toString(), - ), - ), - ); - } -} + return LinkifySpan( + text: text, + options: const LinkifyOptions(humanize: false), + linkStyle: linkStyle, + onOpen: onOpen, + ); + } -class SpoilerExtension extends HtmlExtension { - final Color textColor; - - const SpoilerExtension({required this.textColor}); - - @override - Set get supportedTags => {'span'}; - - static const String customDataAttribute = 'data-mx-spoiler'; - - @override - bool matches(ExtensionContext context) { - if (context.elementName != 'span') return false; - return context.element?.attributes.containsKey(customDataAttribute) ?? - false; - } - - @override - InlineSpan build(ExtensionContext context) { - var obscure = true; - final children = context.inlineSpanChildren; - return WidgetSpan( - child: StatefulBuilder( - builder: (context, setState) { - return InkWell( - onTap: () => setState(() { - obscure = !obscure; - }), - child: RichText( - text: TextSpan( - style: obscure ? TextStyle(backgroundColor: textColor) : null, - children: children, + switch (node.localName) { + case 'br': + return const TextSpan(text: '\n'); + case 'a': + final href = node.attributes['href']; + if (href == null) continue block; + final matrixId = node.attributes['href'] + ?.parseIdentifierIntoParts() + ?.primaryIdentifier; + if (matrixId != null) { + if (matrixId.sigil == '@') { + final user = room.unsafeGetUserFromMemoryOrFallback(matrixId); + return WidgetSpan( + child: MatrixPill( + key: Key('user_pill_$matrixId'), + name: user.calcDisplayname(), + avatar: user.avatarUrl, + uri: href, + outerContext: context, + fontSize: fontSize, + color: linkStyle.color, ), - ), - ); - }, - ), - ); - } -} - -class MatrixMathExtension extends HtmlExtension { - final TextStyle? style; - - MatrixMathExtension({this.style}); - @override - Set get supportedTags => {'div'}; - - @override - bool matches(ExtensionContext context) { - if (context.elementName != 'div') return false; - final mathData = context.element?.attributes['data-mx-maths']; - return mathData != null; - } - - @override - InlineSpan build(ExtensionContext context) { - final data = context.element?.attributes['data-mx-maths'] ?? ''; - return WidgetSpan( - child: Math.tex( - data, - textStyle: style, - onErrorFallback: (e) { - Logs().d('Flutter math parse error', e); - return Text( - data, - style: style, - ); - }, - ), - ); - } -} - -class CodeExtension extends HtmlExtension { - final double fontSize; - - CodeExtension({required this.fontSize}); - @override - Set get supportedTags => {'code'}; - - @override - InlineSpan build(ExtensionContext context) => WidgetSpan( - child: Material( - clipBehavior: Clip.hardEdge, - borderRadius: BorderRadius.circular(4), - child: SingleChildScrollView( - scrollDirection: Axis.horizontal, - child: HighlightView( - context.element?.text ?? '', - language: context.element?.className - .split(' ') - .singleWhereOrNull( - (className) => className.startsWith('language-'), - ) - ?.split('language-') - .last ?? - 'md', - theme: shadesOfPurpleTheme, - padding: EdgeInsets.symmetric( - horizontal: 6, - vertical: context.element?.parent?.localName == 'pre' ? 6 : 0, + ); + } + if (matrixId.sigil == '#' || matrixId.sigil == '!') { + final room = matrixId.sigil == '!' + ? this.room.client.getRoomById(matrixId) + : this.room.client.getRoomByAlias(matrixId); + return WidgetSpan( + child: MatrixPill( + name: room?.getLocalizedDisplayname() ?? matrixId, + avatar: room?.avatar, + uri: href, + outerContext: context, + fontSize: fontSize, + color: linkStyle.color, ), - textStyle: TextStyle(fontSize: fontSize), - ), - ), - ), - ); -} - -class FallbackTextExtension extends HtmlExtension { - final double fontSize; - - FallbackTextExtension({required this.fontSize}); - @override - Set get supportedTags => HtmlMessage.fallbackTextTags; - - @override - InlineSpan build(ExtensionContext context) => TextSpan( - text: context.element?.text ?? '', - style: TextStyle( - fontSize: fontSize, - ), - ); -} - -class RoomPillExtension extends HtmlExtension { - final Room room; - final BuildContext context; - final double fontSize; - final Color color; - - RoomPillExtension(this.context, this.room, this.fontSize, this.color); - @override - Set get supportedTags => {'a'}; - - @override - bool matches(ExtensionContext context) { - if (context.elementName != 'a') return false; - final userId = context.element?.attributes['href'] - ?.parseIdentifierIntoParts() - ?.primaryIdentifier; - return userId != null; - } - - static final _cachedUsers = {}; - - Future _fetchUser(String matrixId) async => - _cachedUsers[room.id + matrixId] ??= await room.requestUser(matrixId); - - @override - InlineSpan build(ExtensionContext context) { - final href = context.element?.attributes['href']; - final matrixId = href?.parseIdentifierIntoParts()?.primaryIdentifier; - if (href == null || matrixId == null) { - return TextSpan(text: context.innerHtml); - } - if (matrixId.sigil == '@') { - return WidgetSpan( - child: FutureBuilder( - future: _fetchUser(matrixId), - builder: (context, snapshot) => MatrixPill( - key: Key('user_pill_$matrixId'), - name: _cachedUsers[room.id + matrixId]?.calcDisplayname() ?? - matrixId.localpart ?? - matrixId, - avatar: _cachedUsers[room.id + matrixId]?.avatarUrl, - uri: href, - outerContext: this.context, - fontSize: fontSize, - color: color, - ), - ), - ); - } - if (matrixId.sigil == '#' || matrixId.sigil == '!') { - final room = matrixId.sigil == '!' - ? this.room.client.getRoomById(matrixId) - : this.room.client.getRoomByAlias(matrixId); - if (room != null) { + ); + } + } return WidgetSpan( - child: MatrixPill( - name: room.getLocalizedDisplayname(), - avatar: room.avatar, - uri: href, - outerContext: this.context, - fontSize: fontSize, - color: color, + child: Tooltip( + message: href, + child: InkWell( + splashColor: Colors.transparent, + onTap: () => UrlLauncher(context, href, node.text).launchUrl(), + child: Text.rich( + TextSpan( + children: _renderWithLineBreaks( + node.nodes, + context, + depth: depth, + ), + style: linkStyle, + ), + style: const TextStyle(height: 1.25), + ), + ), ), ); - } - } + case 'li': + if (!{'ol', 'ul'}.contains(node.parent?.localName)) { + continue block; + } + final eventId = this.eventId; - return TextSpan(text: context.innerHtml); + final isCheckbox = node.className == 'task-list-item'; + final checkboxIndex = isCheckbox + ? node.rootElement + .getElementsByClassName('task-list-item') + .indexOf(node) + + 1 + : null; + final checkedByReaction = !isCheckbox + ? null + : checkboxCheckedEvents?.firstWhereOrNull( + (event) => event.checkedCheckboxId == checkboxIndex, + ); + final staticallyChecked = + isCheckbox && node.children.first.attributes['checked'] == 'true'; + + return WidgetSpan( + child: Padding( + padding: EdgeInsets.only(left: fontSize), + child: Text.rich( + TextSpan( + children: [ + if (!isCheckbox) ...[ + if (node.parent?.localName == 'ul') + const TextSpan(text: '• '), + if (node.parent?.localName == 'ol') + TextSpan( + text: + '${(node.parent?.nodes.whereType().toList().indexOf(node) ?? 0) + (int.tryParse(node.parent?.attributes['start'] ?? '1') ?? 1)}. ', + ), + ], + if (node.className == 'task-list-item') + WidgetSpan( + child: Padding( + padding: const EdgeInsets.symmetric(horizontal: 8.0), + child: SizedBox.square( + dimension: fontSize + 2, + child: CupertinoCheckbox( + checkColor: textColor, + side: BorderSide(color: textColor), + activeColor: textColor.withAlpha(64), + value: + staticallyChecked || checkedByReaction != null, + onChanged: + eventId == null || + checkboxIndex == null || + staticallyChecked || + !room.canSendDefaultMessages || + (checkedByReaction != null && + checkedByReaction.senderId != + room.client.userID) + ? null + : (_) => showFutureLoadingDialog( + context: context, + future: () => checkedByReaction != null + ? room.redactEvent( + checkedByReaction.eventId, + ) + : room.checkCheckbox( + eventId, + checkboxIndex, + ), + ), + ), + ), + ), + ), + ..._renderWithLineBreaks(node.nodes, context, depth: depth), + ], + style: TextStyle(fontSize: fontSize, color: textColor), + ), + ), + ), + ); + case 'blockquote': + return WidgetSpan( + child: Container( + padding: const EdgeInsets.only(left: 8.0), + decoration: BoxDecoration( + border: Border(left: BorderSide(color: textColor, width: 5)), + ), + child: Text.rich( + TextSpan( + children: _renderWithLineBreaks( + node.nodes, + context, + depth: depth, + ), + ), + style: TextStyle( + fontStyle: FontStyle.italic, + fontSize: fontSize, + color: textColor, + ), + ), + ), + ); + case 'code': + final isInline = node.parent?.localName != 'pre'; + final lang = + node.className + .split(' ') + .singleWhereOrNull( + (className) => className.startsWith('language-'), + ) + ?.split('language-') + .last ?? + 'md'; + final highlightedHtml = highlight + .parse(node.text, language: lang) + .toHtml(); + final element = parser.parse(highlightedHtml).body; + if (element == null) { + return const TextSpan(text: 'Unable to render code block!'); + } + + return WidgetSpan( + child: Material( + color: atomOneBackgroundColor, + shape: RoundedRectangleBorder( + side: const BorderSide(color: hightlightTextColor), + borderRadius: BorderRadius.circular(4), + ), + child: Padding( + padding: isInline + ? const EdgeInsets.symmetric(horizontal: 4.0) + : const EdgeInsets.symmetric(horizontal: 8.0, vertical: 4.0), + child: Text.rich( + TextSpan(children: [_renderCodeBlockNode(element)]), + selectionColor: hightlightTextColor.withAlpha(128), + ), + ), + ), + ); + case 'img': + final mxcUrl = Uri.tryParse(node.attributes['src'] ?? ''); + if (mxcUrl == null || mxcUrl.scheme != 'mxc') { + return TextSpan(text: node.attributes['alt']); + } + + final width = double.tryParse(node.attributes['width'] ?? ''); + final height = double.tryParse(node.attributes['height'] ?? ''); + const defaultDimension = 64.0; + final actualWidth = width ?? height ?? defaultDimension; + final actualHeight = height ?? width ?? defaultDimension; + + return WidgetSpan( + child: SizedBox( + width: actualWidth, + height: actualHeight, + child: MxcImage( + uri: mxcUrl, + width: actualWidth, + height: actualHeight, + isThumbnail: (actualWidth * actualHeight) > (256 * 256), + ), + ), + ); + case 'hr': + return const WidgetSpan(child: Divider()); + case 'details': + var obscure = true; + return WidgetSpan( + child: StatefulBuilder( + builder: (context, setState) => InkWell( + splashColor: Colors.transparent, + onTap: () => setState(() { + obscure = !obscure; + }), + child: Text.rich( + TextSpan( + children: [ + WidgetSpan( + child: Icon( + obscure ? Icons.arrow_right : Icons.arrow_drop_down, + size: fontSize * 1.2, + color: textColor, + ), + ), + if (obscure) + ...node.nodes + .where( + (node) => + node is dom.Element && + node.localName == 'summary', + ) + .map( + (node) => _renderHtml(node, context, depth: depth), + ) + else + ..._renderWithLineBreaks( + node.nodes, + context, + depth: depth, + ), + ], + ), + style: TextStyle(fontSize: fontSize, color: textColor), + ), + ), + ), + ); + case 'span': + if (!node.attributes.containsKey('data-mx-spoiler')) { + continue block; + } + var obscure = true; + return WidgetSpan( + child: StatefulBuilder( + builder: (context, setState) => InkWell( + splashColor: Colors.transparent, + onTap: () => setState(() { + obscure = !obscure; + }), + child: Text.rich( + TextSpan( + children: _renderWithLineBreaks( + node.nodes, + context, + depth: depth, + ), + ), + style: TextStyle( + fontSize: fontSize, + color: textColor, + backgroundColor: obscure ? textColor : null, + ), + ), + ), + ), + ); + block: + default: + return TextSpan( + style: switch (node.localName) { + 'body' => TextStyle(fontSize: fontSize, color: textColor), + 'a' => linkStyle, + 'strong' => const TextStyle(fontWeight: FontWeight.bold), + 'em' || 'i' => const TextStyle(fontStyle: FontStyle.italic), + 'del' || 's' || 'strikethrough' => const TextStyle( + decoration: TextDecoration.lineThrough, + ), + 'u' => const TextStyle(decoration: TextDecoration.underline), + 'h1' => TextStyle(fontSize: fontSize * 1.6, height: 2), + 'h2' => TextStyle(fontSize: fontSize * 1.5, height: 2), + 'h3' => TextStyle(fontSize: fontSize * 1.4, height: 2), + 'h4' => TextStyle(fontSize: fontSize * 1.3, height: 1.75), + 'h5' => TextStyle(fontSize: fontSize * 1.2, height: 1.75), + 'h6' => TextStyle(fontSize: fontSize * 1.1, height: 1.5), + 'span' => TextStyle( + color: + node.attributes['color']?.hexToColor ?? + node.attributes['data-mx-color']?.hexToColor ?? + textColor, + backgroundColor: node.attributes['data-mx-bg-color']?.hexToColor, + ), + 'sup' => const TextStyle( + fontFeatures: [FontFeature.superscripts()], + ), + 'sub' => const TextStyle(fontFeatures: [FontFeature.subscripts()]), + _ => null, + }, + children: _renderWithLineBreaks(node.nodes, context, depth: depth), + ); + } + } + + @override + Widget build(BuildContext context) { + final element = parser.parse(html).body ?? dom.Element.html(''); + return Text.rich( + _renderHtml(element, context), + style: TextStyle(fontSize: fontSize, color: textColor), + maxLines: limitHeight ? 64 : null, + overflow: TextOverflow.fade, + selectionColor: textColor.withAlpha(128), + ); } } @@ -505,28 +541,44 @@ class MatrixPill extends StatelessWidget { @override Widget build(BuildContext context) { return InkWell( + splashColor: Colors.transparent, onTap: UrlLauncher(outerContext, uri).launchUrl, - child: Row( - mainAxisSize: MainAxisSize.min, - children: [ - Avatar( - mxContent: avatar, - name: name, - size: 16, - ), - const SizedBox(width: 6), - Text( - name, - style: TextStyle( - color: color, - decorationColor: color, - decoration: TextDecoration.underline, - fontSize: fontSize, - height: 1.25, + child: Text.rich( + TextSpan( + children: [ + WidgetSpan( + child: Padding( + padding: const EdgeInsets.only(right: 4.0), + child: Avatar(mxContent: avatar, name: name, size: 16), + ), ), - ), - ], + TextSpan( + text: name, + style: TextStyle( + color: color, + decorationColor: color, + decoration: TextDecoration.underline, + fontSize: fontSize, + height: 1.25, + ), + ), + ], + ), ), ); } } + +extension on String { + Color? get hexToColor { + var hexCode = this; + if (hexCode.startsWith('#')) hexCode = hexCode.substring(1); + if (hexCode.length == 6) hexCode = 'FF$hexCode'; + final colorValue = int.tryParse(hexCode, radix: 16); + return colorValue == null ? null : Color(colorValue); + } +} + +extension on dom.Element { + dom.Element get rootElement => parent?.rootElement ?? this; +} diff --git a/lib/pages/chat/events/image_bubble.dart b/lib/pages/chat/events/image_bubble.dart index f5219b054..845814fc1 100644 --- a/lib/pages/chat/events/image_bubble.dart +++ b/lib/pages/chat/events/image_bubble.dart @@ -1,9 +1,12 @@ import 'package:flutter/material.dart'; +import 'package:flutter_linkify/flutter_linkify.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/pages/image_viewer/image_viewer.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/utils/file_description.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; import '../../../widgets/blur_hash.dart'; @@ -11,19 +14,20 @@ class ImageBubble extends StatelessWidget { final Event event; final bool tapToView; final BoxFit fit; - final bool maxSize; final Color? backgroundColor; + final Color? textColor; + final Color? linkColor; final bool thumbnailOnly; final bool animated; final double width; final double height; final void Function()? onTap; final BorderRadius? borderRadius; + final Timeline? timeline; const ImageBubble( this.event, { this.tapToView = true, - this.maxSize = true, this.backgroundColor, this.fit = BoxFit.contain, this.thumbnailOnly = true, @@ -32,14 +36,16 @@ class ImageBubble extends StatelessWidget { this.animated = false, this.onTap, this.borderRadius, + this.timeline, + this.textColor, + this.linkColor, super.key, }); Widget _buildPlaceholder(BuildContext context) { - final String blurHashString = - event.infoMap['xyz.amorgan.blurhash'] is String - ? event.infoMap['xyz.amorgan.blurhash'] - : 'LEHV6nWB2yk8pyo0adR*.7kCMdnj'; + final blurHashString = + event.infoMap.tryGet('xyz.amorgan.blurhash') ?? + 'LEHV6nWB2yk8pyo0adR*.7kCMdnj'; return SizedBox( width: width, height: height, @@ -52,52 +58,85 @@ class ImageBubble extends StatelessWidget { ); } - void _onTap(BuildContext context) { - if (onTap != null) { - onTap!(); - return; - } - if (!tapToView) return; - showDialog( - context: context, - useRootNavigator: false, - builder: (_) => ImageViewer(event), - ); - } - @override Widget build(BuildContext context) { - final borderRadius = + final theme = Theme.of(context); + + var borderRadius = this.borderRadius ?? BorderRadius.circular(AppConfig.borderRadius); - return Material( - color: Colors.transparent, - clipBehavior: Clip.hardEdge, - shape: RoundedRectangleBorder( - borderRadius: borderRadius, - side: BorderSide( - color: event.messageType == MessageTypes.Sticker - ? Colors.transparent - : Theme.of(context).dividerColor, - ), - ), - child: InkWell( - onTap: () => _onTap(context), - borderRadius: borderRadius, - child: Hero( - tag: event.eventId, - child: MxcImage( - event: event, - width: width, - height: height, - fit: fit, - animated: animated, - isThumbnail: thumbnailOnly, - placeholder: event.messageType == MessageTypes.Sticker - ? null - : _buildPlaceholder, + + final fileDescription = event.fileDescription; + final textColor = this.textColor; + + if (fileDescription != null) { + borderRadius = borderRadius.copyWith( + bottomLeft: Radius.zero, + bottomRight: Radius.zero, + ); + } + + return Column( + mainAxisSize: .min, + spacing: 8, + children: [ + Material( + color: Colors.transparent, + clipBehavior: Clip.hardEdge, + shape: RoundedRectangleBorder( + borderRadius: borderRadius, + side: BorderSide( + color: event.messageType == MessageTypes.Sticker + ? Colors.transparent + : theme.dividerColor, + ), + ), + child: InkWell( + onTap: onTap, + borderRadius: borderRadius, + child: Hero( + tag: event.eventId, + child: MxcImage( + event: event, + width: width, + height: height, + fit: fit, + animated: animated, + isThumbnail: thumbnailOnly, + placeholder: event.messageType == MessageTypes.Sticker + ? null + : _buildPlaceholder, + ), + ), ), ), - ), + if (fileDescription != null && textColor != null) + SizedBox( + width: width, + child: Padding( + padding: const EdgeInsets.symmetric(horizontal: 16, vertical: 8), + child: Linkify( + text: fileDescription, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + style: TextStyle( + color: textColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + ), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: linkColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + decoration: TextDecoration.underline, + decorationColor: linkColor, + ), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), + ), + ), + ), + ], ); } } diff --git a/lib/pages/chat/events/map_bubble.dart b/lib/pages/chat/events/map_bubble.dart index e9eab056b..a23dc7a8d 100644 --- a/lib/pages/chat/events/map_bubble.dart +++ b/lib/pages/chat/events/map_bubble.dart @@ -3,6 +3,8 @@ import 'package:flutter/material.dart'; import 'package:flutter_map/flutter_map.dart'; import 'package:latlong2/latlong.dart'; +import '../../../config/app_config.dart'; + class MapBubble extends StatelessWidget { final double latitude; final double longitude; @@ -22,6 +24,8 @@ class MapBubble extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return ClipRRect( borderRadius: BorderRadius.circular(radius), child: Container( @@ -41,6 +45,7 @@ class MapBubble extends StatelessWidget { minZoom: 0, urlTemplate: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', + userAgentPackageName: AppConfig.appId, subdomains: const ['a', 'b', 'c'], ), MarkerLayer( @@ -72,11 +77,10 @@ class MapBubble extends StatelessWidget { child: Text( ' © OpenStreetMap contributors ', style: TextStyle( - color: Theme.of(context).brightness == Brightness.dark + color: theme.brightness == Brightness.dark ? Colors.white : Colors.black, - backgroundColor: - Theme.of(context).appBarTheme.backgroundColor, + backgroundColor: theme.appBarTheme.backgroundColor, ), ), ), diff --git a/lib/pages/chat/events/message.dart b/lib/pages/chat/events/message.dart index 6a4ec3f2e..a350599e6 100644 --- a/lib/pages/chat/events/message.dart +++ b/lib/pages/chat/events/message.dart @@ -1,21 +1,28 @@ +import 'dart:ui' as ui; + import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:emoji_picker_flutter/emoji_picker_flutter.dart'; import 'package:matrix/matrix.dart'; import 'package:swipe_to_action/swipe_to_action.dart'; +import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/date_time_extension.dart'; +import 'package:fluffychat/utils/file_description.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import 'package:fluffychat/utils/string_color.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import 'package:fluffychat/widgets/member_actions_popup_menu_button.dart'; import '../../../config/app_config.dart'; import 'message_content.dart'; import 'message_reactions.dart'; import 'reply_content.dart'; import 'state_message.dart'; -import 'verification_request_content.dart'; class Message extends StatelessWidget { final Event event; @@ -23,17 +30,25 @@ class Message extends StatelessWidget { final Event? previousEvent; final bool displayReadMarker; final void Function(Event) onSelect; - final void Function(Event) onAvatarTab; final void Function(Event) onInfoTab; final void Function(String) scrollToEventId; final void Function() onSwipe; + final void Function() onMention; + final void Function() onEdit; + final void Function(String eventId)? enterThread; final bool longPressSelect; final bool selected; + final bool singleSelected; final Timeline timeline; final bool highlightMarker; final bool animateIn; final void Function()? resetAnimateIn; - final Color? avatarPresenceBackgroundColor; + final bool wallpaperMode; + final ScrollController scrollController; + final List colors; + final void Function()? onExpand; + final bool isCollapsed; + final Set bigEmojis; const Message( this.event, { @@ -41,48 +56,61 @@ class Message extends StatelessWidget { this.previousEvent, this.displayReadMarker = false, this.longPressSelect = false, + required this.bigEmojis, required this.onSelect, required this.onInfoTab, - required this.onAvatarTab, required this.scrollToEventId, required this.onSwipe, this.selected = false, + required this.onEdit, + required this.singleSelected, required this.timeline, this.highlightMarker = false, this.animateIn = false, this.resetAnimateIn, - this.avatarPresenceBackgroundColor, + this.wallpaperMode = false, + required this.onMention, + required this.scrollController, + required this.colors, + this.onExpand, + required this.enterThread, + this.isCollapsed = false, super.key, }); @override Widget build(BuildContext context) { + final theme = Theme.of(context); + if (!{ EventTypes.Message, EventTypes.Sticker, EventTypes.Encrypted, EventTypes.CallInvite, + PollEventContent.startType, }.contains(event.type)) { if (event.type.startsWith('m.call.')) { return const SizedBox.shrink(); } - return StateMessage(event); + return StateMessage(event, onExpand: onExpand, isCollapsed: isCollapsed); } if (event.type == EventTypes.Message && event.messageType == EventTypes.KeyVerificationRequest) { - return VerificationRequestContent(event: event, timeline: timeline); + return StateMessage(event); } final client = Matrix.of(context).client; final ownMessage = event.senderId == client.userID; final alignment = ownMessage ? Alignment.topRight : Alignment.topLeft; - // ignore: deprecated_member_use - var color = Theme.of(context).colorScheme.surfaceVariant; - final displayTime = event.type == EventTypes.RoomCreate || + + var color = theme.colorScheme.surfaceContainerHigh; + final displayTime = + event.type == EventTypes.RoomCreate || nextEvent == null || !event.originServerTs.sameEnvironment(nextEvent!.originServerTs); - final nextEventSameSender = nextEvent != null && + final nextEventSameSender = + nextEvent != null && { EventTypes.Message, EventTypes.Sticker, @@ -91,7 +119,8 @@ class Message extends StatelessWidget { nextEvent!.senderId == event.senderId && !displayTime; - final previousEventSameSender = previousEvent != null && + final previousEventSameSender = + previousEvent != null && { EventTypes.Message, EventTypes.Sticker, @@ -101,10 +130,18 @@ class Message extends StatelessWidget { previousEvent!.originServerTs.sameEnvironment(event.originServerTs); final textColor = ownMessage - ? Theme.of(context).colorScheme.onPrimary - : Theme.of(context).colorScheme.onSurface; - final rowMainAxisAlignment = - ownMessage ? MainAxisAlignment.end : MainAxisAlignment.start; + ? theme.onBubbleColor + : theme.colorScheme.onSurface; + + final linkColor = ownMessage + ? theme.brightness == Brightness.light + ? theme.colorScheme.primaryFixed + : theme.colorScheme.onTertiaryContainer + : theme.colorScheme.primary; + + final rowMainAxisAlignment = ownMessage + ? MainAxisAlignment.end + : MainAxisAlignment.start; final displayEvent = event.getDisplayEvent(timeline); const hardCorner = Radius.circular(4); @@ -112,416 +149,80 @@ class Message extends StatelessWidget { final borderRadius = BorderRadius.only( topLeft: !ownMessage && nextEventSameSender ? hardCorner : roundedCorner, topRight: ownMessage && nextEventSameSender ? hardCorner : roundedCorner, - bottomLeft: - !ownMessage && previousEventSameSender ? hardCorner : roundedCorner, - bottomRight: - ownMessage && previousEventSameSender ? hardCorner : roundedCorner, + bottomLeft: !ownMessage && previousEventSameSender + ? hardCorner + : roundedCorner, + bottomRight: ownMessage && previousEventSameSender + ? hardCorner + : roundedCorner, ); - final noBubble = { + final noBubble = + ({ MessageTypes.Video, MessageTypes.Image, MessageTypes.Sticker, }.contains(event.messageType) && - !event.redacted; - final noPadding = { - MessageTypes.File, - MessageTypes.Audio, - }.contains(event.messageType); + event.fileDescription == null && + !event.redacted); if (ownMessage) { color = displayEvent.status.isError ? Colors.redAccent - : Theme.of(context).colorScheme.primary; + : theme.bubbleColor; } final resetAnimateIn = this.resetAnimateIn; var animateIn = this.animateIn; - final row = StatefulBuilder( - builder: (context, setState) { - if (animateIn && resetAnimateIn != null) { - WidgetsBinding.instance.addPostFrameCallback((timeStamp) { - animateIn = false; - setState(resetAnimateIn); - }); - } - return AnimatedSize( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - clipBehavior: Clip.none, - alignment: ownMessage ? Alignment.bottomRight : Alignment.bottomLeft, - child: animateIn - ? const SizedBox(height: 0, width: double.infinity) - : Stack( - children: [ - Positioned( - top: 0, - bottom: 0, - left: 0, - right: 0, - child: InkWell( - onTap: () => onSelect(event), - onLongPress: () => onSelect(event), - borderRadius: - BorderRadius.circular(AppConfig.borderRadius / 2), - child: Material( - borderRadius: - BorderRadius.circular(AppConfig.borderRadius / 2), - color: selected - ? Theme.of(context) - .colorScheme - .secondaryContainer - .withAlpha(100) - : highlightMarker - ? Theme.of(context) - .colorScheme - .tertiaryContainer - .withAlpha(100) - : Colors.transparent, - ), - ), - ), - Row( - crossAxisAlignment: CrossAxisAlignment.start, - mainAxisAlignment: rowMainAxisAlignment, - children: [ - if (longPressSelect) - SizedBox( - height: 32, - width: Avatar.defaultSize, - child: Checkbox.adaptive( - value: selected, - shape: const CircleBorder(), - onChanged: (_) => onSelect(event), - ), - ) - else if (nextEventSameSender || ownMessage) - SizedBox( - width: Avatar.defaultSize, - child: Center( - child: SizedBox( - width: 16, - height: 16, - child: event.status == EventStatus.error - ? const Icon(Icons.error, color: Colors.red) - : event.fileSendingStatus != null - ? const CircularProgressIndicator - .adaptive( - strokeWidth: 1, - ) - : null, - ), - ), - ) - else - FutureBuilder( - future: event.fetchSenderUser(), - builder: (context, snapshot) { - final user = snapshot.data ?? - event.senderFromMemoryOrFallback; - return Avatar( - mxContent: user.avatarUrl, - name: user.calcDisplayname(), - presenceUserId: user.stateKey, - presenceBackgroundColor: - avatarPresenceBackgroundColor, - onTap: () => onAvatarTab(event), - ); - }, - ), - Expanded( - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - mainAxisSize: MainAxisSize.min, - children: [ - if (!nextEventSameSender) - Padding( - padding: const EdgeInsets.only( - left: 8.0, - bottom: 4, - ), - child: ownMessage || event.room.isDirectChat - ? const SizedBox(height: 12) - : FutureBuilder( - future: event.fetchSenderUser(), - builder: (context, snapshot) { - final displayname = snapshot.data - ?.calcDisplayname() ?? - event.senderFromMemoryOrFallback - .calcDisplayname(); - return Text( - displayname, - style: TextStyle( - fontSize: 12, - color: (Theme.of(context) - .brightness == - Brightness.light - ? displayname.color - : displayname - .lightColorText), - ), - maxLines: 1, - overflow: TextOverflow.ellipsis, - ); - }, - ), - ), - Container( - alignment: alignment, - padding: const EdgeInsets.only(left: 8), - child: GestureDetector( - onLongPress: longPressSelect - ? null - : () { - HapticFeedback.heavyImpact(); - onSelect(event); - }, - child: AnimatedOpacity( - opacity: animateIn - ? 0 - : event.redacted || - event.messageType == - MessageTypes.BadEncrypted || - event.status.isSending - ? 0.5 - : 1, - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - child: Material( - color: - noBubble ? Colors.transparent : color, - clipBehavior: Clip.antiAlias, - shape: RoundedRectangleBorder( - borderRadius: borderRadius, - ), - child: Container( - decoration: BoxDecoration( - borderRadius: BorderRadius.circular( - AppConfig.borderRadius, - ), - ), - padding: noBubble || noPadding - ? EdgeInsets.zero - : const EdgeInsets.symmetric( - horizontal: 16, - vertical: 8, - ), - constraints: const BoxConstraints( - maxWidth: - FluffyThemes.columnWidth * 1.5, - ), - child: Column( - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: - CrossAxisAlignment.start, - children: [ - if (event.relationshipType == - RelationshipTypes.reply) - FutureBuilder( - future: event - .getReplyEvent(timeline), - builder: ( - BuildContext context, - snapshot, - ) { - final replyEvent = snapshot - .hasData - ? snapshot.data! - : Event( - eventId: event - .relationshipEventId!, - content: { - 'msgtype': 'm.text', - 'body': '...', - }, - senderId: - event.senderId, - type: - 'm.room.message', - room: event.room, - status: - EventStatus.sent, - originServerTs: - DateTime.now(), - ); - return Padding( - padding: - const EdgeInsets.only( - bottom: 4.0, - ), - child: InkWell( - borderRadius: ReplyContent - .borderRadius, - onTap: () => - scrollToEventId( - replyEvent.eventId, - ), - child: AbsorbPointer( - child: ReplyContent( - replyEvent, - ownMessage: - ownMessage, - timeline: timeline, - ), - ), - ), - ); - }, - ), - MessageContent( - displayEvent, - textColor: textColor, - onInfoTab: onInfoTab, - borderRadius: borderRadius, - ), - if (event.hasAggregatedEvents( - timeline, - RelationshipTypes.edit, - )) - Padding( - padding: const EdgeInsets.only( - top: 4.0, - ), - child: Row( - mainAxisSize: - MainAxisSize.min, - children: [ - Icon( - Icons.edit_outlined, - color: textColor - .withAlpha(164), - size: 14, - ), - Text( - ' - ${displayEvent.originServerTs.localizedTimeShort(context)}', - style: TextStyle( - color: textColor - .withAlpha(164), - fontSize: 12, - ), - ), - ], - ), - ), - ], - ), - ), - ), - ), - ), - ), - ], - ), - ), - ], - ), - ], - ), - ); - }, - ); - Widget container; - final showReceiptsRow = - event.hasAggregatedEvents(timeline, RelationshipTypes.reaction); - if (showReceiptsRow || displayTime || selected || displayReadMarker) { - container = Column( - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: - ownMessage ? CrossAxisAlignment.end : CrossAxisAlignment.start, - children: [ - if (displayTime || selected) - Padding( - padding: displayTime - ? const EdgeInsets.symmetric(vertical: 8.0) - : EdgeInsets.zero, - child: Center( - child: Material( - color: displayTime - ? Theme.of(context).colorScheme.surface - : Theme.of(context).colorScheme.surface.withOpacity(0.33), - borderRadius: - BorderRadius.circular(AppConfig.borderRadius / 2), - clipBehavior: Clip.antiAlias, - child: Padding( - padding: const EdgeInsets.only(top: 4.0), - child: Text( - event.originServerTs.localizedTime(context), - style: TextStyle( - fontWeight: FontWeight.bold, - fontSize: 12 * AppConfig.fontSizeFactor, - color: Theme.of(context).colorScheme.secondary, - ), - ), - ), - ), - ), - ), - row, - AnimatedSize( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - child: !showReceiptsRow - ? const SizedBox.shrink() - : Padding( - padding: EdgeInsets.only( - top: 4.0, - left: (ownMessage ? 0 : Avatar.defaultSize) + 12.0, - right: ownMessage ? 0 : 12.0, - ), - child: MessageReactions(event, timeline), - ), - ), - if (displayReadMarker) - Row( - children: [ - Expanded( - child: Divider(color: Theme.of(context).colorScheme.primary), - ), - Container( - decoration: BoxDecoration( - border: Border.all( - color: Theme.of(context).colorScheme.primary, - ), - color: Theme.of(context).colorScheme.primaryContainer, - borderRadius: BorderRadius.circular(4), - ), - margin: const EdgeInsets.all(8.0), - padding: const EdgeInsets.symmetric( - horizontal: 8, - ), - child: Text( - L10n.of(context)!.readUpToHere, - style: - TextStyle(color: Theme.of(context).colorScheme.primary), - ), - ), - Expanded( - child: Divider(color: Theme.of(context).colorScheme.primary), - ), - ], - ), - ], + final sentReactions = {}; + if (singleSelected) { + sentReactions.addAll( + event + .aggregatedEvents(timeline, RelationshipTypes.reaction) + .where( + (event) => + event.senderId == event.room.client.userID && + event.type == 'm.reaction', + ) + .map( + (event) => event.content + .tryGetMap('m.relates_to') + ?.tryGet('key'), + ) + .whereType(), ); - } else { - container = row; } + final hasReactions = event.hasAggregatedEvents( + timeline, + RelationshipTypes.reaction, + ); + + final threadChildren = event.aggregatedEvents( + timeline, + RelationshipTypes.thread, + ); + + final showReactionPicker = + singleSelected && event.room.canSendDefaultMessages; + + final enterThread = this.enterThread; + final sender = event.senderFromMemoryOrFallback; + return Center( child: Swipeable( key: ValueKey(event.eventId), background: const Padding( padding: EdgeInsets.symmetric(horizontal: 12.0), - child: Center( - child: Icon(Icons.check_outlined), - ), + child: Center(child: Icon(Icons.check_outlined)), ), - direction: AppConfig.swipeRightToLeftToReply + direction: AppSettings.swipeRightToLeftToReply.value ? SwipeDirection.endToStart : SwipeDirection.startToEnd, onSwipe: (_) => onSwipe(), child: Container( constraints: const BoxConstraints( - maxWidth: FluffyThemes.columnWidth * 2.5, + maxWidth: FluffyThemes.maxTimelineWidth, ), padding: EdgeInsets.only( left: 8.0, @@ -529,9 +230,806 @@ class Message extends StatelessWidget { top: nextEventSameSender ? 1.0 : 4.0, bottom: previousEventSameSender ? 1.0 : 4.0, ), - child: container, + child: Column( + mainAxisSize: .min, + crossAxisAlignment: ownMessage ? .end : .start, + children: [ + if (displayTime || selected) + Padding( + padding: displayTime + ? const EdgeInsets.symmetric(vertical: 8.0) + : EdgeInsets.zero, + child: Center( + child: Padding( + padding: const EdgeInsets.only(top: 4.0), + child: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius * 2, + ), + color: theme.colorScheme.surface.withAlpha(128), + child: Padding( + padding: const EdgeInsets.symmetric( + horizontal: 8.0, + vertical: 2.0, + ), + child: Text( + event.originServerTs.localizedTime(context), + style: TextStyle( + fontSize: 12 * AppSettings.fontSizeFactor.value, + fontWeight: FontWeight.bold, + color: theme.colorScheme.secondary, + ), + ), + ), + ), + ), + ), + ), + StatefulBuilder( + builder: (context, setState) { + if (animateIn && resetAnimateIn != null) { + WidgetsBinding.instance.addPostFrameCallback((timeStamp) { + animateIn = false; + setState(resetAnimateIn); + }); + } + return AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + clipBehavior: Clip.none, + alignment: ownMessage + ? Alignment.bottomRight + : Alignment.bottomLeft, + child: animateIn + ? const SizedBox(height: 0, width: double.infinity) + : Stack( + clipBehavior: Clip.none, + children: [ + Positioned( + top: 0, + bottom: 0, + left: 0, + right: 0, + child: InkWell( + hoverColor: longPressSelect + ? Colors.transparent + : null, + enableFeedback: !selected, + onTap: longPressSelect + ? null + : () => onSelect(event), + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 2, + ), + child: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 2, + ), + color: selected || highlightMarker + ? theme.colorScheme.secondaryContainer + .withAlpha(128) + : Colors.transparent, + ), + ), + ), + Row( + crossAxisAlignment: .start, + mainAxisAlignment: rowMainAxisAlignment, + children: [ + if (longPressSelect && !event.redacted) + SizedBox( + height: 32, + width: Avatar.defaultSize, + child: IconButton( + padding: EdgeInsets.zero, + tooltip: L10n.of(context).select, + icon: Icon( + selected + ? Icons.check_circle + : Icons.circle_outlined, + ), + onPressed: () => onSelect(event), + ), + ) + else if (nextEventSameSender || ownMessage) + SizedBox( + width: Avatar.defaultSize, + child: Center( + child: SizedBox( + width: 16, + height: 16, + child: + event.status == EventStatus.error + ? const Icon( + Icons.error, + color: Colors.red, + ) + : event.fileSendingStatus != null + ? const CircularProgressIndicator.adaptive( + strokeWidth: 1, + ) + : null, + ), + ), + ) + else + FutureBuilder( + future: event.fetchSenderUser(), + builder: (context, snapshot) { + final user = snapshot.data ?? sender; + return Avatar( + mxContent: user.avatarUrl, + name: user.calcDisplayname(), + onTap: () => + showMemberActionsPopupMenu( + context: context, + user: user, + onMention: onMention, + ), + presenceUserId: user.stateKey, + presenceBackgroundColor: wallpaperMode + ? Colors.transparent + : null, + ); + }, + ), + Expanded( + child: Column( + crossAxisAlignment: .start, + mainAxisSize: .min, + children: [ + if (!nextEventSameSender) + Padding( + padding: const EdgeInsets.only( + left: 8.0, + bottom: 4, + ), + child: + ownMessage || + event.room.isDirectChat + ? const SizedBox(height: 12) + : Row( + children: [ + if (sender.powerLevel >= + 50) + Padding( + padding: + const EdgeInsets.only( + right: 2.0, + ), + child: Icon( + sender.powerLevel >= + 100 + ? Icons + .admin_panel_settings + : Icons + .add_moderator_outlined, + size: 14, + color: theme + .colorScheme + .onPrimaryContainer, + ), + ), + Expanded( + child: FutureBuilder( + future: event + .fetchSenderUser(), + builder: (context, snapshot) { + final displayname = + snapshot.data + ?.calcDisplayname() ?? + sender + .calcDisplayname(); + return Text( + displayname, + style: TextStyle( + fontSize: 11, + fontWeight: + FontWeight + .bold, + color: + (theme.brightness == + Brightness + .light + ? displayname + .color + : displayname + .lightColorText), + shadows: + !wallpaperMode + ? null + : [ + const Shadow( + offset: Offset( + 0.0, + 0.0, + ), + blurRadius: + 3, + color: + Colors.black, + ), + ], + ), + maxLines: 1, + overflow: + TextOverflow + .ellipsis, + ); + }, + ), + ), + ], + ), + ), + Container( + alignment: alignment, + padding: const EdgeInsets.only( + left: 8, + ), + child: GestureDetector( + onLongPress: longPressSelect + ? null + : () { + HapticFeedback.heavyImpact(); + onSelect(event); + }, + child: AnimatedOpacity( + opacity: animateIn + ? 0 + : event.messageType == + MessageTypes + .BadEncrypted || + event.status.isSending + ? 0.5 + : 1, + duration: FluffyThemes + .animationDuration, + curve: + FluffyThemes.animationCurve, + child: Container( + decoration: BoxDecoration( + color: noBubble + ? Colors.transparent + : color, + borderRadius: borderRadius, + ), + clipBehavior: Clip.antiAlias, + child: BubbleBackground( + colors: colors, + ignore: + noBubble || + !ownMessage || + MediaQuery.highContrastOf( + context, + ), + scrollController: + scrollController, + child: Container( + decoration: BoxDecoration( + borderRadius: + BorderRadius.circular( + AppConfig + .borderRadius, + ), + ), + constraints: + const BoxConstraints( + maxWidth: + FluffyThemes + .columnWidth * + 1.5, + ), + child: Column( + mainAxisSize: .min, + crossAxisAlignment: + CrossAxisAlignment + .start, + children: [ + if (event.inReplyToEventId( + includingFallback: + false, + ) != + null) + FutureBuilder( + future: event + .getReplyEvent( + timeline, + ), + builder: + ( + BuildContext + context, + snapshot, + ) { + final replyEvent = + snapshot + .hasData + ? snapshot + .data! + : Event( + eventId: + event.inReplyToEventId() ?? + '\$fake_event_id', + content: { + 'msgtype': + 'm.text', + 'body': + '...', + }, + senderId: + event.senderId, + type: + 'm.room.message', + room: + event.room, + status: + EventStatus.sent, + originServerTs: + DateTime.now(), + ); + return Padding( + padding: + const EdgeInsets.only( + left: + 16, + right: + 16, + top: + 8, + ), + child: Material( + color: Colors + .transparent, + borderRadius: + ReplyContent + .borderRadius, + child: InkWell( + borderRadius: + ReplyContent.borderRadius, + onTap: () => scrollToEventId( + replyEvent + .eventId, + ), + child: AbsorbPointer( + child: ReplyContent( + replyEvent, + ownMessage: + ownMessage, + timeline: + timeline, + ), + ), + ), + ), + ); + }, + ), + MessageContent( + displayEvent, + textColor: textColor, + linkColor: linkColor, + onInfoTab: onInfoTab, + borderRadius: + borderRadius, + timeline: timeline, + selected: selected, + bigEmojis: bigEmojis, + ), + if (event + .hasAggregatedEvents( + timeline, + RelationshipTypes + .edit, + )) + Padding( + padding: + const EdgeInsets.only( + bottom: 8.0, + left: 16.0, + right: 16.0, + ), + child: Row( + mainAxisSize: + MainAxisSize + .min, + spacing: 4.0, + children: [ + Icon( + Icons + .edit_outlined, + color: textColor + .withAlpha( + 164, + ), + size: 14, + ), + Text( + displayEvent + .originServerTs + .localizedTimeShort( + context, + ), + style: TextStyle( + color: textColor + .withAlpha( + 164, + ), + fontSize: + 11, + ), + ), + ], + ), + ), + ], + ), + ), + ), + ), + ), + ), + ), + Align( + alignment: ownMessage + ? Alignment.bottomRight + : Alignment.bottomLeft, + child: AnimatedSize( + duration: + FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: showReactionPicker + ? Padding( + padding: + const EdgeInsets.all( + 4.0, + ), + child: Material( + elevation: 4, + borderRadius: + BorderRadius.circular( + AppConfig + .borderRadius, + ), + shadowColor: theme + .colorScheme + .surface + .withAlpha(128), + child: SingleChildScrollView( + scrollDirection: + Axis.horizontal, + child: Row( + mainAxisSize: .min, + children: [ + ...AppConfig.defaultReactions.map( + ( + emoji, + ) => IconButton( + padding: + EdgeInsets + .zero, + icon: Center( + child: Opacity( + opacity: + sentReactions.contains( + emoji, + ) + ? 0.33 + : 1, + child: Text( + emoji, + style: const TextStyle( + fontSize: + 20, + ), + textAlign: + TextAlign + .center, + ), + ), + ), + onPressed: + sentReactions + .contains( + emoji, + ) + ? null + : () { + onSelect( + event, + ); + event.room.sendReaction( + event + .eventId, + emoji, + ); + }, + ), + ), + IconButton( + icon: const Icon( + Icons + .add_reaction_outlined, + ), + tooltip: L10n.of( + context, + ).customReaction, + onPressed: () async { + final emoji = await showAdaptiveBottomSheet( + context: + context, + builder: (context) => Scaffold( + appBar: AppBar( + title: Text( + L10n.of( + context, + ).customReaction, + ), + leading: CloseButton( + onPressed: () => Navigator.of( + context, + ).pop(null), + ), + ), + body: SizedBox( + height: double + .infinity, + child: EmojiPicker( + onEmojiSelected: + ( + _, + emoji, + ) => + Navigator.of( + context, + ).pop( + emoji.emoji, + ), + config: Config( + locale: Localizations.localeOf( + context, + ), + emojiViewConfig: const EmojiViewConfig( + backgroundColor: + Colors.transparent, + ), + bottomActionBarConfig: const BottomActionBarConfig( + enabled: + false, + ), + categoryViewConfig: CategoryViewConfig( + initCategory: + Category.SMILEYS, + backspaceColor: + theme.colorScheme.primary, + iconColor: theme.colorScheme.primary.withAlpha( + 128, + ), + iconColorSelected: + theme.colorScheme.primary, + indicatorColor: + theme.colorScheme.primary, + backgroundColor: + theme.colorScheme.surface, + ), + skinToneConfig: SkinToneConfig( + dialogBackgroundColor: Color.lerp( + theme.colorScheme.surface, + theme.colorScheme.primaryContainer, + 0.75, + )!, + indicatorColor: + theme.colorScheme.onSurface, + ), + ), + ), + ), + ), + ); + if (emoji == + null) { + return; + } + if (sentReactions + .contains( + emoji, + )) { + return; + } + onSelect(event); + + await event.room + .sendReaction( + event + .eventId, + emoji, + ); + }, + ), + ], + ), + ), + ), + ) + : const SizedBox.shrink(), + ), + ), + ], + ), + ), + ], + ), + ], + ), + ); + }, + ), + + AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + alignment: Alignment.bottomCenter, + child: !hasReactions + ? const SizedBox.shrink() + : Padding( + padding: EdgeInsets.only( + top: 1.0, + left: (ownMessage ? 0 : Avatar.defaultSize) + 12.0, + right: ownMessage ? 0 : 12.0, + ), + child: MessageReactions(event, timeline), + ), + ), + if (enterThread != null) + AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + alignment: Alignment.bottomCenter, + child: threadChildren.isEmpty + ? const SizedBox.shrink() + : Padding( + padding: const EdgeInsets.only( + top: 2.0, + bottom: 8.0, + left: Avatar.defaultSize + 8, + ), + child: ConstrainedBox( + constraints: const BoxConstraints( + maxWidth: FluffyThemes.columnWidth * 1.5, + ), + child: TextButton.icon( + style: TextButton.styleFrom( + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular(4), + ), + foregroundColor: + theme.colorScheme.onSecondaryContainer, + backgroundColor: + theme.colorScheme.secondaryContainer, + ), + onPressed: () => enterThread(event.eventId), + icon: const Icon(Icons.message), + label: Text( + '${L10n.of(context).countReplies(threadChildren.length)} | ${threadChildren.first.calcLocalizedBodyFallback(MatrixLocals(L10n.of(context)), withSenderNamePrefix: true)}', + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + ), + ), + ), + ), + if (displayReadMarker) + Row( + children: [ + Expanded( + child: Divider( + color: theme.colorScheme.surfaceContainerHighest, + ), + ), + Container( + margin: const EdgeInsets.symmetric( + horizontal: 4, + vertical: 16.0, + ), + padding: const EdgeInsets.symmetric( + horizontal: 8, + vertical: 2, + ), + decoration: BoxDecoration( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 3, + ), + color: theme.colorScheme.surface.withAlpha(128), + ), + child: Text( + L10n.of(context).readUpToHere, + style: TextStyle( + fontSize: 12 * AppSettings.fontSizeFactor.value, + ), + ), + ), + Expanded( + child: Divider( + color: theme.colorScheme.surfaceContainerHighest, + ), + ), + ], + ), + ], + ), ), ), ); } } + +class BubbleBackground extends StatelessWidget { + const BubbleBackground({ + super.key, + required this.scrollController, + required this.colors, + required this.ignore, + required this.child, + }); + + final ScrollController scrollController; + final List colors; + final bool ignore; + final Widget child; + + @override + Widget build(BuildContext context) { + if (ignore) return child; + return CustomPaint( + painter: BubblePainter( + repaint: scrollController, + colors: colors, + context: context, + ), + child: child, + ); + } +} + +class BubblePainter extends CustomPainter { + BubblePainter({ + required this.context, + required this.colors, + required super.repaint, + }); + + final BuildContext context; + final List colors; + ScrollableState? _scrollable; + + @override + void paint(Canvas canvas, Size size) { + final scrollable = _scrollable ??= Scrollable.of(context); + final scrollableBox = scrollable.context.findRenderObject() as RenderBox; + final scrollableRect = Offset.zero & scrollableBox.size; + final bubbleBox = context.findRenderObject() as RenderBox; + + final origin = bubbleBox.localToGlobal( + Offset.zero, + ancestor: scrollableBox, + ); + final paint = Paint() + ..shader = ui.Gradient.linear( + scrollableRect.topCenter, + scrollableRect.bottomCenter, + colors, + [0.0, 1.0], + TileMode.clamp, + Matrix4.translationValues(-origin.dx, -origin.dy, 0.0).storage, + ); + canvas.drawRect(Offset.zero & size, paint); + } + + @override + bool shouldRepaint(BubblePainter oldDelegate) { + final scrollable = Scrollable.of(context); + final oldScrollable = _scrollable; + _scrollable = scrollable; + return scrollable.position != oldScrollable?.position; + } +} diff --git a/lib/pages/chat/events/message_content.dart b/lib/pages/chat/events/message_content.dart index 5aeb650a4..24041eab0 100644 --- a/lib/pages/chat/events/message_content.dart +++ b/lib/pages/chat/events/message_content.dart @@ -2,20 +2,24 @@ import 'dart:math'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_linkify/flutter_linkify.dart'; +import 'package:go_router/go_router.dart'; +import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat/events/poll.dart'; import 'package:fluffychat/pages/chat/events/video_player.dart'; +import 'package:fluffychat/pages/image_viewer/image_viewer.dart'; import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/date_time_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/matrix.dart'; import '../../../config/app_config.dart'; +import '../../../utils/event_checkbox_extension.dart'; import '../../../utils/platform_infos.dart'; import '../../../utils/url_launcher.dart'; -import '../../bootstrap/bootstrap_dialog.dart'; import 'audio_player.dart'; import 'cute_events.dart'; import 'html_message.dart'; @@ -26,34 +30,39 @@ import 'message_download_content.dart'; class MessageContent extends StatelessWidget { final Event event; final Color textColor; + final Color linkColor; final void Function(Event)? onInfoTab; final BorderRadius borderRadius; + final Timeline timeline; + final bool selected; + final Set bigEmojis; const MessageContent( this.event, { this.onInfoTab, super.key, + required this.timeline, required this.textColor, + required this.linkColor, required this.borderRadius, + required this.selected, + required this.bigEmojis, }); - void _verifyOrRequestKey(BuildContext context) async { - final l10n = L10n.of(context)!; + Future _verifyOrRequestKey(BuildContext context) async { + final l10n = L10n.of(context); if (event.content['can_request_session'] != true) { ScaffoldMessenger.of(context).showSnackBar( SnackBar( - content: Text( - event.calcLocalizedBodyFallback(MatrixLocals(l10n)), - ), + content: Text(event.calcLocalizedBodyFallback(MatrixLocals(l10n))), ), ); return; } final client = Matrix.of(context).client; - if (client.isUnknownSession && client.encryption!.crossSigning.enabled) { - final success = await BootstrapDialog( - client: Matrix.of(context).client, - ).show(context); + final state = await client.getCryptoIdentityState(); + if (!state.connected) { + final success = await context.push('/backup'); if (success != true) return; } event.requestKey(); @@ -85,11 +94,7 @@ class MessageContent extends StatelessWidget { trailing: const Icon(Icons.lock_outlined), ), const Divider(), - Text( - event.calcLocalizedBodyFallback( - MatrixLocals(l10n), - ), - ), + Text(event.calcLocalizedBodyFallback(MatrixLocals(l10n))), ], ), ), @@ -99,7 +104,8 @@ class MessageContent extends StatelessWidget { @override Widget build(BuildContext context) { - final fontSize = AppConfig.messageFontSize * AppConfig.fontSizeFactor; + final fontSize = + AppConfig.messageFontSize * AppSettings.fontSizeFactor.value; final buttonTextColor = textColor; switch (event.type) { case EventTypes.Message: @@ -109,7 +115,9 @@ class MessageContent extends StatelessWidget { case MessageTypes.Image: case MessageTypes.Sticker: if (event.redacted) continue textmessage; - const maxSize = 256.0; + final maxSize = event.messageType == MessageTypes.Sticker + ? 128.0 + : 256.0; final w = event.content .tryGetMap('info') ?.tryGet('w'); @@ -137,70 +145,77 @@ class MessageContent extends StatelessWidget { height: height, fit: fit, borderRadius: borderRadius, + timeline: timeline, + textColor: textColor, + onTap: () => showDialog( + context: context, + builder: (_) => ImageViewer( + event, + timeline: timeline, + outerContext: context, + ), + ), ); case CuteEventContent.eventType: return CuteContent(event); case MessageTypes.Audio: if (PlatformInfos.isMobile || - PlatformInfos.isMacOS || - PlatformInfos.isWeb - // Disabled until https://github.com/bleonard252/just_audio_mpv/issues/3 - // is fixed - // || PlatformInfos.isLinux - ) { + PlatformInfos.isMacOS || + PlatformInfos.isWeb + // Disabled until https://github.com/bleonard252/just_audio_mpv/issues/3 + // is fixed + // || PlatformInfos.isLinux + ) { return AudioPlayerWidget( event, color: textColor, + linkColor: linkColor, + fontSize: fontSize, ); } - return MessageDownloadContent(event, textColor); + return MessageDownloadContent( + event, + textColor: textColor, + linkColor: linkColor, + ); case MessageTypes.Video: - return EventVideoPlayer(event); + return EventVideoPlayer( + event, + textColor: textColor, + linkColor: linkColor, + timeline: timeline, + ); case MessageTypes.File: - return MessageDownloadContent(event, textColor); - - case MessageTypes.Text: - case MessageTypes.Notice: - case MessageTypes.Emote: - if (AppConfig.renderHtml && - !event.redacted && - event.isRichMessage) { - var html = event.formattedText; - if (event.messageType == MessageTypes.Emote) { - html = '* $html'; - } - return HtmlMessage( - html: html, - textColor: textColor, - room: event.room, - ); - } - // else we fall through to the normal message rendering - continue textmessage; + return MessageDownloadContent( + event, + textColor: textColor, + linkColor: linkColor, + ); case MessageTypes.BadEncrypted: case EventTypes.Encrypted: return _ButtonContent( textColor: buttonTextColor, onPressed: () => _verifyOrRequestKey(context), icon: '🔒', - label: L10n.of(context)!.encrypted, + label: L10n.of(context).encrypted, fontSize: fontSize, ); case MessageTypes.Location: - final geoUri = - Uri.tryParse(event.content.tryGet('geo_uri')!); + final geoUri = Uri.tryParse( + event.content.tryGet('geo_uri')!, + ); if (geoUri != null && geoUri.scheme == 'geo') { final latlong = geoUri.path .split(';') .first .split(',') - .map((s) => double.tryParse(s)) + .map(double.tryParse) .toList(); if (latlong.length == 2 && latlong.first != null && latlong.last != null) { return Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ MapBubble( latitude: latlong.first!, @@ -209,10 +224,12 @@ class MessageContent extends StatelessWidget { const SizedBox(height: 6), OutlinedButton.icon( icon: Icon(Icons.location_on_outlined, color: textColor), - onPressed: - UrlLauncher(context, geoUri.toString()).launchUrl, + onPressed: UrlLauncher( + context, + geoUri.toString(), + ).launchUrl, label: Text( - L10n.of(context)!.openInMaps, + L10n.of(context).openInMaps, style: TextStyle(color: textColor), ), ), @@ -221,62 +238,79 @@ class MessageContent extends StatelessWidget { } } continue textmessage; + case MessageTypes.Text: + case MessageTypes.Notice: + case MessageTypes.Emote: case MessageTypes.None: textmessage: default: if (event.redacted) { - return FutureBuilder( - future: event.redactedBecause?.fetchSenderUser(), - builder: (context, snapshot) { - final reason = - event.redactedBecause?.content.tryGet('reason'); - final redactedBy = snapshot.data?.calcDisplayname() ?? - event.redactedBecause?.senderId.localpart ?? - L10n.of(context)!.user; - return _ButtonContent( - label: reason == null - ? L10n.of(context)!.redactedBy(redactedBy) - : L10n.of(context)!.redactedByBecause( - redactedBy, - reason, - ), - icon: '🗑️', - textColor: buttonTextColor, - onPressed: () => onInfoTab!(event), - fontSize: fontSize, - ); - }, + return RedactionWidget( + event: event, + buttonTextColor: buttonTextColor, + onInfoTab: onInfoTab, + fontSize: fontSize, ); } - final bigEmotes = event.onlyEmotes && - event.numberEmotes > 0 && - event.numberEmotes <= 10; - return Linkify( - text: event.calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), - hideReply: true, + var html = AppSettings.renderHtml.value && event.isRichMessage + ? event.formattedText + : event.body.replaceAll('<', '<').replaceAll('>', '>'); + if (event.messageType == MessageTypes.Emote) { + html = '* $html'; + } + + final bigEmotes = + !event.isRichMessage && bigEmojis.contains(event.body); + + return Padding( + padding: const EdgeInsets.symmetric(horizontal: 16, vertical: 8), + child: HtmlMessage( + html: html, + textColor: textColor, + room: event.room, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize * + (bigEmotes ? 5 : 1), + limitHeight: !selected, + linkStyle: TextStyle( + color: linkColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + decoration: TextDecoration.underline, + decorationColor: linkColor, + ), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), + eventId: event.eventId, + checkboxCheckedEvents: event.aggregatedEvents( + timeline, + EventCheckboxRoomExtension.relationshipType, + ), ), - style: TextStyle( - color: textColor, - fontSize: bigEmotes ? fontSize * 3 : fontSize, - decoration: event.redacted ? TextDecoration.lineThrough : null, - ), - options: const LinkifyOptions(humanize: false), - linkStyle: TextStyle( - color: textColor.withAlpha(150), - fontSize: bigEmotes ? fontSize * 3 : fontSize, - decoration: TextDecoration.underline, - decorationColor: textColor.withAlpha(150), - ), - onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), ); } + case PollEventContent.startType: + if (event.redacted) { + return RedactionWidget( + event: event, + buttonTextColor: buttonTextColor, + onInfoTab: onInfoTab, + fontSize: fontSize, + ); + } + return PollWidget( + event: event, + timeline: timeline, + textColor: textColor, + linkColor: linkColor, + ); case EventTypes.CallInvite: return FutureBuilder( future: event.fetchSenderUser(), builder: (context, snapshot) { return _ButtonContent( - label: L10n.of(context)!.startedACall( + label: L10n.of(context).startedACall( snapshot.data?.calcDisplayname() ?? event.senderFromMemoryOrFallback.calcDisplayname(), ), @@ -292,7 +326,7 @@ class MessageContent extends StatelessWidget { future: event.fetchSenderUser(), builder: (context, snapshot) { return _ButtonContent( - label: L10n.of(context)!.userSentUnknownEvent( + label: L10n.of(context).userSentUnknownEvent( snapshot.data?.calcDisplayname() ?? event.senderFromMemoryOrFallback.calcDisplayname(), event.type, @@ -308,6 +342,44 @@ class MessageContent extends StatelessWidget { } } +class RedactionWidget extends StatelessWidget { + const RedactionWidget({ + super.key, + required this.event, + required this.buttonTextColor, + required this.onInfoTab, + required this.fontSize, + }); + + final Event event; + final Color buttonTextColor; + final void Function(Event p1)? onInfoTab; + final double fontSize; + + @override + Widget build(BuildContext context) { + return FutureBuilder( + future: event.redactedBecause?.fetchSenderUser(), + builder: (context, snapshot) { + final reason = event.redactedBecause?.content.tryGet('reason'); + final redactedBy = + snapshot.data?.calcDisplayname() ?? + event.redactedBecause?.senderId.localpart ?? + L10n.of(context).user; + return _ButtonContent( + label: reason == null + ? L10n.of(context).redactedBy(redactedBy) + : L10n.of(context).redactedByBecause(redactedBy, reason), + icon: '🗑️', + textColor: buttonTextColor.withAlpha(128), + onPressed: () => onInfoTab!(event), + fontSize: fontSize, + ); + }, + ); + } +} + class _ButtonContent extends StatelessWidget { final void Function() onPressed; final String label; @@ -325,13 +397,13 @@ class _ButtonContent extends StatelessWidget { @override Widget build(BuildContext context) { - return InkWell( - onTap: onPressed, - child: Text( - '$icon $label', - style: TextStyle( - color: textColor, - fontSize: fontSize, + return Padding( + padding: const EdgeInsets.symmetric(horizontal: 16, vertical: 8), + child: InkWell( + onTap: onPressed, + child: Text( + '$icon $label', + style: TextStyle(color: textColor, fontSize: fontSize), ), ), ); diff --git a/lib/pages/chat/events/message_download_content.dart b/lib/pages/chat/events/message_download_content.dart index 767ea8e7b..501c02433 100644 --- a/lib/pages/chat/events/message_download_content.dart +++ b/lib/pages/chat/events/message_download_content.dart @@ -1,14 +1,25 @@ import 'package:flutter/material.dart'; +import 'package:flutter_linkify/flutter_linkify.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/utils/file_description.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/event_extension.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; class MessageDownloadContent extends StatelessWidget { final Event event; final Color textColor; + final Color linkColor; - const MessageDownloadContent(this.event, this.textColor, {super.key}); + const MessageDownloadContent( + this.event, { + required this.textColor, + required this.linkColor, + super.key, + }); @override Widget build(BuildContext context) { @@ -16,64 +27,90 @@ class MessageDownloadContent extends StatelessWidget { final filetype = (filename.contains('.') ? filename.split('.').last.toUpperCase() : event.content - .tryGetMap('info') - ?.tryGet('mimetype') - ?.toUpperCase() ?? - 'UNKNOWN'); - final sizeString = event.sizeString; - return InkWell( - onTap: () => event.saveFile(context), - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - mainAxisSize: MainAxisSize.min, - children: [ - Padding( - padding: const EdgeInsets.all(16.0), - child: Row( - children: [ - Icon( - Icons.file_download_outlined, - color: textColor, - ), - const SizedBox(width: 16), - Flexible( - child: Text( - filename, - maxLines: 1, - style: TextStyle( - color: textColor, - fontWeight: FontWeight.bold, - ), - overflow: TextOverflow.ellipsis, + .tryGetMap('info') + ?.tryGet('mimetype') + ?.toUpperCase() ?? + 'UNKNOWN'); + final sizeString = event.sizeString ?? '?MB'; + final fileDescription = event.fileDescription; + return Column( + mainAxisSize: .min, + crossAxisAlignment: .start, + spacing: 8, + children: [ + Material( + color: Colors.transparent, + child: InkWell( + borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), + onTap: () => event.saveFile(context), + child: Container( + width: 400, + padding: const EdgeInsets.all(16.0), + child: Row( + mainAxisSize: .min, + spacing: 16, + children: [ + CircleAvatar( + backgroundColor: textColor.withAlpha(32), + child: Icon(Icons.file_download_outlined, color: textColor), ), - ), - ], + Flexible( + child: Column( + crossAxisAlignment: .start, + mainAxisSize: .min, + children: [ + Text( + filename, + maxLines: 1, + overflow: TextOverflow.ellipsis, + style: TextStyle( + color: textColor, + fontWeight: FontWeight.w500, + ), + ), + Text( + '$sizeString | $filetype', + maxLines: 1, + overflow: TextOverflow.ellipsis, + style: TextStyle(color: textColor, fontSize: 10), + ), + ], + ), + ), + ], + ), ), ), - const Divider(height: 1), + ), + if (fileDescription != null) ...[ Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0, vertical: 8), - child: Row( - children: [ - Text( - filetype, - style: TextStyle( - color: textColor.withAlpha(150), - ), - ), - const Spacer(), - if (sizeString != null) - Text( - sizeString, - style: TextStyle( - color: textColor.withAlpha(150), - ), - ), - ], + padding: const EdgeInsets.symmetric( + horizontal: 16.0, + vertical: 8.0, + ), + child: Linkify( + text: fileDescription, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + style: TextStyle( + color: textColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + ), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: linkColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + decoration: TextDecoration.underline, + decorationColor: linkColor, + ), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), ), ), ], - ), + ], ); } } diff --git a/lib/pages/chat/events/message_reactions.dart b/lib/pages/chat/events/message_reactions.dart index 56286cae0..4bafaa6f3 100644 --- a/lib/pages/chat/events/message_reactions.dart +++ b/lib/pages/chat/events/message_reactions.dart @@ -1,11 +1,11 @@ import 'package:flutter/material.dart'; import 'package:collection/collection.dart' show IterableExtension; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; @@ -17,14 +17,16 @@ class MessageReactions extends StatelessWidget { @override Widget build(BuildContext context) { - final allReactionEvents = - event.aggregatedEvents(timeline, RelationshipTypes.reaction); + final allReactionEvents = event.aggregatedEvents( + timeline, + RelationshipTypes.reaction, + ); final reactionMap = {}; final client = Matrix.of(context).client; for (final e in allReactionEvents) { final key = e.content - .tryGetMap('m.relates_to') + .tryGetMap('m.relates_to') ?.tryGet('key'); if (key != null) { if (!reactionMap.containsKey(key)) { @@ -64,7 +66,7 @@ class MessageReactions extends StatelessWidget { if (evt != null) { showFutureLoadingDialog( context: context, - future: () => evt.redactEvent(), + future: evt.redactEvent, ); } } else { @@ -108,27 +110,27 @@ class _Reaction extends StatelessWidget { @override Widget build(BuildContext context) { - final textColor = Theme.of(context).brightness == Brightness.dark - ? Colors.white - : Colors.black; - final color = Theme.of(context).colorScheme.surface; + final theme = Theme.of(context); + Widget content; if (reactionKey.startsWith('mxc://')) { content = Row( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ MxcImage( uri: Uri.parse(reactionKey), width: 20, height: 20, animated: false, + isThumbnail: false, ), if (count > 1) ...[ const SizedBox(width: 4), Text( count.toString(), + textAlign: TextAlign.center, style: TextStyle( - color: textColor, + color: theme.colorScheme.onSurface, fontSize: DefaultTextStyle.of(context).style.fontSize, ), ), @@ -143,7 +145,7 @@ class _Reaction extends StatelessWidget { content = Text( renderKey.toString() + (count > 1 ? ' $count' : ''), style: TextStyle( - color: textColor, + color: theme.colorScheme.onSurface, fontSize: DefaultTextStyle.of(context).style.fontSize, ), ); @@ -154,12 +156,14 @@ class _Reaction extends StatelessWidget { borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), child: Container( decoration: BoxDecoration( - color: color, + color: reacted == true + ? theme.colorScheme.primaryContainer + : theme.colorScheme.surfaceContainerHigh, border: Border.all( + color: reacted == true + ? theme.colorScheme.primary + : theme.colorScheme.surfaceContainerHigh, width: 1, - color: reacted! - ? Theme.of(context).colorScheme.primary - : Theme.of(context).colorScheme.primaryContainer, ), borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), ), @@ -188,17 +192,14 @@ class _AdaptableReactorsDialog extends StatelessWidget { final Client? client; final _ReactionEntry? reactionEntry; - const _AdaptableReactorsDialog({ - this.client, - this.reactionEntry, - }); + const _AdaptableReactorsDialog({this.client, this.reactionEntry}); Future show(BuildContext context) => showAdaptiveDialog( - context: context, - builder: (context) => this, - barrierDismissible: true, - useRootNavigator: false, - ); + context: context, + builder: (context) => this, + barrierDismissible: true, + useRootNavigator: false, + ); @override Widget build(BuildContext context) { @@ -224,9 +225,6 @@ class _AdaptableReactorsDialog extends StatelessWidget { final title = Center(child: Text(reactionEntry!.key)); - return AlertDialog.adaptive( - title: title, - content: body, - ); + return AlertDialog.adaptive(title: title, content: body); } } diff --git a/lib/pages/chat/events/poll.dart b/lib/pages/chat/events/poll.dart new file mode 100644 index 000000000..d4506602d --- /dev/null +++ b/lib/pages/chat/events/poll.dart @@ -0,0 +1,230 @@ +import 'package:flutter/material.dart'; + +import 'package:async/async.dart'; +import 'package:flutter_linkify/flutter_linkify.dart'; +import 'package:matrix/matrix.dart' hide Result; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; +import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; + +class PollWidget extends StatelessWidget { + final Event event; + final Timeline timeline; + final Color textColor; + final Color linkColor; + const PollWidget({ + required this.event, + required this.timeline, + required this.textColor, + required this.linkColor, + super.key, + }); + + void _endPoll(BuildContext context) => + showFutureLoadingDialog(context: context, future: event.endPoll); + + void _toggleVote(BuildContext context, String answerId, int maxSelection) { + final userId = event.room.client.userID!; + final answerIds = event.getPollResponses(timeline)[userId] ?? {}; + if (!answerIds.remove(answerId)) { + answerIds.add(answerId); + if (answerIds.length > maxSelection) { + answerIds.clear(); + answerIds.add(answerId); + } + } + + showFutureLoadingDialog( + context: context, + future: () => event.answerPoll(answerIds.toList()), + ); + } + + @override + Widget build(BuildContext context) { + final eventContentResult = Result(() => event.parsedPollEventContent); + final eventContent = eventContentResult.asValue?.value; + if (eventContent == null) { + Logs().w('Invalid poll event', eventContentResult.error); + return const Text('Unable to parse poll event...'); + } + final responses = event.getPollResponses(timeline); + final pollHasBeenEnded = event.getPollHasBeenEnded(timeline); + final canVote = + event.room.canSendEvent(PollEventContent.responseType) && + !pollHasBeenEnded; + final maxPolls = responses.length; + final answersVisible = + eventContent.pollStartContent.kind == PollKind.disclosed || + pollHasBeenEnded; + + return Padding( + padding: const EdgeInsets.symmetric(vertical: 8), + child: Column( + mainAxisSize: .min, + crossAxisAlignment: .start, + children: [ + Padding( + padding: const EdgeInsets.symmetric(horizontal: 16), + child: Linkify( + text: eventContent.pollStartContent.question.mText, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + style: TextStyle( + color: textColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + ), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: linkColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + decoration: TextDecoration.underline, + decorationColor: linkColor, + ), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), + ), + ), + Divider(color: linkColor.withAlpha(64)), + ...eventContent.pollStartContent.answers.map((answer) { + final votedUserIds = responses.entries + .where((entry) => entry.value.contains(answer.id)) + .map((entry) => entry.key) + .toSet(); + return Material( + color: Colors.transparent, + clipBehavior: Clip.hardEdge, + child: CheckboxListTile.adaptive( + value: + responses[event.room.client.userID!]?.contains(answer.id) ?? + false, + contentPadding: const EdgeInsets.symmetric(horizontal: 16), + checkboxScaleFactor: 1.5, + checkboxShape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular(32), + ), + onChanged: !canVote + ? null + : (_) => _toggleVote( + context, + answer.id, + eventContent.pollStartContent.maxSelections, + ), + title: Text( + answer.mText, + maxLines: 1, + overflow: TextOverflow.ellipsis, + style: TextStyle( + color: textColor, + fontSize: + AppConfig.messageFontSize * + AppSettings.fontSizeFactor.value, + ), + ), + subtitle: answersVisible + ? Column( + crossAxisAlignment: .start, + mainAxisSize: .min, + children: [ + SingleChildScrollView( + scrollDirection: Axis.horizontal, + child: Row( + children: [ + Text( + L10n.of( + context, + ).countVotes(votedUserIds.length), + maxLines: 1, + overflow: TextOverflow.ellipsis, + style: TextStyle( + color: linkColor, + fontSize: + 12 * AppSettings.fontSizeFactor.value, + ), + ), + const SizedBox(width: 2), + ...votedUserIds.map((userId) { + final user = event.room + .getState(EventTypes.RoomMember, userId) + ?.asUser(event.room); + return Padding( + padding: const EdgeInsets.symmetric( + horizontal: 2.0, + ), + child: Avatar( + mxContent: user?.avatarUrl, + name: + user?.calcDisplayname() ?? + userId.localpart, + size: + 12 * AppSettings.fontSizeFactor.value, + ), + ); + }), + const SizedBox(width: 2), + ], + ), + ), + LinearProgressIndicator( + color: linkColor, + backgroundColor: linkColor.withAlpha(128), + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + value: maxPolls == 0 + ? 0 + : votedUserIds.length / maxPolls, + ), + ], + ) + : null, + ), + ); + }), + if (!pollHasBeenEnded && event.senderId == event.room.client.userID) + Padding( + padding: const EdgeInsets.symmetric(horizontal: 16), + child: OutlinedButton( + onPressed: () => _endPoll(context), + style: OutlinedButton.styleFrom( + foregroundColor: linkColor, + side: BorderSide(color: linkColor.withAlpha(64)), + ), + child: Text(L10n.of(context).endPoll), + ), + ) + else if (!answersVisible) + Padding( + padding: const EdgeInsets.symmetric(horizontal: 16), + child: Text( + L10n.of(context).answersWillBeVisibleWhenPollHasEnded, + style: TextStyle( + color: linkColor, + fontSize: 12 * AppSettings.fontSizeFactor.value, + fontStyle: FontStyle.italic, + ), + ), + ) + else if (pollHasBeenEnded) + Padding( + padding: const EdgeInsets.symmetric(horizontal: 16), + child: Text( + L10n.of(context).pollHasBeenEnded, + style: TextStyle( + color: linkColor, + fontSize: 12 * AppSettings.fontSizeFactor.value, + fontStyle: FontStyle.italic, + ), + ), + ), + ], + ), + ); + } +} diff --git a/lib/pages/chat/events/reply_content.dart b/lib/pages/chat/events/reply_content.dart index 945ae22ac..8211e431f 100644 --- a/lib/pages/chat/events/reply_content.dart +++ b/lib/pages/chat/events/reply_content.dart @@ -1,8 +1,9 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import '../../../config/app_config.dart'; @@ -10,14 +11,12 @@ class ReplyContent extends StatelessWidget { final Event replyEvent; final bool ownMessage; final Timeline? timeline; - final Color? backgroundColor; const ReplyContent( this.replyEvent, { this.ownMessage = false, super.key, this.timeline, - this.backgroundColor, }); static const BorderRadius borderRadius = BorderRadius.only( @@ -27,36 +26,42 @@ class ReplyContent extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final timeline = this.timeline; - final displayEvent = - timeline != null ? replyEvent.getDisplayEvent(timeline) : replyEvent; - final fontSize = AppConfig.messageFontSize * AppConfig.fontSizeFactor; - final color = ownMessage - ? Theme.of(context).colorScheme.primaryContainer - : Theme.of(context).colorScheme.primary; + final displayEvent = timeline != null + ? replyEvent.getDisplayEvent(timeline) + : replyEvent; + final fontSize = + AppConfig.messageFontSize * AppSettings.fontSizeFactor.value; + final color = theme.brightness == Brightness.dark + ? theme.colorScheme.onTertiaryContainer + : ownMessage + ? theme.colorScheme.tertiaryContainer + : theme.colorScheme.tertiary; return Material( - color: backgroundColor ?? - Theme.of(context) - .colorScheme - .surface - .withOpacity(ownMessage ? 0.2 : 0.33), + color: Colors.transparent, borderRadius: borderRadius, child: Row( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ Container( - width: 3, + width: 5, height: fontSize * 2 + 16, - color: color, + decoration: BoxDecoration( + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + color: color, + ), ), const SizedBox(width: 6), Flexible( child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - mainAxisAlignment: MainAxisAlignment.center, + crossAxisAlignment: .start, + mainAxisAlignment: .center, children: [ FutureBuilder( + initialData: displayEvent.senderFromMemoryOrFallback, future: displayEvent.fetchSenderUser(), builder: (context, snapshot) { return Text( @@ -73,16 +78,19 @@ class ReplyContent extends StatelessWidget { ), Text( displayEvent.calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), withSenderNamePrefix: false, hideReply: true, + plaintextBody: true, ), overflow: TextOverflow.ellipsis, maxLines: 1, style: TextStyle( - color: ownMessage - ? Theme.of(context).colorScheme.onPrimary - : Theme.of(context).colorScheme.onSurface, + color: theme.brightness == Brightness.dark + ? theme.colorScheme.onSurface + : ownMessage + ? theme.colorScheme.onTertiary + : theme.colorScheme.onSurface, fontSize: fontSize, ), ), diff --git a/lib/pages/chat/events/state_message.dart b/lib/pages/chat/events/state_message.dart index 0aa5d9dc2..9c8ad3da7 100644 --- a/lib/pages/chat/events/state_message.dart +++ b/lib/pages/chat/events/state_message.dart @@ -1,38 +1,83 @@ +import 'package:flutter/gestures.dart'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import '../../../config/app_config.dart'; class StateMessage extends StatelessWidget { final Event event; - const StateMessage(this.event, {super.key}); + final void Function()? onExpand; + final bool isCollapsed; + const StateMessage( + this.event, { + this.onExpand, + this.isCollapsed = false, + super.key, + }); @override Widget build(BuildContext context) { - return Padding( - padding: const EdgeInsets.symmetric(horizontal: 8.0), - child: Center( - child: Container( - padding: const EdgeInsets.all(8), - decoration: BoxDecoration( - color: Theme.of(context).colorScheme.surface, - borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), - ), - child: Text( - event.calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), + final theme = Theme.of(context); + return AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: isCollapsed + ? const SizedBox.shrink() + : Padding( + padding: const EdgeInsets.symmetric(horizontal: 8.0), + child: Center( + child: Padding( + padding: const EdgeInsets.all(4), + child: Material( + color: theme.colorScheme.surface.withAlpha(128), + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 3, + ), + child: Padding( + padding: const EdgeInsets.symmetric( + horizontal: 8.0, + vertical: 4.0, + ), + child: Text.rich( + TextSpan( + children: [ + TextSpan( + text: event.calcLocalizedBodyFallback( + MatrixLocals(L10n.of(context)), + ), + ), + if (onExpand != null) ...[ + const TextSpan(text: '\n'), + TextSpan( + style: TextStyle( + color: theme.colorScheme.primary, + decoration: TextDecoration.underline, + ), + recognizer: TapGestureRecognizer() + ..onTap = onExpand, + text: L10n.of(context).moreEvents, + ), + ], + ], + ), + textAlign: TextAlign.center, + style: TextStyle( + fontSize: 11 * AppSettings.fontSizeFactor.value, + decoration: event.redacted + ? TextDecoration.lineThrough + : null, + ), + ), + ), + ), + ), + ), ), - textAlign: TextAlign.center, - style: TextStyle( - fontSize: 12 * AppConfig.fontSizeFactor, - decoration: event.redacted ? TextDecoration.lineThrough : null, - ), - ), - ), - ), ); } } diff --git a/lib/pages/chat/events/verification_request_content.dart b/lib/pages/chat/events/verification_request_content.dart deleted file mode 100644 index b6ec3fd09..000000000 --- a/lib/pages/chat/events/verification_request_content.dart +++ /dev/null @@ -1,70 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:matrix/matrix.dart'; - -import '../../../config/app_config.dart'; - -class VerificationRequestContent extends StatelessWidget { - final Event event; - final Timeline timeline; - - const VerificationRequestContent({ - required this.event, - required this.timeline, - super.key, - }); - - @override - Widget build(BuildContext context) { - final events = event.aggregatedEvents(timeline, 'm.reference'); - final done = events.where((e) => e.type == EventTypes.KeyVerificationDone); - final start = - events.where((e) => e.type == EventTypes.KeyVerificationStart); - final cancel = - events.where((e) => e.type == EventTypes.KeyVerificationCancel); - final fullyDone = done.length >= 2; - final started = start.isNotEmpty; - final canceled = cancel.isNotEmpty; - return Padding( - padding: const EdgeInsets.symmetric( - horizontal: 8.0, - vertical: 4.0, - ), - child: Center( - child: Container( - padding: const EdgeInsets.all(8), - decoration: BoxDecoration( - border: Border.all( - color: Theme.of(context).dividerColor, - ), - borderRadius: BorderRadius.circular(AppConfig.borderRadius), - color: Theme.of(context).colorScheme.surface, - ), - child: Row( - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: CrossAxisAlignment.center, - children: [ - Icon( - Icons.lock_outlined, - color: canceled - ? Colors.red - : (fullyDone ? Colors.green : Colors.grey), - ), - const SizedBox(width: 8), - Text( - canceled - ? 'Error ${cancel.first.content.tryGet('code')}: ${cancel.first.content.tryGet('reason')}' - : (fullyDone - ? L10n.of(context)!.verifySuccess - : (started - ? L10n.of(context)!.loadingPleaseWait - : L10n.of(context)!.newVerificationRequest)), - ), - ], - ), - ), - ), - ); - } -} diff --git a/lib/pages/chat/events/video_player.dart b/lib/pages/chat/events/video_player.dart index 1b0983bd4..d0593cb4a 100644 --- a/lib/pages/chat/events/video_player.dart +++ b/lib/pages/chat/events/video_player.dart @@ -1,150 +1,160 @@ -import 'dart:io'; +import 'dart:math'; -import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; -import 'package:chewie/chewie.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:flutter_linkify/flutter_linkify.dart'; import 'package:matrix/matrix.dart'; -import 'package:path_provider/path_provider.dart'; -import 'package:universal_html/html.dart' as html; -import 'package:video_player/video_player.dart'; import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/pages/chat/events/image_bubble.dart'; -import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/utils/file_description.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/event_extension.dart'; import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; import 'package:fluffychat/widgets/blur_hash.dart'; -import '../../../utils/error_reporter.dart'; +import 'package:fluffychat/widgets/mxc_image.dart'; +import '../../image_viewer/image_viewer.dart'; -class EventVideoPlayer extends StatefulWidget { +class EventVideoPlayer extends StatelessWidget { final Event event; - const EventVideoPlayer(this.event, {super.key}); + final Timeline? timeline; + final Color? textColor; + final Color? linkColor; - @override - EventVideoPlayerState createState() => EventVideoPlayerState(); -} - -class EventVideoPlayerState extends State { - ChewieController? _chewieManager; - bool _isDownloading = false; - String? _networkUri; - File? _tmpFile; - - void _downloadAction() async { - if (PlatformInfos.isDesktop) { - widget.event.saveFile(context); - return; - } - setState(() => _isDownloading = true); - try { - final videoFile = await widget.event.downloadAndDecryptAttachment(); - if (kIsWeb) { - final blob = html.Blob([videoFile.bytes]); - _networkUri = html.Url.createObjectUrlFromBlob(blob); - } else { - final tempDir = await getTemporaryDirectory(); - final fileName = Uri.encodeComponent( - widget.event.attachmentOrThumbnailMxcUrl()!.pathSegments.last, - ); - final file = File('${tempDir.path}/${fileName}_${videoFile.name}'); - if (await file.exists() == false) { - await file.writeAsBytes(videoFile.bytes); - } - _tmpFile = file; - } - final tmpFile = _tmpFile; - final networkUri = _networkUri; - if (kIsWeb && networkUri != null && _chewieManager == null) { - _chewieManager ??= ChewieController( - videoPlayerController: - VideoPlayerController.networkUrl(Uri.parse(networkUri)), - autoPlay: true, - autoInitialize: true, - ); - } else if (!kIsWeb && tmpFile != null && _chewieManager == null) { - _chewieManager ??= ChewieController( - useRootNavigator: false, - videoPlayerController: VideoPlayerController.file(tmpFile), - autoPlay: true, - autoInitialize: true, - ); - } - } on MatrixConnectionException catch (e) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text(e.toLocalizedString(context)), - ), - ); - } catch (e, s) { - ErrorReporter(context, 'Unable to play video').onErrorCallback(e, s); - } finally { - // Workaround for Chewie needs time to get the aspectRatio - await Future.delayed(const Duration(milliseconds: 100)); - setState(() => _isDownloading = false); - } - } - - @override - void dispose() { - _chewieManager?.dispose(); - super.dispose(); - } + const EventVideoPlayer( + this.event, { + this.timeline, + this.textColor, + this.linkColor, + super.key, + }); static const String fallbackBlurHash = 'L5H2EC=PM+yV0g-mq.wG9c010J}I'; @override Widget build(BuildContext context) { - final hasThumbnail = widget.event.hasThumbnail; - final blurHash = (widget.event.infoMap as Map) - .tryGet('xyz.amorgan.blurhash') ?? - fallbackBlurHash; + final supportsVideoPlayer = PlatformInfos.supportsVideoPlayer; - final chewieManager = _chewieManager; - return Material( - color: Colors.black, - borderRadius: BorderRadius.circular(AppConfig.borderRadius), - child: SizedBox( - height: 300, - child: chewieManager != null - ? Center(child: Chewie(controller: chewieManager)) - : Stack( - children: [ - if (hasThumbnail) - Center( - child: ImageBubble( - widget.event, - tapToView: false, - ), - ) - else - BlurHash(blurhash: blurHash, width: 300, height: 300), - Center( - child: IconButton( - style: IconButton.styleFrom( - backgroundColor: Theme.of(context).colorScheme.surface, - ), - icon: _isDownloading - ? const SizedBox( - width: 24, - height: 24, - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, - ), - ) - : const Icon(Icons.play_circle_outlined), - tooltip: _isDownloading - ? L10n.of(context)!.loadingPleaseWait - : L10n.of(context)!.videoWithSize( - widget.event.sizeString ?? '?MB', - ), - onPressed: _isDownloading ? null : _downloadAction, + final blurHash = + (event.infoMap as Map).tryGet( + 'xyz.amorgan.blurhash', + ) ?? + fallbackBlurHash; + final fileDescription = event.fileDescription; + const maxDimension = 300.0; + final infoMap = event.content.tryGetMap('info'); + final videoWidth = infoMap?.tryGet('w') ?? maxDimension; + final videoHeight = infoMap?.tryGet('h') ?? maxDimension; + + final modifier = max(videoWidth, videoHeight) / maxDimension; + final width = videoWidth / modifier; + final height = videoHeight / modifier; + + final durationInt = infoMap?.tryGet('duration'); + final duration = durationInt == null + ? null + : Duration(milliseconds: durationInt); + + return Column( + mainAxisSize: .min, + spacing: 8, + children: [ + Material( + color: Colors.black, + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + child: InkWell( + onTap: () => supportsVideoPlayer + ? showDialog( + context: context, + builder: (_) => ImageViewer( + event, + timeline: timeline, + outerContext: context, ), - ), - ], + ) + : event.saveFile(context), + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + child: SizedBox( + width: width, + height: height, + child: Hero( + tag: event.eventId, + child: Stack( + children: [ + if (event.hasThumbnail) + MxcImage( + event: event, + isThumbnail: true, + width: width, + height: height, + fit: BoxFit.cover, + placeholder: (context) => BlurHash( + blurhash: blurHash, + width: width, + height: height, + fit: BoxFit.cover, + ), + ) + else + BlurHash( + blurhash: blurHash, + width: width, + height: height, + fit: BoxFit.cover, + ), + Center( + child: CircleAvatar( + child: supportsVideoPlayer + ? const Icon(Icons.play_arrow_outlined) + : const Icon(Icons.file_download_outlined), + ), + ), + if (duration != null) + Positioned( + bottom: 8, + left: 16, + child: Text( + '${duration.inMinutes.toString().padLeft(2, '0')}:${(duration.inSeconds % 60).toString().padLeft(2, '0')}', + style: TextStyle( + color: Colors.white, + backgroundColor: Colors.black.withAlpha(32), + ), + ), + ), + ], + ), ), - ), + ), + ), + ), + if (fileDescription != null && textColor != null && linkColor != null) + SizedBox( + width: width, + child: Padding( + padding: const EdgeInsets.symmetric(horizontal: 16, vertical: 8), + child: Linkify( + text: fileDescription, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + style: TextStyle( + color: textColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + ), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: linkColor, + fontSize: + AppSettings.fontSizeFactor.value * + AppConfig.messageFontSize, + decoration: TextDecoration.underline, + decorationColor: linkColor, + ), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), + ), + ), + ), + ], ); } } diff --git a/lib/pages/chat/input_bar.dart b/lib/pages/chat/input_bar.dart index 5cd801e04..bc1261ff3 100644 --- a/lib/pages/chat/input_bar.dart +++ b/lib/pages/chat/input_bar.dart @@ -1,15 +1,14 @@ import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:emojis/emoji.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_typeahead/flutter_typeahead.dart'; +import 'package:emoji_picker_flutter/emoji_picker_flutter.dart'; import 'package:matrix/matrix.dart'; -import 'package:pasteboard/pasteboard.dart'; import 'package:slugify/slugify.dart'; import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/markdown_context_builder.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; import '../../widgets/avatar.dart'; import '../../widgets/matrix.dart'; @@ -25,10 +24,11 @@ class InputBar extends StatelessWidget { final ValueChanged? onSubmitImage; final FocusNode? focusNode; final TextEditingController? controller; - final InputDecoration? decoration; + final InputDecoration decoration; final ValueChanged? onChanged; final bool? autofocus; final bool readOnly; + final List suggestionEmojis; const InputBar({ required this.room, @@ -39,23 +39,22 @@ class InputBar extends StatelessWidget { this.onSubmitImage, this.focusNode, this.controller, - this.decoration, + required this.decoration, this.onChanged, this.autofocus, this.textInputAction, this.readOnly = false, + required this.suggestionEmojis, super.key, }); - List> getSuggestions(String text) { - if (controller!.selection.baseOffset != - controller!.selection.extentOffset || - controller!.selection.baseOffset < 0) { + List> getSuggestions(TextEditingValue text) { + if (text.selection.baseOffset != text.selection.extentOffset || + text.selection.baseOffset < 0) { return []; // no entries if there is selected text } - final searchText = - controller!.text.substring(0, controller!.selection.baseOffset); - final List> ret = >[]; + final searchText = text.text.substring(0, text.selection.baseOffset); + final ret = >[]; const maxResults = 30; final commandMatch = RegExp(r'^/(\w*)$').firstMatch(searchText); @@ -63,17 +62,16 @@ class InputBar extends StatelessWidget { final commandSearch = commandMatch[1]!.toLowerCase(); for (final command in room.client.commands.keys) { if (command.contains(commandSearch)) { - ret.add({ - 'type': 'command', - 'name': command, - }); + ret.add({'type': 'command', 'name': command}); } if (ret.length > maxResults) return ret; } } - final emojiMatch = - RegExp(r'(?:\s|^):(?:([-\w]+)~)?([-\w]+)$').firstMatch(searchText); + final emojiMatch = RegExp( + r'(?:\s|^):(?:([\p{L}\p{N}_-]+)~)?([\p{L}\p{N}_-]+)$', + unicode: true, + ).firstMatch(searchText); if (emojiMatch != null) { final packSearch = emojiMatch[1]; final emoteSearch = emojiMatch[2]!.toLowerCase(); @@ -106,8 +104,8 @@ class InputBar extends StatelessWidget { 'type': 'emote', 'name': emote.key, 'pack': packSearch, - 'pack_avatar_url': - emotePacks[packSearch]!.pack.avatarUrl?.toString(), + 'pack_avatar_url': emotePacks[packSearch]!.pack.avatarUrl + ?.toString(), 'pack_display_name': emotePacks[packSearch]!.pack.displayName ?? packSearch, 'mxc': emote.value.url.toString(), @@ -118,13 +116,12 @@ class InputBar extends StatelessWidget { } } } + // aside of emote packs, also propose normal (tm) unicode emojis - final matchingUnicodeEmojis = Emoji.all() - .where( - (element) => [element.name, ...element.keywords] - .any((element) => element.toLowerCase().contains(emoteSearch)), - ) + final matchingUnicodeEmojis = suggestionEmojis + .where((emoji) => emoji.name.toLowerCase().contains(emoteSearch)) .toList(); + // sort by the index of the search term in the name in order to have // best matches first // (thanks for the hint by github.com/nextcloud/circles devs) @@ -144,9 +141,8 @@ class InputBar extends StatelessWidget { for (final emoji in matchingUnicodeEmojis) { ret.add({ 'type': 'emoji', - 'emoji': emoji.char, - // don't include sub-group names, splitting at `:` hence - 'label': '${emoji.char} - ${emoji.name.split(':').first}', + 'emoji': emoji.emoji, + 'label': emoji.name, 'current_word': ':$emoteSearch', }); if (ret.length > maxResults) { @@ -160,9 +156,10 @@ class InputBar extends StatelessWidget { for (final user in room.getParticipants()) { if ((user.displayName != null && (user.displayName!.toLowerCase().contains(userSearch) || - slugify(user.displayName!.toLowerCase()) - .contains(userSearch))) || - user.id.split(':')[0].toLowerCase().contains(userSearch)) { + slugify( + user.displayName!.toLowerCase(), + ).contains(userSearch))) || + user.id.localpart!.toLowerCase().contains(userSearch)) { ret.add({ 'type': 'user', 'mxid': user.id, @@ -188,17 +185,14 @@ class InputBar extends StatelessWidget { ((state.content['alias'] is String && state.content .tryGet('alias')! - .split(':')[0] + .localpart! .toLowerCase() .contains(roomSearch)) || (state.content['alt_aliases'] is List && (state.content['alt_aliases'] as List).any( (l) => l is String && - l - .split(':')[0] - .toLowerCase() - .contains(roomSearch), + l.localpart!.toLowerCase().contains(roomSearch), )))) || (r.name.toLowerCase().contains(roomSearch))) { ret.add({ @@ -219,32 +213,28 @@ class InputBar extends StatelessWidget { Widget buildSuggestion( BuildContext context, Map suggestion, + void Function(Map) onSelected, Client? client, ) { + final theme = Theme.of(context); const size = 30.0; - const padding = EdgeInsets.all(4.0); if (suggestion['type'] == 'command') { final command = suggestion['name']!; - final hint = commandHint(L10n.of(context)!, command); + final hint = commandHint(L10n.of(context), command); return Tooltip( message: hint, waitDuration: const Duration(days: 1), // don't show on hover - child: Container( - padding: padding, - child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text( - commandExample(command), - style: const TextStyle(fontFamily: 'monospace'), - ), - Text( - hint, - maxLines: 1, - overflow: TextOverflow.ellipsis, - style: Theme.of(context).textTheme.bodySmall, - ), - ], + child: ListTile( + onTap: () => onSelected(suggestion), + title: Text( + commandExample(command), + style: const TextStyle(fontFamily: 'RobotoMono'), + ), + subtitle: Text( + hint, + maxLines: 1, + overflow: TextOverflow.ellipsis, + style: theme.textTheme.bodySmall, ), ), ); @@ -254,28 +244,35 @@ class InputBar extends StatelessWidget { return Tooltip( message: label, waitDuration: const Duration(days: 1), // don't show on hover - child: Container( - padding: padding, - child: Text(label, style: const TextStyle(fontFamily: 'monospace')), + child: ListTile( + onTap: () => onSelected(suggestion), + leading: SizedBox.square( + dimension: size, + child: Text( + suggestion['emoji']!, + style: const TextStyle(fontSize: 16), + ), + ), + title: Text(label, maxLines: 1, overflow: TextOverflow.ellipsis), ), ); } if (suggestion['type'] == 'emote') { - return Container( - padding: padding, - child: Row( - crossAxisAlignment: CrossAxisAlignment.center, + return ListTile( + onTap: () => onSelected(suggestion), + leading: MxcImage( + // ensure proper ordering ... + key: ValueKey(suggestion['name']), + uri: suggestion['mxc'] is String + ? Uri.parse(suggestion['mxc'] ?? '') + : null, + width: size, + height: size, + isThumbnail: false, + ), + title: Row( + crossAxisAlignment: .center, children: [ - MxcImage( - // ensure proper ordering ... - key: ValueKey(suggestion['name']), - uri: suggestion['mxc'] is String - ? Uri.parse(suggestion['mxc'] ?? '') - : null, - width: size, - height: size, - ), - const SizedBox(width: 6), Text(suggestion['name']!), Expanded( child: Align( @@ -301,30 +298,27 @@ class InputBar extends StatelessWidget { } if (suggestion['type'] == 'user' || suggestion['type'] == 'room') { final url = Uri.parse(suggestion['avatar_url'] ?? ''); - return Container( - padding: padding, - child: Row( - crossAxisAlignment: CrossAxisAlignment.center, - children: [ - Avatar( - mxContent: url, - name: suggestion.tryGet('displayname') ?? - suggestion.tryGet('mxid'), - size: size, - client: client, - ), - const SizedBox(width: 6), - Text(suggestion['displayname'] ?? suggestion['mxid']!), - ], + return ListTile( + onTap: () => onSelected(suggestion), + leading: Avatar( + mxContent: url, + name: + suggestion.tryGet('displayname') ?? + suggestion.tryGet('mxid'), + size: size, + client: client, ), + title: Text(suggestion['displayname'] ?? suggestion['mxid']!), ); } return const SizedBox.shrink(); } - void insertSuggestion(_, Map suggestion) { - final replaceText = - controller!.text.substring(0, controller!.selection.baseOffset); + String insertSuggestion(Map suggestion) { + final replaceText = controller!.text.substring( + 0, + controller!.selection.baseOffset, + ); var startText = ''; final afterText = replaceText == controller!.text ? '' @@ -383,134 +377,81 @@ class InputBar extends StatelessWidget { (Match m) => '${m[1]}$insertText', ); } - if (insertText.isNotEmpty && startText.isNotEmpty) { - controller!.text = startText + afterText; - controller!.selection = TextSelection( - baseOffset: startText.length, - extentOffset: startText.length, - ); - } + + return startText + afterText; } @override Widget build(BuildContext context) { - final useShortCuts = (AppConfig.sendOnEnter ?? !PlatformInfos.isMobile); - return Shortcuts( - shortcuts: !useShortCuts - ? {} - : { - LogicalKeySet(LogicalKeyboardKey.shift, LogicalKeyboardKey.enter): - NewLineIntent(), - LogicalKeySet(LogicalKeyboardKey.enter): SubmitLineIntent(), - LogicalKeySet( - LogicalKeyboardKey.controlLeft, - LogicalKeyboardKey.keyM, - ): PasteLineIntent(), - }, - child: Actions( - actions: !useShortCuts - ? {} - : { - NewLineIntent: CallbackAction( - onInvoke: (i) { - final val = controller!.value; - final selection = val.selection.start; - final messageWithoutNewLine = - '${controller!.text.substring(0, val.selection.start)}\n${controller!.text.substring(val.selection.end)}'; - controller!.value = TextEditingValue( - text: messageWithoutNewLine, - selection: TextSelection.fromPosition( - TextPosition(offset: selection + 1), - ), - ); - return null; - }, - ), - SubmitLineIntent: CallbackAction( - onInvoke: (i) { - onSubmitted!(controller!.text); - return null; - }, - ), - PasteLineIntent: CallbackAction( - onInvoke: (i) async { - final image = await Pasteboard.image; - if (image != null) { - onSubmitImage!(image); - return null; - } - return null; - }, - ), - }, - child: TypeAheadField>( - direction: VerticalDirection.up, - hideOnEmpty: true, - hideOnLoading: true, + final theme = Theme.of(context); + return Autocomplete>( + focusNode: focusNode, + textEditingController: controller, + optionsBuilder: getSuggestions, + fieldViewBuilder: (context, controller, focusNode, _) => TextField( + controller: controller, + focusNode: focusNode, + readOnly: readOnly, + contextMenuBuilder: (c, e) => MarkdownContextBuilder( + editableTextState: e, controller: controller, - focusNode: focusNode, - hideOnSelect: false, - debounceDuration: const Duration(milliseconds: 50), - // show suggestions after 50ms idle time (default is 300) - builder: (context, controller, focusNode) => TextField( - controller: controller, - focusNode: focusNode, - contentInsertionConfiguration: ContentInsertionConfiguration( - onContentInserted: (KeyboardInsertedContent content) { - final data = content.data; - if (data == null) return; - - final file = MatrixFile( - mimeType: content.mimeType, - bytes: data, - name: content.uri.split('/').last, - ); - room.sendFileEvent( - file, - shrinkImageMaxDimension: 1600, - ); - }, - ), - minLines: minLines, - maxLines: maxLines, - keyboardType: keyboardType!, - textInputAction: textInputAction, - autofocus: autofocus!, - inputFormatters: [ - LengthLimitingTextInputFormatter((maxPDUSize / 3).floor()), - ], - onSubmitted: (text) { - // fix for library for now - // it sets the types for the callback incorrectly - onSubmitted!(text); - }, - decoration: decoration!, - onChanged: (text) { - // fix for the library for now - // it sets the types for the callback incorrectly - onChanged!(text); - }, - textCapitalization: TextCapitalization.sentences, - ), - suggestionsCallback: getSuggestions, - itemBuilder: (c, s) => - buildSuggestion(c, s, Matrix.of(context).client), - onSelected: (Map suggestion) => - insertSuggestion(context, suggestion), - errorBuilder: (BuildContext context, Object? error) => - const SizedBox.shrink(), - loadingBuilder: (BuildContext context) => const SizedBox.shrink(), - // fix loading briefly flickering a dark box - emptyBuilder: (BuildContext context) => const SizedBox - .shrink(), // fix loading briefly showing no suggestions ), + contentInsertionConfiguration: ContentInsertionConfiguration( + onContentInserted: (KeyboardInsertedContent content) { + final data = content.data; + if (data == null) return; + + final file = MatrixFile( + mimeType: content.mimeType, + bytes: data, + name: content.uri.split('/').last, + ); + room.sendFileEvent(file, shrinkImageMaxDimension: 1600); + }, + ), + minLines: minLines, + maxLines: maxLines, + keyboardType: keyboardType, + textInputAction: textInputAction, + autofocus: autofocus!, + inputFormatters: [ + LengthLimitingTextInputFormatter((maxPDUSize / 3).floor()), + ], + onSubmitted: (text) { + // fix for library for now + // it sets the types for the callback incorrectly + onSubmitted!(text); + }, + maxLength: AppSettings.textMessageMaxLength.value, + decoration: decoration, + onChanged: (text) { + // fix for the library for now + // it sets the types for the callback incorrectly + onChanged!(text); + }, + textCapitalization: TextCapitalization.sentences, ), + optionsViewBuilder: (c, onSelected, s) { + final suggestions = s.toList(); + return Material( + elevation: theme.appBarTheme.scrolledUnderElevation ?? 4, + shadowColor: theme.appBarTheme.shadowColor, + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + clipBehavior: Clip.hardEdge, + child: ListView.builder( + shrinkWrap: true, + itemCount: suggestions.length, + itemBuilder: (context, i) => buildSuggestion( + c, + suggestions[i], + onSelected, + Matrix.of(context).client, + ), + ), + ); + }, + displayStringForOption: insertSuggestion, + optionsViewOpenDirection: OptionsViewOpenDirection.up, ); } } - -class NewLineIntent extends Intent {} - -class SubmitLineIntent extends Intent {} - -class PasteLineIntent extends Intent {} diff --git a/lib/pages/chat/pinned_events.dart b/lib/pages/chat/pinned_events.dart index 0940a786f..da600a223 100644 --- a/lib/pages/chat/pinned_events.dart +++ b/lib/pages/chat/pinned_events.dart @@ -2,14 +2,14 @@ import 'dart:async'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat/chat.dart'; import 'package:fluffychat/pages/chat/chat_app_bar_list_tile.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; class PinnedEvents extends StatelessWidget { final ChatController controller; @@ -30,15 +30,18 @@ class PinnedEvents extends StatelessWidget { final eventId = events.length == 1 ? events.single?.eventId - : await showConfirmationDialog( + : await showModalActionPopup( context: context, - title: L10n.of(context)!.pinMessage, + title: L10n.of(context).pin, + cancelLabel: L10n.of(context).cancel, actions: events .map( - (event) => AlertDialogAction( - key: event?.eventId ?? '', - label: event?.calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), + (event) => AdaptiveModalAction( + value: event?.eventId ?? '', + icon: const Icon(Icons.push_pin_outlined), + label: + event?.calcLocalizedBodyFallback( + MatrixLocals(L10n.of(context)), withSenderNamePrefix: true, hideReply: true, ) ?? @@ -53,9 +56,11 @@ class PinnedEvents extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final pinnedEventIds = controller.room.pinnedEventIds; - if (pinnedEventIds.isEmpty) { + if (pinnedEventIds.isEmpty || controller.activeThreadId != null) { return const SizedBox.shrink(); } @@ -64,18 +69,19 @@ class PinnedEvents extends StatelessWidget { builder: (context, snapshot) { final event = snapshot.data; return ChatAppBarListTile( - title: event?.calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), + title: + event?.calcLocalizedBodyFallback( + MatrixLocals(L10n.of(context)), withSenderNamePrefix: true, hideReply: true, ) ?? - L10n.of(context)!.loadingPleaseWait, + L10n.of(context).loadingPleaseWait, leading: IconButton( - splashRadius: 20, - iconSize: 20, - color: Theme.of(context).colorScheme.onSurfaceVariant, + splashRadius: 18, + iconSize: 18, + color: theme.colorScheme.onSurfaceVariant, icon: const Icon(Icons.push_pin), - tooltip: L10n.of(context)!.unpin, + tooltip: L10n.of(context).unpin, onPressed: controller.room.canSendEvent(EventTypes.RoomPinnedEvents) ? () => controller.unpinEvent(event!.eventId) : null, diff --git a/lib/pages/chat/reactions_picker.dart b/lib/pages/chat/reactions_picker.dart deleted file mode 100644 index 7256e00bc..000000000 --- a/lib/pages/chat/reactions_picker.dart +++ /dev/null @@ -1,110 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:emoji_proposal/emoji_proposal.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/config/app_emojis.dart'; -import 'package:fluffychat/pages/chat/chat.dart'; -import '../../config/themes.dart'; - -class ReactionsPicker extends StatelessWidget { - final ChatController controller; - - const ReactionsPicker(this.controller, {super.key}); - - @override - Widget build(BuildContext context) { - if (controller.showEmojiPicker) return const SizedBox.shrink(); - final display = controller.editEvent == null && - controller.replyEvent == null && - controller.room.canSendDefaultMessages && - controller.selectedEvents.isNotEmpty; - return AnimatedContainer( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - height: (display) ? 56 : 0, - child: Material( - color: Colors.transparent, - child: Builder( - builder: (context) { - if (!display) { - return const SizedBox.shrink(); - } - final proposals = proposeEmojis( - controller.selectedEvents.first.plaintextBody, - number: 25, - languageCodes: EmojiProposalLanguageCodes.values.toSet(), - ); - final emojis = proposals.isNotEmpty - ? proposals.map((e) => e.char).toList() - : List.from(AppEmojis.emojis); - final allReactionEvents = controller.selectedEvents.first - .aggregatedEvents( - controller.timeline!, - RelationshipTypes.reaction, - ) - .where( - (event) => - event.senderId == event.room.client.userID && - event.type == 'm.reaction', - ); - - for (final event in allReactionEvents) { - try { - emojis.remove(event.content.tryGetMap('m.relates_to')!['key']); - } catch (_) {} - } - return Row( - children: [ - Expanded( - child: Container( - decoration: BoxDecoration( - color: Theme.of(context).colorScheme.onInverseSurface, - borderRadius: const BorderRadius.only( - bottomRight: Radius.circular(AppConfig.borderRadius), - ), - ), - padding: const EdgeInsets.only(right: 1), - child: ListView.builder( - scrollDirection: Axis.horizontal, - itemCount: emojis.length, - itemBuilder: (c, i) => InkWell( - borderRadius: BorderRadius.circular(8), - onTap: () => controller.sendEmojiAction(emojis[i]), - child: Container( - width: 56, - height: 56, - alignment: Alignment.center, - child: Text( - emojis[i], - style: const TextStyle(fontSize: 30), - ), - ), - ), - ), - ), - ), - InkWell( - borderRadius: BorderRadius.circular(8), - child: Container( - margin: const EdgeInsets.symmetric(horizontal: 8), - width: 36, - height: 56, - decoration: BoxDecoration( - color: Theme.of(context).colorScheme.onInverseSurface, - shape: BoxShape.circle, - ), - child: const Icon(Icons.add_outlined), - ), - onTap: () => - controller.pickEmojiReactionAction(allReactionEvents), - ), - ], - ); - }, - ), - ), - ); - } -} diff --git a/lib/pages/chat/recording_dialog.dart b/lib/pages/chat/recording_dialog.dart deleted file mode 100644 index bc92f3ff5..000000000 --- a/lib/pages/chat/recording_dialog.dart +++ /dev/null @@ -1,239 +0,0 @@ -import 'dart:async'; - -import 'package:flutter/cupertino.dart'; -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:path_provider/path_provider.dart'; -import 'package:record/record.dart'; -import 'package:wakelock_plus/wakelock_plus.dart'; - -import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/utils/platform_infos.dart'; -import 'events/audio_player.dart'; - -class RecordingDialog extends StatefulWidget { - static const String recordingFileType = 'm4a'; - const RecordingDialog({ - super.key, - }); - - @override - RecordingDialogState createState() => RecordingDialogState(); -} - -class RecordingDialogState extends State { - Timer? _recorderSubscription; - Duration _duration = Duration.zero; - - bool error = false; - String? _recordedPath; - final _audioRecorder = AudioRecorder(); - final List amplitudeTimeline = []; - - static const int bitRate = 64000; - static const int samplingRate = 44100; - - Future startRecording() async { - try { - final tempDir = await getTemporaryDirectory(); - final path = _recordedPath = - '${tempDir.path}/recording${DateTime.now().microsecondsSinceEpoch}.${RecordingDialog.recordingFileType}'; - - final result = await _audioRecorder.hasPermission(); - if (result != true) { - setState(() => error = true); - return; - } - await WakelockPlus.enable(); - await _audioRecorder.start( - const RecordConfig( - bitRate: bitRate, - sampleRate: samplingRate, - numChannels: 1, - autoGain: true, - echoCancel: true, - noiseSuppress: true, - ), - path: path, - ); - setState(() => _duration = Duration.zero); - _recorderSubscription?.cancel(); - _recorderSubscription = - Timer.periodic(const Duration(milliseconds: 100), (_) async { - final amplitude = await _audioRecorder.getAmplitude(); - var value = 100 + amplitude.current * 2; - value = value < 1 ? 1 : value; - amplitudeTimeline.add(value); - setState(() { - _duration += const Duration(milliseconds: 100); - }); - }); - } catch (_) { - setState(() => error = true); - rethrow; - } - } - - @override - void initState() { - super.initState(); - startRecording(); - } - - @override - void dispose() { - WakelockPlus.disable(); - _recorderSubscription?.cancel(); - _audioRecorder.stop(); - super.dispose(); - } - - void _stopAndSend() async { - _recorderSubscription?.cancel(); - await _audioRecorder.stop(); - final path = _recordedPath; - if (path == null) throw ('Recording failed!'); - const waveCount = AudioPlayerWidget.wavesCount; - final step = amplitudeTimeline.length < waveCount - ? 1 - : (amplitudeTimeline.length / waveCount).round(); - final waveform = []; - for (var i = 0; i < amplitudeTimeline.length; i += step) { - waveform.add((amplitudeTimeline[i] / 100 * 1024).round()); - } - Navigator.of(context, rootNavigator: false).pop( - RecordingResult( - path: path, - duration: _duration.inMilliseconds, - waveform: waveform, - ), - ); - } - - @override - Widget build(BuildContext context) { - const maxDecibalWidth = 64.0; - final time = - '${_duration.inMinutes.toString().padLeft(2, '0')}:${(_duration.inSeconds % 60).toString().padLeft(2, '0')}'; - final content = error - ? Text(L10n.of(context)!.oopsSomethingWentWrong) - : Row( - children: [ - Container( - width: 16, - height: 16, - decoration: BoxDecoration( - borderRadius: BorderRadius.circular(32), - color: Colors.red, - ), - ), - Expanded( - child: Row( - mainAxisSize: MainAxisSize.min, - mainAxisAlignment: MainAxisAlignment.end, - children: amplitudeTimeline.reversed - .take(26) - .toList() - .reversed - .map( - (amplitude) => Container( - margin: const EdgeInsets.only(left: 2), - width: 4, - decoration: BoxDecoration( - color: Theme.of(context).colorScheme.primary, - borderRadius: - BorderRadius.circular(AppConfig.borderRadius), - ), - height: maxDecibalWidth * (amplitude / 100), - ), - ) - .toList(), - ), - ), - const SizedBox(width: 8), - SizedBox( - width: 48, - child: Text(time), - ), - ], - ); - if (PlatformInfos.isCupertinoStyle) { - return CupertinoAlertDialog( - content: content, - actions: [ - CupertinoDialogAction( - onPressed: () => Navigator.of(context, rootNavigator: false).pop(), - child: Text( - L10n.of(context)!.cancel.toUpperCase(), - style: TextStyle( - color: Theme.of(context) - .textTheme - .bodyMedium - ?.color - ?.withAlpha(150), - ), - ), - ), - if (error != true) - CupertinoDialogAction( - onPressed: _stopAndSend, - child: Text(L10n.of(context)!.send.toUpperCase()), - ), - ], - ); - } - return AlertDialog( - content: content, - actions: [ - TextButton( - onPressed: () => Navigator.of(context, rootNavigator: false).pop(), - child: Text( - L10n.of(context)!.cancel.toUpperCase(), - style: TextStyle( - color: - Theme.of(context).textTheme.bodyMedium?.color?.withAlpha(150), - ), - ), - ), - if (error != true) - TextButton( - onPressed: _stopAndSend, - child: Row( - mainAxisSize: MainAxisSize.min, - children: [ - Text(L10n.of(context)!.send.toUpperCase()), - const SizedBox(width: 4), - const Icon(Icons.send_outlined, size: 15), - ], - ), - ), - ], - ); - } -} - -class RecordingResult { - final String path; - final int duration; - final List waveform; - - const RecordingResult({ - required this.path, - required this.duration, - required this.waveform, - }); - - factory RecordingResult.fromJson(Map json) => - RecordingResult( - path: json['path'], - duration: json['duration'], - waveform: List.from(json['waveform']), - ); - - Map toJson() => { - 'path': path, - 'duration': duration, - 'waveform': waveform, - }; -} diff --git a/lib/pages/chat/recording_input_row.dart b/lib/pages/chat/recording_input_row.dart new file mode 100644 index 000000000..b5b66706f --- /dev/null +++ b/lib/pages/chat/recording_input_row.dart @@ -0,0 +1,108 @@ +import 'package:flutter/material.dart'; + +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat/chat_input_row.dart'; +import 'package:fluffychat/pages/chat/recording_view_model.dart'; + +class RecordingInputRow extends StatelessWidget { + final RecordingViewModelState state; + final Future Function(String, int, List, String?) onSend; + const RecordingInputRow({ + required this.state, + required this.onSend, + super.key, + }); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + const maxDecibalWidth = 36.0; + final time = + '${state.duration.inMinutes.toString().padLeft(2, '0')}:${(state.duration.inSeconds % 60).toString().padLeft(2, '0')}'; + return SizedBox( + height: ChatInputRow.height, + child: Row( + crossAxisAlignment: .center, + mainAxisAlignment: .spaceBetween, + children: [ + const SizedBox(width: 8), + Container( + alignment: .center, + width: 48, + child: IconButton( + tooltip: L10n.of(context).cancel, + icon: const Icon(Icons.delete_outlined), + color: theme.colorScheme.error, + onPressed: state.cancel, + ), + ), + if (state.isPaused) + Container( + alignment: .center, + width: 48, + child: IconButton( + tooltip: L10n.of(context).resume, + icon: const Icon(Icons.play_circle_outline_outlined), + onPressed: state.resume, + ), + ) + else + Container( + alignment: .center, + width: 48, + child: IconButton( + tooltip: L10n.of(context).pause, + icon: const Icon(Icons.pause_circle_outline_outlined), + onPressed: state.pause, + ), + ), + Text(time), + Expanded( + child: LayoutBuilder( + builder: (context, constraints) { + const width = 4; + return Row( + mainAxisSize: .min, + mainAxisAlignment: .end, + children: state.amplitudeTimeline.reversed + .take((constraints.maxWidth / (width + 2)).floor()) + .toList() + .reversed + .map( + (amplitude) => Container( + margin: const EdgeInsets.only(left: 2), + width: width.toDouble(), + decoration: BoxDecoration( + color: theme.colorScheme.primary, + borderRadius: BorderRadius.circular(2), + ), + height: maxDecibalWidth * (amplitude / 100), + ), + ) + .toList(), + ); + }, + ), + ), + IconButton( + style: IconButton.styleFrom( + disabledBackgroundColor: theme.bubbleColor.withAlpha(128), + backgroundColor: theme.bubbleColor, + foregroundColor: theme.onBubbleColor, + ), + tooltip: L10n.of(context).sendAudio, + icon: state.isSending + ? const SizedBox.square( + dimension: 24, + child: CircularProgressIndicator.adaptive(), + ) + : const Icon(Icons.send_outlined), + onPressed: state.isSending ? null : () => state.stopAndSend(onSend), + ), + const SizedBox(width: 4), + ], + ), + ); + } +} diff --git a/lib/pages/chat/recording_view_model.dart b/lib/pages/chat/recording_view_model.dart new file mode 100644 index 000000000..2f401c1cb --- /dev/null +++ b/lib/pages/chat/recording_view_model.dart @@ -0,0 +1,227 @@ +import 'dart:async'; + +import 'package:flutter/cupertino.dart'; +import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; + +import 'package:device_info_plus/device_info_plus.dart'; +import 'package:matrix/matrix.dart'; +import 'package:path/path.dart' as path_lib; +import 'package:path_provider/path_provider.dart'; +import 'package:record/record.dart'; +import 'package:wakelock_plus/wakelock_plus.dart'; + +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'events/audio_player.dart'; + +class RecordingViewModel extends StatefulWidget { + final Widget Function(BuildContext, RecordingViewModelState) builder; + + const RecordingViewModel({required this.builder, super.key}); + + @override + RecordingViewModelState createState() => RecordingViewModelState(); +} + +class RecordingViewModelState extends State { + Timer? _recorderSubscription; + Duration duration = Duration.zero; + + bool isSending = false; + + bool get isRecording => _audioRecorder != null; + + AudioRecorder? _audioRecorder; + final List amplitudeTimeline = []; + + String? fileName; + + bool isPaused = false; + + Future startRecording(Room room) async { + room.client.getConfig(); // Preload server file configuration. + if (PlatformInfos.isAndroid) { + final info = await DeviceInfoPlugin().androidInfo; + if (info.version.sdkInt < 19) { + showOkAlertDialog( + context: context, + title: L10n.of(context).unsupportedAndroidVersion, + message: L10n.of(context).unsupportedAndroidVersionLong, + okLabel: L10n.of(context).close, + ); + return; + } + } + if (await AudioRecorder().hasPermission() == false) return; + + final audioRecorder = _audioRecorder ??= AudioRecorder(); + setState(() {}); + + try { + final codec = + !PlatformInfos + .isIOS && // Blocked by https://github.com/llfbandit/record/issues/560 + await audioRecorder.isEncoderSupported(AudioEncoder.opus) + ? AudioEncoder.opus + : AudioEncoder.aacLc; + fileName = + 'recording${DateTime.now().microsecondsSinceEpoch}.${codec.fileExtension}'; + String? path; + if (!kIsWeb) { + final tempDir = await getTemporaryDirectory(); + path = path_lib.join(tempDir.path, fileName); + } + + final result = await audioRecorder.hasPermission(); + if (result != true) { + showOkAlertDialog( + context: context, + title: L10n.of(context).oopsSomethingWentWrong, + message: L10n.of(context).noPermission, + ); + return; + } + await WakelockPlus.enable(); + + await audioRecorder.start( + RecordConfig( + bitRate: AppSettings.audioRecordingBitRate.value, + sampleRate: AppSettings.audioRecordingSamplingRate.value, + numChannels: AppSettings.audioRecordingNumChannels.value, + autoGain: AppSettings.audioRecordingAutoGain.value, + echoCancel: AppSettings.audioRecordingEchoCancel.value, + noiseSuppress: AppSettings.audioRecordingNoiseSuppress.value, + encoder: codec, + ), + path: path ?? '', + ); + setState(() => duration = Duration.zero); + _subscribe(); + } catch (e, s) { + Logs().w('Unable to start voice message recording', e, s); + showOkAlertDialog( + context: context, + title: L10n.of(context).oopsSomethingWentWrong, + message: e.toString(), + ); + setState(_reset); + } + } + + @override + void dispose() { + _reset(); + super.dispose(); + } + + void _subscribe() { + _recorderSubscription?.cancel(); + _recorderSubscription = Timer.periodic(const Duration(milliseconds: 100), ( + _, + ) async { + final amplitude = await _audioRecorder!.getAmplitude(); + var value = 100 + amplitude.current * 2; + value = value < 1 ? 1 : value; + amplitudeTimeline.add(value); + setState(() { + duration += const Duration(milliseconds: 100); + }); + }); + } + + void _reset() { + WakelockPlus.disable(); + _recorderSubscription?.cancel(); + _audioRecorder?.stop(); + _audioRecorder = null; + isSending = false; + fileName = null; + duration = Duration.zero; + amplitudeTimeline.clear(); + isPaused = false; + } + + void cancel() { + setState(_reset); + } + + void pause() { + _audioRecorder?.pause(); + _recorderSubscription?.cancel(); + setState(() { + isPaused = true; + }); + } + + void resume() { + _audioRecorder?.resume(); + _subscribe(); + setState(() { + isPaused = false; + }); + } + + Future stopAndSend( + Future Function( + String path, + int duration, + List waveform, + String? fileName, + ) + onSend, + ) async { + _recorderSubscription?.cancel(); + final path = await _audioRecorder?.stop(); + + if (path == null) throw ('Recording failed!'); + const waveCount = AudioPlayerWidget.wavesCount; + final step = amplitudeTimeline.length < waveCount + ? 1 + : (amplitudeTimeline.length / waveCount).round(); + final waveform = []; + for (var i = 0; i < amplitudeTimeline.length; i += step) { + waveform.add((amplitudeTimeline[i] / 100 * 1024).round()); + } + + setState(() { + isSending = true; + }); + try { + await onSend(path, duration.inMilliseconds, waveform, fileName); + } catch (e, s) { + Logs().e('Unable to send voice message', e, s); + setState(() { + isSending = false; + }); + return; + } + + cancel(); + } + + @override + Widget build(BuildContext context) => widget.builder(context, this); +} + +extension on AudioEncoder { + String get fileExtension { + switch (this) { + case AudioEncoder.aacLc: + case AudioEncoder.aacEld: + case AudioEncoder.aacHe: + return 'm4a'; + case AudioEncoder.opus: + return 'ogg'; + case AudioEncoder.wav: + return 'wav'; + case AudioEncoder.amrNb: + case AudioEncoder.amrWb: + case AudioEncoder.flac: + case AudioEncoder.pcm16bits: + throw UnsupportedError('Not yet used'); + } + } +} diff --git a/lib/pages/chat/reply_display.dart b/lib/pages/chat/reply_display.dart index 03acd269e..2090cecca 100644 --- a/lib/pages/chat/reply_display.dart +++ b/lib/pages/chat/reply_display.dart @@ -1,8 +1,8 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import '../../config/themes.dart'; import 'chat.dart'; @@ -14,6 +14,8 @@ class ReplyDisplay extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return AnimatedContainer( duration: FluffyThemes.animationDuration, curve: FluffyThemes.animationCurve, @@ -21,13 +23,11 @@ class ReplyDisplay extends StatelessWidget { ? 56 : 0, clipBehavior: Clip.hardEdge, - decoration: BoxDecoration( - color: Theme.of(context).colorScheme.onInverseSurface, - ), + decoration: BoxDecoration(color: theme.colorScheme.onInverseSurface), child: Row( children: [ IconButton( - tooltip: L10n.of(context)!.close, + tooltip: L10n.of(context).close, icon: const Icon(Icons.close), onPressed: controller.cancelReplyEventAction, ), @@ -35,8 +35,7 @@ class ReplyDisplay extends StatelessWidget { child: controller.replyEvent != null ? ReplyContent( controller.replyEvent!, - timeline: controller.timeline!, - backgroundColor: Colors.transparent, + timeline: controller.timeline, ) : _EditContent( controller.editEvent?.getDisplayEvent(controller.timeline!), @@ -55,28 +54,24 @@ class _EditContent extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); final event = this.event; if (event == null) { return const SizedBox.shrink(); } return Row( children: [ - Icon( - Icons.edit, - color: Theme.of(context).colorScheme.primary, - ), + Icon(Icons.edit, color: theme.colorScheme.primary), Container(width: 15.0), Text( event.calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), withSenderNamePrefix: false, hideReply: true, ), overflow: TextOverflow.ellipsis, maxLines: 1, - style: TextStyle( - color: Theme.of(context).textTheme.bodyMedium!.color, - ), + style: TextStyle(color: theme.textTheme.bodyMedium!.color), ), ], ); diff --git a/lib/pages/chat/seen_by_row.dart b/lib/pages/chat/seen_by_row.dart index 9b1ad8953..65ecf6cde 100644 --- a/lib/pages/chat/seen_by_row.dart +++ b/lib/pages/chat/seen_by_row.dart @@ -1,67 +1,91 @@ import 'package:flutter/material.dart'; +import 'package:matrix/matrix.dart'; + import 'package:fluffychat/config/themes.dart'; -import 'package:fluffychat/pages/chat/chat.dart'; -import 'package:fluffychat/utils/room_status_extension.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/matrix.dart'; class SeenByRow extends StatelessWidget { - final ChatController controller; - const SeenByRow(this.controller, {super.key}); + final Event event; + const SeenByRow({super.key, required this.event}); @override Widget build(BuildContext context) { - final seenByUsers = controller.room.getSeenByUsers(controller.timeline!); + final theme = Theme.of(context); + const maxAvatars = 7; - return Container( - width: double.infinity, - alignment: Alignment.center, - child: AnimatedContainer( - constraints: - const BoxConstraints(maxWidth: FluffyThemes.columnWidth * 2.5), - height: seenByUsers.isEmpty ? 0 : 24, - duration: seenByUsers.isEmpty - ? Duration.zero - : FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - alignment: controller.timeline!.events.isNotEmpty && - controller.timeline!.events.first.senderId == - Matrix.of(context).client.userID - ? Alignment.topRight - : Alignment.topLeft, - padding: const EdgeInsets.only(left: 8, right: 8, bottom: 4), - child: Wrap( - spacing: 4, - children: [ - ...(seenByUsers.length > maxAvatars - ? seenByUsers.sublist(0, maxAvatars) - : seenByUsers) - .map( - (user) => Avatar( - mxContent: user.avatarUrl, - name: user.calcDisplayname(), - size: 16, - ), + return StreamBuilder( + stream: event.room.client.onSync.stream.where( + (syncUpdate) => + syncUpdate.rooms?.join?[event.room.id]?.ephemeral?.any( + (ephemeral) => ephemeral.type == 'm.receipt', + ) ?? + false, + ), + builder: (context, asyncSnapshot) { + final seenByUsers = event.receipts + .map((r) => r.user) + .where( + (user) => + user.id != event.room.client.userID && + user.id != event.senderId, + ) + .toList(); + return Container( + width: double.infinity, + alignment: Alignment.center, + child: AnimatedContainer( + constraints: const BoxConstraints( + maxWidth: FluffyThemes.maxTimelineWidth, ), - if (seenByUsers.length > maxAvatars) - SizedBox( - width: 16, - height: 16, - child: Material( - color: Theme.of(context).colorScheme.surface, - borderRadius: BorderRadius.circular(32), - child: Center( - child: Text( - '+${seenByUsers.length - maxAvatars}', - style: const TextStyle(fontSize: 9), + height: seenByUsers.isEmpty ? 0 : 24, + duration: seenByUsers.isEmpty + ? Duration.zero + : FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + alignment: event.senderId == Matrix.of(context).client.userID + ? Alignment.topRight + : Alignment.topLeft, + padding: const EdgeInsets.only( + bottom: 4, + top: 1, + left: 8, + right: 8, + ), + child: Wrap( + spacing: 4, + children: [ + ...(seenByUsers.length > maxAvatars + ? seenByUsers.sublist(0, maxAvatars) + : seenByUsers) + .map( + (user) => Avatar( + mxContent: user.avatarUrl, + name: user.calcDisplayname(), + size: 16, + ), + ), + if (seenByUsers.length > maxAvatars) + SizedBox( + width: 16, + height: 16, + child: Material( + color: theme.colorScheme.surface, + borderRadius: BorderRadius.circular(32), + child: Center( + child: Text( + '+${seenByUsers.length - maxAvatars}', + style: const TextStyle(fontSize: 9), + ), + ), ), ), - ), - ), - ], - ), - ), + ], + ), + ), + ); + }, ); } } diff --git a/lib/pages/chat/send_file_dialog.dart b/lib/pages/chat/send_file_dialog.dart index b2885a635..57f124b2c 100644 --- a/lib/pages/chat/send_file_dialog.dart +++ b/lib/pages/chat/send_file_dialog.dart @@ -1,22 +1,33 @@ import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; +import 'package:cross_file/cross_file.dart'; import 'package:matrix/matrix.dart'; +import 'package:mime/mime.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_file_extension.dart'; +import 'package:fluffychat/utils/other_party_can_receive.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; import 'package:fluffychat/utils/size_string.dart'; -import '../../utils/resize_image.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/dialog_text_field.dart'; +import '../../utils/resize_video.dart'; class SendFileDialog extends StatefulWidget { final Room room; - final List files; + final List files; + final BuildContext outerContext; + final String? threadLastEventId, threadRootEventId; const SendFileDialog({ required this.room, required this.files, + required this.outerContext, + required this.threadLastEventId, + required this.threadRootEventId, super.key, }); @@ -25,158 +36,414 @@ class SendFileDialog extends StatefulWidget { } class SendFileDialogState extends State { - bool origImage = false; + bool compress = true; /// Images smaller than 20kb don't need compression. - static const int minSizeToCompress = 20 * 1024; + static const int minSizeToCompress = 20 * 1000; + + final TextEditingController _labelTextController = TextEditingController(); Future _send() async { - for (var file in widget.files) { - MatrixImageFile? thumbnail; - if (file is MatrixVideoFile && file.bytes.length > minSizeToCompress) { - await showFutureLoadingDialog( - context: context, - future: () async { - file = origImage ? file : await file.resizeVideo(); - thumbnail = await file.getVideoThumbnail(); - }, - ); + final scaffoldMessenger = ScaffoldMessenger.of(widget.outerContext); + final l10n = L10n.of(context); + + try { + if (!widget.room.otherPartyCanReceiveMessages) { + throw OtherPartyCanNotReceiveMessages(); } - final scaffoldMessenger = ScaffoldMessenger.of(context); - widget.room - .sendFileEvent( - file, - thumbnail: thumbnail, - shrinkImageMaxDimension: origImage ? null : 1600, - ) - .catchError((e) { - scaffoldMessenger.showSnackBar( - SnackBar(content: Text((e as Object).toLocalizedString(context))), - ); - return null; - }); + scaffoldMessenger.showLoadingSnackBar(l10n.prepareSendingAttachment); + Navigator.of(context, rootNavigator: false).pop(); + final clientConfig = await widget.room.client.getConfig(); + final maxUploadSize = clientConfig.mUploadSize ?? 100 * 1000 * 1000; + + for (final xfile in widget.files) { + final MatrixFile file; + MatrixImageFile? thumbnail; + final length = await xfile.length(); + final mimeType = xfile.mimeType ?? lookupMimeType(xfile.path); + + // Generate video thumbnail + if (PlatformInfos.isMobile && + mimeType != null && + mimeType.startsWith('video')) { + scaffoldMessenger.showLoadingSnackBar(l10n.generatingVideoThumbnail); + thumbnail = await xfile.getVideoThumbnail(); + } + + // If file is a video, shrink it! + if (PlatformInfos.isMobile && + mimeType != null && + mimeType.startsWith('video')) { + scaffoldMessenger.showLoadingSnackBar(l10n.compressVideo); + file = await xfile.getVideoInfo( + compress: length > minSizeToCompress && compress, + ); + } else { + if (length > maxUploadSize) { + throw FileTooBigMatrixException(length, maxUploadSize); + } + // Else we just create a MatrixFile + file = MatrixFile( + bytes: await xfile.readAsBytes(), + name: xfile.name, + mimeType: mimeType, + ).detectFileType; + } + + if (file.bytes.length > maxUploadSize) { + throw FileTooBigMatrixException(length, maxUploadSize); + } + + if (widget.files.length > 1) { + scaffoldMessenger.showLoadingSnackBar( + l10n.sendingAttachmentCountOfCount( + widget.files.indexOf(xfile) + 1, + widget.files.length, + ), + ); + } + + final label = _labelTextController.text.trim(); + + try { + await widget.room.sendFileEvent( + file, + thumbnail: thumbnail, + shrinkImageMaxDimension: compress ? 1600 : null, + extraContent: label.isEmpty ? null : {'body': label}, + threadRootEventId: widget.threadRootEventId, + threadLastEventId: widget.threadLastEventId, + ); + } on MatrixException catch (e) { + final retryAfterMs = e.retryAfterMs; + if (e.error != MatrixError.M_LIMIT_EXCEEDED || retryAfterMs == null) { + rethrow; + } + final retryAfterDuration = Duration( + milliseconds: retryAfterMs + 1000, + ); + + scaffoldMessenger.showSnackBar( + SnackBar( + content: Text( + l10n.serverLimitReached(retryAfterDuration.inSeconds), + ), + ), + ); + await Future.delayed(retryAfterDuration); + + scaffoldMessenger.showLoadingSnackBar(l10n.sendingAttachment); + + await widget.room.sendFileEvent( + file, + thumbnail: thumbnail, + shrinkImageMaxDimension: compress ? 1600 : null, + extraContent: label.isEmpty ? null : {'body': label}, + ); + } + } + scaffoldMessenger.clearSnackBars(); + } catch (e) { + scaffoldMessenger.clearSnackBars(); + final theme = Theme.of(context); + scaffoldMessenger.showSnackBar( + SnackBar( + backgroundColor: theme.colorScheme.errorContainer, + closeIconColor: theme.colorScheme.onErrorContainer, + content: Text( + e.toLocalizedString(widget.outerContext), + style: TextStyle(color: theme.colorScheme.onErrorContainer), + ), + duration: const Duration(seconds: 30), + showCloseIcon: true, + ), + ); + rethrow; } - Navigator.of(context, rootNavigator: false).pop(); return; } + Future _calcCombinedFileSize() async { + final lengths = await Future.wait( + widget.files.map((file) => file.length()), + ); + return lengths.fold(0, (p, length) => p + length).sizeString; + } + @override Widget build(BuildContext context) { - var sendStr = L10n.of(context)!.sendFile; - final bool allFilesAreImages = - widget.files.every((file) => file is MatrixImageFile); - final sizeString = widget.files - .fold(0, (p, file) => p + file.bytes.length) - .sizeString; + final theme = Theme.of(context); + + var sendStr = L10n.of(context).sendFile; + final uniqueFileType = widget.files + .map((file) => file.mimeType ?? lookupMimeType(file.name)) + .map((mimeType) => mimeType?.split('/').first) + .toSet() + .singleOrNull; + final fileName = widget.files.length == 1 ? widget.files.single.name - : L10n.of(context)!.countFiles(widget.files.length.toString()); + : L10n.of(context).countFiles(widget.files.length); + final fileTypes = widget.files + .map((file) => file.name.split('.').last) + .toSet() + .join(', ') + .toUpperCase(); - if (allFilesAreImages) { - sendStr = L10n.of(context)!.sendImage; - } else if (widget.files.every((file) => file is MatrixAudioFile)) { - sendStr = L10n.of(context)!.sendAudio; - } else if (widget.files.every((file) => file is MatrixVideoFile)) { - sendStr = L10n.of(context)!.sendVideo; + if (uniqueFileType == 'image') { + if (widget.files.length == 1) { + sendStr = L10n.of(context).sendImage; + } else { + sendStr = L10n.of(context).sendImages(widget.files.length); + } + } else if (uniqueFileType == 'audio') { + sendStr = L10n.of(context).sendAudio; + } else if (uniqueFileType == 'video') { + sendStr = L10n.of(context).sendVideo; } - Widget contentWidget; - if (allFilesAreImages) { - contentWidget = Column( - mainAxisSize: MainAxisSize.min, - children: [ - Flexible( - child: Material( - borderRadius: BorderRadius.circular(AppConfig.borderRadius), - elevation: - Theme.of(context).appBarTheme.scrolledUnderElevation ?? 4, - shadowColor: Theme.of(context).appBarTheme.shadowColor, - clipBehavior: Clip.hardEdge, - child: Image.memory( - widget.files.first.bytes, - fit: BoxFit.contain, - height: 256, + + final compressionSupported = + uniqueFileType != 'video' || PlatformInfos.isMobile; + + return FutureBuilder( + future: _calcCombinedFileSize(), + builder: (context, snapshot) { + final sizeString = + snapshot.data ?? L10n.of(context).calculatingFileSize; + + return AlertDialog.adaptive( + title: Text(sendStr), + content: SizedBox( + width: 256, + child: SingleChildScrollView( + child: Column( + mainAxisSize: .min, + children: [ + const SizedBox(height: 12), + if (uniqueFileType == 'image') + Padding( + padding: const EdgeInsets.only(bottom: 16.0), + child: SizedBox( + height: 256, + child: Center( + child: ListView.builder( + shrinkWrap: true, + itemCount: widget.files.length, + scrollDirection: Axis.horizontal, + itemBuilder: (context, i) => Padding( + padding: const EdgeInsets.only(right: 8.0), + child: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 2, + ), + color: Colors.black, + clipBehavior: Clip.hardEdge, + child: FutureBuilder( + future: widget.files[i].readAsBytes(), + builder: (context, snapshot) { + final bytes = snapshot.data; + if (bytes == null) { + return const Center( + child: + CircularProgressIndicator.adaptive(), + ); + } + if (snapshot.error != null) { + Logs().w( + 'Unable to preview image', + snapshot.error, + snapshot.stackTrace, + ); + return const Center( + child: SizedBox( + width: 256, + height: 256, + child: Icon( + Icons.broken_image_outlined, + size: 64, + ), + ), + ); + } + return Image.memory( + bytes, + height: 256, + width: widget.files.length == 1 + ? 256 - 36 + : null, + fit: BoxFit.contain, + errorBuilder: (context, e, s) { + Logs().w( + 'Unable to preview image', + e, + s, + ); + return const Center( + child: SizedBox( + width: 256, + height: 256, + child: Icon( + Icons.broken_image_outlined, + size: 64, + ), + ), + ); + }, + ); + }, + ), + ), + ), + ), + ), + ), + ), + if (uniqueFileType != 'image') + Padding( + padding: const EdgeInsets.only(bottom: 16.0), + child: Row( + children: [ + Icon( + uniqueFileType == null + ? Icons.description_outlined + : uniqueFileType == 'video' + ? Icons.video_file_outlined + : uniqueFileType == 'audio' + ? Icons.audio_file_outlined + : Icons.description_outlined, + size: 32, + ), + const SizedBox(width: 8), + Expanded( + child: Column( + mainAxisSize: .min, + crossAxisAlignment: .start, + children: [ + Text( + fileName, + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + Text( + '$sizeString - $fileTypes', + style: theme.textTheme.labelSmall, + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + ], + ), + ), + ], + ), + ), + if (widget.files.length == 1) + Padding( + padding: const EdgeInsets.only(bottom: 8.0), + child: DialogTextField( + controller: _labelTextController, + labelText: L10n.of(context).optionalMessage, + minLines: 1, + maxLines: 3, + maxLength: 255, + counterText: '', + ), + ), + // Workaround for SwitchListTile.adaptive crashes in CupertinoDialog + if ({'image', 'video'}.contains(uniqueFileType)) + Row( + crossAxisAlignment: .center, + children: [ + if ({ + TargetPlatform.iOS, + TargetPlatform.macOS, + }.contains(theme.platform)) + CupertinoSwitch( + value: compressionSupported && compress, + onChanged: compressionSupported + ? (v) => setState(() => compress = v) + : null, + ) + else + Switch.adaptive( + value: compressionSupported && compress, + onChanged: compressionSupported + ? (v) => setState(() => compress = v) + : null, + ), + const SizedBox(width: 16), + Expanded( + child: Column( + mainAxisSize: .min, + crossAxisAlignment: .start, + children: [ + Row( + mainAxisSize: .min, + children: [ + Text( + L10n.of(context).compress, + style: theme.textTheme.titleMedium, + textAlign: TextAlign.left, + ), + ], + ), + if (!compress) + Text( + ' ($sizeString)', + style: theme.textTheme.labelSmall, + ), + if (!compressionSupported) + Text( + L10n.of(context).notSupportedOnThisDevice, + style: theme.textTheme.labelSmall, + ), + ], + ), + ), + ], + ), + ], ), ), ), - const SizedBox(height: 16), - // Workaround for SwitchListTile.adaptive crashes in CupertinoDialog - Row( - crossAxisAlignment: CrossAxisAlignment.center, - children: [ - CupertinoSwitch( - value: origImage, - onChanged: (v) => setState(() => origImage = v), - ), - const SizedBox(width: 16), - Expanded( - child: Column( - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text( - L10n.of(context)!.sendOriginal, - style: const TextStyle(fontWeight: FontWeight.bold), - ), - Text(sizeString), - ], - ), - ), - ], - ), - ], - ); - } else if (widget.files.every((file) => file is MatrixVideoFile)) { - contentWidget = Column( - mainAxisSize: MainAxisSize.min, - children: [ - Text(fileName), - const SizedBox(height: 16), - // Workaround for SwitchListTile.adaptive crashes in CupertinoDialog - Row( - crossAxisAlignment: CrossAxisAlignment.center, - children: [ - CupertinoSwitch( - value: origImage, - onChanged: (v) => setState(() => origImage = v), - ), - const SizedBox(width: 16), - Expanded( - child: Column( - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text( - L10n.of(context)!.sendOriginal, - style: const TextStyle(fontWeight: FontWeight.bold), - ), - Text(sizeString), - ], - ), - ), - ], - ), - ], - ); - } else { - contentWidget = Text('$fileName ($sizeString)'); - } - return AlertDialog.adaptive( - title: Text(sendStr), - content: contentWidget, - actions: [ - TextButton( - onPressed: () { - // just close the dialog - Navigator.of(context, rootNavigator: false).pop(); - }, - child: Text(L10n.of(context)!.cancel), - ), - TextButton( - onPressed: _send, - child: Text(L10n.of(context)!.send), - ), - ], + actions: [ + AdaptiveDialogAction( + onPressed: () => + Navigator.of(context, rootNavigator: false).pop(), + child: Text(L10n.of(context).cancel), + ), + AdaptiveDialogAction( + onPressed: _send, + child: Text(L10n.of(context).send), + ), + ], + ); + }, + ); + } +} + +extension on ScaffoldMessengerState { + ScaffoldFeatureController showLoadingSnackBar( + String title, + ) { + clearSnackBars(); + return showSnackBar( + SnackBar( + duration: const Duration(minutes: 5), + dismissDirection: DismissDirection.none, + content: Row( + children: [ + const SizedBox( + width: 16, + height: 16, + child: CircularProgressIndicator.adaptive(strokeWidth: 2), + ), + const SizedBox(width: 16), + Text(title), + ], + ), + ), ); } } diff --git a/lib/pages/chat/send_location_dialog.dart b/lib/pages/chat/send_location_dialog.dart index b2a99004e..914604679 100644 --- a/lib/pages/chat/send_location_dialog.dart +++ b/lib/pages/chat/send_location_dialog.dart @@ -3,20 +3,18 @@ import 'dart:async'; import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:geolocator/geolocator.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat/events/map_bubble.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; class SendLocationDialog extends StatefulWidget { final Room room; - const SendLocationDialog({ - required this.room, - super.key, - }); + const SendLocationDialog({required this.room, super.key}); @override SendLocationDialogState createState() => SendLocationDialogState(); @@ -56,13 +54,17 @@ class SendLocationDialogState extends State { Position position; try { position = await Geolocator.getCurrentPosition( - desiredAccuracy: LocationAccuracy.best, - timeLimit: const Duration(seconds: 30), + locationSettings: const LocationSettings( + accuracy: LocationAccuracy.best, + timeLimit: Duration(seconds: 30), + ), ); } on TimeoutException { position = await Geolocator.getCurrentPosition( - desiredAccuracy: LocationAccuracy.medium, - timeLimit: const Duration(seconds: 30), + locationSettings: const LocationSettings( + accuracy: LocationAccuracy.medium, + timeLimit: Duration(seconds: 30), + ), ); } setState(() => this.position = position); @@ -71,7 +73,7 @@ class SendLocationDialogState extends State { } } - void sendAction() async { + Future sendAction() async { setState(() => isSending = true); final body = 'https://www.openstreetmap.org/?mlat=${position!.latitude}&mlon=${position!.longitude}#map=16/${position!.latitude}/${position!.longitude}'; @@ -93,35 +95,36 @@ class SendLocationDialogState extends State { longitude: position!.longitude, ); } else if (disabled) { - contentWidget = Text(L10n.of(context)!.locationDisabledNotice); + contentWidget = Text(L10n.of(context).locationDisabledNotice); } else if (denied) { - contentWidget = Text(L10n.of(context)!.locationPermissionDeniedNotice); + contentWidget = Text(L10n.of(context).locationPermissionDeniedNotice); } else if (error != null) { - contentWidget = - Text(L10n.of(context)!.errorObtainingLocation(error.toString())); + contentWidget = Text( + L10n.of(context).errorObtainingLocation(error.toString()), + ); } else { contentWidget = Row( - mainAxisSize: MainAxisSize.min, - mainAxisAlignment: MainAxisAlignment.center, + mainAxisSize: .min, + mainAxisAlignment: .center, children: [ const CupertinoActivityIndicator(), const SizedBox(width: 12), - Text(L10n.of(context)!.obtainingLocation), + Text(L10n.of(context).obtainingLocation), ], ); } return AlertDialog.adaptive( - title: Text(L10n.of(context)!.shareLocation), + title: Text(L10n.of(context).shareLocation), content: contentWidget, actions: [ - TextButton( + AdaptiveDialogAction( onPressed: Navigator.of(context, rootNavigator: false).pop, - child: Text(L10n.of(context)!.cancel), + child: Text(L10n.of(context).cancel), ), if (position != null) - TextButton( + AdaptiveDialogAction( onPressed: isSending ? null : sendAction, - child: Text(L10n.of(context)!.send), + child: Text(L10n.of(context).send), ), ], ); diff --git a/lib/pages/chat/start_poll_bottom_sheet.dart b/lib/pages/chat/start_poll_bottom_sheet.dart new file mode 100644 index 000000000..7c5bf176c --- /dev/null +++ b/lib/pages/chat/start_poll_bottom_sheet.dart @@ -0,0 +1,158 @@ +import 'package:flutter/material.dart'; + +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; + +class StartPollBottomSheet extends StatefulWidget { + final Room room; + const StartPollBottomSheet({required this.room, super.key}); + + @override + State createState() => _StartPollBottomSheetState(); +} + +class _StartPollBottomSheetState extends State { + final TextEditingController _bodyController = TextEditingController(); + bool _allowMultipleAnswers = false; + final List _answers = [ + TextEditingController(), + TextEditingController(), + ]; + PollKind _pollKind = PollKind.disclosed; + + bool _canCreate = false; + + bool isLoading = false; + + String? _txid; + + Future _createPoll() async { + try { + var id = 0; + _txid ??= widget.room.client.generateUniqueTransactionId(); + await widget.room.startPoll( + question: _bodyController.text.trim(), + answers: _answers + .map( + (answerController) => PollAnswer( + id: (++id).toString(), + mText: answerController.text.trim(), + ), + ) + .toList(), + kind: _pollKind, + maxSelections: _allowMultipleAnswers ? _answers.length : 1, + txid: _txid, + ); + Navigator.of(context).pop(); + } catch (e, s) { + Logs().w('Unable to create poll', e, s); + if (!mounted) return; + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); + } + } + + void _updateCanCreate([_]) { + final newCanCreate = + _bodyController.text.trim().isNotEmpty && + !_answers.any((controller) => controller.text.trim().isEmpty); + if (_canCreate != newCanCreate) { + setState(() { + _canCreate = newCanCreate; + }); + } + } + + @override + Widget build(BuildContext context) { + const maxAnswers = 10; + return Scaffold( + appBar: AppBar( + leading: CloseButton(onPressed: Navigator.of(context).pop), + title: Text(L10n.of(context).startPoll), + ), + body: ListView( + padding: const EdgeInsets.symmetric(horizontal: 32, vertical: 16), + children: [ + TextField( + controller: _bodyController, + minLines: 2, + maxLines: 4, + maxLength: 1024, + onChanged: _updateCanCreate, + decoration: InputDecoration( + hintText: L10n.of(context).pollQuestion, + counter: const SizedBox.shrink(), + ), + ), + const Divider(height: 32), + ..._answers.map( + (answerController) => Padding( + padding: const EdgeInsets.only(bottom: 16.0), + child: TextField( + controller: answerController, + onChanged: _updateCanCreate, + maxLength: 64, + decoration: InputDecoration( + counter: const SizedBox.shrink(), + hintText: L10n.of(context).answerOption, + suffixIcon: _answers.length == 2 + ? null + : IconButton( + icon: const Icon(Icons.cancel_outlined), + onPressed: () => setState(() { + _answers.remove(answerController..dispose()); + }), + ), + ), + ), + ), + ), + Align( + alignment: Alignment.centerLeft, + child: TextButton.icon( + icon: const Icon(Icons.add_outlined), + onPressed: _answers.length < maxAnswers + ? () => setState(() { + _answers.add(TextEditingController()); + }) + : null, + label: Text(L10n.of(context).addAnswerOption), + ), + ), + const Divider(height: 32), + ListTile( + contentPadding: EdgeInsets.zero, + leading: Switch.adaptive( + value: _pollKind == PollKind.disclosed, + onChanged: (allow) => setState(() { + _pollKind = allow ? PollKind.disclosed : PollKind.undisclosed; + }), + ), + title: Text(L10n.of(context).answersVisible), + ), + ListTile( + contentPadding: EdgeInsets.zero, + leading: Switch.adaptive( + value: _allowMultipleAnswers, + onChanged: (allow) => setState(() { + _allowMultipleAnswers = allow; + }), + ), + title: Text(L10n.of(context).allowMultipleAnswers), + ), + ElevatedButton( + onPressed: !isLoading && _canCreate ? _createPoll : null, + child: isLoading + ? const LinearProgressIndicator() + : Text(L10n.of(context).startPoll), + ), + ], + ), + ); + } +} diff --git a/lib/pages/chat/sticker_picker_dialog.dart b/lib/pages/chat/sticker_picker_dialog.dart index c0a6ec76b..e4c21f46e 100644 --- a/lib/pages/chat/sticker_picker_dialog.dart +++ b/lib/pages/chat/sticker_picker_dialog.dart @@ -1,9 +1,9 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/url_launcher.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; import '../../widgets/avatar.dart'; @@ -27,6 +27,8 @@ class StickerPickerDialogState extends State { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final stickerPacks = widget.room.getImagePacks(ImagePackUsage.sticker); final packSlugs = stickerPacks.keys.toList(); @@ -36,15 +38,17 @@ class StickerPickerDialogState extends State { final filteredImagePackImageEntried = pack.images.entries.toList(); if (searchFilter?.isNotEmpty ?? false) { filteredImagePackImageEntried.removeWhere( - (e) => !(e.key.toLowerCase().contains(searchFilter!.toLowerCase()) || - (e.value.body - ?.toLowerCase() - .contains(searchFilter!.toLowerCase()) ?? - false)), + (e) => + !(e.key.toLowerCase().contains(searchFilter!.toLowerCase()) || + (e.value.body?.toLowerCase().contains( + searchFilter!.toLowerCase(), + ) ?? + false)), ); } - final imageKeys = - filteredImagePackImageEntried.map((e) => e.key).toList(); + final imageKeys = filteredImagePackImageEntried + .map((e) => e.key) + .toList(); if (imageKeys.isEmpty) { return const SizedBox.shrink(); } @@ -65,31 +69,38 @@ class StickerPickerDialogState extends State { GridView.builder( itemCount: imageKeys.length, gridDelegate: const SliverGridDelegateWithMaxCrossAxisExtent( - maxCrossAxisExtent: 128, + maxCrossAxisExtent: 84, + mainAxisSpacing: 8.0, + crossAxisSpacing: 8.0, ), shrinkWrap: true, physics: const NeverScrollableScrollPhysics(), itemBuilder: (BuildContext context, int imageIndex) { final image = pack.images[imageKeys[imageIndex]]!; - return InkWell( - radius: AppConfig.borderRadius, - key: ValueKey(image.url.toString()), - onTap: () { - // copy the image - final imageCopy = - ImagePackImageContent.fromJson(image.toJson().copy()); - // set the body, if it doesn't exist, to the key - imageCopy.body ??= imageKeys[imageIndex]; - widget.onSelected(imageCopy); - }, - child: AbsorbPointer( - absorbing: true, - child: MxcImage( - uri: image.url, - fit: BoxFit.contain, - width: 128, - height: 128, - animated: true, + return Tooltip( + message: image.body ?? imageKeys[imageIndex], + child: InkWell( + radius: AppConfig.borderRadius, + key: ValueKey(image.url.toString()), + onTap: () { + // copy the image + final imageCopy = ImagePackImageContent.fromJson( + image.toJson().copy(), + ); + // set the body, if it doesn't exist, to the key + imageCopy.body ??= imageKeys[imageIndex]; + widget.onSelected(imageCopy); + }, + child: AbsorbPointer( + absorbing: true, + child: MxcImage( + uri: image.url, + fit: BoxFit.contain, + width: 128, + height: 128, + animated: true, + isThumbnail: false, + ), ), ), ); @@ -100,7 +111,7 @@ class StickerPickerDialogState extends State { }; return Scaffold( - backgroundColor: Theme.of(context).colorScheme.onInverseSurface, + backgroundColor: theme.colorScheme.onInverseSurface, body: SizedBox( width: double.maxFinite, child: CustomScrollView( @@ -108,6 +119,7 @@ class StickerPickerDialogState extends State { SliverAppBar( floating: true, pinned: true, + scrolledUnderElevation: 0, automaticallyImplyLeading: false, backgroundColor: Colors.transparent, title: SizedBox( @@ -115,7 +127,8 @@ class StickerPickerDialogState extends State { child: TextField( autofocus: false, decoration: InputDecoration( - hintText: L10n.of(context)!.search, + filled: true, + hintText: L10n.of(context).search, prefixIcon: const Icon(Icons.search_outlined), contentPadding: EdgeInsets.zero, ), @@ -127,17 +140,17 @@ class StickerPickerDialogState extends State { SliverFillRemaining( child: Center( child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ - Text(L10n.of(context)!.noEmotesFound), + Text(L10n.of(context).noEmotesFound), const SizedBox(height: 12), OutlinedButton.icon( onPressed: () => UrlLauncher( context, - 'https://matrix.to/#/#fluffychat-stickers:janian.de', + AppConfig.howDoIGetStickersTutorial, ).launchUrl(), icon: const Icon(Icons.explore_outlined), - label: Text(L10n.of(context)!.discover), + label: Text(L10n.of(context).discover), ), ], ), diff --git a/lib/pages/chat/typing_indicators.dart b/lib/pages/chat/typing_indicators.dart index 35fbf5d25..236c30e59 100644 --- a/lib/pages/chat/typing_indicators.dart +++ b/lib/pages/chat/typing_indicators.dart @@ -14,13 +14,16 @@ class TypingIndicators extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + const avatarSize = Avatar.defaultSize / 2; return StreamBuilder( stream: controller.room.client.onSync.stream.where( (syncUpdate) => - syncUpdate.rooms?.join?[controller.room.id]?.ephemeral - ?.any((ephemeral) => ephemeral.type == 'm.typing') ?? + syncUpdate.rooms?.join?[controller.room.id]?.ephemeral?.any( + (ephemeral) => ephemeral.type == 'm.typing', + ) ?? false, ), builder: (context, _) { @@ -31,22 +34,21 @@ class TypingIndicators extends StatelessWidget { width: double.infinity, alignment: Alignment.center, child: AnimatedContainer( - constraints: - const BoxConstraints(maxWidth: FluffyThemes.columnWidth * 2.5), + constraints: const BoxConstraints( + maxWidth: FluffyThemes.maxTimelineWidth, + ), height: typingUsers.isEmpty ? 0 : avatarSize + 8, duration: FluffyThemes.animationDuration, curve: FluffyThemes.animationCurve, - alignment: controller.timeline!.events.isNotEmpty && + alignment: + controller.timeline!.events.isNotEmpty && controller.timeline!.events.first.senderId == Matrix.of(context).client.userID ? Alignment.topRight : Alignment.topLeft, clipBehavior: Clip.hardEdge, decoration: const BoxDecoration(), - padding: const EdgeInsets.symmetric( - horizontal: 8.0, - vertical: 4.0, - ), + padding: const EdgeInsets.symmetric(horizontal: 8.0, vertical: 4.0), child: Row( children: [ Container( @@ -79,9 +81,7 @@ class TypingIndicators extends StatelessWidget { ), const SizedBox(width: 8), Material( - color: - // ignore: deprecated_member_use - Theme.of(context).colorScheme.surfaceVariant, + color: theme.colorScheme.surfaceContainerHigh, borderRadius: const BorderRadius.all( Radius.circular(AppConfig.borderRadius), ), @@ -115,17 +115,14 @@ class __TypingDotsState extends State<_TypingDots> { @override void initState() { - _timer = Timer.periodic( - animationDuration, - (_) { - if (!mounted) { - return; - } - setState(() { - _tick = (_tick + 1) % 4; - }); - }, - ); + _timer = Timer.periodic(animationDuration, (_) { + if (!mounted) { + return; + } + setState(() { + _tick = (_tick + 1) % 4; + }); + }); super.initState(); } @@ -137,10 +134,11 @@ class __TypingDotsState extends State<_TypingDots> { @override Widget build(BuildContext context) { + final theme = Theme.of(context); const size = 8.0; return Row( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ for (var i = 1; i <= 3; i++) AnimatedContainer( @@ -154,7 +152,7 @@ class __TypingDotsState extends State<_TypingDots> { ), decoration: BoxDecoration( borderRadius: BorderRadius.circular(size * 2), - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, ), ), ], diff --git a/lib/pages/chat_access_settings/chat_access_settings_controller.dart b/lib/pages/chat_access_settings/chat_access_settings_controller.dart index c0ab1fa7a..93f5cda09 100644 --- a/lib/pages/chat_access_settings/chat_access_settings_controller.dart +++ b/lib/pages/chat_access_settings/chat_access_settings_controller.dart @@ -1,12 +1,15 @@ import 'package:flutter/material.dart' hide Visibility; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; +import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_access_settings/chat_access_settings_page.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; class ChatAccessSettings extends StatefulWidget { @@ -23,25 +26,81 @@ class ChatAccessSettingsController extends State { bool historyVisibilityLoading = false; bool guestAccessLoading = false; Room get room => Matrix.of(context).client.getRoomById(widget.roomId)!; + Set get knownSpaceParents => { + ...room.client.rooms.where( + (space) => + space.isSpace && + space.spaceChildren.any((child) => child.roomId == room.id), + ), + ...room.spaceParents + .map((parent) => room.client.getRoomById(parent.roomId ?? '')) + .whereType(), + }; - void setJoinRule(JoinRules? newJoinRules) async { + String get roomVersion => + room + .getState(EventTypes.RoomCreate)! + .content + .tryGet('room_version') ?? + 'Unknown'; + + /// Calculates which join rules are available based on the information on + /// https://spec.matrix.org/v1.11/rooms/#feature-matrix + List get availableJoinRules { + final joinRules = Set.from(JoinRules.values); + + final roomVersionInt = int.tryParse(roomVersion); + + // Knock is only supported for rooms up from version 7: + if (roomVersionInt != null && roomVersionInt <= 6) { + joinRules.remove(JoinRules.knock); + } + + // Restricted is only supported for rooms up from version 8: + if (roomVersionInt != null && roomVersionInt <= 7) { + joinRules.remove(JoinRules.restricted); + } + + // Knock-Restricted is only supported for rooms up from version 10: + if (roomVersionInt != null && roomVersionInt <= 9) { + joinRules.remove(JoinRules.knockRestricted); + } + + if (knownSpaceParents.isEmpty) { + joinRules.remove(JoinRules.restricted); + joinRules.remove(JoinRules.knockRestricted); + } + + // If an unsupported join rule is the current join rule, display it: + final currentJoinRule = room.joinRules; + if (currentJoinRule != null) joinRules.add(currentJoinRule); + + return joinRules.toList(); + } + + Future setJoinRule(JoinRules? newJoinRules) async { if (newJoinRules == null) return; setState(() { joinRulesLoading = true; }); try { - await room.setJoinRules(newJoinRules); + await room.setJoinRules( + newJoinRules, + allowConditionRoomIds: + { + JoinRules.restricted, + JoinRules.knockRestricted, + }.contains(newJoinRules) + ? knownSpaceParents.map((parent) => parent.id).toList() + : null, + ); } catch (e, s) { Logs().w('Unable to change join rules', e, s); if (mounted) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text( - e.toLocalizedString(context), - ), - ), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); } } finally { if (mounted) { @@ -52,7 +111,9 @@ class ChatAccessSettingsController extends State { } } - void setHistoryVisibility(HistoryVisibility? historyVisibility) async { + Future setHistoryVisibility( + HistoryVisibility? historyVisibility, + ) async { if (historyVisibility == null) return; setState(() { historyVisibilityLoading = true; @@ -63,13 +124,9 @@ class ChatAccessSettingsController extends State { } catch (e, s) { Logs().w('Unable to change history visibility', e, s); if (mounted) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text( - e.toLocalizedString(context), - ), - ), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); } } finally { if (mounted) { @@ -80,7 +137,7 @@ class ChatAccessSettingsController extends State { } } - void setGuestAccess(GuestAccess? guestAccess) async { + Future setGuestAccess(GuestAccess? guestAccess) async { if (guestAccess == null) return; setState(() { guestAccessLoading = true; @@ -91,13 +148,9 @@ class ChatAccessSettingsController extends State { } catch (e, s) { Logs().w('Unable to change guest access', e, s); if (mounted) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text( - e.toLocalizedString(context), - ), - ), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); } } finally { if (mounted) { @@ -108,7 +161,7 @@ class ChatAccessSettingsController extends State { } } - void updateRoomAction() async { + Future updateRoomAction() async { final roomVersion = room .getState(EventTypes.RoomCreate)! .content @@ -119,14 +172,15 @@ class ChatAccessSettingsController extends State { ); final capabilities = capabilitiesResult.result; if (capabilities == null) return; - final newVersion = await showConfirmationDialog( + final newVersion = await showModalActionPopup( context: context, - title: L10n.of(context)!.replaceRoomWithNewerVersion, + title: L10n.of(context).replaceRoomWithNewerVersion, + cancelLabel: L10n.of(context).cancel, actions: capabilities.mRoomVersions!.available.entries .where((r) => r.key != roomVersion) .map( - (version) => AlertDialogAction( - key: version.key, + (version) => AdaptiveModalAction( + value: version.key, label: '${version.key} (${version.value.toString().split('.').last})', ), @@ -136,20 +190,58 @@ class ChatAccessSettingsController extends State { if (newVersion == null || OkCancelResult.cancel == await showOkCancelAlertDialog( - useRootNavigator: false, context: context, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.cancel, - title: L10n.of(context)!.areYouSure, - message: L10n.of(context)!.roomUpgradeDescription, - isDestructiveAction: true, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).cancel, + title: L10n.of(context).areYouSure, + message: L10n.of(context).roomUpgradeDescription, + isDestructive: true, )) { return; } - await showFutureLoadingDialog( + final result = await showFutureLoadingDialog( context: context, - future: () => room.client.upgradeRoom(room.id, newVersion), + futureWithProgress: (onProgress) async { + final newRoomId = await room.client.upgradeRoom(room.id, newVersion); + var newRoom = room.client.getRoomById(newRoomId); + while (newRoom == null) { + await room.client.onSync.stream.first; + newRoom = room.client.getRoomById(newRoomId); + } + + if ({ + JoinRules.invite, + JoinRules.knock, + JoinRules.knockRestricted, + }.contains(room.joinRules)) { + final users = await room.requestParticipants([ + Membership.join, + Membership.invite, + ]); + users.removeWhere((user) => user.id == room.client.userID); + for (final (i, user) in users.indexed) { + try { + Logs().v('Inviting...', user.id); + await newRoom.invite(user.id); + onProgress(i / users.length); + } on MatrixException catch (e) { + final retryAfterMs = e.retryAfterMs; + if (e.error != MatrixError.M_LIMIT_EXCEEDED || + retryAfterMs == null) { + rethrow; + } + Logs().d('Limit exceeded. Retry after $retryAfterMs'); + await Future.delayed(Duration(milliseconds: retryAfterMs)); + await newRoom.invite(user.id); + onProgress(i / users.length); + } + } + } + }, ); + if (result.error != null) return; + if (!mounted) return; + context.go('/rooms/${room.id}'); } Future addAlias() async { @@ -160,16 +252,12 @@ class ChatAccessSettingsController extends State { final input = await showTextInputDialog( context: context, - title: L10n.of(context)!.editRoomAliases, - textFields: [ - DialogTextField( - prefixText: '#', - suffixText: domain, - hintText: L10n.of(context)!.alias, - ), - ], + title: L10n.of(context).editRoomAliases, + prefixText: '#', + suffixText: domain, + hintText: L10n.of(context).alias, ); - final aliasLocalpart = input?.singleOrNull?.trim(); + final aliasLocalpart = input?.trim(); if (aliasLocalpart == null || aliasLocalpart.isEmpty) return; final alias = '#$aliasLocalpart:$domain'; @@ -184,13 +272,14 @@ class ChatAccessSettingsController extends State { final canonicalAliasConsent = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.setAsCanonicalAlias, + title: L10n.of(context).setAsCanonicalAlias, message: alias, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.no, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).no, ); - final altAliases = room + final altAliases = + room .getState(EventTypes.RoomCanonicalAlias) ?.content .tryGetList('alt_aliases') @@ -206,21 +295,17 @@ class ChatAccessSettingsController extends State { await showFutureLoadingDialog( context: context, - future: () => room.client.setRoomStateWithKey( - room.id, - EventTypes.RoomCanonicalAlias, - '', - { - 'alias': canonicalAliasConsent == OkCancelResult.ok - ? alias - : room.canonicalAlias, - if (altAliases.isNotEmpty) 'alt_aliases': altAliases.toList(), - }, - ), + future: () => room.client + .setRoomStateWithKey(room.id, EventTypes.RoomCanonicalAlias, '', { + 'alias': canonicalAliasConsent == OkCancelResult.ok + ? alias + : room.canonicalAlias, + if (altAliases.isNotEmpty) 'alt_aliases': altAliases.toList(), + }), ); } - void deleteAlias(String alias) async { + Future deleteAlias(String alias) async { await showFutureLoadingDialog( context: context, future: () => room.client.deleteRoomAlias(alias), @@ -228,7 +313,7 @@ class ChatAccessSettingsController extends State { setState(() {}); } - void setChatVisibilityOnDirectory(bool? visibility) async { + Future setChatVisibilityOnDirectory(bool? visibility) async { if (visibility == null) return; setState(() { visibilityLoading = true; @@ -243,13 +328,9 @@ class ChatAccessSettingsController extends State { } catch (e, s) { Logs().w('Unable to change visibility', e, s); if (mounted) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text( - e.toLocalizedString(context), - ), - ), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); } } finally { if (mounted) { diff --git a/lib/pages/chat_access_settings/chat_access_settings_page.dart b/lib/pages/chat_access_settings/chat_access_settings_page.dart index 7de6f3793..5c1c55c66 100644 --- a/lib/pages/chat_access_settings/chat_access_settings_page.dart +++ b/lib/pages/chat_access_settings/chat_access_settings_page.dart @@ -1,8 +1,8 @@ import 'package:flutter/material.dart' hide Visibility; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_access_settings/chat_access_settings_controller.dart'; import 'package:fluffychat/utils/fluffy_share.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; @@ -14,118 +14,151 @@ class ChatAccessSettingsPageView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final room = controller.room; return Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.accessAndVisibility), + title: Text(L10n.of(context).accessAndVisibility), ), body: MaxWidthBody( child: StreamBuilder( - stream: room.client.onRoomState.stream - .where((update) => update.roomId == controller.room.id), + stream: room.client.onRoomState.stream.where( + (update) => update.roomId == controller.room.id, + ), builder: (context, snapshot) { final canonicalAlias = room.canonicalAlias; - final altAliases = room + final altAliases = + room .getState(EventTypes.RoomCanonicalAlias) ?.content .tryGetList('alt_aliases') ?? []; return Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ ListTile( title: Text( - L10n.of(context)!.visibilityOfTheChatHistory, + L10n.of(context).visibilityOfTheChatHistory, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), - for (final historyVisibility in HistoryVisibility.values) - RadioListTile.adaptive( - title: Text( - historyVisibility - .getLocalizedString(MatrixLocals(L10n.of(context)!)), - ), - value: historyVisibility, - groupValue: room.historyVisibility, - onChanged: controller.historyVisibilityLoading || - !room.canChangeHistoryVisibility - ? null - : controller.setHistoryVisibility, + RadioGroup( + groupValue: room.historyVisibility, + onChanged: + controller.historyVisibilityLoading || + !room.canChangeHistoryVisibility + ? (_) {} + : controller.setHistoryVisibility, + child: Column( + mainAxisSize: .min, + children: [ + for (final historyVisibility in HistoryVisibility.values) + RadioListTile.adaptive( + title: Text( + historyVisibility.getLocalizedString( + MatrixLocals(L10n.of(context)), + ), + ), + value: historyVisibility, + ), + ], ), - Divider(color: Theme.of(context).dividerColor), + ), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.whoIsAllowedToJoinThisGroup, + L10n.of(context).whoIsAllowedToJoinThisGroup, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), - for (final joinRule in JoinRules.values) - if (joinRule != JoinRules.private) - RadioListTile.adaptive( - title: Text( - joinRule.localizedString(L10n.of(context)!), - ), - value: joinRule, - groupValue: room.joinRules, - onChanged: controller.joinRulesLoading || - !room.canChangeJoinRules - ? null - : controller.setJoinRule, - ), - Divider(color: Theme.of(context).dividerColor), - if ({JoinRules.public, JoinRules.knock} - .contains(room.joinRules)) ...[ + RadioGroup( + groupValue: room.joinRules, + onChanged: controller.setJoinRule, + child: Column( + mainAxisSize: .min, + children: [ + for (final joinRule in controller.availableJoinRules) + if (joinRule != JoinRules.private) + RadioListTile.adaptive( + enabled: + !controller.joinRulesLoading && + room.canChangeJoinRules, + title: Text( + joinRule.localizedString( + L10n.of(context), + controller.knownSpaceParents, + ), + ), + value: joinRule, + ), + ], + ), + ), + Divider(color: theme.dividerColor), + if ({ + JoinRules.public, + JoinRules.knock, + }.contains(room.joinRules)) ...[ ListTile( title: Text( - L10n.of(context)!.areGuestsAllowedToJoin, + L10n.of(context).areGuestsAllowedToJoin, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), - for (final guestAccess in GuestAccess.values) - RadioListTile.adaptive( - title: Text( - guestAccess.getLocalizedString( - MatrixLocals(L10n.of(context)!), - ), - ), - value: guestAccess, - groupValue: room.guestAccess, - onChanged: controller.guestAccessLoading || - !room.canChangeGuestAccess - ? null - : controller.setGuestAccess, + RadioGroup( + groupValue: room.guestAccess, + onChanged: controller.setGuestAccess, + child: Column( + mainAxisSize: .min, + children: [ + for (final guestAccess in GuestAccess.values) + RadioListTile.adaptive( + enabled: + !controller.guestAccessLoading && + room.canChangeGuestAccess, + title: Text( + guestAccess.getLocalizedString( + MatrixLocals(L10n.of(context)), + ), + ), + value: guestAccess, + ), + ], ), - Divider(color: Theme.of(context).dividerColor), + ), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.publicChatAddresses, + L10n.of(context).publicChatAddresses, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), trailing: IconButton( icon: const Icon(Icons.add_outlined), - tooltip: L10n.of(context)!.createNewAddress, + tooltip: L10n.of(context).createNewAddress, onPressed: controller.addAlias, ), ), if (canonicalAlias.isNotEmpty) _AliasListTile( alias: canonicalAlias, - onDelete: room.canChangeStateEvent( - EventTypes.RoomCanonicalAlias, - ) + onDelete: + room.canChangeStateEvent( + EventTypes.RoomCanonicalAlias, + ) ? () => controller.deleteAlias(canonicalAlias) : null, isCanonicalAlias: true, @@ -133,9 +166,10 @@ class ChatAccessSettingsPageView extends StatelessWidget { for (final alias in altAliases) _AliasListTile( alias: alias, - onDelete: room.canChangeStateEvent( - EventTypes.RoomCanonicalAlias, - ) + onDelete: + room.canChangeStateEvent( + EventTypes.RoomCanonicalAlias, + ) ? () => controller.deleteAlias(alias) : null, ), @@ -147,10 +181,9 @@ class ChatAccessSettingsPageView extends StatelessWidget { return const SizedBox.shrink(); } localAddresses.remove(room.canonicalAlias); - localAddresses - .removeWhere((alias) => altAliases.contains(alias)); + localAddresses.removeWhere(altAliases.contains); return Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: localAddresses .map( (alias) => _AliasListTile( @@ -163,13 +196,13 @@ class ChatAccessSettingsPageView extends StatelessWidget { ); }, ), - Divider(color: Theme.of(context).dividerColor), + Divider(color: theme.dividerColor), FutureBuilder( future: room.client.getRoomVisibilityOnDirectory(room.id), builder: (context, snapshot) => SwitchListTile.adaptive( value: snapshot.data == Visibility.public, title: Text( - L10n.of(context)!.chatCanBeDiscoveredViaSearchOnServer( + L10n.of(context).chatCanBeDiscoveredViaSearchOnServer( room.client.userID!.domain!, ), ), @@ -178,7 +211,7 @@ class ChatAccessSettingsPageView extends StatelessWidget { ), ], ListTile( - title: Text(L10n.of(context)!.globalChatId), + title: Text(L10n.of(context).globalChatId), subtitle: SelectableText(room.id), trailing: IconButton( icon: const Icon(Icons.copy_outlined), @@ -186,7 +219,7 @@ class ChatAccessSettingsPageView extends StatelessWidget { ), ), ListTile( - title: Text(L10n.of(context)!.roomVersion), + title: Text(L10n.of(context).roomVersion), subtitle: SelectableText( room .getState(EventTypes.RoomCreate)! @@ -225,28 +258,27 @@ class _AliasListTile extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return ListTile( leading: isCanonicalAlias ? const Icon(Icons.star) : const Icon(Icons.link_outlined), title: InkWell( - onTap: () => FluffyShare.share( - 'https://matrix.to/#/$alias', - context, - ), - child: Text( - 'https://matrix.to/#/$alias', + onTap: () => FluffyShare.share('https://matrix.to/#/$alias', context), + child: SelectableText( + alias, style: TextStyle( decoration: TextDecoration.underline, - decorationColor: Theme.of(context).colorScheme.primary, - color: Theme.of(context).colorScheme.primary, + decorationColor: theme.colorScheme.primary, + color: theme.colorScheme.primary, fontSize: 14, ), ), ), trailing: onDelete != null ? IconButton( - color: Theme.of(context).colorScheme.error, + color: theme.colorScheme.error, icon: const Icon(Icons.delete_outlined), onPressed: onDelete, ) @@ -256,7 +288,7 @@ class _AliasListTile extends StatelessWidget { } extension JoinRulesDisplayString on JoinRules { - String localizedString(L10n l10n) { + String localizedString(L10n l10n, Set spaceParents) { switch (this) { case JoinRules.public: return l10n.anyoneCanJoin; @@ -267,9 +299,17 @@ extension JoinRulesDisplayString on JoinRules { case JoinRules.private: return l10n.noOneCanJoin; case JoinRules.restricted: - return l10n.restricted; + return l10n.spaceMemberOf( + spaceParents + .map((space) => space.getLocalizedDisplayname(MatrixLocals(l10n))) + .join(', '), + ); case JoinRules.knockRestricted: - return l10n.knockRestricted; + return l10n.spaceMemberOfCanKnock( + spaceParents + .map((space) => space.getLocalizedDisplayname(MatrixLocals(l10n))) + .join(', '), + ); } } } diff --git a/lib/pages/chat_details/chat_details.dart b/lib/pages/chat_details/chat_details.dart index 6c78adda6..b9a02690b 100644 --- a/lib/pages/chat_details/chat_details.dart +++ b/lib/pages/chat_details/chat_details.dart @@ -1,23 +1,21 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; import 'package:collection/collection.dart'; import 'package:file_picker/file_picker.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:go_router/go_router.dart'; import 'package:image_picker/image_picker.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_details/chat_details_view.dart'; import 'package:fluffychat/pages/settings/settings.dart'; +import 'package:fluffychat/utils/file_selector.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/widgets/app_lock.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; -enum AliasActions { copy, delete, setCanonical } - class ChatDetails extends StatefulWidget { final String roomId; final Widget? embeddedCloseButton; @@ -40,107 +38,80 @@ class ChatDetailsController extends State { String? get roomId => widget.roomId; - void setDisplaynameAction() async { + Future setDisplaynameAction() async { final room = Matrix.of(context).client.getRoomById(roomId!)!; final input = await showTextInputDialog( context: context, - title: L10n.of(context)!.changeTheNameOfTheGroup, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - initialText: room.getLocalizedDisplayname( - MatrixLocals( - L10n.of(context)!, - ), - ), - ), - ], + title: L10n.of(context).changeTheNameOfTheGroup, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + initialText: room.getLocalizedDisplayname(MatrixLocals(L10n.of(context))), ); if (input == null) return; final success = await showFutureLoadingDialog( context: context, - future: () => room.setName(input.single), + future: () => room.setName(input), ); if (success.error == null) { ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.displaynameHasBeenChanged)), + SnackBar(content: Text(L10n.of(context).displaynameHasBeenChanged)), ); } } - void setTopicAction() async { + Future setTopicAction() async { final room = Matrix.of(context).client.getRoomById(roomId!)!; final input = await showTextInputDialog( context: context, - title: L10n.of(context)!.setChatDescription, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - hintText: L10n.of(context)!.noChatDescriptionYet, - initialText: room.topic, - minLines: 4, - maxLines: 8, - ), - ], + title: L10n.of(context).setChatDescription, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + hintText: L10n.of(context).noChatDescriptionYet, + initialText: room.topic, + minLines: 4, + maxLines: 8, ); if (input == null) return; final success = await showFutureLoadingDialog( context: context, - future: () => room.setDescription(input.single), + future: () => room.setDescription(input), ); if (success.error == null) { ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text(L10n.of(context)!.chatDescriptionHasBeenChanged), - ), + SnackBar(content: Text(L10n.of(context).chatDescriptionHasBeenChanged)), ); } } - void goToEmoteSettings() async { - final room = Matrix.of(context).client.getRoomById(roomId!)!; - // okay, we need to test if there are any emote state events other than the default one - // if so, we need to be directed to a selection screen for which pack we want to look at - // otherwise, we just open the normal one. - if ((room.states['im.ponies.room_emotes'] ?? {}) - .keys - .any((String s) => s.isNotEmpty)) { - context.push('/rooms/${room.id}/details/multiple_emotes'); - } else { - context.push('/rooms/${room.id}/details/emotes'); - } - } - - void setAvatarAction() async { + Future setAvatarAction() async { final room = Matrix.of(context).client.getRoomById(roomId!); final actions = [ if (PlatformInfos.isMobile) - SheetAction( - key: AvatarAction.camera, - label: L10n.of(context)!.openCamera, + AdaptiveModalAction( + value: AvatarAction.camera, + label: L10n.of(context).openCamera, isDefaultAction: true, - icon: Icons.camera_alt_outlined, + icon: const Icon(Icons.camera_alt_outlined), ), - SheetAction( - key: AvatarAction.file, - label: L10n.of(context)!.openGallery, - icon: Icons.photo_outlined, + AdaptiveModalAction( + value: AvatarAction.file, + label: L10n.of(context).openGallery, + icon: const Icon(Icons.photo_outlined), ), if (room?.avatar != null) - SheetAction( - key: AvatarAction.remove, - label: L10n.of(context)!.delete, - isDestructiveAction: true, - icon: Icons.delete_outlined, + AdaptiveModalAction( + value: AvatarAction.remove, + label: L10n.of(context).delete, + isDestructive: true, + icon: const Icon(Icons.delete_outlined), ), ]; final action = actions.length == 1 - ? actions.single.key - : await showModalActionSheet( + ? actions.single.value + : await showModalActionPopup( context: context, - title: L10n.of(context)!.editRoomAvatar, + title: L10n.of(context).editRoomAvatar, + cancelLabel: L10n.of(context).cancel, actions: actions, ); if (action == null) return; @@ -160,21 +131,17 @@ class ChatDetailsController extends State { imageQuality: 50, ); if (result == null) return; - file = MatrixFile( - bytes: await result.readAsBytes(), - name: result.path, - ); + file = MatrixFile(bytes: await result.readAsBytes(), name: result.path); } else { - final picked = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles( - type: FileType.image, - withData: true, - ), + final picked = await selectFiles( + context, + allowMultiple: false, + type: FileType.image, ); - final pickedFile = picked?.files.firstOrNull; + final pickedFile = picked.firstOrNull; if (pickedFile == null) return; file = MatrixFile( - bytes: pickedFile.bytes!, + bytes: await pickedFile.readAsBytes(), name: pickedFile.name, ); } diff --git a/lib/pages/chat_details/chat_details_view.dart b/lib/pages/chat_details/chat_details_view.dart index 4e19e43ca..e17e21a80 100644 --- a/lib/pages/chat_details/chat_details_view.dart +++ b/lib/pages/chat_details/chat_details_view.dart @@ -1,11 +1,10 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_linkify/flutter_linkify.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_details/chat_details.dart'; import 'package:fluffychat/pages/chat_details/participant_list_item.dart'; import 'package:fluffychat/utils/fluffy_share.dart'; @@ -15,6 +14,8 @@ import 'package:fluffychat/widgets/chat_settings_popup_menu.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'package:fluffychat/widgets/matrix.dart'; import '../../utils/url_launcher.dart'; +import '../../widgets/mxc_image_viewer.dart'; +import '../../widgets/qr_code_viewer.dart'; class ChatDetailsView extends StatelessWidget { final ChatDetailsController controller; @@ -23,52 +24,63 @@ class ChatDetailsView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final room = Matrix.of(context).client.getRoomById(controller.roomId!); if (room == null) { return Scaffold( - appBar: AppBar( - title: Text(L10n.of(context)!.oopsSomethingWentWrong), - ), + appBar: AppBar(title: Text(L10n.of(context).oopsSomethingWentWrong)), body: Center( - child: Text(L10n.of(context)!.youAreNoLongerParticipatingInThisChat), + child: Text(L10n.of(context).youAreNoLongerParticipatingInThisChat), ), ); } + final directChatMatrixID = room.directChatMatrixID; + final roomAvatar = room.avatar; + return StreamBuilder( - stream: room.client.onRoomState.stream - .where((update) => update.roomId == room.id), + stream: room.client.onRoomState.stream.where( + (update) => update.roomId == room.id, + ), builder: (context, snapshot) { var members = room.getParticipants().toList() ..sort((b, a) => a.powerLevel.compareTo(b.powerLevel)); members = members.take(10).toList(); - final actualMembersCount = (room.summary.mInvitedMemberCount ?? 0) + + final actualMembersCount = + (room.summary.mInvitedMemberCount ?? 0) + (room.summary.mJoinedMemberCount ?? 0); final canRequestMoreMembers = members.length < actualMembersCount; - final iconColor = Theme.of(context).textTheme.bodyLarge!.color; + final iconColor = theme.textTheme.bodyLarge!.color; final displayname = room.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), ); return Scaffold( appBar: AppBar( - leading: controller.widget.embeddedCloseButton ?? + leading: + controller.widget.embeddedCloseButton ?? const Center(child: BackButton()), - elevation: Theme.of(context).appBarTheme.elevation, + elevation: theme.appBarTheme.elevation, actions: [ if (room.canonicalAlias.isNotEmpty) IconButton( - tooltip: L10n.of(context)!.share, - icon: Icon(Icons.adaptive.share_outlined), - onPressed: () => FluffyShare.share( - AppConfig.inviteLinkPrefix + room.canonicalAlias, - context, - ), + tooltip: L10n.of(context).share, + icon: const Icon(Icons.qr_code_rounded), + onPressed: () => + showQrCodeViewer(context, room.canonicalAlias), + ) + else if (directChatMatrixID != null) + IconButton( + tooltip: L10n.of(context).share, + icon: const Icon(Icons.qr_code_rounded), + onPressed: () => + showQrCodeViewer(context, directChatMatrixID), ), if (controller.widget.embeddedCloseButton == null) ChatSettingsPopupMenu(room, false), ], - title: Text(L10n.of(context)!.chatDetails), - backgroundColor: Theme.of(context).appBarTheme.backgroundColor, + title: Text(L10n.of(context).chatDetails), + backgroundColor: theme.appBarTheme.backgroundColor, ), body: MaxWidthBody( child: ListView.builder( @@ -77,7 +89,7 @@ class ChatDetailsView extends StatelessWidget { itemCount: members.length + 1 + (canRequestMoreMembers ? 1 : 0), itemBuilder: (BuildContext context, int i) => i == 0 ? Column( - crossAxisAlignment: CrossAxisAlignment.stretch, + crossAxisAlignment: .stretch, children: [ Row( children: [ @@ -85,33 +97,23 @@ class ChatDetailsView extends StatelessWidget { padding: const EdgeInsets.all(32.0), child: Stack( children: [ - Material( - elevation: Theme.of(context) - .appBarTheme - .scrolledUnderElevation ?? - 4, - shadowColor: Theme.of(context) - .appBarTheme - .shadowColor, - shape: RoundedRectangleBorder( - side: BorderSide( - color: Theme.of(context).dividerColor, - ), - borderRadius: BorderRadius.circular( - Avatar.defaultSize * 2.5, - ), - ), - child: Hero( - tag: controller - .widget.embeddedCloseButton != - null - ? 'embedded_content_banner' - : 'content_banner', - child: Avatar( - mxContent: room.avatar, - name: displayname, - size: Avatar.defaultSize * 2.5, - ), + Hero( + tag: + controller.widget.embeddedCloseButton != + null + ? 'embedded_content_banner' + : 'content_banner', + child: Avatar( + mxContent: room.avatar, + name: displayname, + size: Avatar.defaultSize * 2.5, + onTap: roomAvatar != null + ? () => showDialog( + context: context, + builder: (_) => + MxcImageViewer(roomAvatar), + ) + : null, ), ), if (!room.isDirectChat && @@ -134,8 +136,8 @@ class ChatDetailsView extends StatelessWidget { ), Expanded( child: Column( - mainAxisAlignment: MainAxisAlignment.center, - crossAxisAlignment: CrossAxisAlignment.start, + mainAxisAlignment: .center, + crossAxisAlignment: .start, children: [ TextButton.icon( onPressed: () => room.isDirectChat @@ -143,34 +145,34 @@ class ChatDetailsView extends StatelessWidget { : room.canChangeStateEvent( EventTypes.RoomName, ) - ? controller.setDisplaynameAction() - : FluffyShare.share( - displayname, - context, - copyOnly: true, - ), + ? controller.setDisplaynameAction() + : FluffyShare.share( + displayname, + context, + copyOnly: true, + ), icon: Icon( room.isDirectChat ? Icons.chat_bubble_outline : room.canChangeStateEvent( EventTypes.RoomName, ) - ? Icons.edit_outlined - : Icons.copy_outlined, + ? Icons.edit_outlined + : Icons.copy_outlined, size: 16, ), style: TextButton.styleFrom( - foregroundColor: Theme.of(context) - .colorScheme - .onSurface, + foregroundColor: + theme.colorScheme.onSurface, + iconColor: theme.colorScheme.onSurface, ), label: Text( room.isDirectChat - ? L10n.of(context)!.directChat + ? L10n.of(context).directChat : displayname, maxLines: 1, overflow: TextOverflow.ellipsis, - // style: const TextStyle(fontSize: 18), + style: const TextStyle(fontSize: 18), ), ), TextButton.icon( @@ -184,14 +186,14 @@ class ChatDetailsView extends StatelessWidget { size: 14, ), style: TextButton.styleFrom( - foregroundColor: Theme.of(context) - .colorScheme - .secondary, + foregroundColor: + theme.colorScheme.secondary, + iconColor: theme.colorScheme.secondary, ), label: Text( - L10n.of(context)!.countParticipants( - actualMembersCount, - ), + L10n.of( + context, + ).countParticipants(actualMembersCount), maxLines: 1, overflow: TextOverflow.ellipsis, // style: const TextStyle(fontSize: 12), @@ -202,145 +204,116 @@ class ChatDetailsView extends StatelessWidget { ), ], ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, - ), - if (!room.canChangeStateEvent(EventTypes.RoomTopic)) + if (room.canChangeStateEvent(EventTypes.RoomTopic) || + room.topic.isNotEmpty) ...[ + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.chatDescription, + L10n.of(context).chatDescription, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), - ) - else + trailing: + room.canChangeStateEvent(EventTypes.RoomTopic) + ? IconButton( + onPressed: controller.setTopicAction, + tooltip: L10n.of( + context, + ).setChatDescription, + icon: const Icon(Icons.edit_outlined), + ) + : null, + ), Padding( - padding: const EdgeInsets.all(16.0), - child: TextButton.icon( - onPressed: controller.setTopicAction, - label: Text(L10n.of(context)!.setChatDescription), - icon: const Icon(Icons.edit_outlined), - style: TextButton.styleFrom( - backgroundColor: Theme.of(context) - .colorScheme - .secondaryContainer, - foregroundColor: Theme.of(context) - .colorScheme - .onSecondaryContainer, + padding: const EdgeInsets.symmetric( + horizontal: 16.0, + ), + child: SelectableLinkify( + text: room.topic.isEmpty + ? L10n.of(context).noChatDescriptionYet + : room.topic, + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + options: const LinkifyOptions(humanize: false), + linkStyle: const TextStyle( + color: Colors.blueAccent, + decorationColor: Colors.blueAccent, ), + style: TextStyle( + fontSize: 14, + fontStyle: room.topic.isEmpty + ? FontStyle.italic + : FontStyle.normal, + color: theme.textTheme.bodyMedium!.color, + decorationColor: + theme.textTheme.bodyMedium!.color, + ), + onOpen: (url) => + UrlLauncher(context, url.url).launchUrl(), ), ), - Padding( - padding: const EdgeInsets.symmetric( - horizontal: 16.0, - ), - child: SelectableLinkify( - text: room.topic.isEmpty - ? L10n.of(context)!.noChatDescriptionYet - : room.topic, - options: const LinkifyOptions(humanize: false), - linkStyle: const TextStyle( - color: Colors.blueAccent, - decorationColor: Colors.blueAccent, - ), - style: TextStyle( - fontSize: 14, - fontStyle: room.topic.isEmpty - ? FontStyle.italic - : FontStyle.normal, - color: - Theme.of(context).textTheme.bodyMedium!.color, - decorationColor: - Theme.of(context).textTheme.bodyMedium!.color, - ), - onOpen: (url) => - UrlLauncher(context, url.url).launchUrl(), - ), - ), - const SizedBox(height: 16), - Divider( - height: 1, - color: Theme.of(context).dividerColor, - ), - ListTile( - leading: CircleAvatar( - backgroundColor: - Theme.of(context).scaffoldBackgroundColor, - foregroundColor: iconColor, - child: const Icon( - Icons.insert_emoticon_outlined, - ), - ), - title: - Text(L10n.of(context)!.customEmojisAndStickers), - subtitle: Text(L10n.of(context)!.setCustomEmotes), - onTap: controller.goToEmoteSettings, - trailing: const Icon(Icons.chevron_right_outlined), - ), - if (!room.isDirectChat) + const SizedBox(height: 16), + ], + if (!room.isDirectChat) ...[ + Divider(color: theme.dividerColor), ListTile( leading: CircleAvatar( backgroundColor: - Theme.of(context).scaffoldBackgroundColor, - foregroundColor: iconColor, - child: const Icon(Icons.shield_outlined), - ), - title: Text( - L10n.of(context)!.accessAndVisibility, - ), - subtitle: Text( - L10n.of(context)!.accessAndVisibilityDescription, - ), - onTap: () => context - .push('/rooms/${room.id}/details/access'), - trailing: const Icon(Icons.chevron_right_outlined), - ), - if (!room.isDirectChat) - ListTile( - title: Text(L10n.of(context)!.chatPermissions), - subtitle: Text( - L10n.of(context)!.whoCanPerformWhichAction, - ), - leading: CircleAvatar( - backgroundColor: - Theme.of(context).scaffoldBackgroundColor, + theme.colorScheme.surfaceContainer, foregroundColor: iconColor, child: const Icon( - Icons.edit_attributes_outlined, + Icons.admin_panel_settings_outlined, ), ), + title: Text(L10n.of(context).accessAndVisibility), + subtitle: Text( + L10n.of(context).accessAndVisibilityDescription, + ), + onTap: () => context.push( + '/rooms/${room.id}/details/access', + ), trailing: const Icon(Icons.chevron_right_outlined), - onTap: () => context - .push('/rooms/${room.id}/details/permissions'), ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, - ), + ListTile( + title: Text(L10n.of(context).chatPermissions), + subtitle: Text( + L10n.of(context).whoCanPerformWhichAction, + ), + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.surfaceContainer, + foregroundColor: iconColor, + child: const Icon(Icons.tune_outlined), + ), + trailing: const Icon(Icons.chevron_right_outlined), + onTap: () => context.push( + '/rooms/${room.id}/details/permissions', + ), + ), + ], + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.countParticipants( - actualMembersCount.toString(), - ), + L10n.of( + context, + ).countParticipants(actualMembersCount), style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), if (!room.isDirectChat && room.canInvite) ListTile( - title: Text(L10n.of(context)!.inviteContact), + title: Text(L10n.of(context).inviteContact), leading: CircleAvatar( - backgroundColor: Theme.of(context) - .colorScheme - .primaryContainer, - foregroundColor: Theme.of(context) - .colorScheme - .onPrimaryContainer, + backgroundColor: + theme.colorScheme.primaryContainer, + foregroundColor: + theme.colorScheme.onPrimaryContainer, radius: Avatar.defaultSize / 2, child: const Icon(Icons.add_outlined), ), @@ -350,26 +323,25 @@ class ChatDetailsView extends StatelessWidget { ], ) : i < members.length + 1 - ? ParticipantListItem(members[i - 1]) - : ListTile( - title: Text( - L10n.of(context)!.loadCountMoreParticipants( - (actualMembersCount - members.length).toString(), - ), - ), - leading: CircleAvatar( - backgroundColor: - Theme.of(context).scaffoldBackgroundColor, - child: const Icon( - Icons.group_outlined, - color: Colors.grey, - ), - ), - onTap: () => context.push( - '/rooms/${controller.roomId!}/details/members', - ), - trailing: const Icon(Icons.chevron_right_outlined), + ? ParticipantListItem(members[i - 1]) + : ListTile( + title: Text( + L10n.of(context).loadCountMoreParticipants( + (actualMembersCount - members.length), ), + ), + leading: CircleAvatar( + backgroundColor: theme.scaffoldBackgroundColor, + child: const Icon( + Icons.group_outlined, + color: Colors.grey, + ), + ), + onTap: () => context.push( + '/rooms/${controller.roomId!}/details/members', + ), + trailing: const Icon(Icons.chevron_right_outlined), + ), ), ), ); diff --git a/lib/pages/chat_details/participant_list_item.dart b/lib/pages/chat_details/participant_list_item.dart index 661153634..54dcf8be3 100644 --- a/lib/pages/chat_details/participant_list_item.dart +++ b/lib/pages/chat_details/participant_list_item.dart @@ -1,11 +1,11 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/member_actions_popup_menu_button.dart'; import '../../widgets/avatar.dart'; -import '../user_bottom_sheet/user_bottom_sheet.dart'; class ParticipantListItem extends StatelessWidget { final User user; @@ -14,75 +14,79 @@ class ParticipantListItem extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final membershipBatch = switch (user.membership) { - Membership.ban => L10n.of(context)!.banned, - Membership.invite => L10n.of(context)!.invited, + Membership.ban => L10n.of(context).banned, + Membership.invite => L10n.of(context).invited, Membership.join => null, - Membership.knock => L10n.of(context)!.knocking, - Membership.leave => L10n.of(context)!.leftTheChat, + Membership.knock => L10n.of(context).knocking, + Membership.leave => L10n.of(context).leftTheChat, }; - final permissionBatch = user.powerLevel == 100 - ? L10n.of(context)!.admin + final permissionBatch = user.room.creatorUserIds.contains(user.id) + ? L10n.of(context).owner + : user.powerLevel >= 100 + ? L10n.of(context).admin : user.powerLevel >= 50 - ? L10n.of(context)!.moderator - : ''; + ? L10n.of(context).moderator + : ''; - return Opacity( - opacity: user.membership == Membership.join ? 1 : 0.5, - child: ListTile( - onTap: () => showAdaptiveBottomSheet( - context: context, - builder: (c) => UserBottomSheet( - user: user, - outerContext: context, + return ListTile( + onTap: () => showMemberActionsPopupMenu(context: context, user: user), + title: Row( + children: [ + Expanded( + child: Text( + user.calcDisplayname(), + overflow: TextOverflow.ellipsis, + ), ), - ), - title: Row( - children: [ - Expanded( + if (permissionBatch.isNotEmpty) + Container( + padding: const EdgeInsets.symmetric(horizontal: 12, vertical: 6), + decoration: BoxDecoration( + color: user.powerLevel >= 100 + ? theme.colorScheme.tertiary + : theme.colorScheme.tertiaryContainer, + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + ), child: Text( - user.calcDisplayname(), - overflow: TextOverflow.ellipsis, + permissionBatch, + style: theme.textTheme.labelSmall?.copyWith( + color: user.powerLevel >= 100 + ? theme.colorScheme.onTertiary + : theme.colorScheme.onTertiaryContainer, + ), ), ), - if (permissionBatch.isNotEmpty) - Container( - padding: const EdgeInsets.symmetric( - horizontal: 4, - vertical: 2, - ), - margin: const EdgeInsets.symmetric(horizontal: 8), - decoration: BoxDecoration( - color: Theme.of(context).colorScheme.primaryContainer, - borderRadius: BorderRadius.circular(8), - border: Border.all( - color: Theme.of(context).colorScheme.primary, + membershipBatch == null + ? const SizedBox.shrink() + : Container( + padding: const EdgeInsets.symmetric( + vertical: 4, + horizontal: 8, ), - ), - child: Text( - permissionBatch, - style: TextStyle( - fontSize: 14, - color: Theme.of(context).colorScheme.primary, + margin: const EdgeInsets.symmetric(horizontal: 8), + decoration: BoxDecoration( + color: theme.colorScheme.secondaryContainer, + borderRadius: BorderRadius.circular(8), ), - ), - ), - membershipBatch == null - ? const SizedBox.shrink() - : Container( - padding: const EdgeInsets.all(4), - margin: const EdgeInsets.symmetric(horizontal: 8), - decoration: BoxDecoration( - color: Theme.of(context).secondaryHeaderColor, - borderRadius: BorderRadius.circular(8), + child: Center( + child: Text( + membershipBatch, + style: theme.textTheme.labelSmall?.copyWith( + color: theme.colorScheme.onSecondaryContainer, + ), ), - child: Center(child: Text(membershipBatch)), ), - ], - ), - subtitle: Text(user.id), - leading: Avatar( + ), + ], + ), + subtitle: Text(user.id, maxLines: 1, overflow: TextOverflow.ellipsis), + leading: Opacity( + opacity: user.membership == Membership.join ? 1 : 0.5, + child: Avatar( mxContent: user.avatarUrl, name: user.calcDisplayname(), presenceUserId: user.stateKey, diff --git a/lib/pages/chat_encryption_settings/chat_encryption_settings.dart b/lib/pages/chat_encryption_settings/chat_encryption_settings.dart index 559aa2063..d8db6f25e 100644 --- a/lib/pages/chat_encryption_settings/chat_encryption_settings.dart +++ b/lib/pages/chat_encryption_settings/chat_encryption_settings.dart @@ -1,13 +1,13 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_encryption_settings/chat_encryption_settings_view.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; import '../key_verification/key_verification_dialog.dart'; @@ -30,37 +30,37 @@ class ChatEncryptionSettingsController extends State { } } - void enableEncryption(_) async { + Future enableEncryption(_) async { if (room.encrypted) { showOkAlertDialog( context: context, - title: L10n.of(context)!.sorryThatsNotPossible, - message: L10n.of(context)!.disableEncryptionWarning, + title: L10n.of(context).sorryThatsNotPossible, + message: L10n.of(context).disableEncryptionWarning, ); return; } if (room.joinRules == JoinRules.public) { showOkAlertDialog( context: context, - title: L10n.of(context)!.sorryThatsNotPossible, - message: L10n.of(context)!.noEncryptionForPublicRooms, + title: L10n.of(context).sorryThatsNotPossible, + message: L10n.of(context).noEncryptionForPublicRooms, ); return; } if (!room.canChangeStateEvent(EventTypes.Encryption)) { showOkAlertDialog( context: context, - title: L10n.of(context)!.sorryThatsNotPossible, - message: L10n.of(context)!.noPermission, + title: L10n.of(context).sorryThatsNotPossible, + message: L10n.of(context).noPermission, ); return; } final consent = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.areYouSure, - message: L10n.of(context)!.enableEncryptionWarning, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).areYouSure, + message: L10n.of(context).enableEncryptionWarning, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).cancel, ); if (consent != OkCancelResult.ok) return; await showFutureLoadingDialog( @@ -69,14 +69,13 @@ class ChatEncryptionSettingsController extends State { ); } - void startVerification() async { + Future startVerification() async { final consent = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.verifyOtherUser, - message: L10n.of(context)!.verifyOtherUserDescription, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - fullyCapitalizedForMaterial: false, + title: L10n.of(context).verifyOtherUser, + message: L10n.of(context).verifyOtherUserDescription, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, ); if (consent != OkCancelResult.ok) return; final req = await room.client.userDeviceKeys[room.directChatMatrixID]! diff --git a/lib/pages/chat_encryption_settings/chat_encryption_settings_view.dart b/lib/pages/chat_encryption_settings/chat_encryption_settings_view.dart index d1be4e7d1..03309d178 100644 --- a/lib/pages/chat_encryption_settings/chat_encryption_settings_view.dart +++ b/lib/pages/chat_encryption_settings/chat_encryption_settings_view.dart @@ -1,14 +1,15 @@ import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; import 'package:url_launcher/url_launcher_string.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_encryption_settings/chat_encryption_settings.dart'; import 'package:fluffychat/utils/beautify_string_extension.dart'; +import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; class ChatEncryptionSettingsView extends StatelessWidget { @@ -18,6 +19,8 @@ class ChatEncryptionSettingsView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final room = controller.room; return StreamBuilder( stream: room.client.onSync.stream.where( @@ -29,36 +32,33 @@ class ChatEncryptionSettingsView extends StatelessWidget { icon: const Icon(Icons.close_outlined), onPressed: () => context.go('/rooms/${controller.roomId!}'), ), - title: Text(L10n.of(context)!.encryption), + title: Text(L10n.of(context).encryption), actions: [ TextButton( onPressed: () => launchUrlString(AppConfig.encryptionTutorial), - child: Text(L10n.of(context)!.help), + child: Text(L10n.of(context).help), ), ], ), body: MaxWidthBody( child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ SwitchListTile( secondary: CircleAvatar( - foregroundColor: - Theme.of(context).colorScheme.onPrimaryContainer, - backgroundColor: - Theme.of(context).colorScheme.primaryContainer, + foregroundColor: theme.colorScheme.onPrimaryContainer, + backgroundColor: theme.colorScheme.primaryContainer, child: const Icon(Icons.lock_outlined), ), - title: Text(L10n.of(context)!.encryptThisChat), + title: Text(L10n.of(context).encryptThisChat), value: room.encrypted, onChanged: controller.enableEncryption, ), Icon( CupertinoIcons.lock_shield, size: 128, - color: Theme.of(context).colorScheme.onInverseSurface, + color: theme.colorScheme.onInverseSurface, ), - const Divider(), if (room.isDirectChat) Padding( padding: const EdgeInsets.all(16.0), @@ -67,7 +67,7 @@ class ChatEncryptionSettingsView extends StatelessWidget { child: ElevatedButton.icon( onPressed: controller.startVerification, icon: const Icon(Icons.verified_outlined), - label: Text(L10n.of(context)!.verifyStart), + label: Text(L10n.of(context).verifyStart), ), ), ), @@ -75,23 +75,21 @@ class ChatEncryptionSettingsView extends StatelessWidget { const SizedBox(height: 16), ListTile( title: Text( - L10n.of(context)!.deviceKeys, - style: const TextStyle( - fontWeight: FontWeight.bold, - ), + L10n.of(context).deviceKeys, + style: const TextStyle(fontWeight: FontWeight.bold), ), ), StreamBuilder( - stream: room.client.onRoomState.stream - .where((update) => update.roomId == controller.room.id), - builder: (context, snapshot) => - FutureBuilder>( + stream: room.client.onRoomState.stream.where( + (update) => update.roomId == controller.room.id, + ), + builder: (context, snapshot) => FutureBuilder>( future: room.getUserDeviceKeys(), builder: (BuildContext context, snapshot) { if (snapshot.hasError) { return Center( child: Text( - '${L10n.of(context)!.oopsSomethingWentWrong}: ${snapshot.error}', + '${L10n.of(context).oopsSomethingWentWrong}: ${snapshot.error}', ), ); } @@ -103,81 +101,84 @@ class ChatEncryptionSettingsView extends StatelessWidget { ); } final deviceKeys = snapshot.data!; - return ListView.builder( - shrinkWrap: true, - physics: const NeverScrollableScrollPhysics(), - itemCount: deviceKeys.length, - itemBuilder: (BuildContext context, int i) => - SwitchListTile( - value: !deviceKeys[i].blocked, - activeColor: deviceKeys[i].verified - ? Colors.green - : Colors.orange, - onChanged: (_) => - controller.toggleDeviceKey(deviceKeys[i]), - title: Row( + return SelectionArea( + child: ListView.builder( + shrinkWrap: true, + physics: const NeverScrollableScrollPhysics(), + itemCount: deviceKeys.length, + itemBuilder: (BuildContext context, int i) => Column( + mainAxisSize: .min, children: [ - Icon( - deviceKeys[i].verified - ? Icons.verified_outlined - : deviceKeys[i].blocked - ? Icons.block_outlined - : Icons.info_outlined, - color: deviceKeys[i].verified - ? Colors.green - : deviceKeys[i].blocked - ? Colors.red - : Colors.orange, - size: 20, - ), - const SizedBox(width: 4), - Text( - deviceKeys[i].deviceId ?? - L10n.of(context)!.unknownDevice, - ), - const SizedBox(width: 4), - Flexible( - fit: FlexFit.loose, - child: Material( - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular( - AppConfig.borderRadius, - ), - side: BorderSide( - color: - Theme.of(context).colorScheme.primary, - ), + if (i == 0 || + deviceKeys[i].userId != + deviceKeys[i - 1].userId) ...[ + const Divider(), + FutureBuilder( + future: room.client.getUserProfile( + deviceKeys[i].userId, ), - color: Theme.of(context) - .colorScheme - .primaryContainer, - child: Padding( - padding: const EdgeInsets.all(4.0), - child: Text( - deviceKeys[i].userId, - maxLines: 1, - overflow: TextOverflow.ellipsis, + builder: (context, snapshot) { + final displayname = + snapshot.data?.displayname ?? + deviceKeys[i].userId.localpart ?? + deviceKeys[i].userId; + return ListTile( + leading: Avatar( + name: displayname, + mxContent: snapshot.data?.avatarUrl, + ), + title: Text(displayname), + subtitle: Text(deviceKeys[i].userId), + ); + }, + ), + ], + ListTile( + leading: Switch.adaptive( + value: !deviceKeys[i].blocked, + activeThumbColor: deviceKeys[i].verified + ? Colors.green + : Colors.orange, + onChanged: (_) => + controller.toggleDeviceKey(deviceKeys[i]), + ), + title: Row( + children: [ + Text( + deviceKeys[i].verified + ? L10n.of(context).verified + : deviceKeys[i].blocked + ? L10n.of(context).blocked + : L10n.of(context).unverified, style: TextStyle( - color: Theme.of(context) - .colorScheme - .primary, - fontSize: 12, - fontStyle: FontStyle.italic, + color: deviceKeys[i].verified + ? Colors.green + : deviceKeys[i].blocked + ? Colors.red + : Colors.orange, ), ), + const Text(' | ID: '), + Text( + deviceKeys[i].deviceId ?? + L10n.of(context).unknownDevice, + ), + ], + ), + subtitle: Text( + deviceKeys[i].ed25519Key?.beautified ?? + L10n.of( + context, + ).unknownEncryptionAlgorithm, + style: TextStyle( + fontFamily: 'RobotoMono', + color: theme.colorScheme.secondary, + fontSize: 11, ), ), ), ], ), - subtitle: Text( - deviceKeys[i].ed25519Key?.beautified ?? - L10n.of(context)!.unknownEncryptionAlgorithm, - style: TextStyle( - fontFamily: 'RobotoMono', - color: Theme.of(context).colorScheme.secondary, - ), - ), ), ); }, @@ -188,10 +189,8 @@ class ChatEncryptionSettingsView extends StatelessWidget { padding: const EdgeInsets.all(16.0), child: Center( child: Text( - L10n.of(context)!.encryptionNotEnabled, - style: const TextStyle( - fontStyle: FontStyle.italic, - ), + L10n.of(context).encryptionNotEnabled, + style: const TextStyle(fontStyle: FontStyle.italic), ), ), ), diff --git a/lib/pages/chat_list/chat_list.dart b/lib/pages/chat_list/chat_list.dart index 1c84f66af..4300b25db 100644 --- a/lib/pages/chat_list/chat_list.dart +++ b/lib/pages/chat_list/chat_list.dart @@ -1,67 +1,63 @@ import 'dart:async'; -import 'dart:io'; -import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_shortcuts/flutter_shortcuts.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; +import 'package:app_links/app_links.dart'; +import 'package:cross_file/cross_file.dart'; +import 'package:flutter_shortcuts_new/flutter_shortcuts_new.dart'; import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart' as sdk; import 'package:matrix/matrix.dart'; import 'package:receive_sharing_intent/receive_sharing_intent.dart'; -import 'package:uni_links/uni_links.dart'; -import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_list/chat_list_view.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/utils/show_scaffold_dialog.dart'; +import 'package:fluffychat/utils/show_update_snackbar.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; +import 'package:fluffychat/widgets/share_scaffold_dialog.dart'; import '../../../utils/account_bundles.dart'; import '../../config/setting_keys.dart'; -import '../../utils/matrix_sdk_extensions/matrix_file_extension.dart'; import '../../utils/url_launcher.dart'; -import '../../utils/voip/callkeep_manager.dart'; -import '../../widgets/fluffy_chat_app.dart'; import '../../widgets/matrix.dart'; -import '../bootstrap/bootstrap_dialog.dart'; -import 'package:fluffychat/utils/tor_stub.dart' - if (dart.library.html) 'package:tor_detector_web/tor_detector_web.dart'; +enum ActiveFilter { allChats, messages, groups, unread, spaces } -enum SelectMode { - normal, - share, - select, -} - -enum PopupMenuAction { - settings, - invite, - newGroup, - newSpace, - setStatus, - archive, -} - -enum ActiveFilter { - allChats, - groups, - messages, - spaces, +extension LocalizedActiveFilter on ActiveFilter { + String toLocalizedString(BuildContext context) { + switch (this) { + case ActiveFilter.allChats: + return L10n.of(context).all; + case ActiveFilter.messages: + return L10n.of(context).messages; + case ActiveFilter.unread: + return L10n.of(context).unread; + case ActiveFilter.groups: + return L10n.of(context).groups; + case ActiveFilter.spaces: + return L10n.of(context).spaces; + } + } } class ChatList extends StatefulWidget { static BuildContext? contextForVoip; - final bool displayNavigationRail; final String? activeChat; + final String? activeSpace; + final bool displayNavigationRail; const ChatList({ super.key, - this.displayNavigationRail = false, required this.activeChat, + this.activeSpace, + this.displayNavigationRail = false, }); @override @@ -76,93 +72,78 @@ class ChatListController extends State StreamSubscription? _intentUriStreamSubscription; - bool get displayNavigationBar => - !FluffyThemes.isColumnMode(context) && - (spaces.isNotEmpty || AppConfig.separateChatTypes); + late ActiveFilter activeFilter; - String? activeSpaceId; + String? _activeSpaceId; + String? get activeSpaceId => _activeSpaceId; + + Future setActiveSpace(String spaceId) async { + await Matrix.of(context).client.getRoomById(spaceId)!.postLoad(); - void resetActiveSpaceId() { setState(() { - selectedRoomIds.clear(); - activeSpaceId = null; + _activeSpaceId = spaceId; }); } - void setActiveSpace(String? spaceId) { - setState(() { - selectedRoomIds.clear(); - activeSpaceId = spaceId; - activeFilter = ActiveFilter.spaces; - }); - } + void clearActiveSpace() => setState(() { + _activeSpaceId = null; + }); - void createNewSpace() async { - final spaceId = await context.push('/rooms/newspace'); - if (spaceId != null) { - setActiveSpace(spaceId); + Future onChatTap(Room room) async { + if (room.membership == Membership.invite) { + final joinResult = await showFutureLoadingDialog( + context: context, + future: () async { + final waitForRoom = room.client.waitForRoomInSync( + room.id, + join: true, + ); + await room.join(); + await waitForRoom; + }, + exceptionContext: ExceptionContext.joinRoom, + ); + if (joinResult.error != null) return; } - } - int get selectedIndex { - switch (activeFilter) { - case ActiveFilter.allChats: - case ActiveFilter.messages: - return 0; - case ActiveFilter.groups: - return 1; - case ActiveFilter.spaces: - return AppConfig.separateChatTypes ? 2 : 1; + if (room.membership == Membership.ban) { + ScaffoldMessenger.of(context).showSnackBar( + SnackBar(content: Text(L10n.of(context).youHaveBeenBannedFromThisChat)), + ); + return; } - } - ActiveFilter getActiveFilterByDestination(int? i) { - switch (i) { - case 1: - if (AppConfig.separateChatTypes) { - return ActiveFilter.groups; - } - return ActiveFilter.spaces; - case 2: - return ActiveFilter.spaces; - case 0: - default: - if (AppConfig.separateChatTypes) { - return ActiveFilter.messages; - } - return ActiveFilter.allChats; + if (room.membership == Membership.leave) { + context.go('/rooms/archive/${room.id}'); + return; } - } - void onDestinationSelected(int? i) { - setState(() { - selectedRoomIds.clear(); - activeFilter = getActiveFilterByDestination(i); - }); - } + if (room.isSpace) { + setActiveSpace(room.id); + return; + } - ActiveFilter activeFilter = AppConfig.separateChatTypes - ? ActiveFilter.messages - : ActiveFilter.allChats; + context.go('/rooms/${room.id}'); + } bool Function(Room) getRoomFilterByActiveFilter(ActiveFilter activeFilter) { switch (activeFilter) { case ActiveFilter.allChats: - return (room) => !room.isSpace; - case ActiveFilter.groups: - return (room) => !room.isSpace && !room.isDirectChat; + return (room) => true; case ActiveFilter.messages: return (room) => !room.isSpace && room.isDirectChat; + case ActiveFilter.groups: + return (room) => !room.isSpace && !room.isDirectChat; + case ActiveFilter.unread: + return (room) => room.isUnreadOrInvited; case ActiveFilter.spaces: - return (r) => r.isSpace; + return (room) => room.isSpace; } } - List get filteredRooms => Matrix.of(context) - .client - .rooms - .where(getRoomFilterByActiveFilter(activeFilter)) - .toList(); + List get filteredRooms => Matrix.of( + context, + ).client.rooms.where(getRoomFilterByActiveFilter(activeFilter)).toList(); bool isSearchMode = false; Future? publicRoomsResponse; @@ -174,30 +155,26 @@ class ChatListController extends State bool isSearching = false; static const String _serverStoreNamespace = 'im.fluffychat.search.server'; - void setServer() async { + Future setServer() async { final newServer = await showTextInputDialog( useRootNavigator: false, - title: L10n.of(context)!.changeTheHomeserver, + title: L10n.of(context).changeTheHomeserver, context: context, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - prefixText: 'https://', - hintText: Matrix.of(context).client.homeserver?.host, - initialText: searchServer, - keyboardType: TextInputType.url, - autocorrect: false, - validator: (server) => server?.contains('.') == true - ? null - : L10n.of(context)!.invalidServerName, - ), - ], + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + prefixText: 'https://', + hintText: Matrix.of(context).client.homeserver?.host, + initialText: searchServer, + keyboardType: TextInputType.url, + autocorrect: false, + validator: (server) => server.contains('.') == true + ? null + : L10n.of(context).invalidServerName, ); if (newServer == null) return; - Matrix.of(context).store.setString(_serverStoreNamespace, newServer.single); + Matrix.of(context).store.setString(_serverStoreNamespace, newServer); setState(() { - searchServer = newServer.single; + searchServer = newServer; }); _coolDown?.cancel(); _coolDown = Timer(const Duration(milliseconds: 500), _search); @@ -206,7 +183,7 @@ class ChatListController extends State final TextEditingController searchController = TextEditingController(); final FocusNode searchFocusNode = FocusNode(); - void _search() async { + Future _search() async { final client = Matrix.of(context).client; if (!isSearching) { setState(() { @@ -225,14 +202,15 @@ class ChatListController extends State if (searchQuery.isValidMatrixId && searchQuery.sigil == '#' && - roomSearchResult.chunk - .any((room) => room.canonicalAlias == searchQuery) == + roomSearchResult.chunk.any( + (room) => room.canonicalAlias == searchQuery, + ) == false) { final response = await client.getRoomIdByAlias(searchQuery); final roomId = response.roomId; if (roomId != null) { roomSearchResult.chunk.add( - PublicRoomsChunk( + PublishedRoomsChunk( name: searchQuery, guestCanJoin: false, numJoinedMembers: 0, @@ -249,13 +227,9 @@ class ChatListController extends State ); } catch (e, s) { Logs().w('Searching has crashed', e, s); - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text( - e.toLocalizedString(context), - ), - ), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); } if (!isSearchMode) return; setState(() { @@ -299,8 +273,6 @@ class ChatListController extends State if (unfocus) searchFocusNode.unfocus(); } - bool isTorBrowser = false; - BoxConstraints? snappingSheetContainerSize; final ScrollController scrollController = ScrollController(); @@ -319,7 +291,7 @@ class ChatListController extends State } } - void editSpace(BuildContext context, String spaceId) async { + Future editSpace(BuildContext context, String spaceId) async { await Matrix.of(context).client.getRoomById(spaceId)!.postLoad(); if (mounted) { context.push('/rooms/$spaceId/details'); @@ -330,50 +302,34 @@ class ChatListController extends State List get spaces => Matrix.of(context).client.rooms.where((r) => r.isSpace).toList(); - final selectedRoomIds = {}; - String? get activeChat => widget.activeChat; - SelectMode get selectMode => Matrix.of(context).shareContent != null - ? SelectMode.share - : selectedRoomIds.isEmpty - ? SelectMode.normal - : SelectMode.select; - - void _processIncomingSharedFiles(List files) { + void _processIncomingSharedMedia(List files) { if (files.isEmpty) return; - final file = File(files.first.path.replaceFirst('file://', '')); - Matrix.of(context).shareContent = { - 'msgtype': 'chat.fluffy.shared_file', - 'file': MatrixFile( - bytes: file.readAsBytesSync(), - name: file.path, - ).detectFileType, - }; - context.go('/rooms'); + showScaffoldDialog( + context: context, + builder: (context) => ShareScaffoldDialog( + items: files.map((file) { + if ({SharedMediaType.text, SharedMediaType.url}.contains(file.type)) { + return TextShareItem(file.path); + } + return FileShareItem( + XFile( + file.path.replaceFirst('file://', ''), + mimeType: file.mimeType, + ), + ); + }).toList(), + ), + ); } - void _processIncomingSharedText(String? text) { - if (text == null) return; - if (text.toLowerCase().startsWith(AppConfig.deepLinkPrefix) || - text.toLowerCase().startsWith(AppConfig.inviteLinkPrefix) || - (text.toLowerCase().startsWith(AppConfig.schemePrefix) && - !RegExp(r'\s').hasMatch(text))) { - return _processIncomingUris(text); - } - Matrix.of(context).shareContent = { - 'msgtype': 'm.text', - 'body': text, - }; - context.go('/rooms'); - } - - void _processIncomingUris(String? text) async { - if (text == null) return; + Future _processIncomingUris(Uri? uri) async { + if (uri == null) return; context.go('/rooms'); WidgetsBinding.instance.addPostFrameCallback((_) { - UrlLauncher(context, text).openMatrixToUrl(); + UrlLauncher(context, uri.toString()).openMatrixToUrl(); }); } @@ -381,55 +337,50 @@ class ChatListController extends State if (!PlatformInfos.isMobile) return; // For sharing images coming from outside the app while the app is in the memory - _intentFileStreamSubscription = ReceiveSharingIntent.getMediaStream() - .listen(_processIncomingSharedFiles, onError: print); + _intentFileStreamSubscription = ReceiveSharingIntent.instance + .getMediaStream() + .listen(_processIncomingSharedMedia, onError: print); // For sharing images coming from outside the app while the app is closed - ReceiveSharingIntent.getInitialMedia().then(_processIncomingSharedFiles); - - // For sharing or opening urls/text coming from outside the app while the app is in the memory - _intentDataStreamSubscription = ReceiveSharingIntent.getTextStream() - .listen(_processIncomingSharedText, onError: print); - - // For sharing or opening urls/text coming from outside the app while the app is closed - ReceiveSharingIntent.getInitialText().then(_processIncomingSharedText); + ReceiveSharingIntent.instance.getInitialMedia().then( + _processIncomingSharedMedia, + ); // For receiving shared Uris - _intentUriStreamSubscription = linkStream.listen(_processIncomingUris); - if (FluffyChatApp.gotInitialLink == false) { - FluffyChatApp.gotInitialLink = true; - getInitialLink().then(_processIncomingUris); - } + _intentUriStreamSubscription = AppLinks().uriLinkStream.listen( + _processIncomingUris, + ); if (PlatformInfos.isAndroid) { final shortcuts = FlutterShortcuts(); shortcuts.initialize().then( - (_) => shortcuts.listenAction((action) { - if (!mounted) return; - UrlLauncher(context, action).launchUrl(); - }), - ); + (_) => shortcuts.listenAction((action) { + if (!mounted) return; + UrlLauncher(context, action).launchUrl(); + }), + ); } } @override void initState() { + activeFilter = ActiveFilter.allChats; _initReceiveSharingIntent(); + _activeSpaceId = widget.activeSpace; scrollController.addListener(_onScroll); _waitForFirstSync(); _hackyWebRTCFixForWeb(); - CallKeepManager().initialize(); - WidgetsBinding.instance.addPostFrameCallback((_) async { + WidgetsBinding.instance.addPostFrameCallback((_) { if (mounted) { - searchServer = - Matrix.of(context).store.getString(_serverStoreNamespace); + searchServer = Matrix.of( + context, + ).store.getString(_serverStoreNamespace); Matrix.of(context).backgroundPush?.setupPush(); + UpdateNotifier.showUpdateSnackBar(context); } }); - _checkTorBrowser(); - super.initState(); } @@ -442,113 +393,295 @@ class ChatListController extends State super.dispose(); } - void toggleSelection(String roomId) { - setState( - () => selectedRoomIds.contains(roomId) - ? selectedRoomIds.remove(roomId) - : selectedRoomIds.add(roomId), - ); - } + Future chatContextAction( + Room room, + BuildContext posContext, [ + Room? space, + ]) async { + final overlay = + Overlay.of(posContext).context.findRenderObject() as RenderBox; - Future toggleUnread() async { - await showFutureLoadingDialog( - context: context, - future: () async { - final markUnread = anySelectedRoomNotMarkedUnread; - final client = Matrix.of(context).client; - for (final roomId in selectedRoomIds) { - final room = client.getRoomById(roomId)!; - if (room.markedUnread == markUnread) continue; - await client.getRoomById(roomId)!.markUnread(markUnread); - } - }, - ); - cancelAction(); - } + final button = posContext.findRenderObject() as RenderBox; - Future toggleFavouriteRoom() async { - await showFutureLoadingDialog( - context: context, - future: () async { - final makeFavorite = anySelectedRoomNotFavorite; - final client = Matrix.of(context).client; - for (final roomId in selectedRoomIds) { - final room = client.getRoomById(roomId)!; - if (room.isFavourite == makeFavorite) continue; - await client.getRoomById(roomId)!.setFavourite(makeFavorite); - } - }, + final position = RelativeRect.fromRect( + Rect.fromPoints( + button.localToGlobal(const Offset(0, -65), ancestor: overlay), + button.localToGlobal( + button.size.bottomRight(Offset.zero) + const Offset(-50, 0), + ancestor: overlay, + ), + ), + Offset.zero & overlay.size, ); - cancelAction(); - } - Future toggleMuted() async { - await showFutureLoadingDialog( - context: context, - future: () async { - final newState = anySelectedRoomNotMuted - ? PushRuleState.mentionsOnly - : PushRuleState.notify; - final client = Matrix.of(context).client; - for (final roomId in selectedRoomIds) { - final room = client.getRoomById(roomId)!; - if (room.pushRuleState == newState) continue; - await client.getRoomById(roomId)!.setPushRuleState(newState); - } - }, + final displayname = room.getLocalizedDisplayname( + MatrixLocals(L10n.of(context)), ); - cancelAction(); - } - Future archiveAction() async { - final confirmed = await showOkCancelAlertDialog( - useRootNavigator: false, + final spacesWithPowerLevels = room.client.rooms + .where( + (space) => + space.isSpace && + space.canChangeStateEvent(EventTypes.SpaceChild) && + !space.spaceChildren.any((c) => c.roomId == room.id), + ) + .toList(); + + final action = await showMenu( + context: posContext, + position: position, + items: [ + PopupMenuItem( + value: ChatContextAction.open, + child: Row( + spacing: 12.0, + children: [ + Avatar(mxContent: room.avatar, name: displayname, size: 24), + ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 200), + child: Text(displayname, maxLines: 1, overflow: .ellipsis), + ), + ], + ), + ), + if (space != null) + PopupMenuItem( + value: ChatContextAction.goToSpace, + child: Row( + mainAxisSize: .min, + children: [ + Avatar( + mxContent: space.avatar, + size: Avatar.defaultSize / 2, + name: space.getLocalizedDisplayname(), + ), + const SizedBox(width: 12), + Expanded( + child: Text( + L10n.of(context).goToSpace(space.getLocalizedDisplayname()), + ), + ), + ], + ), + ), + if (room.membership == Membership.join) ...[ + PopupMenuItem( + value: ChatContextAction.mute, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + room.pushRuleState == PushRuleState.notify + ? Icons.notifications_off_outlined + : Icons.notifications_off, + ), + const SizedBox(width: 12), + Text( + room.pushRuleState == PushRuleState.notify + ? L10n.of(context).muteChat + : L10n.of(context).unmuteChat, + ), + ], + ), + ), + PopupMenuItem( + value: ChatContextAction.markUnread, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + room.markedUnread + ? Icons.mark_as_unread + : Icons.mark_as_unread_outlined, + ), + const SizedBox(width: 12), + Text( + room.markedUnread + ? L10n.of(context).markAsRead + : L10n.of(context).markAsUnread, + ), + ], + ), + ), + PopupMenuItem( + value: ChatContextAction.favorite, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + room.isFavourite ? Icons.push_pin : Icons.push_pin_outlined, + ), + const SizedBox(width: 12), + Text( + room.isFavourite + ? L10n.of(context).unpin + : L10n.of(context).pin, + ), + ], + ), + ), + if (spacesWithPowerLevels.isNotEmpty) + PopupMenuItem( + value: ChatContextAction.addToSpace, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.group_work_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).addToSpace), + ], + ), + ), + ], + PopupMenuItem( + value: ChatContextAction.leave, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + Icons.delete_outlined, + color: Theme.of(context).colorScheme.onErrorContainer, + ), + const SizedBox(width: 12), + Text( + room.membership == Membership.invite + ? L10n.of(context).delete + : L10n.of(context).leave, + style: TextStyle( + color: Theme.of(context).colorScheme.onErrorContainer, + ), + ), + ], + ), + ), + if (room.membership == Membership.invite) + PopupMenuItem( + value: ChatContextAction.block, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + Icons.block_outlined, + color: Theme.of(context).colorScheme.onErrorContainer, + ), + const SizedBox(width: 12), + Text( + L10n.of(context).block, + style: TextStyle( + color: Theme.of(context).colorScheme.onErrorContainer, + ), + ), + ], + ), + ), + ], + ); + + if (action == null) return; + if (!mounted) return; + + switch (action) { + case ChatContextAction.open: + onChatTap(room); + return; + case ChatContextAction.goToSpace: + setActiveSpace(space!.id); + return; + case ChatContextAction.favorite: + await showFutureLoadingDialog( context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.cancel, - message: L10n.of(context)!.archiveRoomDescription, - ) == - OkCancelResult.ok; - if (!confirmed) return; - await showFutureLoadingDialog( - context: context, - future: () => _archiveSelectedRooms(), - ); - setState(() {}); + future: () => room.setFavourite(!room.isFavourite), + ); + return; + case ChatContextAction.markUnread: + await showFutureLoadingDialog( + context: context, + future: () => room.markUnread(!room.markedUnread), + ); + return; + case ChatContextAction.mute: + await showFutureLoadingDialog( + context: context, + future: () => room.setPushRuleState( + room.pushRuleState == PushRuleState.notify + ? PushRuleState.mentionsOnly + : PushRuleState.notify, + ), + ); + return; + case ChatContextAction.block: + final inviteEvent = room.getState( + EventTypes.RoomMember, + room.client.userID!, + ); + context.go( + '/rooms/settings/security/ignorelist', + extra: inviteEvent?.senderId, + ); + case ChatContextAction.leave: + final confirmed = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + message: L10n.of(context).archiveRoomDescription, + okLabel: L10n.of(context).leave, + cancelLabel: L10n.of(context).cancel, + isDestructive: true, + ); + if (confirmed == OkCancelResult.cancel) return; + if (!mounted) return; + + await showFutureLoadingDialog(context: context, future: room.leave); + + return; + case ChatContextAction.addToSpace: + final space = await showModalActionPopup( + context: context, + title: L10n.of(context).space, + actions: spacesWithPowerLevels + .map( + (space) => AdaptiveModalAction( + value: space, + label: space.getLocalizedDisplayname( + MatrixLocals(L10n.of(context)), + ), + ), + ) + .toList(), + ); + if (space == null) return; + await showFutureLoadingDialog( + context: context, + future: () => space.setSpaceChild(room.id), + ); + } } - void dismissStatusList() async { + Future dismissStatusList() async { final result = await showOkCancelAlertDialog( - title: L10n.of(context)!.hidePresences, + title: L10n.of(context).hidePresences, context: context, ); if (result == OkCancelResult.ok) { - await Matrix.of(context).store.setBool(SettingKeys.showPresences, false); - AppConfig.showPresences = false; + AppSettings.showPresences.setItem(false); setState(() {}); } } - void setStatus() async { + Future setStatus() async { final client = Matrix.of(context).client; final currentPresence = await client.fetchCurrentPresence(client.userID!); final input = await showTextInputDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.setStatus, - message: L10n.of(context)!.leaveEmptyToClearStatus, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - hintText: L10n.of(context)!.statusExampleMessage, - maxLines: 6, - minLines: 1, - maxLength: 255, - initialText: currentPresence.statusMsg, - ), - ], + title: L10n.of(context).setStatus, + message: L10n.of(context).leaveEmptyToClearStatus, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + hintText: L10n.of(context).statusExampleMessage, + maxLines: 6, + minLines: 1, + maxLength: 255, + initialText: currentPresence.statusMsg, ); if (input == null) return; if (!mounted) return; @@ -557,122 +690,74 @@ class ChatListController extends State future: () => client.setPresence( client.userID!, PresenceType.online, - statusMsg: input.single, + statusMsg: input, ), ); } - Future _archiveSelectedRooms() async { - final client = Matrix.of(context).client; - while (selectedRoomIds.isNotEmpty) { - final roomId = selectedRoomIds.first; - try { - await client.getRoomById(roomId)!.leave(); - } finally { - toggleSelection(roomId); - } - } - } - - Future addToSpace() async { - final selectedSpace = await showConfirmationDialog( - context: context, - title: L10n.of(context)!.addToSpace, - message: L10n.of(context)!.addToSpaceDescription, - fullyCapitalizedForMaterial: false, - actions: Matrix.of(context) - .client - .rooms - .where((r) => r.isSpace) - .map( - (space) => AlertDialogAction( - key: space.id, - label: space - .getLocalizedDisplayname(MatrixLocals(L10n.of(context)!)), - ), - ) - .toList(), - ); - if (selectedSpace == null) return; - final result = await showFutureLoadingDialog( - context: context, - future: () async { - final space = Matrix.of(context).client.getRoomById(selectedSpace)!; - if (space.canSendDefaultStates) { - for (final roomId in selectedRoomIds) { - await space.setSpaceChild(roomId); - } - } - }, - ); - if (result.error == null) { - if (!mounted) return; - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text(L10n.of(context)!.chatHasBeenAddedToThisSpace), - ), - ); - } - - setState(() => selectedRoomIds.clear()); - } - - bool get anySelectedRoomNotMarkedUnread => selectedRoomIds.any( - (roomId) => - !Matrix.of(context).client.getRoomById(roomId)!.markedUnread, - ); - - bool get anySelectedRoomNotFavorite => selectedRoomIds.any( - (roomId) => !Matrix.of(context).client.getRoomById(roomId)!.isFavourite, - ); - - bool get anySelectedRoomNotMuted => selectedRoomIds.any( - (roomId) => - Matrix.of(context).client.getRoomById(roomId)!.pushRuleState == - PushRuleState.notify, - ); - bool waitForFirstSync = false; Future _waitForFirstSync() async { + final router = GoRouter.of(context); final client = Matrix.of(context).client; await client.roomsLoading; await client.accountDataLoading; await client.userDeviceKeysLoading; if (client.prevBatch == null) { - await client.onSync.stream.first; + await client.onSyncStatus.stream.firstWhere( + (status) => status.status == SyncStatus.finished, + ); - // Display first login bootstrap if enabled - if (client.encryption?.keyManager.enabled == true) { - if (await client.encryption?.keyManager.isCached() == false || - await client.encryption?.crossSigning.isCached() == false || - client.isUnknownSession && !mounted) { - await BootstrapDialog(client: client).show(context); - } - } + if (!mounted) return; + setState(() { + waitForFirstSync = true; + }); } if (!mounted) return; setState(() { waitForFirstSync = true; }); + + if (client.userDeviceKeys[client.userID!]?.deviceKeys.values.any( + (device) => !device.verified && !device.blocked, + ) ?? + false) { + late final ScaffoldFeatureController controller; + final theme = Theme.of(context); + controller = ScaffoldMessenger.of(context).showSnackBar( + SnackBar( + duration: const Duration(seconds: 15), + showCloseIcon: true, + backgroundColor: theme.colorScheme.errorContainer, + closeIconColor: theme.colorScheme.onErrorContainer, + content: Text( + L10n.of(context).oneOfYourDevicesIsNotVerified, + style: TextStyle(color: theme.colorScheme.onErrorContainer), + ), + action: SnackBarAction( + onPressed: () { + controller.close(); + router.go('/rooms/settings/devices'); + }, + textColor: theme.colorScheme.onErrorContainer, + label: L10n.of(context).settings, + ), + ), + ); + } } - void cancelAction() { - if (selectMode == SelectMode.share) { - setState(() => Matrix.of(context).shareContent = null); - } else { - setState(() => selectedRoomIds.clear()); - } + void setActiveFilter(ActiveFilter filter) { + setState(() { + activeFilter = filter; + }); } void setActiveClient(Client client) { context.go('/rooms'); setState(() { - activeFilter = AppConfig.separateChatTypes - ? ActiveFilter.messages - : ActiveFilter.allChats; - activeSpaceId = null; - selectedRoomIds.clear(); + activeFilter = ActiveFilter.allChats; + _activeSpaceId = null; Matrix.of(context).setActiveClient(client); }); _clientStream.add(client); @@ -681,34 +766,39 @@ class ChatListController extends State void setActiveBundle(String bundle) { context.go('/rooms'); setState(() { - selectedRoomIds.clear(); + _activeSpaceId = null; Matrix.of(context).activeBundle = bundle; - if (!Matrix.of(context) - .currentBundle! - .any((client) => client == Matrix.of(context).client)) { - Matrix.of(context) - .setActiveClient(Matrix.of(context).currentBundle!.first); + if (!Matrix.of( + context, + ).currentBundle!.any((client) => client == Matrix.of(context).client)) { + Matrix.of( + context, + ).setActiveClient(Matrix.of(context).currentBundle!.first); } }); } - void editBundlesForAccount(String? userId, String? activeBundle) async { - final l10n = L10n.of(context)!; - final client = Matrix.of(context) - .widget - .clients[Matrix.of(context).getClientIndexByMatrixId(userId!)]; - final action = await showConfirmationDialog( + Future editBundlesForAccount( + String? userId, + String? activeBundle, + ) async { + final l10n = L10n.of(context); + final client = Matrix.of( + context, + ).widget.clients[Matrix.of(context).getClientIndexByMatrixId(userId!)]; + final action = await showModalActionPopup( context: context, - title: L10n.of(context)!.editBundlesForAccount, + title: L10n.of(context).editBundlesForAccount, + cancelLabel: L10n.of(context).cancel, actions: [ - AlertDialogAction( - key: EditBundleAction.addToBundle, - label: L10n.of(context)!.addToBundle, + AdaptiveModalAction( + value: EditBundleAction.addToBundle, + label: L10n.of(context).addToBundle, ), if (activeBundle != client.userID) - AlertDialogAction( - key: EditBundleAction.removeFromBundle, - label: L10n.of(context)!.removeFromBundle, + AdaptiveModalAction( + value: EditBundleAction.removeFromBundle, + label: L10n.of(context).removeFromBundle, ), ], ); @@ -718,12 +808,12 @@ class ChatListController extends State final bundle = await showTextInputDialog( context: context, title: l10n.bundleName, - textFields: [DialogTextField(hintText: l10n.bundleName)], + hintText: l10n.bundleName, ); - if (bundle == null || bundle.isEmpty || bundle.single.isEmpty) return; + if (bundle == null || bundle.isEmpty || bundle.isEmpty) return; await showFutureLoadingDialog( context: context, - future: () => client.setAccountBundle(bundle.single), + future: () => client.setAccountBundle(bundle), ); break; case EditBundleAction.removeFromBundle: @@ -740,10 +830,9 @@ class ChatListController extends State String? get secureActiveBundle { if (Matrix.of(context).activeBundle == null || - !Matrix.of(context) - .accountBundles - .keys - .contains(Matrix.of(context).activeBundle)) { + !Matrix.of( + context, + ).accountBundles.keys.contains(Matrix.of(context).activeBundle)) { return Matrix.of(context).accountBundles.keys.first; } return Matrix.of(context).activeBundle; @@ -764,13 +853,18 @@ class ChatListController extends State ChatList.contextForVoip = context; } - Future _checkTorBrowser() async { - if (!kIsWeb) return; - final isTor = await TorBrowserDetector.isTorBrowser; - isTorBrowser = isTor; - } - - Future dehydrate() => Matrix.of(context).dehydrateAction(); + Future dehydrate() => Matrix.of(context).dehydrateAction(context); } enum EditBundleAction { addToBundle, removeFromBundle } + +enum ChatContextAction { + open, + goToSpace, + favorite, + markUnread, + mute, + leave, + addToSpace, + block, +} diff --git a/lib/pages/chat_list/chat_list_body.dart b/lib/pages/chat_list/chat_list_body.dart index eeb6bb656..ba1fee31d 100644 --- a/lib/pages/chat_list/chat_list_body.dart +++ b/lib/pages/chat_list/chat_list_body.dart @@ -1,24 +1,21 @@ import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; -import 'package:animations/animations.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_list/chat_list.dart'; import 'package:fluffychat/pages/chat_list/chat_list_item.dart'; +import 'package:fluffychat/pages/chat_list/dummy_chat_list_item.dart'; import 'package:fluffychat/pages/chat_list/search_title.dart'; import 'package:fluffychat/pages/chat_list/space_view.dart'; import 'package:fluffychat/pages/chat_list/status_msg_list.dart'; -import 'package:fluffychat/pages/chat_list/utils/on_chat_tap.dart'; -import 'package:fluffychat/pages/user_bottom_sheet/user_bottom_sheet.dart'; -import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/stream_extension.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/public_room_dialog.dart'; import 'package:fluffychat/widgets/avatar.dart'; -import 'package:fluffychat/widgets/public_room_bottom_sheet.dart'; import '../../config/themes.dart'; -import '../../widgets/connection_status_header.dart'; +import '../../widgets/adaptive_dialogs/user_dialog.dart'; import '../../widgets/matrix.dart'; import 'chat_list_header.dart'; @@ -29,6 +26,29 @@ class ChatListViewBody extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + + final client = Matrix.of(context).client; + final activeSpace = controller.activeSpaceId; + if (activeSpace != null) { + return SpaceView( + key: ValueKey(activeSpace), + spaceId: activeSpace, + onBack: controller.clearActiveSpace, + onChatTab: controller.onChatTap, + activeChat: controller.activeChat, + ); + } + final spaces = client.rooms.where((r) => r.isSpace); + final spaceDelegateCandidates = {}; + for (final space in spaces) { + for (final spaceChild in space.spaceChildren) { + final roomId = spaceChild.roomId; + if (roomId == null) continue; + spaceDelegateCandidates[roomId] = space; + } + } + final publicRooms = controller.roomSearchResult?.chunk .where((room) => room.roomType != 'm.space') .toList(); @@ -36,242 +56,204 @@ class ChatListViewBody extends StatelessWidget { .where((room) => room.roomType == 'm.space') .toList(); final userSearchResult = controller.userSearchResult; - final client = Matrix.of(context).client; const dummyChatCount = 4; - final titleColor = - Theme.of(context).textTheme.bodyLarge!.color!.withAlpha(100); - final subtitleColor = - Theme.of(context).textTheme.bodyLarge!.color!.withAlpha(50); final filter = controller.searchController.text.toLowerCase(); - return PageTransitionSwitcher( - transitionBuilder: ( - Widget child, - Animation primaryAnimation, - Animation secondaryAnimation, - ) { - return SharedAxisTransition( - animation: primaryAnimation, - secondaryAnimation: secondaryAnimation, - transitionType: SharedAxisTransitionType.vertical, - fillColor: Theme.of(context).scaffoldBackgroundColor, - child: child, - ); - }, - child: StreamBuilder( - key: ValueKey( - client.userID.toString() + - controller.activeFilter.toString() + - controller.activeSpaceId.toString(), - ), - stream: client.onSync.stream - .where((s) => s.hasRoomUpdate) - .rateLimit(const Duration(seconds: 1)), - builder: (context, _) { - if (controller.activeFilter == ActiveFilter.spaces) { - return SpaceView( - controller, - scrollController: controller.scrollController, - key: Key(controller.activeSpaceId ?? 'Spaces'), - ); - } - final rooms = controller.filteredRooms; - return SafeArea( - child: CustomScrollView( - controller: controller.scrollController, - slivers: [ - ChatListHeader(controller: controller), - SliverList( - delegate: SliverChildListDelegate( - [ - if (controller.isSearchMode) ...[ - SearchTitle( - title: L10n.of(context)!.publicRooms, - icon: const Icon(Icons.explore_outlined), - ), - PublicRoomsHorizontalList(publicRooms: publicRooms), - SearchTitle( - title: L10n.of(context)!.publicSpaces, - icon: const Icon(Icons.workspaces_outlined), - ), - PublicRoomsHorizontalList(publicRooms: publicSpaces), - SearchTitle( - title: L10n.of(context)!.users, - icon: const Icon(Icons.group_outlined), - ), - AnimatedContainer( - clipBehavior: Clip.hardEdge, - decoration: const BoxDecoration(), - height: userSearchResult == null || - userSearchResult.results.isEmpty - ? 0 - : 106, - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - child: userSearchResult == null - ? null - : ListView.builder( - scrollDirection: Axis.horizontal, - itemCount: userSearchResult.results.length, - itemBuilder: (context, i) => _SearchItem( - title: userSearchResult - .results[i].displayName ?? - userSearchResult - .results[i].userId.localpart ?? - L10n.of(context)!.unknownDevice, - avatar: - userSearchResult.results[i].avatarUrl, - onPressed: () => showAdaptiveBottomSheet( - context: context, - builder: (c) => UserBottomSheet( - profile: userSearchResult.results[i], - outerContext: context, + return StreamBuilder( + key: ValueKey(client.userID.toString()), + stream: client.onSync.stream + .where((s) => s.hasRoomUpdate) + .rateLimit(const Duration(seconds: 1)), + builder: (context, _) { + final rooms = controller.filteredRooms; + + return SafeArea( + child: CustomScrollView( + controller: controller.scrollController, + slivers: [ + ChatListHeader(controller: controller), + SliverList( + delegate: SliverChildListDelegate([ + if (controller.isSearchMode) ...[ + SearchTitle( + title: L10n.of(context).publicRooms, + icon: const Icon(Icons.explore_outlined), + ), + PublicRoomsHorizontalList(publicRooms: publicRooms), + SearchTitle( + title: L10n.of(context).publicSpaces, + icon: const Icon(Icons.workspaces_outlined), + ), + PublicRoomsHorizontalList(publicRooms: publicSpaces), + SearchTitle( + title: L10n.of(context).users, + icon: const Icon(Icons.group_outlined), + ), + AnimatedContainer( + clipBehavior: Clip.hardEdge, + decoration: const BoxDecoration(), + height: + userSearchResult == null || + userSearchResult.results.isEmpty + ? 0 + : 106, + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: userSearchResult == null + ? null + : ListView.builder( + scrollDirection: Axis.horizontal, + itemCount: userSearchResult.results.length, + itemBuilder: (context, i) => _SearchItem( + title: + userSearchResult.results[i].displayName ?? + userSearchResult + .results[i] + .userId + .localpart ?? + L10n.of(context).unknownDevice, + avatar: userSearchResult.results[i].avatarUrl, + onPressed: () => UserDialog.show( + context: context, + profile: userSearchResult.results[i], + ), + ), + ), + ), + ], + if (!controller.isSearchMode && + AppSettings.showPresences.value) + GestureDetector( + onLongPress: controller.dismissStatusList, + child: StatusMessageList( + onStatusEdit: controller.setStatus, + ), + ), + if (client.rooms.isNotEmpty && !controller.isSearchMode) + SizedBox( + height: 64, + child: ListView( + padding: const EdgeInsets.all(12.0), + shrinkWrap: true, + scrollDirection: Axis.horizontal, + children: + [ + ActiveFilter.allChats, + + if (spaces.isNotEmpty && + !AppSettings + .displayNavigationRail + .value && + !FluffyThemes.isColumnMode(context)) + ActiveFilter.spaces, + ActiveFilter.unread, + ActiveFilter.groups, + ActiveFilter.messages, + ] + .map( + (filter) => Padding( + padding: const EdgeInsets.symmetric( + horizontal: 4.0, + ), + child: FilterChip( + selected: + filter == controller.activeFilter, + onSelected: (_) => + controller.setActiveFilter(filter), + label: Text( + filter.toLocalizedString(context), ), ), ), - ), - ), - ], - if (!controller.isSearchMode && - controller.activeFilter != ActiveFilter.groups && - AppConfig.showPresences) - GestureDetector( - onLongPress: () => controller.dismissStatusList(), - child: StatusMessageList( - onStatusEdit: controller.setStatus, - ), - ), - const ConnectionStatusHeader(), - AnimatedContainer( - height: controller.isTorBrowser ? 64 : 0, - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - clipBehavior: Clip.hardEdge, - decoration: const BoxDecoration(), - child: Material( - color: Theme.of(context).colorScheme.surface, - child: ListTile( - leading: const Icon(Icons.vpn_key), - title: Text(L10n.of(context)!.dehydrateTor), - subtitle: Text(L10n.of(context)!.dehydrateTorLong), - trailing: const Icon(Icons.chevron_right_outlined), - onTap: controller.dehydrate, - ), - ), + ) + .toList(), ), - if (controller.isSearchMode) - SearchTitle( - title: L10n.of(context)!.chats, - icon: const Icon(Icons.forum_outlined), + ), + if (controller.isSearchMode) + SearchTitle( + title: L10n.of(context).chats, + icon: const Icon(Icons.forum_outlined), + ), + if (client.prevBatch != null && + rooms.isEmpty && + !controller.isSearchMode) ...[ + Column( + mainAxisAlignment: .center, + children: [ + Stack( + alignment: Alignment.center, + children: [ + const Column( + mainAxisSize: .min, + children: [ + DummyChatListItem(opacity: 0.5, animate: false), + DummyChatListItem(opacity: 0.3, animate: false), + ], + ), + Icon( + CupertinoIcons.chat_bubble_text_fill, + size: 128, + color: theme.colorScheme.secondary, + ), + ], ), - if (client.prevBatch != null && - rooms.isEmpty && - !controller.isSearchMode) ...[ Padding( - padding: const EdgeInsets.all(32.0), - child: Icon( - CupertinoIcons.chat_bubble_2, - size: 128, - color: - Theme.of(context).colorScheme.onInverseSurface, + padding: const EdgeInsets.all(16.0), + child: Text( + client.rooms.isEmpty + ? L10n.of(context).noChatsFoundHere + : L10n.of(context).noMoreChatsFound, + textAlign: TextAlign.center, + style: TextStyle( + fontSize: 18, + color: theme.colorScheme.secondary, + ), ), ), ], - ], + ), + ], + ]), + ), + if (client.prevBatch == null) + SliverList( + delegate: SliverChildBuilderDelegate( + (context, i) => DummyChatListItem( + opacity: (dummyChatCount - i) / dummyChatCount, + animate: true, + ), + childCount: dummyChatCount, ), ), - if (client.prevBatch == null) - SliverList( - delegate: SliverChildBuilderDelegate( - (context, i) => Opacity( - opacity: (dummyChatCount - i) / dummyChatCount, - child: ListTile( - leading: CircleAvatar( - backgroundColor: titleColor, - child: CircularProgressIndicator( - strokeWidth: 1, - color: - Theme.of(context).textTheme.bodyLarge!.color, - ), - ), - title: Row( - children: [ - Expanded( - child: Container( - height: 14, - decoration: BoxDecoration( - color: titleColor, - borderRadius: BorderRadius.circular(3), - ), - ), - ), - const SizedBox(width: 36), - Container( - height: 14, - width: 14, - decoration: BoxDecoration( - color: subtitleColor, - borderRadius: BorderRadius.circular(14), - ), - ), - const SizedBox(width: 12), - Container( - height: 14, - width: 14, - decoration: BoxDecoration( - color: subtitleColor, - borderRadius: BorderRadius.circular(14), - ), - ), - ], - ), - subtitle: Container( - decoration: BoxDecoration( - color: subtitleColor, - borderRadius: BorderRadius.circular(3), - ), - height: 12, - margin: const EdgeInsets.only(right: 22), - ), - ), - ), - childCount: dummyChatCount, - ), - ), - if (client.prevBatch != null) - SliverList.builder( - itemCount: rooms.length, - itemBuilder: (BuildContext context, int i) { - return ChatListItem( - rooms[i], - key: Key('chat_list_item_${rooms[i].id}'), - filter: filter, - selected: - controller.selectedRoomIds.contains(rooms[i].id), - onTap: controller.selectMode == SelectMode.select - ? () => controller.toggleSelection(rooms[i].id) - : () => onChatTap(rooms[i], context), - onLongPress: () => - controller.toggleSelection(rooms[i].id), - activeChat: controller.activeChat == rooms[i].id, - ); - }, - ), - ], - ), - ); - }, - ), + if (client.prevBatch != null) + SliverList.builder( + itemCount: rooms.length, + itemBuilder: (BuildContext context, int i) { + final room = rooms[i]; + final space = spaceDelegateCandidates[room.id]; + return ChatListItem( + room, + space: space, + key: Key('chat_list_item_${room.id}'), + filter: filter, + onTap: () => controller.onChatTap(room), + onLongPress: (context) => + controller.chatContextAction(room, context, space), + activeChat: controller.activeChat == room.id, + ); + }, + ), + ], + ), + ); + }, ); } } class PublicRoomsHorizontalList extends StatelessWidget { - const PublicRoomsHorizontalList({ - super.key, - required this.publicRooms, - }); + const PublicRoomsHorizontalList({super.key, required this.publicRooms}); - final List? publicRooms; + final List? publicRooms; @override Widget build(BuildContext context) { @@ -288,16 +270,16 @@ class PublicRoomsHorizontalList extends StatelessWidget { scrollDirection: Axis.horizontal, itemCount: publicRooms.length, itemBuilder: (context, i) => _SearchItem( - title: publicRooms[i].name ?? + title: + publicRooms[i].name ?? publicRooms[i].canonicalAlias?.localpart ?? - L10n.of(context)!.group, + L10n.of(context).group, avatar: publicRooms[i].avatarUrl, - onPressed: () => showAdaptiveBottomSheet( + onPressed: () => showAdaptiveDialog( context: context, - builder: (c) => PublicRoomBottomSheet( + builder: (c) => PublicRoomDialog( roomAlias: publicRooms[i].canonicalAlias ?? publicRooms[i].roomId, - outerContext: context, chunk: publicRooms[i], ), ), @@ -320,31 +302,26 @@ class _SearchItem extends StatelessWidget { @override Widget build(BuildContext context) => InkWell( - onTap: onPressed, - child: SizedBox( - width: 84, - child: Column( - mainAxisSize: MainAxisSize.min, - children: [ - const SizedBox(height: 8), - Avatar( - mxContent: avatar, - name: title, - ), - Padding( - padding: const EdgeInsets.all(8.0), - child: Text( - title, - maxLines: 2, - textAlign: TextAlign.center, - overflow: TextOverflow.ellipsis, - style: const TextStyle( - fontSize: 12, - ), - ), - ), - ], + onTap: onPressed, + child: SizedBox( + width: 84, + child: Column( + mainAxisSize: .min, + children: [ + const SizedBox(height: 8), + Avatar(mxContent: avatar, name: title), + Padding( + padding: const EdgeInsets.all(8.0), + child: Text( + title, + maxLines: 2, + textAlign: TextAlign.center, + overflow: TextOverflow.ellipsis, + style: const TextStyle(fontSize: 12), + ), ), - ), - ); + ], + ), + ), + ); } diff --git a/lib/pages/chat_list/chat_list_header.dart b/lib/pages/chat_list/chat_list_header.dart index 5e76e780f..fa1b9ff1e 100644 --- a/lib/pages/chat_list/chat_list_header.dart +++ b/lib/pages/chat_list/chat_list_header.dart @@ -1,10 +1,12 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_list/chat_list.dart'; import 'package:fluffychat/pages/chat_list/client_chooser_button.dart'; +import 'package:fluffychat/utils/sync_status_localization.dart'; import '../../widgets/matrix.dart'; class ChatListHeader extends StatelessWidget implements PreferredSizeWidget { @@ -19,164 +21,107 @@ class ChatListHeader extends StatelessWidget implements PreferredSizeWidget { @override Widget build(BuildContext context) { - final selectMode = controller.selectMode; + final theme = Theme.of(context); + final client = Matrix.of(context).client; return SliverAppBar( floating: true, toolbarHeight: 72, - pinned: - FluffyThemes.isColumnMode(context) || selectMode != SelectMode.normal, - scrolledUnderElevation: selectMode == SelectMode.normal ? 0 : null, - backgroundColor: - selectMode == SelectMode.normal ? Colors.transparent : null, + pinned: FluffyThemes.isColumnMode(context), + scrolledUnderElevation: 0, + backgroundColor: Colors.transparent, automaticallyImplyLeading: false, - leading: selectMode == SelectMode.normal - ? null - : IconButton( - tooltip: L10n.of(context)!.cancel, - icon: const Icon(Icons.close_outlined), - onPressed: controller.cancelAction, - color: Theme.of(context).colorScheme.primary, - ), - title: selectMode == SelectMode.share - ? Text( - L10n.of(context)!.share, - key: const ValueKey(SelectMode.share), - ) - : selectMode == SelectMode.select - ? Text( - controller.selectedRoomIds.length.toString(), - key: const ValueKey(SelectMode.select), - ) - : TextField( - controller: controller.searchController, - focusNode: controller.searchFocusNode, - textInputAction: TextInputAction.search, - onChanged: (text) => controller.onSearchEnter( - text, - globalSearch: globalSearch, - ), - decoration: InputDecoration( - fillColor: Theme.of(context).colorScheme.secondaryContainer, - border: OutlineInputBorder( - borderSide: BorderSide.none, - borderRadius: BorderRadius.circular(99), - ), - contentPadding: EdgeInsets.zero, - hintText: L10n.of(context)!.searchChatsRooms, - hintStyle: TextStyle( - color: Theme.of(context).colorScheme.onPrimaryContainer, - fontWeight: FontWeight.normal, - ), - floatingLabelBehavior: FloatingLabelBehavior.never, - prefixIcon: controller.isSearchMode + title: StreamBuilder( + stream: client.onSyncStatus.stream, + builder: (context, snapshot) { + final status = + client.onSyncStatus.value ?? + const SyncStatusUpdate(SyncStatus.waitingForResponse); + final hide = + client.onSync.value != null && + status.status != SyncStatus.error && + client.prevBatch != null; + return TextField( + controller: controller.searchController, + focusNode: controller.searchFocusNode, + textInputAction: TextInputAction.search, + onChanged: (text) => + controller.onSearchEnter(text, globalSearch: globalSearch), + decoration: InputDecoration( + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + contentPadding: EdgeInsets.zero, + hintText: hide + ? L10n.of(context).searchChatsRooms + : status.calcLocalizedString(context), + hintStyle: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontWeight: FontWeight.normal, + ), + prefixIcon: hide + ? controller.isSearchMode ? IconButton( - tooltip: L10n.of(context)!.cancel, + tooltip: L10n.of(context).cancel, icon: const Icon(Icons.close_outlined), onPressed: controller.cancelSearch, - color: Theme.of(context) - .colorScheme - .onPrimaryContainer, + color: theme.colorScheme.onPrimaryContainer, ) : IconButton( onPressed: controller.startSearch, icon: Icon( Icons.search_outlined, - color: Theme.of(context) - .colorScheme - .onPrimaryContainer, + color: theme.colorScheme.onPrimaryContainer, ), - ), - suffixIcon: controller.isSearchMode && globalSearch - ? controller.isSearching - ? const Padding( - padding: EdgeInsets.symmetric( - vertical: 10.0, - horizontal: 12, - ), - child: SizedBox.square( - dimension: 24, - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, - ), - ), - ) - : TextButton.icon( - onPressed: controller.setServer, - style: TextButton.styleFrom( - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(99), - ), - textStyle: const TextStyle(fontSize: 12), - ), - icon: const Icon(Icons.edit_outlined, size: 16), - label: Text( - controller.searchServer ?? - Matrix.of(context) - .client - .homeserver! - .host, - maxLines: 2, - ), - ) - : SizedBox( - width: 0, - child: ClientChooserButton(controller), - ), - ), - ), - actions: selectMode == SelectMode.share - ? [ - Padding( - padding: const EdgeInsets.symmetric( - horizontal: 16.0, - vertical: 8.0, - ), - child: ClientChooserButton(controller), - ), - ] - : selectMode == SelectMode.select - ? [ - if (controller.spaces.isNotEmpty) - IconButton( - tooltip: L10n.of(context)!.addToSpace, - icon: const Icon(Icons.workspaces_outlined), - onPressed: controller.addToSpace, + ) + : Container( + margin: const EdgeInsets.all(12), + width: 8, + height: 8, + child: Center( + child: CircularProgressIndicator.adaptive( + strokeWidth: 2, + value: status.progress, + ), + ), ), - IconButton( - tooltip: L10n.of(context)!.toggleUnread, - icon: Icon( - controller.anySelectedRoomNotMarkedUnread - ? Icons.mark_chat_unread_outlined - : Icons.mark_chat_read_outlined, - ), - onPressed: controller.toggleUnread, - ), - IconButton( - tooltip: L10n.of(context)!.toggleFavorite, - icon: Icon( - controller.anySelectedRoomNotFavorite - ? Icons.push_pin - : Icons.push_pin_outlined, - ), - onPressed: controller.toggleFavouriteRoom, - ), - IconButton( - icon: Icon( - controller.anySelectedRoomNotMuted - ? Icons.notifications_off_outlined - : Icons.notifications_outlined, - ), - tooltip: L10n.of(context)!.toggleMuted, - onPressed: controller.toggleMuted, - ), - IconButton( - icon: const Icon(Icons.delete_outlined), - tooltip: L10n.of(context)!.archive, - onPressed: controller.archiveAction, - ), - ] - : null, + suffixIcon: controller.isSearchMode && globalSearch + ? controller.isSearching + ? const Padding( + padding: EdgeInsets.symmetric( + vertical: 10.0, + horizontal: 12, + ), + child: SizedBox.square( + dimension: 24, + child: CircularProgressIndicator.adaptive( + strokeWidth: 2, + ), + ), + ) + : TextButton.icon( + onPressed: controller.setServer, + style: TextButton.styleFrom( + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular(99), + ), + textStyle: const TextStyle(fontSize: 12), + ), + icon: const Icon(Icons.edit_outlined, size: 16), + label: Text( + controller.searchServer ?? + Matrix.of(context).client.homeserver!.host, + maxLines: 2, + ), + ) + : SizedBox(width: 0, child: ClientChooserButton(controller)), + ), + ); + }, + ), ); } diff --git a/lib/pages/chat_list/chat_list_item.dart b/lib/pages/chat_list/chat_list_item.dart index 965c73917..b30828127 100644 --- a/lib/pages/chat_list/chat_list_item.dart +++ b/lib/pages/chat_list/chat_list_item.dart @@ -1,25 +1,24 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat_list/unread_bubble.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import 'package:fluffychat/utils/room_status_extension.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/hover_builder.dart'; import '../../config/themes.dart'; import '../../utils/date_time_extension.dart'; import '../../widgets/avatar.dart'; -enum ArchivedRoomAction { delete, rejoin } - class ChatListItem extends StatelessWidget { final Room room; + final Room? space; final bool activeChat; - final bool selected; - final void Function()? onLongPress; + final void Function(BuildContext context)? onLongPress; final void Function()? onForget; final void Function() onTap; final String? filter; @@ -27,126 +26,155 @@ class ChatListItem extends StatelessWidget { const ChatListItem( this.room, { this.activeChat = false, - this.selected = false, required this.onTap, this.onLongPress, this.onForget, this.filter, + this.space, super.key, }); - Future archiveAction(BuildContext context) async { - { - if ([Membership.leave, Membership.ban].contains(room.membership)) { - await showFutureLoadingDialog( - context: context, - future: () => room.forget(), - ); - return; - } - final confirmed = await showOkCancelAlertDialog( - useRootNavigator: false, - context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.no, - message: L10n.of(context)!.archiveRoomDescription, - ); - if (confirmed == OkCancelResult.cancel) return; - await showFutureLoadingDialog( - context: context, - future: () => room.leave(), - ); - return; - } - } - @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final isMuted = room.pushRuleState != PushRuleState.notify; final typingText = room.getLocalizedTypingText(context); final lastEvent = room.lastEvent; final ownMessage = lastEvent?.senderId == room.client.userID; - final unread = room.isUnread || room.membership == Membership.invite; - final theme = Theme.of(context); final directChatMatrixId = room.directChatMatrixID; final isDirectChat = directChatMatrixId != null; - final unreadBubbleSize = unread || room.hasNewMessages - ? room.notificationCount > 0 - ? 20.0 - : 14.0 - : 0.0; final hasNotifications = room.notificationCount > 0; - final backgroundColor = selected - ? theme.colorScheme.primaryContainer - : activeChat - ? theme.colorScheme.secondaryContainer - : null; + final backgroundColor = activeChat + ? theme.colorScheme.secondaryContainer + : null; final displayname = room.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), ); final filter = this.filter; if (filter != null && !displayname.toLowerCase().contains(filter)) { return const SizedBox.shrink(); } - final needLastEventSender = lastEvent == null - ? false - : room.getState(EventTypes.RoomMember, lastEvent.senderId) == null; + final needLastEventSender = + lastEvent != null && + room.getState(EventTypes.RoomMember, lastEvent.senderId) == null; + final space = this.space; return Padding( - padding: const EdgeInsets.symmetric( - horizontal: 8, - vertical: 1, - ), + padding: const EdgeInsets.symmetric(horizontal: 8, vertical: 1), child: Material( borderRadius: BorderRadius.circular(AppConfig.borderRadius), clipBehavior: Clip.hardEdge, color: backgroundColor, child: FutureBuilder( - future: room.loadHeroUsers(), - builder: (context, snapshot) => HoverBuilder( - builder: (context, hovered) => ListTile( + future: room.name.isEmpty ? room.loadHeroUsers() : null, + builder: (context, _) => HoverBuilder( + builder: (context, listTileHovered) => ListTile( visualDensity: const VisualDensity(vertical: -0.5), contentPadding: const EdgeInsets.symmetric(horizontal: 8), - onLongPress: onLongPress, - leading: Stack( - clipBehavior: Clip.none, - children: [ - HoverBuilder( - builder: (context, hovered) => AnimatedScale( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - scale: hovered ? 1.1 : 1.0, - child: Avatar( - mxContent: room.avatar, - name: displayname, - presenceUserId: directChatMatrixId, - presenceBackgroundColor: backgroundColor, - onTap: onLongPress, - ), - ), - ), - Positioned( - bottom: -2, - right: -2, - child: AnimatedScale( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - scale: (hovered || selected) ? 1.0 : 0.0, - child: Material( - color: backgroundColor, - borderRadius: BorderRadius.circular(16), - child: Icon( - selected - ? Icons.check_circle - : Icons.check_circle_outlined, - size: 18, + onLongPress: () => onLongPress?.call(context), + leading: HoverBuilder( + builder: (context, hovered) => AnimatedScale( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + scale: hovered ? 1.1 : 1.0, + child: SizedBox( + width: Avatar.defaultSize, + height: Avatar.defaultSize, + child: Stack( + children: [ + if (space != null) + Positioned( + top: 0, + left: 0, + child: Avatar( + shapeBorder: RoundedSuperellipseBorder( + side: BorderSide( + width: 2, + color: + backgroundColor ?? + theme.colorScheme.surface, + ), + borderRadius: BorderRadius.circular( + AppConfig.spaceBorderRadius * 0.75, + ), + ), + borderRadius: BorderRadius.circular( + AppConfig.spaceBorderRadius * 0.75, + ), + mxContent: space.avatar, + size: Avatar.defaultSize * 0.75, + name: space.getLocalizedDisplayname(), + onTap: () => onLongPress?.call(context), + ), + ), + Positioned( + bottom: 0, + right: 0, + child: Avatar( + shapeBorder: space == null + ? room.isSpace + ? RoundedSuperellipseBorder( + side: BorderSide( + width: 1, + color: theme.dividerColor, + ), + borderRadius: BorderRadius.circular( + AppConfig.spaceBorderRadius, + ), + ) + : null + : RoundedRectangleBorder( + side: BorderSide( + width: 2, + color: + backgroundColor ?? + theme.colorScheme.surface, + ), + borderRadius: BorderRadius.circular( + Avatar.defaultSize, + ), + ), + borderRadius: room.isSpace + ? BorderRadius.circular( + AppConfig.spaceBorderRadius, + ) + : null, + mxContent: room.avatar, + size: space != null + ? Avatar.defaultSize * 0.75 + : Avatar.defaultSize, + name: displayname, + presenceUserId: directChatMatrixId, + presenceBackgroundColor: backgroundColor, + onTap: () => onLongPress?.call(context), + ), ), - ), + Positioned( + top: 0, + right: 0, + child: GestureDetector( + onTap: () => onLongPress?.call(context), + child: AnimatedScale( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + scale: listTileHovered ? 1.0 : 0.0, + child: Material( + color: backgroundColor, + borderRadius: BorderRadius.circular(16), + child: const Icon( + Icons.arrow_drop_down_circle_outlined, + size: 18, + ), + ), + ), + ), + ), + ], ), ), - ], + ), ), title: Row( children: [ @@ -156,20 +184,14 @@ class ChatListItem extends StatelessWidget { maxLines: 1, overflow: TextOverflow.ellipsis, softWrap: false, - style: unread || room.hasNewMessages - ? const TextStyle(fontWeight: FontWeight.bold) - : null, ), ), if (isMuted) const Padding( padding: EdgeInsets.only(left: 4.0), - child: Icon( - Icons.notifications_off_outlined, - size: 16, - ), + child: Icon(Icons.notifications_off_outlined, size: 16), ), - if (room.isFavourite || room.membership == Membership.invite) + if (room.isFavourite) Padding( padding: EdgeInsets.only( right: hasNotifications ? 4.0 : 0.0, @@ -180,27 +202,25 @@ class ChatListItem extends StatelessWidget { color: theme.colorScheme.primary, ), ), - if (lastEvent != null && room.membership != Membership.invite) + if (!room.isSpace && room.membership != Membership.invite) Padding( padding: const EdgeInsets.only(left: 4.0), child: Text( - lastEvent.originServerTs.localizedTimeShort(context), - style: TextStyle( - fontSize: 13, - color: unread - ? theme.colorScheme.secondary - : theme.textTheme.bodyMedium!.color, + room.latestEventReceivedTime.localizedTimeShort( + context, ), + style: TextStyle(fontSize: 11), ), ), ], ), subtitle: Row( - mainAxisAlignment: MainAxisAlignment.center, + crossAxisAlignment: .start, + mainAxisAlignment: .center, children: [ if (typingText.isEmpty && ownMessage && - room.lastEvent!.status.isSending) ...[ + room.lastEvent?.status.isSending == true) ...[ const SizedBox( width: 16, height: 16, @@ -208,68 +228,112 @@ class ChatListItem extends StatelessWidget { ), const SizedBox(width: 4), ], - AnimatedContainer( - width: typingText.isEmpty ? 0 : 18, + AnimatedSize( clipBehavior: Clip.hardEdge, - decoration: const BoxDecoration(), duration: FluffyThemes.animationDuration, curve: FluffyThemes.animationCurve, - padding: const EdgeInsets.only(right: 4), - child: Icon( - Icons.edit_outlined, - color: theme.colorScheme.secondary, - size: 14, - ), + child: typingText.isNotEmpty + ? Padding( + padding: const EdgeInsets.only(right: 4.0), + child: Icon( + Icons.edit_outlined, + color: theme.colorScheme.secondary, + size: 16, + ), + ) + : room.lastEvent?.relationshipType == + RelationshipTypes.thread + ? Container( + decoration: BoxDecoration( + border: Border.all( + color: theme.colorScheme.outline, + ), + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + ), + padding: const EdgeInsets.symmetric( + horizontal: 8.0, + ), + margin: const EdgeInsets.only(right: 4.0), + child: Row( + mainAxisSize: .min, + children: [ + Icon( + Icons.message_outlined, + size: 12, + color: theme.colorScheme.outline, + ), + const SizedBox(width: 4), + Text( + L10n.of(context).thread, + style: TextStyle(fontSize: 11), + ), + ], + ), + ) + : const SizedBox.shrink(), ), Expanded( - child: typingText.isNotEmpty + child: room.isSpace && room.membership == Membership.join + ? Text( + L10n.of( + context, + ).countChats(room.spaceChildren.length), + ) + : typingText.isNotEmpty ? Text( typingText, - style: TextStyle( - color: theme.colorScheme.primary, - ), + style: TextStyle(color: theme.colorScheme.primary), maxLines: 1, softWrap: false, ) : FutureBuilder( - key: ValueKey(lastEvent?.eventId), + key: ValueKey( + '${lastEvent?.eventId}_${lastEvent?.type}_${lastEvent?.redacted}', + ), future: needLastEventSender ? lastEvent.calcLocalizedBody( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), hideReply: true, hideEdit: true, plaintextBody: true, removeMarkdown: true, - withSenderNamePrefix: !isDirectChat || + withSenderNamePrefix: + (!isDirectChat || directChatMatrixId != - room.lastEvent?.senderId, + room.lastEvent?.senderId), ) : null, initialData: lastEvent?.calcLocalizedBodyFallback( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), hideReply: true, hideEdit: true, plaintextBody: true, removeMarkdown: true, - withSenderNamePrefix: !isDirectChat || + withSenderNamePrefix: + (!isDirectChat || directChatMatrixId != - room.lastEvent?.senderId, + room.lastEvent?.senderId), ), builder: (context, snapshot) => Text( room.membership == Membership.invite - ? isDirectChat - ? L10n.of(context)!.invitePrivateChat - : L10n.of(context)!.inviteGroupChat + ? room + .getState( + EventTypes.RoomMember, + room.client.userID!, + ) + ?.content + .tryGet('reason') ?? + (isDirectChat + ? L10n.of(context).newChatRequest + : L10n.of(context).inviteGroupChat) : snapshot.data ?? - L10n.of(context)!.emptyChat, + L10n.of(context).noMessagesYet, softWrap: false, - maxLines: 1, + maxLines: room.notificationCount >= 1 ? 2 : 1, overflow: TextOverflow.ellipsis, style: TextStyle( - fontWeight: unread || room.hasNewMessages - ? FontWeight.bold - : null, - color: theme.colorScheme.onSurfaceVariant, decoration: room.lastEvent?.redacted == true ? TextDecoration.lineThrough : null, @@ -278,47 +342,33 @@ class ChatListItem extends StatelessWidget { ), ), const SizedBox(width: 8), - AnimatedContainer( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - padding: const EdgeInsets.symmetric(horizontal: 7), - height: unreadBubbleSize, - width: !hasNotifications && !unread && !room.hasNewMessages - ? 0 - : (unreadBubbleSize - 9) * - room.notificationCount.toString().length + - 9, - decoration: BoxDecoration( - color: room.highlightCount > 0 || - room.membership == Membership.invite - ? Colors.red - : hasNotifications || room.markedUnread - ? theme.colorScheme.primary - : theme.colorScheme.primaryContainer, - borderRadius: - BorderRadius.circular(AppConfig.borderRadius), - ), - child: Center( - child: hasNotifications - ? Text( - room.notificationCount.toString(), - style: TextStyle( - color: room.highlightCount > 0 - ? Colors.white - : hasNotifications - ? theme.colorScheme.onPrimary - : theme.colorScheme.onPrimaryContainer, - fontSize: 13, - ), - ) - : const SizedBox.shrink(), - ), - ), + UnreadBubble(room: room), ], ), onTap: onTap, trailing: onForget == null - ? null + ? room.membership == Membership.invite + ? IconButton( + tooltip: L10n.of(context).declineInvitation, + icon: const Icon(Icons.delete_forever_outlined), + color: theme.colorScheme.error, + onPressed: () async { + final consent = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).declineInvitation, + message: L10n.of(context).areYouSure, + okLabel: L10n.of(context).yes, + isDestructive: true, + ); + if (consent != OkCancelResult.ok) return; + if (!context.mounted) return; + await showFutureLoadingDialog( + context: context, + future: room.leave, + ); + }, + ) + : null : IconButton( icon: const Icon(Icons.delete_outlined), onPressed: onForget, diff --git a/lib/pages/chat_list/chat_list_view.dart b/lib/pages/chat_list/chat_list_view.dart index 160db9b86..3c332ce4b 100644 --- a/lib/pages/chat_list/chat_list_view.dart +++ b/lib/pages/chat_list/chat_list_view.dart @@ -1,228 +1,61 @@ import 'package:flutter/material.dart'; -import 'package:flutter/services.dart'; -import 'package:badges/badges.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:go_router/go_router.dart'; -import 'package:keyboard_shortcuts/keyboard_shortcuts.dart'; - -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/config/themes.dart'; import 'package:fluffychat/pages/chat_list/chat_list.dart'; -import 'package:fluffychat/pages/chat_list/navi_rail_item.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; -import 'package:fluffychat/widgets/avatar.dart'; -import 'package:fluffychat/widgets/unread_rooms_badge.dart'; -import '../../widgets/matrix.dart'; +import 'package:fluffychat/pages/chat_list/start_chat_fab.dart'; +import 'package:fluffychat/widgets/navigation_rail.dart'; import 'chat_list_body.dart'; -import 'start_chat_fab.dart'; class ChatListView extends StatelessWidget { final ChatListController controller; const ChatListView(this.controller, {super.key}); - List getNavigationDestinations(BuildContext context) { - final badgePosition = BadgePosition.topEnd(top: -12, end: -8); - return [ - if (AppConfig.separateChatTypes) ...[ - NavigationDestination( - icon: UnreadRoomsBadge( - badgePosition: badgePosition, - filter: - controller.getRoomFilterByActiveFilter(ActiveFilter.messages), - child: const Icon(Icons.chat_outlined), - ), - selectedIcon: UnreadRoomsBadge( - badgePosition: badgePosition, - filter: - controller.getRoomFilterByActiveFilter(ActiveFilter.messages), - child: const Icon(Icons.chat), - ), - label: L10n.of(context)!.messages, - ), - NavigationDestination( - icon: UnreadRoomsBadge( - badgePosition: badgePosition, - filter: controller.getRoomFilterByActiveFilter(ActiveFilter.groups), - child: const Icon(Icons.group_outlined), - ), - selectedIcon: UnreadRoomsBadge( - badgePosition: badgePosition, - filter: controller.getRoomFilterByActiveFilter(ActiveFilter.groups), - child: const Icon(Icons.group), - ), - label: L10n.of(context)!.groups, - ), - ] else - NavigationDestination( - icon: UnreadRoomsBadge( - badgePosition: badgePosition, - filter: - controller.getRoomFilterByActiveFilter(ActiveFilter.allChats), - child: const Icon(Icons.chat_outlined), - ), - selectedIcon: UnreadRoomsBadge( - badgePosition: badgePosition, - filter: - controller.getRoomFilterByActiveFilter(ActiveFilter.allChats), - child: const Icon(Icons.chat), - ), - label: L10n.of(context)!.chats, - ), - if (controller.spaces.isNotEmpty) - const NavigationDestination( - icon: Icon(Icons.workspaces_outlined), - selectedIcon: Icon(Icons.workspaces), - label: 'Spaces', - ), - ]; - } - @override Widget build(BuildContext context) { - final client = Matrix.of(context).client; - return StreamBuilder( - stream: Matrix.of(context).onShareContentChanged.stream, - builder: (_, __) { - final selectMode = controller.selectMode; - return PopScope( - canPop: controller.selectMode == SelectMode.normal && - !controller.isSearchMode && - controller.activeFilter == - (AppConfig.separateChatTypes - ? ActiveFilter.messages - : ActiveFilter.allChats), - onPopInvoked: (pop) async { - if (pop) return; - final selMode = controller.selectMode; - if (controller.isSearchMode) { - controller.cancelSearch(); - return; - } - if (selMode != SelectMode.normal) { - controller.cancelAction(); - return; - } - if (controller.activeFilter != - (AppConfig.separateChatTypes - ? ActiveFilter.messages - : ActiveFilter.allChats)) { - controller - .onDestinationSelected(AppConfig.separateChatTypes ? 1 : 0); - return; - } - }, - child: Row( - children: [ - if (FluffyThemes.isColumnMode(context) && - controller.widget.displayNavigationRail) ...[ - Builder( - builder: (context) { - final allSpaces = - client.rooms.where((room) => room.isSpace); - final rootSpaces = allSpaces - .where( - (space) => !allSpaces.any( - (parentSpace) => parentSpace.spaceChildren - .any((child) => child.roomId == space.id), - ), - ) - .toList(); - final destinations = getNavigationDestinations(context); - - return SizedBox( - width: FluffyThemes.navRailWidth, - child: ListView.builder( - scrollDirection: Axis.vertical, - itemCount: rootSpaces.length + destinations.length, - itemBuilder: (context, i) { - if (i < destinations.length) { - return NaviRailItem( - isSelected: i == controller.selectedIndex, - onTap: () => controller.onDestinationSelected(i), - icon: destinations[i].icon, - selectedIcon: destinations[i].selectedIcon, - toolTip: destinations[i].label, - ); - } - i -= destinations.length; - final isSelected = - controller.activeFilter == ActiveFilter.spaces && - rootSpaces[i].id == controller.activeSpaceId; - return NaviRailItem( - toolTip: rootSpaces[i].getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), - ), - isSelected: isSelected, - onTap: () => - controller.setActiveSpace(rootSpaces[i].id), - icon: Avatar( - mxContent: rootSpaces[i].avatar, - name: rootSpaces[i].getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), - ), - size: 32, - ), - ); - }, - ), - ); - }, - ), - Container( - color: Theme.of(context).dividerColor, - width: 1, - ), - ], - Expanded( - child: GestureDetector( - onTap: FocusManager.instance.primaryFocus?.unfocus, - excludeFromSemantics: true, - behavior: HitTestBehavior.translucent, - child: Scaffold( - body: ChatListViewBody(controller), - bottomNavigationBar: controller.displayNavigationBar - ? NavigationBar( - elevation: 4, - labelBehavior: - NavigationDestinationLabelBehavior.alwaysShow, - shadowColor: - Theme.of(context).colorScheme.onSurface, - backgroundColor: - Theme.of(context).colorScheme.surface, - surfaceTintColor: - Theme.of(context).colorScheme.surface, - selectedIndex: controller.selectedIndex, - onDestinationSelected: - controller.onDestinationSelected, - destinations: getNavigationDestinations(context), - ) - : null, - floatingActionButton: KeyBoardShortcuts( - keysToPress: { - LogicalKeyboardKey.controlLeft, - LogicalKeyboardKey.keyN, - }, - onKeysPressed: () => context.go('/rooms/newprivatechat'), - helpLabel: L10n.of(context)!.newChat, - child: selectMode == SelectMode.normal && - !controller.isSearchMode - ? StartChatFloatingActionButton( - activeFilter: controller.activeFilter, - roomsIsEmpty: false, - scrolledToTop: controller.scrolledToTop, - createNewSpace: controller.createNewSpace, - ) - : const SizedBox.shrink(), - ), - ), - ), - ), - ], - ), - ); + return PopScope( + canPop: !controller.isSearchMode && controller.activeSpaceId == null, + onPopInvokedWithResult: (pop, _) { + if (pop) return; + if (controller.activeSpaceId != null) { + controller.clearActiveSpace(); + return; + } + if (controller.isSearchMode) { + controller.cancelSearch(); + return; + } }, + child: Row( + children: [ + if (FluffyThemes.isColumnMode(context) || + AppSettings.displayNavigationRail.value) ...[ + SpacesNavigationRail( + activeSpaceId: controller.activeSpaceId, + onGoToChats: controller.clearActiveSpace, + onGoToSpaceId: controller.setActiveSpace, + ), + Container(color: Theme.of(context).dividerColor, width: 1), + ], + Expanded( + child: GestureDetector( + onTap: FocusManager.instance.primaryFocus?.unfocus, + excludeFromSemantics: true, + behavior: HitTestBehavior.translucent, + child: Scaffold( + body: ChatListViewBody(controller), + floatingActionButton: + !controller.isSearchMode && + controller.activeSpaceId == null && + !FluffyThemes.isColumnMode(context) + ? StartChatFab() + : const SizedBox.shrink(), + ), + ), + ), + ], + ), ); } } diff --git a/lib/pages/chat_list/client_chooser_button.dart b/lib/pages/chat_list/client_chooser_button.dart index a37901b2f..b4dca19dc 100644 --- a/lib/pages/chat_list/client_chooser_button.dart +++ b/lib/pages/chat_list/client_chooser_button.dart @@ -1,12 +1,13 @@ import 'package:flutter/material.dart'; -import 'package:flutter/services.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; -import 'package:keyboard_shortcuts/keyboard_shortcuts.dart'; import 'package:matrix/matrix.dart'; +import 'package:url_launcher/url_launcher_string.dart'; +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/matrix.dart'; import '../../utils/fluffy_share.dart'; @@ -24,8 +25,8 @@ class ClientChooserButton extends StatelessWidget { (a, b) => a!.isValidMatrixId == b!.isValidMatrixId ? 0 : a.isValidMatrixId && !b.isValidMatrixId - ? -1 - : 1, + ? -1 + : 1, ); return >[ PopupMenuItem( @@ -34,17 +35,7 @@ class ClientChooserButton extends StatelessWidget { children: [ const Icon(Icons.group_add_outlined), const SizedBox(width: 18), - Text(L10n.of(context)!.createGroup), - ], - ), - ), - PopupMenuItem( - value: SettingsAction.newSpace, - child: Row( - children: [ - const Icon(Icons.workspaces_outlined), - const SizedBox(width: 18), - Text(L10n.of(context)!.createNewSpace), + Text(L10n.of(context).createGroup), ], ), ), @@ -54,7 +45,7 @@ class ClientChooserButton extends StatelessWidget { children: [ const Icon(Icons.edit_outlined), const SizedBox(width: 18), - Text(L10n.of(context)!.setStatus), + Text(L10n.of(context).setStatus), ], ), ), @@ -64,7 +55,7 @@ class ClientChooserButton extends StatelessWidget { children: [ Icon(Icons.adaptive.share_outlined), const SizedBox(width: 18), - Text(L10n.of(context)!.inviteContact), + Text(L10n.of(context).inviteContact), ], ), ), @@ -74,17 +65,28 @@ class ClientChooserButton extends StatelessWidget { children: [ const Icon(Icons.archive_outlined), const SizedBox(width: 18), - Text(L10n.of(context)!.archive), + Text(L10n.of(context).archive), ], ), ), + if (Matrix.of(context).backgroundPush?.firebaseEnabled != true) + PopupMenuItem( + value: SettingsAction.support, + child: Row( + children: [ + const Icon(Icons.favorite, color: Colors.red), + const SizedBox(width: 18), + Text(L10n.of(context).donate), + ], + ), + ), PopupMenuItem( value: SettingsAction.settings, child: Row( children: [ const Icon(Icons.settings_outlined), const SizedBox(width: 18), - Text(L10n.of(context)!.settings), + Text(L10n.of(context).settings), ], ), ), @@ -95,8 +97,8 @@ class ClientChooserButton extends StatelessWidget { PopupMenuItem( value: null, child: Column( - crossAxisAlignment: CrossAxisAlignment.start, - mainAxisSize: MainAxisSize.min, + crossAxisAlignment: .start, + mainAxisSize: .min, children: [ Text( bundle!, @@ -109,44 +111,44 @@ class ClientChooserButton extends StatelessWidget { ], ), ), - ...matrix.accountBundles[bundle]!.map( - (client) => PopupMenuItem( - value: client, - child: FutureBuilder( - // analyzer does not understand this type cast for error - // handling - // - // ignore: unnecessary_cast - future: (client!.fetchOwnProfile() as Future) - .onError((e, s) => null), - builder: (context, snapshot) => Row( - children: [ - Avatar( - mxContent: snapshot.data?.avatarUrl, - name: - snapshot.data?.displayName ?? client.userID!.localpart, - size: 32, + ...matrix.accountBundles[bundle]! + .whereType() + .where((client) => client.isLogged()) + .map( + (client) => PopupMenuItem( + value: client, + child: FutureBuilder( + future: client.fetchOwnProfile(), + builder: (context, snapshot) => Row( + children: [ + Avatar( + mxContent: snapshot.data?.avatarUrl, + name: + snapshot.data?.displayName ?? + client.userID!.localpart, + size: 32, + ), + const SizedBox(width: 12), + Expanded( + child: Text( + snapshot.data?.displayName ?? + client.userID!.localpart!, + overflow: TextOverflow.ellipsis, + ), + ), + const SizedBox(width: 12), + IconButton( + icon: const Icon(Icons.edit_outlined), + onPressed: () => controller.editBundlesForAccount( + client.userID, + bundle, + ), + ), + ], ), - const SizedBox(width: 12), - Expanded( - child: Text( - snapshot.data?.displayName ?? client.userID!.localpart!, - overflow: TextOverflow.ellipsis, - ), - ), - const SizedBox(width: 12), - IconButton( - icon: const Icon(Icons.edit_outlined), - onPressed: () => controller.editBundlesForAccount( - client.userID, - bundle, - ), - ), - ], + ), ), ), - ), - ), ], PopupMenuItem( value: SettingsAction.addAccount, @@ -154,7 +156,7 @@ class ClientChooserButton extends StatelessWidget { children: [ const Icon(Icons.person_add_outlined), const SizedBox(width: 18), - Text(L10n.of(context)!.addAccount), + Text(L10n.of(context).addAccount), ], ), ), @@ -165,79 +167,39 @@ class ClientChooserButton extends StatelessWidget { Widget build(BuildContext context) { final matrix = Matrix.of(context); - int clientCount = 0; + var clientCount = 0; matrix.accountBundles.forEach((key, value) => clientCount += value.length); return FutureBuilder( - future: matrix.client.fetchOwnProfile(), - builder: (context, snapshot) => Stack( - alignment: Alignment.center, - children: [ - ...List.generate( - clientCount, - (index) => KeyBoardShortcuts( - keysToPress: _buildKeyboardShortcut(index + 1), - helpLabel: L10n.of(context)!.switchToAccount(index + 1), - onKeysPressed: () => _handleKeyboardShortcut( - matrix, - index, - context, - ), - child: const SizedBox.shrink(), - ), - ), - KeyBoardShortcuts( - keysToPress: { - LogicalKeyboardKey.controlLeft, - LogicalKeyboardKey.tab, - }, - helpLabel: L10n.of(context)!.nextAccount, - onKeysPressed: () => _nextAccount(matrix, context), - child: const SizedBox.shrink(), - ), - KeyBoardShortcuts( - keysToPress: { - LogicalKeyboardKey.controlLeft, - LogicalKeyboardKey.shiftLeft, - LogicalKeyboardKey.tab, - }, - helpLabel: L10n.of(context)!.previousAccount, - onKeysPressed: () => _previousAccount(matrix, context), - child: const SizedBox.shrink(), - ), - PopupMenuButton( + future: matrix.client.isLogged() ? matrix.client.fetchOwnProfile() : null, + builder: (context, snapshot) => Material( + clipBehavior: Clip.hardEdge, + borderRadius: BorderRadius.circular(99), + color: Colors.transparent, + child: Semantics( + identifier: 'accounts_and_settings', + child: PopupMenuButton( + tooltip: 'Accounts and settings', + popUpAnimationStyle: FluffyThemes.isColumnMode(context) + ? AnimationStyle.noAnimation + : null, // https://github.com/flutter/flutter/issues/167180 onSelected: (o) => _clientSelected(o, context), itemBuilder: _bundleMenuItems, - child: Material( - color: Colors.transparent, - borderRadius: BorderRadius.circular(99), + child: Center( child: Avatar( mxContent: snapshot.data?.avatarUrl, - name: snapshot.data?.displayName ?? - matrix.client.userID!.localpart, + name: + snapshot.data?.displayName ?? + matrix.client.userID?.localpart, size: 32, ), ), ), - ], + ), ), ); } - Set? _buildKeyboardShortcut(int index) { - if (index > 0 && index < 10) { - return { - LogicalKeyboardKey.altLeft, - LogicalKeyboardKey(0x00000000030 + index), - }; - } else { - return null; - } - } - - void _clientSelected( - Object object, - BuildContext context, - ) async { + Future _clientSelected(Object object, BuildContext context) async { if (object is Client) { controller.setActiveClient(object); } else if (object is String) { @@ -247,10 +209,10 @@ class ClientChooserButton extends StatelessWidget { case SettingsAction.addAccount: final consent = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.addAccount, - message: L10n.of(context)!.enableMultiAccounts, - okLabel: L10n.of(context)!.next, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).addAccount, + message: L10n.of(context).enableMultiAccounts, + okLabel: L10n.of(context).next, + cancelLabel: L10n.of(context).cancel, ); if (consent != OkCancelResult.ok) return; context.go('/rooms/settings/addaccount'); @@ -258,12 +220,12 @@ class ClientChooserButton extends StatelessWidget { case SettingsAction.newGroup: context.go('/rooms/newgroup'); break; - case SettingsAction.newSpace: - controller.createNewSpace(); - break; case SettingsAction.invite: FluffyShare.shareInviteLink(context); break; + case SettingsAction.support: + launchUrlString(AppConfig.donationUrl); + break; case SettingsAction.settings: context.go('/rooms/settings'); break; @@ -276,83 +238,14 @@ class ClientChooserButton extends StatelessWidget { } } } - - void _handleKeyboardShortcut( - MatrixState matrix, - int index, - BuildContext context, - ) { - final bundles = matrix.accountBundles.keys.toList() - ..sort( - (a, b) => a!.isValidMatrixId == b!.isValidMatrixId - ? 0 - : a.isValidMatrixId && !b.isValidMatrixId - ? -1 - : 1, - ); - // beginning from end if negative - if (index < 0) { - int clientCount = 0; - matrix.accountBundles - .forEach((key, value) => clientCount += value.length); - _handleKeyboardShortcut(matrix, clientCount, context); - } - for (final bundleName in bundles) { - final bundle = matrix.accountBundles[bundleName]; - if (bundle != null) { - if (index < bundle.length) { - return _clientSelected(bundle[index]!, context); - } else { - index -= bundle.length; - } - } - } - // if index too high, restarting from 0 - _handleKeyboardShortcut(matrix, 0, context); - } - - int? _shortcutIndexOfClient(MatrixState matrix, Client client) { - int index = 0; - - final bundles = matrix.accountBundles.keys.toList() - ..sort( - (a, b) => a!.isValidMatrixId == b!.isValidMatrixId - ? 0 - : a.isValidMatrixId && !b.isValidMatrixId - ? -1 - : 1, - ); - for (final bundleName in bundles) { - final bundle = matrix.accountBundles[bundleName]; - if (bundle == null) return null; - if (bundle.contains(client)) { - return index + bundle.indexOf(client); - } else { - index += bundle.length; - } - } - return null; - } - - void _nextAccount(MatrixState matrix, BuildContext context) { - final client = matrix.client; - final lastIndex = _shortcutIndexOfClient(matrix, client); - _handleKeyboardShortcut(matrix, lastIndex! + 1, context); - } - - void _previousAccount(MatrixState matrix, BuildContext context) { - final client = matrix.client; - final lastIndex = _shortcutIndexOfClient(matrix, client); - _handleKeyboardShortcut(matrix, lastIndex! - 1, context); - } } enum SettingsAction { addAccount, newGroup, - newSpace, setStatus, invite, + support, settings, archive, } diff --git a/lib/pages/chat_list/dummy_chat_list_item.dart b/lib/pages/chat_list/dummy_chat_list_item.dart new file mode 100644 index 000000000..8652cccd1 --- /dev/null +++ b/lib/pages/chat_list/dummy_chat_list_item.dart @@ -0,0 +1,72 @@ +import 'package:flutter/material.dart'; + +class DummyChatListItem extends StatelessWidget { + final double opacity; + final bool animate; + + const DummyChatListItem({ + required this.opacity, + required this.animate, + super.key, + }); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + final titleColor = theme.textTheme.bodyLarge!.color!.withAlpha(100); + final subtitleColor = theme.textTheme.bodyLarge!.color!.withAlpha(50); + return Opacity( + opacity: opacity, + child: ListTile( + leading: CircleAvatar( + backgroundColor: titleColor, + child: animate + ? CircularProgressIndicator( + strokeWidth: 1, + color: theme.textTheme.bodyLarge!.color, + ) + : const SizedBox.shrink(), + ), + title: Row( + children: [ + Expanded( + child: Container( + height: 14, + decoration: BoxDecoration( + color: titleColor, + borderRadius: BorderRadius.circular(3), + ), + ), + ), + const SizedBox(width: 36), + Container( + height: 14, + width: 14, + decoration: BoxDecoration( + color: subtitleColor, + borderRadius: BorderRadius.circular(14), + ), + ), + const SizedBox(width: 12), + Container( + height: 14, + width: 14, + decoration: BoxDecoration( + color: subtitleColor, + borderRadius: BorderRadius.circular(14), + ), + ), + ], + ), + subtitle: Container( + decoration: BoxDecoration( + color: subtitleColor, + borderRadius: BorderRadius.circular(3), + ), + height: 12, + margin: const EdgeInsets.only(right: 22), + ), + ), + ); + } +} diff --git a/lib/pages/chat_list/navi_rail_item.dart b/lib/pages/chat_list/navi_rail_item.dart index d09659f88..b0c50a923 100644 --- a/lib/pages/chat_list/navi_rail_item.dart +++ b/lib/pages/chat_list/navi_rail_item.dart @@ -1,14 +1,20 @@ import 'package:flutter/material.dart'; +import 'package:badges/badges.dart'; +import 'package:matrix/matrix.dart'; + import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/widgets/hover_builder.dart'; +import 'package:fluffychat/widgets/unread_rooms_badge.dart'; import '../../config/themes.dart'; -class NaviRailItem extends StatefulWidget { +class NaviRailItem extends StatelessWidget { final String toolTip; final bool isSelected; final void Function() onTap; final Widget icon; final Widget? selectedIcon; + final bool Function(Room)? unreadBadgeFilter; const NaviRailItem({ required this.toolTip, @@ -16,80 +22,78 @@ class NaviRailItem extends StatefulWidget { required this.onTap, required this.icon, this.selectedIcon, + this.unreadBadgeFilter, super.key, }); - - @override - State createState() => _NaviRailItemState(); -} - -class _NaviRailItemState extends State { - bool _hovered = false; - - void _onHover(bool hover) { - if (hover == _hovered) return; - setState(() { - _hovered = hover; - }); - } - @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final borderRadius = BorderRadius.circular(AppConfig.borderRadius); - return SizedBox( - height: 64, - width: 64, - child: Stack( - children: [ - Positioned( - top: 16, - bottom: 16, - left: 0, - child: AnimatedContainer( - width: widget.isSelected ? 4 : 0, - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - decoration: BoxDecoration( - color: Theme.of(context).colorScheme.primary, - borderRadius: const BorderRadius.only( - topRight: Radius.circular(90), - bottomRight: Radius.circular(90), - ), - ), - ), - ), - Center( - child: AnimatedScale( - scale: _hovered ? 1.2 : 1.0, - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - child: Material( - borderRadius: borderRadius, - color: widget.isSelected - ? Theme.of(context).colorScheme.primaryContainer - : Theme.of(context).colorScheme.surface, - child: Tooltip( - message: widget.toolTip, - child: InkWell( - borderRadius: borderRadius, - onTap: widget.onTap, - onHover: _onHover, - child: Padding( - padding: const EdgeInsets.symmetric( - horizontal: 8.0, - vertical: 8.0, - ), - child: widget.isSelected - ? widget.selectedIcon ?? widget.icon - : widget.icon, + final icon = isSelected ? selectedIcon ?? this.icon : this.icon; + final unreadBadgeFilter = this.unreadBadgeFilter; + return HoverBuilder( + builder: (context, hovered) { + return SizedBox( + height: 72, + width: FluffyThemes.navRailWidth, + child: Stack( + children: [ + Positioned( + top: 8, + bottom: 8, + left: 0, + child: AnimatedContainer( + width: isSelected + ? FluffyThemes.isColumnMode(context) + ? 8 + : 4 + : 0, + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + decoration: BoxDecoration( + color: theme.colorScheme.primary, + borderRadius: const BorderRadius.only( + topRight: Radius.circular(90), + bottomRight: Radius.circular(90), ), ), ), ), - ), + Center( + child: AnimatedScale( + scale: hovered ? 1.1 : 1.0, + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: Material( + borderRadius: borderRadius, + color: isSelected + ? theme.colorScheme.primaryContainer + : theme.colorScheme.surfaceContainerHigh, + child: Tooltip( + message: toolTip, + child: InkWell( + borderRadius: borderRadius, + onTap: onTap, + child: unreadBadgeFilter == null + ? icon + : UnreadRoomsBadge( + filter: unreadBadgeFilter, + badgePosition: BadgePosition.topEnd( + top: -12, + end: -8, + ), + child: icon, + ), + ), + ), + ), + ), + ), + ], ), - ], - ), + ); + }, ); } } diff --git a/lib/pages/chat_list/search_title.dart b/lib/pages/chat_list/search_title.dart index 62bcfb684..5f9b2f844 100644 --- a/lib/pages/chat_list/search_title.dart +++ b/lib/pages/chat_list/search_title.dart @@ -17,55 +17,50 @@ class SearchTitle extends StatelessWidget { }); @override - Widget build(BuildContext context) => Material( - shape: Border( - top: BorderSide( - color: Theme.of(context).dividerColor, - width: 1, - ), - bottom: BorderSide( - color: Theme.of(context).dividerColor, - width: 1, - ), - ), - color: color ?? Theme.of(context).colorScheme.surface, - child: InkWell( - onTap: onTap, - splashColor: Theme.of(context).colorScheme.surface, - child: Align( - alignment: Alignment.centerLeft, - child: Padding( - padding: const EdgeInsets.symmetric( - horizontal: 16, - vertical: 8, - ), - child: IconTheme( - data: Theme.of(context).iconTheme.copyWith(size: 16), - child: Row( - children: [ - icon, - const SizedBox(width: 16), - Text( - title, - textAlign: TextAlign.left, - style: TextStyle( - color: Theme.of(context).colorScheme.onSurface, - fontSize: 12, - fontWeight: FontWeight.bold, + Widget build(BuildContext context) { + final theme = Theme.of(context); + + return Material( + shape: Border( + top: BorderSide(color: theme.dividerColor, width: 1), + bottom: BorderSide(color: theme.dividerColor, width: 1), + ), + color: color ?? theme.colorScheme.surface, + child: InkWell( + onTap: onTap, + splashColor: theme.colorScheme.surface, + child: Align( + alignment: Alignment.centerLeft, + child: Padding( + padding: const EdgeInsets.symmetric(horizontal: 16, vertical: 8), + child: IconTheme( + data: theme.iconTheme.copyWith(size: 16), + child: Row( + children: [ + icon, + const SizedBox(width: 16), + Text( + title, + textAlign: TextAlign.left, + style: TextStyle( + color: theme.colorScheme.onSurface, + fontSize: 12, + fontWeight: FontWeight.bold, + ), + ), + if (trailing != null) + Expanded( + child: Align( + alignment: Alignment.centerRight, + child: trailing, ), ), - if (trailing != null) - Expanded( - child: Align( - alignment: Alignment.centerRight, - child: trailing!, - ), - ), - ], - ), + ], ), ), ), ), - ); + ), + ); + } } diff --git a/lib/pages/chat_list/space_view.dart b/lib/pages/chat_list/space_view.dart index a984b4377..72c9446a4 100644 --- a/lib/pages/chat_list/space_view.dart +++ b/lib/pages/chat_list/space_view.dart @@ -1,30 +1,49 @@ +import 'dart:async'; +import 'dart:convert'; + import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; import 'package:collection/collection.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart' as sdk; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/pages/chat_list/chat_list.dart'; -import 'package:fluffychat/pages/chat_list/chat_list_item.dart'; -import 'package:fluffychat/pages/chat_list/search_title.dart'; -import 'package:fluffychat/pages/chat_list/utils/on_chat_tap.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat_list/unread_bubble.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/utils/stream_extension.dart'; +import 'package:fluffychat/utils/string_color.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; import 'package:fluffychat/widgets/avatar.dart'; -import '../../utils/localized_exception_extension.dart'; -import '../../widgets/matrix.dart'; -import 'chat_list_header.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; +import 'package:fluffychat/widgets/hover_builder.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +enum SpaceChildAction { + mute, + unmute, + markAsUnread, + markAsRead, + removeFromSpace, + leave, +} + +enum SpaceActions { settings, invite, members, leave } class SpaceView extends StatefulWidget { - final ChatListController controller; - final ScrollController scrollController; - const SpaceView( - this.controller, { + final String spaceId; + final void Function() onBack; + final void Function(Room room) onChatTab; + final String? activeChat; + + const SpaceView({ + required this.spaceId, + required this.onBack, + required this.onChatTab, + required this.activeChat, super.key, - required this.scrollController, }); @override @@ -32,543 +51,621 @@ class SpaceView extends StatefulWidget { } class _SpaceViewState extends State { - static final Map _lastResponse = {}; + final List _discoveredChildren = []; + final TextEditingController _filterController = TextEditingController(); + String? _nextBatch; + bool _noMoreRooms = false; + bool _isLoading = false; - String? prevBatch; - Object? error; - bool loading = false; + StreamSubscription? _childStateSub; @override void initState() { - loadHierarchy(); + _loadHierarchy(); + _childStateSub = Matrix.of(context).client.onSync.stream + .where( + (syncUpdate) => + syncUpdate.rooms?.join?[widget.spaceId]?.timeline?.events?.any( + (event) => event.type == EventTypes.SpaceChild, + ) ?? + false, + ) + .listen(_loadHierarchy); super.initState(); } - void _refresh() { - _lastResponse.remove(widget.controller.activeSpaceId); - loadHierarchy(); + @override + void dispose() { + _childStateSub?.cancel(); + super.dispose(); } - Future loadHierarchy([String? prevBatch]) async { - final activeSpaceId = widget.controller.activeSpaceId; - if (activeSpaceId == null) return null; - final client = Matrix.of(context).client; + Future _loadHierarchy([_]) async { + final matrix = Matrix.of(context); + final room = matrix.client.getRoomById(widget.spaceId); + if (room == null) return; - final activeSpace = client.getRoomById(activeSpaceId); - await activeSpace?.postLoad(); + final cacheKey = 'spaces_history_cache${room.id}'; + if (_discoveredChildren.isEmpty) { + final cachedChildren = matrix.store.getStringList(cacheKey); + if (cachedChildren != null) { + try { + _discoveredChildren.addAll( + cachedChildren.map( + (jsonString) => + SpaceRoomsChunk$2.fromJson(jsonDecode(jsonString)), + ), + ); + } catch (e, s) { + Logs().e('Unable to json decode spaces hierarchy cache!', e, s); + matrix.store.remove(cacheKey); + } + } + } setState(() { - error = null; - loading = true; + _isLoading = true; }); try { - final response = await client.getSpaceHierarchy( - activeSpaceId, - maxDepth: 1, - from: prevBatch, + final hierarchy = await room.client.getSpaceHierarchy( + widget.spaceId, + suggestedOnly: false, + maxDepth: 2, + from: _nextBatch, ); + if (!mounted) return; + setState(() { + if (_nextBatch == null) _discoveredChildren.clear(); + _nextBatch = hierarchy.nextBatch; + if (hierarchy.nextBatch == null) { + _noMoreRooms = true; + } + _discoveredChildren.addAll( + hierarchy.rooms.where((room) => room.roomId != widget.spaceId), + ); + _isLoading = false; + }); - if (prevBatch != null) { - response.rooms.insertAll(0, _lastResponse[activeSpaceId]?.rooms ?? []); + if (_nextBatch == null) { + matrix.store.setStringList( + cacheKey, + _discoveredChildren + .map((child) => jsonEncode(child.toJson())) + .toList(), + ); } + } catch (e, s) { + Logs().w('Unable to load hierarchy', e, s); + if (!mounted) return; + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); setState(() { - _lastResponse[activeSpaceId] = response; - }); - return _lastResponse[activeSpaceId]!; - } catch (e) { - setState(() { - error = e; - }); - rethrow; - } finally { - setState(() { - loading = false; + _isLoading = false; }); } } - void _onJoinSpaceChild(SpaceRoomsChunk spaceChild) async { + Future _joinChildRoom(SpaceRoomsChunk$2 item) async { final client = Matrix.of(context).client; - final space = client.getRoomById(widget.controller.activeSpaceId!); - if (client.getRoomById(spaceChild.roomId) == null) { - final result = await showFutureLoadingDialog( - context: context, - future: () async { - await client.joinRoom( - spaceChild.roomId, - serverName: space?.spaceChildren - .firstWhereOrNull( - (child) => child.roomId == spaceChild.roomId, - ) - ?.via, - ); - if (client.getRoomById(spaceChild.roomId) == null) { - // Wait for room actually appears in sync - await client.waitForRoomInSync(spaceChild.roomId, join: true); - } - }, - ); - if (result.error != null) return; - _refresh(); - } - if (spaceChild.roomType == 'm.space') { - if (spaceChild.roomId == widget.controller.activeSpaceId) { - context.go('/rooms/${spaceChild.roomId}'); - } else { - widget.controller.setActiveSpace(spaceChild.roomId); - } - return; - } - context.go('/rooms/${spaceChild.roomId}'); - } - - void _onSpaceChildContextMenu([ - SpaceRoomsChunk? spaceChild, - Room? room, - ]) async { - final client = Matrix.of(context).client; - final activeSpaceId = widget.controller.activeSpaceId; - final activeSpace = - activeSpaceId == null ? null : client.getRoomById(activeSpaceId); - final action = await showModalActionSheet( + final space = client.getRoomById(widget.spaceId); + final via = space?.spaceChildren + .firstWhereOrNull((child) => child.roomId == item.roomId) + ?.via; + final roomResult = await showFutureLoadingDialog( context: context, - title: spaceChild?.name ?? - room?.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), + future: () async { + final waitForRoom = client.waitForRoomInSync(item.roomId, join: true); + await client.joinRoom(item.roomId, via: via); + await waitForRoom; + return client.getRoomById(item.roomId)!; + }, + ); + final room = roomResult.result; + if (room != null) widget.onChatTab(room); + } + + Future _onSpaceAction(SpaceActions action) async { + final space = Matrix.of(context).client.getRoomById(widget.spaceId); + + switch (action) { + case SpaceActions.settings: + await space?.postLoad(); + context.push('/rooms/${widget.spaceId}/details'); + break; + case SpaceActions.invite: + await space?.postLoad(); + context.push('/rooms/${widget.spaceId}/invite'); + break; + case SpaceActions.members: + await space?.postLoad(); + context.push('/rooms/${widget.spaceId}/details/members'); + break; + case SpaceActions.leave: + final confirmed = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + message: L10n.of(context).archiveRoomDescription, + okLabel: L10n.of(context).leave, + cancelLabel: L10n.of(context).cancel, + isDestructive: true, + ); + if (!mounted) return; + if (confirmed != OkCancelResult.ok) return; + + final success = await showFutureLoadingDialog( + context: context, + future: () async => await space?.leave(), + ); + if (!mounted) return; + if (success.error != null) return; + widget.onBack(); + } + } + + Future _showSpaceChildEditMenu( + BuildContext posContext, + String roomId, + ) async { + final client = Matrix.of(context).client; + final space = client.getRoomById(widget.spaceId); + final room = client.getRoomById(roomId); + if (space == null) return; + final overlay = + Overlay.of(posContext).context.findRenderObject() as RenderBox; + + final button = posContext.findRenderObject() as RenderBox; + + final position = RelativeRect.fromRect( + Rect.fromPoints( + button.localToGlobal(const Offset(0, -65), ancestor: overlay), + button.localToGlobal( + button.size.bottomRight(Offset.zero) + const Offset(-50, 0), + ancestor: overlay, + ), + ), + Offset.zero & overlay.size, + ); + + final action = await showMenu( + context: posContext, + position: position, + items: [ + if (room != null && room.membership == Membership.join) ...[ + PopupMenuItem( + value: room.pushRuleState == PushRuleState.notify + ? SpaceChildAction.mute + : SpaceChildAction.unmute, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + room.pushRuleState == PushRuleState.notify + ? Icons.notifications_off_outlined + : Icons.notifications_on_outlined, + ), + const SizedBox(width: 12), + Text( + room.pushRuleState == PushRuleState.notify + ? L10n.of(context).muteChat + : L10n.of(context).unmuteChat, + ), + ], + ), ), - message: spaceChild?.topic ?? room?.topic, - actions: [ - if (room == null) - SheetAction( - key: SpaceChildContextAction.join, - label: L10n.of(context)!.joinRoom, - icon: Icons.send_outlined, + PopupMenuItem( + value: room.markedUnread + ? SpaceChildAction.markAsRead + : SpaceChildAction.markAsUnread, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + room.markedUnread + ? Icons.mark_as_unread + : Icons.mark_as_unread_outlined, + ), + const SizedBox(width: 12), + Text( + room.isUnread + ? L10n.of(context).markAsRead + : L10n.of(context).markAsUnread, + ), + ], + ), ), - if (spaceChild != null && - (activeSpace?.canChangeStateEvent(EventTypes.SpaceChild) ?? false)) - SheetAction( - key: SpaceChildContextAction.removeFromSpace, - label: L10n.of(context)!.removeFromSpace, - icon: Icons.delete_sweep_outlined, + PopupMenuItem( + value: SpaceChildAction.leave, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + Icons.delete_outlined, + color: Theme.of(context).colorScheme.onErrorContainer, + ), + const SizedBox(width: 12), + Text( + L10n.of(context).leave, + style: TextStyle( + color: Theme.of(context).colorScheme.onErrorContainer, + ), + ), + ], + ), ), - if (room != null) - SheetAction( - key: SpaceChildContextAction.leave, - label: L10n.of(context)!.leave, - icon: Icons.delete_outlined, - isDestructiveAction: true, + ], + if (space.canChangeStateEvent(EventTypes.SpaceChild) == true) + PopupMenuItem( + value: SpaceChildAction.removeFromSpace, + child: Row( + mainAxisSize: .min, + children: [ + Icon( + Icons.remove, + color: Theme.of(context).colorScheme.onErrorContainer, + ), + const SizedBox(width: 12), + Text( + L10n.of(context).removeFromSpace, + style: TextStyle( + color: Theme.of(context).colorScheme.onErrorContainer, + ), + ), + ], + ), ), ], ); if (action == null) return; - + if (!mounted) return; switch (action) { - case SpaceChildContextAction.join: - _onJoinSpaceChild(spaceChild!); - break; - case SpaceChildContextAction.leave: + case SpaceChildAction.removeFromSpace: + final consent = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).removeFromSpace, + message: L10n.of(context).removeFromSpaceDescription, + ); + if (consent != OkCancelResult.ok) return; + if (!mounted) return; + final result = await showFutureLoadingDialog( + context: context, + future: () => space.removeSpaceChild(roomId), + ); + if (result.isError) return; + if (!mounted) return; + _nextBatch = null; + return; + case SpaceChildAction.mute: await showFutureLoadingDialog( context: context, - future: room!.leave, + future: () => room!.setPushRuleState(PushRuleState.mentionsOnly), ); - break; - case SpaceChildContextAction.removeFromSpace: + case SpaceChildAction.unmute: await showFutureLoadingDialog( context: context, - future: () => activeSpace!.removeSpaceChild(spaceChild!.roomId), + future: () => room!.setPushRuleState(PushRuleState.notify), + ); + case SpaceChildAction.markAsUnread: + await showFutureLoadingDialog( + context: context, + future: () => room!.markUnread(true), + ); + case SpaceChildAction.markAsRead: + await showFutureLoadingDialog( + context: context, + future: () => room!.markUnread(false), + ); + case SpaceChildAction.leave: + await showFutureLoadingDialog( + context: context, + future: () => room!.leave(), ); - break; } } - void _addChatOrSubSpace() async { - final roomType = await showConfirmationDialog( - context: context, - title: L10n.of(context)!.addChatOrSubSpace, - actions: [ - AlertDialogAction( - key: AddRoomType.subspace, - label: L10n.of(context)!.createNewSpace, - ), - AlertDialogAction( - key: AddRoomType.chat, - label: L10n.of(context)!.createGroup, - ), - ], - ); - if (roomType == null) return; - - final names = await showTextInputDialog( - context: context, - title: roomType == AddRoomType.subspace - ? L10n.of(context)!.createNewSpace - : L10n.of(context)!.createGroup, - textFields: [ - DialogTextField( - hintText: roomType == AddRoomType.subspace - ? L10n.of(context)!.spaceName - : L10n.of(context)!.groupName, - minLines: 1, - maxLines: 1, - maxLength: 64, - validator: (text) { - if (text == null || text.isEmpty) { - return L10n.of(context)!.pleaseChoose; - } - return null; - }, - ), - DialogTextField( - hintText: L10n.of(context)!.chatDescription, - minLines: 4, - maxLines: 8, - maxLength: 255, - ), - ], - okLabel: L10n.of(context)!.create, - cancelLabel: L10n.of(context)!.cancel, - ); - if (names == null) return; - final client = Matrix.of(context).client; - final result = await showFutureLoadingDialog( - context: context, - future: () async { - late final String roomId; - final activeSpace = client.getRoomById( - widget.controller.activeSpaceId!, - )!; - - if (roomType == AddRoomType.subspace) { - roomId = await client.createSpace( - name: names.first, - topic: names.last.isEmpty ? null : names.last, - visibility: activeSpace.joinRules == JoinRules.public - ? sdk.Visibility.public - : sdk.Visibility.private, - ); - } else { - roomId = await client.createGroupChat( - groupName: names.first, - initialState: names.length > 1 && names.last.isNotEmpty - ? [ - sdk.StateEvent( - type: sdk.EventTypes.RoomTopic, - content: {'topic': names.last}, - ), - ] - : null, - ); - } - await activeSpace.setSpaceChild(roomId); - }, - ); - if (result.error != null) return; - _refresh(); - } - @override Widget build(BuildContext context) { - final client = Matrix.of(context).client; - final activeSpaceId = widget.controller.activeSpaceId; - final activeSpace = activeSpaceId == null - ? null - : client.getRoomById( - activeSpaceId, - ); - final allSpaces = client.rooms.where((room) => room.isSpace); - if (activeSpaceId == null) { - final rootSpaces = allSpaces - .where( - (space) => - !allSpaces.any( - (parentSpace) => parentSpace.spaceChildren - .any((child) => child.roomId == space.id), - ) && - space - .getLocalizedDisplayname(MatrixLocals(L10n.of(context)!)) - .toLowerCase() - .contains( - widget.controller.searchController.text.toLowerCase(), - ), - ) - .toList(); + final theme = Theme.of(context); - return SafeArea( - child: CustomScrollView( - controller: widget.scrollController, - slivers: [ - ChatListHeader(controller: widget.controller), - SliverList( - delegate: SliverChildBuilderDelegate( - (context, i) { - final rootSpace = rootSpaces[i]; - final displayname = rootSpace.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), - ); - return Material( - color: Theme.of(context).colorScheme.surface, - child: ListTile( - leading: Avatar( - mxContent: rootSpace.avatar, - name: displayname, - ), - title: Text( - displayname, - maxLines: 1, - overflow: TextOverflow.ellipsis, - ), - subtitle: Text( - L10n.of(context)!.numChats( - rootSpace.spaceChildren.length.toString(), - ), - ), - onTap: () => - widget.controller.setActiveSpace(rootSpace.id), - onLongPress: () => - _onSpaceChildContextMenu(null, rootSpace), - trailing: const Icon(Icons.chevron_right_outlined), - ), - ); - }, - childCount: rootSpaces.length, - ), + final room = Matrix.of(context).client.getRoomById(widget.spaceId); + final displayname = + room?.getLocalizedDisplayname() ?? L10n.of(context).nothingFound; + const avatarSize = Avatar.defaultSize / 1.5; + final isAdmin = room?.canChangeStateEvent(EventTypes.SpaceChild) == true; + return Scaffold( + appBar: AppBar( + leading: FluffyThemes.isColumnMode(context) + ? null + : Center(child: CloseButton(onPressed: widget.onBack)), + automaticallyImplyLeading: false, + titleSpacing: FluffyThemes.isColumnMode(context) ? null : 0, + title: ListTile( + contentPadding: EdgeInsets.zero, + leading: Avatar( + size: avatarSize, + mxContent: room?.avatar, + name: displayname, + shapeBorder: RoundedSuperellipseBorder( + side: BorderSide(width: 1, color: theme.dividerColor), + borderRadius: BorderRadius.circular(AppConfig.spaceBorderRadius), ), - ], + borderRadius: BorderRadius.circular(AppConfig.spaceBorderRadius), + ), + title: Text( + displayname, + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), ), - ); - } - - final parentSpace = allSpaces.firstWhereOrNull( - (space) => - space.spaceChildren.any((child) => child.roomId == activeSpaceId), - ); - return PopScope( - canPop: parentSpace == null, - onPopInvoked: (pop) async { - if (pop) return; - if (parentSpace != null) { - widget.controller.setActiveSpace(parentSpace.id); - } - }, - child: SafeArea( - child: CustomScrollView( - controller: widget.scrollController, - slivers: [ - ChatListHeader(controller: widget.controller, globalSearch: false), - SliverAppBar( - automaticallyImplyLeading: false, - primary: false, - titleSpacing: 0, - title: ListTile( - leading: BackButton( - onPressed: () => - widget.controller.setActiveSpace(parentSpace?.id), - ), - title: Text( - parentSpace == null - ? L10n.of(context)!.allSpaces - : parentSpace.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), - ), - ), - trailing: IconButton( - icon: loading - ? const CircularProgressIndicator.adaptive(strokeWidth: 2) - : const Icon(Icons.refresh_outlined), - onPressed: loading ? null : _refresh, + actions: [ + if (isAdmin) + IconButton( + icon: Icon(Icons.add_outlined), + tooltip: L10n.of(context).addChatOrSubSpace, + onPressed: () => + context.go('/rooms/newgroup?space_id=${widget.spaceId}'), + ), + PopupMenuButton( + useRootNavigator: true, + onSelected: _onSpaceAction, + itemBuilder: (context) => [ + PopupMenuItem( + value: SpaceActions.settings, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.settings_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).settings), + ], ), ), - ), - Builder( - builder: (context) { - final response = _lastResponse[activeSpaceId]; - final error = this.error; - if (error != null) { - return SliverFillRemaining( - child: Column( - crossAxisAlignment: CrossAxisAlignment.center, - mainAxisAlignment: MainAxisAlignment.center, - children: [ - Padding( - padding: const EdgeInsets.all(16.0), - child: Text(error.toLocalizedString(context)), - ), - IconButton( - onPressed: _refresh, - icon: const Icon(Icons.refresh_outlined), - ), - ], + PopupMenuItem( + value: SpaceActions.invite, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.person_add_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).invite), + ], + ), + ), + PopupMenuItem( + value: SpaceActions.members, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.group_outlined), + const SizedBox(width: 12), + Text( + L10n.of(context).countParticipants( + room?.summary.mJoinedMemberCount ?? 1, + ), ), - ); - } - if (response == null) { - return SliverFillRemaining( - child: Center( - child: Text(L10n.of(context)!.loadingPleaseWait), + ], + ), + ), + PopupMenuItem( + value: SpaceActions.leave, + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.delete_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).leave), + ], + ), + ), + ], + ), + ], + ), + body: room == null + ? const Center(child: Icon(Icons.search_outlined, size: 80)) + : StreamBuilder( + stream: room.client.onSync.stream + .where((s) => s.hasRoomUpdate) + .rateLimit(const Duration(seconds: 1)), + builder: (context, snapshot) { + final filter = _filterController.text.trim().toLowerCase(); + return CustomScrollView( + slivers: [ + SliverAppBar( + floating: true, + scrolledUnderElevation: 0, + backgroundColor: Colors.transparent, + automaticallyImplyLeading: false, + title: TextField( + controller: _filterController, + onChanged: (_) => setState(() {}), + textInputAction: TextInputAction.search, + decoration: InputDecoration( + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + contentPadding: EdgeInsets.zero, + hintText: L10n.of(context).search, + hintStyle: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontWeight: FontWeight.normal, + ), + floatingLabelBehavior: FloatingLabelBehavior.never, + prefixIcon: IconButton( + onPressed: () {}, + icon: Icon( + Icons.search_outlined, + color: theme.colorScheme.onPrimaryContainer, + ), + ), + ), + ), ), - ); - } - final spaceChildren = response.rooms; - final canLoadMore = response.nextBatch != null; - return SliverList( - delegate: SliverChildBuilderDelegate( - (context, i) { - if (canLoadMore && i == spaceChildren.length) { + SliverList.builder( + itemCount: _discoveredChildren.length + 1, + itemBuilder: (context, i) { + if (i == _discoveredChildren.length) { + if (_noMoreRooms) { + return const SizedBox.shrink(); + } + return Padding( + padding: const EdgeInsets.symmetric( + horizontal: 12.0, + vertical: 2.0, + ), + child: TextButton( + onPressed: _isLoading ? null : _loadHierarchy, + child: _isLoading + ? const CircularProgressIndicator.adaptive() + : Text(L10n.of(context).loadMore), + ), + ); + } + final item = _discoveredChildren[i]; + final displayname = + item.name ?? + item.canonicalAlias ?? + L10n.of(context).emptyChat; + if (!displayname.toLowerCase().contains(filter)) { + return const SizedBox.shrink(); + } + var joinedRoom = room.client.getRoomById(item.roomId); + if (joinedRoom?.membership == Membership.leave) { + joinedRoom = null; + } + return Padding( - padding: const EdgeInsets.all(16.0), - child: OutlinedButton.icon( - label: loading - ? const LinearProgressIndicator() - : Text(L10n.of(context)!.loadMore), - icon: const Icon(Icons.chevron_right_outlined), - onPressed: loading - ? null - : () { - loadHierarchy(response.nextBatch); - }, + padding: const EdgeInsets.symmetric( + horizontal: 8, + vertical: 1, ), - ); - } - final spaceChild = spaceChildren[i]; - final room = client.getRoomById(spaceChild.roomId); - if (room != null && !room.isSpace) { - return ChatListItem( - room, - onLongPress: () => - _onSpaceChildContextMenu(spaceChild, room), - activeChat: widget.controller.activeChat == room.id, - onTap: () => onChatTap(room, context), - ); - } - final isSpace = spaceChild.roomType == 'm.space'; - final topic = spaceChild.topic?.isEmpty ?? true - ? null - : spaceChild.topic; - if (spaceChild.roomId == activeSpaceId) { - return Column( - mainAxisSize: MainAxisSize.min, - children: [ - SearchTitle( - title: spaceChild.name ?? - spaceChild.canonicalAlias ?? - 'Space', - icon: Padding( - padding: const EdgeInsets.symmetric( - horizontal: 10.0, - ), - child: Avatar( - size: 24, - mxContent: spaceChild.avatarUrl, - name: spaceChild.name, - ), - ), - color: Theme.of(context) - .colorScheme - .secondaryContainer - .withAlpha(128), - trailing: const Padding( - padding: EdgeInsets.symmetric(horizontal: 16.0), - child: Icon(Icons.edit_outlined), - ), - onTap: () => _onJoinSpaceChild(spaceChild), + child: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, ), - if (activeSpace?.canChangeStateEvent( - EventTypes.SpaceChild, - ) == - true) - Material( - child: ListTile( - leading: const CircleAvatar( - child: Icon(Icons.group_add_outlined), - ), - title: - Text(L10n.of(context)!.addChatOrSubSpace), - trailing: - const Icon(Icons.chevron_right_outlined), - onTap: _addChatOrSubSpace, + clipBehavior: Clip.hardEdge, + color: + joinedRoom != null && + widget.activeChat == joinedRoom.id + ? theme.colorScheme.secondaryContainer + : Colors.transparent, + child: HoverBuilder( + builder: (context, hovered) => ListTile( + visualDensity: const VisualDensity( + vertical: -0.5, + ), + contentPadding: EdgeInsets.only( + left: 8, + right: joinedRoom == null ? 0 : 8, + ), + onTap: joinedRoom != null + ? () => widget.onChatTab(joinedRoom!) + : null, + onLongPress: joinedRoom != null + ? () => _showSpaceChildEditMenu( + context, + item.roomId, + ) + : null, + leading: hovered + ? SizedBox.square( + dimension: avatarSize, + child: IconButton( + splashRadius: avatarSize, + iconSize: 14, + style: IconButton.styleFrom( + foregroundColor: theme + .colorScheme + .onTertiaryContainer, + backgroundColor: theme + .colorScheme + .tertiaryContainer, + ), + onPressed: + isAdmin || joinedRoom != null + ? () => _showSpaceChildEditMenu( + context, + item.roomId, + ) + : null, + icon: const Icon(Icons.edit_outlined), + ), + ) + : Avatar( + size: avatarSize, + mxContent: item.avatarUrl, + name: '#', + backgroundColor: + theme.colorScheme.surfaceContainer, + textColor: + item.name?.darkColor ?? + theme.colorScheme.onSurface, + shapeBorder: item.roomType == 'm.space' + ? RoundedSuperellipseBorder( + side: BorderSide( + color: theme + .colorScheme + .surfaceContainerHighest, + ), + borderRadius: + BorderRadius.circular( + AppConfig.borderRadius / + 4, + ), + ) + : null, + borderRadius: item.roomType == 'm.space' + ? BorderRadius.circular( + AppConfig.borderRadius / 4, + ) + : null, + ), + title: Row( + children: [ + Expanded( + child: Opacity( + opacity: joinedRoom == null ? 0.5 : 1, + child: Text( + displayname, + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + ), + ), + if (joinedRoom != null && + joinedRoom.pushRuleState != + PushRuleState.notify) + const Padding( + padding: EdgeInsets.only(left: 4.0), + child: Icon( + Icons.notifications_off_outlined, + size: 16, + ), + ), + if (joinedRoom != null) + UnreadBubble(room: joinedRoom) + else + TextButton( + onPressed: () => _joinChildRoom(item), + child: Text(L10n.of(context).join), + ), + ], ), ), - ], - ); - } - final name = spaceChild.name ?? - spaceChild.canonicalAlias ?? - L10n.of(context)!.chat; - if (widget.controller.isSearchMode && - !name.toLowerCase().contains( - widget.controller.searchController.text - .toLowerCase(), - )) { - return const SizedBox.shrink(); - } - return Material( - child: ListTile( - leading: Avatar( - mxContent: spaceChild.avatarUrl, - name: spaceChild.name, - ), - title: Row( - children: [ - Expanded( - child: Text( - name, - maxLines: 1, - style: const TextStyle( - fontWeight: FontWeight.bold, - ), - ), - ), - if (!isSpace) ...[ - const Icon( - Icons.people_outline, - size: 16, - ), - const SizedBox(width: 4), - Text( - spaceChild.numJoinedMembers.toString(), - style: const TextStyle(fontSize: 14), - ), - ], - ], - ), - onTap: () => room?.isSpace == true - ? widget.controller.setActiveSpace(room!.id) - : _onSpaceChildContextMenu(spaceChild, room), - onLongPress: () => - _onSpaceChildContextMenu(spaceChild, room), - subtitle: Text( - topic ?? - (isSpace - ? L10n.of(context)!.enterSpace - : L10n.of(context)!.enterRoom), - maxLines: 1, - style: TextStyle( - color: Theme.of(context).colorScheme.onSurface, ), ), - trailing: isSpace - ? const Icon(Icons.chevron_right_outlined) - : null, - ), - ); - }, - childCount: spaceChildren.length + (canLoadMore ? 1 : 0), - ), + ); + }, + ), + const SliverPadding(padding: EdgeInsets.only(top: 32)), + ], ); }, ), - ], - ), - ), ); } } - -enum SpaceChildContextAction { - join, - leave, - removeFromSpace, -} - -enum AddRoomType { chat, subspace } diff --git a/lib/pages/chat_list/start_chat_fab.dart b/lib/pages/chat_list/start_chat_fab.dart index c6a74c0fd..3f206b2a3 100644 --- a/lib/pages/chat_list/start_chat_fab.dart +++ b/lib/pages/chat_list/start_chat_fab.dart @@ -1,88 +1,21 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; -import '../../config/themes.dart'; -import 'chat_list.dart'; +import 'package:fluffychat/l10n/l10n.dart'; -class StartChatFloatingActionButton extends StatelessWidget { - final ActiveFilter activeFilter; - final ValueNotifier scrolledToTop; - final bool roomsIsEmpty; - final void Function() createNewSpace; - - const StartChatFloatingActionButton({ - super.key, - required this.activeFilter, - required this.scrolledToTop, - required this.roomsIsEmpty, - required this.createNewSpace, - }); - - void _onPressed(BuildContext context) async { - switch (activeFilter) { - case ActiveFilter.allChats: - case ActiveFilter.messages: - context.go('/rooms/newprivatechat'); - break; - case ActiveFilter.groups: - context.go('/rooms/newgroup'); - break; - case ActiveFilter.spaces: - createNewSpace(); - break; - } - } - - IconData get icon { - switch (activeFilter) { - case ActiveFilter.allChats: - case ActiveFilter.messages: - return Icons.add_outlined; - case ActiveFilter.groups: - return Icons.group_add_outlined; - case ActiveFilter.spaces: - return Icons.workspaces_outlined; - } - } - - String getLabel(BuildContext context) { - switch (activeFilter) { - case ActiveFilter.allChats: - case ActiveFilter.messages: - return roomsIsEmpty - ? L10n.of(context)!.startFirstChat - : L10n.of(context)!.newChat; - case ActiveFilter.groups: - return L10n.of(context)!.newGroup; - case ActiveFilter.spaces: - return L10n.of(context)!.newSpace; - } - } +class StartChatFab extends StatelessWidget { + const StartChatFab({super.key}); @override Widget build(BuildContext context) { - return ValueListenableBuilder( - valueListenable: scrolledToTop, - builder: (context, scrolledToTop, _) => AnimatedSize( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - clipBehavior: Clip.none, - child: scrolledToTop - ? FloatingActionButton.extended( - onPressed: () => _onPressed(context), - icon: Icon(icon), - label: Text( - getLabel(context), - overflow: TextOverflow.fade, - ), - ) - : FloatingActionButton( - onPressed: () => _onPressed(context), - child: Icon(icon), - ), - ), + return FloatingActionButton( + heroTag: 'start_chat_fab', + backgroundColor: Theme.of(context).colorScheme.primary, + foregroundColor: Theme.of(context).colorScheme.onPrimary, + onPressed: () => context.go('/rooms/newprivatechat'), + tooltip: L10n.of(context).newChat, + child: const Icon(Icons.edit_square), ); } } diff --git a/lib/pages/chat_list/status_msg_list.dart b/lib/pages/chat_list/status_msg_list.dart index 9b69e2a16..7677e031f 100644 --- a/lib/pages/chat_list/status_msg_list.dart +++ b/lib/pages/chat_list/status_msg_list.dart @@ -4,19 +4,16 @@ import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/themes.dart'; -import 'package:fluffychat/pages/user_bottom_sheet/user_bottom_sheet.dart'; -import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/stream_extension.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/hover_builder.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import '../../widgets/adaptive_dialogs/user_dialog.dart'; class StatusMessageList extends StatelessWidget { final void Function() onStatusEdit; - const StatusMessageList({ - required this.onStatusEdit, - super.key, - }); + + const StatusMessageList({required this.onStatusEdit, super.key}); static const double height = 116; @@ -24,13 +21,7 @@ class StatusMessageList extends StatelessWidget { final client = Matrix.of(context).client; if (profile.userId == client.userID) return onStatusEdit(); - showAdaptiveBottomSheet( - context: context, - builder: (c) => UserBottomSheet( - profile: profile, - outerContext: context, - ), - ); + UserDialog.show(context: context, profile: profile); return; } @@ -59,8 +50,9 @@ class StatusMessageList extends StatelessWidget { ), ), builder: (context, snapshot) { - final presences = - snapshot.data?.where(isInterestingPresence).toList(); + final presences = snapshot.data + ?.where(isInterestingPresence) + .toList(); // If no other presences than the own entry is interesting, we // hide the presence header. @@ -79,7 +71,12 @@ class StatusMessageList extends StatelessWidget { return SizedBox( height: StatusMessageList.height, child: ListView.builder( - padding: const EdgeInsets.all(8), + padding: const EdgeInsets.only( + left: 8.0, + right: 8.0, + top: 8.0, + bottom: 6.0, + ), scrollDirection: Axis.horizontal, itemCount: presences.length, itemBuilder: (context, i) => PresenceAvatar( @@ -111,22 +108,23 @@ class PresenceAvatar extends StatelessWidget { @override Widget build(BuildContext context) { - final avatarSize = height - 16 - 16 - 8; + final avatarSize = height - 16 - 16 - 6; final client = Matrix.of(context).client; return FutureBuilder( future: client.getProfileFromUserId(presence.userid), builder: (context, snapshot) { + final theme = Theme.of(context); + final profile = snapshot.data; - final displayName = profile?.displayName ?? + final displayName = + profile?.displayName ?? presence.userid.localpart ?? presence.userid; final statusMsg = presence.statusMsg; - final statusMsgBubbleElevation = - Theme.of(context).appBarTheme.scrolledUnderElevation ?? 4; - final statusMsgBubbleShadowColor = - Theme.of(context).colorScheme.onSurface; - final statusMsgBubbleColor = Colors.white.withAlpha(245); + const statusMsgBubbleElevation = 6.0; + final statusMsgBubbleShadowColor = theme.colorScheme.surfaceBright; + final statusMsgBubbleColor = Colors.white.withAlpha(212); return Padding( padding: const EdgeInsets.symmetric(horizontal: 8.0), child: SizedBox( @@ -150,13 +148,26 @@ class PresenceAvatar extends StatelessWidget { padding: const EdgeInsets.all(3), decoration: BoxDecoration( gradient: presence.gradient, - borderRadius: - BorderRadius.circular(avatarSize), + borderRadius: BorderRadius.circular( + avatarSize, + ), ), - child: Avatar( - name: displayName, - mxContent: profile?.avatarUrl, - size: avatarSize - 6, + alignment: Alignment.center, + child: Container( + height: avatarSize - 6, + alignment: Alignment.center, + decoration: BoxDecoration( + color: theme.colorScheme.surface, + borderRadius: BorderRadius.circular( + avatarSize, + ), + ), + padding: const EdgeInsets.all(3.0), + child: Avatar( + name: displayName, + mxContent: profile?.avatarUrl, + size: avatarSize - 12, + ), ), ), if (presence.userid == client.userID) @@ -186,58 +197,70 @@ class PresenceAvatar extends StatelessWidget { Positioned( left: 0, top: 0, - right: 8, - child: Material( - elevation: statusMsgBubbleElevation, - shadowColor: statusMsgBubbleShadowColor, - borderRadius: BorderRadius.circular( - AppConfig.borderRadius / 2, - ), - color: statusMsgBubbleColor, - child: Padding( - padding: const EdgeInsets.all(2.0), - child: Text( - statusMsg, - maxLines: 2, - overflow: TextOverflow.ellipsis, - style: const TextStyle( - color: Colors.black, - fontSize: 10.5, + right: 0, + child: Column( + spacing: 2, + crossAxisAlignment: .start, + mainAxisSize: .min, + children: [ + Material( + elevation: statusMsgBubbleElevation, + shadowColor: statusMsgBubbleShadowColor, + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 2, + ), + color: statusMsgBubbleColor, + child: Padding( + padding: const EdgeInsets.symmetric( + vertical: 2.0, + horizontal: 4.0, + ), + child: Text( + statusMsg, + maxLines: 2, + overflow: TextOverflow.ellipsis, + style: const TextStyle( + color: Colors.black, + fontSize: 9, + ), + ), ), ), - ), - ), - ), - Positioned( - left: 8, - top: 32, - child: Material( - color: statusMsgBubbleColor, - elevation: statusMsgBubbleElevation, - shadowColor: statusMsgBubbleShadowColor, - borderRadius: BorderRadius.circular( - AppConfig.borderRadius / 2, - ), - child: const SizedBox( - width: 8, - height: 8, - ), - ), - ), - Positioned( - left: 14, - top: 40, - child: Material( - color: statusMsgBubbleColor, - elevation: statusMsgBubbleElevation, - shadowColor: statusMsgBubbleShadowColor, - borderRadius: BorderRadius.circular( - AppConfig.borderRadius / 2, - ), - child: const SizedBox( - width: 4, - height: 4, - ), + Padding( + padding: const EdgeInsets.only( + left: 8.0, + ), + child: Material( + color: statusMsgBubbleColor, + elevation: statusMsgBubbleElevation, + shadowColor: + statusMsgBubbleShadowColor, + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + child: const SizedBox.square( + dimension: 8, + ), + ), + ), + Padding( + padding: const EdgeInsets.only( + left: 13.0, + ), + child: Material( + color: statusMsgBubbleColor, + elevation: statusMsgBubbleElevation, + shadowColor: + statusMsgBubbleShadowColor, + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + child: const SizedBox.square( + dimension: 5, + ), + ), + ), + ], ), ), ], @@ -256,9 +279,7 @@ class PresenceAvatar extends StatelessWidget { textAlign: TextAlign.center, maxLines: 1, overflow: TextOverflow.ellipsis, - style: const TextStyle( - fontSize: 13, - ), + style: const TextStyle(fontSize: 11), ), ), ], @@ -272,10 +293,12 @@ class PresenceAvatar extends StatelessWidget { extension on Client { Set get interestingPresences { - final allHeroes = rooms.map((room) => room.summary.mHeroes).fold( - {}, - (previousValue, element) => previousValue..addAll(element ?? {}), - ); + final allHeroes = rooms + .map((room) => room.summary.mHeroes) + .fold( + {}, + (previousValue, element) => previousValue..addAll(element ?? {}), + ); allHeroes.add(userID!); return allHeroes; } @@ -290,33 +313,26 @@ extension on CachedPresence { (currentlyActive == true ? DateTime.now() : DateTime.fromMillisecondsSinceEpoch(0)); + LinearGradient get gradient => presence.isOnline == true ? LinearGradient( - colors: [ - Colors.green, - Colors.green.shade200, - Colors.green.shade900, - ], + colors: [Colors.green, Colors.green.shade200, Colors.green.shade900], begin: Alignment.topLeft, end: Alignment.bottomRight, ) : presence.isUnavailable - ? LinearGradient( - colors: [ - Colors.yellow, - Colors.yellow.shade200, - Colors.yellow.shade900, - ], - begin: Alignment.topLeft, - end: Alignment.bottomRight, - ) - : LinearGradient( - colors: [ - Colors.grey, - Colors.grey.shade200, - Colors.grey.shade900, - ], - begin: Alignment.topLeft, - end: Alignment.bottomRight, - ); + ? LinearGradient( + colors: [ + Colors.yellow, + Colors.yellow.shade200, + Colors.yellow.shade900, + ], + begin: Alignment.topLeft, + end: Alignment.bottomRight, + ) + : LinearGradient( + colors: [Colors.grey, Colors.grey.shade200, Colors.grey.shade900], + begin: Alignment.topLeft, + end: Alignment.bottomRight, + ); } diff --git a/lib/pages/chat_list/unread_bubble.dart b/lib/pages/chat_list/unread_bubble.dart new file mode 100644 index 000000000..9dfd92490 --- /dev/null +++ b/lib/pages/chat_list/unread_bubble.dart @@ -0,0 +1,56 @@ +import 'package:flutter/material.dart'; + +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/config/themes.dart'; + +class UnreadBubble extends StatelessWidget { + final Room room; + const UnreadBubble({required this.room, super.key}); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + final unread = room.isUnread; + final hasNotifications = room.notificationCount > 0; + final unreadBubbleSize = unread || room.hasNewMessages + ? room.notificationCount > 0 + ? 20.0 + : 14.0 + : 0.0; + return AnimatedContainer( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + alignment: Alignment.center, + padding: const EdgeInsets.symmetric(horizontal: 7), + height: unreadBubbleSize, + width: !hasNotifications && !unread && !room.hasNewMessages + ? 0 + : (unreadBubbleSize - 9) * room.notificationCount.toString().length + + 9, + decoration: BoxDecoration( + color: room.highlightCount > 0 + ? theme.colorScheme.error + : hasNotifications || room.markedUnread + ? theme.colorScheme.primary + : theme.colorScheme.primaryContainer, + borderRadius: BorderRadius.circular(unreadBubbleSize), + ), + child: hasNotifications || room.markedUnread + ? Text( + room.notificationCount.toString(), + style: TextStyle( + color: room.highlightCount > 0 + ? theme.colorScheme.onError + : hasNotifications + ? theme.colorScheme.onPrimary + : theme.colorScheme.onPrimaryContainer, + fontSize: 13, + fontWeight: FontWeight.w500, + ), + textAlign: .center, + ) + : const SizedBox.shrink(), + ); + } +} diff --git a/lib/pages/chat_list/utils/on_chat_tap.dart b/lib/pages/chat_list/utils/on_chat_tap.dart deleted file mode 100644 index d24af1fb4..000000000 --- a/lib/pages/chat_list/utils/on_chat_tap.dart +++ /dev/null @@ -1,127 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:go_router/go_router.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/pages/chat/send_file_dialog.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; -import 'package:fluffychat/widgets/matrix.dart'; - -void onChatTap(Room room, BuildContext context) async { - if (room.membership == Membership.invite) { - final inviterId = - room.getState(EventTypes.RoomMember, room.client.userID!)?.senderId; - final inviteAction = await showModalActionSheet( - context: context, - message: room.isDirectChat - ? L10n.of(context)!.invitePrivateChat - : L10n.of(context)!.inviteGroupChat, - title: room.getLocalizedDisplayname(MatrixLocals(L10n.of(context)!)), - actions: [ - SheetAction( - key: InviteActions.accept, - label: L10n.of(context)!.accept, - icon: Icons.check_outlined, - isDefaultAction: true, - ), - SheetAction( - key: InviteActions.decline, - label: L10n.of(context)!.decline, - icon: Icons.close_outlined, - isDestructiveAction: true, - ), - SheetAction( - key: InviteActions.block, - label: L10n.of(context)!.block, - icon: Icons.block_outlined, - isDestructiveAction: true, - ), - ], - ); - if (inviteAction == null) return; - if (inviteAction == InviteActions.block) { - context.go('/rooms/settings/security/ignorelist', extra: inviterId); - return; - } - if (inviteAction == InviteActions.decline) { - await showFutureLoadingDialog( - context: context, - future: room.leave, - ); - return; - } - final joinResult = await showFutureLoadingDialog( - context: context, - future: () async { - final waitForRoom = room.client.waitForRoomInSync( - room.id, - join: true, - ); - await room.join(); - await waitForRoom; - }, - ); - if (joinResult.error != null) return; - } - - if (room.membership == Membership.ban) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text(L10n.of(context)!.youHaveBeenBannedFromThisChat), - ), - ); - return; - } - - if (room.membership == Membership.leave) { - context.go('/rooms/archive/${room.id}'); - return; - } - - // Share content into this room - final shareContent = Matrix.of(context).shareContent; - if (shareContent != null) { - final shareFile = shareContent.tryGet('file'); - if (shareContent.tryGet('msgtype') == 'chat.fluffy.shared_file' && - shareFile != null) { - await showDialog( - context: context, - useRootNavigator: false, - builder: (c) => SendFileDialog( - files: [shareFile], - room: room, - ), - ); - Matrix.of(context).shareContent = null; - } else { - final consent = await showOkCancelAlertDialog( - context: context, - title: L10n.of(context)!.forward, - message: L10n.of(context)!.forwardMessageTo( - room.getLocalizedDisplayname(MatrixLocals(L10n.of(context)!)), - ), - okLabel: L10n.of(context)!.forward, - cancelLabel: L10n.of(context)!.cancel, - ); - if (consent == OkCancelResult.cancel) { - Matrix.of(context).shareContent = null; - return; - } - if (consent == OkCancelResult.ok) { - room.sendEvent(shareContent); - Matrix.of(context).shareContent = null; - } - } - } - - context.go('/rooms/${room.id}'); -} - -enum InviteActions { - accept, - decline, - block, -} diff --git a/lib/pages/chat_members/chat_members.dart b/lib/pages/chat_members/chat_members.dart index c777d286e..a652eff06 100644 --- a/lib/pages/chat_members/chat_members.dart +++ b/lib/pages/chat_members/chat_members.dart @@ -1,3 +1,5 @@ +import 'dart:async'; + import 'package:flutter/material.dart'; import 'package:matrix/matrix.dart'; @@ -7,6 +9,7 @@ import 'chat_members_view.dart'; class ChatMembersPage extends StatefulWidget { final String roomId; + const ChatMembersPage({required this.roomId, super.key}); @override @@ -17,12 +20,22 @@ class ChatMembersController extends State { List? members; List? filteredMembers; Object? error; + Membership membershipFilter = Membership.join; final TextEditingController filterController = TextEditingController(); - void setFilter([_]) async { + void setMembershipFilter(Membership membership) { + membershipFilter = membership; + setFilter(); + } + + Future setFilter([_]) async { final filter = filterController.text.toLowerCase().trim(); + final members = this.members + ?.where((member) => member.membership == membershipFilter) + .toList(); + if (filter.isEmpty) { setState(() { filteredMembers = members @@ -31,26 +44,29 @@ class ChatMembersController extends State { return; } setState(() { - filteredMembers = members - ?.where( - (user) => - user.displayName?.toLowerCase().contains(filter) ?? - user.id.toLowerCase().contains(filter), - ) - .toList() - ?..sort((b, a) => a.powerLevel.compareTo(b.powerLevel)); + filteredMembers = + members + ?.where( + (user) => + user.displayName?.toLowerCase().contains(filter) ?? + user.id.toLowerCase().contains(filter), + ) + .toList() + ?..sort((b, a) => a.powerLevel.compareTo(b.powerLevel)); }); } - void refreshMembers() async { + Future refreshMembers([_]) async { + Logs().d('Load room members from', widget.roomId); try { setState(() { error = null; }); - final participants = await Matrix.of(context) - .client + final participants = await Matrix.of(context).client .getRoomById(widget.roomId) - ?.requestParticipants(); + ?.requestParticipants( + [...Membership.values]..remove(Membership.leave), + ); if (!mounted) return; @@ -59,18 +75,39 @@ class ChatMembersController extends State { }); setFilter(); } catch (e, s) { - Logs() - .d('Unable to request participants. Try again in 3 seconds...', e, s); + Logs().d( + 'Unable to request participants. Try again in 3 seconds...', + e, + s, + ); setState(() { error = e; }); } } + StreamSubscription? _updateSub; + @override void initState() { super.initState(); refreshMembers(); + + _updateSub = Matrix.of(context).client.onSync.stream + .where( + (syncUpdate) => + syncUpdate.rooms?.join?[widget.roomId]?.timeline?.events?.any( + (state) => state.type == EventTypes.RoomMember, + ) ?? + false, + ) + .listen(refreshMembers); + } + + @override + void dispose() { + _updateSub?.cancel(); + super.dispose(); } @override diff --git a/lib/pages/chat_members/chat_members_view.dart b/lib/pages/chat_members/chat_members_view.dart index b699fcef0..81e15ea68 100644 --- a/lib/pages/chat_members/chat_members_view.dart +++ b/lib/pages/chat_members/chat_members_view.dart @@ -1,8 +1,9 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; import '../../widgets/layouts/max_width_body.dart'; import '../../widgets/matrix.dart'; @@ -11,43 +12,41 @@ import 'chat_members.dart'; class ChatMembersView extends StatelessWidget { final ChatMembersController controller; + const ChatMembersView(this.controller, {super.key}); @override Widget build(BuildContext context) { - final room = - Matrix.of(context).client.getRoomById(controller.widget.roomId); + final room = Matrix.of( + context, + ).client.getRoomById(controller.widget.roomId); if (room == null) { return Scaffold( - appBar: AppBar( - title: Text(L10n.of(context)!.oopsSomethingWentWrong), - ), + appBar: AppBar(title: Text(L10n.of(context).oopsSomethingWentWrong)), body: Center( - child: Text(L10n.of(context)!.youAreNoLongerParticipatingInThisChat), + child: Text(L10n.of(context).youAreNoLongerParticipatingInThisChat), ), ); } final members = controller.filteredMembers; - final roomCount = (room.summary.mJoinedMemberCount ?? 0) + + final roomCount = + (room.summary.mJoinedMemberCount ?? 0) + (room.summary.mInvitedMemberCount ?? 0); final error = controller.error; + final theme = Theme.of(context); return Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), - title: Text( - L10n.of(context)!.countParticipants(roomCount), - ), + title: Text(L10n.of(context).countParticipants(roomCount)), actions: [ if (room.canInvite) IconButton( onPressed: () => context.go('/rooms/${room.id}/invite'), - icon: const Icon( - Icons.person_add_outlined, - ), + icon: const Icon(Icons.person_add_outlined), ), ], ), @@ -59,7 +58,7 @@ class ChatMembersView extends StatelessWidget { child: Padding( padding: const EdgeInsets.all(16.0), child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ const Icon(Icons.error_outline), Text(error.toLocalizedString(context)), @@ -67,36 +66,121 @@ class ChatMembersView extends StatelessWidget { OutlinedButton.icon( onPressed: controller.refreshMembers, icon: const Icon(Icons.refresh_outlined), - label: Text(L10n.of(context)!.tryAgain), + label: Text(L10n.of(context).tryAgain), ), ], ), ), ) : members == null - ? const Center( - child: Padding( - padding: EdgeInsets.all(16.0), - child: CircularProgressIndicator.adaptive(), - ), - ) - : ListView.builder( - shrinkWrap: true, - itemCount: members.length + 1, - itemBuilder: (context, i) => i == 0 - ? Padding( - padding: const EdgeInsets.all(16.0), - child: TextField( - controller: controller.filterController, - onChanged: controller.setFilter, - decoration: InputDecoration( - prefixIcon: const Icon(Icons.search_outlined), - hintText: L10n.of(context)!.search, + ? const Center( + child: Padding( + padding: EdgeInsets.all(16.0), + child: CircularProgressIndicator.adaptive(), + ), + ) + : ListView.builder( + shrinkWrap: true, + itemCount: members.length + 1, + itemBuilder: (context, i) { + if (i == 0) { + final availableFilters = Membership.values + .where( + (membership) => + controller.members?.any( + (member) => member.membership == membership, + ) ?? + false, + ) + .toList(); + availableFilters.sort( + (a, b) => a == Membership.join ? -1 : 1, + ); + return Column( + mainAxisSize: .min, + children: [ + Padding( + padding: const EdgeInsets.all(16.0), + child: TextField( + controller: controller.filterController, + onChanged: controller.setFilter, + decoration: InputDecoration( + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + hintStyle: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontWeight: FontWeight.normal, + ), + prefixIcon: const Icon(Icons.search_outlined), + hintText: L10n.of(context).search, + ), + ), + ), + if (availableFilters.length > 1) + SizedBox( + height: 64, + child: ListView.builder( + padding: const EdgeInsets.all(12.0), + scrollDirection: Axis.horizontal, + itemCount: availableFilters.length, + itemBuilder: (context, i) => Padding( + padding: const EdgeInsets.symmetric( + horizontal: 4.0, + ), + child: FilterChip( + label: Text(switch (availableFilters[i]) { + Membership.ban => L10n.of(context).banned, + Membership.invite => + L10n.of(context).countInvited( + room.summary.mInvitedMemberCount ?? + controller.members + ?.where( + (member) => + member.membership == + Membership.invite, + ) + .length ?? + 0, + ), + Membership.join => + L10n.of(context).countParticipants( + room.summary.mJoinedMemberCount ?? + controller.members + ?.where( + (member) => + member.membership == + Membership.join, + ) + .length ?? + 0, + ), + Membership.knock => L10n.of( + context, + ).knocking, + Membership.leave => L10n.of( + context, + ).leftTheChat, + }), + selected: + controller.membershipFilter == + availableFilters[i], + onSelected: (_) => controller + .setMembershipFilter(availableFilters[i]), + ), ), ), - ) - : ParticipantListItem(members[i - 1]), - ), + ), + ], + ); + } + i--; + return ParticipantListItem(members[i]); + }, + ), ), ); } diff --git a/lib/pages/chat_permissions_settings/chat_permissions_settings.dart b/lib/pages/chat_permissions_settings/chat_permissions_settings.dart index 6ea94c105..e3dbfde40 100644 --- a/lib/pages/chat_permissions_settings/chat_permissions_settings.dart +++ b/lib/pages/chat_permissions_settings/chat_permissions_settings.dart @@ -2,12 +2,12 @@ import 'dart:developer'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_permissions_settings/chat_permissions_settings_view.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; import 'package:fluffychat/widgets/permission_slider_dialog.dart'; @@ -21,7 +21,7 @@ class ChatPermissionsSettings extends StatefulWidget { class ChatPermissionsSettingsController extends State { String? get roomId => GoRouterState.of(context).pathParameters['roomid']; - void editPowerLevel( + Future editPowerLevel( BuildContext context, String key, int currentLevel, { @@ -30,9 +30,9 @@ class ChatPermissionsSettingsController extends State { }) async { final room = Matrix.of(context).client.getRoomById(roomId!)!; if (!room.canSendEvent(EventTypes.RoomPowerLevels)) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.noPermission)), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(L10n.of(context).noPermission))); return; } newLevel ??= await showPermissionChooser( @@ -64,12 +64,13 @@ class ChatPermissionsSettingsController extends State { } Stream get onChanged => Matrix.of(context).client.onSync.stream.where( - (e) => - (e.rooms?.join?.containsKey(roomId) ?? false) && - (e.rooms!.join![roomId!]?.timeline?.events - ?.any((s) => s.type == EventTypes.RoomPowerLevels) ?? - false), - ); + (e) => + (e.rooms?.join?.containsKey(roomId) ?? false) && + (e.rooms!.join![roomId!]?.timeline?.events?.any( + (s) => s.type == EventTypes.RoomPowerLevels, + ) ?? + false), + ); @override Widget build(BuildContext context) => ChatPermissionsSettingsView(this); diff --git a/lib/pages/chat_permissions_settings/chat_permissions_settings_view.dart b/lib/pages/chat_permissions_settings/chat_permissions_settings_view.dart index 50d46c08e..e904403a1 100644 --- a/lib/pages/chat_permissions_settings/chat_permissions_settings_view.dart +++ b/lib/pages/chat_permissions_settings/chat_permissions_settings_view.dart @@ -1,8 +1,8 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_permissions_settings/chat_permissions_settings.dart'; import 'package:fluffychat/pages/chat_permissions_settings/permission_list_tile.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; @@ -15,10 +15,12 @@ class ChatPermissionsSettingsView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.chatPermissions), + title: Text(L10n.of(context).chatPermissions), ), body: MaxWidthBody( child: StreamBuilder( @@ -29,7 +31,7 @@ class ChatPermissionsSettingsView extends StatelessWidget { ? null : Matrix.of(context).client.getRoomById(roomId); if (room == null) { - return Center(child: Text(L10n.of(context)!.noRoomsFound)); + return Center(child: Text(L10n.of(context).noRoomsFound)); } final powerLevelsContent = Map.from( room.getState(EventTypes.RoomPowerLevels)?.content ?? {}, @@ -41,8 +43,22 @@ class ChatPermissionsSettingsView extends StatelessWidget { )..removeWhere((k, v) => v is! int); return Column( children: [ + ListTile( + leading: const Icon(Icons.info_outlined), + subtitle: Text(L10n.of(context).chatPermissionsDescription), + ), + Divider(color: theme.dividerColor), + ListTile( + title: Text( + L10n.of(context).chatPermissions, + style: TextStyle( + color: theme.colorScheme.primary, + fontWeight: FontWeight.bold, + ), + ), + ), Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ for (final entry in powerLevels.entries) PermissionsListTile( @@ -56,12 +72,12 @@ class ChatPermissionsSettingsView extends StatelessWidget { ), canEdit: room.canChangePowerLevel, ), - Divider(color: Theme.of(context).dividerColor), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.notifications, + L10n.of(context).notifications, style: TextStyle( - color: Theme.of(context).colorScheme.primary, + color: theme.colorScheme.primary, fontWeight: FontWeight.bold, ), ), @@ -69,12 +85,14 @@ class ChatPermissionsSettingsView extends StatelessWidget { Builder( builder: (context) { const key = 'rooms'; - final value = powerLevelsContent - .containsKey('notifications') + final value = + powerLevelsContent.containsKey('notifications') ? powerLevelsContent - .tryGetMap('notifications') - ?.tryGet('rooms') ?? - 0 + .tryGetMap( + 'notifications', + ) + ?.tryGet('rooms') ?? + 0 : 0; return PermissionsListTile( permissionKey: key, @@ -91,12 +109,12 @@ class ChatPermissionsSettingsView extends StatelessWidget { ); }, ), - Divider(color: Theme.of(context).dividerColor), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.configureChat, + L10n.of(context).configureChat, style: TextStyle( - color: Theme.of(context).colorScheme.primary, + color: theme.colorScheme.primary, fontWeight: FontWeight.bold, ), ), diff --git a/lib/pages/chat_permissions_settings/permission_list_tile.dart b/lib/pages/chat_permissions_settings/permission_list_tile.dart index af447cbec..7344ba5b7 100644 --- a/lib/pages/chat_permissions_settings/permission_list_tile.dart +++ b/lib/pages/chat_permissions_settings/permission_list_tile.dart @@ -1,9 +1,9 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; class PermissionsListTile extends StatelessWidget { final String permissionKey; @@ -25,43 +25,45 @@ class PermissionsListTile extends StatelessWidget { if (category == null) { switch (permissionKey) { case 'users_default': - return L10n.of(context)!.defaultPermissionLevel; + return L10n.of(context).defaultPermissionLevel; case 'events_default': - return L10n.of(context)!.sendMessages; + return L10n.of(context).sendMessages; case 'state_default': - return L10n.of(context)!.configureChat; + return L10n.of(context).changeGeneralChatSettings; case 'ban': - return L10n.of(context)!.banFromChat; + return L10n.of(context).banFromChat; case 'kick': - return L10n.of(context)!.kickFromChat; + return L10n.of(context).kickFromChat; case 'redact': - return L10n.of(context)!.deleteMessage; + return L10n.of(context).deleteMessage; case 'invite': - return L10n.of(context)!.inviteContact; + return L10n.of(context).inviteOtherUsers; } } else if (category == 'notifications') { switch (permissionKey) { case 'rooms': - return L10n.of(context)!.notifications; + return L10n.of(context).sendRoomNotifications; } } else if (category == 'events') { switch (permissionKey) { case EventTypes.RoomName: - return L10n.of(context)!.changeTheNameOfTheGroup; + return L10n.of(context).changeTheNameOfTheGroup; + case EventTypes.RoomTopic: + return L10n.of(context).changeTheDescriptionOfTheGroup; case EventTypes.RoomPowerLevels: - return L10n.of(context)!.chatPermissions; + return L10n.of(context).changeTheChatPermissions; case EventTypes.HistoryVisibility: - return L10n.of(context)!.visibilityOfTheChatHistory; + return L10n.of(context).changeTheVisibilityOfChatHistory; case EventTypes.RoomCanonicalAlias: - return L10n.of(context)!.setInvitationLink; + return L10n.of(context).changeTheCanonicalRoomAlias; case EventTypes.RoomAvatar: - return L10n.of(context)!.editRoomAvatar; + return L10n.of(context).editRoomAvatar; case EventTypes.RoomTombstone: - return L10n.of(context)!.replaceRoomWithNewerVersion; + return L10n.of(context).replaceRoomWithNewerVersion; case EventTypes.Encryption: - return L10n.of(context)!.enableEncryption; + return L10n.of(context).enableEncryption; case 'm.room.server_acl': - return L10n.of(context)!.editBlockedServers; + return L10n.of(context).editBlockedServers; } } return permissionKey; @@ -69,37 +71,51 @@ class PermissionsListTile extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + + final color = permission >= 100 + ? Colors.orangeAccent + : permission >= 50 + ? Colors.blueAccent + : Colors.greenAccent; return ListTile( - title: Text(getLocalizedPowerLevelString(context)), - subtitle: Text( - L10n.of(context)!.minimumPowerLevel(permission.toString()), + title: Text( + getLocalizedPowerLevelString(context), + style: theme.textTheme.titleSmall, ), trailing: Material( + color: color.withAlpha(32), borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), - color: Theme.of(context).colorScheme.onInverseSurface, child: DropdownButton( padding: const EdgeInsets.symmetric(horizontal: 8.0), borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), underline: const SizedBox.shrink(), onChanged: canEdit ? onChanged : null, - value: {0, 50, 100}.contains(permission) ? permission : null, + value: permission, items: [ DropdownMenuItem( - value: 0, - child: Text(L10n.of(context)!.user), + value: permission < 50 ? permission : 0, + child: Text( + L10n.of(context).userLevel(permission < 50 ? permission : 0), + ), ), DropdownMenuItem( - value: 50, - child: Text(L10n.of(context)!.moderator), + value: permission < 100 && permission >= 50 ? permission : 50, + child: Text( + L10n.of(context).moderatorLevel( + permission < 100 && permission >= 50 ? permission : 50, + ), + ), ), DropdownMenuItem( - value: 100, - child: Text(L10n.of(context)!.admin), - ), - DropdownMenuItem( - value: null, - child: Text(L10n.of(context)!.custom), + value: permission >= 100 ? permission : 100, + child: Text( + L10n.of( + context, + ).adminLevel(permission >= 100 ? permission : 100), + ), ), + DropdownMenuItem(value: null, child: Text(L10n.of(context).custom)), ], ), ), diff --git a/lib/pages/chat_search/chat_search_files_tab.dart b/lib/pages/chat_search/chat_search_files_tab.dart index 85525ab6f..4aa95225d 100644 --- a/lib/pages/chat_search/chat_search_files_tab.dart +++ b/lib/pages/chat_search/chat_search_files_tab.dart @@ -1,176 +1,109 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat_search/search_footer.dart'; import 'package:fluffychat/utils/date_time_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/event_extension.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; class ChatSearchFilesTab extends StatelessWidget { final Room room; - final Stream<(List, String?)>? searchStream; - final void Function({ - String? prevBatch, - List? previousSearchResult, - }) startSearch; + final List events; + final void Function() onStartSearch; + final bool endReached, isLoading; + final DateTime? searchedUntil; const ChatSearchFilesTab({ required this.room, - required this.startSearch, - required this.searchStream, + required this.events, + required this.onStartSearch, + required this.endReached, + required this.isLoading, super.key, + required this.searchedUntil, }); @override Widget build(BuildContext context) { - return StreamBuilder( - stream: searchStream, - builder: (context, snapshot) { - final events = snapshot.data?.$1; - if (searchStream == null || events == null) { - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - const CircularProgressIndicator.adaptive(strokeWidth: 2), - const SizedBox(height: 8), - Text( - L10n.of(context)!.searchIn( - room.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), - ), - ), - ), - ], - ); - } - - if (events.isEmpty) { - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - const Icon(Icons.file_present_outlined, size: 64), - const SizedBox(height: 8), - Text(L10n.of(context)!.nothingFound), - ], - ); - } - - return SelectionArea( - child: ListView.builder( + final theme = Theme.of(context); + return SelectionArea( + child: ListView.builder( + padding: const EdgeInsets.all(8.0), + itemCount: events.length + 1, + itemBuilder: (context, i) { + if (i == events.length) { + return SearchFooter( + searchedUntil: searchedUntil, + endReached: endReached, + isLoading: isLoading, + onStartSearch: onStartSearch, + ); + } + final event = events[i]; + final filename = + event.content.tryGet('filename') ?? + event.content.tryGet('body') ?? + L10n.of(context).unknownEvent('File'); + final filetype = (filename.contains('.') + ? filename.split('.').last.toUpperCase() + : event.content + .tryGetMap('info') + ?.tryGet('mimetype') + ?.toUpperCase() ?? + 'UNKNOWN'); + final sizeString = event.sizeString; + final prevEvent = i > 0 ? events[i - 1] : null; + final sameEnvironment = + prevEvent != null && + prevEvent.originServerTs.sameEnvironment(event.originServerTs); + return Padding( padding: const EdgeInsets.all(8.0), - itemCount: events.length + 1, - itemBuilder: (context, i) { - if (i == events.length) { - if (snapshot.connectionState != ConnectionState.done) { - return const Padding( - padding: EdgeInsets.all(16.0), - child: Center( - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, + child: Column( + mainAxisSize: MainAxisSize.min, + children: [ + if (!sameEnvironment) ...[ + Row( + children: [ + Expanded( + child: Container(height: 1, color: theme.dividerColor), ), - ), - ); - } - final nextBatch = snapshot.data?.$2; - if (nextBatch == null) { - return const SizedBox.shrink(); - } - return Center( - child: Padding( - padding: const EdgeInsets.all(16.0), - child: TextButton.icon( - style: TextButton.styleFrom( - backgroundColor: - Theme.of(context).colorScheme.secondaryContainer, - foregroundColor: - Theme.of(context).colorScheme.onSecondaryContainer, - ), - onPressed: () => startSearch( - prevBatch: nextBatch, - previousSearchResult: events, - ), - icon: const Icon( - Icons.arrow_downward_outlined, - ), - label: Text(L10n.of(context)!.searchMore), - ), - ), - ); - } - final event = events[i]; - final filename = event.content.tryGet('filename') ?? - event.content.tryGet('body') ?? - L10n.of(context)!.unknownEvent('File'); - final filetype = (filename.contains('.') - ? filename.split('.').last.toUpperCase() - : event.content - .tryGetMap('info') - ?.tryGet('mimetype') - ?.toUpperCase() ?? - 'UNKNOWN'); - final sizeString = event.sizeString; - final prevEvent = i > 0 ? events[i - 1] : null; - final sameEnvironment = prevEvent == null - ? false - : prevEvent.originServerTs - .sameEnvironment(event.originServerTs); - return Padding( - padding: const EdgeInsets.all(8.0), - child: Column( - mainAxisSize: MainAxisSize.min, - children: [ - if (!sameEnvironment) ...[ - Row( - children: [ - Expanded( - child: Container( - height: 1, - color: Theme.of(context).dividerColor, - ), - ), - Padding( - padding: const EdgeInsets.all(8.0), - child: Text( - event.originServerTs.localizedTime(context), - style: Theme.of(context).textTheme.labelSmall, - textAlign: TextAlign.center, - ), - ), - Expanded( - child: Container( - height: 1, - color: Theme.of(context).dividerColor, - ), - ), - ], - ), - const SizedBox(height: 4), - ], - Material( - borderRadius: - BorderRadius.circular(AppConfig.borderRadius), - color: Theme.of(context).colorScheme.onInverseSurface, - clipBehavior: Clip.hardEdge, - child: ListTile( - leading: const Icon(Icons.file_present_outlined), - title: Text( - filename, - maxLines: 1, - overflow: TextOverflow.ellipsis, + Padding( + padding: const EdgeInsets.all(8.0), + child: Text( + event.originServerTs.localizedTime(context), + style: theme.textTheme.labelSmall, + textAlign: TextAlign.center, ), - subtitle: Text('$sizeString | $filetype'), - onTap: () => event.saveFile(context), ), + Expanded( + child: Container(height: 1, color: theme.dividerColor), + ), + ], + ), + const SizedBox(height: 4), + ], + Material( + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + color: theme.colorScheme.onInverseSurface, + clipBehavior: Clip.hardEdge, + child: ListTile( + leading: const Icon(Icons.file_present_outlined), + title: Text( + filename, + maxLines: 1, + overflow: TextOverflow.ellipsis, ), - ], + subtitle: Text('$sizeString | $filetype'), + onTap: () => event.saveFile(context), + ), ), - ); - }, - ), - ); - }, + ], + ), + ); + }, + ), ); } } diff --git a/lib/pages/chat_search/chat_search_images_tab.dart b/lib/pages/chat_search/chat_search_images_tab.dart index 9f8c1f0c9..5b018ccc4 100644 --- a/lib/pages/chat_search/chat_search_images_tab.dart +++ b/lib/pages/chat_search/chat_search_images_tab.dart @@ -1,167 +1,124 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:intl/intl.dart'; import 'package:matrix/matrix.dart'; -import 'package:fluffychat/pages/chat/events/image_bubble.dart'; +import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/pages/chat/events/video_player.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/pages/chat_search/search_footer.dart'; +import 'package:fluffychat/pages/image_viewer/image_viewer.dart'; +import 'package:fluffychat/widgets/mxc_image.dart'; class ChatSearchImagesTab extends StatelessWidget { final Room room; - final Stream<(List, String?)>? searchStream; - final void Function({ - String? prevBatch, - List? previousSearchResult, - }) startSearch; + final List events; + final void Function() onStartSearch; + final bool endReached, isLoading; + final DateTime? searchedUntil; const ChatSearchImagesTab({ required this.room, - required this.startSearch, - required this.searchStream, + required this.events, + required this.onStartSearch, + required this.endReached, + required this.isLoading, super.key, + required this.searchedUntil, }); @override Widget build(BuildContext context) { - return StreamBuilder( - stream: searchStream, - builder: (context, snapshot) { - final events = snapshot.data?.$1; - if (searchStream == null || events == null) { - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - const CircularProgressIndicator.adaptive(strokeWidth: 2), - const SizedBox(height: 8), - Text( - L10n.of(context)!.searchIn( - room.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), + final borderRadius = BorderRadius.circular(AppConfig.borderRadius / 2); + final theme = Theme.of(context); + + final eventsByMonth = >{}; + for (final event in events) { + final month = DateTime( + event.originServerTs.year, + event.originServerTs.month, + ); + eventsByMonth[month] ??= []; + eventsByMonth[month]!.add(event); + } + final eventsByMonthList = eventsByMonth.entries.toList(); + + const padding = 8.0; + + return ListView.builder( + itemCount: eventsByMonth.length + 1, + itemBuilder: (context, i) { + if (i == eventsByMonth.length) { + return SearchFooter( + searchedUntil: searchedUntil, + endReached: endReached, + isLoading: isLoading, + onStartSearch: onStartSearch, + ); + } + + final monthEvents = eventsByMonthList[i].value; + return Column( + mainAxisSize: MainAxisSize.min, + children: [ + const SizedBox(height: 4), + Row( + children: [ + Expanded( + child: Container(height: 1, color: theme.dividerColor), + ), + Padding( + padding: const EdgeInsets.all(8.0), + child: Text( + DateFormat.yMMMM( + Localizations.localeOf(context).languageCode, + ).format(eventsByMonthList[i].key), + style: theme.textTheme.labelSmall, + textAlign: TextAlign.center, ), ), - ), - ], - ); - } - if (events.isEmpty) { - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - const Icon(Icons.photo_outlined, size: 64), - const SizedBox(height: 8), - Text(L10n.of(context)!.nothingFound), - ], - ); - } - final eventsByMonth = >{}; - for (final event in events) { - final month = DateTime( - event.originServerTs.year, - event.originServerTs.month, - ); - eventsByMonth[month] ??= []; - eventsByMonth[month]!.add(event); - } - final eventsByMonthList = eventsByMonth.entries.toList(); - - const padding = 8.0; - - return ListView.builder( - itemCount: eventsByMonth.length + 1, - itemBuilder: (context, i) { - if (i == eventsByMonth.length) { - if (snapshot.connectionState != ConnectionState.done) { - return const Padding( - padding: EdgeInsets.all(16.0), - child: Center( - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, + Expanded( + child: Container(height: 1, color: theme.dividerColor), + ), + ], + ), + GridView.count( + physics: const NeverScrollableScrollPhysics(), + shrinkWrap: true, + mainAxisSpacing: padding, + crossAxisSpacing: padding, + clipBehavior: Clip.hardEdge, + padding: const EdgeInsets.all(padding), + crossAxisCount: 3, + children: monthEvents.map((event) { + if (event.messageType == MessageTypes.Video) { + return Material( + clipBehavior: Clip.hardEdge, + borderRadius: borderRadius, + child: EventVideoPlayer(event), + ); + } + return InkWell( + onTap: () => showDialog( + context: context, + builder: (_) => ImageViewer(event, outerContext: context), + ), + borderRadius: borderRadius, + child: Material( + clipBehavior: Clip.hardEdge, + borderRadius: borderRadius, + child: MxcImage( + event: event, + width: 128, + height: 128, + fit: BoxFit.cover, + animated: true, + isThumbnail: true, ), ), ); - } - final nextBatch = snapshot.data?.$2; - if (nextBatch == null) { - return const SizedBox.shrink(); - } - return Center( - child: Padding( - padding: const EdgeInsets.all(16.0), - child: TextButton.icon( - style: TextButton.styleFrom( - backgroundColor: - Theme.of(context).colorScheme.secondaryContainer, - foregroundColor: - Theme.of(context).colorScheme.onSecondaryContainer, - ), - onPressed: () => startSearch( - prevBatch: nextBatch, - previousSearchResult: events, - ), - icon: const Icon( - Icons.arrow_downward_outlined, - ), - label: Text(L10n.of(context)!.searchMore), - ), - ), - ); - } - - final monthEvents = eventsByMonthList[i].value; - return Column( - mainAxisSize: MainAxisSize.min, - children: [ - const SizedBox(height: 4), - Row( - children: [ - Expanded( - child: Container( - height: 1, - color: Theme.of(context).dividerColor, - ), - ), - Padding( - padding: const EdgeInsets.all(8.0), - child: Text( - DateFormat.yMMMM( - Localizations.localeOf(context).languageCode, - ).format(eventsByMonthList[i].key), - style: Theme.of(context).textTheme.labelSmall, - textAlign: TextAlign.center, - ), - ), - Expanded( - child: Container( - height: 1, - color: Theme.of(context).dividerColor, - ), - ), - ], - ), - GridView.count( - physics: const NeverScrollableScrollPhysics(), - shrinkWrap: true, - mainAxisSpacing: padding, - crossAxisSpacing: padding, - padding: const EdgeInsets.all(padding), - crossAxisCount: 3, - children: monthEvents.map( - (event) { - if (event.messageType == MessageTypes.Video) { - return EventVideoPlayer(event); - } - return ImageBubble( - event, - fit: BoxFit.cover, - ); - }, - ).toList(), - ), - ], - ); - }, + }).toList(), + ), + ], ); }, ); diff --git a/lib/pages/chat_search/chat_search_message_tab.dart b/lib/pages/chat_search/chat_search_message_tab.dart index 7542d6ae9..c58a2de35 100644 --- a/lib/pages/chat_search/chat_search_message_tab.dart +++ b/lib/pages/chat_search/chat_search_message_tab.dart @@ -1,10 +1,11 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_linkify/flutter_linkify.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat_search/search_footer.dart'; import 'package:fluffychat/utils/date_time_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import 'package:fluffychat/utils/url_launcher.dart'; @@ -13,104 +14,71 @@ import 'package:fluffychat/widgets/avatar.dart'; class ChatSearchMessageTab extends StatelessWidget { final String searchQuery; final Room room; - final Stream<(List, String?)>? searchStream; - final void Function({ - String? prevBatch, - List? previousSearchResult, - }) startSearch; + final List events; + final void Function() onStartSearch; + final bool endReached, isLoading; + final DateTime? searchedUntil; const ChatSearchMessageTab({ required this.searchQuery, required this.room, - required this.searchStream, - required this.startSearch, + required this.onStartSearch, + required this.events, + required this.searchedUntil, + required this.endReached, + required this.isLoading, super.key, }); @override Widget build(BuildContext context) { - return StreamBuilder( - key: ValueKey(searchQuery), - stream: searchStream, - builder: (context, snapshot) { - if (searchStream == null) { - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - const Icon(Icons.search_outlined, size: 64), - const SizedBox(height: 8), - Text( - L10n.of(context)!.searchIn( - room.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), - ), - ), + final theme = Theme.of(context); + if (events.isEmpty && searchQuery.isEmpty) { + return Column( + mainAxisAlignment: MainAxisAlignment.center, + children: [ + const Icon(Icons.search_outlined, size: 64), + const SizedBox(height: 8), + Padding( + padding: const EdgeInsets.symmetric(horizontal: 32.0), + child: Text( + L10n.of(context).searchIn( + room.getLocalizedDisplayname(MatrixLocals(L10n.of(context))), ), - ], - ); - } - final events = snapshot.data?.$1 ?? []; - - return SelectionArea( - child: ListView.separated( - itemCount: events.length + 1, - separatorBuilder: (context, _) => Divider( - color: Theme.of(context).dividerColor, - height: 1, + textAlign: TextAlign.center, ), - itemBuilder: (context, i) { - if (i == events.length) { - if (snapshot.connectionState != ConnectionState.done) { - return const Padding( - padding: EdgeInsets.all(16.0), - child: Center( - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, - ), - ), - ); - } - final nextBatch = snapshot.data?.$2; - if (nextBatch == null) { - return const SizedBox.shrink(); - } - return Center( - child: Padding( - padding: const EdgeInsets.all(16.0), - child: TextButton.icon( - style: TextButton.styleFrom( - backgroundColor: - Theme.of(context).colorScheme.secondaryContainer, - foregroundColor: - Theme.of(context).colorScheme.onSecondaryContainer, - ), - onPressed: () => startSearch( - prevBatch: nextBatch, - previousSearchResult: events, - ), - icon: const Icon( - Icons.arrow_downward_outlined, - ), - label: Text(L10n.of(context)!.searchMore), - ), - ), - ); - } - final event = events[i]; - final sender = event.senderFromMemoryOrFallback; - final displayname = sender.calcDisplayname( - i18n: MatrixLocals(L10n.of(context)!), - ); - return _MessageSearchResultListTile( - sender: sender, - displayname: displayname, - event: event, - room: room, - ); - }, ), - ); - }, + ], + ); + } + + return SelectionArea( + child: ListView.separated( + itemCount: events.length + 1, + separatorBuilder: (context, _) => + Divider(color: theme.dividerColor, height: 1), + itemBuilder: (context, i) { + if (i == events.length) { + return SearchFooter( + searchedUntil: searchedUntil, + endReached: endReached, + isLoading: isLoading, + onStartSearch: onStartSearch, + ); + } + final event = events[i]; + final sender = event.senderFromMemoryOrFallback; + final displayname = sender.calcDisplayname( + i18n: MatrixLocals(L10n.of(context)), + ); + return _MessageSearchResultListTile( + sender: sender, + displayname: displayname, + event: event, + room: room, + ); + }, + ), ); } } @@ -130,18 +98,14 @@ class _MessageSearchResultListTile extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return ListTile( title: Row( children: [ - Avatar( - mxContent: sender.avatarUrl, - name: displayname, - size: 16, - ), + Avatar(mxContent: sender.avatarUrl, name: displayname, size: 16), const SizedBox(width: 8), - Text( - displayname, - ), + Text(displayname), Expanded( child: Text( ' | ${event.originServerTs.localizedTimeShort(context)}', @@ -151,34 +115,28 @@ class _MessageSearchResultListTile extends StatelessWidget { ], ), subtitle: Linkify( + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), options: const LinkifyOptions(humanize: false), linkStyle: TextStyle( - color: Theme.of(context).colorScheme.primary, + color: theme.colorScheme.primary, decoration: TextDecoration.underline, - decorationColor: Theme.of(context).colorScheme.primary, + decorationColor: theme.colorScheme.primary, ), onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), text: event .calcLocalizedBodyFallback( plaintextBody: true, removeMarkdown: true, - MatrixLocals( - L10n.of(context)!, - ), + MatrixLocals(L10n.of(context)), ) .trim(), maxLines: 7, overflow: TextOverflow.ellipsis, ), trailing: IconButton( - icon: const Icon( - Icons.chevron_right_outlined, - ), + icon: const Icon(Icons.chevron_right_outlined), onPressed: () => context.go( - '/${Uri( - pathSegments: ['rooms', room.id], - queryParameters: {'event': event.eventId}, - )}', + '/${Uri(pathSegments: ['rooms', room.id], queryParameters: {'event': event.eventId})}', ), ), ); diff --git a/lib/pages/chat_search/chat_search_page.dart b/lib/pages/chat_search/chat_search_page.dart index 40109d0b6..579a21037 100644 --- a/lib/pages/chat_search/chat_search_page.dart +++ b/lib/pages/chat_search/chat_search_page.dart @@ -1,5 +1,3 @@ -import 'dart:async'; - import 'package:flutter/material.dart'; import 'package:matrix/matrix.dart'; @@ -22,156 +20,100 @@ class ChatSearchController extends State final TextEditingController searchController = TextEditingController(); late final TabController tabController; - Timeline? timeline; - - Stream<(List, String?)>? searchStream; - Stream<(List, String?)>? galleryStream; - Stream<(List, String?)>? fileStream; + final List messages = []; + final List images = []; + final List files = []; + String? messagesNextBatch, imagesNextBatch, filesNextBatch; + bool messagesEndReached = false; + bool imagesEndReached = false; + bool filesEndReached = false; + bool isLoading = false; + DateTime? searchedUntil; void restartSearch() { - if (searchController.text.isEmpty) { - setState(() { - searchStream = null; - }); - return; - } setState(() { - searchStream = const Stream.empty(); + messages.clear(); + images.clear(); + files.clear(); + messagesNextBatch = imagesNextBatch = filesNextBatch = searchedUntil = + null; + messagesEndReached = imagesEndReached = filesEndReached = false; }); WidgetsBinding.instance.addPostFrameCallback((timeStamp) { - startMessageSearch(); + startSearch(); }); } - void startMessageSearch({ - String? prevBatch, - List? previousSearchResult, - }) async { - final timeline = this.timeline ??= await room!.getTimeline(); - - if (tabController.index == 0 && searchController.text.isEmpty) { - return; + Future startSearch() async { + switch (tabController.index) { + case 0: + final searchQuery = searchController.text.trim(); + if (searchQuery.isEmpty) return; + setState(() { + isLoading = true; + }); + final result = await room!.searchEvents( + searchTerm: searchController.text.trim(), + nextBatch: messagesNextBatch, + ); + setState(() { + isLoading = false; + messages.addAll(result.events); + messagesNextBatch = result.nextBatch; + messagesEndReached = result.nextBatch == null; + searchedUntil = result.searchedUntil; + }); + return; + case 1: + setState(() { + isLoading = true; + }); + final result = await room!.searchEvents( + searchFunc: (event) => { + MessageTypes.Image, + MessageTypes.Video, + }.contains(event.messageType), + nextBatch: imagesNextBatch, + ); + setState(() { + isLoading = false; + images.addAll(result.events); + imagesNextBatch = result.nextBatch; + imagesEndReached = result.nextBatch == null; + searchedUntil = result.searchedUntil; + }); + return; + case 2: + setState(() { + isLoading = true; + }); + final result = await room!.searchEvents( + searchFunc: (event) => + event.messageType == MessageTypes.File || + (event.messageType == MessageTypes.Audio && + !event.content.containsKey('org.matrix.msc3245.voice')), + nextBatch: filesNextBatch, + ); + setState(() { + isLoading = false; + files.addAll(result.events); + filesNextBatch = result.nextBatch; + filesEndReached = result.nextBatch == null; + searchedUntil = result.searchedUntil; + }); + return; + default: + return; } - - setState(() { - searchStream = timeline - .startSearch( - searchTerm: searchController.text, - prevBatch: prevBatch, - requestHistoryCount: 1000, - limit: 32, - ) - .map( - (result) => ( - [ - if (previousSearchResult != null) ...previousSearchResult, - ...result.$1, - ], - result.$2, - ), - ) - // Deduplication workaround for - // https://github.com/famedly/matrix-dart-sdk/issues/1831 - .map( - (result) => ( - { - for (final event in result.$1) event.eventId: event, - }.values.toList(), - result.$2, - ), - ) - .asBroadcastStream(); - }); - } - - void startGallerySearch({ - String? prevBatch, - List? previousSearchResult, - }) async { - final timeline = this.timeline ??= await room!.getTimeline(); - - setState(() { - galleryStream = timeline - .startSearch( - searchFunc: (event) => { - MessageTypes.Image, - MessageTypes.Video, - }.contains(event.messageType), - prevBatch: prevBatch, - requestHistoryCount: 1000, - limit: 32, - ) - .map( - (result) => ( - [ - if (previousSearchResult != null) ...previousSearchResult, - ...result.$1, - ], - result.$2, - ), - ) - // Deduplication workaround for - // https://github.com/famedly/matrix-dart-sdk/issues/1831 - .map( - (result) => ( - { - for (final event in result.$1) event.eventId: event, - }.values.toList(), - result.$2, - ), - ) - .asBroadcastStream(); - }); - } - - void startFileSearch({ - String? prevBatch, - List? previousSearchResult, - }) async { - final timeline = this.timeline ??= await room!.getTimeline(); - - setState(() { - fileStream = timeline - .startSearch( - searchFunc: (event) => - event.messageType == MessageTypes.File || - (event.messageType == MessageTypes.Audio && - !event.content.containsKey('org.matrix.msc3245.voice')), - prevBatch: prevBatch, - requestHistoryCount: 1000, - limit: 32, - ) - .map( - (result) => ( - [ - if (previousSearchResult != null) ...previousSearchResult, - ...result.$1, - ], - result.$2, - ), - ) - // Deduplication workaround for - // https://github.com/famedly/matrix-dart-sdk/issues/1831 - .map( - (result) => ( - { - for (final event in result.$1) event.eventId: event, - }.values.toList(), - result.$2, - ), - ) - .asBroadcastStream(); - }); } void _onTabChanged() { switch (tabController.index) { case 1: - startGallerySearch(); - break; case 2: - startFileSearch(); + startSearch(); break; + case 0: default: restartSearch(); break; diff --git a/lib/pages/chat_search/chat_search_view.dart b/lib/pages/chat_search/chat_search_view.dart index e08f25a2b..278478fa3 100644 --- a/lib/pages/chat_search/chat_search_view.dart +++ b/lib/pages/chat_search/chat_search_view.dart @@ -1,8 +1,7 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; - import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/chat_search/chat_search_files_tab.dart'; import 'package:fluffychat/pages/chat_search/chat_search_images_tab.dart'; import 'package:fluffychat/pages/chat_search/chat_search_message_tab.dart'; @@ -20,24 +19,25 @@ class ChatSearchView extends StatelessWidget { final room = controller.room; if (room == null) { return Scaffold( - appBar: AppBar(title: Text(L10n.of(context)!.oopsSomethingWentWrong)), + appBar: AppBar(title: Text(L10n.of(context).oopsSomethingWentWrong)), body: Center( child: Padding( padding: const EdgeInsets.all(16), - child: - Text(L10n.of(context)!.youAreNoLongerParticipatingInThisChat), + child: Text(L10n.of(context).youAreNoLongerParticipatingInThisChat), ), ), ); } + final theme = Theme.of(context); + return Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), titleSpacing: 0, title: Text( - L10n.of(context)!.searchIn( - room.getLocalizedDisplayname(MatrixLocals(L10n.of(context)!)), + L10n.of(context).searchIn( + room.getLocalizedDisplayname(MatrixLocals(L10n.of(context))), ), ), ), @@ -48,26 +48,34 @@ class ChatSearchView extends StatelessWidget { if (FluffyThemes.isThreeColumnMode(context)) const SizedBox(height: 16), Padding( - padding: const EdgeInsets.symmetric( - horizontal: 16, - ), + padding: const EdgeInsets.symmetric(horizontal: 16), child: TextField( controller: controller.searchController, onSubmitted: (_) => controller.restartSearch(), autofocus: true, enabled: controller.tabController.index == 0, decoration: InputDecoration( - hintText: L10n.of(context)!.search, - suffixIcon: const Icon(Icons.search_outlined), + hintText: L10n.of(context).search, + prefixIcon: const Icon(Icons.search_outlined), + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + hintStyle: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontWeight: FontWeight.normal, + ), ), ), ), TabBar( controller: controller.tabController, tabs: [ - Tab(child: Text(L10n.of(context)!.messages)), - Tab(child: Text(L10n.of(context)!.gallery)), - Tab(child: Text(L10n.of(context)!.files)), + Tab(child: Text(L10n.of(context).messages)), + Tab(child: Text(L10n.of(context).gallery)), + Tab(child: Text(L10n.of(context).files)), ], ), Expanded( @@ -77,18 +85,27 @@ class ChatSearchView extends StatelessWidget { ChatSearchMessageTab( searchQuery: controller.searchController.text, room: room, - startSearch: controller.startMessageSearch, - searchStream: controller.searchStream, + onStartSearch: controller.startSearch, + events: controller.messages, + endReached: controller.messagesEndReached, + isLoading: controller.isLoading, + searchedUntil: controller.searchedUntil, ), ChatSearchImagesTab( room: room, - startSearch: controller.startGallerySearch, - searchStream: controller.galleryStream, + onStartSearch: controller.startSearch, + events: controller.images, + endReached: controller.imagesEndReached, + isLoading: controller.isLoading, + searchedUntil: controller.searchedUntil, ), ChatSearchFilesTab( room: room, - startSearch: controller.startFileSearch, - searchStream: controller.fileStream, + onStartSearch: controller.startSearch, + events: controller.files, + endReached: controller.filesEndReached, + isLoading: controller.isLoading, + searchedUntil: controller.searchedUntil, ), ], ), diff --git a/lib/pages/chat_search/search_footer.dart b/lib/pages/chat_search/search_footer.dart new file mode 100644 index 000000000..cac19c4ea --- /dev/null +++ b/lib/pages/chat_search/search_footer.dart @@ -0,0 +1,68 @@ +import 'package:flutter/material.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/date_time_extension.dart'; + +class SearchFooter extends StatelessWidget { + final DateTime? searchedUntil; + final bool endReached, isLoading; + final void Function() onStartSearch; + + const SearchFooter({ + super.key, + required this.searchedUntil, + required this.endReached, + required this.isLoading, + required this.onStartSearch, + }); + + @override + Widget build(BuildContext context) { + if (endReached) { + return Center( + child: Padding( + padding: const EdgeInsets.all(16.0), + child: Text(L10n.of(context).noMoreResultsFound), + ), + ); + } + final theme = Theme.of(context); + final searchedUntil = this.searchedUntil; + return Center( + child: Padding( + padding: const EdgeInsets.all(16.0), + child: Column( + mainAxisSize: .min, + children: [ + if (searchedUntil != null) + Padding( + padding: const EdgeInsets.only(bottom: 8.0), + child: Text( + L10n.of( + context, + ).chatSearchedUntil(searchedUntil.localizedTime(context)), + style: TextStyle(fontSize: 10.5), + ), + ), + TextButton.icon( + style: TextButton.styleFrom( + backgroundColor: theme.colorScheme.secondaryContainer, + foregroundColor: theme.colorScheme.onSecondaryContainer, + ), + onPressed: isLoading ? null : onStartSearch, + icon: isLoading + ? SizedBox.square( + dimension: 18, + child: const CircularProgressIndicator.adaptive( + strokeWidth: 2, + ), + ) + : const Icon(Icons.arrow_downward_outlined), + label: Text(L10n.of(context).searchMore), + ), + ], + ), + ), + ); + } +} diff --git a/lib/pages/device_settings/device_settings.dart b/lib/pages/device_settings/device_settings.dart index d2eb96a42..014359a8c 100644 --- a/lib/pages/device_settings/device_settings.dart +++ b/lib/pages/device_settings/device_settings.dart @@ -1,15 +1,16 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; import 'package:collection/collection.dart' show IterableExtension; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:matrix/encryption/utils/key_verification.dart'; +import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; +import 'package:url_launcher/url_launcher_string.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/device_settings/device_settings_view.dart'; import 'package:fluffychat/pages/key_verification/key_verification_dialog.dart'; -import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import '../../widgets/matrix.dart'; class DevicesSettings extends StatefulWidget { @@ -29,76 +30,87 @@ class DevicesSettingsController extends State { void reload() => setState(() => devices = null); - bool loadingDeletingDevices = false; - String? errorDeletingDevices; + bool? chatBackupEnabled; - void removeDevicesAction(List devices) async { + @override + void initState() { + _checkChatBackup(); + super.initState(); + } + + Future _checkChatBackup() async { + final client = Matrix.of(context).client; + final state = await client.getCryptoIdentityState(); + setState(() { + chatBackupEnabled = state.initialized && !state.connected; + }); + } + + Future removeDevicesAction(List devices) async { + final client = Matrix.of(context).client; + + final wellKnown = await client.getWellknown(); + final accountManageUrl = wellKnown.additionalProperties + .tryGetMap('org.matrix.msc2965.authentication') + ?.tryGet('account'); + if (accountManageUrl != null) { + launchUrlString(accountManageUrl, mode: LaunchMode.inAppBrowserView); + return; + } if (await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.cancel, - message: L10n.of(context)!.removeDevicesDescription, + title: L10n.of(context).areYouSure, + okLabel: L10n.of(context).remove, + cancelLabel: L10n.of(context).cancel, + message: L10n.of(context).removeDevicesDescription, + isDestructive: true, ) == - OkCancelResult.cancel) return; + OkCancelResult.cancel) { + return; + } final matrix = Matrix.of(context); final deviceIds = []; for (final userDevice in devices) { deviceIds.add(userDevice.deviceId); } - try { - setState(() { - loadingDeletingDevices = true; - errorDeletingDevices = null; - }); - await matrix.client.uiaRequestBackground( - (auth) => matrix.client.deleteDevices( - deviceIds, - auth: auth, - ), - ); - reload(); - } catch (e, s) { - Logs().w('Error while deleting devices', e, s); - setState(() => errorDeletingDevices = e.toLocalizedString(context)); - } finally { - setState(() => loadingDeletingDevices = false); - } + await showFutureLoadingDialog( + context: context, + delay: false, + future: () => matrix.client.uiaRequestBackground( + (auth) => matrix.client.deleteDevices(deviceIds, auth: auth), + ), + ); + reload(); } - void renameDeviceAction(Device device) async { + Future renameDeviceAction(Device device) async { final displayName = await showTextInputDialog( context: context, - title: L10n.of(context)!.changeDeviceName, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - hintText: device.displayName, - ), - ], + title: L10n.of(context).changeDeviceName, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + hintText: device.displayName, ); if (displayName == null) return; final success = await showFutureLoadingDialog( context: context, - future: () => Matrix.of(context) - .client - .updateDevice(device.deviceId, displayName: displayName.single), + future: () => Matrix.of( + context, + ).client.updateDevice(device.deviceId, displayName: displayName), ); if (success.error == null) { reload(); } } - void verifyDeviceAction(Device device) async { + Future verifyDeviceAction(Device device) async { final consent = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.verifyOtherDevice, - message: L10n.of(context)!.verifyOtherDeviceDescription, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - fullyCapitalizedForMaterial: false, + title: L10n.of(context).verifyOtherDevice, + message: L10n.of(context).verifyOtherDeviceDescription, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, ); if (consent != OkCancelResult.ok) return; final req = await Matrix.of(context) @@ -107,15 +119,17 @@ class DevicesSettingsController extends State { .deviceKeys[device.deviceId]! .startVerification(); req.onUpdate = () { - if ({KeyVerificationState.error, KeyVerificationState.done} - .contains(req.state)) { + if ({ + KeyVerificationState.error, + KeyVerificationState.done, + }.contains(req.state)) { setState(() {}); } }; await KeyVerificationDialog(request: req).show(context); } - void blockDeviceAction(Device device) async { + Future blockDeviceAction(Device device) async { final key = Matrix.of(context) .client .userDeviceKeys[Matrix.of(context).client.userID!]! @@ -127,7 +141,7 @@ class DevicesSettingsController extends State { setState(() {}); } - void unblockDeviceAction(Device device) async { + Future unblockDeviceAction(Device device) async { final key = Matrix.of(context) .client .userDeviceKeys[Matrix.of(context).client.userID!]! @@ -139,9 +153,7 @@ class DevicesSettingsController extends State { bool _isOwnDevice(Device userDevice) => userDevice.deviceId == Matrix.of(context).client.deviceID; - Device? get thisDevice => devices!.firstWhereOrNull( - _isOwnDevice, - ); + Device? get thisDevice => devices!.firstWhereOrNull(_isOwnDevice); List get notThisDevice => List.from(devices!) ..removeWhere(_isOwnDevice) diff --git a/lib/pages/device_settings/device_settings_view.dart b/lib/pages/device_settings/device_settings_view.dart index e107d30c9..232ae06c9 100644 --- a/lib/pages/device_settings/device_settings_view.dart +++ b/lib/pages/device_settings/device_settings_view.dart @@ -1,7 +1,7 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; - +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/device_settings/device_settings.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'user_device_list_item.dart'; @@ -15,17 +15,19 @@ class DevicesSettingsView extends StatelessWidget { Widget build(BuildContext context) { return Scaffold( appBar: AppBar( - leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.devices), + automaticallyImplyLeading: !FluffyThemes.isColumnMode(context), + centerTitle: FluffyThemes.isColumnMode(context), + title: Text(L10n.of(context).devices), ), body: MaxWidthBody( child: FutureBuilder( future: controller.loadUserDevices(context), builder: (BuildContext context, snapshot) { + final theme = Theme.of(context); if (snapshot.hasError) { return Center( child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ const Icon(Icons.error_outlined), Text(snapshot.error.toString()), @@ -45,8 +47,22 @@ class DevicesSettingsView extends StatelessWidget { itemBuilder: (BuildContext context, int i) { if (i == 0) { return Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ + if (controller.chatBackupEnabled == false) + Padding( + padding: const EdgeInsets.symmetric(horizontal: 8.0), + child: ListTile( + leading: const CircleAvatar( + child: Icon(Icons.info_outlined), + ), + subtitle: Text( + L10n.of( + context, + ).noticeChatBackupDeviceVerification, + ), + ), + ), if (controller.thisDevice != null) ...[ Container( padding: const EdgeInsets.symmetric( @@ -55,10 +71,10 @@ class DevicesSettingsView extends StatelessWidget { ), alignment: Alignment.centerLeft, child: Text( - L10n.of(context)!.thisDevice, + L10n.of(context).thisDevice, style: TextStyle( fontWeight: FontWeight.bold, - color: Theme.of(context).colorScheme.primary, + color: theme.colorScheme.primary, ), textAlign: TextAlign.left, ), @@ -82,27 +98,19 @@ class DevicesSettingsView extends StatelessWidget { width: double.infinity, child: TextButton.icon( label: Text( - controller.errorDeletingDevices ?? - L10n.of(context)!.removeAllOtherDevices, + L10n.of(context).removeAllOtherDevices, ), style: TextButton.styleFrom( - foregroundColor: Theme.of(context) - .colorScheme - .onErrorContainer, - backgroundColor: Theme.of(context) - .colorScheme - .errorContainer, + iconColor: theme.colorScheme.onErrorContainer, + foregroundColor: + theme.colorScheme.onErrorContainer, + backgroundColor: + theme.colorScheme.errorContainer, + ), + icon: const Icon(Icons.delete_outline), + onPressed: () => controller.removeDevicesAction( + controller.notThisDevice, ), - icon: controller.loadingDeletingDevices - ? const CircularProgressIndicator.adaptive( - strokeWidth: 2, - ) - : const Icon(Icons.delete_outline), - onPressed: controller.loadingDeletingDevices - ? null - : () => controller.removeDevicesAction( - controller.notThisDevice, - ), ), ), ) @@ -110,7 +118,7 @@ class DevicesSettingsView extends StatelessWidget { Center( child: Padding( padding: const EdgeInsets.all(16.0), - child: Text(L10n.of(context)!.noOtherDevicesFound), + child: Text(L10n.of(context).noOtherDevicesFound), ), ), ], diff --git a/lib/pages/device_settings/user_device_list_item.dart b/lib/pages/device_settings/user_device_list_item.dart index cf3acd6c9..095a4335c 100644 --- a/lib/pages/device_settings/user_device_list_item.dart +++ b/lib/pages/device_settings/user_device_list_item.dart @@ -1,21 +1,15 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; import '../../utils/date_time_extension.dart'; import '../../utils/matrix_sdk_extensions/device_extension.dart'; import '../../widgets/matrix.dart'; -enum UserDeviceListItemAction { - rename, - remove, - verify, - block, - unblock, -} +enum UserDeviceListItemAction { rename, remove, verify, block, unblock } class UserDeviceListItem extends StatelessWidget { final Device userDevice; @@ -38,7 +32,8 @@ class UserDeviceListItem extends StatelessWidget { @override Widget build(BuildContext context) { final client = Matrix.of(context).client; - final keys = client.userDeviceKeys[Matrix.of(context).client.userID] + final keys = client + .userDeviceKeys[Matrix.of(context).client.userID] ?.deviceKeys[userDevice.deviceId]; final isOwnDevice = userDevice.deviceId == client.deviceID; @@ -49,37 +44,43 @@ class UserDeviceListItem extends StatelessWidget { clipBehavior: Clip.hardEdge, child: ListTile( onTap: () async { - final action = await showModalActionSheet( + final action = await showModalActionPopup( context: context, title: '${userDevice.displayName} (${userDevice.deviceId})', + cancelLabel: L10n.of(context).cancel, actions: [ - SheetAction( - key: UserDeviceListItemAction.rename, - label: L10n.of(context)!.changeDeviceName, + AdaptiveModalAction( + value: UserDeviceListItemAction.rename, + icon: const Icon(Icons.edit_outlined), + label: L10n.of(context).changeDeviceName, ), if (!isOwnDevice && keys != null) ...{ - SheetAction( - key: UserDeviceListItemAction.verify, - label: L10n.of(context)!.verifyStart, + AdaptiveModalAction( + value: UserDeviceListItemAction.verify, + icon: const Icon(Icons.verified_outlined), + label: L10n.of(context).verifyStart, ), if (!keys.blocked) - SheetAction( - key: UserDeviceListItemAction.block, - label: L10n.of(context)!.blockDevice, - isDestructiveAction: true, + AdaptiveModalAction( + value: UserDeviceListItemAction.block, + icon: const Icon(Icons.block_outlined), + label: L10n.of(context).blockDevice, + isDestructive: true, ), if (keys.blocked) - SheetAction( - key: UserDeviceListItemAction.unblock, - label: L10n.of(context)!.unblockDevice, - isDestructiveAction: true, + AdaptiveModalAction( + value: UserDeviceListItemAction.unblock, + icon: const Icon(Icons.block), + label: L10n.of(context).unblockDevice, + isDestructive: true, ), }, if (!isOwnDevice) - SheetAction( - key: UserDeviceListItemAction.remove, - label: L10n.of(context)!.delete, - isDestructiveAction: true, + AdaptiveModalAction( + value: UserDeviceListItemAction.remove, + icon: const Icon(Icons.delete_outlined), + label: L10n.of(context).delete, + isDestructive: true, ), ], ); @@ -107,10 +108,10 @@ class UserDeviceListItem extends StatelessWidget { backgroundColor: keys == null ? Colors.grey[700] : keys.blocked - ? Colors.red - : keys.verified - ? Colors.green - : Colors.orange, + ? Colors.red + : keys.verified + ? Colors.green + : Colors.orange, child: Icon(userDevice.icon), ), title: Text( @@ -119,9 +120,10 @@ class UserDeviceListItem extends StatelessWidget { overflow: TextOverflow.ellipsis, ), subtitle: Text( - L10n.of(context)!.lastActiveAgo( - DateTime.fromMillisecondsSinceEpoch(userDevice.lastSeenTs ?? 0) - .localizedTimeShort(context), + L10n.of(context).lastActiveAgo( + DateTime.fromMillisecondsSinceEpoch( + userDevice.lastSeenTs ?? 0, + ).localizedTimeShort(context), ), style: const TextStyle(fontWeight: FontWeight.w300), ), @@ -129,16 +131,16 @@ class UserDeviceListItem extends StatelessWidget { ? null : Text( keys.blocked - ? L10n.of(context)!.blocked + ? L10n.of(context).blocked : keys.verified - ? L10n.of(context)!.verified - : L10n.of(context)!.unverified, + ? L10n.of(context).verified + : L10n.of(context).unverified, style: TextStyle( color: keys.blocked ? Colors.red : keys.verified - ? Colors.green - : Colors.orange, + ? Colors.green + : Colors.orange, ), ), ), diff --git a/lib/pages/dialer/dialer.dart b/lib/pages/dialer/dialer.dart index 84e6fe923..f7af5b540 100644 --- a/lib/pages/dialer/dialer.dart +++ b/lib/pages/dialer/dialer.dart @@ -24,12 +24,12 @@ import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:flutter_foreground_task/flutter_foreground_task.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_webrtc/flutter_webrtc.dart' hide VideoRenderer; import 'package:just_audio/just_audio.dart'; import 'package:matrix/matrix.dart'; import 'package:wakelock_plus/wakelock_plus.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'package:fluffychat/utils/voip/video_renderer.dart'; @@ -70,9 +70,7 @@ class _StreamView extends StatelessWidget { @override Widget build(BuildContext context) { return Container( - decoration: const BoxDecoration( - color: Colors.black54, - ), + decoration: const BoxDecoration(color: Colors.black54), child: Stack( alignment: Alignment.center, children: [ @@ -133,9 +131,8 @@ class Calling extends StatefulWidget { class MyCallingPage extends State { Room? get room => call.room; - String get displayName => call.room.getLocalizedDisplayname( - MatrixLocals(L10n.of(widget.context)!), - ); + String get displayName => + call.room.getLocalizedDisplayname(MatrixLocals(L10n.of(widget.context))); String get callId => widget.callId; @@ -150,7 +147,7 @@ class MyCallingPage extends State { MediaStream? get remoteStream { if (call.getRemoteStreams.isNotEmpty) { - return call.getRemoteStreams[0].stream!; + return call.getRemoteStreams.first.stream!; } return null; } @@ -174,7 +171,7 @@ class MyCallingPage extends State { EdgeInsetsGeometry? _localVideoMargin; CallState? _state; - void _playCallSound() async { + Future _playCallSound() async { const path = 'assets/sounds/call.ogg'; if (kIsWeb || PlatformInfos.isMobile || PlatformInfos.isMacOS) { final player = AudioPlayer(); @@ -192,14 +189,12 @@ class MyCallingPage extends State { _playCallSound(); } - void initialize() async { + void initialize() { final call = this.call; call.onCallStateChanged.stream.listen(_handleCallState); call.onCallEventChanged.stream.listen((event) { if (event == CallStateChange.kFeedsChanged) { - setState(() { - call.tryRemoveStopedStreams(); - }); + setState(call.tryRemoveStopedStreams); } else if (event == CallStateChange.kLocalHoldUnhold || event == CallStateChange.kRemoteHoldUnhold) { setState(() {}); @@ -219,10 +214,7 @@ class MyCallingPage extends State { } void cleanUp() { - Timer( - const Duration(seconds: 2), - () => widget.onClear?.call(), - ); + Timer(const Duration(seconds: 2), () => widget.onClear?.call()); if (call.type == CallType.kVideo) { try { unawaited(WakelockPlus.disable()); @@ -238,22 +230,22 @@ class MyCallingPage extends State { void _resizeLocalVideo(Orientation orientation) { final shortSide = min( - MediaQuery.of(widget.context).size.width, - MediaQuery.of(widget.context).size.height, + MediaQuery.sizeOf(widget.context).width, + MediaQuery.sizeOf(widget.context).height, ); _localVideoMargin = remoteStream != null ? const EdgeInsets.only(top: 20.0, right: 20.0) : EdgeInsets.zero; _localVideoWidth = remoteStream != null ? shortSide / 3 - : MediaQuery.of(widget.context).size.width; + : MediaQuery.sizeOf(widget.context).width; _localVideoHeight = remoteStream != null ? shortSide / 4 - : MediaQuery.of(widget.context).size.height; + : MediaQuery.sizeOf(widget.context).height; } void _handleCallState(CallState state) { - Logs().v('CallingPage::handleCallState: ${state.toString()}'); + Logs().v('CallingPage::handleCallState: $state'); if ({CallState.kConnected, CallState.kEnded}.contains(state)) { HapticFeedback.heavyImpact(); } @@ -288,22 +280,25 @@ class MyCallingPage extends State { }); } - void _screenSharing() async { + void _screenSharing() { if (PlatformInfos.isAndroid) { if (!call.screensharingEnabled) { FlutterForegroundTask.init( androidNotificationOptions: AndroidNotificationOptions( channelId: 'notification_channel_id', channelName: 'Foreground Notification', - channelDescription: - L10n.of(widget.context)!.foregroundServiceRunning, + channelDescription: L10n.of( + widget.context, + ).foregroundServiceRunning, ), iosNotificationOptions: const IOSNotificationOptions(), - foregroundTaskOptions: const ForegroundTaskOptions(), + foregroundTaskOptions: ForegroundTaskOptions( + eventAction: ForegroundTaskEventAction.nothing(), + ), ); FlutterForegroundTask.startService( - notificationTitle: L10n.of(widget.context)!.screenSharingTitle, - notificationText: L10n.of(widget.context)!.screenSharingDetail, + notificationTitle: L10n.of(widget.context).screenSharingTitle, + notificationText: L10n.of(widget.context).screenSharingDetail, ); } else { FlutterForegroundTask.stopService(); @@ -327,10 +322,10 @@ class MyCallingPage extends State { }); } - void _switchCamera() async { + Future _switchCamera() async { if (call.localUserMediaStream != null) { await Helper.switchCamera( - call.localUserMediaStream!.stream!.getVideoTracks()[0], + call.localUserMediaStream!.stream!.getVideoTracks().first, ); } setState(() {}); @@ -344,244 +339,103 @@ class MyCallingPage extends State { } */ - List _buildActionButtons(bool isFloating) { - if (isFloating) { - return []; - } - - final switchCameraButton = FloatingActionButton( - heroTag: 'switchCamera', - onPressed: _switchCamera, - backgroundColor: Colors.black45, - child: const Icon(Icons.switch_camera), - ); - /* - var switchSpeakerButton = FloatingActionButton( - heroTag: 'switchSpeaker', - child: Icon(_speakerOn ? Icons.volume_up : Icons.volume_off), - onPressed: _switchSpeaker, - foregroundColor: Colors.black54, - backgroundColor: Theme.of(widget.context).backgroundColor, - ); - */ - final hangupButton = FloatingActionButton( - heroTag: 'hangup', - onPressed: _hangUp, - tooltip: 'Hangup', - backgroundColor: _state == CallState.kEnded ? Colors.black45 : Colors.red, - child: const Icon(Icons.call_end), - ); - - final answerButton = FloatingActionButton( - heroTag: 'answer', - onPressed: _answerCall, - tooltip: 'Answer', - backgroundColor: Colors.green, - child: const Icon(Icons.phone), - ); - - final muteMicButton = FloatingActionButton( - heroTag: 'muteMic', - onPressed: _muteMic, - foregroundColor: isMicrophoneMuted ? Colors.black26 : Colors.white, - backgroundColor: isMicrophoneMuted ? Colors.white : Colors.black45, - child: Icon(isMicrophoneMuted ? Icons.mic_off : Icons.mic), - ); - - final screenSharingButton = FloatingActionButton( - heroTag: 'screenSharing', - onPressed: _screenSharing, - foregroundColor: isScreensharingEnabled ? Colors.black26 : Colors.white, - backgroundColor: isScreensharingEnabled ? Colors.white : Colors.black45, - child: const Icon(Icons.desktop_mac), - ); - - final holdButton = FloatingActionButton( - heroTag: 'hold', - onPressed: _remoteOnHold, - foregroundColor: isRemoteOnHold ? Colors.black26 : Colors.white, - backgroundColor: isRemoteOnHold ? Colors.white : Colors.black45, - child: const Icon(Icons.pause), - ); - - final muteCameraButton = FloatingActionButton( - heroTag: 'muteCam', - onPressed: _muteCamera, - foregroundColor: isLocalVideoMuted ? Colors.black26 : Colors.white, - backgroundColor: isLocalVideoMuted ? Colors.white : Colors.black45, - child: Icon(isLocalVideoMuted ? Icons.videocam_off : Icons.videocam), - ); - - switch (_state) { - case CallState.kRinging: - case CallState.kInviteSent: - case CallState.kCreateAnswer: - case CallState.kConnecting: - return call.isOutgoing - ? [hangupButton] - : [answerButton, hangupButton]; - case CallState.kConnected: - return [ - muteMicButton, - //switchSpeakerButton, - if (!voiceonly && !kIsWeb) switchCameraButton, - if (!voiceonly) muteCameraButton, - if (PlatformInfos.isMobile || PlatformInfos.isWeb) - screenSharingButton, - holdButton, - hangupButton, - ]; - case CallState.kEnded: - return [ - hangupButton, - ]; - case CallState.kFledgling: - case CallState.kWaitLocalMedia: - case CallState.kCreateOffer: - case CallState.kEnding: - case null: - break; - } - return []; - } - - List _buildContent(Orientation orientation, bool isFloating) { - final stackWidgets = []; - - final call = this.call; - if (call.callHasEnded) { - return stackWidgets; - } - - if (call.localHold || call.remoteOnHold) { - var title = ''; - if (call.localHold) { - title = '${call.room.getLocalizedDisplayname( - MatrixLocals(L10n.of(widget.context)!), - )} held the call.'; - } else if (call.remoteOnHold) { - title = 'You held the call.'; - } - stackWidgets.add( - Center( - child: Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - const Icon( - Icons.pause, - size: 48.0, - color: Colors.white, - ), - Text( - title, - style: const TextStyle( - color: Colors.white, - fontSize: 24.0, - ), - ), - ], - ), - ), - ); - return stackWidgets; - } - - var primaryStream = call.remoteScreenSharingStream ?? - call.localScreenSharingStream ?? - call.remoteUserMediaStream ?? - call.localUserMediaStream; - - if (!connected) { - primaryStream = call.localUserMediaStream; - } - - if (primaryStream != null) { - stackWidgets.add( - Center( - child: _StreamView( - primaryStream, - mainView: true, - matrixClient: widget.client, - ), - ), - ); - } - - if (isFloating || !connected) { - return stackWidgets; - } - - _resizeLocalVideo(orientation); - - if (call.getRemoteStreams.isEmpty) { - return stackWidgets; - } - - final secondaryStreamViews = []; - - if (call.remoteScreenSharingStream != null) { - final remoteUserMediaStream = call.remoteUserMediaStream; - secondaryStreamViews.add( - SizedBox( - width: _localVideoWidth, - height: _localVideoHeight, - child: - _StreamView(remoteUserMediaStream!, matrixClient: widget.client), - ), - ); - secondaryStreamViews.add(const SizedBox(height: 10)); - } - - final localStream = - call.localUserMediaStream ?? call.localScreenSharingStream; - if (localStream != null && !isFloating) { - secondaryStreamViews.add( - SizedBox( - width: _localVideoWidth, - height: _localVideoHeight, - child: _StreamView(localStream, matrixClient: widget.client), - ), - ); - secondaryStreamViews.add(const SizedBox(height: 10)); - } - - if (call.localScreenSharingStream != null && !isFloating) { - secondaryStreamViews.add( - SizedBox( - width: _localVideoWidth, - height: _localVideoHeight, - child: _StreamView( - call.remoteUserMediaStream!, - matrixClient: widget.client, - ), - ), - ); - secondaryStreamViews.add(const SizedBox(height: 10)); - } - - if (secondaryStreamViews.isNotEmpty) { - stackWidgets.add( - Container( - padding: const EdgeInsets.fromLTRB(0, 20, 0, 120), - alignment: Alignment.bottomRight, - child: Container( - width: _localVideoWidth, - margin: _localVideoMargin, - child: Column( - children: secondaryStreamViews, - ), - ), - ), - ); - } - - return stackWidgets; - } - @override Widget build(BuildContext context) { return PIPView( builder: (context, isFloating) { + // Build action buttons + final switchCameraButton = FloatingActionButton( + heroTag: 'switchCamera', + onPressed: _switchCamera, + backgroundColor: Colors.black45, + child: const Icon(Icons.switch_camera), + ); + final hangupButton = FloatingActionButton( + heroTag: 'hangup', + onPressed: _hangUp, + tooltip: 'Hangup', + backgroundColor: _state == CallState.kEnded + ? Colors.black45 + : Colors.red, + child: const Icon(Icons.call_end), + ); + final answerButton = FloatingActionButton( + heroTag: 'answer', + onPressed: _answerCall, + tooltip: 'Answer', + backgroundColor: Colors.green, + child: const Icon(Icons.phone), + ); + final muteMicButton = FloatingActionButton( + heroTag: 'muteMic', + onPressed: _muteMic, + foregroundColor: isMicrophoneMuted ? Colors.black26 : Colors.white, + backgroundColor: isMicrophoneMuted ? Colors.white : Colors.black45, + child: Icon(isMicrophoneMuted ? Icons.mic_off : Icons.mic), + ); + final screenSharingButton = FloatingActionButton( + heroTag: 'screenSharing', + onPressed: _screenSharing, + foregroundColor: isScreensharingEnabled + ? Colors.black26 + : Colors.white, + backgroundColor: isScreensharingEnabled + ? Colors.white + : Colors.black45, + child: const Icon(Icons.desktop_mac), + ); + final holdButton = FloatingActionButton( + heroTag: 'hold', + onPressed: _remoteOnHold, + foregroundColor: isRemoteOnHold ? Colors.black26 : Colors.white, + backgroundColor: isRemoteOnHold ? Colors.white : Colors.black45, + child: const Icon(Icons.pause), + ); + final muteCameraButton = FloatingActionButton( + heroTag: 'muteCam', + onPressed: _muteCamera, + foregroundColor: isLocalVideoMuted ? Colors.black26 : Colors.white, + backgroundColor: isLocalVideoMuted ? Colors.white : Colors.black45, + child: Icon(isLocalVideoMuted ? Icons.videocam_off : Icons.videocam), + ); + + late final List actionButtons; + if (!isFloating) { + switch (_state) { + case CallState.kRinging: + case CallState.kInviteSent: + case CallState.kCreateAnswer: + case CallState.kConnecting: + actionButtons = call.isOutgoing + ? [hangupButton] + : [answerButton, hangupButton]; + break; + case CallState.kConnected: + actionButtons = [ + muteMicButton, + if (!voiceonly && !kIsWeb) switchCameraButton, + if (!voiceonly) muteCameraButton, + if (PlatformInfos.isMobile || PlatformInfos.isWeb) + screenSharingButton, + holdButton, + hangupButton, + ]; + break; + case CallState.kEnded: + actionButtons = [hangupButton]; + break; + case CallState.kFledgling: + case CallState.kWaitLocalMedia: + case CallState.kCreateOffer: + case CallState.kEnding: + case null: + actionButtons = []; + break; + } + } else { + actionButtons = []; + } + return Scaffold( resizeToAvoidBottomInset: !isFloating, floatingActionButtonLocation: @@ -590,19 +444,148 @@ class MyCallingPage extends State { width: 320.0, height: 150.0, child: Row( - mainAxisAlignment: MainAxisAlignment.spaceAround, - children: _buildActionButtons(isFloating), + mainAxisAlignment: .spaceAround, + children: actionButtons, ), ), body: OrientationBuilder( builder: (BuildContext context, Orientation orientation) { + final stackWidgets = []; + + final callHasEnded = call.callHasEnded; + if (!callHasEnded) { + if (call.localHold || call.remoteOnHold) { + var title = ''; + if (call.localHold) { + title = + '${call.room.getLocalizedDisplayname(MatrixLocals(L10n.of(widget.context)))} held the call.'; + } else if (call.remoteOnHold) { + title = 'You held the call.'; + } + stackWidgets.add( + Center( + child: Column( + mainAxisAlignment: .center, + children: [ + const Icon( + Icons.pause, + size: 48.0, + color: Colors.white, + ), + Text( + title, + style: const TextStyle( + color: Colors.white, + fontSize: 24.0, + ), + ), + ], + ), + ), + ); + } else { + var primaryStream = + call.remoteScreenSharingStream ?? + call.localScreenSharingStream ?? + call.remoteUserMediaStream ?? + call.localUserMediaStream; + + if (!connected) { + primaryStream = call.localUserMediaStream; + } + + if (primaryStream != null) { + stackWidgets.add( + Center( + child: _StreamView( + primaryStream, + mainView: true, + matrixClient: widget.client, + ), + ), + ); + } + + if (!isFloating && connected) { + _resizeLocalVideo(orientation); + + if (call.getRemoteStreams.isNotEmpty) { + final secondaryStreamViews = []; + + if (call.remoteScreenSharingStream != null) { + final remoteUserMediaStream = + call.remoteUserMediaStream; + secondaryStreamViews.add( + SizedBox( + width: _localVideoWidth, + height: _localVideoHeight, + child: _StreamView( + remoteUserMediaStream!, + matrixClient: widget.client, + ), + ), + ); + secondaryStreamViews.add(const SizedBox(height: 10)); + } + + final localStream = + call.localUserMediaStream ?? + call.localScreenSharingStream; + if (localStream != null && !isFloating) { + secondaryStreamViews.add( + SizedBox( + width: _localVideoWidth, + height: _localVideoHeight, + child: _StreamView( + localStream, + matrixClient: widget.client, + ), + ), + ); + secondaryStreamViews.add(const SizedBox(height: 10)); + } + + if (call.localScreenSharingStream != null && + !isFloating) { + secondaryStreamViews.add( + SizedBox( + width: _localVideoWidth, + height: _localVideoHeight, + child: _StreamView( + call.remoteUserMediaStream!, + matrixClient: widget.client, + ), + ), + ); + secondaryStreamViews.add(const SizedBox(height: 10)); + } + + if (secondaryStreamViews.isNotEmpty) { + stackWidgets.add( + Container( + padding: const EdgeInsets.only( + top: 20, + bottom: 120, + ), + alignment: Alignment.bottomRight, + child: Container( + width: _localVideoWidth, + margin: _localVideoMargin, + child: Column(children: secondaryStreamViews), + ), + ), + ); + } + } + } + } + } + return Container( - decoration: const BoxDecoration( - color: Colors.black87, - ), + decoration: const BoxDecoration(color: Colors.black87), child: Stack( children: [ - ..._buildContent(orientation, isFloating), + ...stackWidgets, if (!isFloating) Positioned( top: 24.0, diff --git a/lib/pages/dialer/pip/pip_view.dart b/lib/pages/dialer/pip/pip_view.dart index 5396c9136..804ee8371 100644 --- a/lib/pages/dialer/pip/pip_view.dart +++ b/lib/pages/dialer/pip/pip_view.dart @@ -9,10 +9,7 @@ class PIPView extends StatefulWidget { final double? floatingHeight; final bool avoidKeyboard; - final Widget Function( - BuildContext context, - bool isFloating, - ) builder; + final Widget Function(BuildContext context, bool isFloating) builder; const PIPView({ super.key, @@ -95,10 +92,7 @@ class PIPViewState extends State with TickerProviderStateMixin { void _onPanUpdate(DragUpdateDetails details) { if (!_isDragging) return; setState(() { - _dragOffset = _dragOffset.translate( - details.delta.dx, - details.delta.dy, - ); + _dragOffset = _dragOffset.translate(details.delta.dx, details.delta.dy); }); } @@ -138,10 +132,9 @@ class PIPViewState extends State with TickerProviderStateMixin { @override Widget build(BuildContext context) { - final mediaQuery = MediaQuery.of(context); - var windowPadding = mediaQuery.padding; + var windowPadding = MediaQuery.paddingOf(context); if (widget.avoidKeyboard) { - windowPadding += mediaQuery.viewInsets; + windowPadding += MediaQuery.viewInsetsOf(context); } final isFloating = _floating; @@ -183,9 +176,7 @@ class PIPViewState extends State with TickerProviderStateMixin { _dragAnimationController, ]), builder: (context, child) { - final animationCurve = CurveTween( - curve: Curves.easeInOutQuad, - ); + final animationCurve = CurveTween(curve: Curves.easeInOutQuad); final dragAnimationValue = animationCurve.transform( _dragAnimationController.value, ); @@ -266,21 +257,13 @@ class PIPViewState extends State with TickerProviderStateMixin { } } -enum PIPViewCorner { - topLeft, - topRight, - bottomLeft, - bottomRight, -} +enum PIPViewCorner { topLeft, topRight, bottomLeft, bottomRight } class _CornerDistance { final PIPViewCorner corner; final double distance; - _CornerDistance({ - required this.corner, - required this.distance, - }); + _CornerDistance({required this.corner, required this.distance}); } PIPViewCorner _calculateNearestCorner({ @@ -289,15 +272,9 @@ PIPViewCorner _calculateNearestCorner({ }) { _CornerDistance calculateDistance(PIPViewCorner corner) { final distance = offsets[corner]! - .translate( - -offset.dx, - -offset.dy, - ) + .translate(-offset.dx, -offset.dy) .distanceSquared; - return _CornerDistance( - corner: corner, - distance: distance, - ); + return _CornerDistance(corner: corner, distance: distance); } final distances = PIPViewCorner.values.map(calculateDistance).toList(); @@ -330,8 +307,6 @@ Map _calculateOffsets({ return Offset(left, bottom); case PIPViewCorner.bottomRight: return Offset(right, bottom); - default: - throw Exception('Not implemented.'); } } diff --git a/lib/pages/homeserver_picker/homeserver_app_bar.dart b/lib/pages/homeserver_picker/homeserver_app_bar.dart deleted file mode 100644 index 8a1ad4e2b..000000000 --- a/lib/pages/homeserver_picker/homeserver_app_bar.dart +++ /dev/null @@ -1,108 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_typeahead/flutter_typeahead.dart'; - -import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/config/themes.dart'; -import 'package:fluffychat/pages/homeserver_picker/public_homeserver.dart'; -import 'package:fluffychat/utils/localized_exception_extension.dart'; -import 'homeserver_bottom_sheet.dart'; -import 'homeserver_picker.dart'; - -class HomeserverAppBar extends StatelessWidget { - final HomeserverPickerController controller; - - const HomeserverAppBar({super.key, required this.controller}); - - @override - Widget build(BuildContext context) { - return TypeAheadField( - decorationBuilder: (context, child) => ConstrainedBox( - constraints: const BoxConstraints(maxHeight: 256), - child: Material( - borderRadius: BorderRadius.circular(AppConfig.borderRadius), - elevation: Theme.of(context).appBarTheme.scrolledUnderElevation ?? 4, - shadowColor: - Theme.of(context).appBarTheme.shadowColor ?? Colors.black, - child: child, - ), - ), - emptyBuilder: (context) => ListTile( - leading: const Icon(Icons.search_outlined), - title: Text(L10n.of(context)!.nothingFound), - ), - loadingBuilder: (context) => ListTile( - leading: const CircularProgressIndicator.adaptive(strokeWidth: 2), - title: Text(L10n.of(context)!.loadingPleaseWait), - ), - errorBuilder: (context, error) => ListTile( - leading: const Icon(Icons.error_outlined), - title: Text( - error.toLocalizedString(context), - ), - ), - itemBuilder: (context, homeserver) => ListTile( - title: Text(homeserver.name), - subtitle: homeserver.description == null - ? null - : Text(homeserver.description ?? ''), - trailing: IconButton( - icon: const Icon(Icons.info_outlined), - onPressed: () => showModalBottomSheet( - context: context, - builder: (_) => HomeserverBottomSheet( - homeserver: homeserver, - ), - ), - ), - ), - suggestionsCallback: (pattern) async { - pattern = pattern.toLowerCase().trim(); - final homeservers = await controller.loadHomeserverList(); - final matches = homeservers - .where( - (homeserver) => - homeserver.name.toLowerCase().contains(pattern) || - (homeserver.description?.toLowerCase().contains(pattern) ?? - false), - ) - .toList(); - if (pattern.contains('.') && - pattern.split('.').any((part) => part.isNotEmpty) && - !matches.any((homeserver) => homeserver.name == pattern)) { - matches.add(PublicHomeserver(name: pattern)); - } - return matches; - }, - onSelected: (suggestion) { - controller.homeserverController.text = suggestion.name; - controller.checkHomeserverAction(); - }, - controller: controller.homeserverController, - builder: (context, textEditingController, focusNode) => TextField( - enabled: !controller.isLoggingIn, - controller: textEditingController, - focusNode: focusNode, - decoration: InputDecoration( - prefixIcon: Navigator.of(context).canPop() - ? IconButton( - onPressed: Navigator.of(context).pop, - icon: const Icon(Icons.arrow_back), - ) - : null, - fillColor: FluffyThemes.isColumnMode(context) - ? Theme.of(context).colorScheme.surface - // ignore: deprecated_member_use - : Theme.of(context).colorScheme.surfaceVariant, - prefixText: '${L10n.of(context)!.homeserver}: ', - hintText: L10n.of(context)!.enterYourHomeserver, - suffixIcon: const Icon(Icons.search), - ), - textInputAction: TextInputAction.search, - onSubmitted: controller.checkHomeserverAction, - autocorrect: false, - ), - ); - } -} diff --git a/lib/pages/homeserver_picker/homeserver_bottom_sheet.dart b/lib/pages/homeserver_picker/homeserver_bottom_sheet.dart deleted file mode 100644 index 18256d6fb..000000000 --- a/lib/pages/homeserver_picker/homeserver_bottom_sheet.dart +++ /dev/null @@ -1,53 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:url_launcher/url_launcher_string.dart'; - -import 'package:fluffychat/pages/homeserver_picker/public_homeserver.dart'; - -class HomeserverBottomSheet extends StatelessWidget { - final PublicHomeserver homeserver; - const HomeserverBottomSheet({required this.homeserver, super.key}); - - @override - Widget build(BuildContext context) { - final description = homeserver.description; - final registration = homeserver.regLink; - final jurisdiction = homeserver.staffJur; - final homeserverSoftware = homeserver.software; - return Scaffold( - appBar: AppBar( - title: Text(homeserver.name), - ), - body: ListView( - children: [ - if (description != null && description.isNotEmpty) - ListTile( - leading: const Icon(Icons.info_outlined), - title: Text(description), - ), - if (jurisdiction != null && jurisdiction.isNotEmpty) - ListTile( - leading: const Icon(Icons.location_city_outlined), - title: Text(jurisdiction), - ), - if (homeserverSoftware != null && homeserverSoftware.isNotEmpty) - ListTile( - leading: const Icon(Icons.domain_outlined), - title: Text(homeserverSoftware), - ), - ListTile( - onTap: () => launchUrlString(homeserver.name), - leading: const Icon(Icons.link_outlined), - title: Text(homeserver.name), - ), - if (registration != null) - ListTile( - onTap: () => launchUrlString(registration), - leading: const Icon(Icons.person_add_outlined), - title: Text(registration), - ), - ], - ), - ); - } -} diff --git a/lib/pages/homeserver_picker/homeserver_picker.dart b/lib/pages/homeserver_picker/homeserver_picker.dart deleted file mode 100644 index 7ffe089a2..000000000 --- a/lib/pages/homeserver_picker/homeserver_picker.dart +++ /dev/null @@ -1,257 +0,0 @@ -import 'dart:async'; -import 'dart:convert'; - -import 'package:flutter/foundation.dart'; -import 'package:flutter/material.dart'; - -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:collection/collection.dart'; -import 'package:file_picker/file_picker.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_web_auth_2/flutter_web_auth_2.dart'; -import 'package:go_router/go_router.dart'; -import 'package:hive_flutter/hive_flutter.dart'; -import 'package:matrix/matrix.dart'; -import 'package:universal_html/html.dart' as html; - -import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/pages/homeserver_picker/homeserver_picker_view.dart'; -import 'package:fluffychat/pages/homeserver_picker/public_homeserver.dart'; -import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/widgets/app_lock.dart'; -import 'package:fluffychat/widgets/matrix.dart'; -import '../../utils/localized_exception_extension.dart'; - -import 'package:fluffychat/utils/tor_stub.dart' - if (dart.library.html) 'package:tor_detector_web/tor_detector_web.dart'; - -class HomeserverPicker extends StatefulWidget { - const HomeserverPicker({super.key}); - - @override - HomeserverPickerController createState() => HomeserverPickerController(); -} - -class HomeserverPickerController extends State { - bool isLoading = false; - bool isLoggingIn = false; - - final TextEditingController homeserverController = TextEditingController( - text: AppConfig.defaultHomeserver, - ); - - String? error; - - bool isTorBrowser = false; - - Future _checkTorBrowser() async { - if (!kIsWeb) return; - - Hive.openBox('test').then((value) => null).catchError( - (e, s) async { - await showOkAlertDialog( - context: context, - title: L10n.of(context)!.indexedDbErrorTitle, - message: L10n.of(context)!.indexedDbErrorLong, - ); - _checkTorBrowser(); - }, - ); - - final isTor = await TorBrowserDetector.isTorBrowser; - isTorBrowser = isTor; - } - - String? _lastCheckedUrl; - - /// Starts an analysis of the given homeserver. It uses the current domain and - /// makes sure that it is prefixed with https. Then it searches for the - /// well-known information and forwards to the login page depending on the - /// login type. - Future checkHomeserverAction([_]) async { - homeserverController.text = - homeserverController.text.trim().toLowerCase().replaceAll(' ', '-'); - if (homeserverController.text == _lastCheckedUrl) return; - _lastCheckedUrl = homeserverController.text; - setState(() { - error = _rawLoginTypes = loginFlows = null; - isLoading = true; - }); - - try { - var homeserver = Uri.parse(homeserverController.text); - if (homeserver.scheme.isEmpty) { - homeserver = Uri.https(homeserverController.text, ''); - } - final client = Matrix.of(context).getLoginClient(); - final (_, _, loginFlows) = await client.checkHomeserver(homeserver); - this.loginFlows = loginFlows; - if (supportsSso) { - _rawLoginTypes = await client.request( - RequestType.GET, - '/client/v3/login', - ); - } - } catch (e) { - setState(() => error = (e).toLocalizedString(context)); - } finally { - if (mounted) { - setState(() => isLoading = false); - } - } - } - - List? loginFlows; - - bool _supportsFlow(String flowType) => - loginFlows?.any((flow) => flow.type == flowType) ?? false; - - bool get supportsSso => _supportsFlow('m.login.sso'); - - bool isDefaultPlatform = - (PlatformInfos.isMobile || PlatformInfos.isWeb || PlatformInfos.isMacOS); - - bool get supportsPasswordLogin => _supportsFlow('m.login.password'); - - Map? _rawLoginTypes; - - void ssoLoginAction(String? id) async { - final redirectUrl = kIsWeb - ? Uri.parse(html.window.location.href) - .resolveUri( - Uri(pathSegments: ['auth.html']), - ) - .toString() - : isDefaultPlatform - ? '${AppConfig.appOpenUrlScheme.toLowerCase()}://login' - : 'http://localhost:3001//login'; - - final url = Matrix.of(context).getLoginClient().homeserver!.replace( - path: '/_matrix/client/v3/login/sso/redirect${id == null ? '' : '/$id'}', - queryParameters: {'redirectUrl': redirectUrl}, - ); - - final urlScheme = isDefaultPlatform - ? Uri.parse(redirectUrl).scheme - : "http://localhost:3001"; - final result = await FlutterWebAuth2.authenticate( - url: url.toString(), - callbackUrlScheme: urlScheme, - ); - final token = Uri.parse(result).queryParameters['loginToken']; - if (token?.isEmpty ?? false) return; - - setState(() { - error = null; - isLoading = isLoggingIn = true; - }); - try { - await Matrix.of(context).getLoginClient().login( - LoginType.mLoginToken, - token: token, - initialDeviceDisplayName: PlatformInfos.clientName, - ); - } catch (e) { - setState(() { - error = e.toLocalizedString(context); - }); - } finally { - if (mounted) { - setState(() { - isLoading = isLoggingIn = false; - }); - } - } - } - - List? get identityProviders { - final loginTypes = _rawLoginTypes; - if (loginTypes == null) return null; - final List? rawProviders = - loginTypes.tryGetList('flows')?.singleWhereOrNull( - (flow) => flow['type'] == AuthenticationTypes.sso, - )['identity_providers'] ?? - [ - {'id': null}, - ]; - if (rawProviders == null) return null; - final list = - rawProviders.map((json) => IdentityProvider.fromJson(json)).toList(); - if (PlatformInfos.isCupertinoStyle) { - list.sort((a, b) => a.brand == 'apple' ? -1 : 1); - } - return list; - } - - List? cachedHomeservers; - - Future> loadHomeserverList() async { - if (cachedHomeservers != null) return cachedHomeservers!; - final result = await Matrix.of(context) - .getLoginClient() - .httpClient - .get(AppConfig.homeserverList); - final resultJson = jsonDecode(result.body)['public_servers'] as List; - final homeserverList = - resultJson.map((json) => PublicHomeserver.fromJson(json)).toList(); - return cachedHomeservers = homeserverList; - } - - void login() => context.push( - '${GoRouter.of(context).routeInformationProvider.value.uri.path}/login', - ); - - @override - void initState() { - _checkTorBrowser(); - super.initState(); - WidgetsBinding.instance.addPostFrameCallback(checkHomeserverAction); - } - - @override - Widget build(BuildContext context) => HomeserverPickerView(this); - - Future restoreBackup() async { - final picked = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles(withData: true), - ); - final file = picked?.files.firstOrNull; - if (file == null) return; - setState(() { - error = null; - isLoading = isLoggingIn = true; - }); - try { - final client = Matrix.of(context).getLoginClient(); - await client.importDump(String.fromCharCodes(file.bytes!)); - Matrix.of(context).initMatrix(); - } catch (e) { - setState(() { - error = e.toLocalizedString(context); - }); - } finally { - if (mounted) { - setState(() { - isLoading = isLoggingIn = false; - }); - } - } - } -} - -class IdentityProvider { - final String? id; - final String? name; - final String? icon; - final String? brand; - - IdentityProvider({this.id, this.name, this.icon, this.brand}); - - factory IdentityProvider.fromJson(Map json) => - IdentityProvider( - id: json['id'], - name: json['name'], - icon: json['icon'], - brand: json['brand'], - ); -} diff --git a/lib/pages/homeserver_picker/homeserver_picker_view.dart b/lib/pages/homeserver_picker/homeserver_picker_view.dart deleted file mode 100644 index ce86abec0..000000000 --- a/lib/pages/homeserver_picker/homeserver_picker_view.dart +++ /dev/null @@ -1,222 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:collection/collection.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:url_launcher/url_launcher_string.dart'; - -import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/widgets/layouts/login_scaffold.dart'; -import 'package:fluffychat/widgets/matrix.dart'; -import '../../config/themes.dart'; -import '../../widgets/mxc_image.dart'; -import 'homeserver_app_bar.dart'; -import 'homeserver_picker.dart'; - -class HomeserverPickerView extends StatelessWidget { - final HomeserverPickerController controller; - - const HomeserverPickerView(this.controller, {super.key}); - - @override - Widget build(BuildContext context) { - final identityProviders = controller.identityProviders; - final errorText = controller.error; - final publicHomeserver = controller.cachedHomeservers?.singleWhereOrNull( - (homeserver) => - homeserver.name == - controller.homeserverController.text.trim().toLowerCase(), - ); - final regLink = publicHomeserver?.regLink; - return LoginScaffold( - enforceMobileMode: Matrix.of(context).client.isLogged(), - appBar: AppBar( - titleSpacing: 12, - automaticallyImplyLeading: false, - surfaceTintColor: Theme.of(context).colorScheme.surface, - title: HomeserverAppBar(controller: controller), - ), - body: Column( - children: [ - // display a prominent banner to import session for TOR browser - // users. This feature is just some UX sugar as TOR users are - // usually forced to logout as TOR browser is non-persistent - AnimatedContainer( - height: controller.isTorBrowser ? 64 : 0, - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - clipBehavior: Clip.hardEdge, - decoration: const BoxDecoration(), - child: Material( - clipBehavior: Clip.hardEdge, - borderRadius: - const BorderRadius.vertical(bottom: Radius.circular(8)), - color: Theme.of(context).colorScheme.surface, - child: ListTile( - leading: const Icon(Icons.vpn_key), - title: Text(L10n.of(context)!.hydrateTor), - subtitle: Text(L10n.of(context)!.hydrateTorLong), - trailing: const Icon(Icons.chevron_right_outlined), - onTap: controller.restoreBackup, - ), - ), - ), - Expanded( - child: controller.isLoading - ? const Center(child: CircularProgressIndicator.adaptive()) - : ListView( - children: [ - if (errorText != null) ...[ - const SizedBox(height: 12), - const Center( - child: Icon( - Icons.error_outline, - size: 48, - color: Colors.orange, - ), - ), - const SizedBox(height: 12), - Center( - child: Text( - errorText, - textAlign: TextAlign.center, - style: TextStyle( - color: Theme.of(context).colorScheme.error, - fontSize: 18, - ), - ), - ), - Center( - child: Text( - L10n.of(context)! - .pleaseTryAgainLaterOrChooseDifferentServer, - textAlign: TextAlign.center, - style: TextStyle( - color: Theme.of(context).colorScheme.error, - fontSize: 12, - ), - ), - ), - const SizedBox(height: 36), - ] else - Padding( - padding: const EdgeInsets.only( - top: 0.0, - right: 8.0, - left: 8.0, - bottom: 16.0, - ), - child: Image.asset( - 'assets/banner_transparent.png', - ), - ), - if (identityProviders != null) ...[ - ...identityProviders.map( - (provider) => _LoginButton( - icon: provider.icon == null - ? const Icon( - Icons.open_in_new_outlined, - size: 16, - ) - : Material( - borderRadius: BorderRadius.circular( - AppConfig.borderRadius, - ), - clipBehavior: Clip.hardEdge, - child: MxcImage( - placeholder: (_) => const Icon( - Icons.open_in_new_outlined, - size: 16, - ), - uri: Uri.parse(provider.icon!), - width: 24, - height: 24, - isThumbnail: false, - //isThumbnail: false, - ), - ), - label: L10n.of(context)!.signInWith( - provider.name ?? - provider.brand ?? - L10n.of(context)!.singlesignon, - ), - onPressed: () => - controller.ssoLoginAction(provider.id), - ), - ), - ], - if (controller.supportsPasswordLogin) - _LoginButton( - onPressed: controller.login, - label: L10n.of(context)!.signInWithPassword, - icon: const Icon(Icons.lock_open_outlined, size: 16), - ), - if (regLink != null) - _LoginButton( - onPressed: () => launchUrlString(regLink), - icon: const Icon( - Icons.open_in_new_outlined, - size: 16, - ), - label: L10n.of(context)!.register, - ), - _LoginButton( - onPressed: controller.restoreBackup, - label: L10n.of(context)!.hydrate, - withBorder: false, - ), - const SizedBox(height: 16), - ], - ), - ), - ], - ), - ); - } -} - -class _LoginButton extends StatelessWidget { - final Widget? icon; - final String label; - final void Function() onPressed; - final bool withBorder; - - const _LoginButton({ - this.icon, - required this.label, - required this.onPressed, - this.withBorder = true, - }); - - @override - Widget build(BuildContext context) { - final icon = this.icon; - return Container( - margin: const EdgeInsets.only(bottom: 12), - padding: const EdgeInsets.symmetric(horizontal: 16), - alignment: Alignment.center, - child: SizedBox( - width: double.infinity, - child: OutlinedButton.icon( - style: OutlinedButton.styleFrom( - side: FluffyThemes.isColumnMode(context) - ? BorderSide.none - : BorderSide( - color: Theme.of(context).colorScheme.outlineVariant, - width: 1, - ), - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular(99), - ), - foregroundColor: Theme.of(context).colorScheme.onSurface, - backgroundColor: withBorder - ? Theme.of(context).colorScheme.surface - : Colors.transparent, - ), - onPressed: onPressed, - label: Text(label), - icon: icon ?? const SizedBox.shrink(), - ), - ), - ); - } -} diff --git a/lib/pages/homeserver_picker/public_homeserver.dart b/lib/pages/homeserver_picker/public_homeserver.dart deleted file mode 100644 index 4eef2aa56..000000000 --- a/lib/pages/homeserver_picker/public_homeserver.dart +++ /dev/null @@ -1,73 +0,0 @@ -class PublicHomeserver { - final String name; - final String? clientDomain; - final String? isp; - final String? staffJur; - final bool? usingVanillaReg; - final String? description; - final String? regMethod; - final String? regLink; - final String? software; - final String? version; - final bool? captcha; - final bool? email; - final List? languages; - final List? features; - final int? onlineStatus; - final String? serverDomain; - final int? verStatus; - final int? roomDirectory; - final bool? slidingSync; - final bool? ipv6; - - const PublicHomeserver({ - required this.name, - this.clientDomain, - this.isp, - this.staffJur, - this.usingVanillaReg, - this.description, - this.regMethod, - this.regLink, - this.software, - this.version, - this.captcha, - this.email, - this.languages, - this.features, - this.onlineStatus, - this.serverDomain, - this.verStatus, - this.roomDirectory, - this.slidingSync, - this.ipv6, - }); - - factory PublicHomeserver.fromJson(Map json) => - PublicHomeserver( - name: json['name'], - clientDomain: json['client_domain'], - isp: json['isp'], - staffJur: json['staff_jur'], - usingVanillaReg: json['using_vanilla_reg'], - description: json['description'], - regMethod: json['reg_method'], - regLink: json['reg_link'], - software: json['software'], - version: json['version'], - captcha: json['captcha'], - email: json['email'], - languages: json['languages'] == null - ? null - : List.from(json['languages']), - features: json['features'] == null - ? null - : List.from(json['features']), - onlineStatus: json['online_status'], - serverDomain: json['server_domain'], - verStatus: json['ver_status'], - roomDirectory: json['room_directory'], - slidingSync: json['sliding_sync'], - ipv6: json['ipv6'], - ); -} diff --git a/lib/pages/image_viewer/image_viewer.dart b/lib/pages/image_viewer/image_viewer.dart index 94ab19dd4..fc64d0f4a 100644 --- a/lib/pages/image_viewer/image_viewer.dart +++ b/lib/pages/image_viewer/image_viewer.dart @@ -1,34 +1,110 @@ import 'package:flutter/material.dart'; +import 'package:flutter/services.dart'; -import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/themes.dart'; import 'package:fluffychat/pages/image_viewer/image_viewer_view.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/widgets/matrix.dart'; +import 'package:fluffychat/utils/show_scaffold_dialog.dart'; +import 'package:fluffychat/widgets/share_scaffold_dialog.dart'; import '../../utils/matrix_sdk_extensions/event_extension.dart'; class ImageViewer extends StatefulWidget { final Event event; + final Timeline? timeline; + final BuildContext outerContext; - const ImageViewer(this.event, {super.key}); + const ImageViewer( + this.event, { + required this.outerContext, + this.timeline, + super.key, + }); @override ImageViewerController createState() => ImageViewerController(); } class ImageViewerController extends State { - /// Forward this image to another room. - void forwardAction() { - Matrix.of(context).shareContent = widget.event.content; - context.go('/rooms'); + final FocusNode focusNode = FocusNode(); + + @override + void initState() { + super.initState(); + allEvents = + widget.timeline?.events + .where( + (event) => { + MessageTypes.Image, + MessageTypes.Sticker, + if (PlatformInfos.supportsVideoPlayer) MessageTypes.Video, + }.contains(event.messageType), + ) + .toList() + .reversed + .toList() ?? + [widget.event]; + var index = allEvents.indexWhere( + (event) => event.eventId == widget.event.eventId, + ); + if (index < 0) index = 0; + pageController = PageController(initialPage: index); } - /// Save this file with a system call. - void saveFileAction(BuildContext context) => widget.event.saveFile(context); + late final PageController pageController; + + late final List allEvents; + + void onKeyEvent(KeyEvent event) { + switch (event.logicalKey) { + case LogicalKeyboardKey.arrowUp: + if (canGoBack) prevImage(); + break; + case LogicalKeyboardKey.arrowDown: + if (canGoNext) nextImage(); + break; + } + } + + Future prevImage() async { + await pageController.previousPage( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + ); + if (!mounted) return; + setState(() {}); + } + + Future nextImage() async { + await pageController.nextPage( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + ); + if (!mounted) return; + setState(() {}); + } + + int get _index => pageController.page?.toInt() ?? 0; + + Event get currentEvent => allEvents[_index]; + + bool get canGoNext => _index < allEvents.length - 1; + + bool get canGoBack => _index > 0; + + /// Forward this image to another room. + void forwardAction() => showScaffoldDialog( + context: context, + builder: (context) => + ShareScaffoldDialog(items: [ContentShareItem(currentEvent.content)]), + ); /// Save this file with a system call. - void shareFileAction(BuildContext context) => widget.event.shareFile(context); + void saveFileAction(BuildContext context) => currentEvent.saveFile(context); + + /// Save this file with a system call. + void shareFileAction(BuildContext context) => currentEvent.shareFile(context); static const maxScaleFactor = 1.5; @@ -36,7 +112,7 @@ class ImageViewerController extends State { void onInteractionEnds(ScaleEndDetails endDetails) { if (PlatformInfos.usesTouchscreen == false) { if (endDetails.velocity.pixelsPerSecond.dy > - MediaQuery.of(context).size.height * maxScaleFactor) { + MediaQuery.sizeOf(context).height * maxScaleFactor) { Navigator.of(context, rootNavigator: false).pop(); } } diff --git a/lib/pages/image_viewer/image_viewer_view.dart b/lib/pages/image_viewer/image_viewer_view.dart index e4352864f..7eb529494 100644 --- a/lib/pages/image_viewer/image_viewer_view.dart +++ b/lib/pages/image_viewer/image_viewer_view.dart @@ -1,8 +1,11 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/image_viewer/video_player.dart'; import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/widgets/hover_builder.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; import 'image_viewer.dart'; @@ -13,56 +16,140 @@ class ImageViewerView extends StatelessWidget { @override Widget build(BuildContext context) { - return Scaffold( - backgroundColor: Colors.black, - extendBodyBehindAppBar: true, - appBar: AppBar( - elevation: 0, - leading: IconButton( - icon: const Icon(Icons.close), - onPressed: Navigator.of(context).pop, - color: Colors.white, - tooltip: L10n.of(context)!.close, - ), - backgroundColor: const Color(0x44000000), - actions: [ - IconButton( - icon: const Icon(Icons.reply_outlined), - onPressed: controller.forwardAction, + final iconButtonStyle = IconButton.styleFrom( + backgroundColor: Colors.black.withAlpha(200), + foregroundColor: Colors.white, + ); + return GestureDetector( + onTap: () => Navigator.of(context).pop(), + child: Scaffold( + backgroundColor: Colors.black.withAlpha(128), + extendBodyBehindAppBar: true, + appBar: AppBar( + elevation: 0, + leading: IconButton( + style: iconButtonStyle, + icon: const Icon(Icons.close), + onPressed: Navigator.of(context).pop, color: Colors.white, - tooltip: L10n.of(context)!.share, + tooltip: L10n.of(context).close, ), - IconButton( - icon: const Icon(Icons.download_outlined), - onPressed: () => controller.saveFileAction(context), - color: Colors.white, - tooltip: L10n.of(context)!.downloadFile, - ), - if (PlatformInfos.isMobile) - // Use builder context to correctly position the share dialog on iPad - Builder( - builder: (context) => IconButton( - onPressed: () => controller.shareFileAction(context), - tooltip: L10n.of(context)!.share, - color: Colors.white, - icon: Icon(Icons.adaptive.share_outlined), + backgroundColor: Colors.transparent, + actions: [ + IconButton( + style: iconButtonStyle, + icon: const Icon(Icons.reply_outlined), + onPressed: controller.forwardAction, + color: Colors.white, + tooltip: L10n.of(context).share, + ), + const SizedBox(width: 8), + IconButton( + style: iconButtonStyle, + icon: const Icon(Icons.download_outlined), + onPressed: () => controller.saveFileAction(context), + color: Colors.white, + tooltip: L10n.of(context).downloadFile, + ), + const SizedBox(width: 8), + if (PlatformInfos.isMobile) + // Use builder context to correctly position the share dialog on iPad + Padding( + padding: const EdgeInsets.only(right: 8.0), + child: Builder( + builder: (context) => IconButton( + style: iconButtonStyle, + onPressed: () => controller.shareFileAction(context), + tooltip: L10n.of(context).share, + color: Colors.white, + icon: Icon(Icons.adaptive.share_outlined), + ), + ), ), - ), - ], - ), - body: InteractiveViewer( - minScale: 1.0, - maxScale: 10.0, - onInteractionEnd: controller.onInteractionEnds, - child: Center( - child: Hero( - tag: controller.widget.event.eventId, - child: MxcImage( - event: controller.widget.event, - fit: BoxFit.contain, - isThumbnail: false, - animated: true, - ), + ], + ), + body: HoverBuilder( + builder: (context, hovered) => Stack( + children: [ + KeyboardListener( + focusNode: controller.focusNode, + onKeyEvent: controller.onKeyEvent, + child: PageView.builder( + scrollDirection: Axis.vertical, + controller: controller.pageController, + itemCount: controller.allEvents.length, + itemBuilder: (context, i) { + final event = controller.allEvents[i]; + switch (event.messageType) { + case MessageTypes.Video: + return Padding( + padding: const EdgeInsets.only(top: 52.0), + child: Center( + child: GestureDetector( + // Ignore taps to not go back here: + onTap: () {}, + child: EventVideoPlayer(event), + ), + ), + ); + case MessageTypes.Image: + case MessageTypes.Sticker: + default: + return InteractiveViewer( + minScale: 1.0, + maxScale: 10.0, + onInteractionEnd: controller.onInteractionEnds, + child: Center( + child: Hero( + tag: event.eventId, + child: GestureDetector( + // Ignore taps to not go back here: + onTap: () {}, + child: MxcImage( + key: ValueKey(event.eventId), + event: event, + fit: BoxFit.contain, + isThumbnail: false, + animated: true, + ), + ), + ), + ), + ); + } + }, + ), + ), + if (hovered) + Align( + alignment: Alignment.centerRight, + child: Column( + mainAxisSize: .min, + children: [ + if (controller.canGoBack) + Padding( + padding: const EdgeInsets.all(12.0), + child: IconButton( + style: iconButtonStyle, + tooltip: L10n.of(context).previous, + icon: const Icon(Icons.arrow_upward_outlined), + onPressed: controller.prevImage, + ), + ), + if (controller.canGoNext) + Padding( + padding: const EdgeInsets.all(12.0), + child: IconButton( + style: iconButtonStyle, + tooltip: L10n.of(context).next, + icon: const Icon(Icons.arrow_downward_outlined), + onPressed: controller.nextImage, + ), + ), + ], + ), + ), + ], ), ), ), diff --git a/lib/pages/image_viewer/video_player.dart b/lib/pages/image_viewer/video_player.dart new file mode 100644 index 000000000..2fd5e0c2c --- /dev/null +++ b/lib/pages/image_viewer/video_player.dart @@ -0,0 +1,185 @@ +import 'dart:io'; + +import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; + +import 'package:chewie/chewie.dart'; +import 'package:matrix/matrix.dart'; +import 'package:path_provider/path_provider.dart'; +import 'package:universal_html/html.dart' as html; +import 'package:video_player/video_player.dart'; + +import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/event_extension.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/widgets/blur_hash.dart'; +import '../../../utils/error_reporter.dart'; +import '../../widgets/mxc_image.dart'; + +class EventVideoPlayer extends StatefulWidget { + final Event event; + + const EventVideoPlayer(this.event, {super.key}); + + @override + EventVideoPlayerState createState() => EventVideoPlayerState(); +} + +class EventVideoPlayerState extends State { + ChewieController? _chewieController; + VideoPlayerController? _videoPlayerController; + + double? _downloadProgress; + + // The video_player package only doesn't support Windows and Linux. + final _supportsVideoPlayer = + !PlatformInfos.isWindows && !PlatformInfos.isLinux; + + Future _downloadAction() async { + if (!_supportsVideoPlayer) { + widget.event.saveFile(context); + return; + } + + try { + final fileSize = widget.event.content + .tryGetMap('info') + ?.tryGet('size'); + final videoFile = await widget.event.downloadAndDecryptAttachment( + onDownloadProgress: fileSize == null + ? null + : (progress) { + final progressPercentage = progress / fileSize; + setState(() { + _downloadProgress = progressPercentage < 1 + ? progressPercentage + : null; + }); + }, + ); + + // Dispose the controllers if we already have them. + _disposeControllers(); + late VideoPlayerController videoPlayerController; + + // Create the VideoPlayerController from the contents of videoFile. + if (kIsWeb) { + final blob = html.Blob([videoFile.bytes], videoFile.mimeType); + final networkUri = Uri.parse(html.Url.createObjectUrlFromBlob(blob)); + videoPlayerController = VideoPlayerController.networkUrl(networkUri); + } else { + final tempDir = await getTemporaryDirectory(); + final fileName = Uri.encodeComponent( + widget.event.attachmentOrThumbnailMxcUrl()!.pathSegments.last, + ); + final file = File('${tempDir.path}/${fileName}_${videoFile.name}'); + if (await file.exists() == false) { + await file.writeAsBytes(videoFile.bytes); + } + videoPlayerController = VideoPlayerController.file(file); + } + _videoPlayerController = videoPlayerController; + + await videoPlayerController.initialize(); + + // Create a ChewieController on top. + setState(() { + _chewieController = ChewieController( + videoPlayerController: videoPlayerController, + showControlsOnInitialize: false, + autoPlay: true, + autoInitialize: true, + looping: true, + aspectRatio: _videoPlayerController?.value.aspectRatio, + ); + }); + } on IOException catch (e) { + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); + } catch (e, s) { + ErrorReporter(context, 'Unable to play video').onErrorCallback(e, s); + } + } + + void _disposeControllers() { + _chewieController?.dispose(); + _videoPlayerController?.dispose(); + _chewieController = null; + _videoPlayerController = null; + } + + @override + void dispose() { + _disposeControllers(); + super.dispose(); + } + + @override + void initState() { + super.initState(); + WidgetsBinding.instance.addPostFrameCallback((_) { + _downloadAction(); + }); + } + + static const String fallbackBlurHash = 'L5H2EC=PM+yV0g-mq.wG9c010J}I'; + + @override + Widget build(BuildContext context) { + final hasThumbnail = widget.event.hasThumbnail; + final blurHash = + (widget.event.infoMap as Map).tryGet( + 'xyz.amorgan.blurhash', + ) ?? + fallbackBlurHash; + final infoMap = widget.event.content.tryGetMap('info'); + final videoWidth = infoMap?.tryGet('w') ?? 400; + final videoHeight = infoMap?.tryGet('h') ?? 300; + final height = MediaQuery.sizeOf(context).height - 52; + final width = videoWidth * (height / videoHeight); + + final chewieController = _chewieController; + return chewieController != null + ? Center( + child: SizedBox( + width: width, + height: height, + child: Chewie(controller: chewieController), + ), + ) + : Stack( + children: [ + Center( + child: Hero( + tag: widget.event.eventId, + child: hasThumbnail + ? MxcImage( + event: widget.event, + isThumbnail: true, + width: width, + height: height, + fit: BoxFit.cover, + placeholder: (context) => BlurHash( + blurhash: blurHash, + width: width, + height: height, + fit: BoxFit.cover, + ), + ) + : BlurHash( + blurhash: blurHash, + width: width, + height: height, + ), + ), + ), + Center( + child: CircularProgressIndicator.adaptive( + value: _downloadProgress, + ), + ), + ], + ); + } +} diff --git a/lib/pages/intro/flows/restore_backup_flow.dart b/lib/pages/intro/flows/restore_backup_flow.dart new file mode 100644 index 000000000..c8f18052d --- /dev/null +++ b/lib/pages/intro/flows/restore_backup_flow.dart @@ -0,0 +1,21 @@ +import 'package:flutter/material.dart'; + +import 'package:fluffychat/utils/file_selector.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +Future restoreBackupFlow(BuildContext context) async { + final picked = await selectFiles(context); + final file = picked.firstOrNull; + if (file == null) return; + + if (!context.mounted) return; + await showFutureLoadingDialog( + context: context, + future: () async { + final client = await Matrix.of(context).getLoginClient(); + await client.importDump(String.fromCharCodes(await file.readAsBytes())); + Matrix.of(context).initMatrix(); + }, + ); +} diff --git a/lib/pages/intro/intro_page.dart b/lib/pages/intro/intro_page.dart new file mode 100644 index 000000000..46fd7e5d0 --- /dev/null +++ b/lib/pages/intro/intro_page.dart @@ -0,0 +1,193 @@ +import 'package:flutter/material.dart'; + +import 'package:flutter_linkify/flutter_linkify.dart'; +import 'package:go_router/go_router.dart'; +import 'package:url_launcher/url_launcher.dart'; +import 'package:url_launcher/url_launcher_string.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/intro/flows/restore_backup_flow.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/widgets/layouts/login_scaffold.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +class IntroPage extends StatelessWidget { + final bool isLoading, hasPresetHomeserver; + final String? loggingInToHomeserver, welcomeText; + final VoidCallback login; + + const IntroPage({ + required this.isLoading, + required this.loggingInToHomeserver, + super.key, + required this.hasPresetHomeserver, + required this.welcomeText, + required this.login, + }); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + final addMultiAccount = Matrix.of( + context, + ).widget.clients.any((client) => client.isLogged()); + final loggingInToHomeserver = this.loggingInToHomeserver; + + return LoginScaffold( + appBar: AppBar( + centerTitle: true, + title: Text( + addMultiAccount + ? L10n.of(context).addAccount + : L10n.of(context).login, + ), + actions: [ + PopupMenuButton( + useRootNavigator: true, + itemBuilder: (_) => [ + PopupMenuItem( + onTap: isLoading ? null : () => restoreBackupFlow(context), + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.import_export_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).hydrate), + ], + ), + ), + PopupMenuItem( + onTap: () => launchUrl(AppConfig.privacyUrl), + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.privacy_tip_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).privacy), + ], + ), + ), + PopupMenuItem( + value: () => PlatformInfos.showDialog(context), + child: Row( + mainAxisSize: .min, + children: [ + const Icon(Icons.info_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).about), + ], + ), + ), + ], + ), + ], + ), + body: isLoading + ? Center( + child: Column( + mainAxisAlignment: .center, + children: [ + CircularProgressIndicator.adaptive(), + if (loggingInToHomeserver != null) + Text(L10n.of(context).logInTo(loggingInToHomeserver)), + ], + ), + ) + : LayoutBuilder( + builder: (context, constraints) { + return SingleChildScrollView( + child: ConstrainedBox( + constraints: BoxConstraints( + minHeight: constraints.maxHeight, + ), + child: IntrinsicHeight( + child: Column( + children: [ + Container( + alignment: Alignment.center, + padding: const EdgeInsets.symmetric( + horizontal: 8.0, + ), + child: Hero( + tag: 'info-logo', + child: Image.asset( + './assets/banner_transparent.png', + fit: BoxFit.fitWidth, + ), + ), + ), + const SizedBox(height: 32), + Padding( + padding: const EdgeInsets.symmetric( + horizontal: 32.0, + ), + child: SelectableLinkify( + text: welcomeText ?? L10n.of(context).appIntro, + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + textAlign: TextAlign.center, + linkStyle: TextStyle( + color: theme.colorScheme.secondary, + decorationColor: theme.colorScheme.secondary, + ), + onOpen: (link) => launchUrlString(link.url), + ), + ), + const Spacer(), + Padding( + padding: const EdgeInsets.all(32.0), + child: Column( + mainAxisSize: .min, + crossAxisAlignment: .stretch, + children: [ + if (!hasPresetHomeserver) + ElevatedButton( + style: ElevatedButton.styleFrom( + backgroundColor: + theme.colorScheme.secondary, + foregroundColor: + theme.colorScheme.onSecondary, + ), + onPressed: () => context.go( + '${GoRouterState.of(context).uri.path}/sign_up', + ), + child: Text( + L10n.of(context).createNewAccount, + ), + ), + SizedBox(height: 16), + ElevatedButton( + onPressed: login, + child: Text(L10n.of(context).signIn), + ), + + if (!hasPresetHomeserver) + TextButton( + onPressed: () async { + final client = await Matrix.of( + context, + ).getLoginClient(); + context.go( + '${GoRouterState.of(context).uri.path}/login', + extra: client, + ); + }, + child: Text( + L10n.of(context).loginWithMatrixId, + ), + ), + ], + ), + ), + ], + ), + ), + ), + ); + }, + ), + ); + } +} diff --git a/lib/pages/intro/intro_page_presenter.dart b/lib/pages/intro/intro_page_presenter.dart new file mode 100644 index 000000000..fa702bee5 --- /dev/null +++ b/lib/pages/intro/intro_page_presenter.dart @@ -0,0 +1,123 @@ +import 'dart:convert'; + +import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; + +import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix_api_lite/utils/logs.dart'; +import 'package:matrix/msc_extensions/msc_2964_oidc_login_flow/msc_2964_oidc_login_flow.dart'; +import 'package:shared_preferences/shared_preferences.dart'; +import 'package:universal_html/universal_html.dart' as web; + +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/pages/intro/intro_page.dart'; +import 'package:fluffychat/pages/sign_in/view_model/model/public_homeserver_data.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/oidc_session_json_extension.dart'; +import 'package:fluffychat/utils/sign_in_flows/check_homeserver.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +class IntroPagePresenter extends StatefulWidget { + const IntroPagePresenter({super.key}); + + @override + State createState() => _IntroPagePresenterState(); +} + +class _IntroPagePresenterState extends State { + bool isLoading = kIsWeb; + String? loggingInToHomeserver; + + @override + void initState() { + super.initState(); + + if (kIsWeb) _finishOidcLogin(); + } + + Future _finishOidcLogin() async { + final store = await SharedPreferences.getInstance(); + final storedHomeserverString = store.getString( + OidcSessionJsonExtension.homeserverStoreKey, + ); + final homeserverUrl = storedHomeserverString == null + ? null + : Uri.tryParse(storedHomeserverString); + + final oidcSessionString = store.getString( + OidcSessionJsonExtension.storeKey, + ); + final session = oidcSessionString == null + ? null + : OidcSessionJsonExtension.fromJson(jsonDecode(oidcSessionString)); + + await store.remove(OidcSessionJsonExtension.storeKey); + await store.remove(OidcSessionJsonExtension.homeserverStoreKey); + if (!mounted) return; + + if (homeserverUrl == null || session == null) { + setState(() { + isLoading = false; + }); + + return; + } + setState(() { + loggingInToHomeserver = homeserverUrl.origin; + }); + + try { + final returnUrl = Uri.parse(web.window.location.href); + final queryParameters = returnUrl.hasFragment + ? Uri.parse(returnUrl.fragment).queryParameters + : returnUrl.queryParameters; + final code = queryParameters['code'] as String; + final state = queryParameters['state'] as String; + + final client = await Matrix.of(context).getLoginClient(); + await client.checkHomeserver(homeserverUrl); + await client.oidcLogin(session: session, code: code, state: state); + } catch (e, s) { + Logs().w('Unable to login via OIDC', e, s); + if (mounted) { + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); + } + } finally { + if (mounted) { + setState(() { + isLoading = false; + }); + } + } + } + + void _login() { + final presetHomeserver = AppSettings.presetHomeserver.value; + if (presetHomeserver.isEmpty) { + context.go('${GoRouterState.of(context).uri.path}/sign_in'); + return; + } + + connectToHomeserverFlow( + PublicHomeserverData(name: presetHomeserver), + context, + (snapshot) {}, + false, + ); + } + + @override + Widget build(BuildContext context) { + return IntroPage( + isLoading: isLoading, + loggingInToHomeserver: loggingInToHomeserver, + hasPresetHomeserver: AppSettings.presetHomeserver.value.isNotEmpty, + welcomeText: AppSettings.welcomeText.value.isEmpty + ? null + : AppSettings.welcomeText.value, + login: _login, + ); + } +} diff --git a/lib/pages/invitation_selection/invitation_selection.dart b/lib/pages/invitation_selection/invitation_selection.dart index 15078735d..b662829e5 100644 --- a/lib/pages/invitation_selection/invitation_selection.dart +++ b/lib/pages/invitation_selection/invitation_selection.dart @@ -2,22 +2,17 @@ import 'dart:async'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/invitation_selection/invitation_selection_view.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; import '../../utils/localized_exception_extension.dart'; class InvitationSelection extends StatefulWidget { final String roomId; - const InvitationSelection({ - super.key, - required this.roomId, - }); + const InvitationSelection({super.key, required this.roomId}); @override InvitationSelectionController createState() => @@ -36,7 +31,10 @@ class InvitationSelectionController extends State { Future> getContacts(BuildContext context) async { final client = Matrix.of(context).client; final room = client.getRoomById(roomId!)!; - final participants = await room.requestParticipants(); + + final participants = (room.summary.mJoinedMemberCount ?? 0) > 100 + ? room.getParticipants() + : await room.requestParticipants(); participants.removeWhere( (u) => ![Membership.join, Membership.invite].contains(u.membership), ); @@ -46,29 +44,19 @@ class InvitationSelectionController extends State { .toList(); contacts.sort( (a, b) => a.calcDisplayname().toLowerCase().compareTo( - b.calcDisplayname().toLowerCase(), - ), + b.calcDisplayname().toLowerCase(), + ), ); return contacts; } - void inviteAction(BuildContext context, String id, String displayname) async { + Future inviteAction( + BuildContext context, + String id, + String displayname, + ) async { final room = Matrix.of(context).client.getRoomById(roomId!)!; - if (OkCancelResult.ok != - await showOkCancelAlertDialog( - context: context, - title: L10n.of(context)!.inviteContact, - message: L10n.of(context)!.inviteContactToGroupQuestion( - displayname, - room.getLocalizedDisplayname( - MatrixLocals(L10n.of(context)!), - ), - ), - okLabel: L10n.of(context)!.invite, - cancelLabel: L10n.of(context)!.cancel, - )) { - return; - } + final success = await showFutureLoadingDialog( context: context, future: () => room.invite(id), @@ -76,13 +64,13 @@ class InvitationSelectionController extends State { if (success.error == null) { ScaffoldMessenger.of(context).showSnackBar( SnackBar( - content: Text(L10n.of(context)!.contactHasBeenInvitedToTheGroup), + content: Text(L10n.of(context).contactHasBeenInvitedToTheGroup), ), ); } } - void searchUserWithCoolDown(String text) async { + void searchUserWithCoolDown(String text) { coolDown?.cancel(); coolDown = Timer( const Duration(milliseconds: 500), @@ -90,7 +78,7 @@ class InvitationSelectionController extends State { ); } - void searchUser(BuildContext context, String text) async { + Future searchUser(BuildContext context, String text) async { coolDown?.cancel(); if (text.isEmpty) { setState(() => foundProfiles = []); @@ -104,9 +92,9 @@ class InvitationSelectionController extends State { try { response = await matrix.client.searchUserDirectory(text, limit: 10); } catch (e) { - ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text((e).toLocalizedString(context))), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text((e).toLocalizedString(context)))); return; } finally { setState(() => loading = false); diff --git a/lib/pages/invitation_selection/invitation_selection_view.dart b/lib/pages/invitation_selection/invitation_selection_view.dart index 92596e894..4db33841f 100644 --- a/lib/pages/invitation_selection/invitation_selection_view.dart +++ b/lib/pages/invitation_selection/invitation_selection_view.dart @@ -1,12 +1,13 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/invitation_selection/invitation_selection.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import '../../widgets/adaptive_dialogs/user_dialog.dart'; class InvitationSelectionView extends StatelessWidget { final InvitationSelectionController controller; @@ -15,25 +16,25 @@ class InvitationSelectionView extends StatelessWidget { @override Widget build(BuildContext context) { - final room = - Matrix.of(context).client.getRoomById(controller.widget.roomId); + final room = Matrix.of( + context, + ).client.getRoomById(controller.widget.roomId); if (room == null) { return Scaffold( - appBar: AppBar( - title: Text(L10n.of(context)!.oopsSomethingWentWrong), - ), + appBar: AppBar(title: Text(L10n.of(context).oopsSomethingWentWrong)), body: Center( - child: Text(L10n.of(context)!.youAreNoLongerParticipatingInThisChat), + child: Text(L10n.of(context).youAreNoLongerParticipatingInThisChat), ), ); } - final groupName = room.name.isEmpty ? L10n.of(context)!.group : room.name; + final groupName = room.name.isEmpty ? L10n.of(context).group : room.name; + final theme = Theme.of(context); return Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), titleSpacing: 0, - title: Text(L10n.of(context)!.inviteContact), + title: Text(L10n.of(context).inviteContact), ), body: MaxWidthBody( innerPadding: const EdgeInsets.symmetric(vertical: 8), @@ -44,7 +45,17 @@ class InvitationSelectionView extends StatelessWidget { child: TextField( textInputAction: TextInputAction.search, decoration: InputDecoration( - hintText: L10n.of(context)!.inviteContactToGroup(groupName), + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + hintStyle: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontWeight: FontWeight.normal, + ), + hintText: L10n.of(context).inviteContactToGroup(groupName), prefixIcon: controller.loading ? const Padding( padding: EdgeInsets.symmetric( @@ -64,11 +75,14 @@ class InvitationSelectionView extends StatelessWidget { ), ), StreamBuilder( - stream: room.client.onRoomState.stream - .where((update) => update.roomId == room.id), + stream: room.client.onRoomState.stream.where( + (update) => update.roomId == room.id, + ), builder: (context, snapshot) { - final participants = - room.getParticipants().map((user) => user.id).toSet(); + final participants = room + .getParticipants() + .map((user) => user.id) + .toSet(); return controller.foundProfiles.isNotEmpty ? ListView.builder( physics: const NeverScrollableScrollPhysics(), @@ -76,22 +90,21 @@ class InvitationSelectionView extends StatelessWidget { itemCount: controller.foundProfiles.length, itemBuilder: (BuildContext context, int i) => _InviteContactListTile( - avatarUrl: controller.foundProfiles[i].avatarUrl, - displayname: controller - .foundProfiles[i].displayName ?? - controller.foundProfiles[i].userId.localpart ?? - L10n.of(context)!.user, - userId: controller.foundProfiles[i].userId, - isMember: participants - .contains(controller.foundProfiles[i].userId), - onTap: () => controller.inviteAction( - context, - controller.foundProfiles[i].userId, - controller.foundProfiles[i].displayName ?? - controller.foundProfiles[i].userId.localpart ?? - L10n.of(context)!.user, - ), - ), + profile: controller.foundProfiles[i], + isMember: participants.contains( + controller.foundProfiles[i].userId, + ), + onTap: () => controller.inviteAction( + context, + controller.foundProfiles[i].userId, + controller.foundProfiles[i].displayName ?? + controller + .foundProfiles[i] + .userId + .localpart ?? + L10n.of(context).user, + ), + ), ) : FutureBuilder>( future: controller.getContacts(context), @@ -110,20 +123,26 @@ class InvitationSelectionView extends StatelessWidget { itemCount: contacts.length, itemBuilder: (BuildContext context, int i) => _InviteContactListTile( - avatarUrl: contacts[i].avatarUrl, - displayname: contacts[i].displayName ?? - contacts[i].id.localpart ?? - L10n.of(context)!.user, - userId: contacts[i].id, - isMember: participants.contains(contacts[i].id), - onTap: () => controller.inviteAction( - context, - contacts[i].id, - contacts[i].displayName ?? - contacts[i].id.localpart ?? - L10n.of(context)!.user, - ), - ), + user: contacts[i], + profile: Profile( + avatarUrl: contacts[i].avatarUrl, + displayName: + contacts[i].displayName ?? + contacts[i].id.localpart ?? + L10n.of(context).user, + userId: contacts[i].id, + ), + isMember: participants.contains( + contacts[i].id, + ), + onTap: () => controller.inviteAction( + context, + contacts[i].id, + contacts[i].displayName ?? + contacts[i].id.localpart ?? + L10n.of(context).user, + ), + ), ); }, ); @@ -137,47 +156,45 @@ class InvitationSelectionView extends StatelessWidget { } class _InviteContactListTile extends StatelessWidget { - final String userId; - final String displayname; - final Uri? avatarUrl; + final Profile profile; + final User? user; final bool isMember; final void Function() onTap; const _InviteContactListTile({ - required this.userId, - required this.displayname, - required this.avatarUrl, + required this.profile, + this.user, required this.isMember, required this.onTap, }); @override Widget build(BuildContext context) { - return Opacity( - opacity: isMember ? 0.5 : 1, - child: ListTile( - leading: Avatar( - mxContent: avatarUrl, - name: displayname, - presenceUserId: userId, - ), - title: Text( - displayname, - maxLines: 1, - overflow: TextOverflow.ellipsis, - ), - subtitle: Text( - userId, - maxLines: 1, - overflow: TextOverflow.ellipsis, - style: TextStyle( - color: Theme.of(context).colorScheme.secondary, - ), - ), - onTap: isMember ? null : onTap, - trailing: isMember - ? Text(L10n.of(context)!.participant) - : const Icon(Icons.person_add_outlined), + final theme = Theme.of(context); + final l10n = L10n.of(context); + + return ListTile( + leading: Avatar( + mxContent: profile.avatarUrl, + name: profile.displayName, + presenceUserId: profile.userId, + onTap: () => UserDialog.show(context: context, profile: profile), + ), + title: Text( + profile.displayName ?? profile.userId.localpart ?? l10n.user, + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + subtitle: Text( + profile.userId, + maxLines: 1, + overflow: TextOverflow.ellipsis, + style: TextStyle(color: theme.colorScheme.secondary), + ), + trailing: TextButton.icon( + onPressed: isMember ? null : onTap, + label: Text(isMember ? l10n.participant : l10n.invite), + icon: Icon(isMember ? Icons.check : Icons.add), ), ); } diff --git a/lib/pages/key_verification/key_verification_dialog.dart b/lib/pages/key_verification/key_verification_dialog.dart index 99d082a76..1b04b8dd2 100644 --- a/lib/pages/key_verification/key_verification_dialog.dart +++ b/lib/pages/key_verification/key_verification_dialog.dart @@ -4,27 +4,25 @@ import 'dart:ui'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; class KeyVerificationDialog extends StatefulWidget { - Future show(BuildContext context) => showAdaptiveDialog( - context: context, - builder: (context) => this, - barrierDismissible: false, - ); + Future show(BuildContext context) => showAdaptiveDialog( + context: context, + builder: (context) => this, + barrierDismissible: false, + ); final KeyVerification request; - const KeyVerificationDialog({ - super.key, - required this.request, - }); + const KeyVerificationDialog({super.key, required this.request}); @override KeyVerificationPageState createState() => KeyVerificationPageState(); @@ -56,8 +54,10 @@ class KeyVerificationPageState extends State { void dispose() { widget.request.onUpdate = originalOnUpdate; // don't want to get updates anymore - if (![KeyVerificationState.error, KeyVerificationState.done] - .contains(widget.request.state)) { + if (![ + KeyVerificationState.error, + KeyVerificationState.done, + ].contains(widget.request.state)) { widget.request.cancel('m.user'); } super.dispose(); @@ -87,16 +87,19 @@ class KeyVerificationPageState extends State { await showOkAlertDialog( useRootNavigator: false, context: context, - message: L10n.of(context)!.incorrectPassphraseOrKey, + title: L10n.of(context).incorrectPassphraseOrKey, ); } } @override Widget build(BuildContext context) { + final theme = Theme.of(context); + User? user; - final directChatId = - widget.request.client.getDirectChatFromUserId(widget.request.userId); + final directChatId = widget.request.client.getDirectChatFromUserId( + widget.request.userId, + ); if (directChatId != null) { user = widget.request.client .getRoomById(directChatId)! @@ -104,7 +107,7 @@ class KeyVerificationPageState extends State { } final displayName = user?.calcDisplayname() ?? widget.request.userId.localpart!; - var title = Text(L10n.of(context)!.verifyTitle); + var title = Text(L10n.of(context).verifyTitle); Widget body; final buttons = []; @@ -117,12 +120,12 @@ class KeyVerificationPageState extends State { final textEditingController = TextEditingController(); String input; body = Container( - margin: const EdgeInsets.only(left: 8.0, right: 8.0), + margin: const EdgeInsets.symmetric(horizontal: 8.0), child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ Text( - L10n.of(context)!.askSSSSSign, + L10n.of(context).askSSSSSign, style: const TextStyle(fontSize: 20), ), Container(height: 10), @@ -138,11 +141,9 @@ class KeyVerificationPageState extends State { maxLines: 1, obscureText: true, decoration: InputDecoration( - hintText: L10n.of(context)!.passphraseOrKey, - prefixStyle: - TextStyle(color: Theme.of(context).colorScheme.primary), - suffixStyle: - TextStyle(color: Theme.of(context).colorScheme.primary), + hintText: L10n.of(context).passphraseOrKey, + prefixStyle: TextStyle(color: theme.colorScheme.primary), + suffixStyle: TextStyle(color: theme.colorScheme.primary), border: const OutlineInputBorder(), ), ), @@ -150,26 +151,22 @@ class KeyVerificationPageState extends State { ), ); buttons.add( - TextButton( - child: Text( - L10n.of(context)!.submit, - ), + AdaptiveDialogAction( + child: Text(L10n.of(context).submit), onPressed: () => checkInput(textEditingController.text), ), ); buttons.add( - TextButton( - child: Text( - L10n.of(context)!.skip, - ), + AdaptiveDialogAction( + child: Text(L10n.of(context).skip), onPressed: () => widget.request.openSSSS(skip: true), ), ); break; case KeyVerificationState.askAccept: - title = Text(L10n.of(context)!.newVerificationRequest); + title = Text(L10n.of(context).newVerificationRequest); body = Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ const SizedBox(height: 16), Avatar( @@ -178,26 +175,24 @@ class KeyVerificationPageState extends State { size: Avatar.defaultSize * 2, ), const SizedBox(height: 16), - Text( - L10n.of(context)!.askVerificationRequest(displayName), - ), + Text(L10n.of(context).askVerificationRequest(displayName)), ], ); buttons.add( - TextButton.icon( - icon: const Icon(Icons.close), - style: TextButton.styleFrom(foregroundColor: Colors.red), - label: Text(L10n.of(context)!.reject), - onPressed: () => widget.request - .rejectVerification() - .then((_) => Navigator.of(context, rootNavigator: false).pop()), + AdaptiveDialogAction( + onPressed: () => widget.request.rejectVerification().then( + (_) => Navigator.of(context, rootNavigator: false).pop(false), + ), + child: Text( + L10n.of(context).reject, + style: TextStyle(color: theme.colorScheme.error), + ), ), ); buttons.add( - TextButton.icon( - icon: const Icon(Icons.check), - label: Text(L10n.of(context)!.accept), + AdaptiveDialogAction( onPressed: () => widget.request.acceptVerification(), + child: Text(L10n.of(context).accept), ), ); break; @@ -206,13 +201,11 @@ class KeyVerificationPageState extends State { body = Center( child: Column( children: [ + const SizedBox(height: 16), Stack( alignment: Alignment.center, children: [ - Avatar( - mxContent: user?.avatarUrl, - name: displayName, - ), + Avatar(mxContent: user?.avatarUrl, name: displayName), const SizedBox( width: Avatar.defaultSize + 2, height: Avatar.defaultSize + 2, @@ -222,17 +215,16 @@ class KeyVerificationPageState extends State { ), const SizedBox(height: 16), Text( - L10n.of(context)!.waitingPartnerAcceptRequest, + L10n.of(context).waitingPartnerAcceptRequest, textAlign: TextAlign.center, ), ], ), ); buttons.add( - TextButton.icon( - icon: const Icon(Icons.close), - label: Text(L10n.of(context)!.cancel), + AdaptiveDialogAction( onPressed: () => widget.request.cancel(), + child: Text(L10n.of(context).cancel), ), ); @@ -244,7 +236,7 @@ class KeyVerificationPageState extends State { if (widget.request.sasTypes.contains('emoji')) { title = Text( - L10n.of(context)!.compareEmojiMatch, + L10n.of(context).compareEmojiMatch, maxLines: 1, style: const TextStyle(fontSize: 16), ); @@ -254,86 +246,75 @@ class KeyVerificationPageState extends State { .toList(), ); } else { - title = Text(L10n.of(context)!.compareNumbersMatch); + title = Text(L10n.of(context).compareNumbersMatch); final numbers = widget.request.sasNumbers; - final numbstr = '${numbers[0]}-${numbers[1]}-${numbers[2]}'; - compareWidget = - TextSpan(text: numbstr, style: const TextStyle(fontSize: 40)); + final numbstr = '${numbers.first}-${numbers[1]}-${numbers[2]}'; + compareWidget = TextSpan( + text: numbstr, + style: const TextStyle(fontSize: 40), + ); } body = Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ - Text.rich( - compareWidget, - textAlign: TextAlign.center, - ), + Text.rich(compareWidget, textAlign: TextAlign.center), ], ); buttons.add( - TextButton.icon( - icon: const Icon(Icons.close), - style: TextButton.styleFrom( - foregroundColor: Colors.red, - ), - label: Text(L10n.of(context)!.theyDontMatch), + AdaptiveDialogAction( onPressed: () => widget.request.rejectSas(), + child: Text( + L10n.of(context).theyDontMatch, + style: TextStyle(color: theme.colorScheme.error), + ), ), ); buttons.add( - TextButton.icon( - icon: const Icon(Icons.check_outlined), - label: Text(L10n.of(context)!.theyMatch), + AdaptiveDialogAction( onPressed: () => widget.request.acceptSas(), + child: Text(L10n.of(context).theyMatch), ), ); break; case KeyVerificationState.waitingSas: final acceptText = widget.request.sasTypes.contains('emoji') - ? L10n.of(context)!.waitingPartnerEmoji - : L10n.of(context)!.waitingPartnerNumbers; + ? L10n.of(context).waitingPartnerEmoji + : L10n.of(context).waitingPartnerNumbers; body = Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ + const SizedBox(height: 16), const CircularProgressIndicator.adaptive(strokeWidth: 2), - const SizedBox(height: 10), - Text( - acceptText, - textAlign: TextAlign.center, - ), + const SizedBox(height: 16), + Text(acceptText, textAlign: TextAlign.center), ], ); break; case KeyVerificationState.done: - body = Column( - mainAxisSize: MainAxisSize.min, - children: [ - const Icon( - Icons.check_circle_outlined, - color: Colors.green, - size: 128.0, - ), - const SizedBox(height: 10), - Text( - L10n.of(context)!.verifySuccess, - textAlign: TextAlign.center, - ), - ], + title = Text(L10n.of(context).verifySuccess); + body = const Padding( + padding: EdgeInsets.all(16.0), + child: Icon( + Icons.verified_outlined, + color: Colors.green, + size: 128.0, + ), ); buttons.add( - TextButton( - child: Text( - L10n.of(context)!.close, - ), - onPressed: () => Navigator.of(context, rootNavigator: false).pop(), + AdaptiveDialogAction( + child: Text(L10n.of(context).close), + onPressed: () => + Navigator.of(context, rootNavigator: false).pop(true), ), ); break; case KeyVerificationState.error: title = const Text(''); body = Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ - const Icon(Icons.cancel, color: Colors.red, size: 128.0), + const SizedBox(height: 16), + Icon(Icons.cancel, color: theme.colorScheme.error, size: 64.0), const SizedBox(height: 16), // TODO: Add better error UI to user Text( @@ -343,11 +324,10 @@ class KeyVerificationPageState extends State { ], ); buttons.add( - TextButton( - child: Text( - L10n.of(context)!.close, - ), - onPressed: () => Navigator.of(context, rootNavigator: false).pop(), + AdaptiveDialogAction( + child: Text(L10n.of(context).close), + onPressed: () => + Navigator.of(context, rootNavigator: false).pop(false), ), ); break; @@ -358,9 +338,7 @@ class KeyVerificationPageState extends State { content: SizedBox( height: 256, width: 256, - child: ListView( - children: [body], - ), + child: ListView(children: [body]), ), actions: buttons, ); @@ -402,7 +380,7 @@ class _Emoji extends StatelessWidget { @override Widget build(BuildContext context) { return Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ Text(emoji.emoji, style: const TextStyle(fontSize: 50)), Padding( diff --git a/lib/pages/login/login.dart b/lib/pages/login/login.dart index c62e2100b..b1eecd0b8 100644 --- a/lib/pages/login/login.dart +++ b/lib/pages/login/login.dart @@ -2,18 +2,21 @@ import 'dart:async'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; +import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; import '../../utils/platform_infos.dart'; import 'login_view.dart'; class Login extends StatefulWidget { - const Login({super.key}); + final Client client; + const Login({required this.client, super.key}); @override LoginController createState() => LoginController(); @@ -30,15 +33,15 @@ class LoginController extends State { void toggleShowPassword() => setState(() => showPassword = !loading && !showPassword); - void login() async { + Future login() async { final matrix = Matrix.of(context); if (usernameController.text.isEmpty) { - setState(() => usernameError = L10n.of(context)!.pleaseEnterYourUsername); + setState(() => usernameError = L10n.of(context).pleaseEnterYourUsername); } else { setState(() => usernameError = null); } if (passwordController.text.isEmpty) { - setState(() => passwordError = L10n.of(context)!.pleaseEnterYourPassword); + setState(() => passwordError = L10n.of(context).pleaseEnterYourPassword); } else { setState(() => passwordError = null); } @@ -67,17 +70,21 @@ class LoginController extends State { } else { identifier = AuthenticationUserIdentifier(user: username); } - await matrix.getLoginClient().login( - LoginType.mLoginPassword, - identifier: identifier, - // To stay compatible with older server versions - // ignore: deprecated_member_use - user: identifier.type == AuthenticationIdentifierTypes.userId - ? username - : null, - password: passwordController.text, - initialDeviceDisplayName: PlatformInfos.clientName, - ); + final client = await matrix.getLoginClient(); + await client.login( + LoginType.mLoginPassword, + identifier: identifier, + // To stay compatible with older server versions + // ignore: deprecated_member_use + user: identifier.type == AuthenticationIdentifierTypes.userId + ? username + : null, + password: passwordController.text, + initialDeviceDisplayName: PlatformInfos.clientName, + ); + if (mounted) { + context.go('/backup'); + } } on MatrixException catch (exception) { setState(() => passwordError = exception.errorMessage); return setState(() => loading = false); @@ -91,7 +98,7 @@ class LoginController extends State { Timer? _coolDown; - void checkWellKnownWithCoolDown(String userId) async { + void checkWellKnownWithCoolDown(String userId) { _coolDown?.cancel(); _coolDown = Timer( const Duration(seconds: 1), @@ -99,17 +106,16 @@ class LoginController extends State { ); } - void _checkWellKnown(String userId) async { + Future _checkWellKnown(String userId) async { if (mounted) setState(() => usernameError = null); if (!userId.isValidMatrixId) return; - final oldHomeserver = Matrix.of(context).getLoginClient().homeserver; + final oldHomeserver = widget.client.homeserver; try { var newDomain = Uri.https(userId.domain!, ''); - Matrix.of(context).getLoginClient().homeserver = newDomain; + widget.client.homeserver = newDomain; DiscoveryInformation? wellKnownInformation; try { - wellKnownInformation = - await Matrix.of(context).getLoginClient().getWellknown(); + wellKnownInformation = await widget.client.getWellknown(); if (wellKnownInformation.mHomeserver.baseUrl.toString().isNotEmpty) { newDomain = wellKnownInformation.mHomeserver.baseUrl; } @@ -117,10 +123,10 @@ class LoginController extends State { // do nothing, newDomain is already set to a reasonable fallback } if (newDomain != oldHomeserver) { - await Matrix.of(context).getLoginClient().checkHomeserver(newDomain); + await widget.client.checkHomeserver(newDomain); - if (Matrix.of(context).getLoginClient().homeserver == null) { - Matrix.of(context).getLoginClient().homeserver = oldHomeserver; + if (widget.client.homeserver == null) { + widget.client.homeserver = oldHomeserver; // okay, the server we checked does not appear to be a matrix server Logs().v( '$newDomain is not running a homeserver, asking to use $oldHomeserver', @@ -128,10 +134,11 @@ class LoginController extends State { final dialogResult = await showOkCancelAlertDialog( context: context, useRootNavigator: false, - message: - L10n.of(context)!.noMatrixServer(newDomain, oldHomeserver!), - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of( + context, + ).noMatrixServer(newDomain.toString(), oldHomeserver.toString()), + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, ); if (dialogResult == OkCancelResult.ok) { if (mounted) setState(() => usernameError = null); @@ -143,79 +150,68 @@ class LoginController extends State { usernameError = null; if (mounted) setState(() {}); } else { - Matrix.of(context).getLoginClient().homeserver = oldHomeserver; + widget.client.homeserver = oldHomeserver; if (mounted) { setState(() {}); } } } catch (e) { - Matrix.of(context).getLoginClient().homeserver = oldHomeserver; + widget.client.homeserver = oldHomeserver; usernameError = e.toLocalizedString(context); if (mounted) setState(() {}); } } - void passwordForgotten() async { + Future passwordForgotten() async { final input = await showTextInputDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.passwordForgotten, - message: L10n.of(context)!.enterAnEmailAddress, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - fullyCapitalizedForMaterial: false, - textFields: [ - DialogTextField( - initialText: - usernameController.text.isEmail ? usernameController.text : '', - hintText: L10n.of(context)!.enterAnEmailAddress, - keyboardType: TextInputType.emailAddress, - ), - ], + title: L10n.of(context).passwordForgotten, + message: L10n.of(context).enterAnEmailAddress, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + initialText: usernameController.text.isEmail + ? usernameController.text + : '', + hintText: L10n.of(context).enterAnEmailAddress, + keyboardType: TextInputType.emailAddress, ); if (input == null) return; final clientSecret = DateTime.now().millisecondsSinceEpoch.toString(); final response = await showFutureLoadingDialog( context: context, - future: () => - Matrix.of(context).getLoginClient().requestTokenToResetPasswordEmail( - clientSecret, - input.single, - sendAttempt++, - ), + future: () => widget.client.requestTokenToResetPasswordEmail( + clientSecret, + input, + sendAttempt++, + ), ); if (response.error != null) return; final password = await showTextInputDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.passwordForgotten, - message: L10n.of(context)!.chooseAStrongPassword, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - fullyCapitalizedForMaterial: false, - textFields: [ - const DialogTextField( - hintText: '******', - obscureText: true, - minLines: 1, - maxLines: 1, - ), - ], + title: L10n.of(context).passwordForgotten, + message: L10n.of(context).chooseAStrongPassword, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + hintText: '******', + obscureText: true, + minLines: 1, + maxLines: 1, ); if (password == null) return; final ok = await showOkAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.weSentYouAnEmail, - message: L10n.of(context)!.pleaseClickOnLink, - okLabel: L10n.of(context)!.iHaveClickedOnLink, - fullyCapitalizedForMaterial: false, + title: L10n.of(context).weSentYouAnEmail, + message: L10n.of(context).pleaseClickOnLink, + okLabel: L10n.of(context).iHaveClickedOnLink, ); if (ok != OkCancelResult.ok) return; final data = { - 'new_password': password.single, + 'new_password': password, 'logout_devices': false, - "auth": AuthenticationThreePidCreds( + 'auth': AuthenticationThreePidCreds( type: AuthenticationTypes.emailIdentity, threepidCreds: ThreepidCreds( sid: response.result!.sid, @@ -225,18 +221,18 @@ class LoginController extends State { }; final success = await showFutureLoadingDialog( context: context, - future: () => Matrix.of(context).getLoginClient().request( - RequestType.POST, - '/client/v3/account/password', - data: data, - ), + future: () => widget.client.request( + RequestType.POST, + '/client/v3/account/password', + data: data, + ), ); if (success.error == null) { ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.passwordHasBeenChanged)), + SnackBar(content: Text(L10n.of(context).passwordHasBeenChanged)), ); - usernameController.text = input.single; - passwordController.text = password.single; + usernameController.text = input; + passwordController.text = password; login(); } } @@ -248,8 +244,9 @@ class LoginController extends State { } extension on String { - static final RegExp _phoneRegex = - RegExp(r'^[+]*[(]{0,1}[0-9]{1,4}[)]{0,1}[-\s\./0-9]*$'); + static final RegExp _phoneRegex = RegExp( + r'^[+]*[(]{0,1}[0-9]{1,4}[)]{0,1}[-\s\./0-9]*$', + ); static final RegExp _emailRegex = RegExp(r'(.+)@(.+)\.(.+)'); bool get isEmail => _emailRegex.hasMatch(this); diff --git a/lib/pages/login/login_view.dart b/lib/pages/login/login_view.dart index 8ec092cbf..f0352640b 100644 --- a/lib/pages/login/login_view.dart +++ b/lib/pages/login/login_view.dart @@ -1,10 +1,7 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; - -import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/widgets/layouts/login_scaffold.dart'; -import 'package:fluffychat/widgets/matrix.dart'; import 'login.dart'; class LoginView extends StatelessWidget { @@ -14,38 +11,21 @@ class LoginView extends StatelessWidget { @override Widget build(BuildContext context) { - final homeserver = Matrix.of(context) - .getLoginClient() - .homeserver - .toString() - .replaceFirst('https://', ''); - final title = L10n.of(context)!.logInTo(homeserver); - final titleParts = title.split(homeserver); + final theme = Theme.of(context); - final textFieldFillColor = FluffyThemes.isColumnMode(context) - ? Theme.of(context).colorScheme.surface - // ignore: deprecated_member_use - : Theme.of(context).colorScheme.surfaceVariant; + final homeserver = controller.widget.client.homeserver + ?.toString() + .replaceFirst('https://', ''); + final title = homeserver == null + ? L10n.of(context).loginWithMatrixId + : L10n.of(context).logInTo(homeserver); return LoginScaffold( - enforceMobileMode: Matrix.of(context).client.isLogged(), appBar: AppBar( leading: controller.loading ? null : const Center(child: BackButton()), automaticallyImplyLeading: !controller.loading, titleSpacing: !controller.loading ? 0 : null, - title: Text.rich( - TextSpan( - children: [ - TextSpan(text: titleParts.first), - TextSpan( - text: homeserver, - style: const TextStyle(fontWeight: FontWeight.bold), - ), - TextSpan(text: titleParts.last), - ], - ), - style: const TextStyle(fontSize: 18), - ), + title: Text(title), ), body: Builder( builder: (context) { @@ -53,10 +33,13 @@ class LoginView extends StatelessWidget { child: ListView( padding: const EdgeInsets.symmetric(horizontal: 8), children: [ - Image.asset('assets/banner_transparent.png'), + Hero( + tag: 'info-logo', + child: Image.asset('assets/banner_transparent.png'), + ), const SizedBox(height: 16), Padding( - padding: const EdgeInsets.symmetric(horizontal: 8.0), + padding: const EdgeInsets.symmetric(horizontal: 24.0), child: TextField( readOnly: controller.loading, autocorrect: false, @@ -65,25 +48,27 @@ class LoginView extends StatelessWidget { controller: controller.usernameController, textInputAction: TextInputAction.next, keyboardType: TextInputType.emailAddress, - autofillHints: - controller.loading ? null : [AutofillHints.username], + autofillHints: controller.loading + ? null + : [AutofillHints.username], decoration: InputDecoration( prefixIcon: const Icon(Icons.account_box_outlined), errorText: controller.usernameError, errorStyle: const TextStyle(color: Colors.orange), - fillColor: textFieldFillColor, - hintText: L10n.of(context)!.emailOrUsername, + hintText: '@username:domain', + labelText: L10n.of(context).matrixId, ), ), ), const SizedBox(height: 16), Padding( - padding: const EdgeInsets.symmetric(horizontal: 8.0), + padding: const EdgeInsets.symmetric(horizontal: 24.0), child: TextField( readOnly: controller.loading, autocorrect: false, - autofillHints: - controller.loading ? null : [AutofillHints.password], + autofillHints: controller.loading + ? null + : [AutofillHints.password], controller: controller.passwordController, textInputAction: TextInputAction.go, obscureText: !controller.showPassword, @@ -92,7 +77,6 @@ class LoginView extends StatelessWidget { prefixIcon: const Icon(Icons.lock_outlined), errorText: controller.passwordError, errorStyle: const TextStyle(color: Colors.orange), - fillColor: textFieldFillColor, suffixIcon: IconButton( onPressed: controller.toggleShowPassword, icon: Icon( @@ -102,39 +86,39 @@ class LoginView extends StatelessWidget { color: Colors.black, ), ), - hintText: L10n.of(context)!.password, + hintText: '******', + labelText: L10n.of(context).password, ), ), ), const SizedBox(height: 16), Padding( - padding: const EdgeInsets.symmetric(horizontal: 8.0), - child: ElevatedButton.icon( + padding: const EdgeInsets.symmetric(horizontal: 24.0), + child: ElevatedButton( style: ElevatedButton.styleFrom( - backgroundColor: Theme.of(context).colorScheme.primary, - foregroundColor: Theme.of(context).colorScheme.onPrimary, + backgroundColor: theme.colorScheme.primary, + foregroundColor: theme.colorScheme.onPrimary, ), onPressed: controller.loading ? null : controller.login, - icon: const Icon(Icons.login_outlined), - label: controller.loading + child: controller.loading ? const LinearProgressIndicator() - : Text(L10n.of(context)!.login), + : Text(L10n.of(context).login), ), ), const SizedBox(height: 16), - Padding( - padding: const EdgeInsets.symmetric(horizontal: 8.0), - child: TextButton.icon( - onPressed: controller.loading - ? () {} - : controller.passwordForgotten, - style: TextButton.styleFrom( - foregroundColor: Theme.of(context).colorScheme.error, + if (homeserver != null) + Padding( + padding: const EdgeInsets.symmetric(horizontal: 24.0), + child: TextButton( + onPressed: controller.loading + ? () {} + : controller.passwordForgotten, + style: TextButton.styleFrom( + foregroundColor: theme.colorScheme.error, + ), + child: Text(L10n.of(context).passwordForgotten), ), - icon: const Icon(Icons.safety_check_outlined), - label: Text(L10n.of(context)!.passwordForgotten), ), - ), const SizedBox(height: 16), ], ), diff --git a/lib/pages/new_group/new_group.dart b/lib/pages/new_group/new_group.dart index 584a3f885..f1945e470 100644 --- a/lib/pages/new_group/new_group.dart +++ b/lib/pages/new_group/new_group.dart @@ -5,12 +5,21 @@ import 'package:flutter/material.dart'; import 'package:file_picker/file_picker.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart' as sdk; +import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/new_group/new_group_view.dart'; +import 'package:fluffychat/utils/file_selector.dart'; import 'package:fluffychat/widgets/matrix.dart'; class NewGroup extends StatefulWidget { - const NewGroup({super.key}); + final CreateGroupType createGroupType; + final String? spaceId; + const NewGroup({ + this.createGroupType = CreateGroupType.group, + this.spaceId, + super.key, + }); @override NewGroupController createState() => NewGroupController(); @@ -19,10 +28,8 @@ class NewGroup extends StatefulWidget { class NewGroupController extends State { TextEditingController nameController = TextEditingController(); - TextEditingController topicController = TextEditingController(); - bool publicGroup = false; - bool groupCanBeFound = true; + bool groupCanBeFound = false; Uint8List? avatar; @@ -32,27 +39,107 @@ class NewGroupController extends State { bool loading = false; - void setPublicGroup(bool b) => setState(() => publicGroup = b); + CreateGroupType get createGroupType => + _createGroupType ?? widget.createGroupType; + + CreateGroupType? _createGroupType; + + void setCreateGroupType(Set b) => + setState(() => _createGroupType = b.single); + + void setPublicGroup(bool b) => + setState(() => publicGroup = groupCanBeFound = b); void setGroupCanBeFound(bool b) => setState(() => groupCanBeFound = b); - void selectPhoto() async { - final photo = await FilePicker.platform.pickFiles( + Future selectPhoto() async { + final photo = await selectFiles( + context, type: FileType.image, allowMultiple: false, - withData: true, ); + final bytes = await photo.singleOrNull?.readAsBytes(); setState(() { avatarUrl = null; - avatar = photo?.files.singleOrNull?.bytes; + avatar = bytes; }); } - void submitAction([_]) async { + Future _createGroup() async { + if (!mounted) return; + final client = Matrix.of(context).client; + + final roomId = await client.createGroupChat( + visibility: groupCanBeFound + ? sdk.Visibility.public + : sdk.Visibility.private, + preset: publicGroup + ? sdk.CreateRoomPreset.publicChat + : sdk.CreateRoomPreset.privateChat, + groupName: nameController.text.isNotEmpty ? nameController.text : null, + initialState: [ + if (avatar != null) + sdk.StateEvent( + type: sdk.EventTypes.RoomAvatar, + content: {'url': avatarUrl.toString()}, + ), + ], + ); + await _addToSpace(roomId); + if (!mounted) return; + + context.go('/rooms/$roomId/invite'); + } + + Future _createSpace() async { + if (!mounted) return; + final spaceId = await Matrix.of(context).client.createRoom( + preset: publicGroup + ? sdk.CreateRoomPreset.publicChat + : sdk.CreateRoomPreset.privateChat, + creationContent: {'type': RoomCreationTypes.mSpace}, + visibility: publicGroup ? sdk.Visibility.public : null, + roomAliasName: publicGroup + ? nameController.text.trim().toLowerCase().replaceAll(' ', '_') + : null, + name: nameController.text.trim(), + powerLevelContentOverride: {'events_default': 100}, + initialState: [ + if (avatar != null) + sdk.StateEvent( + type: sdk.EventTypes.RoomAvatar, + content: {'url': avatarUrl.toString()}, + ), + ], + ); + await _addToSpace(spaceId); + if (!mounted) return; + context.pop(spaceId); + } + + Future _addToSpace(String roomId) async { + final spaceId = widget.spaceId; + if (spaceId != null) { + final activeSpace = Matrix.of(context).client.getRoomById(spaceId); + if (activeSpace == null) { + throw Exception('Can not add group to space: Space not found $spaceId'); + } + await activeSpace.postLoad(); + await activeSpace.setSpaceChild(roomId); + } + } + + Future submitAction([_]) async { final client = Matrix.of(context).client; try { + if (nameController.text.trim().isEmpty && + createGroupType == CreateGroupType.space) { + setState(() => error = L10n.of(context).pleaseFillOut); + return; + } + setState(() { loading = true; error = null; @@ -63,34 +150,12 @@ class NewGroupController extends State { if (!mounted) return; - final roomId = await client.createGroupChat( - visibility: - publicGroup ? sdk.Visibility.public : sdk.Visibility.private, - preset: publicGroup - ? sdk.CreateRoomPreset.publicChat - : sdk.CreateRoomPreset.privateChat, - groupName: nameController.text.isNotEmpty ? nameController.text : null, - initialState: [ - if (topicController.text.isNotEmpty) - sdk.StateEvent( - type: sdk.EventTypes.RoomTopic, - content: {'topic': topicController.text}, - ), - if (avatar != null) - sdk.StateEvent( - type: sdk.EventTypes.RoomAvatar, - content: {'url': avatarUrl.toString()}, - ), - ], - ); - if (!mounted) return; - if (publicGroup && groupCanBeFound) { - await client.setRoomVisibilityOnDirectory( - roomId, - visibility: sdk.Visibility.public, - ); + switch (createGroupType) { + case CreateGroupType.group: + await _createGroup(); + case CreateGroupType.space: + await _createSpace(); } - context.go('/rooms/$roomId/invite'); } catch (e, s) { sdk.Logs().d('Unable to create group', e, s); setState(() { @@ -100,6 +165,18 @@ class NewGroupController extends State { } } + @override + void initState() { + final spaceId = widget.spaceId; + if (spaceId != null) { + final space = Matrix.of(context).client.getRoomById(spaceId); + publicGroup = space?.joinRules == JoinRules.public; + } + super.initState(); + } + @override Widget build(BuildContext context) => NewGroupView(this); } + +enum CreateGroupType { group, space } diff --git a/lib/pages/new_group/new_group_view.dart b/lib/pages/new_group/new_group_view.dart index a00ba3754..61f86736b 100644 --- a/lib/pages/new_group/new_group_view.dart +++ b/lib/pages/new_group/new_group_view.dart @@ -1,8 +1,7 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; - import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/new_group/new_group.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; import 'package:fluffychat/widgets/avatar.dart'; @@ -15,6 +14,8 @@ class NewGroupView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final avatar = controller.avatar; final error = controller.error; return Scaffold( @@ -24,77 +25,90 @@ class NewGroupView extends StatelessWidget { onPressed: controller.loading ? null : Navigator.of(context).pop, ), ), - title: Text(L10n.of(context)!.createGroup), + title: Text( + controller.createGroupType == CreateGroupType.space + ? L10n.of(context).newSpace + : L10n.of(context).createGroup, + ), ), body: MaxWidthBody( child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ - const SizedBox(height: 16), Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0), - child: Row( - children: [ - InkWell( - borderRadius: BorderRadius.circular(90), - onTap: controller.loading ? null : controller.selectPhoto, - child: CircleAvatar( - radius: Avatar.defaultSize / 2, - child: avatar == null - ? const Icon(Icons.camera_alt_outlined) - : ClipRRect( - borderRadius: BorderRadius.circular(90), - child: Image.memory( - avatar, - width: Avatar.defaultSize, - height: Avatar.defaultSize, - fit: BoxFit.cover, - ), - ), - ), + padding: const EdgeInsets.all(16.0), + child: SegmentedButton( + selected: {controller.createGroupType}, + onSelectionChanged: controller.setCreateGroupType, + segments: [ + ButtonSegment( + value: CreateGroupType.group, + label: Text(L10n.of(context).group), ), - const SizedBox(width: 16), - Expanded( - child: TextField( - controller: controller.nameController, - autocorrect: false, - readOnly: controller.loading, - decoration: InputDecoration( - prefixIcon: const Icon(Icons.people_outlined), - hintText: L10n.of(context)!.groupName, - ), - ), + ButtonSegment( + value: CreateGroupType.space, + label: Text(L10n.of(context).space), ), ], ), ), const SizedBox(height: 16), + InkWell( + borderRadius: BorderRadius.circular(90), + onTap: controller.loading ? null : controller.selectPhoto, + child: CircleAvatar( + radius: Avatar.defaultSize, + child: avatar == null + ? const Icon(Icons.add_a_photo_outlined) + : ClipRRect( + borderRadius: BorderRadius.circular(90), + child: Image.memory( + avatar, + width: Avatar.defaultSize * 2, + height: Avatar.defaultSize * 2, + fit: BoxFit.cover, + ), + ), + ), + ), + const SizedBox(height: 32), Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0), + padding: const EdgeInsets.symmetric(horizontal: 24.0), child: TextField( - controller: controller.topicController, - minLines: 4, - maxLines: 4, - maxLength: 255, + autofocus: true, + controller: controller.nameController, + autocorrect: false, readOnly: controller.loading, decoration: InputDecoration( - hintText: L10n.of(context)!.addChatDescription, + prefixIcon: const Icon(Icons.people_outlined), + labelText: controller.createGroupType == CreateGroupType.space + ? L10n.of(context).spaceName + : L10n.of(context).groupName, ), ), ), const SizedBox(height: 16), SwitchListTile.adaptive( + contentPadding: const EdgeInsets.symmetric(horizontal: 32), secondary: const Icon(Icons.public_outlined), - title: Text(L10n.of(context)!.groupIsPublic), + title: Text( + controller.createGroupType == CreateGroupType.space + ? L10n.of(context).spaceIsPublic + : L10n.of(context).groupIsPublic, + ), value: controller.publicGroup, onChanged: controller.loading ? null : controller.setPublicGroup, ), AnimatedSize( duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, child: controller.publicGroup ? SwitchListTile.adaptive( + contentPadding: const EdgeInsets.symmetric( + horizontal: 32, + ), secondary: const Icon(Icons.search_outlined), - title: Text(L10n.of(context)!.groupCanBeFoundViaSearch), + title: Text(L10n.of(context).groupCanBeFoundViaSearch), value: controller.groupCanBeFound, onChanged: controller.loading ? null @@ -102,60 +116,74 @@ class NewGroupView extends StatelessWidget { ) : const SizedBox.shrink(), ), - SwitchListTile.adaptive( - secondary: Icon( - Icons.lock_outlined, - color: Theme.of(context).colorScheme.onSurface, - ), - title: Text( - L10n.of(context)!.enableEncryption, - style: TextStyle( - color: Theme.of(context).colorScheme.onSurface, - ), - ), - value: !controller.publicGroup, - onChanged: null, + AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: controller.createGroupType == CreateGroupType.space + ? const SizedBox.shrink() + : SwitchListTile.adaptive( + contentPadding: const EdgeInsets.symmetric( + horizontal: 32, + ), + secondary: Icon( + Icons.lock_outlined, + color: theme.colorScheme.onSurface, + ), + title: Text( + L10n.of(context).enableEncryption, + style: TextStyle(color: theme.colorScheme.onSurface), + ), + value: !controller.publicGroup, + onChanged: null, + ), + ), + AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: controller.createGroupType == CreateGroupType.space + ? ListTile( + contentPadding: const EdgeInsets.symmetric( + horizontal: 32, + ), + trailing: const Padding( + padding: EdgeInsets.symmetric(horizontal: 16.0), + child: Icon(Icons.info_outlined), + ), + subtitle: Text(L10n.of(context).newSpaceDescription), + ) + : const SizedBox.shrink(), ), Padding( padding: const EdgeInsets.all(16.0), child: SizedBox( width: double.infinity, child: ElevatedButton( - style: ElevatedButton.styleFrom( - foregroundColor: Theme.of(context).colorScheme.onPrimary, - backgroundColor: Theme.of(context).colorScheme.primary, - ), - onPressed: - controller.loading ? null : controller.submitAction, + onPressed: controller.loading + ? null + : controller.submitAction, child: controller.loading ? const LinearProgressIndicator() - : Row( - children: [ - Expanded( - child: Text( - L10n.of(context)!.createGroupAndInviteUsers, - ), - ), - Icon(Icons.adaptive.arrow_forward_outlined), - ], + : Text( + controller.createGroupType == CreateGroupType.space + ? L10n.of(context).createNewSpace + : L10n.of(context).createGroupAndInviteUsers, ), ), ), ), AnimatedSize( duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, child: error == null ? const SizedBox.shrink() : ListTile( leading: Icon( Icons.warning_outlined, - color: Theme.of(context).colorScheme.error, + color: theme.colorScheme.error, ), title: Text( error.toLocalizedString(context), - style: TextStyle( - color: Theme.of(context).colorScheme.error, - ), + style: TextStyle(color: theme.colorScheme.error), ), ), ), diff --git a/lib/pages/new_private_chat/new_private_chat.dart b/lib/pages/new_private_chat/new_private_chat.dart index c1d8c649a..55435cc11 100644 --- a/lib/pages/new_private_chat/new_private_chat.dart +++ b/lib/pages/new_private_chat/new_private_chat.dart @@ -4,17 +4,17 @@ import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:device_info_plus/device_info_plus.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/new_private_chat/new_private_chat_view.dart'; import 'package:fluffychat/pages/new_private_chat/qr_scanner_modal.dart'; -import 'package:fluffychat/pages/user_bottom_sheet/user_bottom_sheet.dart'; import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; import 'package:fluffychat/utils/fluffy_share.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'package:fluffychat/utils/url_launcher.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import '../../widgets/adaptive_dialogs/user_dialog.dart'; class NewPrivateChat extends StatefulWidget { const NewPrivateChat({super.key}); @@ -33,7 +33,7 @@ class NewPrivateChatController extends State { static const Duration _coolDown = Duration(milliseconds: 500); - void searchUsers([String? input]) async { + Future searchUsers([String? input]) async { final searchTerm = input ?? controller.text; if (searchTerm.isEmpty) { _searchCoolDown?.cancel(); @@ -52,8 +52,9 @@ class NewPrivateChatController extends State { } Future> _searchUser(String searchTerm) async { - final result = - await Matrix.of(context).client.searchUserDirectory(searchTerm); + final result = await Matrix.of( + context, + ).client.searchUserDirectory(searchTerm); final profiles = result.results; if (searchTerm.isValidMatrixId && @@ -67,15 +68,13 @@ class NewPrivateChatController extends State { void inviteAction() => FluffyShare.shareInviteLink(context); - void openScannerAction() async { + Future openScannerAction() async { if (PlatformInfos.isAndroid) { final info = await DeviceInfoPlugin().androidInfo; if (info.version.sdkInt < 21) { ScaffoldMessenger.of(context).showSnackBar( SnackBar( - content: Text( - L10n.of(context)!.unsupportedAndroidVersionLong, - ), + content: Text(L10n.of(context).unsupportedAndroidVersionLong), ), ); return; @@ -89,22 +88,17 @@ class NewPrivateChatController extends State { ); } - void copyUserId() async { + Future copyUserId() async { await Clipboard.setData( ClipboardData(text: Matrix.of(context).client.userID!), ); - ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.copiedToClipboard)), - ); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(L10n.of(context).copiedToClipboard))); } - void openUserModal(Profile profile) => showAdaptiveBottomSheet( - context: context, - builder: (c) => UserBottomSheet( - profile: profile, - outerContext: context, - ), - ); + void openUserModal(Profile profile) => + UserDialog.show(context: context, profile: profile); @override Widget build(BuildContext context) => NewPrivateChatView(this); diff --git a/lib/pages/new_private_chat/new_private_chat_view.dart b/lib/pages/new_private_chat/new_private_chat_view.dart index 81d10bcf8..d72ba4c28 100644 --- a/lib/pages/new_private_chat/new_private_chat_view.dart +++ b/lib/pages/new_private_chat/new_private_chat_view.dart @@ -1,12 +1,12 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; import 'package:pretty_qr_code/pretty_qr_code.dart'; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/new_private_chat/new_private_chat.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; import 'package:fluffychat/utils/platform_infos.dart'; @@ -14,6 +14,7 @@ import 'package:fluffychat/utils/url_launcher.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import '../../widgets/qr_code_viewer.dart'; class NewPrivateChatView extends StatelessWidget { final NewPrivateChatController controller; @@ -22,18 +23,23 @@ class NewPrivateChatView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final searchResponse = controller.searchResponse; + final userId = Matrix.of(context).client.userID!; return Scaffold( appBar: AppBar( scrolledUnderElevation: 0, leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.newChat), - backgroundColor: Theme.of(context).scaffoldBackgroundColor, + title: Text(L10n.of(context).newChat), + backgroundColor: theme.scaffoldBackgroundColor, actions: [ TextButton( - onPressed: - UrlLauncher(context, AppConfig.startChatTutorial).launchUrl, - child: Text(L10n.of(context)!.help), + onPressed: UrlLauncher( + context, + AppConfig.startChatTutorial, + ).launchUrl, + child: Text(L10n.of(context).help), ), ], ), @@ -51,7 +57,17 @@ class NewPrivateChatView extends StatelessWidget { controller: controller.controller, onChanged: controller.searchUsers, decoration: InputDecoration( - hintText: L10n.of(context)!.searchForUsers, + hintText: L10n.of(context).searchForUsers, + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + hintStyle: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontWeight: FontWeight.normal, + ), prefixIcon: searchResponse == null ? const Icon(Icons.search_outlined) : FutureBuilder( @@ -85,177 +101,191 @@ class NewPrivateChatView extends StatelessWidget { ), ), Expanded( - child: AnimatedCrossFade( + child: AnimatedSwitcher( duration: FluffyThemes.animationDuration, - crossFadeState: searchResponse == null - ? CrossFadeState.showFirst - : CrossFadeState.showSecond, - firstChild: ListView( - children: [ - Padding( - padding: const EdgeInsets.symmetric(horizontal: 18.0), - child: SelectableText.rich( - TextSpan( - children: [ - TextSpan( - text: L10n.of(context)!.yourGlobalUserIdIs, + child: searchResponse == null + ? ListView( + children: [ + Padding( + padding: const EdgeInsets.symmetric( + horizontal: 18.0, ), - TextSpan( - text: Matrix.of(context).client.userID, - style: const TextStyle( - fontWeight: FontWeight.w600, + child: SelectableText.rich( + TextSpan( + children: [ + TextSpan( + text: L10n.of(context).yourGlobalUserIdIs, + ), + TextSpan( + text: Matrix.of(context).client.userID, + style: const TextStyle( + fontWeight: FontWeight.w600, + ), + ), + ], + ), + style: TextStyle( + color: theme.colorScheme.onSurface, + fontSize: 12, ), ), - ], - ), - style: TextStyle( - color: Theme.of(context).colorScheme.onSurface, - fontSize: 13, - ), - ), - ), - const SizedBox(height: 8), - ListTile( - leading: CircleAvatar( - backgroundColor: - Theme.of(context).colorScheme.secondaryContainer, - foregroundColor: - Theme.of(context).colorScheme.onSecondaryContainer, - child: Icon(Icons.adaptive.share_outlined), - ), - title: Text(L10n.of(context)!.shareInviteLink), - onTap: controller.inviteAction, - ), - ListTile( - leading: CircleAvatar( - backgroundColor: - Theme.of(context).colorScheme.tertiaryContainer, - foregroundColor: - Theme.of(context).colorScheme.onTertiaryContainer, - child: const Icon(Icons.group_add_outlined), - ), - title: Text(L10n.of(context)!.createGroup), - onTap: () => context.go('/rooms/newgroup'), - ), - if (PlatformInfos.isMobile) - ListTile( - leading: CircleAvatar( - backgroundColor: - Theme.of(context).colorScheme.primaryContainer, - foregroundColor: - Theme.of(context).colorScheme.onPrimaryContainer, - child: const Icon(Icons.qr_code_scanner_outlined), - ), - title: Text(L10n.of(context)!.scanQrCode), - onTap: controller.openScannerAction, - ), - Center( - child: Padding( - padding: const EdgeInsets.all(64.0), - child: ConstrainedBox( - constraints: const BoxConstraints(maxHeight: 256), - child: Material( - borderRadius: BorderRadius.circular(12), - elevation: 10, - color: Colors.white, - shadowColor: - Theme.of(context).appBarTheme.shadowColor, - clipBehavior: Clip.hardEdge, + ), + const SizedBox(height: 8), + ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.secondaryContainer, + foregroundColor: + theme.colorScheme.onSecondaryContainer, + child: Icon(Icons.adaptive.share_outlined), + ), + title: Text(L10n.of(context).shareInviteLink), + onTap: controller.inviteAction, + ), + ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.tertiaryContainer, + foregroundColor: + theme.colorScheme.onTertiaryContainer, + child: const Icon(Icons.group_add_outlined), + ), + title: Text(L10n.of(context).createGroup), + onTap: () => context.go('/rooms/newgroup'), + ), + if (PlatformInfos.isMobile) + ListTile( + leading: CircleAvatar( + backgroundColor: + theme.colorScheme.primaryContainer, + foregroundColor: + theme.colorScheme.onPrimaryContainer, + child: const Icon( + Icons.qr_code_scanner_outlined, + ), + ), + title: Text(L10n.of(context).scanQrCode), + onTap: controller.openScannerAction, + ), + Center( child: Padding( - padding: const EdgeInsets.all(8), - child: PrettyQrView.data( - data: - 'https://matrix.to/#/${Matrix.of(context).client.userID}', - decoration: PrettyQrDecoration( - shape: PrettyQrSmoothSymbol( - roundFactor: 1, - color: Theme.of(context).brightness == - Brightness.light - ? Theme.of(context).colorScheme.primary - : Theme.of(context) - .colorScheme - .onPrimary, + padding: const EdgeInsets.symmetric( + horizontal: 64.0, + vertical: 24.0, + ), + child: Material( + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + side: BorderSide( + width: 3, + color: theme.colorScheme.primary, + ), + ), + color: Colors.transparent, + clipBehavior: Clip.hardEdge, + child: InkWell( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + onTap: () => + showQrCodeViewer(context, userId), + child: Padding( + padding: const EdgeInsets.all(16.0), + child: ConstrainedBox( + constraints: const BoxConstraints( + maxWidth: 200, + ), + child: PrettyQrView.data( + data: 'https://matrix.to/#/$userId', + decoration: PrettyQrDecoration( + shape: PrettyQrSmoothSymbol( + roundFactor: 1, + color: theme.colorScheme.primary, + ), + ), + ), + ), ), ), ), ), ), - ), + ], + ) + : FutureBuilder( + future: searchResponse, + builder: (context, snapshot) { + final result = snapshot.data; + final error = snapshot.error; + if (error != null) { + return Column( + mainAxisAlignment: .center, + children: [ + Text( + error.toLocalizedString(context), + textAlign: TextAlign.center, + style: TextStyle( + color: theme.colorScheme.error, + ), + ), + const SizedBox(height: 12), + OutlinedButton.icon( + onPressed: controller.searchUsers, + icon: const Icon(Icons.refresh_outlined), + label: Text(L10n.of(context).tryAgain), + ), + ], + ); + } + if (result == null) { + return const Center( + child: CircularProgressIndicator.adaptive(), + ); + } + if (result.isEmpty) { + return Column( + mainAxisAlignment: .center, + children: [ + const Icon(Icons.search_outlined, size: 86), + Padding( + padding: const EdgeInsets.all(16.0), + child: Text( + L10n.of(context).noUsersFoundWithQuery( + controller.controller.text, + ), + style: TextStyle( + color: theme.colorScheme.primary, + ), + textAlign: TextAlign.center, + ), + ), + ], + ); + } + return ListView.builder( + itemCount: result.length, + itemBuilder: (context, i) { + final contact = result[i]; + final displayname = + contact.displayName ?? + contact.userId.localpart ?? + contact.userId; + return ListTile( + leading: Avatar( + name: displayname, + mxContent: contact.avatarUrl, + presenceUserId: contact.userId, + ), + title: Text(displayname), + subtitle: Text(contact.userId), + onTap: () => controller.openUserModal(contact), + ); + }, + ); + }, ), - ), - ], - ), - secondChild: FutureBuilder( - future: searchResponse, - builder: (context, snapshot) { - final result = snapshot.data; - final error = snapshot.error; - if (error != null) { - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - Text( - error.toLocalizedString(context), - textAlign: TextAlign.center, - style: TextStyle( - color: Theme.of(context).colorScheme.error, - ), - ), - const SizedBox(height: 12), - OutlinedButton.icon( - onPressed: controller.searchUsers, - icon: const Icon(Icons.refresh_outlined), - label: Text(L10n.of(context)!.tryAgain), - ), - ], - ); - } - if (result == null) { - return const Center( - child: CircularProgressIndicator.adaptive(), - ); - } - if (result.isEmpty) { - return Column( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - const Icon(Icons.search_outlined, size: 86), - Padding( - padding: const EdgeInsets.all(16.0), - child: Text( - L10n.of(context)!.noUsersFoundWithQuery( - controller.controller.text, - ), - style: TextStyle( - color: Theme.of(context).colorScheme.primary, - ), - textAlign: TextAlign.center, - ), - ), - ], - ); - } - return ListView.builder( - itemCount: result.length, - itemBuilder: (context, i) { - final contact = result[i]; - final displayname = contact.displayName ?? - contact.userId.localpart ?? - contact.userId; - return ListTile( - leading: Avatar( - name: displayname, - mxContent: contact.avatarUrl, - presenceUserId: contact.userId, - ), - title: Text(displayname), - subtitle: Text(contact.userId), - onTap: () => controller.openUserModal(contact), - ); - }, - ); - }, - ), ), ), ], diff --git a/lib/pages/new_private_chat/qr_scanner_modal.dart b/lib/pages/new_private_chat/qr_scanner_modal.dart index fbc1d5e4b..b47dc566f 100644 --- a/lib/pages/new_private_chat/qr_scanner_modal.dart +++ b/lib/pages/new_private_chat/qr_scanner_modal.dart @@ -3,8 +3,9 @@ import 'dart:io'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:qr_code_scanner/qr_code_scanner.dart'; +import 'package:qr_code_scanner_plus/qr_code_scanner_plus.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; class QrScannerModal extends StatefulWidget { final void Function(String) onScan; @@ -35,9 +36,9 @@ class QrScannerModalState extends State { leading: IconButton( icon: const Icon(Icons.close_outlined), onPressed: Navigator.of(context).pop, - tooltip: L10n.of(context)!.close, + tooltip: L10n.of(context).close, ), - title: Text(L10n.of(context)!.scanQrCode), + title: Text(L10n.of(context).scanQrCode), ), body: Stack( children: [ @@ -72,10 +73,4 @@ class QrScannerModalState extends State { if (data != null) widget.onScan(data); }); } - - @override - void dispose() { - controller?.dispose(); - super.dispose(); - } } diff --git a/lib/pages/new_space/new_space.dart b/lib/pages/new_space/new_space.dart deleted file mode 100644 index a5a55c8b1..000000000 --- a/lib/pages/new_space/new_space.dart +++ /dev/null @@ -1,103 +0,0 @@ -import 'dart:typed_data'; - -import 'package:flutter/material.dart'; - -import 'package:file_picker/file_picker.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:go_router/go_router.dart'; -import 'package:matrix/matrix.dart' as sdk; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/pages/new_space/new_space_view.dart'; -import 'package:fluffychat/utils/localized_exception_extension.dart'; -import 'package:fluffychat/widgets/matrix.dart'; - -class NewSpace extends StatefulWidget { - const NewSpace({super.key}); - - @override - NewSpaceController createState() => NewSpaceController(); -} - -class NewSpaceController extends State { - TextEditingController nameController = TextEditingController(); - TextEditingController topicController = TextEditingController(); - bool publicGroup = false; - bool loading = false; - String? nameError; - String? topicError; - - Uint8List? avatar; - - Uri? avatarUrl; - - void selectPhoto() async { - final photo = await FilePicker.platform.pickFiles( - type: FileType.image, - allowMultiple: false, - withData: true, - ); - - setState(() { - avatarUrl = null; - avatar = photo?.files.singleOrNull?.bytes; - }); - } - - void setPublicGroup(bool b) => setState(() => publicGroup = b); - - void submitAction([_]) async { - final client = Matrix.of(context).client; - setState(() { - nameError = topicError = null; - }); - if (nameController.text.isEmpty) { - setState(() { - nameError = L10n.of(context)!.pleaseChoose; - }); - return; - } - setState(() { - loading = true; - }); - try { - final avatar = this.avatar; - avatarUrl ??= avatar == null ? null : await client.uploadContent(avatar); - - final spaceId = await client.createRoom( - preset: publicGroup - ? sdk.CreateRoomPreset.publicChat - : sdk.CreateRoomPreset.privateChat, - creationContent: {'type': RoomCreationTypes.mSpace}, - visibility: publicGroup ? sdk.Visibility.public : null, - roomAliasName: publicGroup - ? nameController.text.trim().toLowerCase().replaceAll(' ', '_') - : null, - name: nameController.text.trim(), - topic: topicController.text.isEmpty ? null : topicController.text, - powerLevelContentOverride: {'events_default': 100}, - initialState: [ - if (avatar != null) - sdk.StateEvent( - type: sdk.EventTypes.RoomAvatar, - content: {'url': avatarUrl.toString()}, - ), - ], - ); - if (!mounted) return; - context.pop(spaceId); - } catch (e) { - setState(() { - topicError = e.toLocalizedString(context); - }); - } finally { - setState(() { - loading = false; - }); - } - // TODO: Go to spaces - } - - @override - Widget build(BuildContext context) => NewSpaceView(this); -} diff --git a/lib/pages/new_space/new_space_view.dart b/lib/pages/new_space/new_space_view.dart deleted file mode 100644 index eb464855e..000000000 --- a/lib/pages/new_space/new_space_view.dart +++ /dev/null @@ -1,124 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; - -import 'package:fluffychat/widgets/avatar.dart'; -import 'package:fluffychat/widgets/layouts/max_width_body.dart'; -import 'new_space.dart'; - -class NewSpaceView extends StatelessWidget { - final NewSpaceController controller; - - const NewSpaceView(this.controller, {super.key}); - - @override - Widget build(BuildContext context) { - final avatar = controller.avatar; - return Scaffold( - appBar: AppBar( - title: Text(L10n.of(context)!.createNewSpace), - ), - body: MaxWidthBody( - child: Column( - mainAxisSize: MainAxisSize.min, - children: [ - ListTile( - trailing: const Padding( - padding: EdgeInsets.symmetric(horizontal: 16.0), - child: Icon(Icons.info_outlined), - ), - subtitle: Text(L10n.of(context)!.newSpaceDescription), - ), - const SizedBox(height: 16), - Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0), - child: Row( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - InkWell( - borderRadius: BorderRadius.circular(90), - onTap: controller.loading ? null : controller.selectPhoto, - child: CircleAvatar( - radius: Avatar.defaultSize / 2, - child: avatar == null - ? const Icon(Icons.camera_alt_outlined) - : ClipRRect( - borderRadius: BorderRadius.circular(90), - child: Image.memory( - avatar, - width: Avatar.defaultSize, - height: Avatar.defaultSize, - fit: BoxFit.cover, - ), - ), - ), - ), - const SizedBox(width: 16), - Expanded( - child: TextField( - controller: controller.nameController, - autocorrect: false, - readOnly: controller.loading, - decoration: InputDecoration( - prefixIcon: const Icon(Icons.people_outlined), - hintText: L10n.of(context)!.spaceName, - errorText: controller.nameError, - ), - ), - ), - ], - ), - ), - const SizedBox(height: 16), - Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0), - child: TextField( - controller: controller.topicController, - minLines: 4, - maxLines: 4, - maxLength: 255, - readOnly: controller.loading, - decoration: InputDecoration( - hintText: L10n.of(context)!.addChatDescription, - errorText: controller.topicError, - ), - ), - ), - const SizedBox(height: 16), - SwitchListTile.adaptive( - title: Text(L10n.of(context)!.spaceIsPublic), - value: controller.publicGroup, - onChanged: controller.setPublicGroup, - ), - Padding( - padding: const EdgeInsets.all(16.0), - child: SizedBox( - width: double.infinity, - child: ElevatedButton( - style: ElevatedButton.styleFrom( - foregroundColor: Theme.of(context).colorScheme.onPrimary, - backgroundColor: Theme.of(context).colorScheme.primary, - ), - onPressed: - controller.loading ? null : controller.submitAction, - child: controller.loading - ? const LinearProgressIndicator() - : Row( - children: [ - Expanded( - child: Text( - L10n.of(context)!.createNewSpace, - ), - ), - Icon(Icons.adaptive.arrow_forward_outlined), - ], - ), - ), - ), - ), - ], - ), - ), - ); - } -} diff --git a/lib/pages/settings/settings.dart b/lib/pages/settings/settings.dart index 97bbec66d..2611af782 100644 --- a/lib/pages/settings/settings.dart +++ b/lib/pages/settings/settings.dart @@ -2,18 +2,21 @@ import 'dart:async'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; import 'package:collection/collection.dart'; import 'package:file_picker/file_picker.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; +import 'package:go_router/go_router.dart'; import 'package:image_picker/image_picker.dart'; +import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/file_selector.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/widgets/app_lock.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import '../../widgets/matrix.dart'; -import '../bootstrap/bootstrap_dialog.dart'; import 'settings_view.dart'; class Settings extends StatefulWidget { @@ -28,47 +31,45 @@ class SettingsController extends State { bool profileUpdated = false; void updateProfile() => setState(() { - profileUpdated = true; - profileFuture = null; - }); + profileUpdated = true; + profileFuture = null; + }); - void setDisplaynameAction() async { + Future setDisplaynameAction() async { final profile = await profileFuture; final input = await showTextInputDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.editDisplayname, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - initialText: profile?.displayName ?? - Matrix.of(context).client.userID!.localpart, - ), - ], + title: L10n.of(context).editDisplayname, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + initialText: + profile?.displayName ?? Matrix.of(context).client.userID!.localpart, ); if (input == null) return; final matrix = Matrix.of(context); final success = await showFutureLoadingDialog( context: context, - future: () => - matrix.client.setDisplayName(matrix.client.userID!, input.single), + future: () => matrix.client.setProfileField( + matrix.client.userID!, + 'displayname', + {'displayname': input}, + ), ); if (success.error == null) { updateProfile(); } } - void logoutAction() async { - final noBackup = showChatBackupBanner == true; + Future logoutAction() async { if (await showOkCancelAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.areYouSureYouWantToLogout, - message: L10n.of(context)!.noBackupWarning, - isDestructiveAction: noBackup, - okLabel: L10n.of(context)!.logout, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).areYouSureYouWantToLogout, + message: L10n.of(context).noBackupWarning, + isDestructive: cryptoIdentityConnected == false, + okLabel: L10n.of(context).logout, + cancelLabel: L10n.of(context).cancel, ) == OkCancelResult.cancel) { return; @@ -78,36 +79,38 @@ class SettingsController extends State { context: context, future: () => matrix.client.logout(), ); + context.go('/'); } - void setAvatarAction() async { + Future setAvatarAction() async { final profile = await profileFuture; final actions = [ if (PlatformInfos.isMobile) - SheetAction( - key: AvatarAction.camera, - label: L10n.of(context)!.openCamera, + AdaptiveModalAction( + value: AvatarAction.camera, + label: L10n.of(context).openCamera, isDefaultAction: true, - icon: Icons.camera_alt_outlined, + icon: const Icon(Icons.camera_alt_outlined), ), - SheetAction( - key: AvatarAction.file, - label: L10n.of(context)!.openGallery, - icon: Icons.photo_outlined, + AdaptiveModalAction( + value: AvatarAction.file, + label: L10n.of(context).openGallery, + icon: const Icon(Icons.photo_outlined), ), if (profile?.avatarUrl != null) - SheetAction( - key: AvatarAction.remove, - label: L10n.of(context)!.removeYourAvatar, - isDestructiveAction: true, - icon: Icons.delete_outlined, + AdaptiveModalAction( + value: AvatarAction.remove, + label: L10n.of(context).removeYourAvatar, + isDestructive: true, + icon: const Icon(Icons.delete_outlined), ), ]; final action = actions.length == 1 - ? actions.single.key - : await showModalActionSheet( + ? actions.single.value + : await showModalActionPopup( context: context, - title: L10n.of(context)!.changeYourAvatar, + title: L10n.of(context).changeYourAvatar, + cancelLabel: L10n.of(context).cancel, actions: actions, ); if (action == null) return; @@ -131,21 +134,13 @@ class SettingsController extends State { imageQuality: 50, ); if (result == null) return; - file = MatrixFile( - bytes: await result.readAsBytes(), - name: result.path, - ); + file = MatrixFile(bytes: await result.readAsBytes(), name: result.path); } else { - final result = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles( - type: FileType.image, - withData: true, - ), - ); - final pickedFile = result?.files.firstOrNull; + final result = await selectFiles(context, type: FileType.image); + final pickedFile = result.firstOrNull; if (pickedFile == null) return; file = MatrixFile( - bytes: pickedFile.bytes!, + bytes: await pickedFile.readAsBytes(), name: pickedFile.name, ); } @@ -165,7 +160,7 @@ class SettingsController extends State { super.initState(); } - void checkBootstrap() async { + Future checkBootstrap() async { final client = Matrix.of(context).client; if (!client.encryptionEnabled) return; await client.accountDataLoading; @@ -173,45 +168,33 @@ class SettingsController extends State { if (client.prevBatch == null) { await client.onSync.stream.first; } - final crossSigning = - await client.encryption?.crossSigning.isCached() ?? false; - final needsBootstrap = - await client.encryption?.keyManager.isCached() == false || - client.encryption?.crossSigning.enabled == false || - crossSigning == false; - final isUnknownSession = client.isUnknownSession; + + final state = await client.getCryptoIdentityState(); setState(() { - showChatBackupBanner = needsBootstrap || isUnknownSession; + cryptoIdentityConnected = state.initialized && state.connected; }); } - bool? crossSigningCached; - bool? showChatBackupBanner; + bool? cryptoIdentityConnected; - void firstRunBootstrapAction([_]) async { - if (showChatBackupBanner != true) { + Future firstRunBootstrapAction([_]) async { + if (cryptoIdentityConnected == true) { showOkAlertDialog( context: context, - title: L10n.of(context)!.chatBackup, - message: L10n.of(context)!.onlineKeyBackupEnabled, - okLabel: L10n.of(context)!.close, + title: L10n.of(context).chatBackup, + message: L10n.of(context).onlineKeyBackupEnabled, + okLabel: L10n.of(context).close, ); return; } - await BootstrapDialog( - client: Matrix.of(context).client, - ).show(context); + await context.push('/backup'); checkBootstrap(); } @override Widget build(BuildContext context) { final client = Matrix.of(context).client; - profileFuture ??= client.getProfileFromUserId( - client.userID!, - cache: !profileUpdated, - getFromRooms: !profileUpdated, - ); + profileFuture ??= client.getProfileFromUserId(client.userID!); return SettingsView(this); } } diff --git a/lib/pages/settings/settings_view.dart b/lib/pages/settings/settings_view.dart index b1d60f142..20b841466 100644 --- a/lib/pages/settings/settings_view.dart +++ b/lib/pages/settings/settings_view.dart @@ -1,15 +1,16 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; -import 'package:url_launcher/url_launcher_string.dart'; +import 'package:url_launcher/url_launcher.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/fluffy_share.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/matrix.dart'; +import '../../widgets/mxc_image_viewer.dart'; import 'settings.dart'; class SettingsView extends StatelessWidget { @@ -19,25 +20,20 @@ class SettingsView extends StatelessWidget { @override Widget build(BuildContext context) { - final showChatBackupBanner = controller.showChatBackupBanner; + final theme = Theme.of(context); + final activeRoute = GoRouter.of( + context, + ).routeInformationProvider.value.uri.path; + return Scaffold( appBar: AppBar( + title: Text(L10n.of(context).settings), leading: Center( - child: CloseButton( - onPressed: () => context.go('/rooms'), - ), + child: BackButton(onPressed: () => context.go('/rooms')), ), - title: Text(L10n.of(context)!.settings), - actions: [ - TextButton.icon( - onPressed: controller.logoutAction, - label: Text(L10n.of(context)!.logout), - icon: const Icon(Icons.logout_outlined), - ), - ], ), body: ListTileTheme( - iconColor: Theme.of(context).colorScheme.onSurface, + iconColor: theme.colorScheme.onSurface, child: ListView( key: const Key('SettingsListViewContent'), children: [ @@ -45,8 +41,9 @@ class SettingsView extends StatelessWidget { future: controller.profileFuture, builder: (context, snapshot) { final profile = snapshot.data; + final avatar = profile?.avatarUrl; final mxid = - Matrix.of(context).client.userID ?? L10n.of(context)!.user; + Matrix.of(context).client.userID ?? L10n.of(context).user; final displayname = profile?.displayName ?? mxid.localpart ?? mxid; return Row( @@ -55,32 +52,23 @@ class SettingsView extends StatelessWidget { padding: const EdgeInsets.all(32.0), child: Stack( children: [ - Material( - elevation: Theme.of(context) - .appBarTheme - .scrolledUnderElevation ?? - 4, - shadowColor: - Theme.of(context).appBarTheme.shadowColor, - shape: RoundedRectangleBorder( - side: BorderSide( - color: Theme.of(context).dividerColor, - ), - borderRadius: BorderRadius.circular( - Avatar.defaultSize * 2.5, - ), - ), - child: Avatar( - mxContent: profile?.avatarUrl, - name: displayname, - size: Avatar.defaultSize * 2.5, - ), + Avatar( + mxContent: avatar, + name: displayname, + size: Avatar.defaultSize * 2.5, + onTap: avatar != null + ? () => showDialog( + context: context, + builder: (_) => MxcImageViewer(avatar), + ) + : null, ), if (profile != null) Positioned( bottom: 0, right: 0, child: FloatingActionButton.small( + elevation: 2, onPressed: controller.setAvatarAction, heroTag: null, child: const Icon(Icons.camera_alt_outlined), @@ -91,35 +79,29 @@ class SettingsView extends StatelessWidget { ), Expanded( child: Column( - mainAxisAlignment: MainAxisAlignment.center, - crossAxisAlignment: CrossAxisAlignment.start, + mainAxisAlignment: .center, + crossAxisAlignment: .start, children: [ TextButton.icon( onPressed: controller.setDisplaynameAction, - icon: const Icon( - Icons.edit_outlined, - size: 16, - ), + icon: const Icon(Icons.edit_outlined, size: 16), style: TextButton.styleFrom( - foregroundColor: - Theme.of(context).colorScheme.onSurface, + foregroundColor: theme.colorScheme.onSurface, + iconColor: theme.colorScheme.onSurface, ), label: Text( displayname, maxLines: 1, overflow: TextOverflow.ellipsis, - // style: const TextStyle(fontSize: 18), + style: const TextStyle(fontSize: 18), ), ), TextButton.icon( onPressed: () => FluffyShare.share(mxid, context), - icon: const Icon( - Icons.copy_outlined, - size: 14, - ), + icon: const Icon(Icons.copy_outlined, size: 14), style: TextButton.styleFrom( - foregroundColor: - Theme.of(context).colorScheme.secondary, + foregroundColor: theme.colorScheme.secondary, + iconColor: theme.colorScheme.secondary, ), label: Text( mxid, @@ -135,79 +117,101 @@ class SettingsView extends StatelessWidget { ); }, ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, + FutureBuilder( + future: Matrix.of(context).client.getAuthMetadata(), + builder: (context, snapshot) { + final accountManageUrl = snapshot.data?.issuer; + if (accountManageUrl == null) { + return const SizedBox.shrink(); + } + return ListTile( + leading: const Icon(Icons.account_circle_outlined), + title: Text(L10n.of(context).manageAccount), + trailing: const Icon(Icons.open_in_new_outlined), + onTap: () => launchUrl( + accountManageUrl, + mode: LaunchMode.inAppBrowserView, + ), + ); + }, ), - if (showChatBackupBanner == null) - ListTile( - leading: const Icon(Icons.backup_outlined), - title: Text(L10n.of(context)!.chatBackup), - trailing: const CircularProgressIndicator.adaptive(), - ) - else - SwitchListTile.adaptive( - controlAffinity: ListTileControlAffinity.trailing, - value: controller.showChatBackupBanner == false, - secondary: const Icon(Icons.backup_outlined), - title: Text(L10n.of(context)!.chatBackup), - onChanged: controller.firstRunBootstrapAction, - ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, + Divider(color: theme.dividerColor), + SwitchListTile.adaptive( + controlAffinity: ListTileControlAffinity.trailing, + value: controller.cryptoIdentityConnected == true, + secondary: const Icon(Icons.backup_outlined), + title: Text(L10n.of(context).chatBackup), + onChanged: controller.firstRunBootstrapAction, ), + Divider(color: theme.dividerColor), ListTile( leading: const Icon(Icons.format_paint_outlined), - title: Text(L10n.of(context)!.changeTheme), + title: Text(L10n.of(context).changeTheme), + tileColor: activeRoute.startsWith('/rooms/settings/style') + ? theme.colorScheme.surfaceContainerHigh + : null, onTap: () => context.go('/rooms/settings/style'), - trailing: const Icon(Icons.chevron_right_outlined), ), ListTile( leading: const Icon(Icons.notifications_outlined), - title: Text(L10n.of(context)!.notifications), + title: Text(L10n.of(context).notifications), + tileColor: activeRoute.startsWith('/rooms/settings/notifications') + ? theme.colorScheme.surfaceContainerHigh + : null, onTap: () => context.go('/rooms/settings/notifications'), - trailing: const Icon(Icons.chevron_right_outlined), ), ListTile( leading: const Icon(Icons.devices_outlined), - title: Text(L10n.of(context)!.devices), + title: Text(L10n.of(context).devices), onTap: () => context.go('/rooms/settings/devices'), - trailing: const Icon(Icons.chevron_right_outlined), + tileColor: activeRoute.startsWith('/rooms/settings/devices') + ? theme.colorScheme.surfaceContainerHigh + : null, ), ListTile( leading: const Icon(Icons.forum_outlined), - title: Text(L10n.of(context)!.chat), + title: Text(L10n.of(context).chat), onTap: () => context.go('/rooms/settings/chat'), - trailing: const Icon(Icons.chevron_right_outlined), + tileColor: activeRoute.startsWith('/rooms/settings/chat') + ? theme.colorScheme.surfaceContainerHigh + : null, ), ListTile( leading: const Icon(Icons.shield_outlined), - title: Text(L10n.of(context)!.security), + title: Text(L10n.of(context).security), onTap: () => context.go('/rooms/settings/security'), - trailing: const Icon(Icons.chevron_right_outlined), + tileColor: activeRoute.startsWith('/rooms/settings/security') + ? theme.colorScheme.surfaceContainerHigh + : null, ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, + Divider(color: theme.dividerColor), + ListTile( + leading: const Icon(Icons.dns_outlined), + title: Text( + L10n.of(context).aboutHomeserver( + Matrix.of(context).client.userID?.domain ?? 'homeserver', + ), + ), + onTap: () => context.go('/rooms/settings/homeserver'), + tileColor: activeRoute.startsWith('/rooms/settings/homeserver') + ? theme.colorScheme.surfaceContainerHigh + : null, ), ListTile( - leading: const Icon(Icons.help_outline_outlined), - title: Text(L10n.of(context)!.help), - onTap: () => launchUrlString(AppConfig.supportUrl), - trailing: const Icon(Icons.open_in_new_outlined), - ), - ListTile( - leading: const Icon(Icons.shield_sharp), - title: Text(L10n.of(context)!.privacy), - onTap: () => launchUrlString(AppConfig.privacyUrl), - trailing: const Icon(Icons.open_in_new_outlined), + leading: const Icon(Icons.privacy_tip_outlined), + title: Text(L10n.of(context).privacy), + onTap: () => launchUrl(AppConfig.privacyUrl), ), ListTile( leading: const Icon(Icons.info_outline_rounded), - title: Text(L10n.of(context)!.about), + title: Text(L10n.of(context).about), onTap: () => PlatformInfos.showDialog(context), - trailing: const Icon(Icons.chevron_right_outlined), + ), + Divider(color: theme.dividerColor), + ListTile( + leading: const Icon(Icons.logout_outlined), + title: Text(L10n.of(context).logout), + onTap: controller.logoutAction, ), ], ), diff --git a/lib/pages/settings_3pid/settings_3pid.dart b/lib/pages/settings_3pid/settings_3pid.dart index d46cac2a9..765399ec6 100644 --- a/lib/pages/settings_3pid/settings_3pid.dart +++ b/lib/pages/settings_3pid/settings_3pid.dart @@ -1,10 +1,11 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; import 'settings_3pid_view.dart'; @@ -18,48 +19,43 @@ class Settings3Pid extends StatefulWidget { } class Settings3PidController extends State { - void add3PidAction() async { + Future add3PidAction() async { final input = await showTextInputDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.enterAnEmailAddress, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - hintText: L10n.of(context)!.enterAnEmailAddress, - keyboardType: TextInputType.emailAddress, - ), - ], + title: L10n.of(context).enterAnEmailAddress, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + hintText: L10n.of(context).enterAnEmailAddress, + keyboardType: TextInputType.emailAddress, ); if (input == null) return; final clientSecret = DateTime.now().millisecondsSinceEpoch.toString(); final response = await showFutureLoadingDialog( context: context, future: () => Matrix.of(context).client.requestTokenToRegisterEmail( - clientSecret, - input.single, - Settings3Pid.sendAttempt++, - ), + clientSecret, + input, + Settings3Pid.sendAttempt++, + ), ); if (response.error != null) return; final ok = await showOkAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.weSentYouAnEmail, - message: L10n.of(context)!.pleaseClickOnLink, - okLabel: L10n.of(context)!.iHaveClickedOnLink, + title: L10n.of(context).weSentYouAnEmail, + message: L10n.of(context).pleaseClickOnLink, + okLabel: L10n.of(context).iHaveClickedOnLink, ); if (ok != OkCancelResult.ok) return; final success = await showFutureLoadingDialog( context: context, + delay: false, future: () => Matrix.of(context).client.uiaRequestBackground( - (auth) => Matrix.of(context).client.add3PID( - clientSecret, - response.result!.sid, - auth: auth, - ), - ), + (auth) => Matrix.of( + context, + ).client.add3PID(clientSecret, response.result!.sid, auth: auth), + ), ); if (success.error != null) return; setState(() => request = null); @@ -67,23 +63,22 @@ class Settings3PidController extends State { Future?>? request; - void delete3Pid(ThirdPartyIdentifier identifier) async { + Future delete3Pid(ThirdPartyIdentifier identifier) async { if (await showOkCancelAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).areYouSure, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).cancel, ) != OkCancelResult.ok) { return; } final success = await showFutureLoadingDialog( context: context, - future: () => Matrix.of(context).client.delete3pidFromAccount( - identifier.address, - identifier.medium, - ), + future: () => Matrix.of( + context, + ).client.delete3pidFromAccount(identifier.address, identifier.medium), ); if (success.error != null) return; setState(() => request = null); diff --git a/lib/pages/settings_3pid/settings_3pid_view.dart b/lib/pages/settings_3pid/settings_3pid_view.dart index 49f8b4489..d01fdc6bf 100644 --- a/lib/pages/settings_3pid/settings_3pid_view.dart +++ b/lib/pages/settings_3pid/settings_3pid_view.dart @@ -1,8 +1,8 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/settings_3pid/settings_3pid.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'package:fluffychat/widgets/matrix.dart'; @@ -14,16 +14,18 @@ class Settings3PidView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + controller.request ??= Matrix.of(context).client.getAccount3PIDs(); return Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.passwordRecovery), + title: Text(L10n.of(context).passwordRecovery), actions: [ IconButton( icon: const Icon(Icons.add_outlined), onPressed: controller.add3PidAction, - tooltip: L10n.of(context)!.addEmail, + tooltip: L10n.of(context).addEmail, ), ], ), @@ -31,68 +33,71 @@ class Settings3PidView extends StatelessWidget { withScrolling: false, child: FutureBuilder?>( future: controller.request, - builder: ( - BuildContext context, - AsyncSnapshot?> snapshot, - ) { - if (snapshot.hasError) { - return Center( - child: Text( - snapshot.error.toString(), - textAlign: TextAlign.center, - ), - ); - } - if (!snapshot.hasData) { - return const Center( - child: CircularProgressIndicator.adaptive(strokeWidth: 2), - ); - } - final identifier = snapshot.data!; - return Column( - children: [ - ListTile( - leading: CircleAvatar( - backgroundColor: Theme.of(context).scaffoldBackgroundColor, - foregroundColor: - identifier.isEmpty ? Colors.orange : Colors.grey, - child: Icon( - identifier.isEmpty - ? Icons.warning_outlined - : Icons.info_outlined, + builder: + ( + BuildContext context, + AsyncSnapshot?> snapshot, + ) { + if (snapshot.hasError) { + return Center( + child: Text( + snapshot.error.toString(), + textAlign: TextAlign.center, ), - ), - title: Text( - identifier.isEmpty - ? L10n.of(context)!.noPasswordRecoveryDescription - : L10n.of(context)! - .withTheseAddressesRecoveryDescription, - ), - ), - const Divider(height: 1), - Expanded( - child: ListView.builder( - itemCount: identifier.length, - itemBuilder: (BuildContext context, int i) => ListTile( + ); + } + if (!snapshot.hasData) { + return const Center( + child: CircularProgressIndicator.adaptive(strokeWidth: 2), + ); + } + final identifier = snapshot.data!; + return Column( + children: [ + ListTile( leading: CircleAvatar( - backgroundColor: - Theme.of(context).scaffoldBackgroundColor, - foregroundColor: Colors.grey, - child: Icon(identifier[i].iconData), + backgroundColor: theme.scaffoldBackgroundColor, + foregroundColor: identifier.isEmpty + ? Colors.orange + : Colors.grey, + child: Icon( + identifier.isEmpty + ? Icons.warning_outlined + : Icons.info_outlined, + ), ), - title: Text(identifier[i].address), - trailing: IconButton( - tooltip: L10n.of(context)!.delete, - icon: const Icon(Icons.delete_forever_outlined), - color: Colors.red, - onPressed: () => controller.delete3Pid(identifier[i]), + title: Text( + identifier.isEmpty + ? L10n.of(context).noPasswordRecoveryDescription + : L10n.of( + context, + ).withTheseAddressesRecoveryDescription, ), ), - ), - ), - ], - ); - }, + const Divider(), + Expanded( + child: ListView.builder( + itemCount: identifier.length, + itemBuilder: (BuildContext context, int i) => ListTile( + leading: CircleAvatar( + backgroundColor: theme.scaffoldBackgroundColor, + foregroundColor: Colors.grey, + child: Icon(identifier[i].iconData), + ), + title: Text(identifier[i].address), + trailing: IconButton( + tooltip: L10n.of(context).delete, + icon: const Icon(Icons.delete_forever_outlined), + color: Colors.red, + onPressed: () => + controller.delete3Pid(identifier[i]), + ), + ), + ), + ), + ], + ); + }, ), ), ); diff --git a/lib/pages/settings_chat/settings_chat_view.dart b/lib/pages/settings_chat/settings_chat_view.dart index c3abe990e..b125cf734 100644 --- a/lib/pages/settings_chat/settings_chat_view.dart +++ b/lib/pages/settings_chat/settings_chat_view.dart @@ -1,12 +1,11 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; -import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/utils/voip/callkeep_manager.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'package:fluffychat/widgets/matrix.dart'; import 'package:fluffychat/widgets/settings_switch_list_tile.dart'; @@ -18,114 +17,83 @@ class SettingsChatView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return Scaffold( - appBar: AppBar(title: Text(L10n.of(context)!.chat)), + appBar: AppBar( + title: Text(L10n.of(context).chat), + automaticallyImplyLeading: !FluffyThemes.isColumnMode(context), + centerTitle: FluffyThemes.isColumnMode(context), + ), body: ListTileTheme( - iconColor: Theme.of(context).textTheme.bodyLarge!.color, + iconColor: theme.textTheme.bodyLarge!.color, child: MaxWidthBody( child: Column( children: [ SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.formattedMessages, - subtitle: L10n.of(context)!.formattedMessagesDescription, - onChanged: (b) => AppConfig.renderHtml = b, - storeKey: SettingKeys.renderHtml, - defaultValue: AppConfig.renderHtml, + title: L10n.of(context).formattedMessages, + subtitle: L10n.of(context).formattedMessagesDescription, + setting: AppSettings.renderHtml, ), SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.hideMemberChangesInPublicChats, - subtitle: L10n.of(context)!.hideMemberChangesInPublicChatsBody, - onChanged: (b) => AppConfig.hideUnimportantStateEvents = b, - storeKey: SettingKeys.hideUnimportantStateEvents, - defaultValue: AppConfig.hideUnimportantStateEvents, + title: L10n.of(context).hideRedactedMessages, + subtitle: L10n.of(context).hideRedactedMessagesBody, + setting: AppSettings.hideRedactedEvents, ), SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.hideRedactedMessages, - subtitle: L10n.of(context)!.hideRedactedMessagesBody, - onChanged: (b) => AppConfig.hideRedactedEvents = b, - storeKey: SettingKeys.hideRedactedEvents, - defaultValue: AppConfig.hideRedactedEvents, - ), - SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.hideInvalidOrUnknownMessageFormats, - onChanged: (b) => AppConfig.hideUnknownEvents = b, - storeKey: SettingKeys.hideUnknownEvents, - defaultValue: AppConfig.hideUnknownEvents, + title: L10n.of(context).hideInvalidOrUnknownMessageFormats, + setting: AppSettings.hideUnknownEvents, ), if (PlatformInfos.isMobile) SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.autoplayImages, - onChanged: (b) => AppConfig.autoplayImages = b, - storeKey: SettingKeys.autoplayImages, - defaultValue: AppConfig.autoplayImages, + title: L10n.of(context).autoplayImages, + setting: AppSettings.autoplayImages, ), SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.sendOnEnter, - onChanged: (b) => AppConfig.sendOnEnter = b, - storeKey: SettingKeys.sendOnEnter, - defaultValue: AppConfig.sendOnEnter ?? !PlatformInfos.isMobile, + title: L10n.of(context).sendOnEnter, + setting: AppSettings.sendOnEnter, ), SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.swipeRightToLeftToReply, - onChanged: (b) => AppConfig.swipeRightToLeftToReply = b, - storeKey: SettingKeys.swipeRightToLeftToReply, - defaultValue: AppConfig.swipeRightToLeftToReply, - ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, + title: L10n.of(context).swipeRightToLeftToReply, + setting: AppSettings.swipeRightToLeftToReply, ), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.customEmojisAndStickers, + L10n.of(context).customEmojisAndStickers, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), ListTile( - title: Text(L10n.of(context)!.customEmojisAndStickers), - subtitle: Text(L10n.of(context)!.customEmojisAndStickersBody), + title: Text(L10n.of(context).customEmojisAndStickers), + subtitle: Text(L10n.of(context).customEmojisAndStickersBody), onTap: () => context.go('/rooms/settings/chat/emotes'), trailing: const Padding( padding: EdgeInsets.all(16.0), child: Icon(Icons.chevron_right_outlined), ), ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, - ), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.calls, + L10n.of(context).calls, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.experimentalVideoCalls, + title: L10n.of(context).experimentalVideoCalls, onChanged: (b) { - AppConfig.experimentalVoip = b; Matrix.of(context).createVoipPlugin(); return; }, - storeKey: SettingKeys.experimentalVoip, - defaultValue: AppConfig.experimentalVoip, + setting: AppSettings.experimentalVoip, ), - if (PlatformInfos.isMobile) - ListTile( - title: Text(L10n.of(context)!.callingPermissions), - onTap: () => - CallKeepManager().checkoutPhoneAccountSetting(context), - trailing: const Padding( - padding: EdgeInsets.all(16.0), - child: Icon(Icons.call), - ), - ), ], ), ), diff --git a/lib/pages/settings_emotes/import_archive_dialog.dart b/lib/pages/settings_emotes/import_archive_dialog.dart index 0ed5bb21f..46bca4d3a 100644 --- a/lib/pages/settings_emotes/import_archive_dialog.dart +++ b/lib/pages/settings_emotes/import_archive_dialog.dart @@ -3,14 +3,14 @@ import 'dart:async'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; import 'package:archive/archive.dart'; import 'package:collection/collection.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/settings_emotes/settings_emotes.dart'; import 'package:fluffychat/utils/client_manager.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; class ImportEmoteArchiveDialog extends StatefulWidget { @@ -44,13 +44,9 @@ class _ImportEmoteArchiveDialogState extends State { @override Widget build(BuildContext context) { return AlertDialog( - title: Text(L10n.of(context)!.importEmojis), + title: Text(L10n.of(context).importEmojis), content: _loading - ? Center( - child: CircularProgressIndicator( - value: _progress, - ), - ) + ? Center(child: CircularProgressIndicator(value: _progress)) : SingleChildScrollView( child: Wrap( alignment: WrapAlignment.spaceEvenly, @@ -73,15 +69,15 @@ class _ImportEmoteArchiveDialogState extends State { actions: [ TextButton( onPressed: _loading ? null : Navigator.of(context).pop, - child: Text(L10n.of(context)!.cancel), + child: Text(L10n.of(context).cancel), ), TextButton( onPressed: _loading ? null : _importMap.isNotEmpty - ? _addEmotePack - : null, - child: Text(L10n.of(context)!.importNow), + ? _addEmotePack + : null, + child: Text(L10n.of(context).importNow), ), ], ); @@ -91,12 +87,8 @@ class _ImportEmoteArchiveDialogState extends State { _importMap = Map.fromEntries( widget.archive.files .where((e) => e.isFile) - .map( - (e) => MapEntry(e, e.name.emoteNameFromPath), - ) - .sorted( - (a, b) => a.value.compareTo(b.value), - ), + .map((e) => MapEntry(e, e.name.emoteNameFromPath)) + .sorted((a, b) => a.value.compareTo(b.value)), ); } @@ -121,10 +113,10 @@ class _ImportEmoteArchiveDialogState extends State { final result = await showOkCancelAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.emoteExists, + title: L10n.of(context).emoteExists, message: imageCode, - cancelLabel: L10n.of(context)!.replace, - okLabel: L10n.of(context)!.skip, + cancelLabel: L10n.of(context).replace, + okLabel: L10n.of(context).skip, ); completer.complete(result); }); @@ -148,10 +140,7 @@ class _ImportEmoteArchiveDialogState extends State { final imageCode = entry.value; try { - var mxcFile = MatrixImageFile( - bytes: file.content, - name: file.name, - ); + var mxcFile = MatrixImageFile(bytes: file.content, name: file.name); final thumbnail = (await mxcFile.generateThumbnail( nativeImplementations: ClientManager.nativeImplementations, @@ -162,14 +151,12 @@ class _ImportEmoteArchiveDialogState extends State { mxcFile = thumbnail; } final uri = await Matrix.of(context).client.uploadContent( - mxcFile.bytes, - filename: mxcFile.name, - contentType: mxcFile.mimeType, - ); + mxcFile.bytes, + filename: mxcFile.name, + contentType: mxcFile.mimeType, + ); - final info = { - ...mxcFile.info, - }; + final info = {...mxcFile.info}; // normalize width / height to 256, required for stickers if (info['w'] is int && info['h'] is int) { @@ -184,9 +171,9 @@ class _ImportEmoteArchiveDialogState extends State { } widget.controller.pack!.images[imageCode] = ImagePackImageContent.fromJson({ - 'url': uri.toString(), - 'info': info, - }); + 'url': uri.toString(), + 'info': info, + }); successfulUploads.add(file.name); } catch (e) { Logs().d('Could not upload emote $imageCode'); @@ -204,8 +191,9 @@ class _ImportEmoteArchiveDialogState extends State { // in case we have unhandled / duplicated emotes left, don't pop if (mounted) setState(() {}); if (_importMap.isEmpty) { - WidgetsBinding.instance - .addPostFrameCallback((_) => Navigator.of(context).pop()); + WidgetsBinding.instance.addPostFrameCallback( + (_) => Navigator.of(context).pop(), + ); } } } @@ -231,6 +219,8 @@ class _EmojiImportPreviewState extends State<_EmojiImportPreview> { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + // TODO: support Lottie here as well ... final controller = TextEditingController(text: widget.entry.value); @@ -240,7 +230,7 @@ class _EmojiImportPreviewState extends State<_EmojiImportPreview> { IconButton( onPressed: widget.onRemove, icon: const Icon(Icons.remove_circle), - tooltip: L10n.of(context)!.remove, + tooltip: L10n.of(context).remove, ), ValueListenableBuilder( valueListenable: hasErrorNotifier, @@ -248,21 +238,20 @@ class _EmojiImportPreviewState extends State<_EmojiImportPreview> { if (hasError) return _ImageFileError(name: widget.entry.key.name); return Column( - mainAxisSize: MainAxisSize.min, - mainAxisAlignment: MainAxisAlignment.center, - crossAxisAlignment: CrossAxisAlignment.center, + mainAxisSize: .min, + mainAxisAlignment: .center, + crossAxisAlignment: .center, children: [ Image.memory( widget.entry.key.content, height: 64, width: 64, errorBuilder: (context, e, s) { - WidgetsBinding.instance - .addPostFrameCallback((_) => _setRenderError()); - - return _ImageFileError( - name: widget.entry.key.name, + WidgetsBinding.instance.addPostFrameCallback( + (_) => _setRenderError(), ); + + return _ImageFileError(name: widget.entry.key.name); }, ), SizedBox( @@ -276,16 +265,16 @@ class _EmojiImportPreviewState extends State<_EmojiImportPreview> { minLines: 1, maxLines: 1, decoration: InputDecoration( - hintText: L10n.of(context)!.emoteShortcode, + hintText: L10n.of(context).emoteShortcode, prefixText: ': ', suffixText: ':', border: const OutlineInputBorder(), prefixStyle: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), suffixStyle: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), @@ -301,7 +290,7 @@ class _EmojiImportPreviewState extends State<_EmojiImportPreview> { ); } - _setRenderError() { + void _setRenderError() { hasErrorNotifier.value = true; widget.onRemove.call(); } @@ -314,20 +303,22 @@ class _ImageFileError extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return SizedBox.square( dimension: 64, child: Tooltip( message: name, child: Column( - mainAxisAlignment: MainAxisAlignment.start, - mainAxisSize: MainAxisSize.min, - crossAxisAlignment: CrossAxisAlignment.center, + mainAxisAlignment: .start, + mainAxisSize: .min, + crossAxisAlignment: .center, children: [ const Icon(Icons.error), Text( - L10n.of(context)!.notAnImage, + L10n.of(context).notAnImage, textAlign: TextAlign.center, - style: Theme.of(context).textTheme.labelSmall, + style: theme.textTheme.labelSmall, ), ], ), @@ -343,8 +334,7 @@ extension on String { /// Used to compute emote name proposal based on file name String get emoteNameFromPath { // ... removing leading path - return split(RegExp(r'[/\\]')) - .last + return split(RegExp(r'[/\\]')).last // ... removing file extension .split('.') .first diff --git a/lib/pages/settings_emotes/settings_emotes.dart b/lib/pages/settings_emotes/settings_emotes.dart index 2ef905b17..8b8cb2f52 100644 --- a/lib/pages/settings_emotes/settings_emotes.dart +++ b/lib/pages/settings_emotes/settings_emotes.dart @@ -3,18 +3,17 @@ import 'dart:async'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:collection/collection.dart'; import 'package:file_picker/file_picker.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:go_router/go_router.dart'; import 'package:http/http.dart' hide Client; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/client_manager.dart'; +import 'package:fluffychat/utils/file_selector.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_file_extension.dart'; -import 'package:fluffychat/widgets/app_lock.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import '../../widgets/matrix.dart'; import 'import_archive_dialog.dart'; import 'settings_emotes_view.dart'; @@ -23,34 +22,58 @@ import 'package:archive/archive.dart' if (dart.library.io) 'package:archive/archive_io.dart'; class EmotesSettings extends StatefulWidget { - const EmotesSettings({super.key}); + final String? roomId; + const EmotesSettings({required this.roomId, super.key}); @override EmotesSettingsController createState() => EmotesSettingsController(); } class EmotesSettingsController extends State { - String? get roomId => GoRouterState.of(context).pathParameters['roomid']; + late final Room? room; - Room? get room => - roomId != null ? Matrix.of(context).client.getRoomById(roomId!) : null; + String? stateKey; - String? get stateKey => GoRouterState.of(context).pathParameters['state_key']; + List? get packKeys { + final room = this.room; + if (room == null) return null; + final keys = room.states['im.ponies.room_emotes']?.keys.toList() ?? []; + keys.sort(); + return keys; + } + + @override + void initState() { + super.initState(); + room = widget.roomId != null + ? Matrix.of(context).client.getRoomById(widget.roomId!) + : null; + setStateKey(packKeys?.firstOrNull, reset: false); + } + + void setStateKey(String? key, {reset = true}) { + stateKey = key; + + final event = key == null + ? null + : room?.getState('im.ponies.room_emotes', key); + final eventPack = event?.content.tryGetMap('pack'); + packDisplayNameController.text = + eventPack?.tryGet('display_name') ?? ''; + packAttributionController.text = + eventPack?.tryGet('attribution') ?? ''; + if (reset) resetAction(); + } bool showSave = false; - TextEditingController newImageCodeController = TextEditingController(); - ValueNotifier newImageController = - ValueNotifier(null); ImagePackContent _getPack() { final client = Matrix.of(context).client; - final event = (room != null + final event = + (room != null ? room!.getState('im.ponies.room_emotes', stateKey ?? '') : client.accountData['im.ponies.user_emotes']) ?? - BasicEvent( - type: 'm.dummy', - content: {}, - ); + BasicEvent(type: 'm.dummy', content: {}); // make sure we work on a *copy* of the event return BasicEvent.fromJson(event.toJson()).parsedImagePackContent; } @@ -70,25 +93,25 @@ class EmotesSettingsController extends State { return; } final client = Matrix.of(context).client; - if (room != null) { - await showFutureLoadingDialog( - context: context, - future: () => client.setRoomStateWithKey( - room!.id, - 'im.ponies.room_emotes', - stateKey ?? '', - pack!.toJson(), - ), - ); - } else { - await showFutureLoadingDialog( - context: context, - future: () => client.setAccountData( - client.userID!, - 'im.ponies.user_emotes', - pack!.toJson(), - ), - ); + final result = await showFutureLoadingDialog( + context: context, + future: () => room != null + ? client.setRoomStateWithKey( + room!.id, + 'im.ponies.room_emotes', + stateKey ?? '', + pack!.toJson(), + ) + : client.setAccountData( + client.userID!, + 'im.ponies.user_emotes', + pack!.toJson(), + ), + ); + if (!result.isError) { + setState(() { + showSave = false; + }); } } @@ -97,7 +120,8 @@ class EmotesSettingsController extends State { return; } final client = Matrix.of(context).client; - final content = client.accountData['im.ponies.emote_rooms']?.content ?? + final content = + client.accountData['im.ponies.emote_rooms']?.content ?? {}; if (active) { if (content['rooms'] is! Map) { @@ -124,24 +148,64 @@ class EmotesSettingsController extends State { setState(() {}); } + final TextEditingController packDisplayNameController = + TextEditingController(); + + final TextEditingController packAttributionController = + TextEditingController(); + void removeImageAction(String oldImageCode) => setState(() { - pack!.images.remove(oldImageCode); - showSave = true; - }); + pack!.images.remove(oldImageCode); + showSave = true; + }); + + void toggleUsage(String imageCode, ImagePackUsage usage) { + setState(() { + final usages = pack!.images[imageCode]!.usage ??= List.from( + ImagePackUsage.values, + ); + if (!usages.remove(usage)) usages.add(usage); + showSave = true; + }); + } + + void submitDisplaynameAction() { + if (readonly) return; + packDisplayNameController.text = packDisplayNameController.text.trim(); + final input = packDisplayNameController.text; + + setState(() { + pack!.pack.displayName = input; + showSave = true; + }); + } + + void submitAttributionAction() { + if (readonly) return; + packAttributionController.text = packAttributionController.text.trim(); + final input = packAttributionController.text; + + setState(() { + pack!.pack.attribution = input; + showSave = true; + }); + } void submitImageAction( String oldImageCode, - String imageCode, ImagePackImageContent image, TextEditingController controller, ) { + controller.text = controller.text.trim().replaceAll(' ', '-'); + final imageCode = controller.text; + if (imageCode == oldImageCode) return; if (pack!.images.keys.any((k) => k == imageCode && k != oldImageCode)) { controller.text = oldImageCode; showOkAlertDialog( useRootNavigator: false, context: context, - message: L10n.of(context)!.emoteExists, - okLabel: L10n.of(context)!.ok, + title: L10n.of(context).emoteExists, + okLabel: L10n.of(context).ok, ); return; } @@ -150,8 +214,8 @@ class EmotesSettingsController extends State { showOkAlertDialog( useRootNavigator: false, context: context, - message: L10n.of(context)!.emoteInvalid, - okLabel: L10n.of(context)!.ok, + title: L10n.of(context).emoteInvalid, + okLabel: L10n.of(context).ok, ); return; } @@ -171,106 +235,119 @@ class EmotesSettingsController extends State { null; bool get readonly => - room == null ? false : !(room!.canSendEvent('im.ponies.room_emotes')); + room != null && + room?.canChangeStateEvent('im.ponies.room_emotes') == false; - void saveAction() async { - await save(context); + void resetAction() { setState(() { + _pack = _getPack(); showSave = false; }); } - void addImageAction() async { - if (newImageCodeController.text.isEmpty || - newImageController.value == null) { - await showOkAlertDialog( - useRootNavigator: false, - context: context, - message: L10n.of(context)!.emoteWarnNeedToPick, - okLabel: L10n.of(context)!.ok, - ); - return; - } - final imageCode = newImageCodeController.text; - if (pack!.images.containsKey(imageCode)) { - await showOkAlertDialog( - useRootNavigator: false, - context: context, - message: L10n.of(context)!.emoteExists, - okLabel: L10n.of(context)!.ok, - ); - return; - } - if (!RegExp(r'^[-\w]+$').hasMatch(imageCode)) { - await showOkAlertDialog( - useRootNavigator: false, - context: context, - message: L10n.of(context)!.emoteInvalid, - okLabel: L10n.of(context)!.ok, - ); - return; - } - pack!.images[imageCode] = newImageController.value!; - await save(context); - setState(() { - newImageCodeController.text = ''; - newImageController.value = null; - showSave = false; - }); - } + Future createImagePack() async { + final room = this.room; + if (room == null) throw Exception('Cannot create image pack without room'); - void imagePickerAction( - ValueNotifier controller, - ) async { - final result = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles( - type: FileType.image, - withData: true, + final input = await showTextInputDialog( + context: context, + title: L10n.of(context).newStickerPack, + hintText: L10n.of(context).name, + okLabel: L10n.of(context).create, + ); + final name = input?.trim(); + if (name == null || name.isEmpty) return; + if (!mounted) return; + + final keyName = name.toLowerCase().replaceAll(' ', '_'); + + if (packKeys?.contains(name) ?? false) { + ScaffoldMessenger.of(context).showSnackBar( + SnackBar(content: Text(L10n.of(context).stickerPackNameAlreadyExists)), + ); + return; + } + + await showFutureLoadingDialog( + context: context, + future: () => room.client.setRoomStateWithKey( + room.id, + 'im.ponies.room_emotes', + keyName, + { + 'images': {}, + 'pack': {'display_name': name}, + }, ), ); - final pickedFile = result?.files.firstOrNull; - if (pickedFile == null) return; - var file = MatrixImageFile( - bytes: pickedFile.bytes!, - name: pickedFile.name, + if (!mounted) return; + setState(() {}); + await room.client.oneShotSync(); + if (!mounted) return; + setState(() {}); + } + + Future saveAction() async { + await save(context); + setState(() { + showSave = false; + }); + } + + Future createStickers() async { + final pickedFiles = await selectFiles( + context, + type: FileType.image, + allowMultiple: true, ); - try { - file = (await file.generateThumbnail( - nativeImplementations: ClientManager.nativeImplementations, - ))!; - } catch (e, s) { - Logs().w('Unable to create thumbnail', e, s); - } - final uploadResp = await showFutureLoadingDialog( + if (pickedFiles.isEmpty) return; + if (!mounted) return; + + await showFutureLoadingDialog( context: context, - future: () => Matrix.of(context).client.uploadContent( + futureWithProgress: (setProgress) async { + for (final (i, pickedFile) in pickedFiles.indexed) { + setProgress(i / pickedFiles.length); + var file = MatrixImageFile( + bytes: await pickedFile.readAsBytes(), + name: pickedFile.name, + ); + file = + await file.generateThumbnail( + nativeImplementations: ClientManager.nativeImplementations, + ) ?? + file; + final uri = await Matrix.of(context).client.uploadContent( file.bytes, filename: file.name, contentType: file.mimeType, - ), - ); - if (uploadResp.error == null) { - setState(() { - final info = { - ...file.info, - }; - // normalize width / height to 256, required for stickers - if (info['w'] is int && info['h'] is int) { - final ratio = info['w'] / info['h']; - if (info['w'] > info['h']) { - info['w'] = 256; - info['h'] = (256.0 / ratio).round(); - } else { - info['h'] = 256; - info['w'] = (ratio * 256.0).round(); - } + ); + + setState(() { + final info = {...file.info}; + // normalize width / height to 256, required for stickers + if (info['w'] is int && info['h'] is int) { + final ratio = info['w'] / info['h']; + if (info['w'] > info['h']) { + info['w'] = 256; + info['h'] = (256.0 / ratio).round(); + } else { + info['h'] = 256; + info['w'] = (ratio * 256.0).round(); + } + } + final imageCode = pickedFile.name.split('.').first; + pack!.images[imageCode] = ImagePackImageContent.fromJson( + {'url': uri.toString(), 'info': info}, + ); + }); } - controller.value = ImagePackImageContent.fromJson({ - 'url': uploadResp.result.toString(), - 'info': info, - }); - }); - } + }, + ); + + setState(() { + showSave = true; + }); } @override @@ -279,42 +356,20 @@ class EmotesSettingsController extends State { } Future importEmojiZip() async { - final result = await showFutureLoadingDialog( - context: context, - future: () async { - final result = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles( - type: FileType.custom, - allowedExtensions: [ - 'zip', - // TODO: add further encoders - ], - // TODO: migrate to stream, currently brrrr because of `archive_io`. - withData: true, - ), - ); + final result = await selectFiles(context, type: FileType.any); - if (result == null) return null; + if (result.isEmpty) return; - final buffer = InputStream(result.files.single.bytes); + final buffer = InputMemoryStream(await result.single.readAsBytes()); - final archive = ZipDecoder().decodeBuffer(buffer); - - return archive; - }, - ); - - final archive = result.result; - if (archive == null) return; + final archive = ZipDecoder().decodeStream(buffer); await showDialog( context: context, // breaks [Matrix.of] calls otherwise useRootNavigator: false, - builder: (context) => ImportEmoteArchiveDialog( - controller: this, - archive: archive, - ), + builder: (context) => + ImportEmoteArchiveDialog(controller: this, archive: archive), ); setState(() {}); } @@ -330,23 +385,20 @@ class EmotesSettingsController extends State { for (final entry in pack.images.entries) { final emote = entry.value; final name = entry.key; - final url = emote.url.getDownloadLink(client); - final response = await get(url); + final url = await emote.url.getDownloadUri(client); + final response = await get( + url, + headers: {'authorization': 'Bearer ${client.accessToken}'}, + ); archive.addFile( - ArchiveFile( - name, - response.bodyBytes.length, - response.bodyBytes, - ), + ArchiveFile(name, response.bodyBytes.length, response.bodyBytes), ); } final fileName = '${pack.pack.displayName ?? client.userID?.localpart ?? 'emotes'}.zip'; final output = ZipEncoder().encode(archive); - if (output == null) return; - MatrixFile( name: fileName, bytes: Uint8List.fromList(output), diff --git a/lib/pages/settings_emotes/settings_emotes_view.dart b/lib/pages/settings_emotes/settings_emotes_view.dart index 7e72cd464..a5baf3979 100644 --- a/lib/pages/settings_emotes/settings_emotes_view.dart +++ b/lib/pages/settings_emotes/settings_emotes_view.dart @@ -1,12 +1,14 @@ import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'package:fluffychat/widgets/mxc_image.dart'; +import 'package:fluffychat/widgets/mxc_image_viewer.dart'; import '../../widgets/matrix.dart'; import 'settings_emotes.dart'; @@ -19,111 +21,201 @@ class EmotesSettingsView extends StatelessWidget { @override Widget build(BuildContext context) { + if (controller.widget.roomId != null && controller.room == null) { + return Scaffold( + appBar: AppBar(title: Text(L10n.of(context).oopsSomethingWentWrong)), + body: Center( + child: Text(L10n.of(context).youAreNoLongerParticipatingInThisChat), + ), + ); + } + final theme = Theme.of(context); + final client = Matrix.of(context).client; final imageKeys = controller.pack!.images.keys.toList(); + final packKeys = controller.packKeys; + if (packKeys != null && packKeys.isEmpty) { + packKeys.add(''); + } + final attributionUrl = Uri.tryParse( + controller.packAttributionController.text, + ); + return Scaffold( appBar: AppBar( - leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.customEmojisAndStickers), + automaticallyImplyLeading: !controller.showSave, + title: controller.showSave + ? TextButton( + onPressed: controller.resetAction, + child: Text(L10n.of(context).cancel), + ) + : Text(L10n.of(context).customEmojisAndStickers), actions: [ - PopupMenuButton( - onSelected: (value) { - switch (value) { - case PopupMenuEmojiActions.export: - controller.exportAsZip(); - break; - case PopupMenuEmojiActions.import: - controller.importEmojiZip(); - break; - } - }, - enabled: !controller.readonly, - itemBuilder: (context) => [ - PopupMenuItem( - value: PopupMenuEmojiActions.import, - child: Text(L10n.of(context)!.importFromZipFile), + if (controller.showSave) + ElevatedButton( + onPressed: () => controller.save(context), + style: ElevatedButton.styleFrom( + backgroundColor: theme.colorScheme.primary, + foregroundColor: theme.colorScheme.onPrimary, ), - PopupMenuItem( - value: PopupMenuEmojiActions.export, - child: Text(L10n.of(context)!.exportEmotePack), - ), - ], - ), - ], - ), - floatingActionButton: controller.showSave - ? FloatingActionButton( - onPressed: controller.saveAction, - child: const Icon(Icons.save_outlined, color: Colors.white), + child: Text(L10n.of(context).saveChanges), ) - : null, + else + PopupMenuButton( + useRootNavigator: true, + onSelected: (value) { + switch (value) { + case PopupMenuEmojiActions.export: + controller.exportAsZip(); + break; + case PopupMenuEmojiActions.import: + controller.importEmojiZip(); + break; + } + }, + itemBuilder: (context) => [ + if (!controller.readonly) + PopupMenuItem( + value: PopupMenuEmojiActions.import, + child: Text(L10n.of(context).importFromZipFile), + ), + if (imageKeys.isNotEmpty) + PopupMenuItem( + value: PopupMenuEmojiActions.export, + child: Text(L10n.of(context).exportEmotePack), + ), + ], + ), + ], + bottom: packKeys == null + ? null + : PreferredSize( + preferredSize: const Size.fromHeight(48), + child: Padding( + padding: const EdgeInsets.all(4.0), + child: SizedBox( + height: 40, + child: ListView.builder( + scrollDirection: Axis.horizontal, + itemCount: packKeys.length + 1, + itemBuilder: (context, i) { + if (i == 0) { + if (controller.readonly) { + return const SizedBox.shrink(); + } + return Padding( + padding: const EdgeInsets.symmetric( + horizontal: 4.0, + ), + child: FilterChip( + label: const Icon(Icons.add_outlined, size: 20), + onSelected: controller.showSave + ? null + : (_) => controller.createImagePack(), + ), + ); + } + i--; + final key = packKeys[i]; + final event = controller.room?.getState( + 'im.ponies.room_emotes', + packKeys[i], + ); + + final eventPack = event?.content + .tryGetMap('pack'); + final packName = + eventPack?.tryGet('display_name') ?? + eventPack?.tryGet('name') ?? + (key.isNotEmpty ? key : 'Default'); + + return Padding( + padding: const EdgeInsets.symmetric(horizontal: 4.0), + child: FilterChip( + label: Text(packName), + selected: + controller.stateKey == key || + (controller.stateKey == null && key.isEmpty), + onSelected: controller.showSave + ? null + : (_) => controller.setStateKey(key), + ), + ); + }, + ), + ), + ), + ), + ), body: MaxWidthBody( child: Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, + crossAxisAlignment: .stretch, children: [ - if (!controller.readonly) - Container( - padding: const EdgeInsets.symmetric( - vertical: 8.0, - ), - child: ListTile( - leading: Container( - width: 180.0, - height: 38, - padding: const EdgeInsets.symmetric(horizontal: 8), - decoration: BoxDecoration( - borderRadius: const BorderRadius.all(Radius.circular(10)), - color: Theme.of(context).secondaryHeaderColor, - ), - child: TextField( - controller: controller.newImageCodeController, - autocorrect: false, - minLines: 1, - maxLines: 1, - decoration: InputDecoration( - hintText: L10n.of(context)!.emoteShortcode, - prefixText: ': ', - suffixText: ':', - prefixStyle: TextStyle( - color: Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, - ), - suffixStyle: TextStyle( - color: Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, - ), - border: InputBorder.none, - ), - ), - ), - title: _ImagePicker( - controller: controller.newImageController, - onPressed: controller.imagePickerAction, - ), - trailing: InkWell( - onTap: controller.addImageAction, - child: const Icon( - Icons.add_outlined, - color: Colors.green, - size: 32.0, - ), + if (controller.room != null) ...[ + const SizedBox(height: 16), + Padding( + padding: const EdgeInsets.symmetric(horizontal: 16.0), + child: TextField( + maxLength: 256, + controller: controller.packDisplayNameController, + readOnly: controller.readonly, + onSubmitted: (_) => controller.submitDisplaynameAction(), + decoration: InputDecoration( + counter: const SizedBox.shrink(), + hintText: controller.stateKey, + labelText: L10n.of(context).stickerPackName, ), ), ), - if (controller.room != null) + const SizedBox(height: 8), + Padding( + padding: const EdgeInsets.symmetric(horizontal: 16.0), + child: TextField( + maxLength: 256, + controller: controller.packAttributionController, + readOnly: controller.readonly, + keyboardType: TextInputType.url, + onSubmitted: (_) => controller.submitAttributionAction(), + decoration: InputDecoration( + counter: const SizedBox.shrink(), + labelText: L10n.of(context).attribution, + suffixIcon: attributionUrl == null + ? null + : IconButton( + icon: const Icon(Icons.link_outlined), + onPressed: () => UrlLauncher( + context, + attributionUrl.toString(), + ).launchUrl(), + ), + ), + ), + ), + ], + if (!controller.readonly) ...[ + Padding( + padding: const EdgeInsets.all(16.0), + child: ElevatedButton.icon( + onPressed: controller.createStickers, + icon: const Icon(Icons.upload_outlined), + label: Text(L10n.of(context).createSticker), + ), + ), + const Divider(), + ], + if (controller.room != null && imageKeys.isNotEmpty) SwitchListTile.adaptive( - title: Text(L10n.of(context)!.enableEmotesGlobally), + title: Text(L10n.of(context).enableEmotesGlobally), value: controller.isGloballyActive(client), onChanged: controller.setIsGloballyActive, ), - if (!controller.readonly || controller.room != null) - const Divider(thickness: 1), imageKeys.isEmpty ? Center( child: Padding( padding: const EdgeInsets.all(16), child: Text( - L10n.of(context)!.noEmotesFound, + L10n.of(context).noEmotesFound, style: const TextStyle(fontSize: 20), ), ), @@ -133,11 +225,8 @@ class EmotesSettingsView extends StatelessWidget { physics: const NeverScrollableScrollPhysics(), separatorBuilder: (BuildContext context, int i) => const SizedBox.shrink(), - itemCount: imageKeys.length + 1, + itemCount: imageKeys.length, itemBuilder: (BuildContext context, int i) { - if (i >= imageKeys.length) { - return Container(height: 70); - } final imageCode = imageKeys[i]; final image = controller.pack!.images[imageCode]!; final textEditingController = TextEditingController(); @@ -145,82 +234,108 @@ class EmotesSettingsView extends StatelessWidget { final useShortCuts = (PlatformInfos.isWeb || PlatformInfos.isDesktop); return ListTile( - leading: Container( - width: 180.0, - height: 38, - padding: const EdgeInsets.symmetric(horizontal: 8), - decoration: BoxDecoration( - borderRadius: - const BorderRadius.all(Radius.circular(10)), - color: Theme.of(context).secondaryHeaderColor, - ), - child: Shortcuts( - shortcuts: !useShortCuts - ? {} - : { - LogicalKeySet(LogicalKeyboardKey.enter): - SubmitLineIntent(), - }, - child: Actions( - actions: !useShortCuts - ? {} - : { - SubmitLineIntent: CallbackAction( - onInvoke: (i) { - controller.submitImageAction( - imageCode, - textEditingController.text, - image, - textEditingController, - ); - return null; + title: Row( + children: [ + Expanded( + child: Shortcuts( + shortcuts: !useShortCuts + ? {} + : { + LogicalKeySet(LogicalKeyboardKey.enter): + SubmitLineIntent(), + }, + child: Actions( + actions: !useShortCuts + ? {} + : { + SubmitLineIntent: CallbackAction( + onInvoke: (i) { + controller.submitImageAction( + imageCode, + image, + textEditingController, + ); + return null; + }, + ), }, + child: TextField( + readOnly: controller.readonly, + controller: textEditingController, + autocorrect: false, + minLines: 1, + maxLines: 1, + maxLength: 128, + decoration: InputDecoration( + hintText: L10n.of(context).emoteShortcode, + prefixText: ': ', + suffixText: ':', + counter: const SizedBox.shrink(), + filled: false, + enabledBorder: const OutlineInputBorder( + borderSide: BorderSide( + color: Colors.transparent, + ), ), - }, - child: TextField( - readOnly: controller.readonly, - controller: textEditingController, - autocorrect: false, - minLines: 1, - maxLines: 1, - decoration: InputDecoration( - hintText: L10n.of(context)!.emoteShortcode, - prefixText: ': ', - suffixText: ':', - prefixStyle: TextStyle( - color: - Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, + ), + onSubmitted: (s) => + controller.submitImageAction( + imageCode, + image, + textEditingController, + ), ), - suffixStyle: TextStyle( - color: - Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, - ), - border: InputBorder.none, - ), - onSubmitted: (s) => - controller.submitImageAction( - imageCode, - s, - image, - textEditingController, ), ), ), - ), + if (!controller.readonly) + PopupMenuButton( + onSelected: (usage) => + controller.toggleUsage(imageCode, usage), + itemBuilder: (context) => [ + PopupMenuItem( + value: ImagePackUsage.sticker, + child: Row( + mainAxisSize: .min, + children: [ + if (image.usage?.contains( + ImagePackUsage.sticker, + ) ?? + true) + const Icon(Icons.check_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).useAsSticker), + ], + ), + ), + PopupMenuItem( + value: ImagePackUsage.emoticon, + child: Row( + mainAxisSize: .min, + children: [ + if (image.usage?.contains( + ImagePackUsage.emoticon, + ) ?? + true) + const Icon(Icons.check_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).useAsEmoji), + ], + ), + ), + ], + icon: const Icon(Icons.edit_outlined), + ), + ], ), - title: _EmoteImage(image.url), + leading: _EmoteImage(image.url), trailing: controller.readonly ? null - : InkWell( - onTap: () => + : IconButton( + tooltip: L10n.of(context).delete, + onPressed: () => controller.removeImageAction(imageCode), - child: const Icon( - Icons.delete_outlined, - color: Colors.red, - size: 32.0, - ), + icon: const Icon(Icons.delete_outlined), ), ); }, @@ -239,42 +354,24 @@ class _EmoteImage extends StatelessWidget { @override Widget build(BuildContext context) { - const size = 38.0; - return SizedBox.square( - dimension: size, + const size = 44.0; + final key = 'sticker_preview_$mxc'; + return InkWell( + borderRadius: BorderRadius.circular(4), + onTap: () => + showDialog(context: context, builder: (_) => MxcImageViewer(mxc)), child: MxcImage( + key: ValueKey(key), + cacheKey: key, uri: mxc, fit: BoxFit.contain, width: size, height: size, + isThumbnail: true, + animated: true, ), ); } } -class _ImagePicker extends StatefulWidget { - final ValueNotifier controller; - - final void Function(ValueNotifier) onPressed; - - const _ImagePicker({required this.controller, required this.onPressed}); - - @override - _ImagePickerState createState() => _ImagePickerState(); -} - -class _ImagePickerState extends State<_ImagePicker> { - @override - Widget build(BuildContext context) { - if (widget.controller.value == null) { - return ElevatedButton( - onPressed: () => widget.onPressed(widget.controller), - child: Text(L10n.of(context)!.pickImage), - ); - } else { - return _EmoteImage(widget.controller.value!.url); - } - } -} - class SubmitLineIntent extends Intent {} diff --git a/lib/pages/settings_homeserver/settings_homeserver.dart b/lib/pages/settings_homeserver/settings_homeserver.dart new file mode 100644 index 000000000..13843336d --- /dev/null +++ b/lib/pages/settings_homeserver/settings_homeserver.dart @@ -0,0 +1,53 @@ +import 'dart:convert'; + +import 'package:flutter/material.dart'; + +import 'package:http/http.dart' as http; +import 'package:matrix/matrix.dart'; + +import '../../widgets/matrix.dart'; +import 'settings_homeserver_view.dart'; + +class SettingsHomeserver extends StatefulWidget { + const SettingsHomeserver({super.key}); + + @override + SettingsHomeserverController createState() => SettingsHomeserverController(); +} + +class SettingsHomeserverController extends State { + Future<({String name, String version, Uri federationBaseUrl})> + fetchServerInfo() async { + final client = Matrix.of(context).client; + final domain = client.userID!.domain!; + final httpClient = client.httpClient; + var federationBaseUrl = Uri(host: domain, port: 8448, scheme: 'https'); + try { + final serverWellKnownResult = await httpClient.get( + Uri.https(domain, '/.well-known/matrix/server'), + ); + final serverWellKnown = jsonDecode(serverWellKnownResult.body); + federationBaseUrl = Uri.https(serverWellKnown['m.server']); + } catch (e, s) { + Logs().w( + 'Unable to fetch federation base uri. Use $federationBaseUrl', + e, + s, + ); + } + + final serverVersionResult = await http.get( + federationBaseUrl.resolveUri(Uri(path: '/_matrix/federation/v1/version')), + ); + final { + 'server': {'name': String name, 'version': String version}, + } = Map>.from( + jsonDecode(serverVersionResult.body), + ); + + return (name: name, version: version, federationBaseUrl: federationBaseUrl); + } + + @override + Widget build(BuildContext context) => SettingsHomeserverView(this); +} diff --git a/lib/pages/settings_homeserver/settings_homeserver_view.dart b/lib/pages/settings_homeserver/settings_homeserver_view.dart new file mode 100644 index 000000000..195c1701e --- /dev/null +++ b/lib/pages/settings_homeserver/settings_homeserver_view.dart @@ -0,0 +1,294 @@ +import 'dart:convert'; + +import 'package:flutter/material.dart'; + +import 'package:flutter_linkify/flutter_linkify.dart'; +import 'package:matrix/matrix.dart'; +import 'package:url_launcher/url_launcher_string.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/widgets/layouts/max_width_body.dart'; +import '../../widgets/matrix.dart'; +import 'settings_homeserver.dart'; + +class SettingsHomeserverView extends StatelessWidget { + final SettingsHomeserverController controller; + + const SettingsHomeserverView(this.controller, {super.key}); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + + final client = Matrix.of(context).client; + + return Scaffold( + appBar: AppBar( + automaticallyImplyLeading: !FluffyThemes.isColumnMode(context), + centerTitle: FluffyThemes.isColumnMode(context), + title: Text( + L10n.of( + context, + ).aboutHomeserver(client.userID?.domain ?? 'Homeserver'), + ), + ), + body: MaxWidthBody( + withScrolling: true, + child: SelectionArea( + child: Column( + mainAxisSize: .min, + children: [ + ListTile( + title: Text( + L10n.of(context).serverInformation, + style: TextStyle( + color: theme.colorScheme.secondary, + fontWeight: FontWeight.bold, + ), + ), + ), + FutureBuilder( + future: client.getWellknownSupport(), + builder: (context, snapshot) { + final error = snapshot.error; + final data = snapshot.data; + if (error != null) { + return ListTile( + leading: const Icon(Icons.error_outlined), + title: Text( + error.toLocalizedString( + context, + ExceptionContext.checkServerSupportInfo, + ), + style: const TextStyle(fontSize: 14), + ), + ); + } + if (data == null) { + return const Center( + child: CircularProgressIndicator.adaptive(strokeWidth: 2), + ); + } + final supportPage = data.supportPage; + final contacts = data.contacts; + if (supportPage == null && contacts == null) { + return ListTile( + leading: const Icon(Icons.error_outlined), + title: Text( + L10n.of(context).noContactInformationProvided, + style: const TextStyle(fontSize: 14), + ), + ); + } + return Column( + mainAxisSize: .min, + children: [ + if (supportPage != null) + ListTile( + title: Text(L10n.of(context).supportPage), + subtitle: Text(supportPage.toString()), + ), + if (contacts != null) + ...contacts.map((contact) { + return ListTile( + title: Text( + contact.role.localizedString(L10n.of(context)), + ), + subtitle: Column( + mainAxisSize: .min, + children: [ + if (contact.emailAddress != null) + TextButton( + onPressed: () {}, + child: Text(contact.emailAddress!), + ), + if (contact.matrixId != null) + TextButton( + onPressed: () {}, + child: Text(contact.matrixId!), + ), + ], + ), + ); + }), + ], + ); + }, + ), + FutureBuilder( + future: controller.fetchServerInfo(), + builder: (context, snapshot) { + final error = snapshot.error; + if (error != null) { + return Column( + mainAxisAlignment: .center, + children: [ + Icon( + Icons.error_outlined, + color: theme.colorScheme.error, + ), + const SizedBox(height: 12), + Text( + error.toLocalizedString(context), + textAlign: TextAlign.center, + style: TextStyle(color: theme.colorScheme.error), + ), + ], + ); + } + final data = snapshot.data; + if (data == null) { + return const Center( + child: CircularProgressIndicator.adaptive(strokeWidth: 2), + ); + } + return Column( + mainAxisSize: .min, + children: [ + ListTile( + title: Text(L10n.of(context).name), + subtitle: Text(data.name), + ), + ListTile( + title: Text(L10n.of(context).version), + subtitle: Text(data.version), + ), + ListTile( + title: Text(L10n.of(context).federationBaseUrl), + subtitle: Linkify( + text: data.federationBaseUrl.toString(), + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: theme.colorScheme.primary, + decorationColor: theme.colorScheme.primary, + ), + onOpen: (link) => launchUrlString(link.url), + ), + ), + ], + ); + }, + ), + Divider(color: theme.dividerColor), + FutureBuilder( + future: client.getWellknown(), + builder: (context, snapshot) { + final error = snapshot.error; + if (error != null) { + return Column( + mainAxisAlignment: .center, + children: [ + Icon( + Icons.error_outlined, + color: theme.colorScheme.error, + ), + const SizedBox(height: 12), + Text( + error.toLocalizedString(context), + textAlign: TextAlign.center, + style: TextStyle(color: theme.colorScheme.error), + ), + ], + ); + } + final wellKnown = snapshot.data; + if (wellKnown == null) { + return const Center( + child: CircularProgressIndicator.adaptive(strokeWidth: 2), + ); + } + final identityServer = wellKnown.mIdentityServer; + return Column( + mainAxisSize: .min, + children: [ + ListTile( + title: Text( + L10n.of(context).clientWellKnownInformation, + style: TextStyle( + color: theme.colorScheme.secondary, + fontWeight: FontWeight.bold, + ), + ), + ), + ListTile( + title: Text(L10n.of(context).baseUrl), + subtitle: Linkify( + text: wellKnown.mHomeserver.baseUrl.toString(), + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: theme.colorScheme.primary, + decorationColor: theme.colorScheme.primary, + ), + onOpen: (link) => launchUrlString(link.url), + ), + ), + if (identityServer != null) + ListTile( + title: Text(L10n.of(context).identityServer), + subtitle: Linkify( + text: identityServer.baseUrl.toString(), + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: theme.colorScheme.primary, + decorationColor: theme.colorScheme.primary, + ), + onOpen: (link) => launchUrlString(link.url), + ), + ), + ...wellKnown.additionalProperties.entries.map( + (entry) => ListTile( + title: Text(entry.key), + subtitle: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + color: theme.colorScheme.surfaceContainer, + child: SingleChildScrollView( + padding: const EdgeInsets.all(16), + scrollDirection: Axis.horizontal, + child: Text( + const JsonEncoder.withIndent( + ' ', + ).convert(entry.value), + style: TextStyle( + color: theme.colorScheme.onSurface, + ), + ), + ), + ), + ), + ), + ], + ); + }, + ), + ], + ), + ), + ), + ); + } +} + +extension on Role { + String localizedString(L10n l10n) { + switch (this) { + case Role.mRoleAdmin: + return l10n.contactServerAdmin; + case Role.mRoleSecurity: + return l10n.contactServerSecurity; + } + } +} diff --git a/lib/pages/settings_ignore_list/settings_ignore_list.dart b/lib/pages/settings_ignore_list/settings_ignore_list.dart index d64be058b..3bcea3dfe 100644 --- a/lib/pages/settings_ignore_list/settings_ignore_list.dart +++ b/lib/pages/settings_ignore_list/settings_ignore_list.dart @@ -1,9 +1,9 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import '../../widgets/matrix.dart'; import 'settings_ignore_list_view.dart'; @@ -22,8 +22,9 @@ class SettingsIgnoreListController extends State { @override void initState() { super.initState(); - if (widget.initialUserId != null) { - controller.text = widget.initialUserId!.replaceAll('@', ''); + final initialUserId = widget.initialUserId; + if (initialUserId != null) { + controller.text = initialUserId; } } @@ -34,7 +35,7 @@ class SettingsIgnoreListController extends State { if (userId.isEmpty) return; if (!userId.isValidMatrixId || userId.sigil != '@') { setState(() { - errorText = L10n.of(context)!.invalidInput; + errorText = L10n.of(context).invalidInput; }); return; } @@ -42,10 +43,12 @@ class SettingsIgnoreListController extends State { errorText = null; }); + final client = Matrix.of(context).client; showFutureLoadingDialog( context: context, - future: () => Matrix.of(context).client.ignoreUser(userId), + future: () => client.ignoreUser(userId), ); + setState(() {}); controller.clear(); } diff --git a/lib/pages/settings_ignore_list/settings_ignore_list_view.dart b/lib/pages/settings_ignore_list/settings_ignore_list_view.dart index dee5e808a..7dee64d11 100644 --- a/lib/pages/settings_ignore_list/settings_ignore_list_view.dart +++ b/lib/pages/settings_ignore_list/settings_ignore_list_view.dart @@ -1,10 +1,7 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import '../../widgets/matrix.dart'; import 'settings_ignore_list.dart'; @@ -16,92 +13,82 @@ class SettingsIgnoreListView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + final client = Matrix.of(context).client; return Scaffold( appBar: AppBar( leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.blockedUsers), + title: Text(L10n.of(context).blockedUsers), ), body: MaxWidthBody( withScrolling: false, - child: Column( - mainAxisSize: MainAxisSize.min, - children: [ - Padding( - padding: const EdgeInsets.all(16.0), - child: Column( - mainAxisSize: MainAxisSize.min, - children: [ - TextField( - controller: controller.controller, - autocorrect: false, - textInputAction: TextInputAction.done, - onSubmitted: (_) => controller.ignoreUser(context), - decoration: InputDecoration( - errorText: controller.errorText, - hintText: '@bad_guy:domain.abc', - floatingLabelBehavior: FloatingLabelBehavior.always, - labelText: L10n.of(context)!.blockUsername, - suffixIcon: IconButton( - tooltip: L10n.of(context)!.block, - icon: const Icon(Icons.send_outlined), - onPressed: () => controller.ignoreUser(context), - ), - ), - ), - const SizedBox(height: 16), - Text( - L10n.of(context)!.blockListDescription, - style: const TextStyle(color: Colors.orange), - ), - ], - ), - ), - Divider( - color: Theme.of(context).dividerColor, - ), - Expanded( - child: StreamBuilder( - stream: client.onSync.stream.where( - (syncUpdate) => - syncUpdate.accountData?.any( - (accountData) => - accountData.type == 'm.ignored_user_list', - ) ?? - false, - ), - builder: (context, snapshot) { - return ListView.builder( - itemCount: client.ignoredUsers.length, - itemBuilder: (c, i) => FutureBuilder( - future: - client.getProfileFromUserId(client.ignoredUsers[i]), - builder: (c, s) => ListTile( - leading: Avatar( - mxContent: s.data?.avatarUrl ?? Uri.parse(''), - name: s.data?.displayName ?? client.ignoredUsers[i], - ), - title: Text( - s.data?.displayName ?? client.ignoredUsers[i], - ), - subtitle: - Text(s.data?.userId ?? client.ignoredUsers[i]), - trailing: IconButton( - tooltip: L10n.of(context)!.delete, - icon: const Icon(Icons.delete_outlined), - onPressed: () => showFutureLoadingDialog( - context: context, - future: () => - client.unignoreUser(client.ignoredUsers[i]), + child: StreamBuilder( + stream: client.onSync.stream.where( + (syncUpdate) => + syncUpdate.accountData?.any( + (accountData) => accountData.type == 'm.ignored_user_list', + ) ?? + false, + ), + builder: (context, asyncSnapshot) { + if (client.prevBatch == null) { + return const Center(child: CircularProgressIndicator.adaptive()); + } + return Column( + mainAxisSize: .min, + children: [ + Padding( + padding: const EdgeInsets.all(16.0), + child: Column( + mainAxisSize: .min, + children: [ + TextField( + controller: controller.controller, + autocorrect: false, + textInputAction: TextInputAction.done, + onSubmitted: (_) => controller.ignoreUser(context), + decoration: InputDecoration( + errorText: controller.errorText, + hintText: '@bad_guy:domain.abc', + floatingLabelBehavior: FloatingLabelBehavior.always, + labelText: L10n.of(context).blockUsername, + suffixIcon: IconButton( + tooltip: L10n.of(context).block, + icon: const Icon(Icons.add), + onPressed: () => controller.ignoreUser(context), ), ), ), + const SizedBox(height: 16), + Text( + L10n.of(context).blockListDescription, + style: const TextStyle(color: Colors.orange), + ), + ], + ), + ), + Divider(color: theme.dividerColor), + Expanded( + child: ListView.builder( + itemCount: client.ignoredUsers.length, + itemBuilder: (c, i) => ListTile( + title: Text(client.ignoredUsers[i]), + trailing: IconButton( + tooltip: L10n.of(context).delete, + icon: const Icon(Icons.delete_outlined), + onPressed: () => showFutureLoadingDialog( + context: context, + future: () => + client.unignoreUser(client.ignoredUsers[i]), + ), + ), ), - ); - }, - ), - ), - ], + ), + ), + ], + ); + }, ), ), ); diff --git a/lib/pages/settings_multiple_emotes/settings_multiple_emotes.dart b/lib/pages/settings_multiple_emotes/settings_multiple_emotes.dart deleted file mode 100644 index 276bc08ad..000000000 --- a/lib/pages/settings_multiple_emotes/settings_multiple_emotes.dart +++ /dev/null @@ -1,19 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:go_router/go_router.dart'; - -import 'settings_multiple_emotes_view.dart'; - -class MultipleEmotesSettings extends StatefulWidget { - const MultipleEmotesSettings({super.key}); - - @override - MultipleEmotesSettingsController createState() => - MultipleEmotesSettingsController(); -} - -class MultipleEmotesSettingsController extends State { - String? get roomId => GoRouterState.of(context).pathParameters['roomid']; - @override - Widget build(BuildContext context) => MultipleEmotesSettingsView(this); -} diff --git a/lib/pages/settings_multiple_emotes/settings_multiple_emotes_view.dart b/lib/pages/settings_multiple_emotes/settings_multiple_emotes_view.dart deleted file mode 100644 index 5b910a8ba..000000000 --- a/lib/pages/settings_multiple_emotes/settings_multiple_emotes_view.dart +++ /dev/null @@ -1,64 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:go_router/go_router.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/pages/settings_multiple_emotes/settings_multiple_emotes.dart'; -import 'package:fluffychat/widgets/matrix.dart'; - -class MultipleEmotesSettingsView extends StatelessWidget { - final MultipleEmotesSettingsController controller; - - const MultipleEmotesSettingsView(this.controller, {super.key}); - - @override - Widget build(BuildContext context) { - final room = Matrix.of(context).client.getRoomById(controller.roomId!)!; - return Scaffold( - appBar: AppBar( - leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.emotePacks), - ), - body: StreamBuilder( - stream: room.client.onRoomState.stream - .where((update) => update.roomId == room.id), - builder: (context, snapshot) { - final packStateEvents = room.states['im.ponies.room_emotes']; - // we need to manually convert the map using Map.of, otherwise assigning null will throw a type error. - final packs = packStateEvents != null - ? Map.of(packStateEvents) - : {}; - if (!packs.containsKey('')) { - packs[''] = null; - } - final keys = packs.keys.toList(); - keys.sort(); - return ListView.separated( - separatorBuilder: (BuildContext context, int i) => - const SizedBox.shrink(), - itemCount: keys.length, - itemBuilder: (BuildContext context, int i) { - final event = packs[keys[i]]; - final eventPack = - event?.content.tryGetMap('pack'); - final packName = eventPack?.tryGet('displayname') ?? - eventPack?.tryGet('name') ?? - (keys[i].isNotEmpty ? keys[i] : 'Default Pack'); - - return ListTile( - title: Text(packName), - onTap: () async { - context.go( - ['', 'rooms', room.id, 'details', 'emotes', keys[i]] - .join('/'), - ); - }, - ); - }, - ); - }, - ), - ); - } -} diff --git a/lib/pages/settings_notifications/push_rule_extensions.dart b/lib/pages/settings_notifications/push_rule_extensions.dart new file mode 100644 index 000000000..103fbc10f --- /dev/null +++ b/lib/pages/settings_notifications/push_rule_extensions.dart @@ -0,0 +1,122 @@ +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; + +extension PushRuleExtension on PushRule { + String getPushRuleName(L10n l10n) { + switch (ruleId) { + case '.m.rule.contains_user_name': + return l10n.notificationRuleContainsUserName; + case '.m.rule.master': + return l10n.notificationRuleMaster; + case '.m.rule.suppress_notices': + return l10n.notificationRuleSuppressNotices; + case '.m.rule.invite_for_me': + return l10n.notificationRuleInviteForMe; + case '.m.rule.member_event': + return l10n.notificationRuleMemberEvent; + case '.m.rule.is_user_mention': + return l10n.notificationRuleIsUserMention; + case '.m.rule.contains_display_name': + return l10n.notificationRuleContainsDisplayName; + case '.m.rule.is_room_mention': + return l10n.notificationRuleIsRoomMention; + case '.m.rule.roomnotif': + return l10n.notificationRuleRoomnotif; + case '.m.rule.tombstone': + return l10n.notificationRuleTombstone; + case '.m.rule.reaction': + return l10n.notificationRuleReaction; + case '.m.rule.room_server_acl': + return l10n.notificationRuleRoomServerAcl; + case '.m.rule.suppress_edits': + return l10n.notificationRuleSuppressEdits; + case '.m.rule.call': + return l10n.notificationRuleCall; + case '.m.rule.encrypted_room_one_to_one': + return l10n.notificationRuleEncryptedRoomOneToOne; + case '.m.rule.room_one_to_one': + return l10n.notificationRuleRoomOneToOne; + case '.m.rule.message': + return l10n.notificationRuleMessage; + case '.m.rule.encrypted': + return l10n.notificationRuleEncrypted; + case '.m.rule.room.server_acl': + return l10n.notificationRuleServerAcl; + case '.im.vector.jitsi': + return l10n.notificationRuleJitsi; + default: + return ruleId.split('.').last.replaceAll('_', ' ').capitalize(); + } + } + + String getPushRuleDescription(L10n l10n) { + switch (ruleId) { + case '.m.rule.contains_user_name': + return l10n.notificationRuleContainsUserNameDescription; + case '.m.rule.master': + return l10n.notificationRuleMasterDescription; + case '.m.rule.suppress_notices': + return l10n.notificationRuleSuppressNoticesDescription; + case '.m.rule.invite_for_me': + return l10n.notificationRuleInviteForMeDescription; + case '.m.rule.member_event': + return l10n.notificationRuleMemberEventDescription; + case '.m.rule.is_user_mention': + return l10n.notificationRuleIsUserMentionDescription; + case '.m.rule.contains_display_name': + return l10n.notificationRuleContainsDisplayNameDescription; + case '.m.rule.is_room_mention': + return l10n.notificationRuleIsRoomMentionDescription; + case '.m.rule.roomnotif': + return l10n.notificationRuleRoomnotifDescription; + case '.m.rule.tombstone': + return l10n.notificationRuleTombstoneDescription; + case '.m.rule.reaction': + return l10n.notificationRuleReactionDescription; + case '.m.rule.room_server_acl': + return l10n.notificationRuleRoomServerAclDescription; + case '.m.rule.suppress_edits': + return l10n.notificationRuleSuppressEditsDescription; + case '.m.rule.call': + return l10n.notificationRuleCallDescription; + case '.m.rule.encrypted_room_one_to_one': + return l10n.notificationRuleEncryptedRoomOneToOneDescription; + case '.m.rule.room_one_to_one': + return l10n.notificationRuleRoomOneToOneDescription; + case '.m.rule.message': + return l10n.notificationRuleMessageDescription; + case '.m.rule.encrypted': + return l10n.notificationRuleEncryptedDescription; + case '.m.rule.room.server_acl': + return l10n.notificationRuleServerAclDescription; + case '.im.vector.jitsi': + return l10n.notificationRuleJitsiDescription; + default: + return l10n.unknownPushRule(ruleId); + } + } +} + +extension PushRuleKindLocal on PushRuleKind { + String localized(L10n l10n) { + switch (this) { + case PushRuleKind.content: + return l10n.contentNotificationSettings; + case PushRuleKind.override: + return l10n.generalNotificationSettings; + case PushRuleKind.room: + return l10n.roomNotificationSettings; + case PushRuleKind.sender: + return l10n.userSpecificNotificationSettings; + case PushRuleKind.underride: + return l10n.otherNotificationSettings; + } + } +} + +extension on String { + String capitalize() { + return '${this[0].toUpperCase()}${substring(1).toLowerCase()}'; + } +} diff --git a/lib/pages/settings_notifications/settings_notifications.dart b/lib/pages/settings_notifications/settings_notifications.dart index 2baf14dd0..05c9e3e54 100644 --- a/lib/pages/settings_notifications/settings_notifications.dart +++ b/lib/pages/settings_notifications/settings_notifications.dart @@ -1,59 +1,20 @@ +import 'dart:convert'; + import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:collection/collection.dart' show IterableExtension; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/settings_notifications/push_rule_extensions.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_modal_action_popup.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import '../../widgets/matrix.dart'; import 'settings_notifications_view.dart'; -class NotificationSettingsItem { - final PushRuleKind type; - final String key; - final String Function(BuildContext) title; - const NotificationSettingsItem(this.type, this.key, this.title); - static List items = [ - NotificationSettingsItem( - PushRuleKind.underride, - '.m.rule.message', - (c) => L10n.of(c)!.allRooms, - ), - NotificationSettingsItem( - PushRuleKind.underride, - '.m.rule.room_one_to_one', - (c) => L10n.of(c)!.directChats, - ), - NotificationSettingsItem( - PushRuleKind.override, - '.m.rule.contains_display_name', - (c) => L10n.of(c)!.containsDisplayName, - ), - NotificationSettingsItem( - PushRuleKind.content, - '.m.rule.contains_user_name', - (c) => L10n.of(c)!.containsUserName, - ), - NotificationSettingsItem( - PushRuleKind.override, - '.m.rule.invite_for_me', - (c) => L10n.of(c)!.inviteForMe, - ), - NotificationSettingsItem( - PushRuleKind.override, - '.m.rule.member_event', - (c) => L10n.of(c)!.memberChanges, - ), - NotificationSettingsItem( - PushRuleKind.override, - '.m.rule.suppress_notices', - (c) => L10n.of(c)!.botMessages, - ), - ]; -} - class SettingsNotifications extends StatefulWidget { const SettingsNotifications({super.key}); @@ -63,91 +24,19 @@ class SettingsNotifications extends StatefulWidget { } class SettingsNotificationsController extends State { - bool? getNotificationSetting(NotificationSettingsItem item) { - final pushRules = Matrix.of(context).client.globalPushRules; - if (pushRules == null) return null; - switch (item.type) { - case PushRuleKind.content: - return pushRules.content - ?.singleWhereOrNull((r) => r.ruleId == item.key) - ?.enabled; - case PushRuleKind.override: - return pushRules.override - ?.singleWhereOrNull((r) => r.ruleId == item.key) - ?.enabled; - case PushRuleKind.room: - return pushRules.room - ?.singleWhereOrNull((r) => r.ruleId == item.key) - ?.enabled; - case PushRuleKind.sender: - return pushRules.sender - ?.singleWhereOrNull((r) => r.ruleId == item.key) - ?.enabled; - case PushRuleKind.underride: - return pushRules.underride - ?.singleWhereOrNull((r) => r.ruleId == item.key) - ?.enabled; - } - } - bool isLoading = false; - void setNotificationSetting( - NotificationSettingsItem item, - bool enabled, - ) async { - final scaffoldMessenger = ScaffoldMessenger.of(context); - setState(() { - isLoading = true; - }); - try { - await Matrix.of(context).client.setPushRuleEnabled( - 'global', - item.type, - item.key, - enabled, - ); - } catch (e, s) { - Logs().w('Unable to change notification settings', e, s); - scaffoldMessenger - .showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); - } finally { - setState(() { - isLoading = false; - }); - } - } - - void onToggleMuteAllNotifications() async { - final scaffoldMessenger = ScaffoldMessenger.of(context); - setState(() { - isLoading = true; - }); - try { - await Matrix.of(context).client.setMuteAllPushNotifications( - !Matrix.of(context).client.allPushNotificationsMuted, - ); - } catch (e, s) { - Logs().w('Unable to change notification settings', e, s); - scaffoldMessenger - .showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); - } finally { - setState(() { - isLoading = false; - }); - } - } - - void onPusherTap(Pusher pusher) async { - final delete = await showModalActionSheet( + Future onPusherTap(Pusher pusher) async { + final delete = await showModalActionPopup( context: context, title: pusher.deviceDisplayName, message: '${pusher.appDisplayName} (${pusher.appId})', + cancelLabel: L10n.of(context).cancel, actions: [ - SheetAction( - label: L10n.of(context)!.delete, - isDestructiveAction: true, - key: true, + AdaptiveModalAction( + label: L10n.of(context).delete, + isDestructive: true, + value: true, ), ], ); @@ -156,11 +45,8 @@ class SettingsNotificationsController extends State { final success = await showFutureLoadingDialog( context: context, future: () => Matrix.of(context).client.deletePusher( - PusherId( - appId: pusher.appId, - pushkey: pusher.pushkey, - ), - ), + PusherId(appId: pusher.appId, pushkey: pusher.pushkey), + ), ); if (success.error != null) return; @@ -172,6 +58,134 @@ class SettingsNotificationsController extends State { Future?>? pusherFuture; + Future togglePushRule(PushRuleKind kind, PushRule pushRule) async { + setState(() { + isLoading = true; + }); + try { + final updateFromSync = Matrix.of(context).client.onSync.stream + .where( + (syncUpdate) => + syncUpdate.accountData?.any( + (accountData) => accountData.type == 'm.push_rules', + ) ?? + false, + ) + .first; + await Matrix.of( + context, + ).client.setPushRuleEnabled(kind, pushRule.ruleId, !pushRule.enabled); + await updateFromSync; + } catch (e, s) { + Logs().w('Unable to toggle push rule', e, s); + if (!mounted) return; + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); + } finally { + if (mounted) { + setState(() { + isLoading = false; + }); + } + } + } + + Future editPushRule(PushRule rule, PushRuleKind kind) async { + final theme = Theme.of(context); + final action = await showAdaptiveDialog( + context: context, + builder: (context) => ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: AlertDialog.adaptive( + title: Text(rule.getPushRuleName(L10n.of(context))), + content: Padding( + padding: const EdgeInsets.only(top: 16.0), + child: Material( + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + color: theme.colorScheme.surfaceContainer, + child: SingleChildScrollView( + padding: const EdgeInsets.all(16), + scrollDirection: Axis.horizontal, + child: SelectableText( + prettyJson(rule.toJson()), + style: TextStyle(color: theme.colorScheme.onSurface), + ), + ), + ), + ), + actions: [ + AdaptiveDialogAction( + onPressed: Navigator.of(context).pop, + child: Text(L10n.of(context).close), + ), + if (!rule.ruleId.startsWith('.m.')) + AdaptiveDialogAction( + onPressed: () => + Navigator.of(context).pop(PushRuleDialogAction.delete), + child: Text( + L10n.of(context).delete, + style: TextStyle(color: theme.colorScheme.error), + ), + ), + ], + ), + ), + ); + if (action == null) return; + if (!mounted) return; + switch (action) { + case PushRuleDialogAction.delete: + final consent = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + message: L10n.of(context).deletePushRuleCanNotBeUndone, + okLabel: L10n.of(context).delete, + isDestructive: true, + ); + if (consent != OkCancelResult.ok) return; + if (!mounted) return; + setState(() { + isLoading = true; + }); + try { + final updateFromSync = Matrix.of(context).client.onSync.stream + .where( + (syncUpdate) => + syncUpdate.accountData?.any( + (accountData) => accountData.type == 'm.push_rules', + ) ?? + false, + ) + .first; + await Matrix.of(context).client.deletePushRule(kind, rule.ruleId); + await updateFromSync; + } catch (e, s) { + Logs().w('Unable to delete push rule', e, s); + if (!mounted) return; + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(e.toLocalizedString(context)))); + } finally { + if (mounted) { + setState(() { + isLoading = false; + }); + } + } + return; + } + } + @override Widget build(BuildContext context) => SettingsNotificationsView(this); } + +enum PushRuleDialogAction { delete } + +String prettyJson(Map json) { + const decoder = JsonDecoder(); + const encoder = JsonEncoder.withIndent(' '); + final object = decoder.convert(jsonEncode(json)); + return encoder.convert(object); +} diff --git a/lib/pages/settings_notifications/settings_notifications_view.dart b/lib/pages/settings_notifications/settings_notifications_view.dart index 6c1d45cc5..8259cfe2b 100644 --- a/lib/pages/settings_notifications/settings_notifications_view.dart +++ b/lib/pages/settings_notifications/settings_notifications_view.dart @@ -1,8 +1,10 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/settings_notifications/push_rule_extensions.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import '../../utils/localized_exception_extension.dart'; import '../../widgets/matrix.dart'; @@ -15,107 +17,150 @@ class SettingsNotificationsView extends StatelessWidget { @override Widget build(BuildContext context) { + final pushRules = Matrix.of(context).client.globalPushRules; + final pushCategories = [ + if (pushRules?.override?.isNotEmpty ?? false) + (rules: pushRules?.override ?? [], kind: PushRuleKind.override), + if (pushRules?.content?.isNotEmpty ?? false) + (rules: pushRules?.content ?? [], kind: PushRuleKind.content), + if (pushRules?.sender?.isNotEmpty ?? false) + (rules: pushRules?.sender ?? [], kind: PushRuleKind.sender), + if (pushRules?.underride?.isNotEmpty ?? false) + (rules: pushRules?.underride ?? [], kind: PushRuleKind.underride), + ]; return Scaffold( appBar: AppBar( - leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.notifications), + automaticallyImplyLeading: !FluffyThemes.isColumnMode(context), + centerTitle: FluffyThemes.isColumnMode(context), + title: Text(L10n.of(context).notifications), ), body: MaxWidthBody( child: StreamBuilder( stream: Matrix.of(context).client.onSync.stream.where( - (syncUpdate) => - syncUpdate.accountData?.any( - (accountData) => accountData.type == 'm.push_rules', - ) ?? - false, - ), + (syncUpdate) => + syncUpdate.accountData?.any( + (accountData) => accountData.type == 'm.push_rules', + ) ?? + false, + ), builder: (BuildContext context, _) { - return Column( - children: [ - SwitchListTile.adaptive( - value: !Matrix.of(context).client.allPushNotificationsMuted, - title: Text( - L10n.of(context)!.notificationsEnabledForThisAccount, - ), - onChanged: controller.isLoading - ? null - : (_) => controller.onToggleMuteAllNotifications(), - ), - Divider(color: Theme.of(context).dividerColor), - ListTile( - title: Text( - L10n.of(context)!.notifyMeFor, - style: TextStyle( - color: Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, - ), - ), - ), - for (final item in NotificationSettingsItem.items) - SwitchListTile.adaptive( - value: Matrix.of(context).client.allPushNotificationsMuted - ? false - : controller.getNotificationSetting(item) ?? true, - title: Text(item.title(context)), - onChanged: controller.isLoading - ? null - : Matrix.of(context).client.allPushNotificationsMuted - ? null - : (bool enabled) => controller - .setNotificationSetting(item, enabled), - ), - Divider(color: Theme.of(context).dividerColor), - ListTile( - title: Text( - L10n.of(context)!.devices, - style: TextStyle( - color: Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, - ), - ), - ), - FutureBuilder?>( - future: controller.pusherFuture ??= - Matrix.of(context).client.getPushers(), - builder: (context, snapshot) { - if (snapshot.hasError) { - Center( - child: Text( - snapshot.error!.toLocalizedString(context), - ), - ); - } - if (snapshot.connectionState != ConnectionState.done) { - const Center( - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, - ), - ); - } - final pushers = snapshot.data ?? []; - if (pushers.isEmpty) { - return Center( - child: Padding( - padding: const EdgeInsets.only(bottom: 16.0), - child: Text(L10n.of(context)!.noOtherDevicesFound), - ), - ); - } - return ListView.builder( - physics: const NeverScrollableScrollPhysics(), - shrinkWrap: true, - itemCount: pushers.length, - itemBuilder: (_, i) => ListTile( + final theme = Theme.of(context); + return SelectionArea( + child: Column( + children: [ + if (pushRules != null) + for (final category in pushCategories) ...[ + ListTile( title: Text( - '${pushers[i].appDisplayName} - ${pushers[i].appId}', + category.kind.localized(L10n.of(context)), + style: TextStyle( + color: theme.colorScheme.secondary, + fontWeight: FontWeight.bold, + ), ), - subtitle: Text(pushers[i].data.url.toString()), - onTap: () => controller.onPusherTap(pushers[i]), ), - ); - }, - ), - ], + for (final rule in category.rules) + ListTile( + title: Text(rule.getPushRuleName(L10n.of(context))), + subtitle: Text.rich( + TextSpan( + children: [ + TextSpan( + text: rule.getPushRuleDescription( + L10n.of(context), + ), + ), + const TextSpan(text: ' '), + WidgetSpan( + child: InkWell( + onTap: () => controller.editPushRule( + rule, + category.kind, + ), + child: Text( + L10n.of(context).more, + style: TextStyle( + color: theme.colorScheme.primary, + decoration: TextDecoration.underline, + decorationColor: + theme.colorScheme.primary, + ), + ), + ), + ), + ], + ), + ), + trailing: Switch.adaptive( + value: rule.enabled, + onChanged: controller.isLoading + ? null + : rule.ruleId != '.m.rule.master' && + Matrix.of( + context, + ).client.allPushNotificationsMuted + ? null + : (_) => controller.togglePushRule( + category.kind, + rule, + ), + ), + ), + Divider(color: theme.dividerColor), + ], + ListTile( + title: Text( + L10n.of(context).devices, + style: TextStyle( + color: theme.colorScheme.secondary, + fontWeight: FontWeight.bold, + ), + ), + ), + FutureBuilder?>( + future: controller.pusherFuture ??= Matrix.of( + context, + ).client.getPushers(), + builder: (context, snapshot) { + if (snapshot.hasError) { + Center( + child: Text( + snapshot.error!.toLocalizedString(context), + ), + ); + } + if (snapshot.connectionState != ConnectionState.done) { + const Center( + child: CircularProgressIndicator.adaptive( + strokeWidth: 2, + ), + ); + } + final pushers = snapshot.data ?? []; + if (pushers.isEmpty) { + return Center( + child: Padding( + padding: const EdgeInsets.only(bottom: 16.0), + child: Text(L10n.of(context).noOtherDevicesFound), + ), + ); + } + return ListView.builder( + physics: const NeverScrollableScrollPhysics(), + shrinkWrap: true, + itemCount: pushers.length, + itemBuilder: (_, i) => ListTile( + title: Text( + '${pushers[i].appDisplayName} - ${pushers[i].appId}', + ), + subtitle: Text(pushers[i].data.url.toString()), + onTap: () => controller.onPusherTap(pushers[i]), + ), + ); + }, + ), + ], + ), ); }, ), diff --git a/lib/pages/settings_password/settings_password.dart b/lib/pages/settings_password/settings_password.dart index cb631d7f3..d2fe2621d 100644 --- a/lib/pages/settings_password/settings_password.dart +++ b/lib/pages/settings_password/settings_password.dart @@ -1,8 +1,8 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/settings_password/settings_password_view.dart'; import 'package:fluffychat/utils/localized_exception_extension.dart'; import 'package:fluffychat/widgets/matrix.dart'; @@ -25,26 +25,26 @@ class SettingsPasswordController extends State { bool loading = false; - void changePassword() async { + Future changePassword() async { setState(() { oldPasswordError = newPassword1Error = newPassword2Error = null; }); if (oldPasswordController.text.isEmpty) { setState(() { - oldPasswordError = L10n.of(context)!.pleaseEnterYourPassword; + oldPasswordError = L10n.of(context).pleaseEnterYourPassword; }); return; } if (newPassword1Controller.text.isEmpty || newPassword1Controller.text.length < 6) { setState(() { - newPassword1Error = L10n.of(context)!.pleaseChooseAStrongPassword; + newPassword1Error = L10n.of(context).pleaseChooseAStrongPassword; }); return; } if (newPassword1Controller.text != newPassword2Controller.text) { setState(() { - newPassword2Error = L10n.of(context)!.passwordsDoNotMatch; + newPassword2Error = L10n.of(context).passwordsDoNotMatch; }); return; } @@ -55,13 +55,11 @@ class SettingsPasswordController extends State { try { final scaffoldMessenger = ScaffoldMessenger.of(context); await Matrix.of(context).client.changePassword( - newPassword1Controller.text, - oldPassword: oldPasswordController.text, - ); + newPassword1Controller.text, + oldPassword: oldPasswordController.text, + ); scaffoldMessenger.showSnackBar( - SnackBar( - content: Text(L10n.of(context)!.passwordHasBeenChanged), - ), + SnackBar(content: Text(L10n.of(context).passwordHasBeenChanged)), ); if (mounted) context.pop(); } catch (e) { diff --git a/lib/pages/settings_password/settings_password_view.dart b/lib/pages/settings_password/settings_password_view.dart index 813bebd18..fc0904a98 100644 --- a/lib/pages/settings_password/settings_password_view.dart +++ b/lib/pages/settings_password/settings_password_view.dart @@ -1,8 +1,8 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/pages/settings_password/settings_password.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; @@ -12,30 +12,17 @@ class SettingsPasswordView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return Scaffold( - appBar: AppBar( - title: Text(L10n.of(context)!.changePassword), - actions: [ - TextButton( - child: Text(L10n.of(context)!.passwordRecoverySettings), - onPressed: () => context.go('/rooms/settings/security/3pid'), - ), - ], - ), + appBar: AppBar(title: Text(L10n.of(context).changePassword)), body: ListTileTheme( - iconColor: Theme.of(context).colorScheme.onSurface, + iconColor: theme.colorScheme.onSurface, child: MaxWidthBody( child: Padding( padding: const EdgeInsets.all(16.0), child: Column( children: [ - Center( - child: Icon( - Icons.key_outlined, - color: Theme.of(context).dividerColor, - size: 80, - ), - ), const SizedBox(height: 16), TextField( controller: controller.oldPasswordController, @@ -44,18 +31,22 @@ class SettingsPasswordView extends StatelessWidget { autofocus: true, readOnly: controller.loading, decoration: InputDecoration( - hintText: L10n.of(context)!.pleaseEnterYourCurrentPassword, + prefixIcon: const Icon(Icons.lock_outlined), + hintText: '********', + labelText: L10n.of(context).pleaseEnterYourCurrentPassword, errorText: controller.oldPasswordError, ), ), - const Divider(height: 32), + const Divider(height: 64), TextField( controller: controller.newPassword1Controller, obscureText: true, autocorrect: false, readOnly: controller.loading, decoration: InputDecoration( - hintText: L10n.of(context)!.newPassword, + prefixIcon: const Icon(Icons.lock_reset_outlined), + hintText: '********', + labelText: L10n.of(context).newPassword, errorText: controller.newPassword1Error, ), ), @@ -66,22 +57,29 @@ class SettingsPasswordView extends StatelessWidget { autocorrect: false, readOnly: controller.loading, decoration: InputDecoration( - hintText: L10n.of(context)!.repeatPassword, + prefixIcon: const Icon(Icons.repeat_outlined), + hintText: '********', + labelText: L10n.of(context).repeatPassword, errorText: controller.newPassword2Error, ), ), - const SizedBox(height: 16), + const SizedBox(height: 32), SizedBox( width: double.infinity, - child: ElevatedButton.icon( - onPressed: - controller.loading ? null : controller.changePassword, - icon: const Icon(Icons.send_outlined), - label: controller.loading + child: ElevatedButton( + onPressed: controller.loading + ? null + : controller.changePassword, + child: controller.loading ? const LinearProgressIndicator() - : Text(L10n.of(context)!.changePassword), + : Text(L10n.of(context).changePassword), ), ), + const SizedBox(height: 16), + TextButton( + child: Text(L10n.of(context).passwordRecoverySettings), + onPressed: () => context.go('/rooms/settings/security/3pid'), + ), ], ), ), diff --git a/lib/pages/settings_security/settings_security.dart b/lib/pages/settings_security/settings_security.dart index 69069d693..25c17db21 100644 --- a/lib/pages/settings_security/settings_security.dart +++ b/lib/pages/settings_security/settings_security.dart @@ -1,13 +1,14 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; import 'package:fluffychat/widgets/app_lock.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; -import '../bootstrap/bootstrap_dialog.dart'; import 'settings_security_view.dart'; class SettingsSecurity extends StatefulWidget { @@ -18,107 +19,88 @@ class SettingsSecurity extends StatefulWidget { } class SettingsSecurityController extends State { - void setAppLockAction() async { + Future setAppLockAction() async { if (AppLock.of(context).isActive) { AppLock.of(context).showLockScreen(); } final newLock = await showTextInputDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.pleaseChooseAPasscode, - message: L10n.of(context)!.pleaseEnter4Digits, - cancelLabel: L10n.of(context)!.cancel, - textFields: [ - DialogTextField( - validator: (text) { - if (text!.isEmpty || - (text.length == 4 && int.tryParse(text)! >= 0)) { - return null; - } - return L10n.of(context)!.pleaseEnter4Digits; - }, - keyboardType: TextInputType.number, - obscureText: true, - maxLines: 1, - minLines: 1, - maxLength: 4, - ), - ], + title: L10n.of(context).pleaseChooseAPasscode, + message: L10n.of(context).pleaseEnter4Digits, + cancelLabel: L10n.of(context).cancel, + validator: (text) { + if (text.isEmpty || (text.length == 4 && int.tryParse(text)! >= 0)) { + return null; + } + return L10n.of(context).pleaseEnter4Digits; + }, + keyboardType: TextInputType.number, + obscureText: true, + maxLines: 1, + minLines: 1, + maxLength: 4, ); if (newLock != null) { - await AppLock.of(context).changePincode(newLock.single); + await AppLock.of(context).changePincode(newLock); } } - void deleteAccountAction() async { + Future deleteAccountAction() async { if (await showOkCancelAlertDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.warning, - message: L10n.of(context)!.deactivateAccountWarning, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - isDestructiveAction: true, + title: L10n.of(context).warning, + message: L10n.of(context).deactivateAccountWarning, + okLabel: L10n.of(context).ok, + cancelLabel: L10n.of(context).cancel, + isDestructive: true, ) == OkCancelResult.cancel) { return; } final supposedMxid = Matrix.of(context).client.userID!; - final mxids = await showTextInputDialog( + final mxid = await showTextInputDialog( useRootNavigator: false, context: context, - title: L10n.of(context)!.confirmMatrixId, - textFields: [ - DialogTextField( - validator: (text) => text == supposedMxid - ? null - : L10n.of(context)!.supposedMxid(supposedMxid), - ), - ], - isDestructiveAction: true, - okLabel: L10n.of(context)!.delete, - cancelLabel: L10n.of(context)!.cancel, + title: L10n.of(context).confirmMatrixId, + validator: (text) => text == supposedMxid + ? null + : L10n.of(context).supposedMxid(supposedMxid), + isDestructive: true, + okLabel: L10n.of(context).delete, + cancelLabel: L10n.of(context).cancel, ); - if (mxids == null || mxids.length != 1 || mxids.single != supposedMxid) { + if (mxid == null || mxid.isEmpty || mxid != supposedMxid) { return; } - final input = await showTextInputDialog( - useRootNavigator: false, + final resp = await showFutureLoadingDialog( context: context, - title: L10n.of(context)!.pleaseEnterYourPassword, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - isDestructiveAction: true, - textFields: [ - const DialogTextField( - obscureText: true, - hintText: '******', - minLines: 1, - maxLines: 1, - ), - ], - ); - if (input == null) return; - await showFutureLoadingDialog( - context: context, - future: () => Matrix.of(context).client.deactivateAccount( - auth: AuthenticationPassword( - password: input.single, - identifier: AuthenticationUserIdentifier( - user: Matrix.of(context).client.userID!, - ), - ), + delay: false, + future: () => + Matrix.of(context).client.uiaRequestBackground( + (auth) => Matrix.of( + context, + ).client.deactivateAccount(auth: auth, erase: true), ), ); + + if (!resp.isError) { + await showFutureLoadingDialog( + context: context, + future: () => Matrix.of(context).client.logout(), + ); + } } - void showBootstrapDialog(BuildContext context) async { - await BootstrapDialog( - client: Matrix.of(context).client, - ).show(context); - } + Future dehydrateAction() => Matrix.of(context).dehydrateAction(context); - Future dehydrateAction() => Matrix.of(context).dehydrateAction(); + Future changeShareKeysWith(ShareKeysWith? shareKeysWith) async { + if (shareKeysWith == null) return; + AppSettings.shareKeysWith.setItem(shareKeysWith.name); + Matrix.of(context).client.shareKeysWith = shareKeysWith; + setState(() {}); + } @override Widget build(BuildContext context) => SettingsSecurityView(this); diff --git a/lib/pages/settings_security/settings_security_view.dart b/lib/pages/settings_security/settings_security_view.dart index 49b39d750..2d38a5c4e 100644 --- a/lib/pages/settings_security/settings_security_view.dart +++ b/lib/pages/settings_security/settings_security_view.dart @@ -1,10 +1,12 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/beautify_string_extension.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; @@ -14,20 +16,26 @@ import 'settings_security.dart'; class SettingsSecurityView extends StatelessWidget { final SettingsSecurityController controller; + const SettingsSecurityView(this.controller, {super.key}); @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return Scaffold( - appBar: AppBar(title: Text(L10n.of(context)!.security)), + appBar: AppBar( + title: Text(L10n.of(context).security), + automaticallyImplyLeading: !FluffyThemes.isColumnMode(context), + centerTitle: FluffyThemes.isColumnMode(context), + ), body: ListTileTheme( - iconColor: Theme.of(context).colorScheme.onSurface, + iconColor: theme.colorScheme.onSurface, child: MaxWidthBody( child: FutureBuilder( - future: Matrix.of(context) - .client - .getCapabilities() - .timeout(const Duration(seconds: 10)), + future: Matrix.of( + context, + ).client.getCapabilities().timeout(const Duration(seconds: 10)), builder: (context, snapshot) { final capabilities = snapshot.data; final error = snapshot.error; @@ -43,33 +51,30 @@ class SettingsSecurityView extends StatelessWidget { children: [ ListTile( title: Text( - L10n.of(context)!.privacy, + L10n.of(context).privacy, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.sendTypingNotifications, - subtitle: - L10n.of(context)!.sendTypingNotificationsDescription, - onChanged: (b) => AppConfig.sendTypingNotifications = b, - storeKey: SettingKeys.sendTypingNotifications, - defaultValue: AppConfig.sendTypingNotifications, + title: L10n.of(context).sendTypingNotifications, + subtitle: L10n.of( + context, + ).sendTypingNotificationsDescription, + setting: AppSettings.sendTypingNotifications, ), SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.sendReadReceipts, - subtitle: L10n.of(context)!.sendReadReceiptsDescription, - onChanged: (b) => AppConfig.sendPublicReadReceipts = b, - storeKey: SettingKeys.sendPublicReadReceipts, - defaultValue: AppConfig.sendPublicReadReceipts, + title: L10n.of(context).sendReadReceipts, + subtitle: L10n.of(context).sendReadReceiptsDescription, + setting: AppSettings.sendPublicReadReceipts, ), ListTile( trailing: const Icon(Icons.chevron_right_outlined), - title: Text(L10n.of(context)!.blockedUsers), + title: Text(L10n.of(context).blockedUsers), subtitle: Text( - L10n.of(context)!.thereAreCountUsersBlocked( + L10n.of(context).thereAreCountUsersBlocked( Matrix.of(context).client.ignoredUsers.length, ), ), @@ -80,30 +85,64 @@ class SettingsSecurityView extends StatelessWidget { if (PlatformInfos.isMobile) ListTile( trailing: const Icon(Icons.chevron_right_outlined), - title: Text(L10n.of(context)!.appLock), - subtitle: Text(L10n.of(context)!.appLockDescription), + title: Text(L10n.of(context).appLock), + subtitle: Text(L10n.of(context).appLockDescription), onTap: controller.setAppLockAction, ), }, - Divider( - height: 1, - color: Theme.of(context).dividerColor, - ), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.account, + L10n.of(context).shareKeysWith, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, + fontWeight: FontWeight.bold, + ), + ), + subtitle: Text(L10n.of(context).shareKeysWithDescription), + ), + ListTile( + title: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 2, + ), + color: theme.colorScheme.onInverseSurface, + child: DropdownButton( + isExpanded: true, + padding: const EdgeInsets.symmetric(horizontal: 8.0), + borderRadius: BorderRadius.circular( + AppConfig.borderRadius / 2, + ), + underline: const SizedBox.shrink(), + value: Matrix.of(context).client.shareKeysWith, + items: ShareKeysWith.values + .map( + (share) => DropdownMenuItem( + value: share, + child: Text(share.localized(L10n.of(context))), + ), + ) + .toList(), + onChanged: controller.changeShareKeysWith, + ), + ), + ), + Divider(color: theme.dividerColor), + ListTile( + title: Text( + L10n.of(context).account, + style: TextStyle( + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), ListTile( - title: Text(L10n.of(context)!.yourPublicKey), + title: Text(L10n.of(context).yourPublicKey), leading: const Icon(Icons.vpn_key_outlined), subtitle: SelectableText( Matrix.of(context).client.fingerprintKey.beautified, - style: const TextStyle(fontFamily: 'monospace'), + style: const TextStyle(fontFamily: 'RobotoMono'), ), ), if (capabilities?.mChangePassword?.enabled != false || @@ -111,24 +150,25 @@ class SettingsSecurityView extends StatelessWidget { ListTile( leading: const Icon(Icons.password_outlined), trailing: const Icon(Icons.chevron_right_outlined), - title: Text(L10n.of(context)!.changePassword), + title: Text(L10n.of(context).changePassword), onTap: () => context.go('/rooms/settings/security/password'), ), ListTile( iconColor: Colors.orange, - leading: const Icon(Icons.tap_and_play), + leading: const Icon(Icons.delete_sweep_outlined), title: Text( - L10n.of(context)!.dehydrate, + L10n.of(context).dehydrate, style: const TextStyle(color: Colors.orange), ), onTap: controller.dehydrateAction, ), + Divider(color: theme.dividerColor), ListTile( iconColor: Colors.red, leading: const Icon(Icons.delete_outlined), title: Text( - L10n.of(context)!.deleteAccount, + L10n.of(context).deleteAccount, style: const TextStyle(color: Colors.red), ), onTap: controller.deleteAccountAction, @@ -142,3 +182,18 @@ class SettingsSecurityView extends StatelessWidget { ); } } + +extension on ShareKeysWith { + String localized(L10n l10n) { + switch (this) { + case ShareKeysWith.all: + return l10n.allDevices; + case ShareKeysWith.crossVerifiedIfEnabled: + return l10n.crossVerifiedDevicesIfEnabled; + case ShareKeysWith.crossVerified: + return l10n.crossVerifiedDevices; + case ShareKeysWith.directlyVerifiedOnly: + return l10n.verifiedDevicesOnly; + } + } +} diff --git a/lib/pages/settings_style/settings_style.dart b/lib/pages/settings_style/settings_style.dart index 58f8e2c1b..c47495686 100644 --- a/lib/pages/settings_style/settings_style.dart +++ b/lib/pages/settings_style/settings_style.dart @@ -1,12 +1,12 @@ import 'package:flutter/material.dart'; import 'package:file_picker/file_picker.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/utils/account_config.dart'; -import 'package:fluffychat/widgets/app_lock.dart'; +import 'package:fluffychat/utils/file_selector.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/theme_builder.dart'; import '../../widgets/matrix.dart'; import 'settings_style_view.dart'; @@ -19,27 +19,24 @@ class SettingsStyle extends StatefulWidget { } class SettingsStyleController extends State { - void setChatColor(Color? color) async { - AppConfig.colorSchemeSeed = color; + void setChatColor(Color? color) { + AppSettings.colorSchemeSeedInt.setItem( + color?.toARGB32() ?? AppSettings.colorSchemeSeedInt.defaultValue, + ); ThemeController.of(context).setPrimaryColor(color); } - void setWallpaper() async { + Future setWallpaper() async { final client = Matrix.of(context).client; - final picked = await AppLock.of(context).pauseWhile( - FilePicker.platform.pickFiles( - type: FileType.image, - withData: true, - ), - ); - final pickedFile = picked?.files.firstOrNull; + final picked = await selectFiles(context, type: FileType.image); + final pickedFile = picked.firstOrNull; if (pickedFile == null) return; await showFutureLoadingDialog( context: context, future: () async { final url = await client.uploadContent( - pickedFile.bytes!, + await pickedFile.readAsBytes(), filename: pickedFile.name, ); await client.updateApplicationAccountConfig( @@ -49,25 +46,67 @@ class SettingsStyleController extends State { ); } - void setChatWallpaperOpacity(double opacity) { + double get wallpaperOpacity => + _wallpaperOpacity ?? + Matrix.of(context).client.applicationAccountConfig.wallpaperOpacity ?? + 0.5; + + double? _wallpaperOpacity; + + Future saveWallpaperOpacity(double opacity) async { final client = Matrix.of(context).client; - showFutureLoadingDialog( + final result = await showFutureLoadingDialog( context: context, future: () => client.updateApplicationAccountConfig( ApplicationAccountConfig(wallpaperOpacity: opacity), ), ); + if (result.isValue) return; + + setState(() { + _wallpaperOpacity = client.applicationAccountConfig.wallpaperOpacity; + }); + } + + void updateWallpaperOpacity(double opacity) { + setState(() { + _wallpaperOpacity = opacity; + }); + } + + double get wallpaperBlur => + _wallpaperBlur ?? + Matrix.of(context).client.applicationAccountConfig.wallpaperBlur ?? + 0.5; + double? _wallpaperBlur; + + Future saveWallpaperBlur(double blur) async { + final client = Matrix.of(context).client; + final result = await showFutureLoadingDialog( + context: context, + future: () => client.updateApplicationAccountConfig( + ApplicationAccountConfig(wallpaperBlur: blur), + ), + ); + if (result.isValue) return; + + setState(() { + _wallpaperBlur = client.applicationAccountConfig.wallpaperBlur; + }); + } + + void updateWallpaperBlur(double blur) { + setState(() { + _wallpaperBlur = blur; + }); } void deleteChatWallpaper() => showFutureLoadingDialog( - context: context, - future: () => Matrix.of(context).client.setApplicationAccountConfig( - const ApplicationAccountConfig( - wallpaperUrl: null, - wallpaperOpacity: null, - ), - ), - ); + context: context, + future: () => Matrix.of(context).client.setApplicationAccountConfig( + const ApplicationAccountConfig(wallpaperUrl: null, wallpaperBlur: null), + ), + ); ThemeMode get currentTheme => ThemeController.of(context).themeMode; Color? get currentColor => ThemeController.of(context).primaryColor; @@ -76,10 +115,26 @@ class SettingsStyleController extends State { null, AppConfig.chatColor, Colors.indigo, + Colors.blue, + Colors.blueAccent, + Colors.teal, + Colors.tealAccent, Colors.green, + Colors.greenAccent, + Colors.yellow, + Colors.yellowAccent, Colors.orange, + Colors.orangeAccent, + Colors.red, + Colors.redAccent, Colors.pink, + Colors.pinkAccent, + Colors.purple, + Colors.purpleAccent, Colors.blueGrey, + Colors.grey, + Colors.white, + Colors.black, ]; void switchTheme(ThemeMode? newTheme) { @@ -98,12 +153,9 @@ class SettingsStyleController extends State { setState(() {}); } - void changeFontSizeFactor(double d) { - setState(() => AppConfig.fontSizeFactor = d); - Matrix.of(context).store.setString( - SettingKeys.fontSizeFactor, - AppConfig.fontSizeFactor.toString(), - ); + Future changeFontSizeFactor(double d) async { + await AppSettings.fontSizeFactor.setItem(d); + setState(() {}); } @override diff --git a/lib/pages/settings_style/settings_style_view.dart b/lib/pages/settings_style/settings_style_view.dart index 86f48fe87..9391bbf3f 100644 --- a/lib/pages/settings_style/settings_style_view.dart +++ b/lib/pages/settings_style/settings_style_view.dart @@ -1,10 +1,16 @@ +import 'dart:ui'; + import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:dynamic_color/dynamic_color.dart'; +import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat/events/state_message.dart'; import 'package:fluffychat/utils/account_config.dart'; +import 'package:fluffychat/utils/color_value.dart'; import 'package:fluffychat/widgets/avatar.dart'; import 'package:fluffychat/widgets/layouts/max_width_body.dart'; import 'package:fluffychat/widgets/matrix.dart'; @@ -20,186 +26,120 @@ class SettingsStyleView extends StatelessWidget { @override Widget build(BuildContext context) { + final theme = Theme.of(context); + const colorPickerSize = 32.0; final client = Matrix.of(context).client; return Scaffold( appBar: AppBar( - leading: const Center(child: BackButton()), - title: Text(L10n.of(context)!.changeTheme), + automaticallyImplyLeading: !FluffyThemes.isColumnMode(context), + centerTitle: FluffyThemes.isColumnMode(context), + title: Text(L10n.of(context).changeTheme), ), - backgroundColor: Theme.of(context).colorScheme.surface, + backgroundColor: theme.colorScheme.surface, body: MaxWidthBody( child: Column( + crossAxisAlignment: .stretch, children: [ + Padding( + padding: const EdgeInsets.all(12.0), + child: SegmentedButton( + selected: {controller.currentTheme}, + onSelectionChanged: (selected) => + controller.switchTheme(selected.single), + segments: [ + ButtonSegment( + value: ThemeMode.light, + label: Text(L10n.of(context).lightTheme), + icon: const Icon(Icons.light_mode_outlined), + ), + ButtonSegment( + value: ThemeMode.dark, + label: Text(L10n.of(context).darkTheme), + icon: const Icon(Icons.dark_mode_outlined), + ), + ButtonSegment( + value: ThemeMode.system, + label: Text(L10n.of(context).systemTheme), + icon: const Icon(Icons.auto_mode_outlined), + ), + ], + ), + ), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.setColorTheme, + L10n.of(context).setColorTheme, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), ), - SizedBox( - height: colorPickerSize + 24, - child: ListView( - shrinkWrap: true, - scrollDirection: Axis.horizontal, - children: SettingsStyleController.customColors - .map( - (color) => Padding( - padding: const EdgeInsets.all(12.0), + DynamicColorBuilder( + builder: (light, dark) { + final systemColor = + Theme.of(context).brightness == Brightness.light + ? light?.primary + : dark?.primary; + final colors = List.from( + SettingsStyleController.customColors, + ); + if (systemColor == null) { + colors.remove(null); + } + return GridView.builder( + shrinkWrap: true, + gridDelegate: const SliverGridDelegateWithMaxCrossAxisExtent( + maxCrossAxisExtent: 64, + ), + itemCount: colors.length, + itemBuilder: (context, i) { + final color = colors[i]; + return Padding( + padding: const EdgeInsets.all(12.0), + child: Tooltip( + message: color == null + ? L10n.of(context).systemTheme + : '#${color.hexValue.toRadixString(16).toUpperCase()}', child: InkWell( borderRadius: BorderRadius.circular(colorPickerSize), onTap: () => controller.setChatColor(color), - child: color == null - ? Material( - elevation: 6, - shadowColor: AppConfig.colorSchemeSeed, - borderRadius: - BorderRadius.circular(colorPickerSize), - child: DecoratedBox( - decoration: BoxDecoration( - borderRadius: BorderRadius.circular( - colorPickerSize, + child: Material( + color: color ?? systemColor, + elevation: 6, + borderRadius: BorderRadius.circular( + colorPickerSize, + ), + child: SizedBox( + width: colorPickerSize, + height: colorPickerSize, + child: controller.currentColor == color + ? Center( + child: Icon( + Icons.check, + size: 16, + color: Theme.of( + context, + ).colorScheme.onPrimary, ), - gradient: FluffyThemes.backgroundGradient( - context, - 255, - ), - ), - child: SizedBox( - height: colorPickerSize, - child: Padding( - padding: const EdgeInsets.symmetric( - horizontal: 8.0, - ), - child: Center( - child: Row( - mainAxisSize: MainAxisSize.min, - children: [ - if (controller.currentColor == - null) - Padding( - padding: - const EdgeInsets.only( - right: 8.0, - ), - child: Icon( - Icons.check, - size: 16, - color: Theme.of(context) - .colorScheme - .onSurface, - ), - ), - Text( - L10n.of(context)!.systemTheme, - textAlign: TextAlign.center, - style: TextStyle( - color: Theme.of(context) - .colorScheme - .onSurface, - ), - ), - ], - ), - ), - ), - ), - ), - ) - : Material( - color: color, - elevation: 6, - borderRadius: - BorderRadius.circular(colorPickerSize), - child: SizedBox( - width: colorPickerSize, - height: colorPickerSize, - child: controller.currentColor == color - ? const Center( - child: Icon( - Icons.check, - size: 16, - color: Colors.white, - ), - ) - : null, - ), - ), + ) + : null, + ), + ), ), ), - ) - .toList(), - ), - ), - const SizedBox(height: 8), - Divider( - height: 1, - color: Theme.of(context).dividerColor, + ); + }, + ); + }, ), + Divider(color: theme.dividerColor), ListTile( title: Text( - L10n.of(context)!.setTheme, + L10n.of(context).messagesStyle, style: TextStyle( - color: Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, - ), - ), - ), - RadioListTile( - groupValue: controller.currentTheme, - value: ThemeMode.system, - title: Text(L10n.of(context)!.systemTheme), - onChanged: controller.switchTheme, - ), - RadioListTile( - groupValue: controller.currentTheme, - value: ThemeMode.light, - title: Text(L10n.of(context)!.lightTheme), - onChanged: controller.switchTheme, - ), - RadioListTile( - groupValue: controller.currentTheme, - value: ThemeMode.dark, - title: Text(L10n.of(context)!.darkTheme), - onChanged: controller.switchTheme, - ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, - ), - ListTile( - title: Text( - L10n.of(context)!.overview, - style: TextStyle( - color: Theme.of(context).colorScheme.secondary, - fontWeight: FontWeight.bold, - ), - ), - ), - SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.presencesToggle, - onChanged: (b) => AppConfig.showPresences = b, - storeKey: SettingKeys.showPresences, - defaultValue: AppConfig.showPresences, - ), - SettingsSwitchListTile.adaptive( - title: L10n.of(context)!.separateChatTypes, - onChanged: (b) => AppConfig.separateChatTypes = b, - storeKey: SettingKeys.separateChatTypes, - defaultValue: AppConfig.separateChatTypes, - ), - Divider( - height: 1, - color: Theme.of(context).dividerColor, - ), - ListTile( - title: Text( - L10n.of(context)!.messagesStyle, - style: TextStyle( - color: Theme.of(context).colorScheme.secondary, + color: theme.colorScheme.secondary, fontWeight: FontWeight.bold, ), ), @@ -216,106 +156,203 @@ class SettingsStyleView extends StatelessWidget { ), builder: (context, snapshot) { final accountConfig = client.applicationAccountConfig; - final wallpaperOpacity = accountConfig.wallpaperOpacity ?? 1; - final wallpaperOpacityIsDefault = wallpaperOpacity == 1; return Column( - mainAxisSize: MainAxisSize.min, + mainAxisSize: .min, children: [ AnimatedContainer( duration: FluffyThemes.animationDuration, curve: FluffyThemes.animationCurve, - alignment: Alignment.centerLeft, decoration: const BoxDecoration(), clipBehavior: Clip.hardEdge, child: Stack( + alignment: Alignment.center, children: [ if (accountConfig.wallpaperUrl != null) Opacity( - opacity: wallpaperOpacity, - child: MxcImage( - uri: accountConfig.wallpaperUrl, - fit: BoxFit.cover, - isThumbnail: true, - width: FluffyThemes.columnWidth * 2, - height: 156, - ), - ), - Padding( - padding: EdgeInsets.only( - left: 12 + 12 + Avatar.defaultSize, - right: 12, - top: accountConfig.wallpaperUrl == null ? 0 : 12, - bottom: 12, - ), - child: Material( - color: Theme.of(context).colorScheme.primary, - borderRadius: BorderRadius.circular( - AppConfig.borderRadius, - ), - child: Padding( - padding: const EdgeInsets.symmetric( - horizontal: 16, - vertical: 8, + opacity: controller.wallpaperOpacity, + child: ImageFiltered( + imageFilter: ImageFilter.blur( + sigmaX: controller.wallpaperBlur, + sigmaY: controller.wallpaperBlur, ), - child: Text( - 'Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor', - style: TextStyle( - color: - Theme.of(context).colorScheme.onPrimary, - fontSize: AppConfig.messageFontSize * - AppConfig.fontSizeFactor, + child: MxcImage( + key: ValueKey(accountConfig.wallpaperUrl), + uri: accountConfig.wallpaperUrl, + fit: BoxFit.cover, + isThumbnail: true, + width: FluffyThemes.columnWidth * 2, + height: 212, + ), + ), + ), + Column( + mainAxisSize: .min, + children: [ + const SizedBox(height: 16), + StateMessage( + Event( + eventId: 'style_dummy', + room: Room( + id: '!style_dummy', + client: client, + ), + content: {'membership': 'join'}, + type: EventTypes.RoomMember, + senderId: client.userID!, + originServerTs: DateTime.now(), + stateKey: client.userID, + ), + ), + Padding( + padding: EdgeInsets.only( + left: 12 + 12 + Avatar.defaultSize, + right: 12, + top: accountConfig.wallpaperUrl == null + ? 0 + : 12, + bottom: 12, + ), + child: DecoratedBox( + decoration: BoxDecoration( + color: theme.bubbleColor, + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + ), + child: Padding( + padding: const EdgeInsets.symmetric( + horizontal: 16, + vertical: 8, + ), + child: Text( + 'Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor', + style: TextStyle( + color: theme.onBubbleColor, + fontSize: + AppConfig.messageFontSize * + AppSettings.fontSizeFactor.value, + ), + ), ), ), ), - ), + Align( + alignment: Alignment.centerLeft, + child: Padding( + padding: EdgeInsets.only( + right: 12, + left: 12, + top: accountConfig.wallpaperUrl == null + ? 0 + : 12, + bottom: 12, + ), + child: Material( + color: + theme.colorScheme.surfaceContainerHigh, + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + child: Padding( + padding: const EdgeInsets.symmetric( + horizontal: 16, + vertical: 8, + ), + child: Text( + 'Lorem ipsum dolor sit amet', + style: TextStyle( + color: theme.colorScheme.onSurface, + fontSize: + AppConfig.messageFontSize * + AppSettings.fontSizeFactor.value, + ), + ), + ), + ), + ), + ), + ], ), ], ), ), + Divider(color: theme.dividerColor), ListTile( - title: Text(L10n.of(context)!.wallpaper), - leading: const Icon(Icons.photo_outlined), + title: TextButton.icon( + style: TextButton.styleFrom( + backgroundColor: theme.colorScheme.secondaryContainer, + foregroundColor: + theme.colorScheme.onSecondaryContainer, + ), + onPressed: controller.setWallpaper, + icon: const Icon(Icons.edit_outlined), + label: Text(L10n.of(context).setWallpaper), + ), trailing: accountConfig.wallpaperUrl == null ? null : IconButton( icon: const Icon(Icons.delete_outlined), - color: Theme.of(context).colorScheme.error, + color: theme.colorScheme.error, onPressed: controller.deleteChatWallpaper, ), - onTap: controller.setWallpaper, - ), - AnimatedSize( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - child: accountConfig.wallpaperUrl != null - ? SwitchListTile.adaptive( - title: Text(L10n.of(context)!.transparent), - secondary: const Icon(Icons.blur_linear_outlined), - value: !wallpaperOpacityIsDefault, - onChanged: (_) => - controller.setChatWallpaperOpacity( - wallpaperOpacityIsDefault ? 0.4 : 1, - ), - ) - : null, ), + if (accountConfig.wallpaperUrl != null) ...[ + ListTile(title: Text(L10n.of(context).opacity)), + Slider.adaptive( + min: 0.1, + max: 1.0, + divisions: 9, + semanticFormatterCallback: (d) => d.toString(), + value: controller.wallpaperOpacity, + onChanged: controller.updateWallpaperOpacity, + onChangeEnd: controller.saveWallpaperOpacity, + ), + ListTile(title: Text(L10n.of(context).blur)), + Slider.adaptive( + min: 0.0, + max: 10.0, + divisions: 10, + semanticFormatterCallback: (d) => d.toString(), + value: controller.wallpaperBlur, + onChanged: controller.updateWallpaperBlur, + onChangeEnd: controller.saveWallpaperBlur, + ), + ], ], ); }, ), ListTile( - title: Text(L10n.of(context)!.fontSize), - trailing: Text('× ${AppConfig.fontSizeFactor}'), + title: Text(L10n.of(context).fontSize), + trailing: Text('× ${AppSettings.fontSizeFactor.value}'), ), Slider.adaptive( min: 0.5, max: 2.5, divisions: 20, - value: AppConfig.fontSizeFactor, + value: AppSettings.fontSizeFactor.value, semanticFormatterCallback: (d) => d.toString(), onChanged: controller.changeFontSizeFactor, ), + Divider(color: theme.dividerColor), + ListTile( + title: Text( + L10n.of(context).overview, + style: TextStyle( + color: theme.colorScheme.secondary, + fontWeight: FontWeight.bold, + ), + ), + ), + SettingsSwitchListTile.adaptive( + title: L10n.of(context).presencesToggle, + setting: AppSettings.showPresences, + ), + SettingsSwitchListTile.adaptive( + title: L10n.of(context).displayNavigationRail, + setting: AppSettings.displayNavigationRail, + ), ], ), ), diff --git a/lib/pages/sign_in/sign_in_page.dart b/lib/pages/sign_in/sign_in_page.dart new file mode 100644 index 000000000..c5b499225 --- /dev/null +++ b/lib/pages/sign_in/sign_in_page.dart @@ -0,0 +1,260 @@ +import 'package:flutter/material.dart'; + +import 'package:url_launcher/url_launcher_string.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/sign_in/view_model/model/public_homeserver_data.dart'; +import 'package:fluffychat/pages/sign_in/view_model/sign_in_view_model.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/utils/sign_in_flows/check_homeserver.dart'; +import 'package:fluffychat/widgets/layouts/login_scaffold.dart'; +import 'package:fluffychat/widgets/matrix.dart'; +import 'package:fluffychat/widgets/view_model_builder.dart'; + +class SignInPage extends StatelessWidget { + final bool signUp; + const SignInPage({required this.signUp, super.key}); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + return ViewModelBuilder( + create: () => SignInViewModel(Matrix.of(context), signUp: signUp), + builder: (context, viewModel, _) { + final state = viewModel.value; + final publicHomeservers = state.filteredPublicHomeservers; + final selectedHomserver = state.selectedHomeserver; + return LoginScaffold( + appBar: AppBar( + leading: + state.loginLoading.connectionState == ConnectionState.waiting + ? CloseButton( + onPressed: () => + viewModel.setLoginLoading(AsyncSnapshot.nothing()), + ) + : BackButton(onPressed: Navigator.of(context).pop), + backgroundColor: theme.colorScheme.surface, + surfaceTintColor: theme.colorScheme.surface, + scrolledUnderElevation: 0, + centerTitle: true, + title: Text( + signUp + ? L10n.of(context).createNewAccount + : L10n.of(context).login, + ), + ), + body: Padding( + padding: const EdgeInsets.symmetric(horizontal: 16.0), + child: Column( + spacing: 16, + children: [ + SelectableText( + signUp + ? L10n.of(context).signUpGreeting + : L10n.of(context).signInGreeting, + textAlign: .center, + ), + TextField( + readOnly: + state.publicHomeservers.connectionState == + ConnectionState.waiting || + state.loginLoading.connectionState == + ConnectionState.waiting, + controller: viewModel.filterTextController, + autocorrect: false, + keyboardType: TextInputType.url, + decoration: InputDecoration( + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + errorText: state.publicHomeservers.error?.toLocalizedString( + context, + ), + prefixIcon: const Icon(Icons.search_outlined), + hintText: L10n.of(context).searchOrEnterHomeserverAddress, + ), + ), + if (state.publicHomeservers.connectionState == + ConnectionState.done) + Expanded( + child: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + clipBehavior: Clip.hardEdge, + color: theme.colorScheme.surfaceContainerLow, + child: RadioGroup( + groupValue: state.selectedHomeserver, + onChanged: viewModel.selectHomeserver, + child: ListView.builder( + itemCount: publicHomeservers.length, + itemBuilder: (context, i) { + final server = publicHomeservers[i]; + final website = server.website; + return Semantics( + identifier: 'homeserver_tile_$i', + child: RadioListTile.adaptive( + value: server, + enabled: + state.loginLoading.connectionState != + ConnectionState.waiting, + radioScaleFactor: + FluffyThemes.isColumnMode(context) || + { + TargetPlatform.iOS, + TargetPlatform.macOS, + }.contains(theme.platform) + ? 2 + : 1, + title: Row( + children: [ + Expanded( + child: Text(server.name ?? 'Unknown'), + ), + if (website != null) + SizedBox.square( + dimension: 32, + child: IconButton( + icon: const Icon( + Icons.open_in_new_outlined, + size: 16, + ), + onPressed: () => + launchUrlString(website), + ), + ), + ], + ), + subtitle: Column( + spacing: 4.0, + crossAxisAlignment: CrossAxisAlignment.start, + mainAxisSize: MainAxisSize.min, + children: [ + if (server.features?.isNotEmpty == true) + Wrap( + spacing: 4.0, + runSpacing: 4.0, + children: [ + ...?server.languages?.map( + (language) => Material( + borderRadius: + BorderRadius.circular( + AppConfig.borderRadius, + ), + color: theme + .colorScheme + .tertiaryContainer, + child: Padding( + padding: + const EdgeInsets.symmetric( + horizontal: 6.0, + vertical: 3.0, + ), + child: Text( + language, + style: TextStyle( + fontSize: 10, + color: theme + .colorScheme + .onTertiaryContainer, + ), + ), + ), + ), + ), + ...server.features!.map( + (feature) => Material( + borderRadius: + BorderRadius.circular( + AppConfig.borderRadius, + ), + color: theme + .colorScheme + .secondaryContainer, + child: Padding( + padding: + const EdgeInsets.symmetric( + horizontal: 6.0, + vertical: 3.0, + ), + child: Text( + feature, + style: TextStyle( + fontSize: 10, + color: theme + .colorScheme + .onSecondaryContainer, + ), + ), + ), + ), + ), + ], + ), + Text( + server.description ?? + 'A matrix homeserver', + ), + ], + ), + ), + ); + }, + ), + ), + ), + ) + else + Center(child: CircularProgressIndicator.adaptive()), + ], + ), + ), + bottomNavigationBar: AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: + selectedHomserver == null || + !publicHomeservers.contains(selectedHomserver) + ? const SizedBox.shrink() + : Material( + child: Padding( + padding: const EdgeInsets.all(16.0), + child: SafeArea( + child: Semantics( + identifier: 'connect_to_homeserver_button', + child: ElevatedButton( + style: ElevatedButton.styleFrom( + backgroundColor: theme.colorScheme.primary, + foregroundColor: theme.colorScheme.onPrimary, + ), + onPressed: + state.loginLoading.connectionState == + ConnectionState.waiting + ? null + : () => connectToHomeserverFlow( + selectedHomserver, + context, + viewModel.setLoginLoading, + signUp, + ), + child: + state.loginLoading.connectionState == + ConnectionState.waiting + ? const CircularProgressIndicator.adaptive() + : Text(L10n.of(context).continueText), + ), + ), + ), + ), + ), + ), + ); + }, + ); + } +} diff --git a/lib/pages/sign_in/utils/sort_homeservers.dart b/lib/pages/sign_in/utils/sort_homeservers.dart new file mode 100644 index 000000000..18f30dfce --- /dev/null +++ b/lib/pages/sign_in/utils/sort_homeservers.dart @@ -0,0 +1,24 @@ +import 'package:fluffychat/pages/sign_in/view_model/model/public_homeserver_data.dart'; + +int sortHomeservers(PublicHomeserverData a, PublicHomeserverData b) { + return _calcHomeserverScore(b).compareTo(_calcHomeserverScore(a)); +} + +int _calcHomeserverScore(PublicHomeserverData homeserver) { + var score = 0; + if (homeserver.description?.isNotEmpty == true) score++; + if (homeserver.website?.isNotEmpty == true) score++; + score += (homeserver.languages?.length ?? 0); + score += (homeserver.features?.length ?? 0); + score += (homeserver.onlineStatus ?? 0); + if (homeserver.ipv6 == true) score++; + if (homeserver.isp?.isNotEmpty == true) score++; + if (homeserver.privacy?.isNotEmpty == true) score++; + if (homeserver.rules?.isNotEmpty == true) score++; + if (homeserver.version?.isNotEmpty == true) score++; + if (homeserver.usingVanillaReg == true) score--; + if (homeserver.regLink != null) score--; + if (homeserver.regMethod != 'SSO') score--; + if (homeserver.regMethod == 'In-house Element') score--; + return score; +} diff --git a/lib/pages/sign_in/view_model/model/public_homeserver_data.dart b/lib/pages/sign_in/view_model/model/public_homeserver_data.dart new file mode 100644 index 000000000..4d484eb10 --- /dev/null +++ b/lib/pages/sign_in/view_model/model/public_homeserver_data.dart @@ -0,0 +1,79 @@ +class PublicHomeserverData { + final String? name; + final String? clientDomain; + final String? website; + final String? isp; + final String? staffJur; + final String? rules; + final String? privacy; + final bool? usingVanillaReg; + final String? description; + final String? regMethod; + final String? regLink; + final String? software; + final String? version; + final bool? captcha; + final bool? email; + final List? languages; + final List? features; + final int? onlineStatus; + final String? serverDomain; + final int? verStatus; + final int? roomDirectory; + final bool? slidingSync; + final bool? ipv6; + + PublicHomeserverData({ + this.name, + this.clientDomain, + this.website, + this.isp, + this.staffJur, + this.rules, + this.privacy, + this.usingVanillaReg, + this.description, + this.regMethod, + this.regLink, + this.software, + this.version, + this.captcha, + this.email, + this.languages, + this.features, + this.onlineStatus, + this.serverDomain, + this.verStatus, + this.roomDirectory, + this.slidingSync, + this.ipv6, + }); + + factory PublicHomeserverData.fromJson(Map json) { + return PublicHomeserverData( + name: json['name'], + clientDomain: json['client_domain'], + website: json['website'], + isp: json['isp'], + staffJur: json['staff_jur'], + rules: json['rules'], + privacy: json['privacy'], + usingVanillaReg: json['using_vanilla_reg'], + description: json['description'], + regMethod: json['reg_method'], + regLink: json['reg_link'], + software: json['software'], + version: json['version'], + captcha: json['captcha'], + email: json['email'], + languages: List.from(json['languages'] ?? []), + features: List.from(json['features'] ?? []), + onlineStatus: json['online_status'], + serverDomain: json['server_domain'], + verStatus: json['ver_status'], + roomDirectory: json['room_directory'], + slidingSync: json['sliding_sync'], + ipv6: json['ipv6'], + ); + } +} diff --git a/lib/pages/sign_in/view_model/sign_in_state.dart b/lib/pages/sign_in/view_model/sign_in_state.dart new file mode 100644 index 000000000..84213152e --- /dev/null +++ b/lib/pages/sign_in/view_model/sign_in_state.dart @@ -0,0 +1,32 @@ +import 'package:flutter/material.dart'; + +import 'package:fluffychat/pages/sign_in/view_model/model/public_homeserver_data.dart'; + +class SignInState { + final PublicHomeserverData? selectedHomeserver; + final AsyncSnapshot> publicHomeservers; + final List filteredPublicHomeservers; + final AsyncSnapshot loginLoading; + + const SignInState({ + this.selectedHomeserver, + this.publicHomeservers = const AsyncSnapshot.nothing(), + this.loginLoading = const AsyncSnapshot.nothing(), + this.filteredPublicHomeservers = const [], + }); + + SignInState copyWith({ + PublicHomeserverData? selectedHomeserver, + AsyncSnapshot>? publicHomeservers, + AsyncSnapshot? loginLoading, + List? filteredPublicHomeservers, + }) { + return SignInState( + selectedHomeserver: selectedHomeserver ?? this.selectedHomeserver, + publicHomeservers: publicHomeservers ?? this.publicHomeservers, + loginLoading: loginLoading ?? this.loginLoading, + filteredPublicHomeservers: + filteredPublicHomeservers ?? this.filteredPublicHomeservers, + ); + } +} diff --git a/lib/pages/sign_in/view_model/sign_in_view_model.dart b/lib/pages/sign_in/view_model/sign_in_view_model.dart new file mode 100644 index 000000000..cb4a41ae8 --- /dev/null +++ b/lib/pages/sign_in/view_model/sign_in_view_model.dart @@ -0,0 +1,111 @@ +import 'dart:convert'; + +import 'package:flutter/widgets.dart'; + +import 'package:collection/collection.dart'; +import 'package:matrix/matrix_api_lite/utils/logs.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/pages/sign_in/utils/sort_homeservers.dart'; +import 'package:fluffychat/pages/sign_in/view_model/model/public_homeserver_data.dart'; +import 'package:fluffychat/pages/sign_in/view_model/sign_in_state.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +class SignInViewModel extends ValueNotifier { + final MatrixState matrixService; + final bool signUp; + final TextEditingController filterTextController = TextEditingController(); + + SignInViewModel(this.matrixService, {required this.signUp}) + : super(SignInState()) { + refreshPublicHomeservers(); + filterTextController.addListener(_filterHomeservers); + } + + @override + void dispose() { + filterTextController.removeListener(_filterHomeservers); + super.dispose(); + } + + void _filterHomeservers() { + final filterText = filterTextController.text.trim().toLowerCase(); + final filteredPublicHomeservers = + value.publicHomeservers.data + ?.where( + (homeserver) => + homeserver.name?.toLowerCase().contains(filterText) ?? false, + ) + .toList() ?? + []; + if (Uri.tryParse(filterText) != null && + !filteredPublicHomeservers.any( + (homeserver) => homeserver.name == filterText, + )) { + filteredPublicHomeservers.add(PublicHomeserverData(name: filterText)); + } + + value = value.copyWith( + filteredPublicHomeservers: filteredPublicHomeservers, + ); + } + + Future refreshPublicHomeservers() async { + value = value.copyWith(publicHomeservers: AsyncSnapshot.waiting()); + final defaultHomeserverData = PublicHomeserverData( + name: AppSettings.defaultHomeserver.value, + ); + try { + final client = await matrixService.getLoginClient(); + final response = await client.httpClient.get(AppConfig.homeserverList); + final json = jsonDecode(response.body) as Map; + final homeserverJsonList = json['public_servers'] as List; + + final publicHomeservers = homeserverJsonList + .map((json) => PublicHomeserverData.fromJson(json)) + .toList(); + + if (signUp) { + publicHomeservers.removeWhere((server) { + return server.regMethod == null; + }); + } + + publicHomeservers.sort(sortHomeservers); + + final defaultServer = publicHomeservers.singleWhereOrNull( + (server) => server.name == AppSettings.defaultHomeserver.value, + ); + + if (defaultServer == null) { + publicHomeservers.insert(0, defaultHomeserverData); + } + + value = value.copyWith( + selectedHomeserver: value.selectedHomeserver ?? publicHomeservers.first, + publicHomeservers: AsyncSnapshot.withData( + ConnectionState.done, + publicHomeservers, + ), + ); + } catch (e, s) { + Logs().w('Unable to fetch public homeservers...', e, s); + value = value.copyWith( + selectedHomeserver: defaultHomeserverData, + publicHomeservers: AsyncSnapshot.withData(ConnectionState.done, [ + defaultHomeserverData, + ]), + ); + } + _filterHomeservers(); + } + + void selectHomeserver(PublicHomeserverData? publicHomeserverData) { + value = value.copyWith(selectedHomeserver: publicHomeserverData); + } + + void setLoginLoading(AsyncSnapshot loginLoading) { + value = value.copyWith(loginLoading: loginLoading); + } +} diff --git a/lib/pages/user_bottom_sheet/user_bottom_sheet.dart b/lib/pages/user_bottom_sheet/user_bottom_sheet.dart deleted file mode 100644 index 527915072..000000000 --- a/lib/pages/user_bottom_sheet/user_bottom_sheet.dart +++ /dev/null @@ -1,280 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:go_router/go_router.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/config/themes.dart'; -import 'package:fluffychat/widgets/permission_slider_dialog.dart'; -import '../../widgets/matrix.dart'; -import 'user_bottom_sheet_view.dart'; - -enum UserBottomSheetAction { - report, - mention, - ban, - kick, - unban, - message, - ignore, -} - -class LoadProfileBottomSheet extends StatelessWidget { - final String userId; - final BuildContext outerContext; - - const LoadProfileBottomSheet({ - super.key, - required this.userId, - required this.outerContext, - }); - - @override - Widget build(BuildContext context) { - return FutureBuilder( - future: Matrix.of(outerContext) - .client - .getUserProfile(userId) - .timeout(const Duration(seconds: 3)), - builder: (context, snapshot) { - if (snapshot.connectionState != ConnectionState.done && - snapshot.data != null) { - return Scaffold( - appBar: AppBar( - leading: CloseButton( - onPressed: Navigator.of(context, rootNavigator: false).pop, - ), - ), - body: const Center( - child: CircularProgressIndicator.adaptive(), - ), - ); - } - return UserBottomSheet( - outerContext: outerContext, - profile: Profile( - userId: userId, - avatarUrl: snapshot.data?.avatarUrl, - displayName: snapshot.data?.displayname, - ), - profileSearchError: snapshot.error, - ); - }, - ); - } -} - -class UserBottomSheet extends StatefulWidget { - final User? user; - final Profile? profile; - final Function? onMention; - final BuildContext outerContext; - final Object? profileSearchError; - - const UserBottomSheet({ - super.key, - this.user, - this.profile, - required this.outerContext, - this.onMention, - this.profileSearchError, - }) : assert(user != null || profile != null); - - @override - UserBottomSheetController createState() => UserBottomSheetController(); -} - -class UserBottomSheetController extends State { - void participantAction(UserBottomSheetAction action) async { - final user = widget.user; - final userId = user?.id ?? widget.profile?.userId; - if (userId == null) throw ('user or profile must not be null!'); - - switch (action) { - case UserBottomSheetAction.report: - if (user == null) throw ('User must not be null for this action!'); - - final score = await showConfirmationDialog( - context: context, - title: L10n.of(context)!.reportUser, - message: L10n.of(context)!.howOffensiveIsThisContent, - cancelLabel: L10n.of(context)!.cancel, - okLabel: L10n.of(context)!.ok, - actions: [ - AlertDialogAction( - key: -100, - label: L10n.of(context)!.extremeOffensive, - ), - AlertDialogAction( - key: -50, - label: L10n.of(context)!.offensive, - ), - AlertDialogAction( - key: 0, - label: L10n.of(context)!.inoffensive, - ), - ], - ); - if (score == null) return; - final reason = await showTextInputDialog( - useRootNavigator: false, - context: context, - title: L10n.of(context)!.whyDoYouWantToReportThis, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - textFields: [DialogTextField(hintText: L10n.of(context)!.reason)], - ); - if (reason == null || reason.single.isEmpty) return; - - final result = await showFutureLoadingDialog( - context: context, - future: () => Matrix.of(widget.outerContext).client.reportContent( - user.room.id, - user.id, - reason: reason.single, - score: score, - ), - ); - if (result.error != null) return; - ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.contentHasBeenReported)), - ); - break; - case UserBottomSheetAction.mention: - if (user == null) throw ('User must not be null for this action!'); - Navigator.of(context).pop(); - widget.onMention!(); - break; - case UserBottomSheetAction.ban: - if (user == null) throw ('User must not be null for this action!'); - if (await showOkCancelAlertDialog( - useRootNavigator: false, - context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.no, - message: L10n.of(context)!.banUserDescription, - ) == - OkCancelResult.ok) { - await showFutureLoadingDialog( - context: context, - future: () => user.ban(), - ); - Navigator.of(context).pop(); - } - break; - case UserBottomSheetAction.unban: - if (user == null) throw ('User must not be null for this action!'); - if (await showOkCancelAlertDialog( - useRootNavigator: false, - context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.no, - message: L10n.of(context)!.unbanUserDescription, - ) == - OkCancelResult.ok) { - await showFutureLoadingDialog( - context: context, - future: () => user.unban(), - ); - Navigator.of(context).pop(); - } - break; - case UserBottomSheetAction.kick: - if (user == null) throw ('User must not be null for this action!'); - if (await showOkCancelAlertDialog( - useRootNavigator: false, - context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.no, - message: L10n.of(context)!.kickUserDescription, - ) == - OkCancelResult.ok) { - await showFutureLoadingDialog( - context: context, - future: () => user.kick(), - ); - Navigator.of(context).pop(); - } - break; - case UserBottomSheetAction.message: - Navigator.of(context).pop(); - // Workaround for https://github.com/flutter/flutter/issues/27495 - await Future.delayed(FluffyThemes.animationDuration); - - final roomIdResult = await showFutureLoadingDialog( - context: widget.outerContext, - future: () => Matrix.of(widget.outerContext) - .client - .startDirectChat(user?.id ?? widget.profile!.userId), - ); - final roomId = roomIdResult.result; - if (roomId == null) return; - widget.outerContext.go('/rooms/$roomId'); - break; - case UserBottomSheetAction.ignore: - Navigator.of(context).pop(); - // Workaround for https://github.com/flutter/flutter/issues/27495 - await Future.delayed(FluffyThemes.animationDuration); - final userId = user?.id ?? widget.profile?.userId; - widget.outerContext - .go('/rooms/settings/security/ignorelist', extra: userId); - } - } - - void knockAccept() async { - final user = widget.user!; - final result = await showFutureLoadingDialog( - context: context, - future: () => user.room.invite(user.id), - ); - if (result.error != null) return; - Navigator.of(context).pop(); - } - - void knockDecline() async { - final user = widget.user!; - final result = await showFutureLoadingDialog( - context: context, - future: () => user.room.kick(user.id), - ); - if (result.error != null) return; - Navigator.of(context).pop(); - } - - void setPowerLevel(int? newLevel) async { - final user = widget.user; - if (user == null) throw ('User must not be null for this action!'); - - final level = newLevel ?? - await showPermissionChooser( - context, - currentLevel: user.powerLevel, - ); - if (level == null) return; - - if (level == 100) { - final consent = await showOkCancelAlertDialog( - useRootNavigator: false, - context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.no, - message: L10n.of(context)!.makeAdminDescription, - ); - if (consent != OkCancelResult.ok) return; - } - - await showFutureLoadingDialog( - context: context, - future: () => user.setPower(level), - ); - } - - @override - Widget build(BuildContext context) => UserBottomSheetView(this); -} diff --git a/lib/pages/user_bottom_sheet/user_bottom_sheet_view.dart b/lib/pages/user_bottom_sheet/user_bottom_sheet_view.dart deleted file mode 100644 index 9e72a4a3f..000000000 --- a/lib/pages/user_bottom_sheet/user_bottom_sheet_view.dart +++ /dev/null @@ -1,395 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_linkify/flutter_linkify.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/utils/date_time_extension.dart'; -import 'package:fluffychat/utils/fluffy_share.dart'; -import 'package:fluffychat/utils/url_launcher.dart'; -import 'package:fluffychat/widgets/avatar.dart'; -import 'package:fluffychat/widgets/presence_builder.dart'; -import '../../widgets/matrix.dart'; -import 'user_bottom_sheet.dart'; - -class UserBottomSheetView extends StatelessWidget { - final UserBottomSheetController controller; - - const UserBottomSheetView(this.controller, {super.key}); - - @override - Widget build(BuildContext context) { - final user = controller.widget.user; - final userId = (user?.id ?? controller.widget.profile?.userId)!; - final displayname = (user?.calcDisplayname() ?? - controller.widget.profile?.displayName ?? - controller.widget.profile?.userId.localpart)!; - final avatarUrl = user?.avatarUrl ?? controller.widget.profile?.avatarUrl; - - final client = Matrix.of(controller.widget.outerContext).client; - final profileSearchError = controller.widget.profileSearchError; - return SafeArea( - child: Scaffold( - appBar: AppBar( - leading: CloseButton( - onPressed: Navigator.of(context, rootNavigator: false).pop, - ), - centerTitle: false, - title: Column( - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - Text(displayname), - PresenceBuilder( - userId: userId, - client: client, - builder: (context, presence) { - if (presence == null || - (presence.presence == PresenceType.offline && - presence.lastActiveTimestamp == null)) { - return const SizedBox.shrink(); - } - - final dotColor = presence.presence.isOnline - ? Colors.green - : presence.presence.isUnavailable - ? Colors.orange - : Colors.grey; - - final lastActiveTimestamp = presence.lastActiveTimestamp; - - return Row( - mainAxisSize: MainAxisSize.min, - children: [ - Container( - width: 8, - height: 8, - margin: const EdgeInsets.only(right: 8), - decoration: BoxDecoration( - color: dotColor, - borderRadius: BorderRadius.circular(16), - ), - ), - if (presence.currentlyActive == true) - Text( - L10n.of(context)!.currentlyActive, - overflow: TextOverflow.ellipsis, - style: Theme.of(context).textTheme.bodySmall, - ) - else if (lastActiveTimestamp != null) - Text( - L10n.of(context)!.lastActiveAgo( - lastActiveTimestamp.localizedTimeShort(context), - ), - overflow: TextOverflow.ellipsis, - style: Theme.of(context).textTheme.bodySmall, - ), - ], - ); - }, - ), - ], - ), - actions: [ - if (userId != client.userID && - !client.ignoredUsers.contains(userId)) - Padding( - padding: const EdgeInsets.only(right: 8.0), - child: IconButton( - icon: const Icon(Icons.block_outlined), - tooltip: L10n.of(context)!.block, - onPressed: () => controller - .participantAction(UserBottomSheetAction.ignore), - ), - ), - ], - ), - body: StreamBuilder( - stream: user?.room.client.onSync.stream.where( - (syncUpdate) => - syncUpdate.rooms?.join?[user.room.id]?.timeline?.events?.any( - (state) => state.type == EventTypes.RoomPowerLevels, - ) ?? - false, - ), - builder: (context, snapshot) { - return ListView( - children: [ - if (user?.membership == Membership.knock) - Padding( - padding: const EdgeInsets.all(12.0), - child: Material( - color: - // ignore: deprecated_member_use - Theme.of(context).colorScheme.surfaceVariant, - borderRadius: - BorderRadius.circular(AppConfig.borderRadius), - child: ListTile( - minVerticalPadding: 16, - title: Padding( - padding: const EdgeInsets.only(bottom: 12.0), - child: Text( - L10n.of(context)! - .userWouldLikeToChangeTheChat(displayname), - ), - ), - subtitle: Row( - children: [ - TextButton.icon( - style: TextButton.styleFrom( - backgroundColor: - Theme.of(context).colorScheme.surface, - foregroundColor: - Theme.of(context).colorScheme.primary, - ), - onPressed: controller.knockAccept, - icon: const Icon(Icons.check_outlined), - label: Text(L10n.of(context)!.accept), - ), - const SizedBox(width: 12), - TextButton.icon( - style: TextButton.styleFrom( - backgroundColor: Theme.of(context) - .colorScheme - .errorContainer, - foregroundColor: Theme.of(context) - .colorScheme - .onErrorContainer, - ), - onPressed: controller.knockDecline, - icon: const Icon(Icons.cancel_outlined), - label: Text(L10n.of(context)!.decline), - ), - ], - ), - ), - ), - ), - Row( - children: [ - Padding( - padding: const EdgeInsets.all(16.0), - child: Material( - elevation: Theme.of(context) - .appBarTheme - .scrolledUnderElevation ?? - 4, - shadowColor: Theme.of(context).appBarTheme.shadowColor, - shape: RoundedRectangleBorder( - side: BorderSide( - color: Theme.of(context).dividerColor, - ), - borderRadius: BorderRadius.circular( - Avatar.defaultSize * 2.5, - ), - ), - child: Avatar( - mxContent: avatarUrl, - name: displayname, - size: Avatar.defaultSize * 2.5, - ), - ), - ), - Expanded( - child: Column( - mainAxisAlignment: MainAxisAlignment.center, - crossAxisAlignment: CrossAxisAlignment.start, - children: [ - TextButton.icon( - onPressed: () => FluffyShare.share( - 'https://matrix.to/#/$userId', - context, - ), - icon: Icon( - Icons.adaptive.share_outlined, - size: 16, - ), - style: TextButton.styleFrom( - foregroundColor: - Theme.of(context).colorScheme.onSurface, - ), - label: Text( - displayname, - maxLines: 1, - overflow: TextOverflow.ellipsis, - // style: const TextStyle(fontSize: 18), - ), - ), - TextButton.icon( - onPressed: () => FluffyShare.share( - userId, - context, - copyOnly: true, - ), - icon: const Icon( - Icons.copy_outlined, - size: 14, - ), - style: TextButton.styleFrom( - foregroundColor: - Theme.of(context).colorScheme.secondary, - ), - label: Text( - userId, - maxLines: 1, - overflow: TextOverflow.ellipsis, - // style: const TextStyle(fontSize: 12), - ), - ), - ], - ), - ), - ], - ), - if (userId != client.userID) - Padding( - padding: const EdgeInsets.symmetric( - horizontal: 16.0, - vertical: 8.0, - ), - child: ElevatedButton.icon( - onPressed: () => controller - .participantAction(UserBottomSheetAction.message), - icon: const Icon(Icons.forum_outlined), - label: Text( - controller.widget.user == null - ? L10n.of(context)!.startConversation - : L10n.of(context)!.sendAMessage, - ), - ), - ), - PresenceBuilder( - userId: userId, - client: client, - builder: (context, presence) { - final status = presence?.statusMsg; - if (status == null || status.isEmpty) { - return const SizedBox.shrink(); - } - return ListTile( - title: SelectableLinkify( - text: status, - style: const TextStyle(fontSize: 16), - options: const LinkifyOptions(humanize: false), - linkStyle: const TextStyle( - color: Colors.blueAccent, - decorationColor: Colors.blueAccent, - ), - onOpen: (url) => - UrlLauncher(context, url.url).launchUrl(), - ), - ); - }, - ), - if (controller.widget.onMention != null) - ListTile( - leading: const Icon(Icons.alternate_email_outlined), - title: Text(L10n.of(context)!.mention), - onTap: () => controller - .participantAction(UserBottomSheetAction.mention), - ), - if (user != null) ...[ - Divider(color: Theme.of(context).dividerColor), - ListTile( - title: Text( - '${L10n.of(context)!.userRole} (${user.powerLevel})', - ), - leading: const Icon(Icons.person_outlined), - trailing: Material( - borderRadius: - BorderRadius.circular(AppConfig.borderRadius / 2), - color: Theme.of(context).colorScheme.onInverseSurface, - child: DropdownButton( - onChanged: user.canChangeUserPowerLevel || - // Workaround until https://github.com/famedly/matrix-dart-sdk/pull/1765 - (user.room.canChangePowerLevel && - user.id == user.room.client.userID) - ? controller.setPowerLevel - : null, - value: {0, 50, 100}.contains(user.powerLevel) - ? user.powerLevel - : null, - padding: const EdgeInsets.symmetric(horizontal: 8.0), - borderRadius: - BorderRadius.circular(AppConfig.borderRadius / 2), - underline: const SizedBox.shrink(), - items: [ - DropdownMenuItem( - value: 0, - child: Text(L10n.of(context)!.user), - ), - DropdownMenuItem( - value: 50, - child: Text(L10n.of(context)!.moderator), - ), - DropdownMenuItem( - value: 100, - child: Text(L10n.of(context)!.admin), - ), - DropdownMenuItem( - value: null, - child: Text(L10n.of(context)!.custom), - ), - ], - ), - ), - ), - Divider(color: Theme.of(context).dividerColor), - ], - if (user != null && user.canKick) - ListTile( - textColor: Theme.of(context).colorScheme.error, - iconColor: Theme.of(context).colorScheme.error, - title: Text(L10n.of(context)!.kickFromChat), - leading: const Icon(Icons.exit_to_app_outlined), - onTap: () => controller - .participantAction(UserBottomSheetAction.kick), - ), - if (user != null && - user.canBan && - user.membership != Membership.ban) - ListTile( - textColor: Theme.of(context).colorScheme.onErrorContainer, - iconColor: Theme.of(context).colorScheme.onErrorContainer, - title: Text(L10n.of(context)!.banFromChat), - leading: const Icon(Icons.warning_sharp), - onTap: () => - controller.participantAction(UserBottomSheetAction.ban), - ) - else if (user != null && - user.canBan && - user.membership == Membership.ban) - ListTile( - title: Text(L10n.of(context)!.unbanFromChat), - leading: const Icon(Icons.warning_outlined), - onTap: () => controller - .participantAction(UserBottomSheetAction.unban), - ), - if (user != null && user.id != client.userID) - ListTile( - textColor: Theme.of(context).colorScheme.onErrorContainer, - iconColor: Theme.of(context).colorScheme.onErrorContainer, - title: Text(L10n.of(context)!.reportUser), - leading: const Icon(Icons.report_outlined), - onTap: () => controller - .participantAction(UserBottomSheetAction.report), - ), - if (profileSearchError != null) - ListTile( - leading: const Icon( - Icons.warning_outlined, - color: Colors.orange, - ), - subtitle: Text( - L10n.of(context)!.profileNotFound, - style: const TextStyle(color: Colors.orange), - ), - ), - ], - ); - }, - ), - ), - ); - } -} diff --git a/lib/utils/account_bundles.dart b/lib/utils/account_bundles.dart index 8bd296e05..7d5619267 100644 --- a/lib/utils/account_bundles.dart +++ b/lib/utils/account_bundles.dart @@ -7,9 +7,9 @@ class AccountBundles { AccountBundles({this.prefix, this.bundles}); AccountBundles.fromJson(Map json) - : prefix = json.tryGet('prefix'), - bundles = json['bundles'] is List - ? json['bundles'] + : prefix = json.tryGet('prefix'), + bundles = json['bundles'] is List + ? json['bundles'] .map((b) { try { return AccountBundle.fromJson(b); @@ -19,13 +19,12 @@ class AccountBundles { }) .whereType() .toList() - : null; + : null; Map toJson() => { - if (prefix != null) 'prefix': prefix, - if (bundles != null) - 'bundles': bundles!.map((v) => v.toJson()).toList(), - }; + if (prefix != null) 'prefix': prefix, + if (bundles != null) 'bundles': bundles!.map((v) => v.toJson()).toList(), + }; } class AccountBundle { @@ -35,13 +34,13 @@ class AccountBundle { AccountBundle({this.name, this.priority}); AccountBundle.fromJson(Map json) - : name = json.tryGet('name'), - priority = json.tryGet('priority'); + : name = json.tryGet('name'), + priority = json.tryGet('priority'); Map toJson() => { - if (name != null) 'name': name, - if (priority != null) 'priority': priority, - }; + if (name != null) 'name': name, + if (priority != null) 'priority': priority, + }; } const accountBundlesType = 'im.fluffychat.account_bundles'; @@ -50,24 +49,21 @@ extension AccountBundlesExtension on Client { List get accountBundles { List? ret; if (accountData.containsKey(accountBundlesType)) { - ret = AccountBundles.fromJson(accountData[accountBundlesType]!.content) - .bundles; + ret = AccountBundles.fromJson( + accountData[accountBundlesType]!.content, + ).bundles; } ret ??= []; if (ret.isEmpty) { - ret.add( - AccountBundle( - name: userID, - priority: 0, - ), - ); + ret.add(AccountBundle(name: userID, priority: 0)); } return ret; } Future setAccountBundle(String name, [int? priority]) async { - final data = - AccountBundles.fromJson(accountData[accountBundlesType]?.content ?? {}); + final data = AccountBundles.fromJson( + accountData[accountBundlesType]?.content ?? {}, + ); var foundBundle = false; final bundles = data.bundles ??= []; for (final bundle in bundles) { @@ -87,16 +83,18 @@ extension AccountBundlesExtension on Client { if (!accountData.containsKey(accountBundlesType)) { return; // nothing to do } - final data = - AccountBundles.fromJson(accountData[accountBundlesType]!.content); + final data = AccountBundles.fromJson( + accountData[accountBundlesType]!.content, + ); if (data.bundles == null) return; data.bundles!.removeWhere((b) => b.name == name); await setAccountData(userID!, accountBundlesType, data.toJson()); } String get sendPrefix { - final data = - AccountBundles.fromJson(accountData[accountBundlesType]?.content ?? {}); + final data = AccountBundles.fromJson( + accountData[accountBundlesType]?.content ?? {}, + ); return data.prefix!; } } diff --git a/lib/utils/account_config.dart b/lib/utils/account_config.dart index ee80e246e..7ac107376 100644 --- a/lib/utils/account_config.dart +++ b/lib/utils/account_config.dart @@ -8,19 +8,11 @@ extension ApplicationAccountConfigExtension on Client { accountData[accountDataKey]?.content ?? {}, ); - Future setApplicationAccountConfig( - ApplicationAccountConfig config, - ) => - setAccountData( - userID!, - accountDataKey, - config.toJson(), - ); + Future setApplicationAccountConfig(ApplicationAccountConfig config) => + setAccountData(userID!, accountDataKey, config.toJson()); /// Only updates the specified values in ApplicationAccountConfig - Future updateApplicationAccountConfig( - ApplicationAccountConfig config, - ) { + Future updateApplicationAccountConfig(ApplicationAccountConfig config) { final currentConfig = applicationAccountConfig; return setAccountData( userID!, @@ -29,6 +21,7 @@ extension ApplicationAccountConfigExtension on Client { wallpaperUrl: config.wallpaperUrl ?? currentConfig.wallpaperUrl, wallpaperOpacity: config.wallpaperOpacity ?? currentConfig.wallpaperOpacity, + wallpaperBlur: config.wallpaperBlur ?? currentConfig.wallpaperBlur, ).toJson(), ); } @@ -37,10 +30,12 @@ extension ApplicationAccountConfigExtension on Client { class ApplicationAccountConfig { final Uri? wallpaperUrl; final double? wallpaperOpacity; + final double? wallpaperBlur; const ApplicationAccountConfig({ this.wallpaperUrl, this.wallpaperOpacity, + this.wallpaperBlur, }); static double _sanitizedOpacity(double? opacity) { @@ -54,12 +49,15 @@ class ApplicationAccountConfig { wallpaperUrl: json['wallpaper_url'] is String ? Uri.tryParse(json['wallpaper_url']) : null, - wallpaperOpacity: - _sanitizedOpacity(json.tryGet('wallpaper_opacity')), + wallpaperOpacity: _sanitizedOpacity( + json.tryGet('wallpaper_opacity'), + ), + wallpaperBlur: json.tryGet('wallpaper_blur'), ); Map toJson() => { - 'wallpaper_url': wallpaperUrl?.toString(), - 'wallpaper_opacity': wallpaperOpacity, - }; + 'wallpaper_url': wallpaperUrl?.toString(), + 'wallpaper_opacity': wallpaperOpacity, + 'wallpaper_blur': wallpaperBlur, + }; } diff --git a/lib/utils/adaptive_bottom_sheet.dart b/lib/utils/adaptive_bottom_sheet.dart index cfe487ffd..a0e187d3e 100644 --- a/lib/utils/adaptive_bottom_sheet.dart +++ b/lib/utils/adaptive_bottom_sheet.dart @@ -1,3 +1,5 @@ +import 'dart:math'; + import 'package:flutter/material.dart'; import 'package:fluffychat/config/app_config.dart'; @@ -8,24 +10,45 @@ Future showAdaptiveBottomSheet({ required Widget Function(BuildContext) builder, bool isDismissible = true, bool isScrollControlled = true, - double maxHeight = 480.0, -}) => - showModalBottomSheet( + bool useRootNavigator = true, +}) { + if (FluffyThemes.isColumnMode(context)) { + return showDialog( context: context, - builder: builder, - // this sadly is ugly on desktops but otherwise breaks `.of(context)` calls - useRootNavigator: false, - isDismissible: isDismissible, - isScrollControlled: isScrollControlled, - constraints: BoxConstraints( - maxHeight: maxHeight, - maxWidth: FluffyThemes.columnWidth * 1.5, - ), - clipBehavior: Clip.hardEdge, - shape: const RoundedRectangleBorder( - borderRadius: BorderRadius.only( - topLeft: Radius.circular(AppConfig.borderRadius), - topRight: Radius.circular(AppConfig.borderRadius), + useRootNavigator: useRootNavigator, + barrierDismissible: isDismissible, + useSafeArea: true, + builder: (context) => Center( + child: Container( + margin: const EdgeInsets.all(16), + constraints: const BoxConstraints(maxWidth: 480, maxHeight: 720), + child: Material( + elevation: Theme.of(context).dialogTheme.elevation ?? 4, + shadowColor: Theme.of(context).dialogTheme.shadowColor, + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + color: Theme.of(context).scaffoldBackgroundColor, + clipBehavior: Clip.hardEdge, + child: builder(context), + ), ), ), ); + } + + return showModalBottomSheet( + context: context, + builder: (context) => ConstrainedBox( + constraints: BoxConstraints( + maxHeight: + MediaQuery.viewInsetsOf(context).bottom + + min(MediaQuery.sizeOf(context).height - 32, 600), + ), + child: builder(context), + ), + useSafeArea: true, + useRootNavigator: useRootNavigator, + isDismissible: isDismissible, + isScrollControlled: isScrollControlled, + clipBehavior: Clip.hardEdge, + ); +} diff --git a/lib/utils/background_push.dart b/lib/utils/background_push.dart index 039dde895..2713073b4 100644 --- a/lib/utils/background_push.dart +++ b/lib/utils/background_push.dart @@ -20,17 +20,22 @@ import 'dart:async'; import 'dart:convert'; import 'dart:io'; +import 'dart:isolate'; +import 'dart:ui'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; -import 'package:flutter_app_badger/flutter_app_badger.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_local_notifications/flutter_local_notifications.dart'; +import 'package:flutter_new_badger/flutter_new_badger.dart'; import 'package:http/http.dart' as http; import 'package:matrix/matrix.dart'; import 'package:unifiedpush/unifiedpush.dart'; +import 'package:unifiedpush_ui/unifiedpush_ui.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/main.dart'; +import 'package:fluffychat/utils/notification_background_handler.dart'; import 'package:fluffychat/utils/push_helper.dart'; import 'package:fluffychat/widgets/fluffy_chat_app.dart'; import '../config/app_config.dart'; @@ -38,11 +43,7 @@ import '../config/setting_keys.dart'; import '../widgets/matrix.dart'; import 'platform_infos.dart'; -//import 'package:fcm_shared_isolate/fcm_shared_isolate.dart'; - -class NoTokenException implements Exception { - String get cause => 'Cannot get firebase token'; -} +//import 'package:fcm_shared_isolate/fcm_shared_isolate.dart'; class BackgroundPush { static BackgroundPush? _instance; @@ -57,43 +58,99 @@ class BackgroundPush { Future loadLocale() async { final context = matrix?.context; // inspired by _lookupL10n in .dart_tool/flutter_gen/gen_l10n/l10n.dart - l10n ??= (context != null ? L10n.of(context) : null) ?? + l10n ??= + (context != null ? L10n.of(context) : null) ?? (await L10n.delegate.load(PlatformDispatcher.instance.locale)); } final pendingTests = >{}; + bool firebaseEnabled = false; - final dynamic firebase = null; //FcmSharedIsolate(); + //final firebase = FcmSharedIsolate(); DateTime? lastReceivedPush; bool upAction = false; - BackgroundPush._(this.client) { - firebase?.setListeners( - onMessage: (message) => pushHelper( - PushNotification.fromJson( - Map.from(message['data'] ?? message), + Future _init() async { + //firebaseEnabled = true; + try { + mainIsolateReceivePort?.listen((message) async { + try { + await notificationTap( + NotificationResponseJson.fromJsonString(message), + client: client, + router: FluffyChatApp.router, + l10n: l10n, + ); + } catch (e, s) { + Logs().wtf('Main Notification Tap crashed', e, s); + } + }); + if (PlatformInfos.isAndroid) { + final port = ReceivePort(); + IsolateNameServer.removePortNameMapping('background_tab_port'); + IsolateNameServer.registerPortWithName( + port.sendPort, + 'background_tab_port', + ); + port.listen((message) async { + try { + await notificationTap( + NotificationResponseJson.fromJsonString(message), + client: client, + router: FluffyChatApp.router, + l10n: l10n, + ); + } catch (e, s) { + Logs().wtf('Main Notification Tap crashed', e, s); + } + }); + } + await _flutterLocalNotificationsPlugin.initialize( + settings: const InitializationSettings( + android: AndroidInitializationSettings('notifications_icon'), + iOS: DarwinInitializationSettings(), ), - client: client, - l10n: l10n, - activeRoomId: matrix?.activeRoomId, - onSelectNotification: goToRoom, - ), - ); - if (Platform.isAndroid) { - UnifiedPush.initialize( - onNewEndpoint: _newUpEndpoint, - onRegistrationFailed: _upUnregistered, - onUnregistered: _upUnregistered, - onMessage: _onUpMessage, + onDidReceiveNotificationResponse: (response) => notificationTap( + response, + client: client, + router: FluffyChatApp.router, + l10n: l10n, + ), + onDidReceiveBackgroundNotificationResponse: notificationTapBackground, ); + Logs().v('Flutter Local Notifications initialized'); + //firebase.setListeners( + // onMessage: (message) => pushHelper( + // PushNotification.fromJson( + // Map.from(message['data'] ?? message), + // ), + // client: client, + // l10n: l10n, + // activeRoomId: matrix?.activeRoomId, + // flutterLocalNotificationsPlugin: _flutterLocalNotificationsPlugin, + // ), + //); + if (Platform.isAndroid) { + await UnifiedPush.initialize( + onNewEndpoint: _newUpEndpoint, + onRegistrationFailed: (_, i) => _upUnregistered(i), + onUnregistered: _upUnregistered, + onMessage: _onUpMessage, + ); + } + } catch (e, s) { + Logs().e('Unable to initialize Flutter local notifications', e, s); } } + BackgroundPush._(this.client) { + _init(); + } + factory BackgroundPush.clientOnly(Client client) { - _instance ??= BackgroundPush._(client); - return _instance!; + return _instance ??= BackgroundPush._(client); } factory BackgroundPush( @@ -109,7 +166,7 @@ class BackgroundPush { Future cancelNotification(String roomId) async { Logs().v('Cancel notification for room', roomId); - await FlutterLocalNotificationsPlugin().cancel(roomId.hashCode); + await _flutterLocalNotificationsPlugin.cancel(id: roomId.hashCode); // Workaround for app icon badge not updating if (Platform.isIOS) { @@ -117,9 +174,9 @@ class BackgroundPush { .where((room) => room.isUnreadOrInvited && room.id != roomId) .length; if (unreadCount == 0) { - FlutterAppBadger.removeBadge(); + FlutterNewBadger.removeBadge(); } else { - FlutterAppBadger.updateBadgeCount(unreadCount); + FlutterNewBadger.setBadge(unreadCount); } return; } @@ -132,16 +189,19 @@ class BackgroundPush { bool useDeviceSpecificAppId = false, }) async { if (PlatformInfos.isIOS) { - await firebase?.requestPermission(); - } else if (PlatformInfos.isAndroid) { + //await firebase.requestPermission(); + } + if (PlatformInfos.isAndroid) { _flutterLocalNotificationsPlugin .resolvePlatformSpecificImplementation< - AndroidFlutterLocalNotificationsPlugin>() + AndroidFlutterLocalNotificationsPlugin + >() ?.requestNotificationsPermission(); } final clientName = PlatformInfos.clientName; oldTokens ??= {}; - final pushers = await (client.getPushers().catchError((e) { + final pushers = + await (client.getPushers().catchError((e) { Logs().w('[Push] Unable to request pushers', e); return []; })) ?? @@ -169,11 +229,10 @@ class BackgroundPush { currentPushers.first.lang == 'en' && currentPushers.first.data.url.toString() == gatewayUrl && currentPushers.first.data.format == - AppConfig.pushNotificationsPusherFormat && - mapEquals( - currentPushers.single.data.additionalProperties, - {"data_message": pusherDataMessageFormat}, - )) { + AppSettings.pushNotificationsPusherFormat.value && + mapEquals(currentPushers.single.data.additionalProperties, { + 'data_message': pusherDataMessageFormat, + })) { Logs().i('[Push] Pusher already set'); } else { Logs().i('Need to set new pusher'); @@ -209,8 +268,8 @@ class BackgroundPush { lang: 'en', data: PusherData( url: Uri.parse(gatewayUrl!), - format: AppConfig.pushNotificationsPusherFormat, - additionalProperties: {"data_message": pusherDataMessageFormat}, + format: AppSettings.pushNotificationsPusherFormat.value, + additionalProperties: {'data_message': pusherDataMessageFormat}, ), kind: 'http', ), @@ -225,13 +284,13 @@ class BackgroundPush { final pusherDataMessageFormat = Platform.isAndroid ? 'android' : Platform.isIOS - ? 'ios' - : null; + ? 'ios' + : null; static bool _wentToRoomOnStartup = false; Future setupPush() async { - Logs().d("SetupPush"); + Logs().d('SetupPush'); if (client.onLoginStateChanged.value != LoginState.loggedIn || !PlatformInfos.isMobile || matrix == null) { @@ -250,16 +309,24 @@ class BackgroundPush { } // ignore: unawaited_futures - _flutterLocalNotificationsPlugin - .getNotificationAppLaunchDetails() - .then((details) { + _flutterLocalNotificationsPlugin.getNotificationAppLaunchDetails().then(( + details, + ) { if (details == null || !details.didNotificationLaunchApp || _wentToRoomOnStartup) { return; } _wentToRoomOnStartup = true; - goToRoom(details.notificationResponse); + final response = details.notificationResponse; + if (response != null) { + notificationTap( + response, + client: client, + router: FluffyChatApp.router, + l10n: l10n, + ); + } }); } @@ -267,7 +334,7 @@ class BackgroundPush { if (matrix == null) { return; } - if ((matrix?.store.getBool(SettingKeys.showNoGoogle) ?? false) == true) { + if (AppSettings.showNoGoogle.value) { return; } await loadLocale(); @@ -275,9 +342,7 @@ class BackgroundPush { if (PlatformInfos.isAndroid) { onFcmError?.call( l10n!.noGoogleServicesWarning, - link: Uri.parse( - AppConfig.enablePushTutorial, - ), + link: Uri.parse(AppConfig.enablePushTutorial), ); return; } @@ -289,7 +354,7 @@ class BackgroundPush { Logs().v('Setup firebase'); if (_fcmToken?.isEmpty ?? true) { try { - _fcmToken = await firebase?.getToken(); + //_fcmToken = await firebase.getToken(); if (_fcmToken == null) throw ('PushToken is null'); } catch (e, s) { Logs().w('[Push] cannot get token', e, e is String ? null : s); @@ -298,35 +363,23 @@ class BackgroundPush { } } await setupPusher( - gatewayUrl: AppConfig.pushNotificationsGatewayUrl, + gatewayUrl: AppSettings.pushNotificationsGatewayUrl.value, token: _fcmToken, ); } - Future goToRoom(NotificationResponse? response) async { - try { - final roomId = response?.payload; - Logs().v('[Push] Attempting to go to room $roomId...'); - if (roomId == null) { - return; - } - await client.roomsLoading; - await client.accountDataLoading; - FluffyChatApp.router.go( - client.getRoomById(roomId)?.membership == Membership.invite - ? '/rooms' - : '/rooms/$roomId', - ); - } catch (e, s) { - Logs().e('[Push] Failed to open room', e, s); - } - } - Future setupUp() async { - await UnifiedPush.registerAppWithDialog(matrix!.context); + await UnifiedPushUi( + context: matrix!.context, + instances: ['default'], + unifiedPushFunctions: UPFunctions(), + showNoDistribDialog: false, + onNoDistribDialogDismissed: () {}, // TODO: Implement me + ).registerAppWithDialog(); } - Future _newUpEndpoint(String newEndpoint, String i) async { + Future _newUpEndpoint(PushEndpoint newPushEndpoint, String i) async { + final newEndpoint = newPushEndpoint.url; upAction = true; if (newEndpoint.isEmpty) { await _upUnregistered(i); @@ -336,15 +389,13 @@ class BackgroundPush { 'https://matrix.gateway.unifiedpush.org/_matrix/push/v1/notify'; try { final url = Uri.parse(newEndpoint) - .replace( - path: '/_matrix/push/v1/notify', - query: '', - ) + .replace(path: '/_matrix/push/v1/notify', query: '') .toString() .split('?') .first; - final res = - json.decode(utf8.decode((await http.get(Uri.parse(url))).bodyBytes)); + final res = json.decode( + utf8.decode((await http.get(Uri.parse(url))).bodyBytes), + ); if (res['gateway'] == 'matrix' || (res['unifiedpush'] is Map && res['unifiedpush']['gateway'] == 'matrix')) { @@ -358,8 +409,8 @@ class BackgroundPush { Logs().i('[Push] UnifiedPush using endpoint $endpoint'); final oldTokens = {}; try { - final fcmToken = await firebase?.getToken(); - oldTokens.add(fcmToken); + //final fcmToken = await firebase.getToken(); + //oldTokens.add(fcmToken); } catch (_) {} await setupPusher( gatewayUrl: endpoint, @@ -367,26 +418,27 @@ class BackgroundPush { oldTokens: oldTokens, useDeviceSpecificAppId: true, ); - await matrix?.store.setString(SettingKeys.unifiedPushEndpoint, newEndpoint); - await matrix?.store.setBool(SettingKeys.unifiedPushRegistered, true); + await AppSettings.unifiedPushEndpoint.setItem(newEndpoint); + await AppSettings.unifiedPushRegistered.setItem(true); } Future _upUnregistered(String i) async { upAction = true; Logs().i('[Push] Removing UnifiedPush endpoint...'); - final oldEndpoint = - matrix?.store.getString(SettingKeys.unifiedPushEndpoint); - await matrix?.store.setBool(SettingKeys.unifiedPushRegistered, false); - await matrix?.store.remove(SettingKeys.unifiedPushEndpoint); - if (oldEndpoint?.isNotEmpty ?? false) { + final oldEndpoint = AppSettings.unifiedPushEndpoint.value; + await AppSettings.unifiedPushEndpoint.setItem( + AppSettings.unifiedPushEndpoint.defaultValue, + ); + await AppSettings.unifiedPushRegistered.setItem(false); + if (oldEndpoint.isNotEmpty) { // remove the old pusher - await setupPusher( - oldTokens: {oldEndpoint}, - ); + await setupPusher(oldTokens: {oldEndpoint}); } } - Future _onUpMessage(Uint8List message, String i) async { + Future _onUpMessage(PushMessage pushMessage, String i) async { + Logs().wtf('Push Notification from UP received', pushMessage); + final message = pushMessage.content; upAction = true; final data = Map.from( json.decode(utf8.decode(message))['notification'], @@ -398,6 +450,35 @@ class BackgroundPush { client: client, l10n: l10n, activeRoomId: matrix?.activeRoomId, + flutterLocalNotificationsPlugin: _flutterLocalNotificationsPlugin, + useNotificationActions: + false, // Buggy with UP: https://codeberg.org/UnifiedPush/flutter-connector/issues/34 ); } } + +class UPFunctions extends UnifiedPushFunctions { + final List features = [ + /*list of features*/ + ]; + + @override + Future getDistributor() async { + return await UnifiedPush.getDistributor(); + } + + @override + Future> getDistributors() async { + return await UnifiedPush.getDistributors(features); + } + + @override + Future registerApp(String instance) async { + await UnifiedPush.register(instance: instance, features: features); + } + + @override + Future saveDistributor(String distributor) async { + await UnifiedPush.saveDistributor(distributor); + } +} diff --git a/lib/utils/client_download_content_extension.dart b/lib/utils/client_download_content_extension.dart new file mode 100644 index 000000000..24a5868da --- /dev/null +++ b/lib/utils/client_download_content_extension.dart @@ -0,0 +1,104 @@ +import 'dart:math' show min; +import 'dart:typed_data'; +import 'dart:ui'; + +import 'package:matrix/matrix.dart'; + +extension ClientDownloadContentExtension on Client { + Future downloadMxcCached( + Uri mxc, { + num? width, + num? height, + bool isThumbnail = false, + bool? animated, + ThumbnailMethod? thumbnailMethod, + bool rounded = false, + }) async { + // To stay compatible with previous storeKeys: + final cacheKey = isThumbnail + // ignore: deprecated_member_use + ? mxc.getThumbnail( + this, + width: width, + height: height, + animated: animated, + method: thumbnailMethod, + ) + : mxc; + + final cachedData = await database.getFile(cacheKey); + if (cachedData != null) return cachedData; + + final httpUri = isThumbnail + ? await mxc.getThumbnailUri( + this, + width: width, + height: height, + animated: animated, + method: thumbnailMethod, + ) + : await mxc.getDownloadUri(this); + + final response = await httpClient.get( + httpUri, + headers: accessToken == null + ? null + : {'authorization': 'Bearer $accessToken'}, + ); + if (response.statusCode != 200) { + throw Exception(); + } + var imageData = response.bodyBytes; + + if (rounded) { + imageData = await _convertToCircularImage( + imageData, + min(width ?? 64, height ?? 64).round(), + ); + } + + await database.storeFile(cacheKey, imageData, 0); + + return imageData; + } +} + +Future _convertToCircularImage( + Uint8List imageBytes, + int size, +) async { + final codec = await instantiateImageCodec(imageBytes); + final frame = await codec.getNextFrame(); + final originalImage = frame.image; + + final recorder = PictureRecorder(); + final canvas = Canvas(recorder); + + final paint = Paint(); + final rect = Rect.fromLTWH(0, 0, size.toDouble(), size.toDouble()); + + final clipPath = Path() + ..addOval( + Rect.fromCircle(center: Offset(size / 2, size / 2), radius: size / 2), + ); + + canvas.clipPath(clipPath); + + canvas.drawImageRect( + originalImage, + Rect.fromLTWH( + 0, + 0, + originalImage.width.toDouble(), + originalImage.height.toDouble(), + ), + rect, + paint, + ); + + final picture = recorder.endRecording(); + final circularImage = await picture.toImage(size, size); + + final byteData = await circularImage.toByteData(format: ImageByteFormat.png); + return byteData!.buffer.asUint8List(); +} diff --git a/lib/utils/client_manager.dart b/lib/utils/client_manager.dart index 3a14e4e79..856a907ab 100644 --- a/lib/utils/client_manager.dart +++ b/lib/utils/client_manager.dart @@ -2,35 +2,30 @@ import 'dart:io'; import 'package:flutter/foundation.dart'; +import 'package:collection/collection.dart'; import 'package:desktop_notifications/desktop_notifications.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_local_notifications/flutter_local_notifications.dart'; -import 'package:hive_flutter/hive_flutter.dart'; +import 'package:flutter_vodozemac/flutter_vodozemac.dart' as vod; import 'package:matrix/encryption/utils/key_verification.dart'; import 'package:matrix/matrix.dart'; -import 'package:path_provider/path_provider.dart'; import 'package:shared_preferences/shared_preferences.dart'; import 'package:universal_html/html.dart' as html; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/custom_http_client.dart'; import 'package:fluffychat/utils/custom_image_resizer.dart'; import 'package:fluffychat/utils/init_with_restore.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/flutter_hive_collections_database.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'matrix_sdk_extensions/flutter_matrix_dart_sdk_database/builder.dart'; abstract class ClientManager { static const String clientNamespace = 'im.fluffychat.store.clients'; + static Future> getClients({ bool initialize = true, required SharedPreferences store, }) async { - if (PlatformInfos.isLinux) { - Hive.init((await getApplicationSupportDirectory()).path); - } else { - await Hive.initFlutter(); - } final clientNames = {}; try { final clientNamesList = store.getStringList(clientNamespace) ?? []; @@ -43,21 +38,27 @@ abstract class ClientManager { clientNames.add(PlatformInfos.clientName); await store.setStringList(clientNamespace, clientNames.toList()); } - final clients = clientNames.map(createClient).toList(); + final clients = await Future.wait( + clientNames.map((name) => createClient(name, store)), + ); if (initialize) { await Future.wait( clients.map( - (client) => client.initWithRestore( - onMigration: () { - final l10n = lookupL10n(PlatformDispatcher.instance.locale); - sendInitNotification( - l10n.databaseMigrationTitle, - l10n.databaseMigrationBody, - ); - }, - ).catchError( - (e, s) => Logs().e('Unable to initialize client', e, s), - ), + (client) => client + .initWithRestore( + onMigration: () async { + final l10n = await lookupL10n( + PlatformDispatcher.instance.locale, + ); + sendInitNotification( + l10n.databaseMigrationTitle, + l10n.databaseMigrationBody, + ); + }, + ) + .catchError( + (e, s) => Logs().e('Unable to initialize client', e, s), + ), ), ); } @@ -94,14 +95,25 @@ abstract class ClientManager { } static NativeImplementations get nativeImplementations => kIsWeb - ? const NativeImplementationsDummy() - : NativeImplementationsIsolate(compute); + ? NativeImplementationsWebWorker( + Uri.parse('native_executor.js'), + timeout: const Duration(minutes: 1), + ) + : NativeImplementationsIsolate( + compute, + vodozemacInit: () => vod.init(wasmPath: './assets/assets/vodozemac/'), + ); + + static Future createClient( + String clientName, + SharedPreferences store, + ) async { + final shareKeysWith = AppSettings.shareKeysWith.value; + final enableSoftLogout = AppSettings.enableSoftLogout.value; - static Client createClient(String clientName) { return Client( clientName, - httpClient: - PlatformInfos.isAndroid ? CustomHttpClient.createHTTPClient() : null, + httpClient: CustomHttpClient.createHTTPClient(), verificationMethods: { KeyVerificationMethod.numbers, if (kIsWeb || PlatformInfos.isMobile || PlatformInfos.isLinux) @@ -111,36 +123,38 @@ abstract class ClientManager { // To make room emotes work 'im.ponies.room_emotes', }, + customImageResizer: customImageResizer, logLevel: kReleaseMode ? Level.warning : Level.verbose, - databaseBuilder: flutterMatrixSdkDatabaseBuilder, - legacyDatabaseBuilder: FlutterHiveCollectionsDatabase.databaseBuilder, + database: await flutterMatrixSdkDatabaseBuilder(clientName), supportedLoginTypes: { AuthenticationTypes.password, AuthenticationTypes.sso, }, nativeImplementations: nativeImplementations, - customImageResizer: PlatformInfos.isMobile ? customImageResizer : null, defaultNetworkRequestTimeout: const Duration(minutes: 30), enableDehydratedDevices: true, + shareKeysWith: + ShareKeysWith.values.singleWhereOrNull( + (share) => share.name == shareKeysWith, + ) ?? + ShareKeysWith.all, + onSoftLogout: enableSoftLogout + ? (client) => client.refreshAccessToken() + : null, ); } - static void sendInitNotification(String title, String body) async { + static Future sendInitNotification(String title, String body) async { if (kIsWeb) { - html.Notification( - title, - body: body, - ); + html.Notification(title, body: body); return; } if (Platform.isLinux) { await NotificationsClient().notify( title, body: body, - appName: AppConfig.applicationName, - hints: [ - NotificationHint.soundName('message-new-instant'), - ], + appName: AppSettings.applicationName.value, + hints: [NotificationHint.soundName('message-new-instant')], ); return; } @@ -148,17 +162,17 @@ abstract class ClientManager { final flutterLocalNotificationsPlugin = FlutterLocalNotificationsPlugin(); await flutterLocalNotificationsPlugin.initialize( - const InitializationSettings( + settings: const InitializationSettings( android: AndroidInitializationSettings('notifications_icon'), iOS: DarwinInitializationSettings(), ), ); - flutterLocalNotificationsPlugin.show( - 0, - title, - body, - const NotificationDetails( + await flutterLocalNotificationsPlugin.show( + id: 0, + title: title, + body: body, + notificationDetails: const NotificationDetails( android: AndroidNotificationDetails( 'error_message', 'Error Messages', diff --git a/lib/utils/code_highlight_theme.dart b/lib/utils/code_highlight_theme.dart new file mode 100644 index 000000000..ac3a19144 --- /dev/null +++ b/lib/utils/code_highlight_theme.dart @@ -0,0 +1,40 @@ +import 'package:flutter/widgets.dart'; + +const hightlightTextColor = Color(0xffabb2bf); +const atomOneBackgroundColor = Color(0xff282c34); +const atomOneDarkTheme = { + 'root': TextStyle(color: hightlightTextColor), + 'comment': TextStyle(color: Color(0xff5c6370), fontStyle: FontStyle.italic), + 'quote': TextStyle(color: Color(0xff5c6370), fontStyle: FontStyle.italic), + 'doctag': TextStyle(color: Color(0xffc678dd)), + 'keyword': TextStyle(color: Color(0xffc678dd)), + 'formula': TextStyle(color: Color(0xffc678dd)), + 'section': TextStyle(color: Color(0xffe06c75)), + 'name': TextStyle(color: Color(0xffe06c75)), + 'selector-tag': TextStyle(color: Color(0xffe06c75)), + 'deletion': TextStyle(color: Color(0xffe06c75)), + 'subst': TextStyle(color: Color(0xffe06c75)), + 'literal': TextStyle(color: Color(0xff56b6c2)), + 'string': TextStyle(color: Color(0xff98c379)), + 'regexp': TextStyle(color: Color(0xff98c379)), + 'addition': TextStyle(color: Color(0xff98c379)), + 'attribute': TextStyle(color: Color(0xff98c379)), + 'meta-string': TextStyle(color: Color(0xff98c379)), + 'built_in': TextStyle(color: Color(0xffe6c07b)), + 'attr': TextStyle(color: Color(0xffd19a66)), + 'variable': TextStyle(color: Color(0xffd19a66)), + 'template-variable': TextStyle(color: Color(0xffd19a66)), + 'type': TextStyle(color: Color(0xffd19a66)), + 'selector-class': TextStyle(color: Color(0xffd19a66)), + 'selector-attr': TextStyle(color: Color(0xffd19a66)), + 'selector-pseudo': TextStyle(color: Color(0xffd19a66)), + 'number': TextStyle(color: Color(0xffd19a66)), + 'symbol': TextStyle(color: Color(0xff61aeee)), + 'bullet': TextStyle(color: Color(0xff61aeee)), + 'link': TextStyle(color: Color(0xff61aeee)), + 'meta': TextStyle(color: Color(0xff61aeee)), + 'selector-id': TextStyle(color: Color(0xff61aeee)), + 'title': TextStyle(color: Color(0xff61aeee)), + 'emphasis': TextStyle(fontStyle: FontStyle.italic), + 'strong': TextStyle(fontWeight: FontWeight.bold), +}; diff --git a/lib/utils/color_value.dart b/lib/utils/color_value.dart new file mode 100644 index 000000000..49195779d --- /dev/null +++ b/lib/utils/color_value.dart @@ -0,0 +1,14 @@ +import 'package:flutter/widgets.dart'; + +extension ColorValue on Color { + int get hexValue { + return _floatToInt8(a) << 24 | + _floatToInt8(r) << 16 | + _floatToInt8(g) << 8 | + _floatToInt8(b) << 0; + } + + static int _floatToInt8(double x) { + return (x * 255.0).round() & 0xff; + } +} diff --git a/lib/utils/custom_http_client.dart b/lib/utils/custom_http_client.dart index 479e5edb5..66b1dcad2 100644 --- a/lib/utils/custom_http_client.dart +++ b/lib/utils/custom_http_client.dart @@ -3,9 +3,15 @@ import 'dart:io'; import 'package:http/http.dart' as http; import 'package:http/io_client.dart'; +import 'package:http/retry.dart' as retry; import 'package:fluffychat/config/isrg_x1.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; +/// Custom Client to add an additional certificate. This is for the isrg X1 +/// certificate which is needed for LetsEncrypt certificates. It is shipped +/// on Android since OS version 7.1. As long as we support older versions we +/// still have to ship this certificate by ourself. class CustomHttpClient { static HttpClient customHttpClient(String? cert) { final context = SecurityContext.defaultContext; @@ -26,5 +32,9 @@ class CustomHttpClient { return HttpClient(context: context); } - static http.Client createHTTPClient() => IOClient(customHttpClient(ISRG_X1)); + static http.Client createHTTPClient() => retry.RetryClient( + PlatformInfos.isAndroid + ? IOClient(customHttpClient(ISRG_X1)) + : http.Client(), + ); } diff --git a/lib/utils/custom_image_resizer.dart b/lib/utils/custom_image_resizer.dart index 48b803a90..9be5f206c 100644 --- a/lib/utils/custom_image_resizer.dart +++ b/lib/utils/custom_image_resizer.dart @@ -1,67 +1,101 @@ -import 'dart:typed_data'; import 'dart:ui'; +import 'package:flutter/foundation.dart'; +import 'package:flutter/painting.dart'; + import 'package:matrix/matrix.dart'; import 'package:native_imaging/native_imaging.dart' as native; +(int, int) _scaleToBox(int width, int height, {required int boxSize}) { + final fit = applyBoxFit( + BoxFit.scaleDown, + Size(width.toDouble(), height.toDouble()), + Size(boxSize.toDouble(), boxSize.toDouble()), + ).destination; + return (fit.width.round(), fit.height.round()); +} + Future customImageResizer( MatrixImageFileResizeArguments arguments, ) async { await native.init(); - late native.Image nativeImg; + + var imageBytes = arguments.bytes; + String? blurhash; + + var originalWidth = 0; + var originalHeight = 0; + var width = 0; + var height = 0; try { - nativeImg = await native.Image.loadEncoded(arguments.bytes); // load on web - } on UnsupportedError { - try { - // for the other platforms - final dartCodec = await instantiateImageCodec(arguments.bytes); - final dartFrame = await dartCodec.getNextFrame(); - final rgbaData = await dartFrame.image.toByteData(); - if (rgbaData == null) { - return null; - } - final rgba = Uint8List.view( - rgbaData.buffer, - rgbaData.offsetInBytes, - rgbaData.lengthInBytes, + // for the other platforms + final dartCodec = await instantiateImageCodec(arguments.bytes); + final frameCount = dartCodec.frameCount; + final dartFrame = await dartCodec.getNextFrame(); + final rgbaData = await dartFrame.image.toByteData(); + if (rgbaData == null) { + return null; + } + final rgba = Uint8List.view( + rgbaData.buffer, + rgbaData.offsetInBytes, + rgbaData.lengthInBytes, + ); + + width = originalWidth = dartFrame.image.width; + height = originalHeight = dartFrame.image.height; + + var nativeImg = native.Image.fromRGBA(width, height, rgba); + + dartFrame.image.dispose(); + dartCodec.dispose(); + + if (arguments.calcBlurhash) { + // scale down image for blurhashing to speed it up + final (blurW, blurH) = _scaleToBox(width, height, boxSize: 100); + final blurhashImg = nativeImg.resample( + blurW, + blurH, + // nearest is unsupported... + native.Transform.bilinear, ); - final width = dartFrame.image.width; - final height = dartFrame.image.height; + blurhash = blurhashImg.toBlurhash(3, 3); - dartFrame.image.dispose(); - dartCodec.dispose(); - - nativeImg = native.Image.fromRGBA(width, height, rgba); - } catch (e, s) { - Logs().e("Could not generate preview", e, s); - rethrow; + blurhashImg.free(); } - } - final width = nativeImg.width; - final height = nativeImg.height; - - final max = arguments.maxDimension; - if (width > max || height > max) { - var w = max, h = max; - if (width > height) { - h = max * height ~/ width; + if (frameCount > 1) { + // Don't scale down animated images, since those would lose frames. + nativeImg.free(); } else { - w = max * width ~/ height; - } + final max = arguments.maxDimension; + if (width > max || height > max) { + (width, height) = _scaleToBox(width, height, boxSize: max); - final scaledImg = nativeImg.resample(w, h, native.Transform.lanczos); - nativeImg.free(); - nativeImg = scaledImg; + final scaledImg = nativeImg.resample( + width, + height, + native.Transform.lanczos, + ); + nativeImg.free(); + nativeImg = scaledImg; + } + + imageBytes = await nativeImg.toJpeg(75); + nativeImg.free(); + } + } catch (e, s) { + Logs().e('Could not generate preview', e, s); } - final jpegBytes = await nativeImg.toJpeg(75); return MatrixImageFileResizedResponse( - bytes: jpegBytes, - width: nativeImg.width, - height: nativeImg.height, - blurhash: arguments.calcBlurhash ? nativeImg.toBlurhash(3, 3) : null, + bytes: imageBytes, + width: width, + height: height, + originalWidth: originalWidth, + originalHeight: originalHeight, + blurhash: blurhash, ); } diff --git a/lib/utils/custom_scroll_behaviour.dart b/lib/utils/custom_scroll_behaviour.dart index ba25e9564..32baa332c 100644 --- a/lib/utils/custom_scroll_behaviour.dart +++ b/lib/utils/custom_scroll_behaviour.dart @@ -4,7 +4,7 @@ import 'package:flutter/material.dart'; class CustomScrollBehavior extends MaterialScrollBehavior { @override Set get dragDevices => { - PointerDeviceKind.touch, - PointerDeviceKind.trackpad, - }; + PointerDeviceKind.touch, + PointerDeviceKind.trackpad, + }; } diff --git a/lib/utils/date_time_extension.dart b/lib/utils/date_time_extension.dart index 121eaf72e..508f13e29 100644 --- a/lib/utils/date_time_extension.dart +++ b/lib/utils/date_time_extension.dart @@ -1,8 +1,10 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:intl/intl.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; + /// Provides extra functionality for formatting the time. extension DateTimeExtension on DateTime { bool operator <(DateTime other) { @@ -21,27 +23,15 @@ extension DateTimeExtension on DateTime { return millisecondsSinceEpoch <= other.millisecondsSinceEpoch; } - /// Two message events can belong to the same environment. That means that they - /// don't need to display the time they were sent because they are close - /// enaugh. - static const minutesBetweenEnvironments = 10; - /// Checks if two DateTimes are close enough to belong to the same /// environment. - bool sameEnvironment(DateTime prevTime) { - return millisecondsSinceEpoch - prevTime.millisecondsSinceEpoch < - 1000 * 60 * minutesBetweenEnvironments; - } + bool sameEnvironment(DateTime prevTime) => + difference(prevTime) < const Duration(hours: 1); /// Returns a simple time String. - /// TODO: Add localization - String localizedTimeOfDay(BuildContext context) { - if (MediaQuery.of(context).alwaysUse24HourFormat) { - return '${_z(hour)}:${_z(minute)}'; - } else { - return '${_z(hour % 12 == 0 ? 12 : hour % 12)}:${_z(minute)} ${hour > 11 ? "pm" : "am"}'; - } - } + String localizedTimeOfDay(BuildContext context) => use24HourFormat(context) + ? DateFormat('HH:mm', L10n.of(context).localeName).format(this) + : DateFormat('h:mm a', L10n.of(context).localeName).format(this); /// Returns [localizedTimeOfDay()] if the ChatTime is today, the name of the week /// day if the ChatTime is this week and a date string else. @@ -52,7 +42,8 @@ extension DateTimeExtension on DateTime { final sameDay = sameYear && now.month == month && now.day == day; - final sameWeek = sameYear && + final sameWeek = + sameYear && !sameDay && now.millisecondsSinceEpoch - millisecondsSinceEpoch < 1000 * 60 * 60 * 24 * 7; @@ -60,19 +51,17 @@ extension DateTimeExtension on DateTime { if (sameDay) { return localizedTimeOfDay(context); } else if (sameWeek) { - return DateFormat.EEEE(Localizations.localeOf(context).languageCode) - .format(this); + return DateFormat.E( + Localizations.localeOf(context).languageCode, + ).format(this); } else if (sameYear) { - return L10n.of(context)!.dateWithoutYear( - month.toString().padLeft(2, '0'), - day.toString().padLeft(2, '0'), - ); + return DateFormat.MMMd( + Localizations.localeOf(context).languageCode, + ).format(this); } - return L10n.of(context)!.dateWithYear( - year.toString(), - month.toString().padLeft(2, '0'), - day.toString().padLeft(2, '0'), - ); + return DateFormat.yMMMd( + Localizations.localeOf(context).languageCode, + ).format(this); } /// If the DateTime is today, this returns [localizedTimeOfDay()], if not it also @@ -86,11 +75,25 @@ extension DateTimeExtension on DateTime { final sameDay = sameYear && now.month == month && now.day == day; if (sameDay) return localizedTimeOfDay(context); - return L10n.of(context)!.dateAndTimeOfDay( + return L10n.of(context).dateAndTimeOfDay( localizedTimeShort(context), localizedTimeOfDay(context), ); } - static String _z(int i) => i < 10 ? '0${i.toString()}' : i.toString(); + /// Check if time needs to be in 24h format + bool use24HourFormat(BuildContext context) { + final mediaQuery24h = MediaQuery.alwaysUse24HourFormatOf(context); + + final l10n24h = L10n.of(context).alwaysUse24HourFormat == 'true'; + + // https://github.com/krille-chan/fluffychat/pull/1457#discussion_r1836817914 + if (PlatformInfos.isAndroid) { + return mediaQuery24h; + } else if (PlatformInfos.isIOS) { + return mediaQuery24h || l10n24h; + } + + return l10n24h; + } } diff --git a/lib/utils/error_reporter.dart b/lib/utils/error_reporter.dart index f9254d351..670d2f8ae 100644 --- a/lib/utils/error_reporter.dart +++ b/lib/utils/error_reporter.dart @@ -1,62 +1,66 @@ import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_highlighter/flutter_highlighter.dart'; -import 'package:flutter_highlighter/themes/shades-of-purple.dart'; import 'package:matrix/matrix.dart'; import 'package:url_launcher/url_launcher.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; class ErrorReporter { - final BuildContext context; + final BuildContext? context; final String? message; const ErrorReporter(this.context, [this.message]); - void onErrorCallback(Object error, [StackTrace? stackTrace]) async { + static const Set ingoredTypes = { + 'IOException', + 'ClientException', + 'SocketException', + 'TlsException', + 'HandshakeException', + }; + + Future onErrorCallback(Object error, [StackTrace? stackTrace]) async { + if (ingoredTypes.contains(error.runtimeType.toString())) return; Logs().e(message ?? 'Error caught', error, stackTrace); final text = '$error\n${stackTrace ?? ''}'; + return _onErrorCallback(text); + } + + Future _onErrorCallback(String text) async { await showAdaptiveDialog( - context: context, + context: context!, builder: (context) => AlertDialog.adaptive( - title: Text(L10n.of(context)!.reportErrorDescription), + title: Text(L10n.of(context).reportErrorDescription), content: SizedBox( height: 256, width: 256, child: SingleChildScrollView( - child: HighlightView( + child: Text( text, - language: 'sh', - theme: shadesOfPurpleTheme, + style: const TextStyle(fontSize: 14, fontFamily: 'RobotoMono'), ), ), ), actions: [ - TextButton( + AdaptiveDialogAction( onPressed: () => Navigator.of(context).pop(), - child: Text(L10n.of(context)!.close), + child: Text(L10n.of(context).close), ), - TextButton( - onPressed: () => Clipboard.setData( - ClipboardData(text: text), - ), - child: Text(L10n.of(context)!.copy), + AdaptiveDialogAction( + onPressed: () => Clipboard.setData(ClipboardData(text: text)), + child: Text(L10n.of(context).copy), ), - TextButton( + AdaptiveDialogAction( onPressed: () => launchUrl( AppConfig.newIssueUrl.resolveUri( - Uri( - queryParameters: { - 'template': 'bug_report.yaml', - 'title': '[BUG]: ${message ?? error.toString()}', - }, - ), + Uri(queryParameters: {'template': 'bug_report.yaml'}), ), mode: LaunchMode.externalApplication, ), - child: Text(L10n.of(context)!.report), + child: Text(L10n.of(context).report), ), ], ), diff --git a/lib/utils/event_checkbox_extension.dart b/lib/utils/event_checkbox_extension.dart new file mode 100644 index 000000000..61e20c408 --- /dev/null +++ b/lib/utils/event_checkbox_extension.dart @@ -0,0 +1,26 @@ +import 'package:matrix/matrix.dart'; + +extension EventCheckboxRoomExtension on Room { + static const String relationshipType = 'im.fluffychat.checkboxes'; + Future checkCheckbox( + String eventId, + int checkboxId, { + String? txid, + }) => sendEvent( + { + 'm.relates_to': { + 'rel_type': relationshipType, + 'event_id': eventId, + 'checkbox_id': checkboxId, + }, + }, + type: EventTypes.Reaction, + txid: txid, + ); +} + +extension EventCheckboxExtension on Event { + int? get checkedCheckboxId => content + .tryGetMap('m.relates_to') + ?.tryGet('checkbox_id'); +} diff --git a/lib/utils/file_description.dart b/lib/utils/file_description.dart new file mode 100644 index 000000000..aa6c98caa --- /dev/null +++ b/lib/utils/file_description.dart @@ -0,0 +1,24 @@ +import 'package:matrix/matrix.dart'; + +extension FileDescriptionExtension on Event { + String? get fileDescription { + if (!{ + MessageTypes.File, + MessageTypes.Image, + MessageTypes.Sticker, + MessageTypes.Video, + MessageTypes.Audio, + }.contains(messageType)) { + return null; + } + final filename = content.tryGet('filename'); + final body = calcUnlocalizedBody(hideReply: true, plaintextBody: true); + + if (filename != body && + filename != null && + content.tryGet('body')?.isNotEmpty == true) { + return body; + } + return null; + } +} diff --git a/lib/utils/file_selector.dart b/lib/utils/file_selector.dart new file mode 100644 index 000000000..97e229c2e --- /dev/null +++ b/lib/utils/file_selector.dart @@ -0,0 +1,26 @@ +import 'package:flutter/widgets.dart'; + +import 'package:file_picker/file_picker.dart'; +import 'package:file_selector/file_selector.dart'; + +import 'package:fluffychat/widgets/app_lock.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; + +Future> selectFiles( + BuildContext context, { + String? title, + FileType type = FileType.any, + bool allowMultiple = false, +}) async { + final result = await AppLock.of(context).pauseWhile( + showFutureLoadingDialog( + context: context, + future: () => FilePicker.platform.pickFiles( + compressionQuality: 0, + allowMultiple: allowMultiple, + type: type, + ), + ), + ); + return result.result?.xFiles ?? []; +} diff --git a/lib/utils/fluffy_share.dart b/lib/utils/fluffy_share.dart index fbe533c54..c2bd2a5de 100644 --- a/lib/utils/fluffy_share.dart +++ b/lib/utils/fluffy_share.dart @@ -1,9 +1,9 @@ import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:share_plus/share_plus.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import '../widgets/matrix.dart'; @@ -15,18 +15,18 @@ abstract class FluffyShare { }) async { if (PlatformInfos.isMobile && !copyOnly) { final box = context.findRenderObject() as RenderBox; - await Share.share( - text, - sharePositionOrigin: box.localToGlobal(Offset.zero) & box.size, + await SharePlus.instance.share( + ShareParams( + text: text, + sharePositionOrigin: box.localToGlobal(Offset.zero) & box.size, + ), ); return; } - await Clipboard.setData( - ClipboardData(text: text), - ); - ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.copiedToClipboard)), - ); + await Clipboard.setData(ClipboardData(text: text)); + ScaffoldMessenger.of( + context, + ).showSnackBar(SnackBar(content: Text(L10n.of(context).copiedToClipboard))); return; } @@ -34,7 +34,7 @@ abstract class FluffyShare { final client = Matrix.of(context).client; final ownProfile = await client.fetchOwnProfile(); await FluffyShare.share( - L10n.of(context)!.inviteText( + L10n.of(context).inviteText( ownProfile.displayName ?? client.userID!, 'https://matrix.to/#/${client.userID}?client=im.fluffychat', ), diff --git a/lib/utils/init_with_restore.dart b/lib/utils/init_with_restore.dart index c99e2ba08..71cc7f8b4 100644 --- a/lib/utils/init_with_restore.dart +++ b/lib/utils/init_with_restore.dart @@ -1,11 +1,12 @@ import 'dart:convert'; import 'dart:ui'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_secure_storage/flutter_secure_storage.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/client_manager.dart'; import 'package:fluffychat/utils/platform_infos.dart'; @@ -30,22 +31,22 @@ class SessionBackup { SessionBackup.fromJson(jsonDecode(json)); factory SessionBackup.fromJson(Map json) => SessionBackup( - olmAccount: json['olm_account'], - accessToken: json['access_token'], - userId: json['user_id'], - homeserver: json['homeserver'], - deviceId: json['device_id'], - deviceName: json['device_name'], - ); + olmAccount: json['olm_account'], + accessToken: json['access_token'], + userId: json['user_id'], + homeserver: json['homeserver'], + deviceId: json['device_id'], + deviceName: json['device_name'], + ); Map toJson() => { - 'olm_account': olmAccount, - 'access_token': accessToken, - 'user_id': userId, - 'homeserver': homeserver, - 'device_id': deviceId, - if (deviceName != null) 'device_name': deviceName, - }; + 'olm_account': olmAccount, + 'access_token': accessToken, + 'user_id': userId, + 'homeserver': homeserver, + 'device_id': deviceId, + if (deviceName != null) 'device_name': deviceName, + }; @override String toString() => jsonEncode(toJson()); @@ -57,20 +58,22 @@ extension InitWithRestoreExtension on Client { ? const FlutterSecureStorage() : null; await storage?.delete( - key: '${AppConfig.applicationName}_session_backup_$clientName', + key: '${AppSettings.applicationName.value}_session_backup_$clientName', ); } Future initWithRestore({void Function()? onMigration}) async { final storageKey = - '${AppConfig.applicationName}_session_backup_$clientName'; + '${AppSettings.applicationName.value}_session_backup_$clientName'; final storage = PlatformInfos.isMobile || PlatformInfos.isLinux ? const FlutterSecureStorage() : null; try { await init( - onMigration: onMigration, + onInitStateChanged: (state) { + if (state == InitState.migratingDatabase) onMigration?.call(); + }, waitForFirstSync: false, waitUntilLoadCompletedLoaded: false, ); @@ -79,7 +82,8 @@ extension InitWithRestoreExtension on Client { final homeserver = this.homeserver?.toString(); final deviceId = deviceID; final userId = userID; - final hasBackup = accessToken != null && + final hasBackup = + accessToken != null && homeserver != null && deviceId != null && userId != null; @@ -101,7 +105,7 @@ extension InitWithRestoreExtension on Client { } } catch (e, s) { Logs().wtf('Client init failed!', e, s); - final l10n = lookupL10n(PlatformDispatcher.instance.locale); + final l10n = await lookupL10n(PlatformDispatcher.instance.locale); final sessionBackupString = await storage?.read(key: storageKey); if (sessionBackupString == null) { ClientManager.sendInitNotification( @@ -122,7 +126,9 @@ extension InitWithRestoreExtension on Client { newUserID: sessionBackup.userId, waitForFirstSync: false, waitUntilLoadCompletedLoaded: false, - onMigration: onMigration, + onInitStateChanged: (state) { + if (state == InitState.migratingDatabase) onMigration?.call(); + }, ); ClientManager.sendInitNotification( l10n.initAppError, diff --git a/lib/utils/localized_exception_extension.dart b/lib/utils/localized_exception_extension.dart index 65be02a1f..0d8ff6599 100644 --- a/lib/utils/localized_exception_extension.dart +++ b/lib/utils/localized_exception_extension.dart @@ -1,54 +1,71 @@ import 'dart:io'; +import 'dart:math'; import 'package:flutter/material.dart'; +import 'package:flutter/services.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:http/http.dart'; import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/other_party_can_receive.dart'; import 'uia_request_manager.dart'; extension LocalizedExceptionExtension on Object { + static String _formatFileSize(int size) { + if (size < 1000) return '$size B'; + final i = (log(size) / log(1000)).floor(); + final num = (size / pow(1000, i)); + final round = num.round(); + final numString = round < 10 + ? num.toStringAsFixed(2) + : round < 100 + ? num.toStringAsFixed(1) + : round.toString(); + return '$numString ${'kMGTPEZY'[i - 1]}B'; + } + String toLocalizedString( BuildContext context, [ ExceptionContext? exceptionContext, ]) { + if (this is FileTooBigMatrixException) { + final exception = this as FileTooBigMatrixException; + return L10n.of( + context, + ).fileIsTooBigForServer(_formatFileSize(exception.maxFileSize)); + } + if (this is OtherPartyCanNotReceiveMessages) { + return L10n.of(context).otherPartyNotLoggedIn; + } if (this is MatrixException) { switch ((this as MatrixException).error) { case MatrixError.M_FORBIDDEN: if (exceptionContext == ExceptionContext.changePassword) { - return L10n.of(context)!.passwordIsWrong; + return L10n.of(context).passwordIsWrong; } - return L10n.of(context)!.noPermission; + return L10n.of(context).noPermission; case MatrixError.M_LIMIT_EXCEEDED: - return L10n.of(context)!.tooManyRequestsWarning; + return L10n.of(context).tooManyRequestsWarning; default: + if (exceptionContext == ExceptionContext.joinRoom) { + return L10n.of(context).unableToJoinChat; + } return (this as MatrixException).errorMessage; } } if (this is InvalidPassphraseException) { - return L10n.of(context)!.wrongRecoveryKey; + return L10n.of(context).wrongRecoveryKey; } - if (this is FileTooBigMatrixException) { - return L10n.of(context)!.fileIsTooBigForServer; - } - if (this is BadServerVersionsException) { - final serverVersions = (this as BadServerVersionsException) - .serverVersions - .toString() - .replaceAll('{', '"') - .replaceAll('}', '"'); - final supportedVersions = (this as BadServerVersionsException) - .supportedVersions - .toString() - .replaceAll('{', '"') - .replaceAll('}', '"'); - return L10n.of(context)!.badServerVersionsException( - serverVersions, - supportedVersions, - serverVersions, - supportedVersions, - ); + if (this is PlatformException) { + if ((this as PlatformException).code == 'CANCELED') { + return L10n.of(context).theProcessWasCanceled; + } + final message = (this as PlatformException).message; + if (message != null) { + return message; + } } if (this is BadServerLoginTypesException) { final serverVersions = (this as BadServerLoginTypesException) @@ -61,24 +78,41 @@ extension LocalizedExceptionExtension on Object { .toString() .replaceAll('{', '"') .replaceAll('}', '"'); - return L10n.of(context)!.badServerLoginTypesException( + return L10n.of(context).badServerLoginTypesException( serverVersions, supportedVersions, supportedVersions, ); } - if (this is MatrixConnectionException || + if (this is IOException || this is SocketException || - this is SyncConnectionException) { - return L10n.of(context)!.noConnectionToTheServer; + this is SyncConnectionException || + this is ClientException) { + return L10n.of(context).noConnectionToTheServer; + } + if (this is FormatException && + exceptionContext == ExceptionContext.checkHomeserver) { + return L10n.of(context).doesNotSeemToBeAValidHomeserver; + } + if (this is FormatException && + exceptionContext == ExceptionContext.checkServerSupportInfo) { + return L10n.of(context).noContactInformationProvided; } if (this is String) return toString(); if (this is UiaException) return toString(); + + if (exceptionContext == ExceptionContext.joinRoom) { + return L10n.of(context).unableToJoinChat; + } + Logs().w('Something went wrong: ', this); - return L10n.of(context)!.oopsSomethingWentWrong; + return L10n.of(context).oopsSomethingWentWrong; } } enum ExceptionContext { changePassword, + checkHomeserver, + checkServerSupportInfo, + joinRoom, } diff --git a/lib/utils/markdown_context_builder.dart b/lib/utils/markdown_context_builder.dart new file mode 100644 index 000000000..57d44d4cd --- /dev/null +++ b/lib/utils/markdown_context_builder.dart @@ -0,0 +1,138 @@ +import 'package:flutter/material.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; + +class MarkdownContextBuilder extends StatelessWidget { + final EditableTextState editableTextState; + final TextEditingController controller; + + const MarkdownContextBuilder({ + required this.editableTextState, + required this.controller, + super.key, + }); + + @override + Widget build(BuildContext context) { + final value = editableTextState.textEditingValue; + final selectedText = value.selection.textInside(value.text); + final buttonItems = editableTextState.contextMenuButtonItems; + final l10n = L10n.of(context); + + return AdaptiveTextSelectionToolbar.buttonItems( + anchors: editableTextState.contextMenuAnchors, + buttonItems: [ + ...buttonItems, + if (selectedText.isNotEmpty) ...[ + ContextMenuButtonItem( + label: l10n.link, + onPressed: () async { + final input = await showTextInputDialog( + context: context, + title: l10n.addLink, + okLabel: l10n.ok, + cancelLabel: l10n.cancel, + validator: (text) { + if (text.isEmpty) { + return l10n.pleaseFillOut; + } + try { + text.startsWith('http') ? Uri.parse(text) : Uri.https(text); + } catch (_) { + return l10n.invalidUrl; + } + return null; + }, + hintText: 'www...', + keyboardType: TextInputType.url, + ); + final urlString = input; + if (urlString == null) return; + final url = urlString.startsWith('http') + ? Uri.parse(urlString) + : Uri.https(urlString); + final selection = controller.selection; + controller.text = controller.text.replaceRange( + selection.start, + selection.end, + '[$selectedText]($url)', + ); + ContextMenuController.removeAny(); + }, + ), + ContextMenuButtonItem( + label: l10n.checkList, + onPressed: () { + final text = controller.text; + final selection = controller.selection; + + var start = selection.textBefore(text).lastIndexOf('\n'); + if (start == -1) start = 0; + final end = selection.end; + + final fullLineSelection = TextSelection( + baseOffset: start, + extentOffset: end, + ); + + const checkBox = '- [ ]'; + + final replacedRange = fullLineSelection + .textInside(text) + .split('\n') + .map( + (line) => line.startsWith(checkBox) || line.isEmpty + ? line + : '$checkBox $line', + ) + .join('\n'); + controller.text = controller.text.replaceRange( + start, + end, + replacedRange, + ); + ContextMenuController.removeAny(); + }, + ), + ContextMenuButtonItem( + label: l10n.boldText, + onPressed: () { + final selection = controller.selection; + controller.text = controller.text.replaceRange( + selection.start, + selection.end, + '**$selectedText**', + ); + ContextMenuController.removeAny(); + }, + ), + ContextMenuButtonItem( + label: l10n.italicText, + onPressed: () { + final selection = controller.selection; + controller.text = controller.text.replaceRange( + selection.start, + selection.end, + '*$selectedText*', + ); + ContextMenuController.removeAny(); + }, + ), + ContextMenuButtonItem( + label: l10n.strikeThrough, + onPressed: () { + final selection = controller.selection; + controller.text = controller.text.replaceRange( + selection.start, + selection.end, + '~~$selectedText~~', + ); + ContextMenuController.removeAny(); + }, + ), + ], + ], + ); + } +} diff --git a/lib/utils/matrix_sdk_extensions/device_extension.dart b/lib/utils/matrix_sdk_extensions/device_extension.dart index 55f3ebfc9..6f8ec4ed6 100644 --- a/lib/utils/matrix_sdk_extensions/device_extension.dart +++ b/lib/utils/matrix_sdk_extensions/device_extension.dart @@ -4,10 +4,10 @@ import 'package:matrix/matrix.dart'; IconData _getIconFromName(String displayname) { final name = displayname.toLowerCase(); - if ({'android'}.any((s) => name.contains(s))) { + if ({'android'}.any(name.contains)) { return Icons.phone_android_outlined; } - if ({'ios', 'ipad', 'iphone', 'ipod'}.any((s) => name.contains(s))) { + if ({'ios', 'ipad', 'iphone', 'ipod'}.any(name.contains)) { return Icons.phone_iphone_outlined; } if ({ @@ -19,11 +19,10 @@ IconData _getIconFromName(String displayname) { '/_matrix', 'safari', 'opera', - }.any((s) => name.contains(s))) { + }.any(name.contains)) { return Icons.web_outlined; } - if ({'desktop', 'windows', 'macos', 'linux', 'ubuntu'} - .any((s) => name.contains(s))) { + if ({'desktop', 'windows', 'macos', 'linux', 'ubuntu'}.any(name.contains)) { return Icons.desktop_mac_outlined; } return Icons.device_unknown_outlined; diff --git a/lib/utils/matrix_sdk_extensions/event_extension.dart b/lib/utils/matrix_sdk_extensions/event_extension.dart index ddd5abe80..6f1138bfd 100644 --- a/lib/utils/matrix_sdk_extensions/event_extension.dart +++ b/lib/utils/matrix_sdk_extensions/event_extension.dart @@ -4,26 +4,35 @@ import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:async/async.dart' as async; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/utils/size_string.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'matrix_file_extension.dart'; extension LocalizedBody on Event { Future> _getFile(BuildContext context) => showFutureLoadingDialog( context: context, - future: downloadAndDecryptAttachment, + futureWithProgress: (onProgress) { + final fileSize = infoMap['size'] is int + ? infoMap['size'] as int + : null; + return downloadAndDecryptAttachment( + onDownloadProgress: fileSize == null + ? null + : (bytes) => onProgress(bytes / fileSize), + ); + }, ); - void saveFile(BuildContext context) async { + Future saveFile(BuildContext context) async { final matrixFile = await _getFile(context); matrixFile.result?.save(context); } - void shareFile(BuildContext context) async { + Future shareFile(BuildContext context) async { final matrixFile = await _getFile(context); inspect(matrixFile); @@ -32,22 +41,25 @@ extension LocalizedBody on Event { bool get isAttachmentSmallEnough => infoMap['size'] is int && - infoMap['size'] < room.client.database!.maxFileSize; + (infoMap['size'] as int) < room.client.database.maxFileSize; bool get isThumbnailSmallEnough => thumbnailInfoMap['size'] is int && - thumbnailInfoMap['size'] < room.client.database!.maxFileSize; + (thumbnailInfoMap['size'] as int) < room.client.database.maxFileSize; bool get showThumbnail => - [MessageTypes.Image, MessageTypes.Sticker, MessageTypes.Video] - .contains(messageType) && + [ + MessageTypes.Image, + MessageTypes.Sticker, + MessageTypes.Video, + ].contains(messageType) && (kIsWeb || isAttachmentSmallEnough || isThumbnailSmallEnough || (content['url'] is String)); String? get sizeString => content - .tryGetMap('info') + .tryGetMap('info') ?.tryGet('size') ?.sizeString; } diff --git a/lib/utils/matrix_sdk_extensions/filtered_timeline_extension.dart b/lib/utils/matrix_sdk_extensions/filtered_timeline_extension.dart index bd1cd8e46..0e9724a39 100644 --- a/lib/utils/matrix_sdk_extensions/filtered_timeline_extension.dart +++ b/lib/utils/matrix_sdk_extensions/filtered_timeline_extension.dart @@ -1,33 +1,58 @@ import 'package:matrix/matrix.dart'; -import '../../config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; + +extension VisibleInGuiExtension on List { + List filterByVisibleInGui({ + String? exceptionEventId, + String? threadId, + }) => where((event) { + if (threadId != null && + event.relationshipType != RelationshipTypes.reaction) { + if ((event.relationshipType != RelationshipTypes.thread || + event.relationshipEventId != threadId) && + event.eventId != threadId) { + return false; + } + } else if (event.relationshipType == RelationshipTypes.thread) { + return false; + } + return event.isVisibleInGui || event.eventId == exceptionEventId; + }).toList(); +} extension IsStateExtension on Event { bool get isVisibleInGui => // always filter out edit and reaction relationships - !{RelationshipTypes.edit, RelationshipTypes.reaction} - .contains(relationshipType) && - // always filter out m.key.* events - !type.startsWith('m.key.verification.') && + !{ + RelationshipTypes.edit, + RelationshipTypes.reaction, + }.contains(relationshipType) && + // always filter out m.key.* and other known but unimportant events + !isKnownHiddenStates && // event types to hide: redaction and reaction events // if a reaction has been redacted we also want it to be hidden in the timeline !{EventTypes.Reaction, EventTypes.Redaction}.contains(type) && // if we enabled to hide all redacted events, don't show those - (!AppConfig.hideRedactedEvents || !redacted) && + (!AppSettings.hideRedactedEvents.value || !redacted) && // if we enabled to hide all unknown events, don't show those - (!AppConfig.hideUnknownEvents || isEventTypeKnown) && - // remove state events that we don't want to render - (isState || !AppConfig.hideAllStateEvents) && - // hide simple join/leave member events in public rooms - (!AppConfig.hideUnimportantStateEvents || - type != EventTypes.RoomMember || - room.joinRules != JoinRules.public || - content.tryGet('membership') == 'ban' || - stateKey != senderId); + (!AppSettings.hideUnknownEvents.value || isEventTypeKnown); bool get isState => !{ - EventTypes.Message, - EventTypes.Sticker, - EventTypes.Encrypted, - }.contains(type); + EventTypes.Message, + EventTypes.Sticker, + EventTypes.Encrypted, + }.contains(type); + + bool get isCollapsedState => !{ + EventTypes.Message, + EventTypes.Sticker, + EventTypes.Encrypted, + EventTypes.RoomCreate, + EventTypes.RoomTombstone, + }.contains(type); + + bool get isKnownHiddenStates => + {PollEventContent.responseType}.contains(type) || + type.startsWith('m.key.verification.'); } diff --git a/lib/utils/matrix_sdk_extensions/flutter_hive_collections_database.dart b/lib/utils/matrix_sdk_extensions/flutter_hive_collections_database.dart deleted file mode 100644 index 1fb9a4e4c..000000000 --- a/lib/utils/matrix_sdk_extensions/flutter_hive_collections_database.dart +++ /dev/null @@ -1,149 +0,0 @@ -import 'dart:convert'; -import 'dart:io'; - -import 'package:flutter/foundation.dart' hide Key; -import 'package:flutter/services.dart'; - -import 'package:flutter_secure_storage/flutter_secure_storage.dart'; -import 'package:hive/hive.dart'; -import 'package:matrix/matrix.dart'; -import 'package:path_provider/path_provider.dart'; -import 'package:universal_html/html.dart' as html; - -// ignore: deprecated_member_use -class FlutterHiveCollectionsDatabase extends HiveCollectionsDatabase { - FlutterHiveCollectionsDatabase( - super.name, - String super.path, { - super.key, - }); - - static const String _cipherStorageKey = 'hive_encryption_key'; - - static Future databaseBuilder( - Client client, - ) async { - Logs().d('Open Hive...'); - HiveAesCipher? hiverCipher; - try { - // Workaround for secure storage is calling Platform.operatingSystem on web - if (kIsWeb) { - // ignore: unawaited_futures - html.window.navigator.storage?.persist(); - throw MissingPluginException(); - } - - const secureStorage = FlutterSecureStorage(); - final containsEncryptionKey = - await secureStorage.read(key: _cipherStorageKey) != null; - if (!containsEncryptionKey) { - // do not try to create a buggy secure storage for new Linux users - if (Platform.isLinux) throw MissingPluginException(); - final key = Hive.generateSecureKey(); - await secureStorage.write( - key: _cipherStorageKey, - value: base64UrlEncode(key), - ); - } - - // workaround for if we just wrote to the key and it still doesn't exist - final rawEncryptionKey = await secureStorage.read(key: _cipherStorageKey); - if (rawEncryptionKey == null) throw MissingPluginException(); - - hiverCipher = HiveAesCipher(base64Url.decode(rawEncryptionKey)); - } on MissingPluginException catch (_) { - const FlutterSecureStorage() - .delete(key: _cipherStorageKey) - .catchError((_) {}); - Logs().i('Hive encryption is not supported on this platform'); - } catch (e, s) { - const FlutterSecureStorage() - .delete(key: _cipherStorageKey) - .catchError((_) {}); - Logs().w('Unable to init Hive encryption', e, s); - } - - final db = FlutterHiveCollectionsDatabase( - 'hive_collections_${client.clientName.replaceAll(' ', '_').toLowerCase()}', - await findDatabasePath(client), - key: hiverCipher, - ); - try { - await db.open(); - } catch (e, s) { - Logs().w('Unable to open Hive. Delete database and storage key...', e, s); - const FlutterSecureStorage().delete(key: _cipherStorageKey); - await db.clear().catchError((_) {}); - await Hive.deleteFromDisk(); - rethrow; - } - Logs().d('Hive is ready'); - return db; - } - - static Future findDatabasePath(Client client) async { - String path = client.clientName; - if (!kIsWeb) { - Directory directory; - try { - if (Platform.isLinux) { - directory = await getApplicationSupportDirectory(); - } else { - directory = await getApplicationDocumentsDirectory(); - } - } catch (_) { - try { - directory = await getLibraryDirectory(); - } catch (_) { - directory = Directory.current; - } - } - // do not destroy your stable FluffyChat in debug mode - directory = Directory( - directory.uri.resolve(kDebugMode ? 'hive_debug' : 'hive').toFilePath(), - ); - directory.create(recursive: true); - path = directory.path; - } - return path; - } - - @override - int get maxFileSize => supportsFileStoring ? 100 * 1024 * 1024 : 0; - @override - bool get supportsFileStoring => !kIsWeb; - - Future _getFileStoreDirectory() async { - try { - try { - return (await getTemporaryDirectory()).path; - } catch (_) { - return (await getApplicationDocumentsDirectory()).path; - } - } catch (_) { - return (await getDownloadsDirectory())!.path; - } - } - - @override - Future getFile(Uri mxcUri) async { - if (!supportsFileStoring) return null; - final tempDirectory = await _getFileStoreDirectory(); - final file = - File('$tempDirectory/${Uri.encodeComponent(mxcUri.toString())}'); - if (await file.exists() == false) return null; - final bytes = await file.readAsBytes(); - return bytes; - } - - @override - Future storeFile(Uri mxcUri, Uint8List bytes, int time) async { - if (!supportsFileStoring) return null; - final tempDirectory = await _getFileStoreDirectory(); - final file = - File('$tempDirectory/${Uri.encodeComponent(mxcUri.toString())}'); - if (await file.exists()) return; - await file.writeAsBytes(bytes); - return; - } -} diff --git a/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/builder.dart b/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/builder.dart index 1add432d2..dfcc9d617 100644 --- a/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/builder.dart +++ b/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/builder.dart @@ -2,103 +2,96 @@ import 'dart:io'; import 'package:flutter/foundation.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; import 'package:path/path.dart'; import 'package:path_provider/path_provider.dart'; import 'package:sqflite_common_ffi/sqflite_ffi.dart'; import 'package:universal_html/html.dart' as html; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/client_manager.dart'; -import 'package:fluffychat/utils/matrix_sdk_extensions/flutter_hive_collections_database.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'cipher.dart'; import 'sqlcipher_stub.dart' if (dart.library.io) 'package:sqlcipher_flutter_libs/sqlcipher_flutter_libs.dart'; -Future flutterMatrixSdkDatabaseBuilder(Client client) async { +Future flutterMatrixSdkDatabaseBuilder(String clientName) async { MatrixSdkDatabase? database; try { - database = await _constructDatabase(client); + database = await _constructDatabase(clientName); await database.open(); return database; } catch (e, s) { Logs().wtf('Unable to construct database!', e, s); - // Try to delete database so that it can created again on next init: - database?.delete().catchError( - (e, s) => Logs().wtf( - 'Unable to delete database, after failed construction', - e, - s, - ), - ); - - // Delete database file: - if (database == null && !kIsWeb) { - final dbFile = File(await _getDatabasePath(client.clientName)); - if (await dbFile.exists()) await dbFile.delete(); - } try { // Send error notification: - final l10n = lookupL10n(PlatformDispatcher.instance.locale); - ClientManager.sendInitNotification( - l10n.initAppError, - l10n.databaseBuildErrorBody( - AppConfig.newIssueUrl.toString(), - e.toString(), - ), - ); + final l10n = await lookupL10n(PlatformDispatcher.instance.locale); + ClientManager.sendInitNotification(l10n.initAppError, e.toString()); } catch (e, s) { Logs().e('Unable to send error notification', e, s); } - return FlutterHiveCollectionsDatabase.databaseBuilder(client); + // Try to delete database so that it can created again on next init: + database?.delete().catchError( + (e, s) => Logs().wtf( + 'Unable to delete database, after failed construction', + e, + s, + ), + ); + + // Delete database file: + if (!kIsWeb) { + final dbFile = File(await _getDatabasePath(clientName)); + if (await dbFile.exists()) await dbFile.delete(); + } + + rethrow; } } -Future _constructDatabase(Client client) async { +Future _constructDatabase(String clientName) async { if (kIsWeb) { html.window.navigator.storage?.persist(); - return MatrixSdkDatabase(client.clientName); + return await MatrixSdkDatabase.init(clientName); } final cipher = await getDatabaseCipher(); Directory? fileStorageLocation; try { - fileStorageLocation = await getTemporaryDirectory(); + final temporaryDirectory = await getTemporaryDirectory(); + fileStorageLocation = await Directory( + join(temporaryDirectory.path, 'fluffychat_download_cache'), + ).create(recursive: true); } on MissingPlatformDirectoryException catch (_) { Logs().w( 'No temporary directory for file cache available on this platform.', ); } - final path = await _getDatabasePath(client.clientName); + final path = await _getDatabasePath(clientName); // fix dlopen for old Android await applyWorkaroundToOpenSqlCipherOnOldAndroidVersions(); // import the SQLite / SQLCipher shared objects / dynamic libraries - final factory = - createDatabaseFactoryFfi(ffiInit: SQfLiteEncryptionHelper.ffiInit); - - // migrate from potential previous SQLite database path to current one - await _migrateLegacyLocation(path, client.clientName); + final factory = createDatabaseFactoryFfi( + ffiInit: SQfLiteEncryptionHelper.ffiInit, + ); // required for [getDatabasesPath] databaseFactory = factory; + // migrate from potential previous SQLite database path to current one + await _migrateLegacyLocation(path, clientName); + // in case we got a cipher, we use the encryption helper // to manage SQLite encryption final helper = cipher == null ? null - : SQfLiteEncryptionHelper( - factory: factory, - path: path, - cipher: cipher, - ); + : SQfLiteEncryptionHelper(factory: factory, path: path, cipher: cipher); // check whether the DB is already encrypted and otherwise do so await helper?.ensureDatabaseFileEncrypted(); @@ -112,10 +105,10 @@ Future _constructDatabase(Client client) async { ), ); - return MatrixSdkDatabase( - client.clientName, + return await MatrixSdkDatabase.init( + clientName, database: database, - maxFileSize: 1024 * 1024 * 10, + maxFileSize: 1000 * 1000 * 10, fileStorageLocation: fileStorageLocation?.uri, deleteFilesAfterDuration: const Duration(days: 30), ); diff --git a/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/cipher.dart b/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/cipher.dart index a1903018d..3862346f9 100644 --- a/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/cipher.dart +++ b/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/cipher.dart @@ -4,12 +4,11 @@ import 'dart:math'; import 'package:flutter/foundation.dart'; import 'package:flutter/services.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_secure_storage/flutter_secure_storage.dart'; import 'package:matrix/matrix.dart'; -import 'package:shared_preferences/shared_preferences.dart'; import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/client_manager.dart'; const _passwordStorageKey = 'database_password'; @@ -26,10 +25,7 @@ Future getDatabaseCipher() async { final list = Uint8List(32); list.setAll(0, Iterable.generate(list.length, (i) => rng.nextInt(256))); final newPassword = base64UrlEncode(list); - await secureStorage.write( - key: _passwordStorageKey, - value: newPassword, - ); + await secureStorage.write(key: _passwordStorageKey, value: newPassword); } // workaround for if we just wrote to the key and it still doesn't exist password = await secureStorage.read(key: _passwordStorageKey); @@ -51,17 +47,16 @@ Future getDatabaseCipher() async { return password; } -void _sendNoEncryptionWarning(Object exception) async { - final store = await SharedPreferences.getInstance(); - final isStored = store.getBool(SettingKeys.noEncryptionWarningShown); +Future _sendNoEncryptionWarning(Object exception) async { + final isStored = AppSettings.noEncryptionWarningShown.value; if (isStored == true) return; - final l10n = lookupL10n(PlatformDispatcher.instance.locale); + final l10n = await lookupL10n(PlatformDispatcher.instance.locale); ClientManager.sendInitNotification( l10n.noDatabaseEncryption, exception.toString(), ); - await store.setBool(SettingKeys.noEncryptionWarningShown, true); + await AppSettings.noEncryptionWarningShown.setItem(true); } diff --git a/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/sqlcipher_stub.dart b/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/sqlcipher_stub.dart index b0f8b43dc..c5ec4feba 100644 --- a/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/sqlcipher_stub.dart +++ b/lib/utils/matrix_sdk_extensions/flutter_matrix_dart_sdk_database/sqlcipher_stub.dart @@ -1 +1,2 @@ -Future applyWorkaroundToOpenSqlCipherOnOldAndroidVersions() async {} +Future applyWorkaroundToOpenSqlCipherOnOldAndroidVersions() => + Future.value(); diff --git a/lib/utils/matrix_sdk_extensions/matrix_file_extension.dart b/lib/utils/matrix_sdk_extensions/matrix_file_extension.dart index 8ffa9201f..857c80954 100644 --- a/lib/utils/matrix_sdk_extensions/matrix_file_extension.dart +++ b/lib/utils/matrix_sdk_extensions/matrix_file_extension.dart @@ -1,46 +1,26 @@ -import 'dart:io'; - import 'package:flutter/material.dart'; import 'package:file_picker/file_picker.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:matrix/matrix.dart'; import 'package:share_plus/share_plus.dart'; -import 'package:universal_html/html.dart' as html; -import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/size_string.dart'; extension MatrixFileExtension on MatrixFile { - void save(BuildContext context) async { - if (PlatformInfos.isWeb) { - _webDownload(); - return; - } - + Future save(BuildContext context) async { + final scaffoldMessenger = ScaffoldMessenger.of(context); + final l10n = L10n.of(context); final downloadPath = await FilePicker.platform.saveFile( - dialogTitle: L10n.of(context)!.saveFile, + dialogTitle: l10n.saveFile, fileName: name, type: filePickerFileType, bytes: bytes, ); if (downloadPath == null) return; - if (PlatformInfos.isDesktop) { - final result = await showFutureLoadingDialog( - context: context, - future: () => File(downloadPath).writeAsBytes(bytes), - ); - if (result.error != null) return; - } - - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text( - L10n.of(context)!.fileHasBeenSavedAt(downloadPath), - ), - ), + scaffoldMessenger.showSnackBar( + SnackBar(content: Text(l10n.fileHasBeenSavedAt(downloadPath))), ); } @@ -51,28 +31,18 @@ extension MatrixFileExtension on MatrixFile { return FileType.any; } - void _webDownload() { - html.AnchorElement( - href: html.Url.createObjectUrlFromBlob( - html.Blob( - [bytes], - mimeType, - ), - ), - ) - ..download = name - ..click(); - } - - void share(BuildContext context) async { + Future share(BuildContext context) async { // Workaround for iPad from // https://github.com/fluttercommunity/plus_plugins/tree/main/packages/share_plus/share_plus#ipad final box = context.findRenderObject() as RenderBox?; - await Share.shareXFiles( - [XFile.fromData(bytes, name: name, mimeType: mimeType)], - sharePositionOrigin: - box == null ? null : box.localToGlobal(Offset.zero) & box.size, + await SharePlus.instance.share( + ShareParams( + files: [XFile.fromData(bytes, name: name, mimeType: mimeType)], + sharePositionOrigin: box == null + ? null + : box.localToGlobal(Offset.zero) & box.size, + ), ); return; } diff --git a/lib/utils/matrix_sdk_extensions/matrix_locals.dart b/lib/utils/matrix_sdk_extensions/matrix_locals.dart index 5714baa22..9a12d25f7 100644 --- a/lib/utils/matrix_sdk_extensions/matrix_locals.dart +++ b/lib/utils/matrix_sdk_extensions/matrix_locals.dart @@ -1,6 +1,7 @@ -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; + /// This is a temporary helper class until there is a proper solution to this with the new system class MatrixLocals extends MatrixLocalizations { final L10n l10n; @@ -36,13 +37,13 @@ class MatrixLocals extends MatrixLocalizations { } @override - String changedTheChatDescriptionTo(String senderName, String content) { - return l10n.changedTheChatDescriptionTo(senderName, content); + String changedTheChatDescriptionTo(String senderName, _) { + return l10n.changedTheChatDescription(senderName); } @override - String changedTheChatNameTo(String senderName, String content) { - return l10n.changedTheChatNameTo(senderName, content); + String changedTheChatNameTo(String senderName, _) { + return l10n.changedTheChatName(senderName); } @override @@ -344,4 +345,30 @@ class MatrixLocals extends MatrixLocalizations { @override String startedKeyVerification(String senderName) => l10n.startedKeyVerification(senderName); + + @override + String invitedBy(String senderName) => senderName; + + @override + String get cancelledSend => l10n.sendCanceled; + + @override + String voiceMessage( + String senderName, + Duration? duration, + ) => l10n.sentVoiceMessage( + senderName, + duration == null + ? '' + : '${duration.inMinutes.toString().padLeft(2, '0')}:${(duration.inSeconds % 60).toString().padLeft(2, '0')}', + ); + + @override + String get refreshingLastEvent => l10n.loadingPleaseWait; + + @override + String startedAPoll(String senderName) => '$senderName started a poll'; + + @override + String get pollHasBeenEnded => l10n.pollHasBeenEnded; } diff --git a/lib/utils/matrix_sdk_extensions/oidc_session_json_extension.dart b/lib/utils/matrix_sdk_extensions/oidc_session_json_extension.dart new file mode 100644 index 000000000..90fb99112 --- /dev/null +++ b/lib/utils/matrix_sdk_extensions/oidc_session_json_extension.dart @@ -0,0 +1,24 @@ +import 'package:matrix/matrix.dart'; + +extension OidcSessionJsonExtension on OidcLoginSession { + static const String storeKey = 'oidc_session'; + static const String homeserverStoreKey = 'oidc_stored_homeserver'; + Map toJson() => { + 'oidc_client_data': oidcClientData.toJson(), + 'authentication_uri': authenticationUri.toString(), + 'redirect_uri': redirectUri.toString(), + 'code_verifier': codeVerifier, + 'state': state, + }; + + static OidcLoginSession fromJson(Map json) => + OidcLoginSession( + oidcClientData: OidcClientData.fromJson( + json['oidc_client_data'] as Map, + ), + authenticationUri: Uri.parse(json['authentication_uri'] as String), + redirectUri: Uri.parse(json['redirect_uri'] as String), + codeVerifier: json['code_verifier'] as String, + state: json['state'] as String, + ); +} diff --git a/lib/utils/notification_background_handler.dart b/lib/utils/notification_background_handler.dart new file mode 100644 index 000000000..6c257e9a1 --- /dev/null +++ b/lib/utils/notification_background_handler.dart @@ -0,0 +1,262 @@ +import 'dart:convert'; +import 'dart:isolate'; +import 'dart:ui'; + +import 'package:collection/collection.dart'; +import 'package:flutter_local_notifications/flutter_local_notifications.dart'; +import 'package:flutter_vodozemac/flutter_vodozemac.dart' as vod; +import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/client_download_content_extension.dart'; +import 'package:fluffychat/utils/client_manager.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/utils/push_helper.dart'; +import '../config/app_config.dart'; +import '../config/setting_keys.dart'; + +bool _vodInitialized = false; + +extension NotificationResponseJson on NotificationResponse { + String toJsonString() => jsonEncode({ + 'type': notificationResponseType.name, + 'id': id, + 'actionId': actionId, + 'input': input, + 'payload': payload, + 'data': data, + }); + + static NotificationResponse fromJsonString(String jsonString) { + final json = jsonDecode(jsonString) as Map; + return NotificationResponse( + notificationResponseType: NotificationResponseType.values.singleWhere( + (t) => t.name == json['type'], + ), + id: json['id'] as int?, + actionId: json['actionId'] as String?, + input: json['input'] as String?, + payload: json['payload'] as String?, + data: json['data'] as Map, + ); + } +} + +Future waitForPushIsolateDone() async { + if (IsolateNameServer.lookupPortByName(AppConfig.pushIsolatePortName) != + null) { + Logs().i('Wait for Push Isolate to be done...'); + await Future.delayed(const Duration(milliseconds: 300)); + } +} + +@pragma('vm:entry-point') +Future notificationTapBackground( + NotificationResponse notificationResponse, +) async { + final sendPort = IsolateNameServer.lookupPortByName( + AppConfig.mainIsolatePortName, + ); + if (sendPort != null) { + sendPort.send(notificationResponse.toJsonString()); + Logs().i('Notification tap sent to main isolate!'); + return; + } + Logs().i( + 'Main isolate no up - Create temporary client for notification tap intend!', + ); + + final pushIsolateReceivePort = ReceivePort(); + IsolateNameServer.registerPortWithName( + pushIsolateReceivePort.sendPort, + AppConfig.pushIsolatePortName, + ); + + if (!_vodInitialized) { + await vod.init(); + _vodInitialized = true; + } + final store = await AppSettings.init(); + final client = (await ClientManager.getClients( + initialize: false, + store: store, + )).first; + await client.abortSync(); + await client.init( + waitForFirstSync: false, + waitUntilLoadCompletedLoaded: false, + ); + + if (!client.isLogged()) { + throw Exception('Notification tab in background but not logged in!'); + } + try { + await notificationTap(notificationResponse, client: client); + } finally { + await client.dispose(closeDatabase: false); + pushIsolateReceivePort.sendPort.send('DONE'); + IsolateNameServer.removePortNameMapping(AppConfig.pushIsolatePortName); + } + return; +} + +Future notificationTap( + NotificationResponse notificationResponse, { + GoRouter? router, + required Client client, + L10n? l10n, +}) async { + Logs().d( + 'Notification action handler started', + notificationResponse.notificationResponseType.name, + ); + final payload = FluffyChatPushPayload.fromString( + notificationResponse.payload ?? '', + ); + switch (notificationResponse.notificationResponseType) { + case NotificationResponseType.selectedNotification: + final roomId = payload.roomId; + if (roomId == null) return; + + if (router == null) { + Logs().v('Ignore select notification action in background mode'); + return; + } + Logs().v('Open room from notification tap', roomId); + await client.roomsLoading; + await client.accountDataLoading; + if (client.getRoomById(roomId) == null) { + await client + .waitForRoomInSync(roomId) + .timeout(const Duration(seconds: 30)); + } + router.go( + client.getRoomById(roomId)?.membership == Membership.invite + ? '/rooms' + : '/rooms/$roomId', + ); + case NotificationResponseType.selectedNotificationAction: + final actionType = FluffyChatNotificationActions.values.singleWhereOrNull( + (action) => action.name == notificationResponse.actionId, + ); + if (actionType == null) { + throw Exception('Selected notification with action but no action ID'); + } + final roomId = payload.roomId; + if (roomId == null) { + throw Exception('Selected notification with action but no payload'); + } + await client.roomsLoading; + await client.accountDataLoading; + await client.userDeviceKeysLoading; + final room = client.getRoomById(roomId); + if (room == null) { + throw Exception( + 'Selected notification with action but unknown room $roomId', + ); + } + switch (actionType) { + case FluffyChatNotificationActions.markAsRead: + await room.setReadMarker( + payload.eventId ?? room.lastEvent!.eventId, + mRead: payload.eventId ?? room.lastEvent!.eventId, + public: AppSettings.sendPublicReadReceipts.value, + ); + case FluffyChatNotificationActions.reply: + final input = notificationResponse.input; + if (input == null || input.isEmpty) { + throw Exception( + 'Selected notification with reply action but without input', + ); + } + + final eventId = await room.sendTextEvent( + input, + parseCommands: false, + displayPendingEvent: false, + ); + + if (PlatformInfos.isAndroid) { + final ownProfile = await room.client.fetchOwnProfile(); + final avatar = ownProfile.avatarUrl; + final avatarFile = avatar == null + ? null + : await client + .downloadMxcCached( + avatar, + thumbnailMethod: ThumbnailMethod.crop, + width: notificationAvatarDimension, + height: notificationAvatarDimension, + animated: false, + isThumbnail: true, + rounded: true, + ) + .timeout(const Duration(seconds: 3)); + final messagingStyleInformation = + await AndroidFlutterLocalNotificationsPlugin() + .getActiveNotificationMessagingStyle(id: room.id.hashCode); + if (messagingStyleInformation == null) return; + l10n ??= await lookupL10n(PlatformDispatcher.instance.locale); + messagingStyleInformation.messages?.add( + Message( + input, + DateTime.now(), + Person( + key: room.client.userID, + name: l10n.you, + icon: avatarFile == null + ? null + : ByteArrayAndroidIcon(avatarFile), + ), + ), + ); + + await FlutterLocalNotificationsPlugin().show( + id: room.id.hashCode, + title: room.getLocalizedDisplayname(MatrixLocals(l10n)), + body: input, + notificationDetails: NotificationDetails( + android: AndroidNotificationDetails( + AppConfig.pushNotificationsChannelId, + l10n.incomingMessages, + category: AndroidNotificationCategory.message, + shortcutId: room.id, + styleInformation: messagingStyleInformation, + groupKey: room.id, + playSound: false, + enableVibration: false, + actions: [ + AndroidNotificationAction( + FluffyChatNotificationActions.reply.name, + l10n.reply, + inputs: [ + AndroidNotificationActionInput( + label: l10n.writeAMessage, + ), + ], + cancelNotification: false, + allowGeneratedReplies: true, + semanticAction: SemanticAction.reply, + ), + AndroidNotificationAction( + FluffyChatNotificationActions.markAsRead.name, + l10n.markAsRead, + semanticAction: SemanticAction.markAsRead, + ), + ], + ), + ), + payload: FluffyChatPushPayload( + client.clientName, + room.id, + eventId, + ).toString(), + ); + } + } + } +} + +enum FluffyChatNotificationActions { markAsRead, reply } diff --git a/lib/utils/other_party_can_receive.dart b/lib/utils/other_party_can_receive.dart new file mode 100644 index 000000000..1738785d2 --- /dev/null +++ b/lib/utils/other_party_can_receive.dart @@ -0,0 +1,21 @@ +import 'package:matrix/matrix.dart'; + +extension OtherPartyCanReceiveExtension on Room { + bool get otherPartyCanReceiveMessages { + if (!encrypted) return true; + final users = getParticipants() + .map((u) => u.id) + .where((userId) => userId != client.userID) + .toSet(); + if (users.isEmpty) return true; + + for (final userId in users) { + if (client.userDeviceKeys[userId]?.deviceKeys.values.isNotEmpty == true) { + return true; + } + } + return false; + } +} + +class OtherPartyCanNotReceiveMessages implements Exception {} diff --git a/lib/utils/platform_infos.dart b/lib/utils/platform_infos.dart index b96104df4..0f225b733 100644 --- a/lib/utils/platform_infos.dart +++ b/lib/utils/platform_infos.dart @@ -3,11 +3,12 @@ import 'dart:io'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; import 'package:package_info_plus/package_info_plus.dart'; import 'package:url_launcher/url_launcher_string.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import '../config/app_config.dart'; abstract class PlatformInfos { @@ -29,10 +30,14 @@ abstract class PlatformInfos { static bool get usesTouchscreen => !isMobile; - static bool get platformCanRecord => (isMobile || isMacOS); + static bool get supportsVideoPlayer => + !PlatformInfos.isWindows && !PlatformInfos.isLinux; + + /// Web could also record in theory but currently only wav which is too large + static bool get platformCanRecord => (isMobile || isMacOS || isWeb); static String get clientName => - '${AppConfig.applicationName} ${isWeb ? 'web' : Platform.operatingSystem}${kReleaseMode ? '' : 'Debug'}'; + '${AppSettings.applicationName.value} ${isWeb ? 'web' : Platform.operatingSystem}${kReleaseMode ? '' : 'Debug'}'; static Future getVersion() async { var version = kIsWeb ? 'Web' : 'Unknown'; @@ -42,21 +47,16 @@ abstract class PlatformInfos { return version; } - static void showDialog(BuildContext context) async { + static Future showDialog(BuildContext context) async { final version = await PlatformInfos.getVersion(); showAboutDialog( context: context, children: [ - Text('Version: $version'), + Text(L10n.of(context).versionWithNumber(version)), TextButton.icon( onPressed: () => launchUrlString(AppConfig.sourceCodeUrl), icon: const Icon(Icons.source_outlined), - label: Text(L10n.of(context)!.sourceCode), - ), - TextButton.icon( - onPressed: () => launchUrlString(AppConfig.emojiFontUrl), - icon: const Icon(Icons.emoji_emotions_outlined), - label: const Text(AppConfig.emojiFontName), + label: Text(L10n.of(context).sourceCode), ), Builder( builder: (innerContext) { @@ -66,7 +66,19 @@ abstract class PlatformInfos { Navigator.of(innerContext).pop(); }, icon: const Icon(Icons.list_outlined), - label: const Text('Logs'), + label: Text(L10n.of(context).logs), + ); + }, + ), + Builder( + builder: (innerContext) { + return TextButton.icon( + onPressed: () { + context.go('/configs'); + Navigator.of(innerContext).pop(); + }, + icon: const Icon(Icons.settings_applications_outlined), + label: Text(L10n.of(context).advancedConfigs), ); }, ), @@ -77,7 +89,7 @@ abstract class PlatformInfos { height: 64, filterQuality: FilterQuality.medium, ), - applicationName: AppConfig.applicationName, + applicationName: AppSettings.applicationName.value, ); } } diff --git a/lib/utils/push_helper.dart b/lib/utils/push_helper.dart index edfdb4941..4b10623e3 100644 --- a/lib/utils/push_helper.dart +++ b/lib/utils/push_helper.dart @@ -1,29 +1,32 @@ -import 'dart:io'; +import 'dart:convert'; import 'dart:ui'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:collection/collection.dart'; -import 'package:flutter_cache_manager/flutter_cache_manager.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:flutter_local_notifications/flutter_local_notifications.dart'; -import 'package:flutter_shortcuts/flutter_shortcuts.dart'; +import 'package:flutter_shortcuts_new/flutter_shortcuts_new.dart'; import 'package:matrix/matrix.dart'; -import 'package:shared_preferences/shared_preferences.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/client_download_content_extension.dart'; import 'package:fluffychat/utils/client_manager.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/utils/notification_background_handler.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import 'package:fluffychat/utils/voip/callkeep_manager.dart'; + +const notificationAvatarDimension = 128; Future pushHelper( PushNotification notification, { Client? client, L10n? l10n, String? activeRoomId, - void Function(NotificationResponse?)? onSelectNotification, + required FlutterLocalNotificationsPlugin flutterLocalNotificationsPlugin, + bool useNotificationActions = true, }) async { try { await _tryPushHelper( @@ -31,35 +34,25 @@ Future pushHelper( client: client, l10n: l10n, activeRoomId: activeRoomId, - onSelectNotification: onSelectNotification, + flutterLocalNotificationsPlugin: flutterLocalNotificationsPlugin, + useNotificationActions: useNotificationActions, ); } catch (e, s) { - Logs().v('Push Helper has crashed!', e, s); + Logs().e('Push Helper has crashed! Writing into temporary file', e, s); - // Initialise the plugin. app_icon needs to be a added as a drawable resource to the Android head project - final flutterLocalNotificationsPlugin = FlutterLocalNotificationsPlugin(); - await flutterLocalNotificationsPlugin.initialize( - const InitializationSettings( - android: AndroidInitializationSettings('notifications_icon'), - iOS: DarwinInitializationSettings(), - ), - onDidReceiveNotificationResponse: onSelectNotification, - onDidReceiveBackgroundNotificationResponse: onSelectNotification, - ); - - l10n ??= lookupL10n(const Locale('en')); - flutterLocalNotificationsPlugin.show( - notification.roomId?.hashCode ?? 0, - l10n.newMessageInFluffyChat, - l10n.openAppToReadMessages, - NotificationDetails( + l10n ??= await lookupL10n(PlatformDispatcher.instance.locale); + await flutterLocalNotificationsPlugin.show( + id: notification.roomId?.hashCode ?? 0, + title: l10n.newMessageInFluffyChat, + body: l10n.openAppToReadMessages, + notificationDetails: NotificationDetails( iOS: const DarwinNotificationDetails(), android: AndroidNotificationDetails( AppConfig.pushNotificationsChannelId, l10n.incomingMessages, number: notification.counts?.unread, ticker: l10n.unreadChatsInApp( - AppConfig.applicationName, + AppSettings.applicationName.value, (notification.counts?.unread ?? 0).toString(), ), importance: Importance.high, @@ -77,7 +70,8 @@ Future _tryPushHelper( Client? client, L10n? l10n, String? activeRoomId, - void Function(NotificationResponse?)? onSelectNotification, + required FlutterLocalNotificationsPlugin flutterLocalNotificationsPlugin, + bool useNotificationActions = true, }) async { final isBackgroundMessage = client == null; Logs().v( @@ -92,25 +86,13 @@ Future _tryPushHelper( return; } - // Initialise the plugin. app_icon needs to be a added as a drawable resource to the Android head project - final flutterLocalNotificationsPlugin = FlutterLocalNotificationsPlugin(); - await flutterLocalNotificationsPlugin.initialize( - const InitializationSettings( - android: AndroidInitializationSettings('notifications_icon'), - iOS: DarwinInitializationSettings(), - ), - onDidReceiveNotificationResponse: onSelectNotification, - //onDidReceiveBackgroundNotificationResponse: onSelectNotification, - ); - client ??= (await ClientManager.getClients( initialize: false, - store: await SharedPreferences.getInstance(), - )) - .first; + store: await AppSettings.init(), + )).first; final event = await client.getEventByPushNotification( notification, - storeInDatabase: isBackgroundMessage, + storeInDatabase: false, ); if (event == null) { @@ -122,14 +104,14 @@ Future _tryPushHelper( // Make sure client is fully loaded and synced before dismiss notifications: await client.roomsLoading; await client.oneShotSync(); - final activeNotifications = - await flutterLocalNotificationsPlugin.getActiveNotifications(); + final activeNotifications = await flutterLocalNotificationsPlugin + .getActiveNotifications(); for (final activeNotification in activeNotifications) { final room = client.rooms.singleWhereOrNull( (room) => room.id.hashCode == activeNotification.id, ); if (room == null || !room.isUnreadOrInvited) { - flutterLocalNotificationsPlugin.cancel(activeNotification.id!); + flutterLocalNotificationsPlugin.cancel(id: activeNotification.id!); } } } @@ -143,9 +125,7 @@ Future _tryPushHelper( client.backgroundSync = true; } - if (event.type == EventTypes.CallInvite) { - CallKeepManager().initialize(); - } else if (event.type == EventTypes.CallHangup) { + if (event.type == EventTypes.CallHangup) { client.backgroundSync = false; } @@ -177,28 +157,26 @@ Future _tryPushHelper( ); // The person object for the android message style notification - final avatar = event.room.avatar - ?.getThumbnail( - client, - width: 256, - height: 256, - ) - .toString(); + final avatar = event.room.avatar; final senderAvatar = event.room.isDirectChat ? avatar - : event.senderFromMemoryOrFallback.avatarUrl - ?.getThumbnail( - client, - width: 256, - height: 256, - ) - .toString(); + : event.senderFromMemoryOrFallback.avatarUrl; - File? roomAvatarFile, senderAvatarFile; + Uint8List? roomAvatarFile, senderAvatarFile; try { roomAvatarFile = avatar == null ? null - : await DefaultCacheManager().getSingleFile(avatar); + : await client + .downloadMxcCached( + avatar, + thumbnailMethod: ThumbnailMethod.crop, + width: notificationAvatarDimension, + height: notificationAvatarDimension, + animated: false, + isThumbnail: true, + rounded: true, + ) + .timeout(const Duration(seconds: 3)); } catch (e, s) { Logs().e('Unable to get avatar picture', e, s); } @@ -206,14 +184,25 @@ Future _tryPushHelper( senderAvatarFile = event.room.isDirectChat ? roomAvatarFile : senderAvatar == null - ? null - : await DefaultCacheManager().getSingleFile(senderAvatar); + ? null + : await client + .downloadMxcCached( + senderAvatar, + thumbnailMethod: ThumbnailMethod.crop, + width: notificationAvatarDimension, + height: notificationAvatarDimension, + animated: false, + isThumbnail: true, + rounded: true, + ) + .timeout(const Duration(seconds: 3)); } catch (e, s) { Logs().e('Unable to get avatar picture', e, s); } final id = notification.roomId.hashCode; + final senderName = event.senderFromMemoryOrFallback.calcDisplayname(); // Show notification final newMessage = Message( @@ -222,23 +211,24 @@ Future _tryPushHelper( Person( bot: event.messageType == MessageTypes.Notice, key: event.senderId, - name: event.senderFromMemoryOrFallback.calcDisplayname(), + name: senderName, icon: senderAvatarFile == null ? null - : BitmapFilePathAndroidIcon(senderAvatarFile.path), + : ByteArrayAndroidIcon(senderAvatarFile), ), ); final messagingStyleInformation = PlatformInfos.isAndroid ? await AndroidFlutterLocalNotificationsPlugin() - .getActiveNotificationMessagingStyle(id) + .getActiveNotificationMessagingStyle(id: id) : null; messagingStyleInformation?.messages?.add(newMessage); final roomName = event.room.getLocalizedDisplayname(MatrixLocals(l10n)); - final notificationGroupId = - event.room.isDirectChat ? 'directChats' : 'groupChats'; + final notificationGroupId = event.room.isDirectChat + ? 'directChats' + : 'groupChats'; final groupName = event.room.isDirectChat ? l10n.directChats : l10n.groups; final messageRooms = AndroidNotificationChannelGroup( @@ -253,11 +243,13 @@ Future _tryPushHelper( await flutterLocalNotificationsPlugin .resolvePlatformSpecificImplementation< - AndroidFlutterLocalNotificationsPlugin>() + AndroidFlutterLocalNotificationsPlugin + >() ?.createNotificationChannelGroup(messageRooms); await flutterLocalNotificationsPlugin .resolvePlatformSpecificImplementation< - AndroidFlutterLocalNotificationsPlugin>() + AndroidFlutterLocalNotificationsPlugin + >() ?.createNotificationChannel(roomsChannel); final androidPlatformChannelSpecifics = AndroidNotificationDetails( @@ -266,31 +258,51 @@ Future _tryPushHelper( number: notification.counts?.unread, category: AndroidNotificationCategory.message, shortcutId: event.room.id, - styleInformation: messagingStyleInformation ?? + styleInformation: + messagingStyleInformation ?? MessagingStyleInformation( Person( - name: event.senderFromMemoryOrFallback.calcDisplayname(), + name: senderName, icon: roomAvatarFile == null ? null - : BitmapFilePathAndroidIcon(roomAvatarFile.path), + : ByteArrayAndroidIcon(roomAvatarFile), key: event.roomId, important: event.room.isFavourite, ), - conversationTitle: roomName, + conversationTitle: event.room.isDirectChat ? null : roomName, groupConversation: !event.room.isDirectChat, messages: [newMessage], ), ticker: event.calcLocalizedBodyFallback( matrixLocals, plaintextBody: true, - withSenderNamePrefix: true, + withSenderNamePrefix: !event.room.isDirectChat, hideReply: true, hideEdit: true, removeMarkdown: true, ), importance: Importance.high, priority: Priority.max, - groupKey: notificationGroupId, + groupKey: event.room.spaceParents.firstOrNull?.roomId ?? 'rooms', + actions: event.type == EventTypes.RoomMember || !useNotificationActions + ? null + : [ + AndroidNotificationAction( + FluffyChatNotificationActions.reply.name, + l10n.reply, + inputs: [ + AndroidNotificationActionInput(label: l10n.writeAMessage), + ], + cancelNotification: false, + allowGeneratedReplies: true, + semanticAction: SemanticAction.reply, + ), + AndroidNotificationAction( + FluffyChatNotificationActions.markAsRead.name, + l10n.markAsRead, + semanticAction: SemanticAction.markAsRead, + ), + ], ); const iOSPlatformChannelSpecifics = DarwinNotificationDetails(); final platformChannelSpecifics = NotificationDetails( @@ -305,15 +317,36 @@ Future _tryPushHelper( } await flutterLocalNotificationsPlugin.show( - id, - title, - body, - platformChannelSpecifics, - payload: event.roomId, + id: id, + title: title, + body: body, + notificationDetails: platformChannelSpecifics, + payload: FluffyChatPushPayload( + client.clientName, + event.room.id, + event.eventId, + ).toString(), ); Logs().v('Push helper has been completed!'); } +class FluffyChatPushPayload { + final String? clientName, roomId, eventId; + + FluffyChatPushPayload(this.clientName, this.roomId, this.eventId); + + factory FluffyChatPushPayload.fromString(String payload) { + final parts = payload.split('|'); + if (parts.length != 3) { + return FluffyChatPushPayload(null, null, null); + } + return FluffyChatPushPayload(parts.first, parts[1], parts[2]); + } + + @override + String toString() => '$clientName|$roomId|$eventId'; +} + /// Creates a shortcut for Android platform but does not block displaying the /// notification. This is optional but provides a nicer view of the /// notification popup. @@ -321,7 +354,7 @@ Future _setShortcut( Event event, L10n l10n, String title, - File? avatarFile, + Uint8List? avatarFile, ) async { final flutterShortcuts = FlutterShortcuts(); await flutterShortcuts.initialize(debug: !kReleaseMode); @@ -331,10 +364,7 @@ Future _setShortcut( action: AppConfig.inviteLinkPrefix + event.room.id, shortLabel: title, conversationShortcut: true, - icon: avatarFile == null - ? null - : ShortcutMemoryIcon(jpegImage: await avatarFile.readAsBytes()) - .toString(), + icon: avatarFile == null ? null : base64Encode(avatarFile), shortcutIconAsset: avatarFile == null ? ShortcutIconAsset.androidAsset : ShortcutIconAsset.memoryAsset, diff --git a/lib/utils/resize_image.dart b/lib/utils/resize_image.dart deleted file mode 100644 index 3bfe81a6d..000000000 --- a/lib/utils/resize_image.dart +++ /dev/null @@ -1,53 +0,0 @@ -import 'dart:io'; - -import 'package:matrix/matrix.dart'; -import 'package:path_provider/path_provider.dart'; -import 'package:video_compress/video_compress.dart'; - -import 'package:fluffychat/utils/platform_infos.dart'; - -extension ResizeImage on MatrixFile { - static const int max = 1200; - static const int quality = 40; - - Future resizeVideo() async { - final tmpDir = await getTemporaryDirectory(); - final tmpFile = File('${tmpDir.path}/$name'); - MediaInfo? mediaInfo; - await tmpFile.writeAsBytes(bytes); - try { - // will throw an error e.g. on Android SDK < 18 - mediaInfo = await VideoCompress.compressVideo(tmpFile.path); - } catch (e, s) { - Logs().w('Error while compressing video', e, s); - } - return MatrixVideoFile( - bytes: (await mediaInfo?.file?.readAsBytes()) ?? bytes, - name: name, - mimeType: mimeType, - width: mediaInfo?.width, - height: mediaInfo?.height, - duration: mediaInfo?.duration?.round(), - ); - } - - Future getVideoThumbnail() async { - if (!PlatformInfos.isMobile) return null; - final tmpDir = await getTemporaryDirectory(); - final tmpFile = File('${tmpDir.path}/$name'); - if (await tmpFile.exists() == false) { - await tmpFile.writeAsBytes(bytes); - } - try { - final bytes = await VideoCompress.getByteThumbnail(tmpFile.path); - if (bytes == null) return null; - return MatrixImageFile( - bytes: bytes, - name: name, - ); - } catch (e, s) { - Logs().w('Error while compressing video', e, s); - } - return null; - } -} diff --git a/lib/utils/resize_video.dart b/lib/utils/resize_video.dart new file mode 100644 index 000000000..ae249818e --- /dev/null +++ b/lib/utils/resize_video.dart @@ -0,0 +1,48 @@ +import 'package:cross_file/cross_file.dart'; +import 'package:matrix/matrix.dart'; +import 'package:video_compress/video_compress.dart'; + +import 'package:fluffychat/utils/platform_infos.dart'; + +extension ResizeImage on XFile { + static const int max = 1200; + static const int quality = 40; + + Future getVideoInfo({bool compress = true}) async { + MediaInfo? mediaInfo; + try { + if (PlatformInfos.isMobile) { + // will throw an error e.g. on Android SDK < 18 + mediaInfo = compress + ? await VideoCompress.compressVideo(path, deleteOrigin: true) + : await VideoCompress.getMediaInfo(path); + } + } catch (e, s) { + Logs().w('Error while fetching video media info', e, s); + } + + return MatrixVideoFile( + bytes: (await mediaInfo?.file?.readAsBytes()) ?? await readAsBytes(), + name: name, + mimeType: mimeType, + // on Android width and height is reversed: + // https://github.com/jonataslaw/VideoCompress/issues/172 + width: PlatformInfos.isAndroid ? mediaInfo?.height : mediaInfo?.width, + height: PlatformInfos.isAndroid ? mediaInfo?.width : mediaInfo?.height, + duration: mediaInfo?.duration?.round(), + ); + } + + Future getVideoThumbnail() async { + if (!PlatformInfos.isMobile) return null; + + try { + final bytes = await VideoCompress.getByteThumbnail(path); + if (bytes == null) return null; + return MatrixImageFile(bytes: bytes, name: name); + } catch (e, s) { + Logs().w('Error while compressing video', e, s); + } + return null; + } +} diff --git a/lib/utils/room_status_extension.dart b/lib/utils/room_status_extension.dart index 02c70b088..3021a3147 100644 --- a/lib/utils/room_status_extension.dart +++ b/lib/utils/room_status_extension.dart @@ -1,8 +1,8 @@ import 'package:flutter/widgets.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import '../config/app_config.dart'; extension RoomStatusExtension on Room { @@ -12,26 +12,26 @@ extension RoomStatusExtension on Room { typingUsers.removeWhere((User u) => u.id == client.userID); if (AppConfig.hideTypingUsernames) { - typingText = L10n.of(context)!.isTyping; + typingText = L10n.of(context).isTyping; if (typingUsers.first.id != directChatMatrixID) { - typingText = - L10n.of(context)!.numUsersTyping(typingUsers.length.toString()); + typingText = L10n.of(context).numUsersTyping(typingUsers.length); } } else if (typingUsers.length == 1) { - typingText = L10n.of(context)!.isTyping; + typingText = L10n.of(context).isTyping; if (typingUsers.first.id != directChatMatrixID) { - typingText = - L10n.of(context)!.userIsTyping(typingUsers.first.calcDisplayname()); + typingText = L10n.of( + context, + ).userIsTyping(typingUsers.first.calcDisplayname()); } } else if (typingUsers.length == 2) { - typingText = L10n.of(context)!.userAndUserAreTyping( + typingText = L10n.of(context).userAndUserAreTyping( typingUsers.first.calcDisplayname(), typingUsers[1].calcDisplayname(), ); } else if (typingUsers.length > 2) { - typingText = L10n.of(context)!.userAndOthersAreTyping( + typingText = L10n.of(context).userAndOthersAreTyping( typingUsers.first.calcDisplayname(), - (typingUsers.length - 1).toString(), + (typingUsers.length - 1), ); } return typingText; diff --git a/lib/utils/show_scaffold_dialog.dart b/lib/utils/show_scaffold_dialog.dart new file mode 100644 index 000000000..7e552f90d --- /dev/null +++ b/lib/utils/show_scaffold_dialog.dart @@ -0,0 +1,34 @@ +import 'package:flutter/material.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; + +Future showScaffoldDialog({ + required BuildContext context, + Color? barrierColor, + Color? containerColor, + double maxWidth = 480, + double maxHeight = 720, + required Widget Function(BuildContext context) builder, +}) => showDialog( + context: context, + useSafeArea: false, + builder: FluffyThemes.isColumnMode(context) + ? (context) => Center( + child: Container( + decoration: BoxDecoration( + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + color: + containerColor ?? Theme.of(context).scaffoldBackgroundColor, + ), + clipBehavior: Clip.hardEdge, + margin: const EdgeInsets.all(16), + constraints: BoxConstraints( + maxWidth: maxWidth, + maxHeight: maxHeight, + ), + child: builder(context), + ), + ) + : builder, +); diff --git a/lib/utils/show_update_snackbar.dart b/lib/utils/show_update_snackbar.dart new file mode 100644 index 000000000..7d47f1bf4 --- /dev/null +++ b/lib/utils/show_update_snackbar.dart @@ -0,0 +1,36 @@ +import 'package:flutter/material.dart'; + +import 'package:shared_preferences/shared_preferences.dart'; +import 'package:url_launcher/url_launcher_string.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; + +abstract class UpdateNotifier { + static const String versionStoreKey = 'last_known_version'; + + static Future showUpdateSnackBar(BuildContext context) async { + final scaffoldMessenger = ScaffoldMessenger.of(context); + final currentVersion = await PlatformInfos.getVersion(); + final store = await SharedPreferences.getInstance(); + final storedVersion = store.getString(versionStoreKey); + + if (currentVersion != storedVersion) { + if (storedVersion != null) { + scaffoldMessenger.showSnackBar( + SnackBar( + duration: const Duration(seconds: 30), + showCloseIcon: true, + content: Text(L10n.of(context).updateInstalled(currentVersion)), + action: SnackBarAction( + label: L10n.of(context).changelog, + onPressed: () => launchUrlString(AppConfig.changelogUrl), + ), + ), + ); + } + await store.setString(versionStoreKey, currentVersion); + } + } +} diff --git a/lib/utils/sign_in_flows/check_homeserver.dart b/lib/utils/sign_in_flows/check_homeserver.dart new file mode 100644 index 000000000..5b1436152 --- /dev/null +++ b/lib/utils/sign_in_flows/check_homeserver.dart @@ -0,0 +1,86 @@ +import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; + +import 'package:go_router/go_router.dart'; +import 'package:url_launcher/url_launcher_string.dart'; + +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/sign_in/view_model/model/public_homeserver_data.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/utils/sign_in_flows/oidc_login.dart'; +import 'package:fluffychat/utils/sign_in_flows/sso_login.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +Future connectToHomeserverFlow( + PublicHomeserverData homeserverData, + BuildContext context, + void Function(AsyncSnapshot) setState, + bool signUp, +) async { + setState(AsyncSnapshot.waiting()); + try { + final homeserverInput = homeserverData.name!; + var homeserver = Uri.parse(homeserverInput); + if (homeserver.scheme.isEmpty) { + homeserver = Uri.https(homeserverInput, ''); + } + final l10n = L10n.of(context); + final client = await Matrix.of(context).getLoginClient(); + final (_, _, loginFlows, authMetadata) = await client.checkHomeserver( + homeserver, + fetchAuthMetadata: true, + ); + + final regLink = homeserverData.regLink; + final supportsSso = loginFlows.any((flow) => flow.type == 'm.login.sso'); + + if ((kIsWeb || PlatformInfos.isLinux) && + (supportsSso || authMetadata != null || (signUp && regLink != null))) { + final consent = await showOkCancelAlertDialog( + context: context, + title: l10n.appWantsToUseForLogin(homeserverInput), + message: l10n.appWantsToUseForLoginDescription, + okLabel: l10n.continueText, + ); + if (consent != OkCancelResult.ok) return; + } + + if (authMetadata != null && AppSettings.enableMatrixNativeOIDC.value) { + await oidcLoginFlow(client, context, signUp); + } else if (supportsSso) { + await ssoLoginFlow(client, context, signUp); + } else { + if (signUp && regLink != null) { + await launchUrlString(regLink); + } + final pathSegments = List.of( + GoRouter.of(context).routeInformationProvider.value.uri.pathSegments, + ); + pathSegments.removeLast(); + pathSegments.add('login'); + context.go('/${pathSegments.join('/')}', extra: client); + setState(AsyncSnapshot.withData(ConnectionState.done, true)); + return; + } + + await AppSettings.defaultHomeserver.setItem(homeserverInput); + + if (context.mounted) { + setState(AsyncSnapshot.withData(ConnectionState.done, true)); + context.go('/backup'); + } + } catch (e, s) { + setState(AsyncSnapshot.withError(ConnectionState.done, e, s)); + if (!context.mounted) return; + ScaffoldMessenger.of(context).showSnackBar( + SnackBar( + content: Text( + e.toLocalizedString(context, ExceptionContext.checkHomeserver), + ), + ), + ); + } +} diff --git a/lib/utils/sign_in_flows/oidc_login.dart b/lib/utils/sign_in_flows/oidc_login.dart new file mode 100644 index 000000000..3dac70791 --- /dev/null +++ b/lib/utils/sign_in_flows/oidc_login.dart @@ -0,0 +1,97 @@ +import 'dart:convert'; + +import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; + +import 'package:flutter_web_auth_2/flutter_web_auth_2.dart'; +import 'package:matrix/matrix.dart'; +import 'package:shared_preferences/shared_preferences.dart'; +import 'package:universal_html/html.dart' as html; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/oidc_session_json_extension.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; + +Future oidcLoginFlow( + Client client, + BuildContext context, + bool signUp, +) async { + Logs().i('Starting Matrix Native OIDC Flow...'); + final redirectUrl = kIsWeb + ? Uri.parse(html.window.location.href.split('#').first.split('?').first) + : (PlatformInfos.isMobile || PlatformInfos.isWeb || PlatformInfos.isMacOS) + ? Uri.parse('${AppConfig.appOpenUrlScheme.toLowerCase()}:/login') + : Uri.parse('http://localhost:3001/login'); + + final urlScheme = + (PlatformInfos.isMobile || PlatformInfos.isWeb || PlatformInfos.isMacOS) + ? redirectUrl.scheme + : 'http://localhost:3001'; + + final clientUri = Uri.parse(AppConfig.website); + final supportWebPlatform = + kIsWeb && + kReleaseMode && + redirectUrl.scheme == 'https' && + redirectUrl.host.contains(clientUri.host); + if (!supportWebPlatform) { + Logs().w( + 'OIDC Application Type web is not supported. Using native now. Please use this instance not in production!', + ); + } + + final oidcClientData = await client.registerOidcClient( + redirectUris: [redirectUrl], + applicationType: supportWebPlatform + ? OidcApplicationType.web + : OidcApplicationType.native, + clientInformation: OidcClientInformation( + clientName: AppSettings.applicationName.value, + clientUri: clientUri, + logoUri: Uri.parse('https://fluffy.chat/assets/favicon.png'), + tosUri: null, + policyUri: AppConfig.privacyUrl, + ), + ); + + final session = await client.initOidcLoginSession( + oidcClientData: oidcClientData, + redirectUri: redirectUrl, + prompt: signUp ? 'create' : null, + ); + + if (!context.mounted) return; + + if (kIsWeb) { + final store = await SharedPreferences.getInstance(); + store.setString( + OidcSessionJsonExtension.homeserverStoreKey, + client.homeserver!.toString(), + ); + store.setString( + OidcSessionJsonExtension.storeKey, + jsonEncode(session.toJson()), + ); + } + + final returnUrlString = await FlutterWebAuth2.authenticate( + url: session.authenticationUri.toString(), + callbackUrlScheme: urlScheme, + options: FlutterWebAuth2Options( + useWebview: PlatformInfos.isMobile, + windowName: '_self', + ), + ); + if (kIsWeb) return; // On Web we return at intro page when app starts again! + + final returnUrl = Uri.parse(returnUrlString); + final queryParameters = returnUrl.hasFragment + ? Uri.parse(returnUrl.fragment).queryParameters + : returnUrl.queryParameters; + final code = queryParameters['code'] as String; + final state = queryParameters['state'] as String; + + await client.oidcLogin(session: session, code: code, state: state); +} diff --git a/lib/utils/sign_in_flows/sso_login.dart b/lib/utils/sign_in_flows/sso_login.dart new file mode 100644 index 000000000..325793c16 --- /dev/null +++ b/lib/utils/sign_in_flows/sso_login.dart @@ -0,0 +1,50 @@ +import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; + +import 'package:flutter_web_auth_2/flutter_web_auth_2.dart'; +import 'package:matrix/matrix.dart'; +import 'package:universal_html/html.dart' as html; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/utils/platform_infos.dart'; + +Future ssoLoginFlow( + Client client, + BuildContext context, + bool signUp, +) async { + Logs().i('Starting legacy SSO Flow...'); + final redirectUrl = kIsWeb + ? Uri.parse( + html.window.location.href, + ).resolveUri(Uri(pathSegments: ['auth.html'])).toString() + : (PlatformInfos.isMobile || PlatformInfos.isWeb || PlatformInfos.isMacOS) + ? '${AppConfig.appOpenUrlScheme.toLowerCase()}://login' + : 'http://localhost:3001//login'; + + final url = client.homeserver!.replace( + path: '/_matrix/client/v3/login/sso/redirect', + queryParameters: { + 'redirectUrl': redirectUrl, + 'action': signUp ? 'register' : 'login', + }, + ); + + final urlScheme = + (PlatformInfos.isMobile || PlatformInfos.isWeb || PlatformInfos.isMacOS) + ? Uri.parse(redirectUrl).scheme + : 'http://localhost:3001'; + final result = await FlutterWebAuth2.authenticate( + url: url.toString(), + callbackUrlScheme: urlScheme, + options: FlutterWebAuth2Options(useWebview: PlatformInfos.isMobile), + ); + final token = Uri.parse(result).queryParameters['loginToken']; + if (token?.isEmpty ?? false) return; + + await client.login( + LoginType.mLoginToken, + token: token, + initialDeviceDisplayName: PlatformInfos.clientName, + ); +} diff --git a/lib/utils/size_string.dart b/lib/utils/size_string.dart index 930a97f9a..619462ab0 100644 --- a/lib/utils/size_string.dart +++ b/lib/utils/size_string.dart @@ -1,18 +1,21 @@ extension SizeString on num { String get sizeString { var size = toDouble(); - if (size < 1000000) { + if (size < 1000) { + return '${size.round()} Bytes'; + } + if (size < 1000 * 1000) { size = size / 1000; size = (size * 10).round() / 10; - return '${size.toString()} KB'; - } else if (size < 1000000000) { + return '$size KB'; + } + if (size < 1000 * 1000 * 1000) { size = size / 1000000; size = (size * 10).round() / 10; - return '${size.toString()} MB'; - } else { - size = size / 1000000000; - size = (size * 10).round() / 10; - return '${size.toString()} GB'; + return '$size MB'; } + size = size / 1000 * 1000 * 1000 * 1000; + size = (size * 10).round() / 10; + return '$size GB'; } } diff --git a/lib/utils/stream_extension.dart b/lib/utils/stream_extension.dart index 66e840fce..80983b50f 100644 --- a/lib/utils/stream_extension.dart +++ b/lib/utils/stream_extension.dart @@ -35,7 +35,7 @@ extension StreamExtension on Stream { }; final subscription = listen( (_) => onMessage?.call(), - onDone: () => controller.close(), + onDone: controller.close, onError: (e, s) => controller.addError(e, s), ); // add proper cleanup to the subscription and the controller, to not memory leak diff --git a/lib/utils/string_color.dart b/lib/utils/string_color.dart index b3c251b3a..a0dfbf5c0 100644 --- a/lib/utils/string_color.dart +++ b/lib/utils/string_color.dart @@ -9,12 +9,12 @@ extension StringColor on String { number += codeUnitAt(i); } number = (number % 12) * 25.5; - return HSLColor.fromAHSL(1, number, 1, light).toColor(); + return HSLColor.fromAHSL(0.75, number, 1, light).toColor(); } Color get color { _colorCache[this] ??= {}; - return _colorCache[this]![0.35] ??= _getColorLight(0.35); + return _colorCache[this]![0.3] ??= _getColorLight(0.3); } Color get darkColor { @@ -29,6 +29,6 @@ extension StringColor on String { Color get lightColorAvatar { _colorCache[this] ??= {}; - return _colorCache[this]![0.4] ??= _getColorLight(0.4); + return _colorCache[this]![0.45] ??= _getColorLight(0.45); } } diff --git a/lib/utils/sync_status_localization.dart b/lib/utils/sync_status_localization.dart new file mode 100644 index 000000000..c48e71252 --- /dev/null +++ b/lib/utils/sync_status_localization.dart @@ -0,0 +1,28 @@ +import 'package:flutter/material.dart'; + +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; + +extension SyncStatusLocalization on SyncStatusUpdate { + String calcLocalizedString(BuildContext context) { + final progress = this.progress; + switch (status) { + case SyncStatus.waitingForResponse: + return L10n.of(context).waitingForServer; + case SyncStatus.error: + return ((error?.exception ?? Object()) as Object).toLocalizedString( + context, + ); + case SyncStatus.processing: + case SyncStatus.cleaningUp: + case SyncStatus.finished: + return progress == null + ? L10n.of(context).synchronizingPleaseWait + : L10n.of(context).synchronizingPleaseWaitCounter( + (progress * 100).round().toString(), + ); + } + } +} diff --git a/lib/utils/tor_stub.dart b/lib/utils/tor_stub.dart deleted file mode 100644 index 3223d087f..000000000 --- a/lib/utils/tor_stub.dart +++ /dev/null @@ -1,7 +0,0 @@ -/// Stub class for [TorBrowserDetector] -/// -/// statically returns false as Tor **browser** can only be detected in a -/// **browser**. -abstract class TorBrowserDetector { - static Future get isTorBrowser => Future.value(false); -} diff --git a/lib/utils/uia_request_manager.dart b/lib/utils/uia_request_manager.dart index 04c8b4844..e422f966c 100644 --- a/lib/utils/uia_request_manager.dart +++ b/lib/utils/uia_request_manager.dart @@ -1,15 +1,22 @@ import 'dart:async'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:matrix/matrix.dart'; -import 'package:url_launcher/url_launcher_string.dart'; +import 'package:flutter/material.dart'; +import 'package:matrix/matrix.dart'; +import 'package:url_launcher/url_launcher.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/fluffy_chat_app.dart'; import 'package:fluffychat/widgets/matrix.dart'; extension UiaRequestManager on MatrixState { Future uiaRequestHandler(UiaRequest uiaRequest) async { - final l10n = L10n.of(context)!; + final l10n = L10n.of(context); + final navigatorContext = + FluffyChatApp.router.routerDelegate.navigatorKey.currentContext ?? + context; try { if (uiaRequest.state != UiaRequestState.waitForUser || uiaRequest.nextStages.isEmpty) { @@ -20,22 +27,18 @@ extension UiaRequestManager on MatrixState { Logs().d('Uia Request Stage: $stage'); switch (stage) { case AuthenticationTypes.password: - final input = cachedPassword ?? + final input = + cachedPassword ?? (await showTextInputDialog( - context: context, + context: navigatorContext, title: l10n.pleaseEnterYourPassword, okLabel: l10n.ok, cancelLabel: l10n.cancel, - textFields: [ - const DialogTextField( - minLines: 1, - maxLines: 1, - obscureText: true, - hintText: '******', - ), - ], - )) - ?.single; + minLines: 1, + maxLines: 1, + obscureText: true, + hintText: '******', + )); if (input == null || input.isEmpty) { return uiaRequest.cancel(); } @@ -49,7 +52,7 @@ extension UiaRequestManager on MatrixState { case AuthenticationTypes.emailIdentity: if (currentThreepidCreds == null) { return uiaRequest.cancel( - UiaException(L10n.of(context)!.serverRequiresEmail), + UiaException(L10n.of(context).serverRequiresEmail), ); } final auth = AuthenticationThreePidCreds( @@ -63,7 +66,7 @@ extension UiaRequestManager on MatrixState { if (OkCancelResult.ok == await showOkCancelAlertDialog( useRootNavigator: false, - context: context, + context: navigatorContext, title: l10n.weSentYouAnEmail, message: l10n.pleaseClickOnLink, okLabel: l10n.iHaveClickedOnLink, @@ -80,24 +83,35 @@ extension UiaRequestManager on MatrixState { ), ); default: - final url = Uri.parse( - '${client.homeserver}/_matrix/client/r0/auth/$stage/fallback/web?session=${uiaRequest.session}', + final stageUrl = uiaRequest.params + .tryGetMap(stage) + ?.tryGet('url'); + final fallbackUrl = client.homeserver!.replace( + path: '/_matrix/client/v3/auth/$stage/fallback/web', + queryParameters: {'session': uiaRequest.session}, + ); + final url = stageUrl != null + ? (Uri.tryParse(stageUrl) ?? fallbackUrl) + : fallbackUrl; + + final consent = await showOkCancelAlertDialog( + useRootNavigator: false, + title: l10n.pleaseFollowInstructionsOnWeb, + context: navigatorContext, + okLabel: l10n.open, + cancelLabel: l10n.cancel, + ); + if (consent != OkCancelResult.ok) return uiaRequest.cancel(); + + launchUrl(url, mode: LaunchMode.inAppBrowserView); + final completer = Completer(); + final listener = AppLifecycleListener(onResume: completer.complete); + await completer.future; + listener.dispose(); + + return uiaRequest.completeStage( + AuthenticationData(session: uiaRequest.session), ); - launchUrlString(url.toString()); - if (OkCancelResult.ok == - await showOkCancelAlertDialog( - useRootNavigator: false, - message: l10n.pleaseFollowInstructionsOnWeb, - context: context, - okLabel: l10n.next, - cancelLabel: l10n.cancel, - )) { - return uiaRequest.completeStage( - AuthenticationData(session: uiaRequest.session), - ); - } else { - return uiaRequest.cancel(); - } } } catch (e, s) { Logs().e('Error while background UIA', e, s); diff --git a/lib/utils/url_launcher.dart b/lib/utils/url_launcher.dart index 53de9b138..d3644e49a 100644 --- a/lib/utils/url_launcher.dart +++ b/lib/utils/url_launcher.dart @@ -1,19 +1,18 @@ import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; import 'package:collection/collection.dart' show IterableExtension; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; import 'package:punycode/punycode.dart'; import 'package:url_launcher/url_launcher_string.dart'; import 'package:fluffychat/config/app_config.dart'; -import 'package:fluffychat/pages/user_bottom_sheet/user_bottom_sheet.dart'; -import 'package:fluffychat/utils/adaptive_bottom_sheet.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/user_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'package:fluffychat/widgets/matrix.dart'; -import 'package:fluffychat/widgets/public_room_bottom_sheet.dart'; +import '../widgets/adaptive_dialogs/public_room_dialog.dart'; import 'platform_infos.dart'; class UrlLauncher { @@ -28,7 +27,7 @@ class UrlLauncher { const UrlLauncher(this.context, this.url, [this.name]); - void launchUrl() async { + Future launchUrl() async { if (url!.toLowerCase().startsWith(AppConfig.deepLinkPrefix) || url!.toLowerCase().startsWith(AppConfig.inviteLinkPrefix) || {'#', '@', '!', '+', '\$'}.contains(url![0]) || @@ -39,7 +38,7 @@ class UrlLauncher { if (uri == null) { // we can't open this thing ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.cantOpenUri(url!))), + SnackBar(content: Text(L10n.of(context).cantOpenUri(url!))), ); return; } @@ -49,10 +48,10 @@ class UrlLauncher { // that the user can see the actual url before opening the browser. final consent = await showOkCancelAlertDialog( context: context, - title: L10n.of(context)!.openLinkInBrowser, + title: L10n.of(context).openLinkInBrowser, message: url, - okLabel: L10n.of(context)!.yes, - cancelLabel: L10n.of(context)!.cancel, + okLabel: L10n.of(context).open, + cancelLabel: L10n.of(context).cancel, ); if (consent != OkCancelResult.ok) return; } @@ -67,7 +66,7 @@ class UrlLauncher { .split(';') .first .split(',') - .map((s) => double.tryParse(s)) + .map(double.tryParse) .toList(); if (latlong.length == 2 && latlong.first != null && @@ -93,20 +92,23 @@ class UrlLauncher { } if (uri.host.isEmpty) { ScaffoldMessenger.of(context).showSnackBar( - SnackBar(content: Text(L10n.of(context)!.cantOpenUri(url!))), + SnackBar(content: Text(L10n.of(context).cantOpenUri(url!))), ); return; } // okay, we have either an http or an https URI. // As some platforms have issues with opening unicode URLs, we are going to help // them out by punycode-encoding them for them ourself. - final newHost = uri.host.split('.').map((hostPartEncoded) { - final hostPart = Uri.decodeComponent(hostPartEncoded); - final hostPartPunycode = punycodeEncode(hostPart); - return hostPartPunycode != '$hostPart-' - ? 'xn--$hostPartPunycode' - : hostPart; - }).join('.'); + final newHost = uri.host + .split('.') + .map((hostPartEncoded) { + final hostPart = Uri.decodeComponent(hostPartEncoded); + final hostPartPunycode = punycodeEncode(hostPart); + return hostPartPunycode != '$hostPart-' + ? 'xn--$hostPartPunycode' + : hostPart; + }) + .join('.'); // Force LaunchMode.externalApplication, otherwise url_launcher will default // to opening links in a webview on mobile platforms. launchUrlString( @@ -115,20 +117,20 @@ class UrlLauncher { ); } - void openMatrixToUrl() async { + Future openMatrixToUrl() async { final matrix = Matrix.of(context); final url = this.url!.replaceFirst( - AppConfig.deepLinkPrefix, - AppConfig.inviteLinkPrefix, - ); + AppConfig.deepLinkPrefix, + AppConfig.inviteLinkPrefix, + ); // The identifier might be a matrix.to url and needs escaping. Or, it might have multiple // identifiers (room id & event id), or it might also have a query part. // All this needs parsing. - final identityParts = url.parseIdentifierIntoParts() ?? + final identityParts = + url.parseIdentifierIntoParts() ?? Uri.tryParse(url)?.host.parseIdentifierIntoParts() ?? - Uri.tryParse(url) - ?.pathSegments + Uri.tryParse(url)?.pathSegments .lastWhereOrNull((_) => true) ?.parseIdentifierIntoParts(); if (identityParts == null) { @@ -139,7 +141,8 @@ class UrlLauncher { // we got a room! Let's open that one final roomIdOrAlias = identityParts.primaryIdentifier; final event = identityParts.secondaryIdentifier; - var room = matrix.client.getRoomByAlias(roomIdOrAlias) ?? + var room = + matrix.client.getRoomByAlias(roomIdOrAlias) ?? matrix.client.getRoomById(roomIdOrAlias); var roomId = room?.id; // we make the servers a set and later on convert to a list, so that we can easily @@ -151,12 +154,12 @@ class UrlLauncher { context: context, future: () => matrix.client.getRoomIdByAlias(roomIdOrAlias), ); - if (response.error != null) { - return; // nothing to do, the alias doesn't exist + final result = response.result; + if (result != null) { + roomId = result.roomId; + servers.addAll(result.servers!); + room = matrix.client.getRoomById(roomId!); } - roomId = response.result!.roomId; - servers.addAll(response.result!.servers!); - room = matrix.client.getRoomById(roomId!); } servers.addAll(identityParts.via); if (room != null) { @@ -169,22 +172,17 @@ class UrlLauncher { // we have the room, so....just open it if (event != null) { context.go( - '/${Uri( - pathSegments: ['rooms', room.id], - queryParameters: {'event': event}, - )}', + '/${Uri(pathSegments: ['rooms', room.id], queryParameters: {'event': event})}', ); } else { context.go('/rooms/${room.id}'); } return; } else { - await showAdaptiveBottomSheet( + await showAdaptiveDialog( context: context, - builder: (c) => PublicRoomBottomSheet( - roomAlias: identityParts.primaryIdentifier, - outerContext: context, - ), + builder: (c) => + PublicRoomDialog(roomAlias: identityParts.primaryIdentifier), ); } if (roomIdOrAlias.sigil == '!') { @@ -221,12 +219,20 @@ class UrlLauncher { } } } else if (identityParts.primaryIdentifier.sigil == '@') { - await showAdaptiveBottomSheet( + final userId = identityParts.primaryIdentifier; + var noProfileWarning = false; + final profileResult = await showFutureLoadingDialog( context: context, - builder: (c) => LoadProfileBottomSheet( - userId: identityParts.primaryIdentifier, - outerContext: context, - ), + future: () => + matrix.client.getProfileFromUserId(userId).catchError((_) { + noProfileWarning = true; + return Profile(userId: userId); + }), + ); + await UserDialog.show( + context: context, + profile: profileResult.result!, + noProfileWarning: noProfileWarning, ); } } diff --git a/lib/utils/voip/callkeep_manager.dart b/lib/utils/voip/callkeep_manager.dart deleted file mode 100644 index a3db3eba1..000000000 --- a/lib/utils/voip/callkeep_manager.dart +++ /dev/null @@ -1,325 +0,0 @@ -import 'dart:async'; - -import 'package:flutter/material.dart'; - -import 'package:callkeep/callkeep.dart'; -import 'package:flutter_foreground_task/flutter_foreground_task.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:matrix/matrix.dart'; -import 'package:permission_handler/permission_handler.dart'; - -class CallKeeper { - CallKeeper(this.callKeepManager, this.call) { - call.onCallStateChanged.stream.listen(_handleCallState); - } - - CallKeepManager callKeepManager; - bool? held = false; - bool? muted = false; - bool connected = false; - CallSession call; - - // update native caller to show what remote user has done. - void _handleCallState(CallState state) { - Logs().i('CallKeepManager::handleCallState: ${state.toString()}'); - switch (state) { - case CallState.kConnecting: - Logs().v('callkeep connecting'); - break; - case CallState.kConnected: - Logs().v('callkeep connected'); - if (!connected) { - callKeepManager.answer(call.callId); - } else { - callKeepManager.setMutedCall(call.callId, false); - callKeepManager.setOnHold(call.callId, false); - } - break; - case CallState.kEnded: - callKeepManager.hangup(call.callId); - break; - - case CallState.kFledgling: - case CallState.kInviteSent: - case CallState.kWaitLocalMedia: - case CallState.kCreateOffer: - case CallState.kCreateAnswer: - case CallState.kRinging: - case CallState.kEnding: - break; - } - } -} - -Map calls = {}; - -class CallKeepManager { - factory CallKeepManager() { - return _instance; - } - - CallKeepManager._internal() { - _callKeep = FlutterCallkeep(); - } - - static final CallKeepManager _instance = CallKeepManager._internal(); - - late FlutterCallkeep _callKeep; - - String get appName => 'FluffyChat'; - - Future get hasPhoneAccountEnabled async => - await _callKeep.hasPhoneAccount(); - - Map get alertOptions => { - 'alertTitle': 'Permissions required', - 'alertDescription': - 'Allow $appName to register as a calling account? This will allow calls to be handled by the native android dialer.', - 'cancelButton': 'Cancel', - 'okButton': 'ok', - // Required to get audio in background when using Android 11 - 'foregroundService': { - 'channelId': 'com.fluffy.fluffychat', - 'channelName': 'Foreground service for my app', - 'notificationTitle': '$appName is running on background', - 'notificationIcon': 'mipmap/ic_notification_launcher', - }, - 'additionalPermissions': [''], - }; - bool setupDone = false; - - Future showCallkitIncoming(CallSession call) async { - if (!setupDone) { - await _callKeep.setup( - null, - { - 'ios': { - 'appName': appName, - }, - 'android': alertOptions, - }, - backgroundMode: true, - ); - } - setupDone = true; - await displayIncomingCall(call); - call.onCallStateChanged.stream.listen((state) { - if (state == CallState.kEnded) { - _callKeep.endAllCalls(); - } - }); - call.onCallEventChanged.stream.listen( - (event) { - if (event == CallStateChange.kLocalHoldUnhold) { - Logs().i( - 'Call hold event: local ${call.localHold}, remote ${call.remoteOnHold}', - ); - } - }, - ); - } - - void removeCall(String? callUUID) { - calls.remove(callUUID); - } - - void addCall(String? callUUID, CallKeeper callKeeper) { - if (calls.containsKey(callUUID)) return; - calls[callUUID] = callKeeper; - } - - void setCallHeld(String? callUUID, bool? held) { - calls[callUUID]!.held = held; - } - - void setCallMuted(String? callUUID, bool? muted) { - calls[callUUID]!.muted = muted; - } - - void didDisplayIncomingCall(CallKeepDidDisplayIncomingCall event) { - final callUUID = event.callUUID; - final number = event.handle; - Logs().v('[displayIncomingCall] $callUUID number: $number'); - // addCall(callUUID, CallKeeper(this null)); - } - - void onPushKitToken(CallKeepPushKitToken event) { - Logs().v('[onPushKitToken] token => ${event.token}'); - } - - Future initialize() async { - _callKeep.on(CallKeepPerformAnswerCallAction(), answerCall); - _callKeep.on(CallKeepDidPerformDTMFAction(), didPerformDTMFAction); - - _callKeep.on(CallKeepDidToggleHoldAction(), didToggleHoldCallAction); - _callKeep.on( - CallKeepDidPerformSetMutedCallAction(), - didPerformSetMutedCallAction, - ); - _callKeep.on(CallKeepPerformEndCallAction(), endCall); - _callKeep.on(CallKeepPushKitToken(), onPushKitToken); - _callKeep.on(CallKeepDidDisplayIncomingCall(), didDisplayIncomingCall); - Logs().i('[VOIP] Initialized'); - } - - Future hangup(String callUUID) async { - await _callKeep.endCall(callUUID); - removeCall(callUUID); - } - - Future reject(String callUUID) async { - await _callKeep.rejectCall(callUUID); - } - - Future answer(String? callUUID) async { - final keeper = calls[callUUID]!; - if (!keeper.connected) { - await _callKeep.answerIncomingCall(callUUID!); - keeper.connected = true; - } - } - - Future setOnHold(String callUUID, bool held) async { - await _callKeep.setOnHold(callUUID, held); - setCallHeld(callUUID, held); - } - - Future setMutedCall(String callUUID, bool muted) async { - await _callKeep.setMutedCall(callUUID, muted); - setCallMuted(callUUID, muted); - } - - Future updateDisplay(String callUUID) async { - // Workaround because Android doesn't display well displayName, se we have to switch ... - if (isIOS) { - await _callKeep.updateDisplay( - callUUID, - displayName: 'New Name', - handle: callUUID, - ); - } else { - await _callKeep.updateDisplay( - callUUID, - displayName: callUUID, - handle: 'New Name', - ); - } - } - - Future displayIncomingCall(CallSession call) async { - final callKeeper = CallKeeper(this, call); - addCall(call.callId, callKeeper); - await _callKeep.displayIncomingCall( - call.callId, - '${call.room.getLocalizedDisplayname()} (FluffyChat)', - localizedCallerName: - '${call.room.getLocalizedDisplayname()} (FluffyChat)', - handleType: 'number', - hasVideo: call.type == CallType.kVideo, - ); - return callKeeper; - } - - Future checkoutPhoneAccountSetting(BuildContext context) async { - showDialog( - context: context, - barrierDismissible: true, - useRootNavigator: false, - builder: (_) => AlertDialog( - title: Text(L10n.of(context)!.callingPermissions), - content: Column( - mainAxisSize: MainAxisSize.min, - children: [ - ListTile( - onTap: () => openCallingAccountsPage(context), - title: Text(L10n.of(context)!.callingAccount), - subtitle: Text(L10n.of(context)!.callingAccountDetails), - trailing: const Icon(Icons.phone), - ), - const Divider(), - ListTile( - onTap: () => FlutterForegroundTask.openSystemAlertWindowSettings( - forceOpen: true, - ), - title: Text(L10n.of(context)!.appearOnTop), - subtitle: Text(L10n.of(context)!.appearOnTopDetails), - trailing: const Icon(Icons.file_upload_rounded), - ), - const Divider(), - ListTile( - onTap: () => openAppSettings(), - title: Text(L10n.of(context)!.otherCallingPermissions), - trailing: const Icon(Icons.mic), - ), - ], - ), - ), - ); - } - - void openCallingAccountsPage(BuildContext context) async { - await _callKeep.setup(context, { - 'ios': { - 'appName': appName, - }, - 'android': alertOptions, - }); - final hasPhoneAccount = await _callKeep.hasPhoneAccount(); - Logs().e(hasPhoneAccount.toString()); - if (!hasPhoneAccount) { - await _callKeep.hasDefaultPhoneAccount(context, alertOptions); - } else { - await _callKeep.openPhoneAccounts(); - } - } - - /// CallActions. - Future answerCall(CallKeepPerformAnswerCallAction event) async { - final callUUID = event.callUUID; - final keeper = calls[event.callUUID]!; - if (!keeper.connected) { - Logs().e('answered'); - // Answer Call - keeper.call.answer(); - keeper.connected = true; - } - Timer(const Duration(seconds: 1), () { - _callKeep.setCurrentCallActive(callUUID!); - }); - } - - Future endCall(CallKeepPerformEndCallAction event) async { - final keeper = calls[event.callUUID]; - keeper?.call.hangup(reason: CallErrorCode.userHangup); - removeCall(event.callUUID); - } - - Future didPerformDTMFAction(CallKeepDidPerformDTMFAction event) async { - final keeper = calls[event.callUUID]!; - keeper.call.sendDTMF(event.digits!); - } - - Future didPerformSetMutedCallAction( - CallKeepDidPerformSetMutedCallAction event, - ) async { - final keeper = calls[event.callUUID]; - if (event.muted!) { - keeper!.call.setMicrophoneMuted(true); - } else { - keeper!.call.setMicrophoneMuted(false); - } - setCallMuted(event.callUUID, event.muted); - } - - Future didToggleHoldCallAction( - CallKeepDidToggleHoldAction event, - ) async { - final keeper = calls[event.callUUID]; - if (event.hold!) { - keeper!.call.setRemoteOnHold(true); - } else { - keeper!.call.setRemoteOnHold(false); - } - setCallHeld(event.callUUID, event.hold); - } -} diff --git a/lib/utils/voip/user_media_manager.dart b/lib/utils/voip/user_media_manager.dart index 03ecd6030..e1677f894 100644 --- a/lib/utils/voip/user_media_manager.dart +++ b/lib/utils/voip/user_media_manager.dart @@ -1,10 +1,5 @@ -import 'package:flutter/foundation.dart'; - -import 'package:flutter_ringtone_player/flutter_ringtone_player.dart'; import 'package:just_audio/just_audio.dart'; -import 'package:fluffychat/utils/platform_infos.dart'; - class UserMediaManager { factory UserMediaManager() { return _instance; @@ -16,25 +11,16 @@ class UserMediaManager { AudioPlayer? _assetsAudioPlayer; - final FlutterRingtonePlayer _flutterRingtonePlayer = FlutterRingtonePlayer(); - Future startRingingTone() async { - if (PlatformInfos.isMobile) { - await _flutterRingtonePlayer.playRingtone(volume: 80); - } else if ((kIsWeb || PlatformInfos.isMacOS) && - _assetsAudioPlayer != null) { - const path = 'assets/sounds/phone.ogg'; - final player = _assetsAudioPlayer = AudioPlayer(); - player.setAsset(path); - player.play(); - } + const path = 'assets/sounds/phone.ogg'; + final player = _assetsAudioPlayer = AudioPlayer(); + player.setAsset(path); + player.play(); + return; } Future stopRingingTone() async { - if (PlatformInfos.isMobile) { - await _flutterRingtonePlayer.stop(); - } await _assetsAudioPlayer?.stop(); _assetsAudioPlayer = null; return; diff --git a/lib/utils/voip/video_renderer.dart b/lib/utils/voip/video_renderer.dart index 46171fdb5..935b3984c 100644 --- a/lib/utils/voip/video_renderer.dart +++ b/lib/utils/voip/video_renderer.dart @@ -45,8 +45,9 @@ class _VideoRendererState extends State { @override void initState() { - _streamChangeSubscription = - widget.stream?.onStreamChanged.stream.listen((stream) { + _streamChangeSubscription = widget.stream?.onStreamChanged.stream.listen(( + stream, + ) { setState(() { _renderer?.srcObject = stream; }); @@ -79,7 +80,7 @@ class _VideoRendererState extends State { filterQuality: FilterQuality.medium, objectFit: widget.fit, placeholderBuilder: (_) => - Container(color: Colors.white.withOpacity(0.18)), + Container(color: Colors.white.withAlpha(45)), ); }, ); diff --git a/lib/utils/voip_plugin.dart b/lib/utils/voip_plugin.dart index 8a71390ef..fb5c57146 100644 --- a/lib/utils/voip_plugin.dart +++ b/lib/utils/voip_plugin.dart @@ -11,7 +11,6 @@ import 'package:webrtc_interface/webrtc_interface.dart' hide Navigator; import 'package:fluffychat/pages/chat_list/chat_list.dart'; import 'package:fluffychat/pages/dialer/dialer.dart'; import 'package:fluffychat/utils/platform_infos.dart'; -import '../../utils/voip/callkeep_manager.dart'; import '../../utils/voip/user_media_manager.dart'; import '../widgets/matrix.dart'; @@ -34,14 +33,15 @@ class VoipPlugin with WidgetsBindingObserver implements WebRTCDelegate { @override void didChangeAppLifecycleState(AppLifecycleState? state) { - background = (state == AppLifecycleState.detached || + background = + (state == AppLifecycleState.detached || state == AppLifecycleState.paused); - Logs().w('Set background mode in VOIP plugin', background); } void addCallingOverlay(String callId, CallSession call) { - final context = - kIsWeb ? ChatList.contextForVoip! : this.context; // web is weird + final context = kIsWeb + ? ChatList.contextForVoip! + : this.context; // web is weird if (overlayEntry != null) { Logs().e('[VOIP] addCallingOverlay: The call session already exists?'); @@ -87,11 +87,9 @@ class VoipPlugin with WidgetsBindingObserver implements WebRTCDelegate { Future createPeerConnection( Map configuration, [ Map constraints = const {}, - ]) => - webrtc_impl.createPeerConnection(configuration, constraints); + ]) => webrtc_impl.createPeerConnection(configuration, constraints); - Future get hasCallingAccount async => - kIsWeb ? false : await CallKeepManager().hasPhoneAccountEnabled; + Future get hasCallingAccount async => false; @override Future playRingtone() async { @@ -114,46 +112,21 @@ class VoipPlugin with WidgetsBindingObserver implements WebRTCDelegate { @override Future handleNewCall(CallSession call) async { if (PlatformInfos.isAndroid) { - // probably works on ios too - final hasCallingAccount = await CallKeepManager().hasPhoneAccountEnabled; - if (call.direction == CallDirection.kIncoming && - hasCallingAccount && - call.type == CallType.kVoice) { - ///Popup native telecom manager call UI for incoming call. - final callKeeper = CallKeeper(CallKeepManager(), call); - CallKeepManager().addCall(call.callId, callKeeper); - await CallKeepManager().showCallkitIncoming(call); - return; - } else { - try { - final wasForeground = await FlutterForegroundTask.isAppOnForeground; + try { + final wasForeground = await FlutterForegroundTask.isAppOnForeground; - await matrix.store.setString( - 'wasForeground', - wasForeground == true ? 'true' : 'false', - ); - FlutterForegroundTask.setOnLockScreenVisibility(true); - FlutterForegroundTask.wakeUpScreen(); - FlutterForegroundTask.launchApp(); - } catch (e) { - Logs().e('VOIP foreground failed $e'); - } - // use fallback flutter call pages for outgoing and video calls. - addCallingOverlay(call.callId, call); - try { - if (!hasCallingAccount) { - ScaffoldMessenger.of(context).showSnackBar( - const SnackBar( - content: Text( - 'No calling accounts found (used for native calls UI)', - ), - ), - ); - } - } catch (e) { - Logs().e('failed to show snackbar'); - } + await matrix.store.setString( + 'wasForeground', + wasForeground == true ? 'true' : 'false', + ); + FlutterForegroundTask.setOnLockScreenVisibility(true); + FlutterForegroundTask.wakeUpScreen(); + FlutterForegroundTask.launchApp(); + } catch (e) { + Logs().e('VOIP foreground failed $e'); } + // use fallback flutter call pages for outgoing and video calls. + addCallingOverlay(call.callId, call); } else { addCallingOverlay(call.callId, call); } @@ -168,7 +141,7 @@ class VoipPlugin with WidgetsBindingObserver implements WebRTCDelegate { FlutterForegroundTask.setOnLockScreenVisibility(false); FlutterForegroundTask.stopService(); final wasForeground = matrix.store.getString('wasForeground'); - wasForeground == 'false' ? FlutterForegroundTask.minimizeApp() : null; + if (wasForeground == 'false') FlutterForegroundTask.minimizeApp(); } } } @@ -196,4 +169,10 @@ class VoipPlugin with WidgetsBindingObserver implements WebRTCDelegate { @override // TODO: implement keyProvider EncryptionKeyProvider? get keyProvider => throw UnimplementedError(); + + @override + Future registerListeners(CallSession session) { + // TODO: implement registerListeners + throw UnimplementedError(); + } } diff --git a/lib/widgets/adaptive_dialogs/adaptive_dialog_action.dart b/lib/widgets/adaptive_dialogs/adaptive_dialog_action.dart new file mode 100644 index 000000000..5848cf545 --- /dev/null +++ b/lib/widgets/adaptive_dialogs/adaptive_dialog_action.dart @@ -0,0 +1,158 @@ +import 'package:flutter/cupertino.dart'; +import 'package:flutter/material.dart'; + +import 'package:fluffychat/config/app_config.dart'; + +class AdaptiveDialogAction extends StatelessWidget { + final VoidCallback? onPressed; + final bool autofocus; + final Widget child; + final bool bigButtons; + final BorderRadius? borderRadius; + + static const BorderRadius topRadius = BorderRadius.only( + topLeft: Radius.circular(AppConfig.borderRadius), + topRight: Radius.circular(AppConfig.borderRadius), + bottomLeft: Radius.circular(2), + bottomRight: Radius.circular(2), + ); + static const BorderRadius centerRadius = BorderRadius.all(Radius.circular(2)); + static const BorderRadius bottomRadius = BorderRadius.only( + bottomLeft: Radius.circular(AppConfig.borderRadius), + bottomRight: Radius.circular(AppConfig.borderRadius), + topLeft: Radius.circular(2), + topRight: Radius.circular(2), + ); + + const AdaptiveDialogAction({ + super.key, + required this.onPressed, + required this.child, + this.autofocus = false, + this.bigButtons = false, + this.borderRadius, + }); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + switch (theme.platform) { + case TargetPlatform.android: + case TargetPlatform.fuchsia: + case TargetPlatform.linux: + case TargetPlatform.windows: + if (bigButtons) { + return Padding( + padding: const EdgeInsets.symmetric(vertical: 2.0), + child: SizedBox( + width: double.infinity, + child: ElevatedButton( + style: ElevatedButton.styleFrom( + shape: RoundedRectangleBorder( + borderRadius: + borderRadius ?? + BorderRadius.circular(AppConfig.borderRadius), + ), + backgroundColor: autofocus + ? theme.colorScheme.primary + : theme.colorScheme.surfaceBright, + foregroundColor: autofocus + ? theme.colorScheme.onPrimary + : theme.colorScheme.primary, + ), + onPressed: onPressed, + autofocus: autofocus, + child: child, + ), + ), + ); + } + return TextButton( + onPressed: onPressed, + autofocus: autofocus, + child: child, + ); + case TargetPlatform.iOS: + case TargetPlatform.macOS: + return CupertinoDialogAction( + onPressed: onPressed, + isDefaultAction: autofocus, + child: child, + ); + } + } +} + +class AdaptiveDialogInkWell extends StatelessWidget { + final Widget child; + final VoidCallback onTap; + final EdgeInsets padding; + + const AdaptiveDialogInkWell({ + super.key, + required this.onTap, + required this.child, + this.padding = const EdgeInsets.all(16), + }); + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + if ({TargetPlatform.iOS, TargetPlatform.macOS}.contains(theme.platform)) { + return CupertinoButton( + onPressed: onTap, + borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), + color: theme.colorScheme.surfaceBright, + padding: padding, + child: child, + ); + } + return Material( + color: theme.colorScheme.surfaceBright, + borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), + child: InkWell( + borderRadius: BorderRadius.circular(AppConfig.borderRadius / 2), + onTap: onTap, + child: Padding( + padding: padding, + child: Center(child: child), + ), + ), + ); + } +} + +class AdaptiveIconTextButton extends StatelessWidget { + final String label; + final IconData icon; + final VoidCallback onTap; + const AdaptiveIconTextButton({ + super.key, + required this.label, + required this.icon, + required this.onTap, + }); + + @override + Widget build(BuildContext context) { + final color = Theme.of(context).colorScheme.secondary; + return Expanded( + child: AdaptiveDialogInkWell( + padding: EdgeInsets.all(8.0), + onTap: onTap, + child: Column( + mainAxisSize: .min, + children: [ + Icon(icon, color: color), + Text( + label, + style: TextStyle(fontSize: 12, color: color), + maxLines: 1, + overflow: .ellipsis, + ), + ], + ), + ), + ); + } +} diff --git a/lib/widgets/adaptive_dialogs/dialog_text_field.dart b/lib/widgets/adaptive_dialogs/dialog_text_field.dart new file mode 100644 index 000000000..4870882da --- /dev/null +++ b/lib/widgets/adaptive_dialogs/dialog_text_field.dart @@ -0,0 +1,96 @@ +import 'package:flutter/cupertino.dart'; +import 'package:flutter/material.dart'; + +class DialogTextField extends StatelessWidget { + final TextEditingController? controller; + final String? hintText; + final String? labelText; + final String? initialText; + final String? counterText; + final String? prefixText; + final String? suffixText; + final String? errorText; + final bool obscureText; + final bool isDestructive = false; + final int? minLines; + final int? maxLines; + final TextInputType? keyboardType; + final int? maxLength; + final bool autocorrect = true; + + const DialogTextField({ + super.key, + this.hintText, + this.labelText, + this.initialText, + this.prefixText, + this.suffixText, + this.minLines, + this.maxLines, + this.keyboardType, + this.maxLength, + this.controller, + this.counterText, + this.errorText, + this.obscureText = false, + }); + + @override + Widget build(BuildContext context) { + final prefixText = this.prefixText; + final suffixText = this.suffixText; + final errorText = this.errorText; + final theme = Theme.of(context); + switch (theme.platform) { + case TargetPlatform.android: + case TargetPlatform.fuchsia: + case TargetPlatform.linux: + case TargetPlatform.windows: + return TextField( + controller: controller, + obscureText: obscureText, + minLines: minLines, + maxLines: maxLines, + maxLength: maxLength, + keyboardType: keyboardType, + autocorrect: autocorrect, + decoration: InputDecoration( + errorText: errorText, + hintText: hintText, + labelText: labelText, + prefixText: prefixText, + suffixText: suffixText, + counterText: counterText, + ), + ); + case TargetPlatform.iOS: + case TargetPlatform.macOS: + final placeholder = labelText ?? hintText; + return Column( + children: [ + SizedBox( + height: placeholder == null ? null : ((maxLines ?? 1) + 1) * 20, + child: CupertinoTextField( + controller: controller, + obscureText: obscureText, + minLines: minLines, + maxLines: maxLines, + maxLength: maxLength, + keyboardType: keyboardType, + autocorrect: autocorrect, + prefix: prefixText != null ? Text(prefixText) : null, + suffix: suffixText != null ? Text(suffixText) : null, + placeholder: placeholder, + ), + ), + if (errorText != null) + Text( + errorText, + style: TextStyle(fontSize: 11, color: theme.colorScheme.error), + textAlign: TextAlign.left, + ), + ], + ); + } + } +} diff --git a/lib/widgets/adaptive_dialogs/public_room_dialog.dart b/lib/widgets/adaptive_dialogs/public_room_dialog.dart new file mode 100644 index 000000000..975507564 --- /dev/null +++ b/lib/widgets/adaptive_dialogs/public_room_dialog.dart @@ -0,0 +1,299 @@ +import 'package:flutter/material.dart'; +import 'package:flutter/services.dart'; + +import 'package:flutter_linkify/flutter_linkify.dart'; +import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/fluffy_share.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import '../../config/themes.dart'; +import '../../utils/url_launcher.dart'; +import '../avatar.dart'; +import '../future_loading_dialog.dart'; +import '../hover_builder.dart'; +import '../matrix.dart'; +import '../mxc_image_viewer.dart'; +import 'adaptive_dialog_action.dart'; + +class PublicRoomDialog extends StatelessWidget { + final String? roomAlias; + final PublishedRoomsChunk? chunk; + final List? via; + + const PublicRoomDialog({super.key, this.roomAlias, this.chunk, this.via}); + + Future _joinRoom(BuildContext context) async { + final client = Matrix.of(context).client; + final chunk = this.chunk; + final knock = chunk?.joinRule == 'knock'; + final result = await showFutureLoadingDialog( + context: context, + future: () async { + if (chunk != null && + client.getRoomById(chunk.roomId) != null && + client.getRoomById(chunk.roomId)?.membership != Membership.leave) { + return chunk.roomId; + } + final roomId = chunk != null && knock + ? await client.knockRoom(chunk.roomId, via: via) + : await client.joinRoom(roomAlias ?? chunk!.roomId, via: via); + + if (!knock && client.getRoomById(roomId) == null) { + await client.waitForRoomInSync(roomId); + } + return roomId; + }, + ); + final roomId = result.result; + if (roomId == null) return; + if (knock && client.getRoomById(roomId) == null) { + Navigator.of(context).pop(true); + await showOkAlertDialog( + context: context, + title: L10n.of(context).youHaveKnocked, + message: L10n.of(context).pleaseWaitUntilInvited, + ); + return; + } + if (result.error != null) return; + if (!context.mounted) return; + Navigator.of(context).pop(true); + // don't open the room if the joined room is a space + if (chunk?.roomType != 'm.space' && + !client.getRoomById(result.result!)!.isSpace) { + context.go('/rooms/$roomId'); + } else { + context.go('/rooms?spaceId=$roomId'); + } + return; + } + + bool _testRoom(PublishedRoomsChunk r) => r.canonicalAlias == roomAlias; + + Future _search(BuildContext context) async { + final chunk = this.chunk; + if (chunk != null) return chunk; + final query = await Matrix.of(context).client.queryPublicRooms( + server: roomAlias!.domain, + filter: PublicRoomQueryFilter(genericSearchTerm: roomAlias), + ); + if (!query.chunk.any(_testRoom)) { + throw (L10n.of(context).noRoomsFound); + } + return query.chunk.firstWhere(_testRoom); + } + + @override + Widget build(BuildContext context) { + final roomAlias = this.roomAlias ?? chunk?.canonicalAlias; + final roomLink = roomAlias ?? chunk?.roomId; + var copied = false; + return AlertDialog.adaptive( + content: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: FutureBuilder( + future: _search(context), + builder: (context, snapshot) { + final theme = Theme.of(context); + + final profile = snapshot.data; + final avatar = profile?.avatarUrl; + final topic = profile?.topic; + return SingleChildScrollView( + child: Column( + spacing: 16, + mainAxisSize: .min, + crossAxisAlignment: .stretch, + children: [ + Row( + spacing: 12, + children: [ + Avatar( + mxContent: avatar, + name: profile?.name ?? roomLink, + size: Avatar.defaultSize * 1.5, + onTap: avatar != null + ? () => showDialog( + context: context, + builder: (_) => MxcImageViewer(avatar), + ) + : null, + ), + Expanded( + child: Column( + crossAxisAlignment: .start, + children: [ + Text( + profile?.name ?? + roomLink ?? + profile?.roomId ?? + ' - ', + maxLines: 1, + overflow: .ellipsis, + style: TextStyle(fontSize: 16), + ), + const SizedBox(height: 8), + if (roomLink != null) + HoverBuilder( + builder: (context, hovered) => StatefulBuilder( + builder: (context, setState) => MouseRegion( + cursor: SystemMouseCursors.click, + child: GestureDetector( + onTap: () { + Clipboard.setData( + ClipboardData(text: roomLink), + ); + setState(() { + copied = true; + }); + }, + child: RichText( + text: TextSpan( + children: [ + WidgetSpan( + child: Padding( + padding: const EdgeInsets.only( + right: 4.0, + ), + child: AnimatedScale( + duration: FluffyThemes + .animationDuration, + curve: FluffyThemes + .animationCurve, + scale: hovered + ? 1.33 + : copied + ? 1.25 + : 1.0, + child: Icon( + copied + ? Icons.check_circle + : Icons.copy, + size: 12, + color: copied + ? Colors.green + : null, + ), + ), + ), + ), + TextSpan(text: roomLink), + ], + style: theme.textTheme.bodyMedium + ?.copyWith(fontSize: 10), + ), + textAlign: TextAlign.center, + ), + ), + ), + ), + ), + + if (profile?.numJoinedMembers != null) + Text( + L10n.of(context).countParticipants( + profile?.numJoinedMembers ?? 0, + ), + style: const TextStyle(fontSize: 10), + textAlign: TextAlign.center, + ), + ], + ), + ), + ], + ), + if (topic != null && topic.isNotEmpty) + ConstrainedBox( + constraints: BoxConstraints(maxHeight: 200), + child: Scrollbar( + thumbVisibility: true, + trackVisibility: true, + child: SingleChildScrollView( + child: SelectableLinkify( + text: topic, + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + textAlign: .start, + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: theme.colorScheme.primary, + decoration: TextDecoration.underline, + decorationColor: theme.colorScheme.primary, + ), + onOpen: (url) => + UrlLauncher(context, url.url).launchUrl(), + ), + ), + ), + ), + + Row( + mainAxisAlignment: .spaceBetween, + spacing: 4, + children: [ + AdaptiveIconTextButton( + label: L10n.of(context).report, + icon: Icons.gavel_outlined, + onTap: () async { + Navigator.of(context).pop(); + final reason = await showTextInputDialog( + context: context, + title: L10n.of(context).whyDoYouWantToReportThis, + okLabel: L10n.of(context).report, + cancelLabel: L10n.of(context).cancel, + hintText: L10n.of(context).reason, + ); + if (reason == null || reason.isEmpty) return; + await showFutureLoadingDialog( + context: context, + future: () => Matrix.of(context).client.reportRoom( + chunk?.roomId ?? roomAlias!, + reason, + ), + ); + }, + ), + AdaptiveIconTextButton( + label: L10n.of(context).copy, + icon: Icons.copy_outlined, + onTap: () => + Clipboard.setData(ClipboardData(text: roomLink!)), + ), + AdaptiveIconTextButton( + label: L10n.of(context).share, + icon: Icons.adaptive.share, + onTap: () => FluffyShare.share( + 'https://matrix.to/#/$roomLink', + context, + ), + ), + ], + ), + AdaptiveDialogInkWell( + onTap: () => _joinRoom(context), + child: Text( + chunk?.joinRule == 'knock' && + Matrix.of( + context, + ).client.getRoomById(chunk!.roomId) == + null + ? L10n.of(context).knock + : chunk?.roomType == 'm.space' + ? L10n.of(context).joinSpace + : L10n.of(context).joinRoom, + style: TextStyle(color: theme.colorScheme.secondary), + ), + ), + ], + ), + ); + }, + ), + ), + ); + } +} diff --git a/lib/widgets/adaptive_dialogs/show_modal_action_popup.dart b/lib/widgets/adaptive_dialogs/show_modal_action_popup.dart new file mode 100644 index 000000000..f99e69353 --- /dev/null +++ b/lib/widgets/adaptive_dialogs/show_modal_action_popup.dart @@ -0,0 +1,114 @@ +import 'package:flutter/cupertino.dart'; +import 'package:flutter/material.dart'; + +Future showModalActionPopup({ + required BuildContext context, + required List> actions, + String? title, + String? message, + String? cancelLabel, + bool useRootNavigator = true, +}) { + final theme = Theme.of(context); + + switch (theme.platform) { + case TargetPlatform.android: + case TargetPlatform.fuchsia: + case TargetPlatform.windows: + case TargetPlatform.linux: + return showModalBottomSheet( + isScrollControlled: true, + useRootNavigator: useRootNavigator, + context: context, + clipBehavior: Clip.hardEdge, + constraints: BoxConstraints( + maxWidth: 512, + maxHeight: MediaQuery.sizeOf(context).height - 32, + ), + builder: (context) => ListView( + shrinkWrap: true, + children: [ + if (title != null || message != null) ...[ + ListTile( + title: title == null + ? null + : Text(title, style: theme.textTheme.labelSmall), + subtitle: message == null ? null : Text(message), + ), + const Divider(height: 1), + ], + ...actions.map( + (action) => ListTile( + leading: action.icon, + title: Text( + action.label, + maxLines: 1, + style: action.isDestructive + ? TextStyle( + color: theme.colorScheme.error, + fontWeight: action.isDefaultAction + ? FontWeight.bold + : null, + ) + : null, + ), + onTap: () => Navigator.of(context).pop(action.value), + ), + ), + if (cancelLabel != null) ...[ + const Divider(height: 1), + ListTile( + title: Text(cancelLabel), + onTap: () => Navigator.of(context).pop(null), + ), + ], + ], + ), + ); + case TargetPlatform.iOS: + case TargetPlatform.macOS: + return showCupertinoModalPopup( + context: context, + useRootNavigator: useRootNavigator, + builder: (context) => ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 512), + child: CupertinoActionSheet( + title: title == null ? null : Text(title), + message: message == null ? null : Text(message), + cancelButton: cancelLabel == null + ? null + : CupertinoActionSheetAction( + onPressed: () => Navigator.of(context).pop(null), + child: Text(cancelLabel), + ), + actions: actions + .map( + (action) => CupertinoActionSheetAction( + isDestructiveAction: action.isDestructive, + isDefaultAction: action.isDefaultAction, + onPressed: () => Navigator.of(context).pop(action.value), + child: Text(action.label, maxLines: 1), + ), + ) + .toList(), + ), + ), + ); + } +} + +class AdaptiveModalAction { + final String label; + final T value; + Icon? icon; + final bool isDefaultAction; + final bool isDestructive; + + AdaptiveModalAction({ + required this.label, + required this.value, + this.icon, + this.isDefaultAction = false, + this.isDestructive = false, + }); +} diff --git a/lib/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart b/lib/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart new file mode 100644 index 000000000..3b6c72684 --- /dev/null +++ b/lib/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart @@ -0,0 +1,101 @@ +import 'package:flutter/material.dart'; + +import 'package:flutter_linkify/flutter_linkify.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; + +enum OkCancelResult { ok, cancel } + +Future showOkCancelAlertDialog({ + required BuildContext context, + required String title, + String? message, + String? okLabel, + String? cancelLabel, + bool isDestructive = false, + bool useRootNavigator = true, +}) => showAdaptiveDialog( + context: context, + useRootNavigator: useRootNavigator, + builder: (context) => AlertDialog.adaptive( + title: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: Text(title), + ), + content: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: message == null + ? null + : SelectableLinkify( + text: message, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + linkStyle: TextStyle( + color: Theme.of(context).colorScheme.primary, + decorationColor: Theme.of(context).colorScheme.primary, + ), + options: const LinkifyOptions(humanize: false), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), + ), + ), + actions: [ + AdaptiveDialogAction( + onPressed: () => + Navigator.of(context).pop(OkCancelResult.cancel), + child: Text(cancelLabel ?? L10n.of(context).cancel), + ), + AdaptiveDialogAction( + onPressed: () => + Navigator.of(context).pop(OkCancelResult.ok), + autofocus: true, + child: Text( + okLabel ?? L10n.of(context).ok, + style: isDestructive + ? TextStyle(color: Theme.of(context).colorScheme.error) + : null, + ), + ), + ], + ), +); + +Future showOkAlertDialog({ + required BuildContext context, + required String title, + String? message, + String? okLabel, + bool useRootNavigator = true, +}) => showAdaptiveDialog( + context: context, + useRootNavigator: useRootNavigator, + builder: (context) => AlertDialog.adaptive( + title: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: Text(title), + ), + content: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: message == null + ? null + : SelectableLinkify( + text: message, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + linkStyle: TextStyle( + color: Theme.of(context).colorScheme.primary, + decorationColor: Theme.of(context).colorScheme.primary, + ), + options: const LinkifyOptions(humanize: false), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), + ), + ), + actions: [ + AdaptiveDialogAction( + onPressed: () => + Navigator.of(context).pop(OkCancelResult.ok), + autofocus: true, + child: Text(okLabel ?? L10n.of(context).close), + ), + ], + ), +); diff --git a/lib/widgets/adaptive_dialogs/show_text_input_dialog.dart b/lib/widgets/adaptive_dialogs/show_text_input_dialog.dart new file mode 100644 index 000000000..38331eafc --- /dev/null +++ b/lib/widgets/adaptive_dialogs/show_text_input_dialog.dart @@ -0,0 +1,108 @@ +import 'package:flutter/material.dart'; + +import 'package:flutter_linkify/flutter_linkify.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/url_launcher.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/dialog_text_field.dart'; + +Future showTextInputDialog({ + required BuildContext context, + required String title, + String? message, + String? okLabel, + String? cancelLabel, + bool useRootNavigator = true, + String? hintText, + String? labelText, + String? initialText, + String? prefixText, + String? suffixText, + bool obscureText = false, + bool isDestructive = false, + int? minLines, + int? maxLines, + String? Function(String input)? validator, + TextInputType? keyboardType, + int? maxLength, + bool autocorrect = true, +}) { + final controller = TextEditingController(text: initialText); + return showAdaptiveDialog( + context: context, + useRootNavigator: useRootNavigator, + builder: (context) { + final error = ValueNotifier(null); + return AlertDialog.adaptive( + title: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: Text(title), + ), + content: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: Column( + mainAxisSize: .min, + children: [ + if (message != null) + SelectableLinkify( + text: message, + textScaleFactor: MediaQuery.textScalerOf(context).scale(1), + linkStyle: TextStyle( + color: Theme.of(context).colorScheme.primary, + decorationColor: Theme.of(context).colorScheme.primary, + ), + options: const LinkifyOptions(humanize: false), + onOpen: (url) => UrlLauncher(context, url.url).launchUrl(), + ), + const SizedBox(height: 16), + ValueListenableBuilder( + valueListenable: error, + builder: (context, error, _) { + return DialogTextField( + hintText: hintText, + errorText: error, + labelText: labelText, + controller: controller, + initialText: initialText, + prefixText: prefixText, + suffixText: suffixText, + minLines: minLines, + maxLines: maxLines, + maxLength: maxLength, + keyboardType: keyboardType, + obscureText: obscureText, + ); + }, + ), + ], + ), + ), + actions: [ + AdaptiveDialogAction( + onPressed: () => Navigator.of(context).pop(null), + child: Text(cancelLabel ?? L10n.of(context).cancel), + ), + AdaptiveDialogAction( + onPressed: () { + final input = controller.text; + final errorText = validator?.call(input); + if (errorText != null) { + error.value = errorText; + return; + } + Navigator.of(context).pop(input); + }, + autofocus: true, + child: Text( + okLabel ?? L10n.of(context).ok, + style: isDestructive + ? TextStyle(color: Theme.of(context).colorScheme.error) + : null, + ), + ), + ], + ); + }, + ); +} diff --git a/lib/widgets/adaptive_dialogs/user_dialog.dart b/lib/widgets/adaptive_dialogs/user_dialog.dart new file mode 100644 index 000000000..fc15c4e44 --- /dev/null +++ b/lib/widgets/adaptive_dialogs/user_dialog.dart @@ -0,0 +1,260 @@ +import 'package:flutter/material.dart'; +import 'package:flutter/services.dart'; + +import 'package:flutter_linkify/flutter_linkify.dart'; +import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/date_time_extension.dart'; +import 'package:fluffychat/utils/fluffy_share.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/presence_builder.dart'; +import '../../utils/url_launcher.dart'; +import '../future_loading_dialog.dart'; +import '../hover_builder.dart'; +import '../matrix.dart'; +import '../mxc_image_viewer.dart'; + +// ignore: unused_import + +class UserDialog extends StatelessWidget { + static Future show({ + required BuildContext context, + required Profile profile, + bool noProfileWarning = false, + }) => showAdaptiveDialog( + context: context, + barrierDismissible: true, + builder: (context) => + UserDialog(profile, noProfileWarning: noProfileWarning), + ); + + final Profile profile; + final bool noProfileWarning; + + const UserDialog(this.profile, {this.noProfileWarning = false, super.key}); + + @override + Widget build(BuildContext context) { + final client = Matrix.of(context).client; + final displayname = + profile.displayName ?? + profile.userId.localpart ?? + L10n.of(context).user; + var copied = false; + final theme = Theme.of(context); + final avatar = profile.avatarUrl; + return AlertDialog.adaptive( + content: PresenceBuilder( + userId: profile.userId, + client: Matrix.of(context).client, + builder: (context, presence) { + if (presence == null) return const SizedBox.shrink(); + final statusMsg = presence.statusMsg; + final lastActiveTimestamp = presence.lastActiveTimestamp; + final presenceText = presence.currentlyActive == true + ? L10n.of(context).currentlyActive + : lastActiveTimestamp != null + ? L10n.of( + context, + ).lastActiveAgo(lastActiveTimestamp.localizedTimeShort(context)) + : null; + return Column( + spacing: 16, + mainAxisSize: .min, + crossAxisAlignment: .stretch, + children: [ + Row( + spacing: 12, + children: [ + Avatar( + mxContent: avatar, + name: displayname, + size: Avatar.defaultSize * 1.5, + onTap: avatar != null + ? () => showDialog( + context: context, + builder: (_) => MxcImageViewer(avatar), + ) + : null, + ), + Expanded( + child: Column( + crossAxisAlignment: .start, + children: [ + Text( + displayname, + maxLines: 1, + overflow: .ellipsis, + style: TextStyle(fontSize: 16), + ), + const SizedBox(height: 8), + HoverBuilder( + builder: (context, hovered) => StatefulBuilder( + builder: (context, setState) => MouseRegion( + cursor: SystemMouseCursors.click, + child: GestureDetector( + onTap: () { + Clipboard.setData( + ClipboardData(text: profile.userId), + ); + setState(() { + copied = true; + }); + }, + child: RichText( + text: TextSpan( + children: [ + WidgetSpan( + child: Padding( + padding: const EdgeInsets.only( + right: 4.0, + ), + child: AnimatedScale( + duration: + FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + scale: hovered + ? 1.33 + : copied + ? 1.25 + : 1.0, + child: Icon( + copied + ? Icons.check_circle + : Icons.copy, + size: 12, + color: copied + ? Colors.green + : null, + ), + ), + ), + ), + TextSpan(text: profile.userId), + ], + style: theme.textTheme.bodyMedium?.copyWith( + fontSize: 10, + ), + ), + maxLines: 1, + overflow: .ellipsis, + textAlign: TextAlign.center, + ), + ), + ), + ), + ), + if (presenceText != null) + Text( + presenceText, + style: theme.textTheme.bodyMedium?.copyWith( + fontSize: 10, + ), + ), + ], + ), + ), + ], + ), + + if (statusMsg != null) + ConstrainedBox( + constraints: BoxConstraints(maxHeight: 200), + child: Scrollbar( + thumbVisibility: true, + trackVisibility: true, + child: SingleChildScrollView( + child: SelectableLinkify( + text: statusMsg, + textScaleFactor: MediaQuery.textScalerOf( + context, + ).scale(1), + textAlign: TextAlign.start, + options: const LinkifyOptions(humanize: false), + linkStyle: TextStyle( + color: theme.colorScheme.primary, + decoration: TextDecoration.underline, + decorationColor: theme.colorScheme.primary, + ), + onOpen: (url) => + UrlLauncher(context, url.url).launchUrl(), + ), + ), + ), + ), + Row( + mainAxisAlignment: .spaceBetween, + spacing: 4, + children: [ + AdaptiveIconTextButton( + label: L10n.of(context).block, + icon: Icons.block_outlined, + onTap: () { + final router = GoRouter.of(context); + Navigator.of(context).pop(); + router.go( + '/rooms/settings/security/ignorelist', + extra: profile.userId, + ); + }, + ), + AdaptiveIconTextButton( + label: L10n.of(context).report, + icon: Icons.gavel_outlined, + onTap: () async { + Navigator.of(context).pop(); + final reason = await showTextInputDialog( + context: context, + title: L10n.of(context).whyDoYouWantToReportThis, + okLabel: L10n.of(context).report, + cancelLabel: L10n.of(context).cancel, + hintText: L10n.of(context).reason, + ); + if (reason == null || reason.isEmpty) return; + await showFutureLoadingDialog( + context: context, + future: () => Matrix.of( + context, + ).client.reportUser(profile.userId, reason), + ); + }, + ), + AdaptiveIconTextButton( + label: L10n.of(context).share, + icon: Icons.adaptive.share, + onTap: () => FluffyShare.share( + 'https://matrix.to/#/${profile.userId}', + context, + ), + ), + ], + ), + AdaptiveDialogInkWell( + onTap: () async { + final router = GoRouter.of(context); + final roomIdResult = await showFutureLoadingDialog( + context: context, + future: () => client.startDirectChat(profile.userId), + ); + final roomId = roomIdResult.result; + if (roomId == null) return; + if (context.mounted) Navigator.of(context).pop(); + router.go('/rooms/$roomId'); + }, + child: Text( + L10n.of(context).sendAMessage, + style: TextStyle(color: theme.colorScheme.secondary), + ), + ), + ], + ); + }, + ), + ); + } +} diff --git a/lib/widgets/app_lock.dart b/lib/widgets/app_lock.dart index d337358d7..70f0a9efb 100644 --- a/lib/widgets/app_lock.dart +++ b/lib/widgets/app_lock.dart @@ -4,7 +4,6 @@ import 'package:flutter_secure_storage/flutter_secure_storage.dart'; import 'package:matrix/matrix.dart'; import 'package:provider/provider.dart'; -import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/widgets/lock_screen.dart'; class AppLockWidget extends StatefulWidget { @@ -42,7 +41,7 @@ class AppLock extends State with WidgetsBindingObserver { WidgetsBinding.instance.addPostFrameCallback(_checkLoggedIn); } - void _checkLoggedIn(_) async { + Future _checkLoggedIn(_) async { if (widget.clients.any((client) => client.isLogged())) return; await changePincode(null); @@ -65,7 +64,7 @@ class AppLock extends State with WidgetsBindingObserver { Future changePincode(String? pincode) async { await const FlutterSecureStorage().write( - key: SettingKeys.appLockKey, + key: 'chat.fluffy.app_lock', value: pincode, ); _pincode = pincode; @@ -83,8 +82,8 @@ class AppLock extends State with WidgetsBindingObserver { } void showLockScreen() => setState(() { - _isLocked = true; - }); + _isLocked = true; + }); Future pauseWhile(Future future) async { _paused = true; @@ -95,20 +94,15 @@ class AppLock extends State with WidgetsBindingObserver { } } - static AppLock of(BuildContext context) => Provider.of( - context, - listen: false, - ); + static AppLock of(BuildContext context) => + Provider.of(context, listen: false); @override Widget build(BuildContext context) => Provider( - create: (_) => this, - child: Stack( - fit: StackFit.expand, - children: [ - widget.child, - if (isLocked) const LockScreen(), - ], - ), - ); + create: (_) => this, + child: Stack( + fit: StackFit.expand, + children: [widget.child, if (isLocked) const LockScreen()], + ), + ); } diff --git a/lib/widgets/avatar.dart b/lib/widgets/avatar.dart index 2066536dc..d78a2fcdc 100644 --- a/lib/widgets/avatar.dart +++ b/lib/widgets/avatar.dart @@ -11,10 +11,15 @@ class Avatar extends StatelessWidget { final String? name; final double size; final void Function()? onTap; - static const double defaultSize = 44; + static const double defaultSize = 48; final Client? client; final String? presenceUserId; final Color? presenceBackgroundColor; + final BorderRadius? borderRadius; + final IconData? icon; + final ShapeBorder? shapeBorder; + final Color? backgroundColor; + final Color? textColor; const Avatar({ this.mxContent, @@ -24,106 +29,129 @@ class Avatar extends StatelessWidget { this.client, this.presenceUserId, this.presenceBackgroundColor, + this.borderRadius, + this.shapeBorder, + this.icon, + this.backgroundColor, + this.textColor, super.key, }); @override Widget build(BuildContext context) { - var fallbackLetters = '@'; + final theme = Theme.of(context); + final name = this.name; - if (name != null) { - if (name.runes.length >= 2) { - fallbackLetters = String.fromCharCodes(name.runes, 0, 2); - } else if (name.runes.length == 1) { - fallbackLetters = name; - } - } - final noPic = mxContent == null || + final fallbackLetters = name == null || name.isEmpty + ? '@' + : name.substring(0, 1); + + final noPic = + mxContent == null || mxContent.toString().isEmpty || mxContent.toString() == 'null'; - final textWidget = Center( - child: Text( - fallbackLetters, - style: TextStyle( - color: noPic ? Colors.white : null, - fontSize: (size / 2.5).roundToDouble(), - ), - ), - ); - final borderRadius = BorderRadius.circular(size / 2); + final borderRadius = this.borderRadius ?? BorderRadius.circular(size / 2); final presenceUserId = this.presenceUserId; - final color = - noPic ? name?.lightColorAvatar : Theme.of(context).secondaryHeaderColor; final container = Stack( children: [ - ClipRRect( - borderRadius: borderRadius, - child: Container( - width: size, - height: size, - color: color, - child: noPic - ? textWidget - : MxcImage( - key: Key(mxContent.toString()), - uri: mxContent, - fit: BoxFit.cover, - width: size, - height: size, - placeholder: (_) => textWidget, - cacheKey: mxContent.toString(), - ), + SizedBox( + width: size, + height: size, + child: Material( + color: theme.brightness == Brightness.light + ? Colors.white + : Colors.black, + shape: + shapeBorder ?? + RoundedSuperellipseBorder( + borderRadius: borderRadius, + side: BorderSide.none, + ), + clipBehavior: Clip.antiAlias, + child: MxcImage( + client: client, + borderRadius: borderRadius, + key: ValueKey(mxContent.toString()), + cacheKey: '${mxContent}_$size', + uri: mxContent, + fit: BoxFit.cover, + width: size, + height: size, + placeholder: (_) => noPic + ? Container( + decoration: BoxDecoration( + color: backgroundColor ?? name?.lightColorAvatar, + ), + alignment: Alignment.center, + child: Text( + fallbackLetters, + textAlign: TextAlign.center, + style: TextStyle( + fontFamily: 'RobotoMono', + color: textColor ?? Colors.white, + fontWeight: FontWeight.bold, + fontSize: (size / 2.5).roundToDouble(), + ), + ), + ) + : Center( + child: Icon( + Icons.person_2, + color: theme.colorScheme.tertiary, + size: size / 1.5, + ), + ), + ), ), ), - PresenceBuilder( - client: client, - userId: presenceUserId, - builder: (context, presence) { - if (presence == null || - (presence.presence == PresenceType.offline && - presence.lastActiveTimestamp == null)) { - return const SizedBox.shrink(); - } - final dotColor = presence.presence.isOnline - ? Colors.green - : presence.presence.isUnavailable - ? Colors.orange - : Colors.grey; - return Positioned( - bottom: -3, - right: -3, - child: Container( - width: 16, - height: 16, - decoration: BoxDecoration( - color: presenceBackgroundColor ?? - Theme.of(context).colorScheme.surface, - borderRadius: BorderRadius.circular(32), - ), - alignment: Alignment.center, + if (presenceUserId != null) + PresenceBuilder( + client: client, + userId: presenceUserId, + builder: (context, presence) { + if (presence == null || + (presence.presence == PresenceType.offline && + presence.lastActiveTimestamp == null)) { + return const SizedBox.shrink(); + } + final dotColor = presence.presence.isOnline + ? Colors.green + : presence.presence.isUnavailable + ? Colors.orange + : Colors.grey; + return Positioned( + bottom: -3, + right: -3, child: Container( - width: 10, - height: 10, + width: 16, + height: 16, decoration: BoxDecoration( - color: dotColor, - borderRadius: BorderRadius.circular(16), - border: Border.all( - width: 1, - color: Theme.of(context).colorScheme.surface, + color: presenceBackgroundColor ?? theme.colorScheme.surface, + borderRadius: BorderRadius.circular(32), + ), + alignment: Alignment.center, + child: Container( + width: 10, + height: 10, + decoration: BoxDecoration( + color: dotColor, + borderRadius: BorderRadius.circular(16), + border: Border.all( + width: 1, + color: theme.colorScheme.surface, + ), ), ), ), - ), - ); - }, - ), + ); + }, + ), ], ); if (onTap == null) return container; - return InkWell( - onTap: onTap, - borderRadius: borderRadius, - child: container, + return MouseRegion( + cursor: SystemMouseCursors.click, + child: GestureDetector(onTap: onTap, child: container), ); } } diff --git a/lib/widgets/blur_hash.dart b/lib/widgets/blur_hash.dart index d4ad1dd47..a7fc4fac0 100644 --- a/lib/widgets/blur_hash.dart +++ b/lib/widgets/blur_hash.dart @@ -25,9 +25,7 @@ class BlurHash extends StatefulWidget { class _BlurHashState extends State { Uint8List? _data; - static Future getBlurhashData( - BlurhashData blurhashData, - ) async { + static Future getBlurhashData(BlurhashData blurhashData) async { final blurhash = b.BlurHash.decode(blurhashData.hsh); final img = blurhash.toImage(blurhashData.w, blurhashData.h); return Uint8List.fromList(image.encodePng(img)); @@ -46,11 +44,7 @@ class _BlurHashState extends State { return _data ??= await compute( getBlurhashData, - BlurhashData( - hsh: widget.blurhash, - w: width, - h: height, - ), + BlurhashData(hsh: widget.blurhash, w: width, h: height), ); } @@ -84,21 +78,10 @@ class BlurhashData { final int w; final int h; - const BlurhashData({ - required this.hsh, - required this.w, - required this.h, - }); + const BlurhashData({required this.hsh, required this.w, required this.h}); - factory BlurhashData.fromJson(Map json) => BlurhashData( - hsh: json['hsh'], - w: json['w'], - h: json['h'], - ); + factory BlurhashData.fromJson(Map json) => + BlurhashData(hsh: json['hsh'], w: json['w'], h: json['h']); - Map toJson() => { - 'hsh': hsh, - 'w': w, - 'h': h, - }; + Map toJson() => {'hsh': hsh, 'w': w, 'h': h}; } diff --git a/lib/widgets/chat_settings_popup_menu.dart b/lib/widgets/chat_settings_popup_menu.dart index 6d9a4ce57..6e90a6a29 100644 --- a/lib/widgets/chat_settings_popup_menu.dart +++ b/lib/widgets/chat_settings_popup_menu.dart @@ -1,18 +1,16 @@ import 'dart:async'; import 'package:flutter/material.dart'; -import 'package:flutter/services.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; import 'package:go_router/go_router.dart'; -import 'package:keyboard_shortcuts/keyboard_shortcuts.dart'; import 'package:matrix/matrix.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import 'matrix.dart'; -enum ChatPopupMenuActions { details, mute, unmute, leave, search } +enum ChatPopupMenuActions { details, mute, unmute, emote, leave, search } class ChatSettingsPopupMenu extends StatefulWidget { final Room room; @@ -33,12 +31,12 @@ class ChatSettingsPopupMenuState extends State { super.dispose(); } + void goToEmoteSettings() => + context.push('/rooms/${widget.room.id}/details/emotes'); + @override Widget build(BuildContext context) { - notificationChangeSub ??= Matrix.of(context) - .client - .onSync - .stream + notificationChangeSub ??= Matrix.of(context).client.onSync.stream .where( (syncUpdate) => syncUpdate.accountData?.any( @@ -46,42 +44,34 @@ class ChatSettingsPopupMenuState extends State { ) ?? false, ) - .listen( - (u) => setState(() {}), - ); + .listen((u) => setState(() {})); return Stack( alignment: Alignment.center, children: [ - KeyBoardShortcuts( - keysToPress: { - LogicalKeyboardKey.controlLeft, - LogicalKeyboardKey.keyI, - }, - helpLabel: L10n.of(context)!.chatDetails, - onKeysPressed: _showChatDetails, - child: const SizedBox.shrink(), - ), + const SizedBox.shrink(), PopupMenuButton( + useRootNavigator: true, onSelected: (choice) async { switch (choice) { case ChatPopupMenuActions.leave: + final router = GoRouter.of(context); final confirmed = await showOkCancelAlertDialog( - useRootNavigator: false, context: context, - title: L10n.of(context)!.areYouSure, - okLabel: L10n.of(context)!.ok, - cancelLabel: L10n.of(context)!.cancel, - message: L10n.of(context)!.archiveRoomDescription, + title: L10n.of(context).areYouSure, + message: L10n.of(context).archiveRoomDescription, + okLabel: L10n.of(context).leave, + cancelLabel: L10n.of(context).cancel, + isDestructive: true, ); - if (confirmed == OkCancelResult.ok) { - final success = await showFutureLoadingDialog( - context: context, - future: () => widget.room.leave(), - ); - if (success.error == null) { - context.go('/rooms'); - } + if (confirmed != OkCancelResult.ok) return; + final result = await showFutureLoadingDialog( + context: context, + future: () => widget.room.leave(), + ); + if (result.error == null) { + router.go('/rooms'); } + break; case ChatPopupMenuActions.mute: await showFutureLoadingDialog( @@ -103,6 +93,8 @@ class ChatSettingsPopupMenuState extends State { case ChatPopupMenuActions.search: context.go('/rooms/${widget.room.id}/search'); break; + case ChatPopupMenuActions.emote: + goToEmoteSettings(); } }, itemBuilder: (BuildContext context) => [ @@ -113,7 +105,7 @@ class ChatSettingsPopupMenuState extends State { children: [ const Icon(Icons.info_outline_rounded), const SizedBox(width: 12), - Text(L10n.of(context)!.chatDetails), + Text(L10n.of(context).chatDetails), ], ), ), @@ -124,7 +116,7 @@ class ChatSettingsPopupMenuState extends State { children: [ const Icon(Icons.notifications_off_outlined), const SizedBox(width: 12), - Text(L10n.of(context)!.muteChat), + Text(L10n.of(context).muteChat), ], ), ) @@ -135,7 +127,7 @@ class ChatSettingsPopupMenuState extends State { children: [ const Icon(Icons.notifications_on_outlined), const SizedBox(width: 12), - Text(L10n.of(context)!.unmuteChat), + Text(L10n.of(context).unmuteChat), ], ), ), @@ -145,7 +137,17 @@ class ChatSettingsPopupMenuState extends State { children: [ const Icon(Icons.search_outlined), const SizedBox(width: 12), - Text(L10n.of(context)!.search), + Text(L10n.of(context).search), + ], + ), + ), + PopupMenuItem( + value: ChatPopupMenuActions.emote, + child: Row( + children: [ + const Icon(Icons.emoji_emotions_outlined), + const SizedBox(width: 12), + Text(L10n.of(context).emoteSettings), ], ), ), @@ -155,7 +157,7 @@ class ChatSettingsPopupMenuState extends State { children: [ const Icon(Icons.delete_outlined), const SizedBox(width: 12), - Text(L10n.of(context)!.leave), + Text(L10n.of(context).leave), ], ), ), diff --git a/lib/widgets/config_viewer.dart b/lib/widgets/config_viewer.dart new file mode 100644 index 000000000..82a9d4ba5 --- /dev/null +++ b/lib/widgets/config_viewer.dart @@ -0,0 +1,101 @@ +import 'package:flutter/material.dart'; + +import 'package:go_router/go_router.dart'; +import 'package:shared_preferences/shared_preferences.dart'; + +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_text_input_dialog.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +class ConfigViewer extends StatefulWidget { + const ConfigViewer({super.key}); + + @override + State createState() => _ConfigViewerState(); +} + +class _ConfigViewerState extends State { + Future _changeSetting( + AppSettings appSetting, + SharedPreferences store, + String initialValue, + ) async { + if (appSetting is AppSettings) { + await appSetting.setItem(!(initialValue == 'true')); + setState(() {}); + return; + } + + final value = await showTextInputDialog( + context: context, + title: appSetting.name, + hintText: appSetting.defaultValue.toString(), + initialText: initialValue, + ); + if (value == null) return; + + if (appSetting is AppSettings) { + await appSetting.setItem(value); + } + if (appSetting is AppSettings) { + await appSetting.setItem(int.parse(value)); + } + if (appSetting is AppSettings) { + await appSetting.setItem(double.parse(value)); + } + + setState(() {}); + } + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + return Scaffold( + appBar: AppBar( + title: Text(L10n.of(context).advancedConfigurations), + leading: BackButton(onPressed: () => context.go('/')), + ), + body: Column( + children: [ + Container( + margin: const EdgeInsets.all(16), + padding: const EdgeInsets.all(16), + color: theme.colorScheme.errorContainer, + child: Text( + 'Changing configs by hand is untested! Use without any warranty!', + style: TextStyle(color: theme.colorScheme.onErrorContainer), + ), + ), + Expanded( + child: ListView.builder( + itemCount: AppSettings.values.length, + itemBuilder: (context, i) { + final store = Matrix.of(context).store; + final appSetting = AppSettings.values[i]; + var value = ''; + if (appSetting is AppSettings) { + value = appSetting.value; + } + if (appSetting is AppSettings) { + value = appSetting.value.toString(); + } + if (appSetting is AppSettings) { + value = appSetting.value.toString(); + } + if (appSetting is AppSettings) { + value = appSetting.value.toString(); + } + return ListTile( + title: Text(appSetting.name), + subtitle: Text(value), + onTap: () => _changeSetting(appSetting, store, value), + ); + }, + ), + ), + ], + ), + ); + } +} diff --git a/lib/widgets/connection_status_header.dart b/lib/widgets/connection_status_header.dart deleted file mode 100644 index 285ebb8bf..000000000 --- a/lib/widgets/connection_status_header.dart +++ /dev/null @@ -1,91 +0,0 @@ -import 'dart:async'; - -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:matrix/matrix.dart'; - -import '../config/themes.dart'; -import '../utils/localized_exception_extension.dart'; -import 'matrix.dart'; - -class ConnectionStatusHeader extends StatefulWidget { - const ConnectionStatusHeader({super.key}); - - @override - ConnectionStatusHeaderState createState() => ConnectionStatusHeaderState(); -} - -class ConnectionStatusHeaderState extends State { - late final StreamSubscription _onSyncSub; - - @override - void initState() { - _onSyncSub = Matrix.of(context).client.onSyncStatus.stream.listen( - (_) => setState(() {}), - ); - super.initState(); - } - - @override - void dispose() { - _onSyncSub.cancel(); - super.dispose(); - } - - @override - Widget build(BuildContext context) { - final client = Matrix.of(context).client; - final status = client.onSyncStatus.value ?? - const SyncStatusUpdate(SyncStatus.waitingForResponse); - final hide = client.onSync.value != null && - status.status != SyncStatus.error && - client.prevBatch != null; - - return AnimatedContainer( - duration: FluffyThemes.animationDuration, - curve: FluffyThemes.animationCurve, - height: hide ? 0 : 36, - clipBehavior: Clip.hardEdge, - decoration: const BoxDecoration(color: Colors.transparent), - padding: const EdgeInsets.symmetric(horizontal: 12), - child: Row( - mainAxisAlignment: MainAxisAlignment.center, - children: [ - SizedBox( - width: 24, - height: 24, - child: CircularProgressIndicator.adaptive( - strokeWidth: 2, - value: hide ? 1.0 : status.progress, - ), - ), - const SizedBox(width: 12), - Text( - status.toLocalizedString(context), - maxLines: 1, - overflow: TextOverflow.ellipsis, - style: TextStyle(color: Theme.of(context).colorScheme.onSurface), - ), - ], - ), - ); - } -} - -extension on SyncStatusUpdate { - String toLocalizedString(BuildContext context) { - switch (status) { - case SyncStatus.waitingForResponse: - return L10n.of(context)!.loadingPleaseWait; - case SyncStatus.error: - return ((error?.exception ?? Object()) as Object) - .toLocalizedString(context); - case SyncStatus.processing: - case SyncStatus.cleaningUp: - case SyncStatus.finished: - default: - return L10n.of(context)!.synchronizingPleaseWait; - } - } -} diff --git a/lib/widgets/error_widget.dart b/lib/widgets/error_widget.dart deleted file mode 100644 index e21e5e4e8..000000000 --- a/lib/widgets/error_widget.dart +++ /dev/null @@ -1,45 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:fluffychat/utils/error_reporter.dart'; - -class FluffyChatErrorWidget extends StatefulWidget { - final FlutterErrorDetails details; - const FluffyChatErrorWidget(this.details, {super.key}); - - @override - State createState() => _FluffyChatErrorWidgetState(); -} - -class _FluffyChatErrorWidgetState extends State { - static final Set knownExceptions = {}; - @override - void initState() { - super.initState(); - - if (knownExceptions.contains(widget.details.exception.toString())) { - return; - } - knownExceptions.add(widget.details.exception.toString()); - WidgetsBinding.instance.addPostFrameCallback((_) { - ErrorReporter(context, 'Error Widget').onErrorCallback( - widget.details.exception, - widget.details.stack, - ); - }); - } - - @override - Widget build(BuildContext context) { - return Material( - color: Colors.orange, - child: Placeholder( - child: Center( - child: Material( - color: Colors.white.withOpacity(0.9), - borderRadius: BorderRadius.circular(8), - ), - ), - ), - ); - } -} diff --git a/lib/widgets/fluffy_chat_app.dart b/lib/widgets/fluffy_chat_app.dart index d9d2f042a..4a72d07dd 100644 --- a/lib/widgets/fluffy_chat_app.dart +++ b/lib/widgets/fluffy_chat_app.dart @@ -1,15 +1,15 @@ import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:go_router/go_router.dart'; import 'package:matrix/matrix.dart'; import 'package:shared_preferences/shared_preferences.dart'; import 'package:fluffychat/config/routes.dart'; +import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/widgets/app_lock.dart'; import 'package:fluffychat/widgets/theme_builder.dart'; -import '../config/app_config.dart'; import '../utils/custom_scroll_behaviour.dart'; import 'matrix.dart'; @@ -34,17 +34,23 @@ class FluffyChatApp extends StatelessWidget { // Router must be outside of build method so that hot reload does not reset // the current path. - static final GoRouter router = GoRouter(routes: AppRoutes.routes); + static final GoRouter router = GoRouter( + routes: AppRoutes.routes, + debugLogDiagnostics: true, + ); @override Widget build(BuildContext context) { return ThemeBuilder( builder: (context, themeMode, primaryColor) => MaterialApp.router( - title: AppConfig.applicationName, + title: AppSettings.applicationName.value, themeMode: themeMode, theme: FluffyThemes.buildTheme(context, Brightness.light, primaryColor), - darkTheme: - FluffyThemes.buildTheme(context, Brightness.dark, primaryColor), + darkTheme: FluffyThemes.buildTheme( + context, + Brightness.dark, + primaryColor, + ), scrollBehavior: CustomScrollBehavior(), localizationsDelegates: L10n.localizationsDelegates, supportedLocales: L10n.supportedLocales, @@ -54,14 +60,10 @@ class FluffyChatApp extends StatelessWidget { clients: clients, // Need a navigator above the Matrix widget for // displaying dialogs - child: Navigator( - onGenerateRoute: (_) => MaterialPageRoute( - builder: (_) => Matrix( - clients: clients, - store: store, - child: testWidget ?? child, - ), - ), + child: Matrix( + clients: clients, + store: store, + child: testWidget ?? child, ), ), ), diff --git a/lib/widgets/future_loading_dialog.dart b/lib/widgets/future_loading_dialog.dart new file mode 100644 index 000000000..cc6b1b409 --- /dev/null +++ b/lib/widgets/future_loading_dialog.dart @@ -0,0 +1,153 @@ +import 'dart:async'; + +import 'package:flutter/material.dart'; + +import 'package:async/async.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/localized_exception_extension.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; + +/// Displays a loading dialog which reacts to the given [future]. The dialog +/// will be dismissed and the value will be returned when the future completes. +/// If an error occured, then [onError] will be called and this method returns +/// null. +Future> showFutureLoadingDialog({ + required BuildContext context, + Future Function()? future, + Future Function(void Function(double?) setProgress)? futureWithProgress, + String? title, + String? backLabel, + bool barrierDismissible = false, + bool delay = true, + ExceptionContext? exceptionContext, + bool ignoreError = false, +}) async { + assert(future != null || futureWithProgress != null); + final onProgressStream = StreamController(); + final futureExec = + futureWithProgress?.call(onProgressStream.add) ?? future!(); + final resultFuture = ResultFuture(futureExec); + + if (delay) { + var i = 3; + while (i > 0) { + final result = resultFuture.result; + if (result != null) { + if (result.isError) break; + return result; + } + await Future.delayed(const Duration(milliseconds: 100)); + i--; + } + } + + final result = await showAdaptiveDialog>( + context: context, + barrierDismissible: barrierDismissible, + builder: (BuildContext context) => LoadingDialog( + future: futureExec, + title: title, + backLabel: backLabel, + exceptionContext: exceptionContext, + onProgressStream: onProgressStream.stream, + ), + ); + return result ?? + Result.error(Exception('FutureDialog canceled'), StackTrace.current); +} + +class LoadingDialog extends StatefulWidget { + final String? title; + final String? backLabel; + final Future future; + final ExceptionContext? exceptionContext; + final Stream onProgressStream; + + const LoadingDialog({ + super.key, + required this.future, + this.title, + this.backLabel, + this.exceptionContext, + required this.onProgressStream, + }); + + @override + LoadingDialogState createState() => LoadingDialogState(); +} + +class LoadingDialogState extends State { + Object? exception; + StackTrace? stackTrace; + + @override + void initState() { + super.initState(); + widget.future.then( + (result) => Navigator.of(context).pop>(Result.value(result)), + onError: (e, s) => setState(() { + exception = e; + stackTrace = s; + }), + ); + } + + @override + Widget build(BuildContext context) { + final exception = this.exception; + final titleLabel = exception != null + ? exception.toLocalizedString(context, widget.exceptionContext) + : widget.title ?? L10n.of(context).loadingPleaseWait; + + return AlertDialog.adaptive( + title: exception == null + ? null + : Icon( + Icons.error_outline_outlined, + color: Theme.of(context).colorScheme.error, + size: 48, + ), + content: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256), + child: Row( + crossAxisAlignment: .center, + children: [ + if (exception == null) ...[ + StreamBuilder( + stream: widget.onProgressStream, + builder: (context, snapshot) => + CircularProgressIndicator.adaptive(value: snapshot.data), + ), + const SizedBox(width: 20), + ], + Expanded( + child: Text( + titleLabel, + maxLines: 4, + textAlign: exception == null ? TextAlign.left : null, + overflow: TextOverflow.ellipsis, + ), + ), + ], + ), + ), + actions: exception == null + ? null + : [ + AdaptiveDialogAction( + onPressed: () => Navigator.of( + context, + ).pop>(Result.error(exception, stackTrace)), + child: Text(widget.backLabel ?? L10n.of(context).close), + ), + ], + ); + } +} + +extension DeprecatedApiAccessExtension on Result { + T? get result => asValue?.value; + + Object? get error => asError?.error; +} diff --git a/lib/widgets/layouts/empty_page.dart b/lib/widgets/layouts/empty_page.dart index 79fe89995..5a0be7862 100644 --- a/lib/widgets/layouts/empty_page.dart +++ b/lib/widgets/layouts/empty_page.dart @@ -7,7 +7,8 @@ class EmptyPage extends StatelessWidget { const EmptyPage({super.key}); @override Widget build(BuildContext context) { - final width = min(MediaQuery.of(context).size.width, EmptyPage._width) / 2; + final width = min(MediaQuery.sizeOf(context).width, EmptyPage._width) / 2; + final theme = Theme.of(context); return Scaffold( // Add invisible appbar to make status bar on Android tablets bright. appBar: AppBar( @@ -19,7 +20,8 @@ class EmptyPage extends StatelessWidget { body: Container( alignment: Alignment.center, child: Image.asset( - 'assets/info-logo.png', + 'assets/logo_transparent.png', + color: theme.colorScheme.surfaceContainerHigh, width: width, height: width, filterQuality: FilterQuality.medium, diff --git a/lib/widgets/layouts/login_scaffold.dart b/lib/widgets/layouts/login_scaffold.dart index b253ec4fa..944ca3919 100644 --- a/lib/widgets/layouts/login_scaffold.dart +++ b/lib/widgets/layouts/login_scaffold.dart @@ -1,99 +1,103 @@ -import 'dart:ui'; - import 'package:flutter/material.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:particles_network/particles_network.dart'; +import 'package:url_launcher/url_launcher.dart'; import 'package:url_launcher/url_launcher_string.dart'; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/platform_infos.dart'; class LoginScaffold extends StatelessWidget { final Widget body; final AppBar? appBar; - final bool enforceMobileMode; + final Widget? bottomNavigationBar; const LoginScaffold({ super.key, required this.body, this.appBar, - this.enforceMobileMode = false, + this.bottomNavigationBar, }); @override Widget build(BuildContext context) { - final isMobileMode = - enforceMobileMode || !FluffyThemes.isColumnMode(context); - final scaffold = Scaffold( - key: const Key('LoginScaffold'), - appBar: appBar == null - ? null - : AppBar( - titleSpacing: appBar?.titleSpacing, - automaticallyImplyLeading: - appBar?.automaticallyImplyLeading ?? true, - centerTitle: appBar?.centerTitle, - title: appBar?.title, - leading: appBar?.leading, - actions: appBar?.actions, - backgroundColor: isMobileMode ? null : Colors.transparent, - ), - body: body, - backgroundColor: isMobileMode - ? null - : Theme.of(context).colorScheme.surface.withOpacity(0.8), - bottomNavigationBar: isMobileMode - ? Material( - elevation: 4, - shadowColor: Theme.of(context).colorScheme.onSurface, - child: const _PrivacyButtons( - mainAxisAlignment: MainAxisAlignment.center, - ), - ) - : null, - ); - if (isMobileMode) return scaffold; - return Container( - decoration: const BoxDecoration( - image: DecorationImage( - fit: BoxFit.cover, - image: AssetImage('assets/login_wallpaper.png'), - ), - ), - child: Column( - children: [ - const SizedBox(height: 16), - Expanded( - child: Center( - child: Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0), - child: Material( - color: Colors.transparent, - borderRadius: BorderRadius.circular(AppConfig.borderRadius), - clipBehavior: Clip.hardEdge, - elevation: - Theme.of(context).appBarTheme.scrolledUnderElevation ?? 4, - shadowColor: Theme.of(context).appBarTheme.shadowColor, - child: ConstrainedBox( - constraints: isMobileMode - ? const BoxConstraints() - : const BoxConstraints(maxWidth: 480, maxHeight: 720), - child: BackdropFilter( - filter: ImageFilter.blur( - sigmaX: 10.0, - sigmaY: 10.0, - ), - child: scaffold, - ), - ), - ), - ), + final theme = Theme.of(context); + + return LayoutBuilder( + builder: (context, constraints) { + final isMobileMode = !FluffyThemes.isColumnModeByWidth( + constraints.maxWidth, + ); + if (isMobileMode) { + return Scaffold( + key: const Key('LoginScaffold'), + appBar: appBar, + body: SafeArea(child: body), + bottomNavigationBar: bottomNavigationBar, + ); + } + return Container( + decoration: BoxDecoration( + gradient: LinearGradient( + colors: [ + theme.colorScheme.surfaceContainerLow, + theme.colorScheme.surfaceContainer, + theme.colorScheme.surfaceContainerHighest, + ], + begin: Alignment.topLeft, + end: Alignment.bottomRight, ), ), - const _PrivacyButtons(mainAxisAlignment: MainAxisAlignment.center), - ], - ), + child: Stack( + children: [ + if (!MediaQuery.disableAnimationsOf(context)) + ParticleNetwork( + maxSpeed: 0.25, + particleColor: theme.colorScheme.primary, + lineColor: theme.colorScheme.secondary, + ), + Column( + children: [ + const SizedBox(height: 16), + Expanded( + child: Center( + child: Padding( + padding: const EdgeInsets.symmetric(horizontal: 16.0), + child: Material( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + clipBehavior: Clip.hardEdge, + elevation: + theme.appBarTheme.scrolledUnderElevation ?? 4, + shadowColor: theme.appBarTheme.shadowColor, + child: ConstrainedBox( + constraints: isMobileMode + ? const BoxConstraints() + : const BoxConstraints( + maxWidth: 480, + maxHeight: 640, + ), + child: Scaffold( + key: const Key('LoginScaffold'), + appBar: appBar, + body: SafeArea(child: body), + bottomNavigationBar: bottomNavigationBar, + ), + ), + ), + ), + ), + ), + const _PrivacyButtons(mainAxisAlignment: .center), + ], + ), + ], + ), + ); + }, ); } } @@ -104,18 +108,8 @@ class _PrivacyButtons extends StatelessWidget { @override Widget build(BuildContext context) { - final shadowTextStyle = FluffyThemes.isColumnMode(context) - ? const TextStyle( - color: Colors.white, - shadows: [ - Shadow( - offset: Offset(0.0, 0.0), - blurRadius: 3, - color: Colors.black, - ), - ], - ) - : null; + final theme = Theme.of(context); + final shadowTextStyle = TextStyle(color: theme.colorScheme.secondary); return SizedBox( height: 64, child: Padding( @@ -124,18 +118,20 @@ class _PrivacyButtons extends StatelessWidget { mainAxisAlignment: mainAxisAlignment, children: [ TextButton( - onPressed: () => PlatformInfos.showDialog(context), - child: Text( - L10n.of(context)!.about, - style: shadowTextStyle, - ), + onPressed: () => launchUrlString(AppConfig.website), + child: Text(L10n.of(context).website, style: shadowTextStyle), ), TextButton( - onPressed: () => launchUrlString(AppConfig.privacyUrl), - child: Text( - L10n.of(context)!.privacy, - style: shadowTextStyle, - ), + onPressed: () => launchUrlString(AppConfig.supportUrl), + child: Text(L10n.of(context).help, style: shadowTextStyle), + ), + TextButton( + onPressed: () => launchUrl(AppConfig.privacyUrl), + child: Text(L10n.of(context).privacy, style: shadowTextStyle), + ), + TextButton( + onPressed: () => PlatformInfos.showDialog(context), + child: Text(L10n.of(context).about, style: shadowTextStyle), ), ], ), diff --git a/lib/widgets/layouts/max_width_body.dart b/lib/widgets/layouts/max_width_body.dart index e9499d31e..c0afc7077 100644 --- a/lib/widgets/layouts/max_width_body.dart +++ b/lib/widgets/layouts/max_width_body.dart @@ -1,20 +1,17 @@ -import 'dart:math'; - import 'package:flutter/material.dart'; import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; class MaxWidthBody extends StatelessWidget { - final Widget? child; + final Widget child; final double maxWidth; - final bool withFrame; final bool withScrolling; final EdgeInsets? innerPadding; const MaxWidthBody({ - this.child, + required this.child, this.maxWidth = 600, - this.withFrame = true, this.withScrolling = true, this.innerPadding, super.key, @@ -24,36 +21,39 @@ class MaxWidthBody extends StatelessWidget { return SafeArea( child: LayoutBuilder( builder: (context, constraints) { - final paddingVal = max(0, (constraints.maxWidth - maxWidth) / 2); - final hasPadding = paddingVal > 0; - final padding = EdgeInsets.symmetric( - vertical: hasPadding ? 32 : 0, - horizontal: max(0, (constraints.maxWidth - maxWidth) / 2), - ); - final childWithPadding = Padding( - padding: padding, - child: withFrame && hasPadding - ? Material( - elevation: - Theme.of(context).appBarTheme.scrolledUnderElevation ?? - 4, - clipBehavior: Clip.hardEdge, - borderRadius: BorderRadius.circular(AppConfig.borderRadius), - shadowColor: Theme.of(context).appBarTheme.shadowColor, - child: child, - ) - : child, - ); - if (!withScrolling) { - return Padding( - padding: innerPadding ?? EdgeInsets.zero, - child: childWithPadding, - ); - } + final theme = Theme.of(context); + + const desiredWidth = FluffyThemes.columnWidth * 1.5; + final body = constraints.maxWidth <= desiredWidth + ? child + : Container( + alignment: Alignment.topCenter, + padding: const EdgeInsets.all(32), + child: ConstrainedBox( + constraints: const BoxConstraints( + maxWidth: FluffyThemes.columnWidth * 1.5, + ), + child: Material( + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + side: BorderSide(color: theme.dividerColor), + ), + clipBehavior: Clip.hardEdge, + child: Padding( + padding: const EdgeInsets.symmetric(vertical: 16.0), + child: child, + ), + ), + ), + ); + if (!withScrolling) return body; + return SingleChildScrollView( padding: innerPadding, physics: const ScrollPhysics(), - child: childWithPadding, + child: body, ); }, ), diff --git a/lib/widgets/layouts/two_column_layout.dart b/lib/widgets/layouts/two_column_layout.dart index a6f4c8bdf..9bcbd515b 100644 --- a/lib/widgets/layouts/two_column_layout.dart +++ b/lib/widgets/layouts/two_column_layout.dart @@ -1,18 +1,22 @@ import 'package:flutter/material.dart'; +import 'package:fluffychat/config/themes.dart'; + class TwoColumnLayout extends StatelessWidget { final Widget mainView; final Widget sideView; - final bool displayNavigationRail; + final bool hasNavigationRail; const TwoColumnLayout({ super.key, required this.mainView, required this.sideView, - required this.displayNavigationRail, + this.hasNavigationRail = true, }); @override Widget build(BuildContext context) { + final theme = Theme.of(context); + return ScaffoldMessenger( child: Scaffold( body: Row( @@ -20,18 +24,13 @@ class TwoColumnLayout extends StatelessWidget { Container( clipBehavior: Clip.antiAlias, decoration: const BoxDecoration(), - width: 360.0 + (displayNavigationRail ? 64 : 0), + width: + FluffyThemes.columnWidth + + (hasNavigationRail ? FluffyThemes.navRailWidth : 0), child: mainView, ), - Container( - width: 1.0, - color: Theme.of(context).dividerColor, - ), - Expanded( - child: ClipRRect( - child: sideView, - ), - ), + Container(width: 1.0, color: theme.dividerColor), + Expanded(child: ClipRRect(child: sideView)), ], ), ), diff --git a/lib/widgets/local_notifications_extension.dart b/lib/widgets/local_notifications_extension.dart index e3d9ff3c4..ee5708a5e 100644 --- a/lib/widgets/local_notifications_extension.dart +++ b/lib/widgets/local_notifications_extension.dart @@ -3,17 +3,18 @@ import 'dart:io'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; +import 'package:collection/collection.dart'; import 'package:desktop_notifications/desktop_notifications.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:go_router/go_router.dart'; -import 'package:http/http.dart' as http; +import 'package:image/image.dart'; import 'package:matrix/matrix.dart'; -import 'package:path_provider/path_provider.dart'; import 'package:universal_html/html.dart' as html; -import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/setting_keys.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/client_download_content_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; -import 'package:fluffychat/utils/platform_infos.dart'; +import 'package:fluffychat/utils/push_helper.dart'; +import 'package:fluffychat/widgets/fluffy_chat_app.dart'; import 'package:fluffychat/widgets/matrix.dart'; extension LocalNotificationsExtension on MatrixState { @@ -21,104 +22,134 @@ extension LocalNotificationsExtension on MatrixState { ..src = 'assets/assets/sounds/notification.ogg' ..load(); - void showLocalNotification(EventUpdate eventUpdate) async { - final roomId = eventUpdate.roomID; + Future showLocalNotification(Event event) async { + final roomId = event.room.id; if (activeRoomId == roomId) { - if (kIsWeb && webHasFocus) return; - if (PlatformInfos.isDesktop && - WidgetsBinding.instance.lifecycleState == AppLifecycleState.resumed) { + if (WidgetsBinding.instance.lifecycleState == AppLifecycleState.resumed) { return; } } - final room = client.getRoomById(roomId); - if (room == null) { - Logs().w('Can not display notification for unknown room $roomId'); - return; - } - if (room.notificationCount == 0) return; - final event = Event.fromJson(eventUpdate.content, room); - final title = room.getLocalizedDisplayname(MatrixLocals(L10n.of(context)!)); + final title = event.room.getLocalizedDisplayname( + MatrixLocals(L10n.of(context)), + ); final body = await event.calcLocalizedBody( - MatrixLocals(L10n.of(context)!), + MatrixLocals(L10n.of(context)), withSenderNamePrefix: - !room.isDirectChat || room.lastEvent?.senderId == client.userID, + !event.room.isDirectChat || + event.room.lastEvent?.senderId == client.userID, plaintextBody: true, hideReply: true, hideEdit: true, removeMarkdown: true, ); - final icon = event.senderFromMemoryOrFallback.avatarUrl?.getThumbnail( - client, - width: 64, - height: 64, - method: ThumbnailMethod.crop, - ) ?? - room.avatar?.getThumbnail( - client, - width: 64, - height: 64, - method: ThumbnailMethod.crop, - ); + if (kIsWeb) { + final avatarUrl = event.senderFromMemoryOrFallback.avatarUrl; + Uri? thumbnailUri; + + if (avatarUrl != null) { + const size = 128; + const thumbnailMethod = ThumbnailMethod.crop; + // Pre-cache so that we can later just set the thumbnail uri as icon: + try { + await client.downloadMxcCached( + avatarUrl, + width: size, + height: size, + thumbnailMethod: thumbnailMethod, + isThumbnail: true, + rounded: true, + ); + } catch (e, s) { + Logs().d('Unable to pre-download avatar for web notification', e, s); + } + + thumbnailUri = await event.senderFromMemoryOrFallback.avatarUrl + ?.getThumbnailUri( + client, + width: size, + height: size, + method: thumbnailMethod, + ); + } + _audioPlayer.play(); + html.Notification( title, body: body, - icon: icon.toString(), + icon: thumbnailUri?.toString(), + tag: event.room.id, ); } else if (Platform.isLinux) { - final appIconUrl = room.avatar?.getThumbnail( - room.client, - width: 56, - height: 56, - ); - File? appIconFile; - if (appIconUrl != null) { - final tempDirectory = await getApplicationSupportDirectory(); - final avatarDirectory = - await Directory('${tempDirectory.path}/notiavatars/').create(); - appIconFile = File( - '${avatarDirectory.path}/${Uri.encodeComponent(appIconUrl.toString())}', + final avatarUrl = event.room.avatar; + final hints = [NotificationHint.soundName('message-new-instant')]; + + if (avatarUrl != null) { + const size = notificationAvatarDimension; + const thumbnailMethod = ThumbnailMethod.crop; + // Pre-cache so that we can later just set the thumbnail uri as icon: + final data = await client.downloadMxcCached( + avatarUrl, + width: size, + height: size, + thumbnailMethod: thumbnailMethod, + isThumbnail: true, + rounded: true, ); - if (await appIconFile.exists() == false) { - final response = await http.get(appIconUrl); - await appIconFile.writeAsBytes(response.bodyBytes); + + final image = decodeImage(data); + if (image != null) { + final realData = image.getBytes(order: ChannelOrder.rgba); + hints.add( + NotificationHint.imageData( + image.width, + image.height, + realData, + hasAlpha: true, + channels: 4, + ), + ); } } final notification = await linuxNotifications!.notify( title, body: body, replacesId: linuxNotificationIds[roomId] ?? 0, - appName: AppConfig.applicationName, - appIcon: appIconFile?.path ?? '', + appName: AppSettings.applicationName.value, + appIcon: 'fluffychat', actions: [ NotificationAction( DesktopNotificationActions.openChat.name, - L10n.of(context)!.openChat, + L10n.of(context).openChat, ), NotificationAction( DesktopNotificationActions.seen.name, - L10n.of(context)!.markAsRead, + L10n.of(context).markAsRead, ), ], - hints: [ - NotificationHint.soundName('message-new-instant'), - ], + hints: hints, ); notification.action.then((actionStr) { - final action = DesktopNotificationActions.values - .singleWhere((a) => a.name == actionStr); - switch (action) { + var action = DesktopNotificationActions.values.singleWhereOrNull( + (a) => a.name == actionStr, + ); + if (action == null && actionStr == 'default') { + action = DesktopNotificationActions.openChat; + } + switch (action!) { case DesktopNotificationActions.seen: - room.setReadMarker( + event.room.setReadMarker( event.eventId, mRead: event.eventId, - public: AppConfig.sendPublicReadReceipts, + public: AppSettings.sendPublicReadReceipts.value, ); break; case DesktopNotificationActions.openChat: - context.go('/rooms/${room.id}'); + setActiveClient(event.room.client); + + FluffyChatApp.router.go('/rooms/${event.room.id}'); break; } }); diff --git a/lib/widgets/lock_screen.dart b/lib/widgets/lock_screen.dart index b756a3954..66a90951c 100644 --- a/lib/widgets/lock_screen.dart +++ b/lib/widgets/lock_screen.dart @@ -3,9 +3,8 @@ import 'dart:async'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; - import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/widgets/app_lock.dart'; class LockScreen extends StatefulWidget { @@ -21,7 +20,8 @@ class _LockScreenState extends State { bool _inputBlocked = false; final TextEditingController _textEditingController = TextEditingController(); - void tryUnlock(String text) async { + Future tryUnlock(String text) async { + text = text.trim(); setState(() { _errorText = null; }); @@ -30,13 +30,13 @@ class _LockScreenState extends State { final enteredPin = int.tryParse(text); if (enteredPin == null || text.length != 4) { setState(() { - _errorText = L10n.of(context)!.invalidInput; + _errorText = L10n.of(context).invalidInput; }); _textEditingController.clear(); return; } - if (AppLock.of(context).unlock(enteredPin.toString())) { + if (AppLock.of(context).unlock(text)) { setState(() { _inputBlocked = false; _errorText = null; @@ -46,7 +46,7 @@ class _LockScreenState extends State { } setState(() { - _errorText = L10n.of(context)!.wrongPinEntered(_coolDownSeconds); + _errorText = L10n.of(context).wrongPinEntered(_coolDownSeconds); _inputBlocked = true; }); Future.delayed(Duration(seconds: _coolDownSeconds)).then((_) { @@ -61,57 +61,54 @@ class _LockScreenState extends State { @override Widget build(BuildContext context) { - return Scaffold( - appBar: AppBar( - title: Text(L10n.of(context)!.pleaseEnterYourPin), - centerTitle: true, - ), - extendBodyBehindAppBar: true, - body: Center( - child: Padding( - padding: const EdgeInsets.all(16.0), - child: ConstrainedBox( - constraints: const BoxConstraints( - maxWidth: FluffyThemes.columnWidth, - ), - child: ListView( - shrinkWrap: true, - children: [ - Center( - child: Image.asset( - 'assets/info-logo.png', - width: 256, + return ScaffoldMessenger( + child: Scaffold( + appBar: AppBar( + title: Text(L10n.of(context).pleaseEnterYourPin), + centerTitle: true, + ), + extendBodyBehindAppBar: true, + body: Center( + child: Padding( + padding: const EdgeInsets.all(16.0), + child: ConstrainedBox( + constraints: const BoxConstraints( + maxWidth: FluffyThemes.columnWidth, + ), + child: ListView( + shrinkWrap: true, + children: [ + Center( + child: Image.asset('assets/info-logo.png', width: 256), ), - ), - TextField( - controller: _textEditingController, - textInputAction: TextInputAction.done, - keyboardType: TextInputType.number, - obscureText: true, - autofocus: true, - textAlign: TextAlign.center, - readOnly: _inputBlocked, - onChanged: tryUnlock, - onSubmitted: tryUnlock, - style: const TextStyle(fontSize: 40), - inputFormatters: [ - LengthLimitingTextInputFormatter(4), - ], - decoration: InputDecoration( - errorText: _errorText, - hintText: '****', - suffix: IconButton( - icon: const Icon(Icons.lock_open_outlined), - onPressed: () => tryUnlock(_textEditingController.text), + TextField( + controller: _textEditingController, + textInputAction: TextInputAction.done, + keyboardType: TextInputType.number, + obscureText: true, + autofocus: true, + textAlign: TextAlign.center, + readOnly: _inputBlocked, + onChanged: tryUnlock, + onSubmitted: tryUnlock, + style: const TextStyle(fontSize: 40), + inputFormatters: [LengthLimitingTextInputFormatter(4)], + decoration: InputDecoration( + errorText: _errorText, + hintText: '****', + suffix: IconButton( + icon: const Icon(Icons.lock_open_outlined), + onPressed: () => tryUnlock(_textEditingController.text), + ), ), ), - ), - if (_inputBlocked) - const Padding( - padding: EdgeInsets.all(8.0), - child: LinearProgressIndicator(), - ), - ], + if (_inputBlocked) + const Padding( + padding: EdgeInsets.all(8.0), + child: LinearProgressIndicator(), + ), + ], + ), ), ), ), diff --git a/lib/widgets/log_view.dart b/lib/widgets/log_view.dart index 6e5e31882..9d34ddf21 100644 --- a/lib/widgets/log_view.dart +++ b/lib/widgets/log_view.dart @@ -15,17 +15,14 @@ class LogViewerState extends State { double fontSize = 14; @override Widget build(BuildContext context) { - final outputEvents = Logs() - .outputEvents + final outputEvents = Logs().outputEvents .where((e) => e.level.index <= logLevel.index) .toList(); return Scaffold( backgroundColor: Colors.black, appBar: AppBar( title: Text(logLevel.toString()), - leading: BackButton( - onPressed: () => context.go('/'), - ), + leading: BackButton(onPressed: () => context.go('/')), actions: [ IconButton( icon: const Icon(Icons.zoom_in_outlined), @@ -36,6 +33,7 @@ class LogViewerState extends State { onPressed: () => setState(() => fontSize--), ), PopupMenuButton( + useRootNavigator: true, itemBuilder: (context) => Level.values .map( (level) => PopupMenuItem( @@ -54,9 +52,7 @@ class LogViewerState extends State { scrollDirection: Axis.horizontal, child: SelectableText( outputEvents[i].toDisplayString(), - style: TextStyle( - color: outputEvents[i].color, - ), + style: TextStyle(color: outputEvents[i].color), ), ), ), @@ -78,7 +74,6 @@ extension on LogEvent { case Level.debug: return Colors.white; case Level.verbose: - default: return Colors.grey; } } @@ -86,10 +81,10 @@ extension on LogEvent { String toDisplayString() { var str = '# [${level.toString().split('.').last.toUpperCase()}] $title'; if (exception != null) { - str += ' - ${exception.toString()}'; + str += ' - $exception'; } if (stackTrace != null) { - str += '\n${stackTrace.toString()}'; + str += '\n$stackTrace'; } return str; } diff --git a/lib/widgets/matrix.dart b/lib/widgets/matrix.dart index 4de23a2f5..60fd73b77 100644 --- a/lib/widgets/matrix.dart +++ b/lib/widgets/matrix.dart @@ -4,14 +4,11 @@ import 'dart:convert'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; import 'package:collection/collection.dart'; import 'package:desktop_notifications/desktop_notifications.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:http/http.dart' as http; import 'package:image_picker/image_picker.dart'; import 'package:intl/intl.dart'; +import 'package:just_audio/just_audio.dart'; import 'package:matrix/encryption.dart'; import 'package:matrix/matrix.dart'; import 'package:provider/provider.dart'; @@ -19,23 +16,22 @@ import 'package:shared_preferences/shared_preferences.dart'; import 'package:universal_html/html.dart' as html; import 'package:url_launcher/url_launcher_string.dart'; +import 'package:fluffychat/l10n/l10n.dart'; import 'package:fluffychat/utils/client_manager.dart'; import 'package:fluffychat/utils/init_with_restore.dart'; -import 'package:fluffychat/utils/localized_exception_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_file_extension.dart'; import 'package:fluffychat/utils/platform_infos.dart'; import 'package:fluffychat/utils/uia_request_manager.dart'; import 'package:fluffychat/utils/voip_plugin.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; import 'package:fluffychat/widgets/fluffy_chat_app.dart'; -import '../config/app_config.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; import '../config/setting_keys.dart'; import '../pages/key_verification/key_verification_dialog.dart'; import '../utils/account_bundles.dart'; import '../utils/background_push.dart'; import 'local_notifications_extension.dart'; -// import 'package:flutter_secure_storage/flutter_secure_storage.dart'; - class Matrix extends StatefulWidget { final Widget? child; @@ -74,9 +70,6 @@ class MatrixState extends State with WidgetsBindingObserver { BackgroundPush? backgroundPush; Client get client { - if (widget.clients.isEmpty) { - widget.clients.add(getLoginClient()); - } if (_activeClient < 0 || _activeClient >= widget.clients.length) { return currentBundle!.first!; } @@ -125,10 +118,7 @@ class MatrixState extends State with WidgetsBindingObserver { } resBundles[bundle.name] ??= []; resBundles[bundle.name]!.add( - _AccountBundleWithClient( - client: widget.clients[i], - bundle: bundle, - ), + _AccountBundleWithClient(client: widget.clients[i], bundle: bundle), ); } } @@ -137,65 +127,58 @@ class MatrixState extends State with WidgetsBindingObserver { (a, b) => a.bundle!.priority == null ? 1 : b.bundle!.priority == null - ? -1 - : a.bundle!.priority!.compareTo(b.bundle!.priority!), + ? -1 + : a.bundle!.priority!.compareTo(b.bundle!.priority!), ); } - return resBundles - .map((k, v) => MapEntry(k, v.map((vv) => vv.client).toList())); + return resBundles.map( + (k, v) => MapEntry(k, v.map((vv) => vv.client).toList()), + ); } bool get hasComplexBundles => accountBundles.values.any((v) => v.length > 1); Client? _loginClientCandidate; - Client getLoginClient() { + AudioPlayer? audioPlayer; + final ValueNotifier voiceMessageEventId = ValueNotifier(null); + + Future getLoginClient() async { if (widget.clients.isNotEmpty && !client.isLogged()) { return client; } - final candidate = _loginClientCandidate ??= ClientManager.createClient( - '${AppConfig.applicationName}-${DateTime.now().millisecondsSinceEpoch}', - )..onLoginStateChanged - .stream - .where((l) => l == LoginState.loggedIn) - .first - .then((_) { - if (!widget.clients.contains(_loginClientCandidate)) { - widget.clients.add(_loginClientCandidate!); - } - ClientManager.addClientNameToStore( - _loginClientCandidate!.clientName, - store, - ); - _registerSubs(_loginClientCandidate!.clientName); - _loginClientCandidate = null; - FluffyChatApp.router.go('/rooms'); - }); + final candidate = _loginClientCandidate ??= + await ClientManager.createClient( + '${AppSettings.applicationName.value}-${DateTime.now().millisecondsSinceEpoch}', + store, + ) + ..onLoginStateChanged.stream + .where((l) => l == LoginState.loggedIn) + .first + .then((_) { + if (!widget.clients.contains(_loginClientCandidate)) { + widget.clients.add(_loginClientCandidate!); + } + ClientManager.addClientNameToStore( + _loginClientCandidate!.clientName, + store, + ); + _registerSubs(_loginClientCandidate!.clientName); + _loginClientCandidate = null; + FluffyChatApp.router.go('/backup'); + }); + if (widget.clients.isEmpty) widget.clients.add(candidate); return candidate; } Client? getClientByName(String name) => widget.clients.firstWhereOrNull((c) => c.clientName == name); - Map? get shareContent => _shareContent; - - set shareContent(Map? content) { - _shareContent = content; - onShareContentChanged.add(_shareContent); - } - - Map? _shareContent; - - final StreamController?> onShareContentChanged = - StreamController.broadcast(); - final onRoomKeyRequestSub = {}; final onKeyVerificationRequestSub = {}; final onNotification = {}; - final onLoginStateChanged = >{}; + final onLogoutSub = >{}; final onUiaRequest = >{}; - StreamSubscription? onFocusSub; - StreamSubscription? onBlurSub; String? _cachedPassword; Timer? _cachedPasswordClearTimer; @@ -212,16 +195,15 @@ class MatrixState extends State with WidgetsBindingObserver { }); } - bool webHasFocus = true; - String? get activeRoomId { final route = FluffyChatApp.router.routeInformationProvider.value.uri.path; if (!route.startsWith('/rooms/')) return null; return route.split('/')[2]; } - final linuxNotifications = - PlatformInfos.isLinux ? NotificationsClient() : null; + final linuxNotifications = PlatformInfos.isLinux + ? NotificationsClient() + : null; final Map linuxNotificationIds = {}; @override @@ -229,34 +211,6 @@ class MatrixState extends State with WidgetsBindingObserver { super.initState(); WidgetsBinding.instance.addObserver(this); initMatrix(); - if (PlatformInfos.isWeb) { - initConfig().then((_) => initSettings()); - } else { - initSettings(); - } - initLoadingDialog(); - } - - void initLoadingDialog() { - WidgetsBinding.instance.addPostFrameCallback((_) { - LoadingDialog.defaultTitle = L10n.of(context)!.loadingPleaseWait; - LoadingDialog.defaultBackLabel = L10n.of(context)!.close; - LoadingDialog.defaultOnError = - (e) => (e as Object?)!.toLocalizedString(context); - }); - } - - Future initConfig() async { - try { - final configJsonString = - utf8.decode((await http.get(Uri.parse('config.json'))).bodyBytes); - final configJson = json.decode(configJsonString); - AppConfig.loadFromJson(configJson); - } on FormatException catch (_) { - Logs().v('[ConfigLoader] config.json not found'); - } catch (e) { - Logs().v('[ConfigLoader] config.json not found', e); - } } void _registerSubs(String name) { @@ -267,8 +221,9 @@ class MatrixState extends State with WidgetsBindingObserver { ); return; } - onRoomKeyRequestSub[name] ??= - c.onRoomKeyRequest.stream.listen((RoomKeyRequest request) async { + onRoomKeyRequestSub[name] ??= c.onRoomKeyRequest.stream.listen(( + RoomKeyRequest request, + ) async { if (widget.clients.any( ((cl) => cl.userID == request.requestingDevice.userId && @@ -282,55 +237,54 @@ class MatrixState extends State with WidgetsBindingObserver { }); onKeyVerificationRequestSub[name] ??= c.onKeyVerificationRequest.stream .listen((KeyVerification request) async { - var hidPopup = false; - request.onUpdate = () { - if (!hidPopup && - {KeyVerificationState.done, KeyVerificationState.error} - .contains(request.state)) { - Navigator.of(context).pop('dialog'); - } - hidPopup = true; - }; - request.onUpdate = null; - hidPopup = true; - await KeyVerificationDialog(request: request).show(context); - }); - onLoginStateChanged[name] ??= c.onLoginStateChanged.stream.listen((state) { - final loggedInWithMultipleClients = widget.clients.length > 1; - if (state == LoginState.loggedOut) { - InitWithRestoreExtension.deleteSessionBackup(name); - } - if (loggedInWithMultipleClients && state != LoginState.loggedIn) { - _cancelSubs(c.clientName); - widget.clients.remove(c); - ClientManager.removeClientNameFromStore(c.clientName, store); - ScaffoldMessenger.of(context).showSnackBar( - SnackBar( - content: Text(L10n.of(context)!.oneClientLoggedOut), - ), - ); + var hidPopup = false; + request.onUpdate = () { + if (!hidPopup && + { + KeyVerificationState.done, + KeyVerificationState.error, + }.contains(request.state)) { + FluffyChatApp.router.pop('dialog'); + } + hidPopup = true; + }; + request.onUpdate = null; + hidPopup = true; + await KeyVerificationDialog(request: request).show( + FluffyChatApp.router.routerDelegate.navigatorKey.currentContext ?? + context, + ); + }); + onLogoutSub[name] ??= c.onLoginStateChanged.stream + .where((state) => state == LoginState.loggedOut) + .listen((state) { + final loggedInWithMultipleClients = widget.clients.length > 1; - if (state != LoginState.loggedIn) { - FluffyChatApp.router.go('/rooms'); - } - } else { - FluffyChatApp.router - .go(state == LoginState.loggedIn ? '/rooms' : '/home'); - } - }); + _cancelSubs(c.clientName); + widget.clients.remove(c); + ClientManager.removeClientNameFromStore(c.clientName, store); + InitWithRestoreExtension.deleteSessionBackup(name); + + if (loggedInWithMultipleClients) { + ScaffoldMessenger.of( + FluffyChatApp.router.routerDelegate.navigatorKey.currentContext ?? + context, + ).showSnackBar( + SnackBar(content: Text(L10n.of(context).oneClientLoggedOut)), + ); + + if (state != LoginState.loggedIn) { + FluffyChatApp.router.go('/rooms'); + } + } + }); onUiaRequest[name] ??= c.onUiaRequest.stream.listen(uiaRequestHandler); if (PlatformInfos.isWeb || PlatformInfos.isLinux) { c.onSync.stream.first.then((s) { html.Notification.requestPermission(); - onNotification[name] ??= c.onEvent.stream - .where( - (e) => - e.type == EventUpdateType.timeline && - [EventTypes.Message, EventTypes.Sticker, EventTypes.Encrypted] - .contains(e.content['type']) && - e.content['sender'] != c.userID, - ) - .listen(showLocalNotification); + onNotification[name] ??= c.onNotification.stream.listen( + showLocalNotification, + ); }); } } @@ -340,8 +294,8 @@ class MatrixState extends State with WidgetsBindingObserver { onRoomKeyRequestSub.remove(name); onKeyVerificationRequestSub[name]?.cancel(); onKeyVerificationRequestSub.remove(name); - onLoginStateChanged[name]?.cancel(); - onLoginStateChanged.remove(name); + onLogoutSub[name]?.cancel(); + onLogoutSub.remove(name); onNotification[name]?.cancel(); onNotification.remove(name); } @@ -351,25 +305,24 @@ class MatrixState extends State with WidgetsBindingObserver { _registerSubs(c.clientName); } - if (kIsWeb) { - onFocusSub = html.window.onFocus.listen((_) => webHasFocus = true); - onBlurSub = html.window.onBlur.listen((_) => webHasFocus = false); - } - if (PlatformInfos.isMobile) { backgroundPush = BackgroundPush( this, onFcmError: (errorMsg, {Uri? link}) async { final result = await showOkCancelAlertDialog( - barrierDismissible: true, - context: context, - title: L10n.of(context)!.pushNotificationsNotAvailable, + context: + FluffyChatApp + .router + .routerDelegate + .navigatorKey + .currentContext ?? + context, + title: L10n.of(context).pushNotificationsNotAvailable, message: errorMsg, - fullyCapitalizedForMaterial: false, okLabel: link == null - ? L10n.of(context)!.ok - : L10n.of(context)!.learnMore, - cancelLabel: L10n.of(context)!.doNotShowAgain, + ? L10n.of(context).ok + : L10n.of(context).learnMore, + cancelLabel: L10n.of(context).doNotShowAgain, ); if (result == OkCancelResult.ok && link != null) { launchUrlString( @@ -378,7 +331,7 @@ class MatrixState extends State with WidgetsBindingObserver { ); } if (result == OkCancelResult.cancel) { - await store.setBool(SettingKeys.showNoGoogle, true); + await AppSettings.showNoGoogle.setItem(true); } }, ); @@ -387,8 +340,8 @@ class MatrixState extends State with WidgetsBindingObserver { createVoipPlugin(); } - void createVoipPlugin() async { - if (store.getBool(SettingKeys.experimentalVoip) == false) { + Future createVoipPlugin() async { + if (AppSettings.experimentalVoip.value) { voipPlugin = null; return; } @@ -397,78 +350,30 @@ class MatrixState extends State with WidgetsBindingObserver { @override void didChangeAppLifecycleState(AppLifecycleState state) { - Logs().v('AppLifecycleState = $state'); - final foreground = state != AppLifecycleState.inactive && + final foreground = + state != AppLifecycleState.inactive && state != AppLifecycleState.paused; - client.syncPresence = - state == AppLifecycleState.resumed ? null : PresenceType.unavailable; - if (PlatformInfos.isMobile) { - client.backgroundSync = foreground; - client.requestHistoryOnLimitedTimeline = !foreground; - Logs().v('Set background sync to', foreground); + for (final client in widget.clients) { + client.syncPresence = state == AppLifecycleState.resumed + ? null + : PresenceType.unavailable; + if (PlatformInfos.isMobile) { + client.backgroundSync = foreground; + client.requestHistoryOnLimitedTimeline = !foreground; + Logs().v('Set background sync to', foreground); + } } } - void initSettings() { - AppConfig.fontSizeFactor = - double.tryParse(store.getString(SettingKeys.fontSizeFactor) ?? '') ?? - AppConfig.fontSizeFactor; - - AppConfig.renderHtml = - store.getBool(SettingKeys.renderHtml) ?? AppConfig.renderHtml; - - AppConfig.swipeRightToLeftToReply = - store.getBool(SettingKeys.swipeRightToLeftToReply) ?? - AppConfig.swipeRightToLeftToReply; - - AppConfig.hideRedactedEvents = - store.getBool(SettingKeys.hideRedactedEvents) ?? - AppConfig.hideRedactedEvents; - - AppConfig.hideUnknownEvents = - store.getBool(SettingKeys.hideUnknownEvents) ?? - AppConfig.hideUnknownEvents; - - AppConfig.hideUnimportantStateEvents = - store.getBool(SettingKeys.hideUnimportantStateEvents) ?? - AppConfig.hideUnimportantStateEvents; - - AppConfig.separateChatTypes = - store.getBool(SettingKeys.separateChatTypes) ?? - AppConfig.separateChatTypes; - - AppConfig.autoplayImages = - store.getBool(SettingKeys.autoplayImages) ?? AppConfig.autoplayImages; - - AppConfig.sendTypingNotifications = - store.getBool(SettingKeys.sendTypingNotifications) ?? - AppConfig.sendTypingNotifications; - - AppConfig.sendPublicReadReceipts = - store.getBool(SettingKeys.sendPublicReadReceipts) ?? - AppConfig.sendPublicReadReceipts; - - AppConfig.sendOnEnter = - store.getBool(SettingKeys.sendOnEnter) ?? AppConfig.sendOnEnter; - - AppConfig.experimentalVoip = store.getBool(SettingKeys.experimentalVoip) ?? - AppConfig.experimentalVoip; - - AppConfig.showPresences = - store.getBool(SettingKeys.showPresences) ?? AppConfig.showPresences; - } - @override void dispose() { WidgetsBinding.instance.removeObserver(this); onRoomKeyRequestSub.values.map((s) => s.cancel()); onKeyVerificationRequestSub.values.map((s) => s.cancel()); - onLoginStateChanged.values.map((s) => s.cancel()); + onLogoutSub.values.map((s) => s.cancel()); onNotification.values.map((s) => s.cancel()); client.httpClient.close(); - onFocusSub?.cancel(); - onBlurSub?.cancel(); linuxNotifications?.close(); @@ -477,18 +382,15 @@ class MatrixState extends State with WidgetsBindingObserver { @override Widget build(BuildContext context) { - return Provider( - create: (_) => this, - child: widget.child, - ); + return Provider(create: (_) => this, child: widget.child); } - Future dehydrateAction() async { + Future dehydrateAction(BuildContext context) async { final response = await showOkCancelAlertDialog( context: context, - isDestructiveAction: true, - title: L10n.of(context)!.dehydrate, - message: L10n.of(context)!.dehydrateWarning, + isDestructive: true, + title: L10n.of(context).dehydrate, + message: L10n.of(context).dehydrateWarning, ); if (response != OkCancelResult.ok) { return; @@ -500,9 +402,7 @@ class MatrixState extends State with WidgetsBindingObserver { final export = result.result; if (export == null) return; - final exportBytes = Uint8List.fromList( - const Utf8Codec().encode(export), - ); + final exportBytes = Uint8List.fromList(const Utf8Codec().encode(export)); final exportFileName = 'fluffychat-export-${DateFormat(DateFormat.YEAR_MONTH_DAY).format(DateTime.now())}.fluffybackup'; diff --git a/lib/widgets/member_actions_popup_menu_button.dart b/lib/widgets/member_actions_popup_menu_button.dart new file mode 100644 index 000000000..26a1bb209 --- /dev/null +++ b/lib/widgets/member_actions_popup_menu_button.dart @@ -0,0 +1,366 @@ +import 'package:flutter/material.dart'; + +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/permission_slider_dialog.dart'; +import 'adaptive_dialogs/show_ok_cancel_alert_dialog.dart'; +import 'adaptive_dialogs/show_text_input_dialog.dart'; +import 'adaptive_dialogs/user_dialog.dart'; +import 'avatar.dart'; +import 'future_loading_dialog.dart'; + +Future showMemberActionsPopupMenu({ + required BuildContext context, + required User user, + void Function()? onMention, +}) async { + final theme = Theme.of(context); + final displayname = user.calcDisplayname(); + final isMe = user.room.client.userID == user.id; + + final overlay = Overlay.of(context).context.findRenderObject() as RenderBox; + + final button = context.findRenderObject() as RenderBox; + + final position = RelativeRect.fromRect( + Rect.fromPoints( + button.localToGlobal(const Offset(0, -65), ancestor: overlay), + button.localToGlobal( + button.size.bottomRight(Offset.zero) + const Offset(-50, 0), + ancestor: overlay, + ), + ), + Offset.zero & overlay.size, + ); + + const defaultPowerLevels = {0, 50, 100, 9007199254740991}; + + final action = await showMenu<_MemberActions>( + context: context, + position: position, + items: >[ + PopupMenuItem( + value: _MemberActions.info, + child: Row( + spacing: 12.0, + children: [ + Avatar(name: displayname, size: 30, mxContent: user.avatarUrl), + ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 200), + child: Text( + displayname, + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + ), + ], + ), + ), + if (onMention != null) + PopupMenuItem( + value: _MemberActions.mention, + child: Row( + children: [ + const Icon(Icons.alternate_email_outlined), + const SizedBox(width: 18), + Text(L10n.of(context).mention), + ], + ), + ), + if (user.membership == Membership.knock) + PopupMenuItem( + value: _MemberActions.approve, + child: Row( + children: [ + const Icon(Icons.how_to_reg_outlined), + const SizedBox(width: 18), + Text(L10n.of(context).approve), + ], + ), + ), + if (user.canChangeUserPowerLevel) ...[ + if (user.powerLevel < 100) + PopupMenuItem( + value: _MemberActions.makeAdmin, + child: Row( + children: [ + const Icon(Icons.admin_panel_settings_outlined), + const SizedBox(width: 18), + Text(L10n.of(context).makeAdmin), + ], + ), + ), + if (user.powerLevel < 50) + PopupMenuItem( + value: _MemberActions.makeModerator, + child: Row( + children: [ + const Icon(Icons.add_moderator_outlined), + const SizedBox(width: 18), + Text(L10n.of(context).makeModerator), + ], + ), + ), + if (user.powerLevel >= 100) + PopupMenuItem( + value: _MemberActions.removeAdmin, + child: Row( + children: [ + const Icon(Icons.remove_moderator_outlined), + const SizedBox(width: 18), + Text(L10n.of(context).removeAdminRights), + ], + ), + ) + else if (user.powerLevel >= 50) + PopupMenuItem( + value: _MemberActions.removeModerator, + child: Row( + children: [ + const Icon(Icons.remove_moderator_outlined), + const SizedBox(width: 18), + Text(L10n.of(context).removeModeratorRights), + ], + ), + ), + ], + if (user.canChangeUserPowerLevel || + !defaultPowerLevels.contains(user.powerLevel)) + PopupMenuItem( + value: _MemberActions.setPowerLevel, + enabled: user.canChangeUserPowerLevel, + child: Row( + children: [ + const Icon(Icons.manage_accounts_outlined), + const SizedBox(width: 18), + Text( + user.canChangeUserPowerLevel + ? L10n.of(context).setPowerLevel + : L10n.of(context).powerLevel, + ), + if (!defaultPowerLevels.contains(user.powerLevel)) + Text(' (${user.powerLevel})'), + ], + ), + ), + if (user.canKick) + PopupMenuItem( + value: _MemberActions.kick, + child: Row( + children: [ + Icon( + Icons.person_remove_outlined, + color: theme.colorScheme.onErrorContainer, + ), + const SizedBox(width: 18), + Text( + L10n.of(context).kickFromChat, + style: TextStyle(color: theme.colorScheme.onErrorContainer), + ), + ], + ), + ), + if (user.canBan && user.membership != Membership.ban) + PopupMenuItem( + value: _MemberActions.ban, + child: Row( + children: [ + Icon( + Icons.block_outlined, + color: theme.colorScheme.onErrorContainer, + ), + const SizedBox(width: 18), + Text( + L10n.of(context).banFromChat, + style: TextStyle(color: theme.colorScheme.onErrorContainer), + ), + ], + ), + ), + if (user.canBan && user.membership == Membership.ban) + PopupMenuItem( + value: _MemberActions.unban, + child: Row( + children: [ + const Icon(Icons.warning), + const SizedBox(width: 18), + Text(L10n.of(context).unbanFromChat), + ], + ), + ), + if (!isMe) + PopupMenuItem( + value: _MemberActions.report, + child: Row( + children: [ + Icon( + Icons.gavel_outlined, + color: theme.colorScheme.onErrorContainer, + ), + const SizedBox(width: 18), + Text( + L10n.of(context).reportUser, + style: TextStyle(color: theme.colorScheme.onErrorContainer), + ), + ], + ), + ), + ], + ); + if (action == null) return; + if (!context.mounted) return; + + switch (action) { + case _MemberActions.mention: + onMention?.call(); + return; + case _MemberActions.setPowerLevel: + final power = await showPermissionChooser( + context, + currentLevel: user.powerLevel, + maxLevel: user.room.ownPowerLevel, + ); + if (power == null) return; + if (!context.mounted) return; + if (power >= 100) { + final consent = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + message: L10n.of(context).makeAdminDescription, + ); + if (consent != OkCancelResult.ok) return; + if (!context.mounted) return; + } + await showFutureLoadingDialog( + context: context, + future: () => user.setPower(power), + ); + return; + case _MemberActions.approve: + await showFutureLoadingDialog( + context: context, + future: () => user.room.invite(user.id), + ); + return; + case _MemberActions.kick: + if (await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).no, + message: L10n.of(context).kickUserDescription, + ) == + OkCancelResult.ok) { + await showFutureLoadingDialog( + context: context, + future: () => user.kick(), + ); + } + return; + case _MemberActions.ban: + if (await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).no, + message: L10n.of(context).banUserDescription, + ) == + OkCancelResult.ok) { + await showFutureLoadingDialog( + context: context, + future: () => user.ban(), + ); + } + return; + case _MemberActions.report: + final reason = await showTextInputDialog( + context: context, + title: L10n.of(context).whyDoYouWantToReportThis, + okLabel: L10n.of(context).report, + cancelLabel: L10n.of(context).cancel, + hintText: L10n.of(context).reason, + ); + if (reason == null || reason.isEmpty) return; + + final result = await showFutureLoadingDialog( + context: context, + future: () => user.room.client.reportUser(user.id, reason), + ); + if (result.error != null) return; + ScaffoldMessenger.of(context).showSnackBar( + SnackBar(content: Text(L10n.of(context).contentHasBeenReported)), + ); + return; + case _MemberActions.info: + await UserDialog.show( + context: context, + profile: Profile( + userId: user.id, + displayName: user.displayName, + avatarUrl: user.avatarUrl, + ), + ); + return; + case _MemberActions.unban: + if (await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + okLabel: L10n.of(context).yes, + cancelLabel: L10n.of(context).no, + message: L10n.of(context).unbanUserDescription, + ) == + OkCancelResult.ok) { + await showFutureLoadingDialog( + context: context, + future: () => user.unban(), + ); + } + case _MemberActions.makeAdmin: + if (user.room.ownPowerLevel <= 100) { + final consent = await showOkCancelAlertDialog( + context: context, + title: L10n.of(context).areYouSure, + message: L10n.of(context).makeAdminDescription, + ); + if (consent != OkCancelResult.ok) return; + if (!context.mounted) return; + } + await showFutureLoadingDialog( + context: context, + future: () => user.setPower(100), + ); + case _MemberActions.makeModerator: + await showFutureLoadingDialog( + context: context, + future: () => user.setPower(50), + ); + case _MemberActions.removeAdmin: + case _MemberActions.removeModerator: + final defaultUserLevel = + user.room + .getState(EventTypes.RoomPowerLevels) + ?.content + .tryGet('users_default') ?? + 0; + await showFutureLoadingDialog( + context: context, + future: () => user.setPower(defaultUserLevel), + ); + } +} + +enum _MemberActions { + info, + mention, + setPowerLevel, + makeAdmin, + makeModerator, + removeAdmin, + removeModerator, + kick, + ban, + approve, + unban, + report, +} diff --git a/lib/widgets/mxc_image.dart b/lib/widgets/mxc_image.dart index 9290156bf..a92338aa3 100644 --- a/lib/widgets/mxc_image.dart +++ b/lib/widgets/mxc_image.dart @@ -1,11 +1,13 @@ +import 'dart:io'; +import 'dart:math'; import 'dart:typed_data'; import 'package:flutter/material.dart'; -import 'package:http/http.dart' as http; import 'package:matrix/matrix.dart'; import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/utils/client_download_content_extension.dart'; import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_file_extension.dart'; import 'package:fluffychat/widgets/matrix.dart'; @@ -23,6 +25,8 @@ class MxcImage extends StatefulWidget { final ThumbnailMethod thumbnailMethod; final Widget Function(BuildContext context)? placeholder; final String? cacheKey; + final Client? client; + final BorderRadius borderRadius; const MxcImage({ this.uri, @@ -38,6 +42,8 @@ class MxcImage extends StatefulWidget { this.animationCurve = FluffyThemes.animationCurve, this.thumbnailMethod = ThumbnailMethod.scale, this.cacheKey, + this.client, + this.borderRadius = BorderRadius.zero, super.key, }); @@ -48,10 +54,10 @@ class MxcImage extends StatefulWidget { class _MxcImageState extends State { static final Map _imageDataCache = {}; Uint8List? _imageDataNoCache; - Uint8List? get _imageData { - final cacheKey = widget.cacheKey; - return cacheKey == null ? _imageDataNoCache : _imageDataCache[cacheKey]; - } + + Uint8List? get _imageData => widget.cacheKey == null + ? _imageDataNoCache + : _imageDataCache[widget.cacheKey]; set _imageData(Uint8List? data) { if (data == null) return; @@ -61,66 +67,39 @@ class _MxcImageState extends State { : _imageDataCache[cacheKey] = data; } - bool? _isCached; - Future _load() async { - final client = Matrix.of(context).client; + if (!mounted) return; + final client = + widget.client ?? widget.event?.room.client ?? Matrix.of(context).client; final uri = widget.uri; final event = widget.event; if (uri != null) { - final devicePixelRatio = MediaQuery.of(context).devicePixelRatio; + final devicePixelRatio = MediaQuery.devicePixelRatioOf(context); final width = widget.width; final realWidth = width == null ? null : width * devicePixelRatio; final height = widget.height; final realHeight = height == null ? null : height * devicePixelRatio; - final httpUri = widget.isThumbnail - ? uri.getThumbnail( - client, - width: realWidth, - height: realHeight, - animated: widget.animated, - method: widget.thumbnailMethod, - ) - : uri.getDownloadLink(client); - - final storeKey = widget.isThumbnail ? httpUri : uri; - - if (_isCached == null) { - final cachedData = await client.database?.getFile(storeKey); - if (cachedData != null) { - if (!mounted) return; - setState(() { - _imageData = cachedData; - _isCached = true; - }); - return; - } - _isCached = false; - } - - final response = await http.get(httpUri); - if (response.statusCode != 200) { - if (response.statusCode == 404) { - return; - } - throw Exception(); - } - final remoteData = response.bodyBytes; - + final remoteData = await client.downloadMxcCached( + uri, + width: realWidth, + height: realHeight, + thumbnailMethod: widget.thumbnailMethod, + isThumbnail: widget.isThumbnail, + animated: widget.animated, + ); if (!mounted) return; setState(() { _imageData = remoteData; }); - await client.database?.storeFile(storeKey, remoteData, 0); } if (event != null) { final data = await event.downloadAndDecryptAttachment( getThumbnail: widget.isThumbnail, ); - if (data.detectFileType is MatrixImageFile) { + if (data.detectFileType is MatrixImageFile || widget.isThumbnail) { if (!mounted) return; setState(() { _imageData = data.bytes; @@ -130,63 +109,88 @@ class _MxcImageState extends State { } } - void _tryLoad(_) async { + Future _tryLoad() async { if (_imageData != null) { return; } try { await _load(); - } catch (_) { + } on IOException catch (_) { if (!mounted) return; await Future.delayed(widget.retryDuration); - _tryLoad(_); + _tryLoad(); } } @override void initState() { super.initState(); - WidgetsBinding.instance.addPostFrameCallback(_tryLoad); + WidgetsBinding.instance.addPostFrameCallback((_) => _tryLoad()); } - Widget placeholder(BuildContext context) => - widget.placeholder?.call(context) ?? - Container( - width: widget.width, - height: widget.height, - alignment: Alignment.center, - child: const CircularProgressIndicator.adaptive(strokeWidth: 2), - ); - @override Widget build(BuildContext context) { final data = _imageData; final hasData = data != null && data.isNotEmpty; - return AnimatedCrossFade( - crossFadeState: - hasData ? CrossFadeState.showSecond : CrossFadeState.showFirst, + return AnimatedSwitcher( duration: FluffyThemes.animationDuration, - firstChild: placeholder(context), - secondChild: hasData - ? Image.memory( - data, - width: widget.width, - height: widget.height, - fit: widget.fit, - filterQuality: - widget.isThumbnail ? FilterQuality.low : FilterQuality.medium, - errorBuilder: (context, __, ___) { - _isCached = false; - _imageData = null; - WidgetsBinding.instance.addPostFrameCallback(_tryLoad); - return placeholder(context); - }, + child: hasData + ? ClipRRect( + borderRadius: widget.borderRadius, + child: Image.memory( + data, + width: widget.width, + height: widget.height, + fit: widget.fit, + filterQuality: widget.isThumbnail + ? FilterQuality.low + : FilterQuality.medium, + errorBuilder: (context, e, s) { + Logs().d('Unable to render mxc image', e, s); + return SizedBox( + width: widget.width, + height: widget.height, + child: Material( + color: Theme.of(context).colorScheme.surfaceContainer, + child: Icon( + Icons.broken_image_outlined, + size: min(widget.height ?? 64, 64), + color: Theme.of(context).colorScheme.onSurface, + ), + ), + ); + }, + ), ) - : SizedBox( + : _MxcImagePlaceholder( width: widget.width, height: widget.height, + placeholder: widget.placeholder, ), ); } } + +class _MxcImagePlaceholder extends StatelessWidget { + final double? width; + final double? height; + final Widget Function(BuildContext context)? placeholder; + + const _MxcImagePlaceholder({ + required this.width, + required this.height, + required this.placeholder, + }); + + @override + Widget build(BuildContext context) { + return placeholder?.call(context) ?? + Container( + width: width, + height: height, + alignment: Alignment.center, + child: const CircularProgressIndicator.adaptive(strokeWidth: 2), + ); + } +} diff --git a/lib/widgets/mxc_image_viewer.dart b/lib/widgets/mxc_image_viewer.dart new file mode 100644 index 000000000..be075d79b --- /dev/null +++ b/lib/widgets/mxc_image_viewer.dart @@ -0,0 +1,59 @@ +import 'package:flutter/material.dart'; + +import 'package:fluffychat/l10n/l10n.dart'; +import 'mxc_image.dart'; + +class MxcImageViewer extends StatelessWidget { + final Uri mxContent; + + const MxcImageViewer(this.mxContent, {super.key}); + + @override + Widget build(BuildContext context) { + final iconButtonStyle = IconButton.styleFrom( + backgroundColor: Colors.black.withAlpha(200), + foregroundColor: Colors.white, + ); + return GestureDetector( + onTap: () => Navigator.of(context).pop(), + child: Scaffold( + backgroundColor: Colors.black.withAlpha(128), + extendBodyBehindAppBar: true, + appBar: AppBar( + elevation: 0, + leading: IconButton( + style: iconButtonStyle, + icon: const Icon(Icons.close), + onPressed: Navigator.of(context).pop, + color: Colors.white, + tooltip: L10n.of(context).close, + ), + backgroundColor: Colors.transparent, + ), + body: InteractiveViewer( + minScale: 1.0, + maxScale: 10.0, + onInteractionEnd: (endDetails) { + if (endDetails.velocity.pixelsPerSecond.dy > + MediaQuery.sizeOf(context).height * 1.5) { + Navigator.of(context, rootNavigator: false).pop(); + } + }, + child: Center( + child: GestureDetector( + // Ignore taps to not go back here: + onTap: () {}, + child: MxcImage( + key: ValueKey(mxContent.toString()), + uri: mxContent, + fit: BoxFit.contain, + isThumbnail: false, + animated: true, + ), + ), + ), + ), + ), + ); + } +} diff --git a/lib/widgets/navigation_rail.dart b/lib/widgets/navigation_rail.dart new file mode 100644 index 000000000..e9201bffb --- /dev/null +++ b/lib/widgets/navigation_rail.dart @@ -0,0 +1,129 @@ +import 'package:flutter/material.dart'; + +import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/pages/chat_list/navi_rail_item.dart'; +import 'package:fluffychat/pages/chat_list/start_chat_fab.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/utils/stream_extension.dart'; +import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +class SpacesNavigationRail extends StatelessWidget { + final String? activeSpaceId; + final void Function() onGoToChats; + final void Function(String) onGoToSpaceId; + + const SpacesNavigationRail({ + required this.activeSpaceId, + required this.onGoToChats, + required this.onGoToSpaceId, + super.key, + }); + + @override + Widget build(BuildContext context) { + final client = Matrix.of(context).client; + return Material( + child: SafeArea( + child: StreamBuilder( + key: ValueKey(client.userID.toString()), + stream: client.onSync.stream + .where((s) => s.hasRoomUpdate) + .rateLimit(const Duration(seconds: 1)), + builder: (context, _) { + final allSpaces = client.rooms + .where((room) => room.isSpace) + .toList(); + + return SizedBox( + width: FluffyThemes.isColumnMode(context) + ? FluffyThemes.navRailWidth + : FluffyThemes.navRailWidth * 0.75, + child: Column( + children: [ + Expanded( + child: ListView.builder( + scrollDirection: Axis.vertical, + itemCount: allSpaces.length + 2, + itemBuilder: (context, i) { + if (i == 0) { + return NaviRailItem( + isSelected: activeSpaceId == null, + onTap: onGoToChats, + icon: const Padding( + padding: EdgeInsets.all(10.0), + child: Icon(Icons.forum_outlined), + ), + selectedIcon: const Padding( + padding: EdgeInsets.all(10.0), + child: Icon(Icons.forum), + ), + toolTip: L10n.of(context).chats, + unreadBadgeFilter: (room) => true, + ); + } + i--; + if (i == allSpaces.length) { + return NaviRailItem( + isSelected: false, + onTap: () => context.go('/rooms/newspace'), + icon: const Padding( + padding: EdgeInsets.all(8.0), + child: Icon(Icons.add), + ), + toolTip: L10n.of(context).createNewSpace, + ); + } + final space = allSpaces[i]; + final displayname = allSpaces[i] + .getLocalizedDisplayname( + MatrixLocals(L10n.of(context)), + ); + final spaceChildrenIds = space.spaceChildren + .map((c) => c.roomId) + .toSet(); + return NaviRailItem( + toolTip: displayname, + isSelected: activeSpaceId == space.id, + onTap: () => onGoToSpaceId(allSpaces[i].id), + unreadBadgeFilter: (room) => + spaceChildrenIds.contains(room.id), + icon: Avatar( + mxContent: allSpaces[i].avatar, + name: displayname, + shapeBorder: RoundedSuperellipseBorder( + side: BorderSide( + width: 1, + color: Theme.of(context).dividerColor, + ), + borderRadius: BorderRadius.circular( + AppConfig.spaceBorderRadius, + ), + ), + borderRadius: BorderRadius.circular( + AppConfig.spaceBorderRadius, + ), + ), + ); + }, + ), + ), + if (FluffyThemes.isColumnMode(context)) + Padding( + padding: const EdgeInsets.all(12.0), + child: StartChatFab(), + ), + ], + ), + ); + }, + ), + ), + ); + } +} diff --git a/lib/widgets/permission_slider_dialog.dart b/lib/widgets/permission_slider_dialog.dart index 1e883e123..1a0f2556d 100644 --- a/lib/widgets/permission_slider_dialog.dart +++ b/lib/widgets/permission_slider_dialog.dart @@ -1,34 +1,62 @@ -import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; -import 'package:adaptive_dialog/adaptive_dialog.dart'; -import 'package:flutter_gen/gen_l10n/l10n.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/adaptive_dialog_action.dart'; +import 'package:fluffychat/widgets/adaptive_dialogs/dialog_text_field.dart'; Future showPermissionChooser( BuildContext context, { int currentLevel = 0, + int maxLevel = 100, }) async { - final customLevel = await showTextInputDialog( + final controller = TextEditingController(text: currentLevel.toString()); + final error = ValueNotifier(null); + return await showAdaptiveDialog( context: context, - title: L10n.of(context)!.setPermissionsLevel, - textFields: [ - DialogTextField( - initialText: currentLevel.toString(), - keyboardType: TextInputType.number, - autocorrect: false, - validator: (text) { - if (text == null) { - return L10n.of(context)!.pleaseEnterANumber; - } - final level = int.tryParse(text); - if (level == null) { - return L10n.of(context)!.pleaseEnterANumber; - } - return null; - }, + builder: (context) => AlertDialog.adaptive( + title: Center(child: Text(L10n.of(context).chatPermissions)), + content: ConstrainedBox( + constraints: const BoxConstraints(maxWidth: 256, maxHeight: 256), + child: Column( + mainAxisSize: .min, + crossAxisAlignment: .stretch, + spacing: 12.0, + children: [ + Text(L10n.of(context).setPowerLevelDescription), + ValueListenableBuilder( + valueListenable: error, + builder: (context, errorText, _) => DialogTextField( + controller: controller, + hintText: currentLevel.toString(), + keyboardType: TextInputType.number, + labelText: L10n.of(context).custom, + errorText: errorText, + ), + ), + ], + ), ), - ], + actions: [ + AdaptiveDialogAction( + onPressed: () { + final level = int.tryParse(controller.text.trim()); + if (level == null) { + error.value = L10n.of(context).pleaseEnterANumber; + return; + } + if (level > maxLevel) { + error.value = L10n.of(context).noPermission; + return; + } + Navigator.of(context).pop(level); + }, + child: Text(L10n.of(context).setPowerLevel), + ), + AdaptiveDialogAction( + onPressed: () => Navigator.of(context).pop(null), + child: Text(L10n.of(context).cancel), + ), + ], + ), ); - if (customLevel == null) return null; - return int.tryParse(customLevel.first); } diff --git a/lib/widgets/presence_builder.dart b/lib/widgets/presence_builder.dart index 2ca963c84..33f5b0546 100644 --- a/lib/widgets/presence_builder.dart +++ b/lib/widgets/presence_builder.dart @@ -1,10 +1,12 @@ +import 'dart:async'; + import 'package:flutter/material.dart'; import 'package:matrix/matrix.dart'; import 'package:fluffychat/widgets/matrix.dart'; -class PresenceBuilder extends StatelessWidget { +class PresenceBuilder extends StatefulWidget { final Widget Function(BuildContext context, CachedPresence? presence) builder; final String? userId; final Client? client; @@ -17,21 +19,39 @@ class PresenceBuilder extends StatelessWidget { }); @override - Widget build(BuildContext context) { - final userId = this.userId; - if (userId == null) return builder(context, null); - - final client = this.client ?? Matrix.of(context).client; - return FutureBuilder( - future: client.fetchCurrentPresence(userId), - builder: (context, cachedPresenceSnapshot) => StreamBuilder( - stream: client.onPresenceChanged.stream - .where((cachedPresence) => cachedPresence.userid == userId), - builder: (context, snapshot) => builder( - context, - snapshot.data ?? cachedPresenceSnapshot.data, - ), - ), - ); - } + State createState() => _PresenceBuilderState(); +} + +class _PresenceBuilderState extends State { + CachedPresence? _presence; + StreamSubscription? _sub; + + void _updatePresence(CachedPresence? presence) { + if (!mounted) return; + setState(() { + _presence = presence; + }); + } + + @override + void initState() { + super.initState(); + final client = widget.client ?? Matrix.of(context).client; + final userId = widget.userId; + if (userId != null) { + client.fetchCurrentPresence(userId).then(_updatePresence); + _sub = client.onPresenceChanged.stream + .where((presence) => presence.userid == userId) + .listen(_updatePresence); + } + } + + @override + void dispose() { + _sub?.cancel(); + super.dispose(); + } + + @override + Widget build(BuildContext context) => widget.builder(context, _presence); } diff --git a/lib/widgets/public_room_bottom_sheet.dart b/lib/widgets/public_room_bottom_sheet.dart deleted file mode 100644 index 8bd354ef5..000000000 --- a/lib/widgets/public_room_bottom_sheet.dart +++ /dev/null @@ -1,208 +0,0 @@ -import 'package:flutter/material.dart'; - -import 'package:flutter_gen/gen_l10n/l10n.dart'; -import 'package:flutter_linkify/flutter_linkify.dart'; -import 'package:future_loading_dialog/future_loading_dialog.dart'; -import 'package:go_router/go_router.dart'; -import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/utils/fluffy_share.dart'; -import 'package:fluffychat/utils/url_launcher.dart'; -import 'package:fluffychat/widgets/avatar.dart'; -import 'package:fluffychat/widgets/matrix.dart'; -import '../utils/localized_exception_extension.dart'; - -class PublicRoomBottomSheet extends StatelessWidget { - final String? roomAlias; - final BuildContext outerContext; - final PublicRoomsChunk? chunk; - final VoidCallback? onRoomJoined; - - PublicRoomBottomSheet({ - this.roomAlias, - required this.outerContext, - this.chunk, - this.onRoomJoined, - super.key, - }) { - assert(roomAlias != null || chunk != null); - } - - void _joinRoom(BuildContext context) async { - final client = Matrix.of(outerContext).client; - final chunk = this.chunk; - final knock = chunk?.joinRule == 'knock'; - final result = await showFutureLoadingDialog( - context: context, - future: () async { - if (chunk != null && client.getRoomById(chunk.roomId) != null) { - return chunk.roomId; - } - final roomId = chunk != null && knock - ? await client.knockRoom(chunk.roomId) - : await client.joinRoom(roomAlias ?? chunk!.roomId); - - if (!knock && client.getRoomById(roomId) == null) { - await client.waitForRoomInSync(roomId); - } - return roomId; - }, - ); - if (knock) { - return; - } - if (result.error == null) { - Navigator.of(context).pop(); - // don't open the room if the joined room is a space - if (chunk?.roomType != 'm.space' && - !client.getRoomById(result.result!)!.isSpace) { - outerContext.go('/rooms/${result.result!}'); - } - return; - } - } - - bool _testRoom(PublicRoomsChunk r) => r.canonicalAlias == roomAlias; - - Future _search(BuildContext context) async { - final chunk = this.chunk; - if (chunk != null) return chunk; - final query = await Matrix.of(context).client.queryPublicRooms( - server: roomAlias!.domain, - filter: PublicRoomQueryFilter( - genericSearchTerm: roomAlias, - ), - ); - if (!query.chunk.any(_testRoom)) { - throw (L10n.of(context)!.noRoomsFound); - } - return query.chunk.firstWhere(_testRoom); - } - - @override - Widget build(BuildContext context) { - final roomAlias = this.roomAlias ?? chunk?.canonicalAlias; - return SafeArea( - child: Scaffold( - appBar: AppBar( - title: Text( - chunk?.name ?? roomAlias ?? chunk?.roomId ?? 'Unknown', - overflow: TextOverflow.fade, - ), - leading: IconButton( - icon: const Icon(Icons.arrow_downward_outlined), - onPressed: Navigator.of(context, rootNavigator: false).pop, - tooltip: L10n.of(context)!.close, - ), - actions: [ - Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0), - child: IconButton( - icon: Icon(Icons.adaptive.share_outlined), - onPressed: () => FluffyShare.share( - 'https://matrix.to/#/${roomAlias ?? chunk?.roomId}', - context, - ), - ), - ), - ], - ), - body: FutureBuilder( - future: _search(context), - builder: (context, snapshot) { - final profile = snapshot.data; - return ListView( - padding: EdgeInsets.zero, - children: [ - if (profile == null) - Container( - height: 156, - alignment: Alignment.center, - color: Theme.of(context).secondaryHeaderColor, - child: snapshot.hasError - ? Text(snapshot.error!.toLocalizedString(context)) - : const CircularProgressIndicator.adaptive( - strokeWidth: 2, - ), - ) - else - Center( - child: Padding( - padding: const EdgeInsets.all(16.0), - child: Avatar( - mxContent: profile.avatarUrl, - name: profile.name ?? roomAlias, - size: Avatar.defaultSize * 3, - ), - ), - ), - Padding( - padding: const EdgeInsets.symmetric(horizontal: 16.0), - child: ElevatedButton.icon( - onPressed: () => _joinRoom(context), - label: Text( - chunk?.joinRule == 'knock' && - Matrix.of(context) - .client - .getRoomById(chunk!.roomId) == - null - ? L10n.of(context)!.knock - : chunk?.roomType == 'm.space' - ? L10n.of(context)!.joinSpace - : L10n.of(context)!.joinRoom, - ), - icon: const Icon(Icons.login_outlined), - ), - ), - const SizedBox(height: 16), - ListTile( - title: Text( - profile?.name ?? - roomAlias?.localpart ?? - chunk?.roomId.localpart ?? - L10n.of(context)!.chat, - ), - subtitle: Text( - '${L10n.of(context)!.participant}: ${profile?.numJoinedMembers ?? 0}', - ), - trailing: const Icon(Icons.account_box_outlined), - ), - if (roomAlias != null) - ListTile( - title: Text(L10n.of(context)!.publicLink), - subtitle: SelectableText(roomAlias), - contentPadding: - const EdgeInsets.symmetric(horizontal: 16.0), - trailing: IconButton( - icon: const Icon(Icons.copy_outlined), - onPressed: () => FluffyShare.share( - roomAlias, - context, - ), - ), - ), - if (profile?.topic?.isNotEmpty ?? false) - ListTile( - subtitle: SelectableLinkify( - text: profile!.topic!, - linkStyle: const TextStyle( - color: Colors.blueAccent, - decorationColor: Colors.blueAccent, - ), - style: TextStyle( - fontSize: 14, - color: Theme.of(context).textTheme.bodyMedium!.color, - ), - options: const LinkifyOptions(humanize: false), - onOpen: (url) => - UrlLauncher(context, url.url).launchUrl(), - ), - ), - ], - ); - }, - ), - ), - ); - } -} diff --git a/lib/widgets/qr_code_viewer.dart b/lib/widgets/qr_code_viewer.dart new file mode 100644 index 000000000..ac87d9942 --- /dev/null +++ b/lib/widgets/qr_code_viewer.dart @@ -0,0 +1,129 @@ +import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; + +import 'package:image/image.dart'; +import 'package:matrix/matrix.dart'; +import 'package:pretty_qr_code/pretty_qr_code.dart'; +import 'package:qr_image/qr_image.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/fluffy_share.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_file_extension.dart'; +import 'package:fluffychat/widgets/future_loading_dialog.dart'; +import '../config/themes.dart'; + +Future showQrCodeViewer(BuildContext context, String content) => + showDialog( + context: context, + builder: (context) => QrCodeViewer(content: content), + ); + +class QrCodeViewer extends StatelessWidget { + final String content; + + const QrCodeViewer({required this.content, super.key}); + + Future _save(BuildContext context) async { + final imageResult = await showFutureLoadingDialog( + context: context, + future: () { + final inviteLink = 'https://matrix.to/#/$content'; + final image = QRImage(inviteLink, size: 256, radius: 1).generate(); + return compute(encodePng, image); + }, + ); + final bytes = imageResult.result; + if (bytes == null) return; + if (!context.mounted) return; + + MatrixImageFile( + bytes: bytes, + name: 'QR_Code_$content.png', + mimeType: 'image/png', + ).save(context); + } + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + final inviteLink = 'https://matrix.to/#/$content'; + return Scaffold( + backgroundColor: Colors.black.withAlpha(128), + extendBodyBehindAppBar: true, + appBar: AppBar( + elevation: 0, + leading: IconButton( + style: IconButton.styleFrom( + backgroundColor: Colors.black.withAlpha(128), + ), + icon: const Icon(Icons.close), + onPressed: Navigator.of(context).pop, + color: Colors.white, + tooltip: L10n.of(context).close, + ), + backgroundColor: Colors.transparent, + actions: [ + IconButton( + style: IconButton.styleFrom( + backgroundColor: Colors.black.withAlpha(128), + ), + icon: Icon(Icons.adaptive.share_outlined), + onPressed: () => FluffyShare.share(inviteLink, context), + color: Colors.white, + tooltip: L10n.of(context).share, + ), + const SizedBox(width: 8), + IconButton( + style: IconButton.styleFrom( + backgroundColor: Colors.black.withAlpha(128), + ), + icon: const Icon(Icons.download_outlined), + onPressed: () => _save(context), + color: Colors.white, + tooltip: L10n.of(context).downloadFile, + ), + const SizedBox(width: 8), + ], + ), + body: Center( + child: Container( + margin: const EdgeInsets.all(32.0), + padding: const EdgeInsets.all(32.0), + decoration: BoxDecoration( + color: theme.colorScheme.primaryContainer, + borderRadius: BorderRadius.circular(AppConfig.borderRadius), + ), + child: Column( + mainAxisSize: .min, + children: [ + ConstrainedBox( + constraints: const BoxConstraints( + maxWidth: FluffyThemes.columnWidth, + ), + child: PrettyQrView.data( + data: inviteLink, + decoration: PrettyQrDecoration( + shape: PrettyQrSmoothSymbol( + roundFactor: 1, + color: theme.colorScheme.onPrimaryContainer, + ), + ), + ), + ), + const SizedBox(height: 8.0), + SelectableText( + content, + textAlign: TextAlign.center, + style: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontSize: 12, + ), + ), + ], + ), + ), + ), + ); + } +} diff --git a/lib/widgets/settings_switch_list_tile.dart b/lib/widgets/settings_switch_list_tile.dart index f49b97598..f625f9e64 100644 --- a/lib/widgets/settings_switch_list_tile.dart +++ b/lib/widgets/settings_switch_list_tile.dart @@ -1,18 +1,16 @@ import 'package:flutter/material.dart'; -import 'matrix.dart'; +import 'package:fluffychat/config/setting_keys.dart'; class SettingsSwitchListTile extends StatefulWidget { - final bool defaultValue; - final String storeKey; + final AppSettings setting; final String title; final String? subtitle; final Function(bool)? onChanged; const SettingsSwitchListTile.adaptive({ super.key, - this.defaultValue = false, - required this.storeKey, + required this.setting, required this.title, this.subtitle, this.onChanged, @@ -27,13 +25,12 @@ class SettingsSwitchListTileState extends State { Widget build(BuildContext context) { final subtitle = widget.subtitle; return SwitchListTile.adaptive( - value: Matrix.of(context).store.getBool(widget.storeKey) ?? - widget.defaultValue, + value: widget.setting.value, title: Text(widget.title), subtitle: subtitle == null ? null : Text(subtitle), onChanged: (bool newValue) async { widget.onChanged?.call(newValue); - await Matrix.of(context).store.setBool(widget.storeKey, newValue); + await widget.setting.setItem(newValue); setState(() {}); }, ); diff --git a/lib/widgets/share_scaffold_dialog.dart b/lib/widgets/share_scaffold_dialog.dart new file mode 100644 index 000000000..2a23e050c --- /dev/null +++ b/lib/widgets/share_scaffold_dialog.dart @@ -0,0 +1,190 @@ +import 'package:flutter/material.dart'; + +import 'package:cross_file/cross_file.dart'; +import 'package:go_router/go_router.dart'; +import 'package:matrix/matrix.dart'; + +import 'package:fluffychat/config/app_config.dart'; +import 'package:fluffychat/config/themes.dart'; +import 'package:fluffychat/l10n/l10n.dart'; +import 'package:fluffychat/utils/matrix_sdk_extensions/matrix_locals.dart'; +import 'package:fluffychat/widgets/avatar.dart'; +import 'package:fluffychat/widgets/matrix.dart'; + +abstract class ShareItem {} + +class TextShareItem extends ShareItem { + final String value; + TextShareItem(this.value); +} + +class ContentShareItem extends ShareItem { + final Map value; + ContentShareItem(this.value); +} + +class FileShareItem extends ShareItem { + final XFile value; + FileShareItem(this.value); +} + +class ShareScaffoldDialog extends StatefulWidget { + final List items; + + const ShareScaffoldDialog({required this.items, super.key}); + + @override + State createState() => _ShareScaffoldDialogState(); +} + +class _ShareScaffoldDialogState extends State { + final TextEditingController _filterController = TextEditingController(); + + String? selectedRoomId; + + void _toggleRoom(String roomId) { + setState(() { + selectedRoomId = roomId; + }); + } + + Future _forwardAction() async { + final roomId = selectedRoomId; + if (roomId == null) { + throw Exception( + 'Started forward action before room was selected. This should never happen.', + ); + } + while (context.canPop()) { + context.pop(); + } + context.go('/rooms/$roomId', extra: widget.items); + } + + @override + Widget build(BuildContext context) { + final theme = Theme.of(context); + final rooms = Matrix.of(context).client.rooms + .where( + (room) => + room.canSendDefaultMessages && + !room.isSpace && + room.membership == Membership.join, + ) + .toList(); + final filter = _filterController.text.trim().toLowerCase(); + return Scaffold( + appBar: AppBar( + leading: Center(child: CloseButton(onPressed: context.pop)), + title: Text(L10n.of(context).share), + ), + body: CustomScrollView( + slivers: [ + SliverAppBar( + floating: true, + toolbarHeight: 72, + scrolledUnderElevation: 0, + backgroundColor: Colors.transparent, + automaticallyImplyLeading: false, + title: TextField( + controller: _filterController, + onChanged: (_) => setState(() {}), + textInputAction: TextInputAction.search, + decoration: InputDecoration( + filled: true, + fillColor: theme.colorScheme.secondaryContainer, + border: OutlineInputBorder( + borderSide: BorderSide.none, + borderRadius: BorderRadius.circular(99), + ), + contentPadding: EdgeInsets.zero, + hintText: L10n.of(context).search, + hintStyle: TextStyle( + color: theme.colorScheme.onPrimaryContainer, + fontWeight: FontWeight.normal, + ), + floatingLabelBehavior: FloatingLabelBehavior.never, + prefixIcon: IconButton( + onPressed: () {}, + icon: Icon( + Icons.search_outlined, + color: theme.colorScheme.onPrimaryContainer, + ), + ), + ), + ), + ), + SliverList.builder( + itemCount: rooms.length, + itemBuilder: (context, i) { + final room = rooms[i]; + final displayname = room.getLocalizedDisplayname( + MatrixLocals(L10n.of(context)), + ); + final value = selectedRoomId == room.id; + final filterOut = !displayname.toLowerCase().contains(filter); + if (!value && filterOut) { + return const SizedBox.shrink(); + } + return Padding( + padding: const EdgeInsets.symmetric(horizontal: 16.0), + child: Opacity( + opacity: filterOut ? 0.5 : 1, + child: CheckboxListTile.adaptive( + checkboxShape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular(90), + ), + controlAffinity: ListTileControlAffinity.trailing, + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular( + AppConfig.borderRadius, + ), + ), + secondary: Avatar( + mxContent: room.avatar, + name: displayname, + size: Avatar.defaultSize * 0.75, + ), + title: Text( + displayname, + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + subtitle: Text( + room.directChatMatrixID ?? + L10n.of(context).countParticipants( + (room.summary.mJoinedMemberCount ?? 0) + + (room.summary.mInvitedMemberCount ?? 0), + ), + maxLines: 1, + overflow: TextOverflow.ellipsis, + ), + value: selectedRoomId == room.id, + onChanged: (_) => _toggleRoom(room.id), + ), + ), + ); + }, + ), + ], + ), + bottomNavigationBar: AnimatedSize( + duration: FluffyThemes.animationDuration, + curve: FluffyThemes.animationCurve, + child: selectedRoomId == null + ? const SizedBox.shrink() + : Material( + elevation: 8, + shadowColor: theme.appBarTheme.shadowColor, + child: Padding( + padding: const EdgeInsets.all(16.0), + child: ElevatedButton( + onPressed: _forwardAction, + child: Text(L10n.of(context).forward), + ), + ), + ), + ), + ); + } +} diff --git a/lib/widgets/theme_builder.dart b/lib/widgets/theme_builder.dart index b35a0b449..77bda417e 100644 --- a/lib/widgets/theme_builder.dart +++ b/lib/widgets/theme_builder.dart @@ -5,12 +5,15 @@ import 'package:dynamic_color/dynamic_color.dart'; import 'package:provider/provider.dart'; import 'package:shared_preferences/shared_preferences.dart'; +import 'package:fluffychat/utils/color_value.dart'; + class ThemeBuilder extends StatefulWidget { final Widget Function( BuildContext context, ThemeMode themeMode, Color? primaryColor, - ) builder; + ) + builder; final String themeModeSettingsKey; final String primaryColorSettingsKey; @@ -36,28 +39,26 @@ class ThemeController extends State { Color? get primaryColor => _primaryColor; static ThemeController of(BuildContext context) => - Provider.of( - context, - listen: false, - ); + Provider.of(context, listen: false); - void _loadData(_) async { - final preferences = - _sharedPreferences ??= await SharedPreferences.getInstance(); + Future _loadData(_) async { + final preferences = _sharedPreferences ??= + await SharedPreferences.getInstance(); final rawThemeMode = preferences.getString(widget.themeModeSettingsKey); final rawColor = preferences.getInt(widget.primaryColorSettingsKey); setState(() { - _themeMode = ThemeMode.values - .singleWhereOrNull((value) => value.name == rawThemeMode); + _themeMode = ThemeMode.values.singleWhereOrNull( + (value) => value.name == rawThemeMode, + ); _primaryColor = rawColor == null ? null : Color(rawColor); }); } Future setThemeMode(ThemeMode newThemeMode) async { - final preferences = - _sharedPreferences ??= await SharedPreferences.getInstance(); + final preferences = _sharedPreferences ??= + await SharedPreferences.getInstance(); await preferences.setString(widget.themeModeSettingsKey, newThemeMode.name); setState(() { _themeMode = newThemeMode; @@ -65,14 +66,14 @@ class ThemeController extends State { } Future setPrimaryColor(Color? newPrimaryColor) async { - final preferences = - _sharedPreferences ??= await SharedPreferences.getInstance(); + final preferences = _sharedPreferences ??= + await SharedPreferences.getInstance(); if (newPrimaryColor == null) { await preferences.remove(widget.primaryColorSettingsKey); } else { await preferences.setInt( widget.primaryColorSettingsKey, - newPrimaryColor.value, + newPrimaryColor.hexValue, ); } setState(() { @@ -91,11 +92,8 @@ class ThemeController extends State { return Provider( create: (_) => this, child: DynamicColorBuilder( - builder: (light, _) => widget.builder( - context, - themeMode, - primaryColor ?? light?.primary, - ), + builder: (light, _) => + widget.builder(context, themeMode, primaryColor ?? light?.primary), ), ); } diff --git a/lib/widgets/unread_rooms_badge.dart b/lib/widgets/unread_rooms_badge.dart index 006691769..986316bd1 100644 --- a/lib/widgets/unread_rooms_badge.dart +++ b/lib/widgets/unread_rooms_badge.dart @@ -19,41 +19,26 @@ class UnreadRoomsBadge extends StatelessWidget { @override Widget build(BuildContext context) { - return StreamBuilder( - stream: Matrix.of(context) - .client - .onSync - .stream - .where((syncUpdate) => syncUpdate.hasRoomUpdate), - builder: (context, _) { - final unreadCount = Matrix.of(context) - .client - .rooms - .where(filter) - .where((r) => (r.isUnread || r.membership == Membership.invite)) - .length; - return b.Badge( - badgeStyle: b.BadgeStyle( - badgeColor: Theme.of(context).colorScheme.primary, - elevation: 4, - borderSide: BorderSide( - color: Theme.of(context).colorScheme.surface, - width: 2, - ), - ), - badgeContent: Text( - unreadCount.toString(), - style: TextStyle( - color: Theme.of(context).colorScheme.onPrimary, - fontSize: 12, - ), - ), - showBadge: unreadCount != 0, - badgeAnimation: const b.BadgeAnimation.scale(), - position: badgePosition ?? b.BadgePosition.bottomEnd(), - child: child, - ); - }, + final theme = Theme.of(context); + + final unreadCount = Matrix.of(context).client.rooms + .where(filter) + .where((r) => (r.isUnread || r.membership == Membership.invite)) + .length; + return b.Badge( + badgeStyle: b.BadgeStyle( + badgeColor: theme.colorScheme.primary, + elevation: 4, + borderSide: BorderSide(color: theme.colorScheme.surface, width: 2), + ), + badgeContent: Text( + unreadCount.toString(), + style: TextStyle(color: theme.colorScheme.onPrimary, fontSize: 12), + ), + showBadge: unreadCount != 0, + badgeAnimation: const b.BadgeAnimation.scale(), + position: badgePosition ?? b.BadgePosition.bottomEnd(), + child: child, ); } } diff --git a/lib/widgets/view_model_builder.dart b/lib/widgets/view_model_builder.dart new file mode 100644 index 000000000..11c30b6e5 --- /dev/null +++ b/lib/widgets/view_model_builder.dart @@ -0,0 +1,43 @@ +import 'package:flutter/material.dart'; + +class ViewModelBuilder extends StatefulWidget { + final T Function() create; + final Widget Function(BuildContext context, T viewModel, Widget? child) + builder; + final Widget? child; + const ViewModelBuilder({ + super.key, + required this.create, + required this.builder, + this.child, + }); + + @override + State> createState() => _ViewModelBuilderState(); +} + +class _ViewModelBuilderState + extends State> { + late final T _viewModel; + + @override + void initState() { + _viewModel = widget.create(); + super.initState(); + } + + @override + void dispose() { + _viewModel.dispose(); + super.dispose(); + } + + @override + Widget build(BuildContext context) { + return ValueListenableBuilder( + valueListenable: _viewModel, + builder: (context, value, child) => + widget.builder.call(context, _viewModel, child), + ); + } +} diff --git a/licenses.yaml b/licenses.yaml index 7b2f79bbf..fe53d876b 100644 --- a/licenses.yaml +++ b/licenses.yaml @@ -12,6 +12,8 @@ permittedLicenses: - BSD-2-Clause - BSD-3-Clause - EUPL-1.2 + - ISC + - LGPL-3.0 - MIT - MPL-2.0 - Zlib @@ -24,6 +26,8 @@ packageLicenseOverride: latlong2: Apache-2.0 platform_detect: Apache-2.0 rxdart: Apache-2.0 + flutter_new_badger: MIT + sqlcipher_flutter_libs: MIT # flutter's internal packages flutter_driver: BSD-3-Clause diff --git a/linux/flutter/generated_plugin_registrant.cc b/linux/flutter/generated_plugin_registrant.cc index 18e739cdd..deccda1dc 100644 --- a/linux/flutter/generated_plugin_registrant.cc +++ b/linux/flutter/generated_plugin_registrant.cc @@ -7,21 +7,29 @@ #include "generated_plugin_registrant.h" #include +#include #include #include #include #include #include -#include +#include +#include #include +#include #include #include +#include +#include #include void fl_register_plugins(FlPluginRegistry* registry) { g_autoptr(FlPluginRegistrar) desktop_drop_registrar = fl_plugin_registry_get_registrar_for_plugin(registry, "DesktopDropPlugin"); desktop_drop_plugin_register_with_registrar(desktop_drop_registrar); + g_autoptr(FlPluginRegistrar) desktop_webview_window_registrar = + fl_plugin_registry_get_registrar_for_plugin(registry, "DesktopWebviewWindowPlugin"); + desktop_webview_window_plugin_register_with_registrar(desktop_webview_window_registrar); g_autoptr(FlPluginRegistrar) dynamic_color_registrar = fl_plugin_registry_get_registrar_for_plugin(registry, "DynamicColorPlugin"); dynamic_color_plugin_register_with_registrar(dynamic_color_registrar); @@ -37,18 +45,30 @@ void fl_register_plugins(FlPluginRegistry* registry) { g_autoptr(FlPluginRegistrar) flutter_webrtc_registrar = fl_plugin_registry_get_registrar_for_plugin(registry, "FlutterWebRTCPlugin"); flutter_web_r_t_c_plugin_register_with_registrar(flutter_webrtc_registrar); - g_autoptr(FlPluginRegistrar) pasteboard_registrar = - fl_plugin_registry_get_registrar_for_plugin(registry, "PasteboardPlugin"); - pasteboard_plugin_register_with_registrar(pasteboard_registrar); + g_autoptr(FlPluginRegistrar) gtk_registrar = + fl_plugin_registry_get_registrar_for_plugin(registry, "GtkPlugin"); + gtk_plugin_register_with_registrar(gtk_registrar); + g_autoptr(FlPluginRegistrar) handy_window_registrar = + fl_plugin_registry_get_registrar_for_plugin(registry, "HandyWindowPlugin"); + handy_window_plugin_register_with_registrar(handy_window_registrar); g_autoptr(FlPluginRegistrar) record_linux_registrar = fl_plugin_registry_get_registrar_for_plugin(registry, "RecordLinuxPlugin"); record_linux_plugin_register_with_registrar(record_linux_registrar); + g_autoptr(FlPluginRegistrar) screen_retriever_linux_registrar = + fl_plugin_registry_get_registrar_for_plugin(registry, "ScreenRetrieverLinuxPlugin"); + screen_retriever_linux_plugin_register_with_registrar(screen_retriever_linux_registrar); g_autoptr(FlPluginRegistrar) sqlcipher_flutter_libs_registrar = fl_plugin_registry_get_registrar_for_plugin(registry, "Sqlite3FlutterLibsPlugin"); sqlite3_flutter_libs_plugin_register_with_registrar(sqlcipher_flutter_libs_registrar); g_autoptr(FlPluginRegistrar) url_launcher_linux_registrar = fl_plugin_registry_get_registrar_for_plugin(registry, "UrlLauncherPlugin"); url_launcher_plugin_register_with_registrar(url_launcher_linux_registrar); + g_autoptr(FlPluginRegistrar) webcrypto_registrar = + fl_plugin_registry_get_registrar_for_plugin(registry, "WebcryptoPlugin"); + webcrypto_plugin_register_with_registrar(webcrypto_registrar); + g_autoptr(FlPluginRegistrar) window_manager_registrar = + fl_plugin_registry_get_registrar_for_plugin(registry, "WindowManagerPlugin"); + window_manager_plugin_register_with_registrar(window_manager_registrar); g_autoptr(FlPluginRegistrar) window_to_front_registrar = fl_plugin_registry_get_registrar_for_plugin(registry, "WindowToFrontPlugin"); window_to_front_plugin_register_with_registrar(window_to_front_registrar); diff --git a/linux/flutter/generated_plugins.cmake b/linux/flutter/generated_plugins.cmake index b4a43e1b9..53413056c 100644 --- a/linux/flutter/generated_plugins.cmake +++ b/linux/flutter/generated_plugins.cmake @@ -4,19 +4,25 @@ list(APPEND FLUTTER_PLUGIN_LIST desktop_drop + desktop_webview_window dynamic_color emoji_picker_flutter file_selector_linux flutter_secure_storage_linux flutter_webrtc - pasteboard + gtk + handy_window record_linux + screen_retriever_linux sqlcipher_flutter_libs url_launcher_linux + webcrypto + window_manager window_to_front ) list(APPEND FLUTTER_FFI_PLUGIN_LIST + flutter_vodozemac ) set(PLUGIN_BUNDLED_LIBRARIES) diff --git a/linux/my_application.cc b/linux/my_application.cc index c185bcd78..986be4ea3 100644 --- a/linux/my_application.cc +++ b/linux/my_application.cc @@ -60,18 +60,18 @@ static void my_application_activate(GApplication* application) { gtk_window_set_title(window, "FluffyChat"); } - gtk_window_set_default_size(window, 864, 680); - gtk_widget_show(GTK_WIDGET(window)); + gtk_window_set_default_size(window, 864, 720); g_autoptr(FlDartProject) project = fl_dart_project_new(); fl_dart_project_set_dart_entrypoint_arguments(project, self->dart_entrypoint_arguments); FlView* view = fl_view_new(project); - gtk_widget_show(GTK_WIDGET(view)); gtk_container_add(GTK_CONTAINER(window), GTK_WIDGET(view)); fl_register_plugins(FL_PLUGIN_REGISTRY(view)); + gtk_widget_show(GTK_WIDGET(window)); + gtk_widget_show(GTK_WIDGET(view)); gtk_widget_grab_focus(GTK_WIDGET(view)); } diff --git a/macos/Flutter/GeneratedPluginRegistrant.swift b/macos/Flutter/GeneratedPluginRegistrant.swift index 50894732e..0e1ab0cac 100644 --- a/macos/Flutter/GeneratedPluginRegistrant.swift +++ b/macos/Flutter/GeneratedPluginRegistrant.swift @@ -5,64 +5,64 @@ import FlutterMacOS import Foundation -import appkit_ui_element_colors +import app_links import audio_session import desktop_drop +import desktop_webview_window import device_info_plus import dynamic_color import emoji_picker_flutter +import file_picker import file_selector_macos -import flutter_app_badger import flutter_local_notifications -import flutter_secure_storage_macos +import flutter_new_badger +import flutter_secure_storage_darwin import flutter_web_auth_2 import flutter_webrtc import geolocator_apple import just_audio -import macos_ui -import macos_window_utils import package_info_plus -import pasteboard -import path_provider_foundation -import record_darwin +import record_macos +import screen_retriever_macos import share_plus import shared_preferences_foundation -import sqflite import sqlcipher_flutter_libs import url_launcher_macos import video_compress import video_player_avfoundation import wakelock_plus +import webcrypto +import window_manager import window_to_front func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) { - AppkitUiElementColorsPlugin.register(with: registry.registrar(forPlugin: "AppkitUiElementColorsPlugin")) + AppLinksMacosPlugin.register(with: registry.registrar(forPlugin: "AppLinksMacosPlugin")) AudioSessionPlugin.register(with: registry.registrar(forPlugin: "AudioSessionPlugin")) DesktopDropPlugin.register(with: registry.registrar(forPlugin: "DesktopDropPlugin")) + DesktopWebviewWindowPlugin.register(with: registry.registrar(forPlugin: "DesktopWebviewWindowPlugin")) DeviceInfoPlusMacosPlugin.register(with: registry.registrar(forPlugin: "DeviceInfoPlusMacosPlugin")) DynamicColorPlugin.register(with: registry.registrar(forPlugin: "DynamicColorPlugin")) EmojiPickerFlutterPlugin.register(with: registry.registrar(forPlugin: "EmojiPickerFlutterPlugin")) + FilePickerPlugin.register(with: registry.registrar(forPlugin: "FilePickerPlugin")) FileSelectorPlugin.register(with: registry.registrar(forPlugin: "FileSelectorPlugin")) - FlutterAppBadgerPlugin.register(with: registry.registrar(forPlugin: "FlutterAppBadgerPlugin")) FlutterLocalNotificationsPlugin.register(with: registry.registrar(forPlugin: "FlutterLocalNotificationsPlugin")) - FlutterSecureStoragePlugin.register(with: registry.registrar(forPlugin: "FlutterSecureStoragePlugin")) + FlutterNewBadgerPlugin.register(with: registry.registrar(forPlugin: "FlutterNewBadgerPlugin")) + FlutterSecureStorageDarwinPlugin.register(with: registry.registrar(forPlugin: "FlutterSecureStorageDarwinPlugin")) FlutterWebAuth2Plugin.register(with: registry.registrar(forPlugin: "FlutterWebAuth2Plugin")) FlutterWebRTCPlugin.register(with: registry.registrar(forPlugin: "FlutterWebRTCPlugin")) GeolocatorPlugin.register(with: registry.registrar(forPlugin: "GeolocatorPlugin")) JustAudioPlugin.register(with: registry.registrar(forPlugin: "JustAudioPlugin")) - MacOSUiPlugin.register(with: registry.registrar(forPlugin: "MacOSUiPlugin")) - MacOSWindowUtilsPlugin.register(with: registry.registrar(forPlugin: "MacOSWindowUtilsPlugin")) FPPPackageInfoPlusPlugin.register(with: registry.registrar(forPlugin: "FPPPackageInfoPlusPlugin")) - PasteboardPlugin.register(with: registry.registrar(forPlugin: "PasteboardPlugin")) - PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin")) - RecordPlugin.register(with: registry.registrar(forPlugin: "RecordPlugin")) + RecordMacOsPlugin.register(with: registry.registrar(forPlugin: "RecordMacOsPlugin")) + ScreenRetrieverMacosPlugin.register(with: registry.registrar(forPlugin: "ScreenRetrieverMacosPlugin")) SharePlusMacosPlugin.register(with: registry.registrar(forPlugin: "SharePlusMacosPlugin")) SharedPreferencesPlugin.register(with: registry.registrar(forPlugin: "SharedPreferencesPlugin")) - SqflitePlugin.register(with: registry.registrar(forPlugin: "SqflitePlugin")) Sqlite3FlutterLibsPlugin.register(with: registry.registrar(forPlugin: "Sqlite3FlutterLibsPlugin")) UrlLauncherPlugin.register(with: registry.registrar(forPlugin: "UrlLauncherPlugin")) VideoCompressPlugin.register(with: registry.registrar(forPlugin: "VideoCompressPlugin")) FVPVideoPlayerPlugin.register(with: registry.registrar(forPlugin: "FVPVideoPlayerPlugin")) WakelockPlusMacosPlugin.register(with: registry.registrar(forPlugin: "WakelockPlusMacosPlugin")) + WebcryptoPlugin.register(with: registry.registrar(forPlugin: "WebcryptoPlugin")) + WindowManagerPlugin.register(with: registry.registrar(forPlugin: "WindowManagerPlugin")) WindowToFrontPlugin.register(with: registry.registrar(forPlugin: "WindowToFrontPlugin")) } diff --git a/macos/Podfile.lock b/macos/Podfile.lock index 221a21755..a4387410d 100644 --- a/macos/Podfile.lock +++ b/macos/Podfile.lock @@ -1,69 +1,62 @@ PODS: - - appkit_ui_element_colors (1.0.0): + - app_links (6.4.1): - FlutterMacOS - audio_session (0.0.1): - FlutterMacOS - desktop_drop (0.0.1): - FlutterMacOS + - desktop_webview_window (0.0.1): + - FlutterMacOS - device_info_plus (0.0.1): - FlutterMacOS - dynamic_color (0.0.2): - FlutterMacOS - emoji_picker_flutter (0.0.1): - FlutterMacOS - - file_selector_macos (0.0.1): + - file_picker (0.0.1): - FlutterMacOS - - flutter_app_badger (1.3.0): + - file_selector_macos (0.0.1): - FlutterMacOS - flutter_local_notifications (0.0.1): - FlutterMacOS - - flutter_secure_storage_macos (6.1.1): + - flutter_new_badger (0.0.1): - FlutterMacOS - - flutter_web_auth_2 (3.0.0): + - flutter_secure_storage_darwin (10.0.0): + - Flutter - FlutterMacOS - - flutter_webrtc (0.9.36): + - flutter_vodozemac (0.0.1): - FlutterMacOS - - WebRTC-SDK (= 114.5735.08) + - flutter_web_auth_2 (5.0.0): + - FlutterMacOS + - flutter_webrtc (1.2.0): + - FlutterMacOS + - WebRTC-SDK (= 137.7151.12) - FlutterMacOS (1.0.0) - - FMDB (2.7.5): - - FMDB/standard (= 2.7.5) - - FMDB/SQLCipher (2.7.5): - - SQLCipher - - FMDB/standard (2.7.5) - geolocator_apple (1.2.0): + - Flutter - FlutterMacOS - just_audio (0.0.1): - - FlutterMacOS - - macos_ui (0.1.0): - - FlutterMacOS - - macos_window_utils (1.0.0): + - Flutter - FlutterMacOS - package_info_plus (0.0.1): - FlutterMacOS - - pasteboard (0.0.1): + - record_macos (1.2.0): - FlutterMacOS - - path_provider_foundation (0.0.1): - - Flutter - - FlutterMacOS - - record_macos (0.2.0): + - screen_retriever_macos (0.0.1): - FlutterMacOS - share_plus (0.0.1): - FlutterMacOS - shared_preferences_foundation (0.0.1): - Flutter - FlutterMacOS - - sqflite (0.0.2): - - FlutterMacOS - - FMDB (>= 2.7.5) - - sqflite_sqlcipher (0.0.1): - - FlutterMacOS - - FMDB/SQLCipher (~> 2.7.5) - - SQLCipher (= 4.5.4) - - SQLCipher (4.5.4): - - SQLCipher/standard (= 4.5.4) - - SQLCipher/common (4.5.4) - - SQLCipher/standard (4.5.4): + - SQLCipher (4.10.0): + - SQLCipher/standard (= 4.10.0) + - SQLCipher/common (4.10.0) + - SQLCipher/standard (4.10.0): - SQLCipher/common + - sqlcipher_flutter_libs (0.0.1): + - FlutterMacOS + - SQLCipher (~> 4.10.0) - url_launcher_macos (0.0.1): - FlutterMacOS - video_compress (0.3.0): @@ -73,69 +66,80 @@ PODS: - FlutterMacOS - wakelock_plus (0.0.1): - FlutterMacOS - - WebRTC-SDK (114.5735.08) + - webcrypto (0.1.1): + - Flutter + - FlutterMacOS + - WebRTC-SDK (137.7151.12) + - window_manager (0.5.0): + - FlutterMacOS - window_to_front (0.0.1): - FlutterMacOS DEPENDENCIES: - - appkit_ui_element_colors (from `Flutter/ephemeral/.symlinks/plugins/appkit_ui_element_colors/macos`) + - app_links (from `Flutter/ephemeral/.symlinks/plugins/app_links/macos`) - audio_session (from `Flutter/ephemeral/.symlinks/plugins/audio_session/macos`) - desktop_drop (from `Flutter/ephemeral/.symlinks/plugins/desktop_drop/macos`) + - desktop_webview_window (from `Flutter/ephemeral/.symlinks/plugins/desktop_webview_window/macos`) - device_info_plus (from `Flutter/ephemeral/.symlinks/plugins/device_info_plus/macos`) - dynamic_color (from `Flutter/ephemeral/.symlinks/plugins/dynamic_color/macos`) - emoji_picker_flutter (from `Flutter/ephemeral/.symlinks/plugins/emoji_picker_flutter/macos`) + - file_picker (from `Flutter/ephemeral/.symlinks/plugins/file_picker/macos`) - file_selector_macos (from `Flutter/ephemeral/.symlinks/plugins/file_selector_macos/macos`) - - flutter_app_badger (from `Flutter/ephemeral/.symlinks/plugins/flutter_app_badger/macos`) - flutter_local_notifications (from `Flutter/ephemeral/.symlinks/plugins/flutter_local_notifications/macos`) - - flutter_secure_storage_macos (from `Flutter/ephemeral/.symlinks/plugins/flutter_secure_storage_macos/macos`) + - flutter_new_badger (from `Flutter/ephemeral/.symlinks/plugins/flutter_new_badger/macos`) + - flutter_secure_storage_darwin (from `Flutter/ephemeral/.symlinks/plugins/flutter_secure_storage_darwin/darwin`) + - flutter_vodozemac (from `Flutter/ephemeral/.symlinks/plugins/flutter_vodozemac/macos`) - flutter_web_auth_2 (from `Flutter/ephemeral/.symlinks/plugins/flutter_web_auth_2/macos`) - flutter_webrtc (from `Flutter/ephemeral/.symlinks/plugins/flutter_webrtc/macos`) - FlutterMacOS (from `Flutter/ephemeral`) - - geolocator_apple (from `Flutter/ephemeral/.symlinks/plugins/geolocator_apple/macos`) - - just_audio (from `Flutter/ephemeral/.symlinks/plugins/just_audio/macos`) - - macos_ui (from `Flutter/ephemeral/.symlinks/plugins/macos_ui/macos`) - - macos_window_utils (from `Flutter/ephemeral/.symlinks/plugins/macos_window_utils/macos`) + - geolocator_apple (from `Flutter/ephemeral/.symlinks/plugins/geolocator_apple/darwin`) + - just_audio (from `Flutter/ephemeral/.symlinks/plugins/just_audio/darwin`) - package_info_plus (from `Flutter/ephemeral/.symlinks/plugins/package_info_plus/macos`) - - pasteboard (from `Flutter/ephemeral/.symlinks/plugins/pasteboard/macos`) - - path_provider_foundation (from `Flutter/ephemeral/.symlinks/plugins/path_provider_foundation/darwin`) - record_macos (from `Flutter/ephemeral/.symlinks/plugins/record_macos/macos`) + - screen_retriever_macos (from `Flutter/ephemeral/.symlinks/plugins/screen_retriever_macos/macos`) - share_plus (from `Flutter/ephemeral/.symlinks/plugins/share_plus/macos`) - shared_preferences_foundation (from `Flutter/ephemeral/.symlinks/plugins/shared_preferences_foundation/darwin`) - - sqflite (from `Flutter/ephemeral/.symlinks/plugins/sqflite/macos`) - - sqflite_sqlcipher (from `Flutter/ephemeral/.symlinks/plugins/sqflite_sqlcipher/macos`) + - sqlcipher_flutter_libs (from `Flutter/ephemeral/.symlinks/plugins/sqlcipher_flutter_libs/macos`) - url_launcher_macos (from `Flutter/ephemeral/.symlinks/plugins/url_launcher_macos/macos`) - video_compress (from `Flutter/ephemeral/.symlinks/plugins/video_compress/macos`) - video_player_avfoundation (from `Flutter/ephemeral/.symlinks/plugins/video_player_avfoundation/darwin`) - wakelock_plus (from `Flutter/ephemeral/.symlinks/plugins/wakelock_plus/macos`) + - webcrypto (from `Flutter/ephemeral/.symlinks/plugins/webcrypto/darwin`) + - window_manager (from `Flutter/ephemeral/.symlinks/plugins/window_manager/macos`) - window_to_front (from `Flutter/ephemeral/.symlinks/plugins/window_to_front/macos`) SPEC REPOS: trunk: - - FMDB - SQLCipher - WebRTC-SDK EXTERNAL SOURCES: - appkit_ui_element_colors: - :path: Flutter/ephemeral/.symlinks/plugins/appkit_ui_element_colors/macos + app_links: + :path: Flutter/ephemeral/.symlinks/plugins/app_links/macos audio_session: :path: Flutter/ephemeral/.symlinks/plugins/audio_session/macos desktop_drop: :path: Flutter/ephemeral/.symlinks/plugins/desktop_drop/macos + desktop_webview_window: + :path: Flutter/ephemeral/.symlinks/plugins/desktop_webview_window/macos device_info_plus: :path: Flutter/ephemeral/.symlinks/plugins/device_info_plus/macos dynamic_color: :path: Flutter/ephemeral/.symlinks/plugins/dynamic_color/macos emoji_picker_flutter: :path: Flutter/ephemeral/.symlinks/plugins/emoji_picker_flutter/macos + file_picker: + :path: Flutter/ephemeral/.symlinks/plugins/file_picker/macos file_selector_macos: :path: Flutter/ephemeral/.symlinks/plugins/file_selector_macos/macos - flutter_app_badger: - :path: Flutter/ephemeral/.symlinks/plugins/flutter_app_badger/macos flutter_local_notifications: :path: Flutter/ephemeral/.symlinks/plugins/flutter_local_notifications/macos - flutter_secure_storage_macos: - :path: Flutter/ephemeral/.symlinks/plugins/flutter_secure_storage_macos/macos + flutter_new_badger: + :path: Flutter/ephemeral/.symlinks/plugins/flutter_new_badger/macos + flutter_secure_storage_darwin: + :path: Flutter/ephemeral/.symlinks/plugins/flutter_secure_storage_darwin/darwin + flutter_vodozemac: + :path: Flutter/ephemeral/.symlinks/plugins/flutter_vodozemac/macos flutter_web_auth_2: :path: Flutter/ephemeral/.symlinks/plugins/flutter_web_auth_2/macos flutter_webrtc: @@ -143,29 +147,21 @@ EXTERNAL SOURCES: FlutterMacOS: :path: Flutter/ephemeral geolocator_apple: - :path: Flutter/ephemeral/.symlinks/plugins/geolocator_apple/macos + :path: Flutter/ephemeral/.symlinks/plugins/geolocator_apple/darwin just_audio: - :path: Flutter/ephemeral/.symlinks/plugins/just_audio/macos - macos_ui: - :path: Flutter/ephemeral/.symlinks/plugins/macos_ui/macos - macos_window_utils: - :path: Flutter/ephemeral/.symlinks/plugins/macos_window_utils/macos + :path: Flutter/ephemeral/.symlinks/plugins/just_audio/darwin package_info_plus: :path: Flutter/ephemeral/.symlinks/plugins/package_info_plus/macos - pasteboard: - :path: Flutter/ephemeral/.symlinks/plugins/pasteboard/macos - path_provider_foundation: - :path: Flutter/ephemeral/.symlinks/plugins/path_provider_foundation/darwin record_macos: :path: Flutter/ephemeral/.symlinks/plugins/record_macos/macos + screen_retriever_macos: + :path: Flutter/ephemeral/.symlinks/plugins/screen_retriever_macos/macos share_plus: :path: Flutter/ephemeral/.symlinks/plugins/share_plus/macos shared_preferences_foundation: :path: Flutter/ephemeral/.symlinks/plugins/shared_preferences_foundation/darwin - sqflite: - :path: Flutter/ephemeral/.symlinks/plugins/sqflite/macos - sqflite_sqlcipher: - :path: Flutter/ephemeral/.symlinks/plugins/sqflite_sqlcipher/macos + sqlcipher_flutter_libs: + :path: Flutter/ephemeral/.symlinks/plugins/sqlcipher_flutter_libs/macos url_launcher_macos: :path: Flutter/ephemeral/.symlinks/plugins/url_launcher_macos/macos video_compress: @@ -174,44 +170,48 @@ EXTERNAL SOURCES: :path: Flutter/ephemeral/.symlinks/plugins/video_player_avfoundation/darwin wakelock_plus: :path: Flutter/ephemeral/.symlinks/plugins/wakelock_plus/macos + webcrypto: + :path: Flutter/ephemeral/.symlinks/plugins/webcrypto/darwin + window_manager: + :path: Flutter/ephemeral/.symlinks/plugins/window_manager/macos window_to_front: :path: Flutter/ephemeral/.symlinks/plugins/window_to_front/macos SPEC CHECKSUMS: - appkit_ui_element_colors: 39bb2d80be3f19b152ccf4c70d5bbe6cba43d74a - audio_session: dea1f41890dbf1718f04a56f1d6150fd50039b72 - desktop_drop: 69eeff437544aa619c8db7f4481b3a65f7696898 - device_info_plus: 5401765fde0b8d062a2f8eb65510fb17e77cf07f - dynamic_color: 2eaa27267de1ca20d879fbd6e01259773fb1670f - emoji_picker_flutter: 533634326b1c5de9a181ba14b9758e6dfe967a20 - file_selector_macos: 468fb6b81fac7c0e88d71317f3eec34c3b008ff9 - flutter_app_badger: 55a64b179f8438e89d574320c77b306e327a1730 - flutter_local_notifications: 3805ca215b2fb7f397d78b66db91f6a747af52e4 - flutter_secure_storage_macos: d56e2d218c1130b262bef8b4a7d64f88d7f9c9ea - flutter_web_auth_2: 2e1dc2d2139973e4723c5286ce247dd590390d70 - flutter_webrtc: cf7dc44d26cbb5c5f1ae5f583dab545871f287f9 - FlutterMacOS: 8f6f14fa908a6fb3fba0cd85dbd81ec4b251fb24 - FMDB: 2ce00b547f966261cd18927a3ddb07cb6f3db82a - geolocator_apple: 821be05bbdb1b49500e029ebcbf2d6acf2dfb966 - just_audio: 9b67ca7b97c61cfc9784ea23cd8cc55eb226d489 - macos_ui: 6229a8922cd97bafb7d9636c8eb8dfb0744183ca - macos_window_utils: 933f91f64805e2eb91a5bd057cf97cd097276663 - package_info_plus: 02d7a575e80f194102bef286361c6c326e4c29ce - pasteboard: 9b69dba6fedbb04866be632205d532fe2f6b1d99 - path_provider_foundation: 29f094ae23ebbca9d3d0cec13889cd9060c0e943 - record_macos: 937889e0f2a7a12b6fc14e97a3678e5a18943de6 - share_plus: 76dd39142738f7a68dd57b05093b5e8193f220f7 - shared_preferences_foundation: 5b919d13b803cadd15ed2dc053125c68730e5126 - sqflite: a5789cceda41d54d23f31d6de539d65bb14100ea - sqflite_sqlcipher: d1ac7c60596e4d624d9757e3ec96e9cfafb734d6 - SQLCipher: 905b145f65f349f26da9e60a19901ad24adcd381 - url_launcher_macos: d2691c7dd33ed713bf3544850a623080ec693d95 - video_compress: c896234f100791b5fef7f049afa38f6d2ef7b42f - video_player_avfoundation: e9e6f9cae7d7a6d9b43519b0aab382bca60fcfd1 - wakelock_plus: 4783562c9a43d209c458cb9b30692134af456269 - WebRTC-SDK: c24d2a6c9f571f2ed42297cb8ffba9557093142b - window_to_front: 4cdc24ddd8461ad1a55fa06286d6a79d8b29e8d8 + app_links: 05a6ec2341985eb05e9f97dc63f5837c39895c3f + audio_session: eaca2512cf2b39212d724f35d11f46180ad3a33e + desktop_drop: 10a3e6a7fa9dbe350541f2574092fecfa345a07b + desktop_webview_window: 7e37af677d6d19294cb433d9b1d878ef78dffa4d + device_info_plus: 4fb280989f669696856f8b129e4a5e3cd6c48f76 + dynamic_color: cb7c2a300ee67ed3bd96c3e852df3af0300bf610 + emoji_picker_flutter: 51ca408e289d84d1e460016b2a28721ec754fcf7 + file_picker: 7584aae6fa07a041af2b36a2655122d42f578c1a + file_selector_macos: 9e9e068e90ebee155097d00e89ae91edb2374db7 + flutter_local_notifications: 4bf37a31afde695b56091b4ae3e4d9c7a7e6cda0 + flutter_new_badger: 6fe9bf7e42793a164032c21f164c0ad9985cd0f2 + flutter_secure_storage_darwin: acdb3f316ed05a3e68f856e0353b133eec373a23 + flutter_vodozemac: fd2ea9cb3e2a37beaac883a369811fbfe042fc53 + flutter_web_auth_2: 7fe624ff12ddcb4c19e5dbcd56c9e9ea4899d967 + flutter_webrtc: 7cda18a9cd917db2f8bfcde8011804f6018a12df + FlutterMacOS: d0db08ddef1a9af05a5ec4b724367152bb0500b1 + geolocator_apple: ab36aa0e8b7d7a2d7639b3b4e48308394e8cef5e + just_audio: 4e391f57b79cad2b0674030a00453ca5ce817eed + package_info_plus: f0052d280d17aa382b932f399edf32507174e870 + record_macos: 7f227161b93c49e7e34fe681c5891c8622c8cc8b + screen_retriever_macos: 452e51764a9e1cdb74b3c541238795849f21557f + share_plus: 510bf0af1a42cd602274b4629920c9649c52f4cc + shared_preferences_foundation: 7036424c3d8ec98dfe75ff1667cb0cd531ec82bb + SQLCipher: eb79c64049cb002b4e9fcb30edb7979bf4706dfc + sqlcipher_flutter_libs: 01ead34db27ae5e49987cae46c8a34199eb22cfe + url_launcher_macos: f87a979182d112f911de6820aefddaf56ee9fbfd + video_compress: 752b161da855df2492dd1a8fa899743cc8fe9534 + video_player_avfoundation: dd410b52df6d2466a42d28550e33e4146928280a + wakelock_plus: 917609be14d812ddd9e9528876538b2263aaa03b + webcrypto: a5f5eb3e375cf0a99993e207e97cdcab5c94ce2e + WebRTC-SDK: 1762e2de812354d27a8407d1b2c532064ec39fce + window_manager: b729e31d38fb04905235df9ea896128991cad99e + window_to_front: 9e76fd432e36700a197dac86a0011e49c89abe0a PODFILE CHECKSUM: d0975b16fbdecb73b109d8fbc88aa77ffe4c7a8d -COCOAPODS: 1.14.3 +COCOAPODS: 1.16.2 diff --git a/macos/Runner.xcodeproj/project.pbxproj b/macos/Runner.xcodeproj/project.pbxproj index 304fc1636..5b297f8ab 100644 --- a/macos/Runner.xcodeproj/project.pbxproj +++ b/macos/Runner.xcodeproj/project.pbxproj @@ -210,13 +210,12 @@ isa = PBXProject; attributes = { LastSwiftUpdateCheck = 0920; - LastUpgradeCheck = 1430; + LastUpgradeCheck = 1510; ORGANIZATIONNAME = ""; TargetAttributes = { 33CC10EC2044A3C60003C045 = { CreatedOnToolsVersion = 9.2; LastSwiftMigration = 1100; - ProvisioningStyle = Automatic; SystemCapabilities = { com.apple.Sandbox = { enabled = 1; @@ -427,7 +426,7 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements; - "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; + CODE_SIGN_IDENTITY = "Apple Development"; CODE_SIGN_STYLE = Automatic; COMBINE_HIDPI_IMAGES = YES; DEVELOPMENT_TEAM = 4NXF6Z997G; @@ -559,7 +558,7 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements; - "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; + CODE_SIGN_IDENTITY = "Apple Development"; CODE_SIGN_STYLE = Automatic; COMBINE_HIDPI_IMAGES = YES; DEVELOPMENT_TEAM = 4NXF6Z997G; @@ -585,7 +584,7 @@ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/Release.entitlements; - "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; + CODE_SIGN_IDENTITY = "Apple Development"; CODE_SIGN_STYLE = Automatic; COMBINE_HIDPI_IMAGES = YES; DEVELOPMENT_TEAM = 4NXF6Z997G; diff --git a/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme b/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme index 4e6cd6256..1a20155a2 100644 --- a/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +++ b/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme @@ -1,6 +1,6 @@ diff --git a/macos/Runner/AppDelegate.swift b/macos/Runner/AppDelegate.swift index d53ef6437..b3c176141 100644 --- a/macos/Runner/AppDelegate.swift +++ b/macos/Runner/AppDelegate.swift @@ -1,9 +1,13 @@ import Cocoa import FlutterMacOS -@NSApplicationMain +@main class AppDelegate: FlutterAppDelegate { override func applicationShouldTerminateAfterLastWindowClosed(_ sender: NSApplication) -> Bool { return true } + + override func applicationSupportsSecureRestorableState(_ app: NSApplication) -> Bool { + return true + } } diff --git a/pubspec.lock b/pubspec.lock index 97aad333e..6d30bd234 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -5,82 +5,106 @@ packages: dependency: transitive description: name: _fe_analyzer_shared - sha256: "0b2f2bd91ba804e53a61d757b986f89f1f9eaed5b11e4b2f5a2468d86d6c9fc7" + sha256: c209688d9f5a5f26b2fb47a188131a6fb9e876ae9e47af3737c0b4f58a93470d url: "https://pub.dev" source: hosted - version: "67.0.0" - adaptive_dialog: - dependency: "direct main" - description: - name: adaptive_dialog - sha256: "817ff9b4bb441434d1fcb39a8d4492e50be456cd3507e4f19c5c7455c9e279e0" - url: "https://pub.dev" - source: hosted - version: "2.1.0" + version: "91.0.0" analyzer: dependency: transitive description: name: analyzer - sha256: "37577842a27e4338429a1cbc32679d508836510b056f1eedf0c8d20e39c1383d" + sha256: f51c8499b35f9b26820cfe914828a6a98a94efd5cc78b37bb7d03debae3a1d08 url: "https://pub.dev" source: hosted - version: "6.4.1" + version: "8.4.1" + analyzer_plugin: + dependency: transitive + description: + name: analyzer_plugin + sha256: "825071d553c4aef2252196d46a665fbd8e0cb06de07725f25d1b29bd18d65fff" + url: "https://pub.dev" + source: hosted + version: "0.13.6" animations: dependency: "direct main" description: name: animations - sha256: d3d6dcfb218225bbe68e87ccf6378bbb2e32a94900722c5f81611dad089911cb + sha256: "18938cefd7dcc04e1ecac0db78973761a01e4bc2d6bfae0cfa596bfeac9e96ab" url: "https://pub.dev" source: hosted - version: "2.0.11" + version: "2.1.1" ansicolor: dependency: transitive description: name: ansicolor - sha256: "8bf17a8ff6ea17499e40a2d2542c2f481cd7615760c6d34065cb22bfd22e6880" + sha256: "50e982d500bc863e1d703448afdbf9e5a72eb48840a4f766fa361ffd6877055f" + url: "https://pub.dev" + source: hosted + version: "2.0.3" + app_links: + dependency: "direct main" + description: + name: app_links + sha256: "5f88447519add627fe1cbcab4fd1da3d4fed15b9baf29f28b22535c95ecee3e8" + url: "https://pub.dev" + source: hosted + version: "6.4.1" + app_links_linux: + dependency: transitive + description: + name: app_links_linux + sha256: f5f7173a78609f3dfd4c2ff2c95bd559ab43c80a87dc6a095921d96c05688c81 + url: "https://pub.dev" + source: hosted + version: "1.0.3" + app_links_platform_interface: + dependency: transitive + description: + name: app_links_platform_interface + sha256: "05f5379577c513b534a29ddea68176a4d4802c46180ee8e2e966257158772a3f" url: "https://pub.dev" source: hosted version: "2.0.2" - appkit_ui_element_colors: + app_links_web: dependency: transitive description: - name: appkit_ui_element_colors - sha256: c3e50f900aae314d339de489535736238627071457c4a4a2dbbb1545b4f04f22 + name: app_links_web + sha256: af060ed76183f9e2b87510a9480e56a5352b6c249778d07bd2c95fc35632a555 url: "https://pub.dev" source: hosted - version: "1.0.0" + version: "1.0.4" archive: dependency: "direct main" description: name: archive - sha256: "22600aa1e926be775fa5fe7e6894e7fb3df9efda8891c73f70fb3262399a432d" + sha256: a96e8b390886ee8abb49b7bd3ac8df6f451c621619f52a26e815fdcf568959ff url: "https://pub.dev" source: hosted - version: "3.4.10" + version: "4.0.9" args: dependency: transitive description: name: args - sha256: "7cf60b9f0cc88203c5a190b4cd62a99feea42759a7fa695010eb5de1c0b2252a" + sha256: d0481093c50b1da8910eb0bb301626d4d8eb7284aa739614d2b394ee09e3ea04 url: "https://pub.dev" source: hosted - version: "2.5.0" + version: "2.7.0" async: dependency: "direct main" description: name: async - sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c" + sha256: "758e6d74e971c3e5aceb4110bfd6698efc7f501675bcfe0c775459a8140750eb" url: "https://pub.dev" source: hosted - version: "2.11.0" + version: "2.13.0" audio_session: dependency: transitive description: name: audio_session - sha256: a49af9981eec5d7cd73b37bacb6ee73f8143a6a9f9bd5b6021e6c346b9b6cf4e + sha256: "8f96a7fecbb718cb093070f868b4cdcb8a9b1053dce342ff8ab2fde10eb9afb7" url: "https://pub.dev" source: hosted - version: "0.1.19" + version: "0.2.2" badges: dependency: "direct main" description: @@ -117,26 +141,18 @@ packages: dependency: transitive description: name: boolean_selector - sha256: "6cfb5af12253eaf2b368f07bacc5a80d1301a071c73360d746b7f2e32d762c66" + sha256: "8aab1771e1243a5063b8b0ff68042d67334e3feab9e95b9490f9a6ebf73b42ea" + url: "https://pub.dev" + source: hosted + version: "2.1.2" + build_cli_annotations: + dependency: transitive + description: + name: build_cli_annotations + sha256: e563c2e01de8974566a1998410d3f6f03521788160a02503b0b1f1a46c7b3d95 url: "https://pub.dev" source: hosted version: "2.1.1" - build_config: - dependency: transitive - description: - name: build_config - sha256: bf80fcfb46a29945b423bd9aad884590fb1dc69b330a4d4700cac476af1708d1 - url: "https://pub.dev" - source: hosted - version: "1.1.1" - callkeep: - dependency: "direct main" - description: - name: callkeep - sha256: "9e86e9632a603a61f7045c179ea5ca0ee4da0a49fc5f80c2fe09fb422b96d3c6" - url: "https://pub.dev" - source: hosted - version: "0.3.3" canonical_json: dependency: transitive description: @@ -149,58 +165,74 @@ packages: dependency: transitive description: name: characters - sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605" + sha256: faf38497bda5ead2a8c7615f4f7939df04333478bf32e4173fcb06d428b5716b url: "https://pub.dev" source: hosted - version: "1.3.0" + version: "1.4.1" charcode: dependency: transitive description: name: charcode - sha256: fb98c0f6d12c920a02ee2d998da788bca066ca5f148492b7085ee23372b12306 + sha256: fb0f1107cac15a5ea6ef0a6ef71a807b9e4267c713bb93e00e92d737cc8dbd8a url: "https://pub.dev" source: hosted - version: "1.3.1" + version: "1.4.0" checked_yaml: dependency: transitive description: name: checked_yaml - sha256: feb6bed21949061731a7a75fc5d2aa727cf160b91af9a3e464c5e3a32e28b5ff + sha256: "959525d3162f249993882720d52b7e0c833978df229be20702b33d48d91de70f" url: "https://pub.dev" source: hosted - version: "2.0.3" + version: "2.0.4" chewie: dependency: "direct main" description: name: chewie - sha256: e53da939709efb9aad0f3d72a69a8d05f889168b7a138af60ce78bab5c94b135 + sha256: "44bcfc5f0dfd1de290c87c9d86a61308b3282a70b63435d5557cfd60f54a69ca" url: "https://pub.dev" source: hosted - version: "1.8.1" + version: "1.13.0" + cli_config: + dependency: transitive + description: + name: cli_config + sha256: ac20a183a07002b700f0c25e61b7ee46b23c309d76ab7b7640a028f18e4d99ec + url: "https://pub.dev" + source: hosted + version: "0.2.0" cli_util: dependency: transitive description: name: cli_util - sha256: c05b7406fdabc7a49a3929d4af76bcaccbbffcbcdcf185b082e1ae07da323d19 + sha256: ff6785f7e9e3c38ac98b2fb035701789de90154024a75b6cb926445e83197d1c url: "https://pub.dev" source: hosted - version: "0.4.1" + version: "0.4.2" clock: dependency: transitive description: name: clock - sha256: cb6d7f03e1de671e34607e909a7213e31d7752be4fb66a86d29fe1eb14bfb5cf + sha256: fddb70d9b5277016c77a80201021d40a2247104d9f4aa7bab7157b7e3f05b84b url: "https://pub.dev" source: hosted - version: "1.1.1" + version: "1.1.2" + code_assets: + dependency: transitive + description: + name: code_assets + sha256: "83ccdaa064c980b5596c35dd64a8d3ecc68620174ab9b90b6343b753aa721687" + url: "https://pub.dev" + source: hosted + version: "1.0.0" collection: dependency: "direct main" description: name: collection - sha256: ee67cb0715911d28db6bf4af1026078bd6f0128b07a5f66fb2ed94ec6783c09a + sha256: "2f5709ae4d3d59dd8f7cd309b4e023046b57d8a6c82130785d2b0e5868084e76" url: "https://pub.dev" source: hosted - version: "1.18.0" + version: "1.19.1" colorize: dependency: transitive description: @@ -209,54 +241,46 @@ packages: url: "https://pub.dev" source: hosted version: "3.0.0" - console: - dependency: transitive - description: - name: console - sha256: e04e7824384c5b39389acdd6dc7d33f3efe6b232f6f16d7626f194f6a01ad69a - url: "https://pub.dev" - source: hosted - version: "4.1.0" convert: dependency: transitive description: name: convert - sha256: "0f08b14755d163f6e2134cb58222dd25ea2a2ee8a195e53983d57c075324d592" + sha256: b30acd5944035672bc15c6b7a8b47d773e41e2f17de064350988c5d02adb1c68 url: "https://pub.dev" source: hosted - version: "3.1.1" + version: "3.1.2" coverage: dependency: transitive description: name: coverage - sha256: "8acabb8306b57a409bf4c83522065672ee13179297a6bb0cb9ead73948df7c76" + sha256: "5da775aa218eaf2151c721b16c01c7676fbfdd99cebba2bf64e8b807a28ff94d" url: "https://pub.dev" source: hosted - version: "1.7.2" + version: "1.15.0" cross_file: - dependency: transitive + dependency: "direct main" description: name: cross_file - sha256: "55d7b444feb71301ef6b8838dbc1ae02e63dd48c8773f3810ff53bb1e2945b32" + sha256: "28bb3ae56f117b5aec029d702a90f57d285cd975c3c5c281eaca38dbc47c5937" url: "https://pub.dev" source: hosted - version: "0.3.4+1" + version: "0.3.5+2" crypto: dependency: transitive description: name: crypto - sha256: ff625774173754681d66daaf4a448684fb04b78f902da9cb3d308c19cc5e8bab + sha256: c8ea0233063ba03258fbcf2ca4d6dadfefe14f02fab57702265467a19f27fadf url: "https://pub.dev" source: hosted - version: "3.0.3" + version: "3.0.7" csslib: dependency: transitive description: name: csslib - sha256: "831883fb353c8bdc1d71979e5b342c7d88acfbc643113c14ae51e2442ea0f20f" + sha256: "09bad715f418841f976c77db72d5398dc1253c21fb9c0c7f0b0b985860b2d58e" url: "https://pub.dev" source: hosted - version: "0.17.3" + version: "1.0.2" cupertino_icons: dependency: "direct main" description: @@ -265,38 +289,62 @@ packages: url: "https://pub.dev" source: hosted version: "1.0.8" + dart_code_linter: + dependency: "direct dev" + description: + name: dart_code_linter + sha256: "1b53722d9933a5f5d4580acc29c7f16b1fde66d21d1ecf7bb2a811caf3a42b42" + url: "https://pub.dev" + source: hosted + version: "3.2.1" + dart_earcut: + dependency: transitive + description: + name: dart_earcut + sha256: e485001bfc05dcbc437d7bfb666316182e3522d4c3f9668048e004d0eb2ce43b + url: "https://pub.dev" + source: hosted + version: "1.2.0" + dart_polylabel2: + dependency: transitive + description: + name: dart_polylabel2 + sha256: "7eeab15ce72894e4bdba6a8765712231fc81be0bd95247de4ad9966abc57adc6" + url: "https://pub.dev" + source: hosted + version: "1.0.0" + dart_style: + dependency: transitive + description: + name: dart_style + sha256: a9c30492da18ff84efe2422ba2d319a89942d93e58eb0b73d32abe822ef54b7b + url: "https://pub.dev" + source: hosted + version: "3.1.3" dart_webrtc: dependency: transitive description: name: dart_webrtc - sha256: b3a4f109c551a10170ece8fc79b5ca1b98223f24bcebc0f971d7fe35daad7a3b + sha256: "4ed7b9fa9924e5a81eb39271e2c2356739dd1039d60a13b86ba6c5f448625086" url: "https://pub.dev" source: hosted - version: "1.4.4" + version: "1.7.0" dbus: dependency: transitive description: name: dbus - sha256: "365c771ac3b0e58845f39ec6deebc76e3276aa9922b0cc60840712094d9047ac" + sha256: d0c98dcd4f5169878b6cf8f6e0a52403a9dff371a3e2f019697accbf6f44a270 url: "https://pub.dev" source: hosted - version: "0.7.10" - dependency_validator: - dependency: transitive - description: - name: dependency_validator - sha256: f727a5627aa405965fab4aef4f468e50a9b632ba0737fd2f98c932fec6d712b9 - url: "https://pub.dev" - source: hosted - version: "3.2.3" + version: "0.7.12" desktop_drop: dependency: "direct main" description: name: desktop_drop - sha256: d55a010fe46c8e8fcff4ea4b451a9ff84a162217bdb3b2a0aa1479776205e15d + sha256: e70b46b2d61f1af7a81a40d1f79b43c28a879e30a4ef31e87e9c27bea4d784e8 url: "https://pub.dev" source: hosted - version: "0.4.4" + version: "0.7.0" desktop_notifications: dependency: "direct main" description: @@ -305,163 +353,155 @@ packages: url: "https://pub.dev" source: hosted version: "0.6.3" + desktop_webview_window: + dependency: transitive + description: + name: desktop_webview_window + sha256: "57cf20d81689d5cbb1adfd0017e96b669398a669d927906073b0e42fc64111c0" + url: "https://pub.dev" + source: hosted + version: "0.2.3" device_info_plus: dependency: "direct main" description: name: device_info_plus - sha256: eead12d1a1ed83d8283ab4c2f3fca23ac4082f29f25f29dff0f758f57d06ec91 + sha256: "4df8babf73058181227e18b08e6ea3520cf5fc5d796888d33b7cb0f33f984b7c" url: "https://pub.dev" source: hosted - version: "10.1.0" + version: "12.3.0" device_info_plus_platform_interface: dependency: transitive description: name: device_info_plus_platform_interface - sha256: d3b01d5868b50ae571cd1dc6e502fc94d956b665756180f7b16ead09e836fd64 + sha256: e1ea89119e34903dca74b883d0dd78eb762814f97fb6c76f35e9ff74d261a18f url: "https://pub.dev" source: hosted - version: "7.0.0" + version: "7.0.3" dynamic_color: dependency: "direct main" description: name: dynamic_color - sha256: eae98052fa6e2826bdac3dd2e921c6ce2903be15c6b7f8b6d8a5d49b5086298d + sha256: "43a5a6679649a7731ab860334a5812f2067c2d9ce6452cf069c5e0c25336c17c" url: "https://pub.dev" source: hosted - version: "1.7.0" + version: "1.8.1" emoji_picker_flutter: dependency: "direct main" description: name: emoji_picker_flutter - sha256: "839200a2bd1af9a65d71133a5a246dbf5b24f7e4f6f4c5390130c2e0ed5f85af" + sha256: "984d3e9b9cf3175df9a868ce4a2d9611491e80e5d3b8e2b1e8991a4998972885" url: "https://pub.dev" source: hosted - version: "2.2.0" - emoji_proposal: - dependency: "direct main" - description: - name: emoji_proposal - sha256: e931bc42b54a65397b3df7915bb58ee7dcbd3ed81c3b8c256b9a5b210e94ea63 - url: "https://pub.dev" - source: hosted - version: "0.0.1" - emojis: - dependency: "direct main" - description: - name: emojis - sha256: "2e4d847c3f1e2670f30dc355909ce6fa7808b4e626c34a4dd503a360995a38bf" - url: "https://pub.dev" - source: hosted - version: "0.9.9" - enhanced_enum: - dependency: transitive - description: - name: enhanced_enum - sha256: "074c5a8b9664799ca91e1e8b68003b8694cb19998671cbafd9c7779c13fcdecf" - url: "https://pub.dev" - source: hosted - version: "0.2.4" - equatable: - dependency: transitive - description: - name: equatable - sha256: c2b87cb7756efdf69892005af546c56c0b5037f54d2a88269b4f347a505e3ca2 - url: "https://pub.dev" - source: hosted - version: "2.0.5" + version: "4.4.0" fake_async: dependency: transitive description: name: fake_async - sha256: "511392330127add0b769b75a987850d136345d9227c6b94c96a04cf4a391bf78" + sha256: "5368f224a74523e8d2e7399ea1638b37aecfca824a3cc4dfdf77bf1fa905ac44" url: "https://pub.dev" source: hosted - version: "1.3.1" + version: "1.3.3" ffi: dependency: transitive description: name: ffi - sha256: "493f37e7df1804778ff3a53bd691d8692ddf69702cf4c1c1096a2e41b4779e21" + sha256: "6d7fd89431262d8f3125e81b50d3847a091d846eafcd4fdb88dd06f36d705a45" url: "https://pub.dev" source: hosted - version: "2.1.2" + version: "2.2.0" file: dependency: transitive description: name: file - sha256: "5fc22d7c25582e38ad9a8515372cd9a93834027aacf1801cf01164dac0ffa08c" + sha256: a3b4f84adafef897088c160faf7dfffb7696046cb13ae90b508c2cbc95d3b8d4 url: "https://pub.dev" source: hosted - version: "7.0.0" + version: "7.0.1" file_picker: dependency: "direct main" description: name: file_picker - sha256: "45c70b43df893027e441a6fa0aacc8f484fb9f9c60c746dc8f1dc4f774cf55cd" + sha256: "57d9a1dd5063f85fa3107fb42d1faffda52fdc948cefd5fe5ea85267a5fc7343" url: "https://pub.dev" source: hosted - version: "8.0.2" + version: "10.3.10" + file_selector: + dependency: "direct main" + description: + name: file_selector + sha256: bd15e43e9268db636b53eeaca9f56324d1622af30e5c34d6e267649758c84d9a + url: "https://pub.dev" + source: hosted + version: "1.1.0" + file_selector_android: + dependency: transitive + description: + name: file_selector_android + sha256: "51e8fd0446de75e4b62c065b76db2210c704562d072339d333bd89c57a7f8a7c" + url: "https://pub.dev" + source: hosted + version: "0.5.2+4" + file_selector_ios: + dependency: transitive + description: + name: file_selector_ios + sha256: e2ecf2885c121691ce13b60db3508f53c01f869fb6e8dc5c1cfa771e4c46aeca + url: "https://pub.dev" + source: hosted + version: "0.5.3+5" file_selector_linux: dependency: transitive description: name: file_selector_linux - sha256: "045d372bf19b02aeb69cacf8b4009555fb5f6f0b7ad8016e5f46dd1387ddd492" + sha256: "2567f398e06ac72dcf2e98a0c95df2a9edd03c2c2e0cacd4780f20cdf56263a0" url: "https://pub.dev" source: hosted - version: "0.9.2+1" + version: "0.9.4" file_selector_macos: dependency: transitive description: name: file_selector_macos - sha256: b15c3da8bd4908b9918111fa486903f5808e388b8d1c559949f584725a6594d6 + sha256: "5e0bbe9c312416f1787a68259ea1505b52f258c587f12920422671807c4d618a" url: "https://pub.dev" source: hosted - version: "0.9.3+3" + version: "0.9.5" file_selector_platform_interface: dependency: transitive description: name: file_selector_platform_interface - sha256: a3994c26f10378a039faa11de174d7b78eb8f79e4dd0af2a451410c1a5c3f66b + sha256: "35e0bd61ebcdb91a3505813b055b09b79dfdc7d0aee9c09a7ba59ae4bb13dc85" url: "https://pub.dev" source: hosted - version: "2.6.2" + version: "2.7.0" + file_selector_web: + dependency: transitive + description: + name: file_selector_web + sha256: c4c0ea4224d97a60a7067eca0c8fd419e708ff830e0c83b11a48faf566cec3e7 + url: "https://pub.dev" + source: hosted + version: "0.9.4+2" file_selector_windows: dependency: transitive description: name: file_selector_windows - sha256: d3547240c20cabf205c7c7f01a50ecdbc413755814d6677f3cb366f04abcead0 + sha256: "62197474ae75893a62df75939c777763d39c2bc5f73ce5b88497208bc269abfd" url: "https://pub.dev" source: hosted - version: "0.9.3+1" + version: "0.9.3+5" fixnum: dependency: transitive description: name: fixnum - sha256: "25517a4deb0c03aa0f32fd12db525856438902d9c16536311e76cdc57b31d7d1" + sha256: b6dc7065e46c974bc7c5f143080a6764ec7a4be6da1285ececdc37be96de53be url: "https://pub.dev" source: hosted - version: "1.1.0" + version: "1.1.1" flutter: dependency: "direct main" description: flutter source: sdk version: "0.0.0" - flutter_app_badger: - dependency: "direct main" - description: - name: flutter_app_badger - sha256: "64d4a279bab862ed28850431b9b446b9820aaae0bf363322d51077419f930fa8" - url: "https://pub.dev" - source: hosted - version: "1.5.0" - flutter_cache_manager: - dependency: "direct main" - description: - name: flutter_cache_manager - sha256: "395d6b7831f21f3b989ebedbb785545932adb9afe2622c1ffacf7f4b53a7e544" - url: "https://pub.dev" - source: hosted - version: "3.3.2" flutter_driver: dependency: transitive description: flutter @@ -471,90 +511,10 @@ packages: dependency: "direct main" description: name: flutter_foreground_task - sha256: d40a1ddd5f275450d2e32055e7f884796c028a02ac26c751c20916576f79e132 + sha256: "1903697944a31f596622e51a6af55e3a9dfb27762f9763ab2841184098c6b0ba" url: "https://pub.dev" source: hosted - version: "6.2.0" - flutter_highlighter: - dependency: "direct main" - description: - name: flutter_highlighter - sha256: "93173afd47a9ada53f3176371755e7ea4a1065362763976d06d6adfb4d946e10" - url: "https://pub.dev" - source: hosted - version: "0.1.1" - flutter_html: - dependency: "direct main" - description: - name: flutter_html - sha256: "02ad69e813ecfc0728a455e4bf892b9379983e050722b1dce00192ee2e41d1ee" - url: "https://pub.dev" - source: hosted - version: "3.0.0-beta.2" - flutter_html_table: - dependency: "direct main" - description: - name: flutter_html_table - sha256: e20c72d67ea2512e7b4949f6f7dd13d004e773b0f82c586a21f895e6bd90383c - url: "https://pub.dev" - source: hosted - version: "3.0.0-beta.2" - flutter_keyboard_visibility: - dependency: transitive - description: - name: flutter_keyboard_visibility - sha256: "98664be7be0e3ffca00de50f7f6a287ab62c763fc8c762e0a21584584a3ff4f8" - url: "https://pub.dev" - source: hosted - version: "6.0.0" - flutter_keyboard_visibility_linux: - dependency: transitive - description: - name: flutter_keyboard_visibility_linux - sha256: "6fba7cd9bb033b6ddd8c2beb4c99ad02d728f1e6e6d9b9446667398b2ac39f08" - url: "https://pub.dev" - source: hosted - version: "1.0.0" - flutter_keyboard_visibility_macos: - dependency: transitive - description: - name: flutter_keyboard_visibility_macos - sha256: c5c49b16fff453dfdafdc16f26bdd8fb8d55812a1d50b0ce25fc8d9f2e53d086 - url: "https://pub.dev" - source: hosted - version: "1.0.0" - flutter_keyboard_visibility_platform_interface: - dependency: transitive - description: - name: flutter_keyboard_visibility_platform_interface - sha256: e43a89845873f7be10cb3884345ceb9aebf00a659f479d1c8f4293fcb37022a4 - url: "https://pub.dev" - source: hosted - version: "2.0.0" - flutter_keyboard_visibility_web: - dependency: transitive - description: - name: flutter_keyboard_visibility_web - sha256: d3771a2e752880c79203f8d80658401d0c998e4183edca05a149f5098ce6e3d1 - url: "https://pub.dev" - source: hosted - version: "2.0.0" - flutter_keyboard_visibility_windows: - dependency: transitive - description: - name: flutter_keyboard_visibility_windows - sha256: fc4b0f0b6be9b93ae527f3d527fb56ee2d918cd88bbca438c478af7bcfd0ef73 - url: "https://pub.dev" - source: hosted - version: "1.0.0" - flutter_layout_grid: - dependency: transitive - description: - name: flutter_layout_grid - sha256: "962a7ec8c7ea46c3b10606dac9c964f9143d10daa5ca28e40f4ce14eeef85b2a" - url: "https://pub.dev" - source: hosted - version: "2.0.6" + version: "9.2.1" flutter_linkify: dependency: "direct main" description: @@ -567,34 +527,42 @@ packages: dependency: "direct dev" description: name: flutter_lints - sha256: "9e8c3858111da373efc5aa341de011d9bd23e2c5c5e0c62bccf32438e192d7b1" + sha256: "3105dc8492f6183fb076ccf1f351ac3d60564bff92e20bfc4af9cc1651f4e7e1" url: "https://pub.dev" source: hosted - version: "3.0.2" + version: "6.0.0" flutter_local_notifications: dependency: "direct main" description: name: flutter_local_notifications - sha256: "8cdc719114ab1c86c64bb7a86d3a679674c3637edd229e3a994797d4a1504ce4" + sha256: "2b50e938a275e1ad77352d6a25e25770f4130baa61eaf02de7a9a884680954ad" url: "https://pub.dev" source: hosted - version: "17.1.0" + version: "20.1.0" flutter_local_notifications_linux: dependency: transitive description: name: flutter_local_notifications_linux - sha256: "33f741ef47b5f63cc7f78fe75eeeac7e19f171ff3c3df054d84c1e38bedb6a03" + sha256: dce0116868cedd2cdf768af0365fc37ff1cbef7c02c4f51d0587482e625868d0 url: "https://pub.dev" source: hosted - version: "4.0.0+1" + version: "7.0.0" flutter_local_notifications_platform_interface: dependency: transitive description: name: flutter_local_notifications_platform_interface - sha256: "340abf67df238f7f0ef58f4a26d2a83e1ab74c77ab03cd2b2d5018ac64db30b7" + sha256: "23de31678a48c084169d7ae95866df9de5c9d2a44be3e5915a2ff067aeeba899" url: "https://pub.dev" source: hosted - version: "7.1.0" + version: "10.0.0" + flutter_local_notifications_windows: + dependency: transitive + description: + name: flutter_local_notifications_windows + sha256: e97a1a3016512437d9c0b12fae7d1491c3c7b9aa7f03a69b974308840656b02a + url: "https://pub.dev" + source: hosted + version: "2.0.1" flutter_localizations: dependency: "direct main" description: flutter @@ -604,152 +572,127 @@ packages: dependency: "direct main" description: name: flutter_map - sha256: cda8d72135b697f519287258b5294a57ce2f2a5ebf234f0e406aad4dc14c9399 + sha256: "391e7dc95cc3f5190748210a69d4cfeb5d8f84dcdfa9c3235d0a9d7742ccb3f8" url: "https://pub.dev" source: hosted - version: "6.1.0" - flutter_math_fork: - dependency: "direct main" - description: - name: flutter_math_fork - sha256: "94bee4642892a94939af0748c6a7de0ff8318feee588379dcdfea7dc5cba06c8" - url: "https://pub.dev" - source: hosted - version: "0.7.2" + version: "8.2.2" flutter_native_splash: dependency: "direct dev" description: name: flutter_native_splash - sha256: edf39bcf4d74aca1eb2c1e43c3e445fd9f494013df7f0da752fefe72020eedc0 + sha256: "4fb9f4113350d3a80841ce05ebf1976a36de622af7d19aca0ca9a9911c7ff002" url: "https://pub.dev" source: hosted - version: "2.4.0" - flutter_olm: + version: "2.4.7" + flutter_new_badger: dependency: "direct main" description: - name: flutter_olm - sha256: "69aaac45d854e74d17d04dac8a0ca3f548266d271a0f0fa7600e006e81432417" + name: flutter_new_badger + sha256: d3742ace8009663db1ac6ba0377b092f479c35deb33e05514ba05cc0b0a5aaaa url: "https://pub.dev" source: hosted - version: "1.3.2" - flutter_openssl_crypto: - dependency: "direct main" - description: - name: flutter_openssl_crypto - sha256: "6dcecf6f7c1804ae6f5d73ee05df8af72ea8133bf2447d25979d739503186c96" - url: "https://pub.dev" - source: hosted - version: "0.3.0" + version: "1.1.1" flutter_plugin_android_lifecycle: dependency: transitive description: name: flutter_plugin_android_lifecycle - sha256: "8cf40eebf5dec866a6d1956ad7b4f7016e6c0cc69847ab946833b7d43743809f" + sha256: ee8068e0e1cd16c4a82714119918efdeed33b3ba7772c54b5d094ab53f9b7fd1 url: "https://pub.dev" source: hosted - version: "2.0.19" - flutter_ringtone_player: - dependency: "direct main" + version: "2.0.33" + flutter_rust_bridge: + dependency: transitive description: - name: flutter_ringtone_player - sha256: bdbf0ba551fd81cf02fab5c45800dc0006fc51167a1ed252321046fd8ac2bce3 + name: flutter_rust_bridge + sha256: "37ef40bc6f863652e865f0b2563ea07f0d3c58d8efad803cc01933a4b2ee067e" url: "https://pub.dev" source: hosted - version: "4.0.0+2" + version: "2.11.1" flutter_secure_storage: dependency: "direct main" description: name: flutter_secure_storage - sha256: ffdbb60130e4665d2af814a0267c481bcf522c41ae2e43caf69fa0146876d685 + sha256: da922f2aab2d733db7e011a6bcc4a825b844892d4edd6df83ff156b09a9b2e40 url: "https://pub.dev" source: hosted - version: "9.0.0" - flutter_secure_storage_linux: - dependency: "direct overridden" - description: - name: flutter_secure_storage_linux - sha256: "0912ae29a572230ad52d8a4697e5518d7f0f429052fd51df7e5a7952c7efe2a3" - url: "https://pub.dev" - source: hosted - version: "1.1.3" - flutter_secure_storage_macos: + version: "10.0.0" + flutter_secure_storage_darwin: dependency: transitive description: - name: flutter_secure_storage_macos - sha256: bd33935b4b628abd0b86c8ca20655c5b36275c3a3f5194769a7b3f37c905369c + name: flutter_secure_storage_darwin + sha256: "8878c25136a79def1668c75985e8e193d9d7d095453ec28730da0315dc69aee3" url: "https://pub.dev" source: hosted - version: "3.0.1" + version: "0.2.0" + flutter_secure_storage_linux: + dependency: transitive + description: + name: flutter_secure_storage_linux + sha256: "2b5c76dce569ab752d55a1cee6a2242bcc11fdba927078fb88c503f150767cda" + url: "https://pub.dev" + source: hosted + version: "3.0.0" flutter_secure_storage_platform_interface: dependency: transitive description: name: flutter_secure_storage_platform_interface - sha256: "0d4d3a5dd4db28c96ae414d7ba3b8422fd735a8255642774803b2532c9a61d7e" + sha256: "8ceea1223bee3c6ac1a22dabd8feefc550e4729b3675de4b5900f55afcb435d6" url: "https://pub.dev" source: hosted - version: "1.0.2" + version: "2.0.1" flutter_secure_storage_web: dependency: transitive description: name: flutter_secure_storage_web - sha256: "30f84f102df9dcdaa2241866a958c2ec976902ebdaa8883fbfe525f1f2f3cf20" + sha256: "6a1137df62b84b54261dca582c1c09ea72f4f9a4b2fcee21b025964132d5d0c3" url: "https://pub.dev" source: hosted - version: "1.1.2" + version: "2.1.0" flutter_secure_storage_windows: dependency: transitive description: name: flutter_secure_storage_windows - sha256: "5809c66f9dd3b4b93b0a6e2e8561539405322ee767ac2f64d084e2ab5429d108" + sha256: "3b7c8e068875dfd46719ff57c90d8c459c87f2302ed6b00ff006b3c9fcad1613" url: "https://pub.dev" source: hosted - version: "3.0.0" - flutter_shortcuts: + version: "4.1.0" + flutter_shortcuts_new: dependency: "direct main" description: - path: "." - ref: HEAD - resolved-ref: "930c51d56c87a7f8cefdf8c1db52c194baddc37d" - url: "https://github.com/krille-chan/flutter_shortcuts.git" - source: git - version: "1.4.0" - flutter_svg: - dependency: transitive - description: - name: flutter_svg - sha256: "7b4ca6cf3304575fe9c8ec64813c8d02ee41d2afe60bcfe0678bcb5375d596a2" + name: flutter_shortcuts_new + sha256: "16ee1c8a9bc9586b5117ebb774a8ff6b396f856743e97251eb483c4dc5769d7f" url: "https://pub.dev" source: hosted - version: "2.0.10+1" + version: "2.0.0" flutter_test: dependency: "direct dev" description: flutter source: sdk version: "0.0.0" - flutter_typeahead: + flutter_vodozemac: dependency: "direct main" description: - name: flutter_typeahead - sha256: d64712c65db240b1057559b952398ebb6e498077baeebf9b0731dade62438a6d + name: flutter_vodozemac + sha256: ef4c3580a7f2fe8eebb7602c6cba593a42b4a5e5466c372a022f77ccc14914a5 url: "https://pub.dev" source: hosted - version: "5.2.0" + version: "0.5.0" flutter_web_auth_2: dependency: "direct main" description: name: flutter_web_auth_2 - sha256: "3ea3a0cc539ca74319f4f2f7484f62742fe5b2ff9a0fca37575426d6e6f07901" + sha256: "432ff8c7b2834eaeec3378d99e24a0210b9ac2f453b3f7a7d739a5c09069fba3" url: "https://pub.dev" source: hosted - version: "3.1.1" + version: "5.0.1" flutter_web_auth_2_platform_interface: dependency: transitive description: name: flutter_web_auth_2_platform_interface - sha256: e8669e262005a8354389ba2971f0fc1c36188481234ff50d013aaf993f30f739 + sha256: ba0fbba55bffb47242025f96852ad1ffba34bc451568f56ef36e613612baffab url: "https://pub.dev" source: hosted - version: "3.1.0" + version: "5.0.0" flutter_web_plugins: dependency: transitive description: flutter @@ -759,135 +702,151 @@ packages: dependency: "direct main" description: name: flutter_webrtc - sha256: "20eac28848a2dffb26cc2b2870a5164613904511a0b7e8f4825e31a2768175d2" + sha256: c549ea8ffb20167110ad0a28e5f17a2650b5bea8837d984898cd9b0ffd5fa78b url: "https://pub.dev" source: hosted - version: "0.10.3" + version: "1.3.1" frontend_server_client: dependency: transitive description: name: frontend_server_client - sha256: "408e3ca148b31c20282ad6f37ebfa6f4bdc8fede5b74bc2f08d9d92b55db3612" + sha256: f64a0333a82f30b0cca061bc3d143813a486dc086b574bfb233b7c1372427694 url: "https://pub.dev" source: hosted - version: "3.2.0" + version: "4.0.0" fuchsia_remote_debug_protocol: dependency: transitive description: flutter source: sdk version: "0.0.0" - future_loading_dialog: - dependency: "direct main" + geoclue: + dependency: transitive description: - name: future_loading_dialog - sha256: "2718b1a308db452da32ab9bca9ad496ff92b683e217add9e92cf50520f90537e" + name: geoclue + sha256: c2a998c77474fc57aa00c6baa2928e58f4b267649057a1c76738656e9dbd2a7f url: "https://pub.dev" source: hosted - version: "0.3.0" + version: "0.1.1" geolocator: dependency: "direct main" description: name: geolocator - sha256: b8f520252c5c66851295bcc263bc8ae7555501938427f72216ba7688702e261d + sha256: "79939537046c9025be47ec645f35c8090ecadb6fe98eba146a0d25e8c1357516" url: "https://pub.dev" source: hosted - version: "7.7.1" + version: "14.0.2" geolocator_android: - dependency: "direct overridden" + dependency: transitive description: name: geolocator_android - sha256: a4834a98fab5124f2d5b881e62a40ebb4a71d6aad6ad577e047a3ffb69b67dac - url: "https://hanntech-gmbh.gitlab.io/free2pass/flutter-geolocator-floss/" + sha256: "179c3cb66dfa674fc9ccbf2be872a02658724d1c067634e2c427cf6df7df901a" + url: "https://pub.dev" source: hosted - version: "1.0.1" + version: "5.0.2" geolocator_apple: dependency: transitive description: name: geolocator_apple - sha256: "1e8e398cc92151d946a4bbd34e2075885333e42d35ca33e418e7ce7b0a29991e" + sha256: dbdd8789d5aaf14cf69f74d4925ad1336b4433a6efdf2fce91e8955dc921bf22 url: "https://pub.dev" source: hosted - version: "1.2.2" + version: "2.3.13" + geolocator_linux: + dependency: transitive + description: + name: geolocator_linux + sha256: d64112a205931926f4363bb6bd48f14cb38e7326833041d170615586cd143797 + url: "https://pub.dev" + source: hosted + version: "0.2.4" geolocator_platform_interface: dependency: transitive description: name: geolocator_platform_interface - sha256: "9d6f34a8a4b704d504f34acc5e52d880a7d2caedd99739902d6319179b0336d4" + sha256: "30cb64f0b9adcc0fb36f628b4ebf4f731a2961a0ebd849f4b56200205056fe67" url: "https://pub.dev" source: hosted - version: "2.3.6" + version: "4.2.6" geolocator_web: dependency: transitive description: name: geolocator_web - sha256: "0b9e0ec13ce2211085cae0055b3516c975bd6cfe2878a20c8f13611f1a259855" + sha256: b1ae9bdfd90f861fde8fd4f209c37b953d65e92823cb73c7dee1fa021b06f172 url: "https://pub.dev" source: hosted - version: "2.0.6" - get_it: + version: "4.1.3" + geolocator_windows: dependency: transitive description: - name: get_it - sha256: d85128a5dae4ea777324730dc65edd9c9f43155c109d5cc0a69cab74139fbac1 + name: geolocator_windows + sha256: "175435404d20278ffd220de83c2ca293b73db95eafbdc8131fe8609be1421eb6" url: "https://pub.dev" source: hosted - version: "7.7.0" + version: "0.2.5" glob: dependency: transitive description: name: glob - sha256: "0e7014b3b7d4dac1ca4d6114f82bf1782ee86745b9b42a92c9289c23d8a0ab63" + sha256: c3f1ee72c96f8f78935e18aa8cecced9ab132419e8625dc187e1c2408efc20de url: "https://pub.dev" source: hosted - version: "2.1.2" + version: "2.1.3" go_router: dependency: "direct main" description: name: go_router - sha256: "466425a64508ca00983882f523400d9169365cb9b464e2e2419f3b6545ff9c51" + sha256: "7974313e217a7771557add6ff2238acb63f635317c35fa590d348fb238f00896" url: "https://pub.dev" source: hosted - version: "14.0.1" - gradient_borders: + version: "17.1.0" + gsettings: dependency: transitive description: - name: gradient_borders - sha256: "69eeaff519d145a4c6c213ada1abae386bcc8981a4970d923e478ce7ba19e309" + name: gsettings + sha256: "1b0ce661f5436d2db1e51f3c4295a49849f03d304003a7ba177d01e3a858249c" url: "https://pub.dev" source: hosted - version: "1.0.0" - highlighter: + version: "0.2.8" + gtk: dependency: transitive description: - name: highlighter - sha256: "92180c72b9da8758e1acf39a45aa305a97dcfe2fdc8f3d1d2947c23f2772bfbc" + name: gtk + sha256: e8ce9ca4b1df106e4d72dad201d345ea1a036cc12c360f1a7d5a758f78ffa42c url: "https://pub.dev" source: hosted - version: "0.1.1" - hive: + version: "2.1.0" + handy_window: dependency: "direct main" description: - name: hive - sha256: "8dcf6db979d7933da8217edcec84e9df1bdb4e4edc7fc77dbd5aa74356d6d941" + name: handy_window + sha256: "06cc2747607022dbcea54b9b863db0962d34d606f998831a9b05a551c5184462" url: "https://pub.dev" source: hosted - version: "2.2.3" - hive_flutter: + version: "0.4.2" + highlight: dependency: "direct main" description: - name: hive_flutter - sha256: dca1da446b1d808a51689fb5d0c6c9510c0a2ba01e22805d492c73b68e33eecc + name: highlight + sha256: "5353a83ffe3e3eca7df0abfb72dcf3fa66cc56b953728e7113ad4ad88497cf21" url: "https://pub.dev" source: hosted - version: "1.1.0" + version: "0.7.0" + hooks: + dependency: transitive + description: + name: hooks + sha256: "7a08a0d684cb3b8fb604b78455d5d352f502b68079f7b80b831c62220ab0a4f6" + url: "https://pub.dev" + source: hosted + version: "1.0.1" html: dependency: "direct main" description: name: html - sha256: "3a7812d5bcd2894edf53dfaf8cd640876cf6cef50a8f238745c8b8120ea74d3a" + sha256: "6d1264f2dffa1b1101c25a91dff0dc2daee4c18e87cd8538729773c073dbf602" url: "https://pub.dev" source: hosted - version: "0.15.4" + version: "0.15.6" html_unescape: dependency: transitive description: @@ -900,98 +859,98 @@ packages: dependency: "direct main" description: name: http - sha256: "761a297c042deedc1ffbb156d6e2af13886bb305c2a343a4d972504cd67dd938" + sha256: "87721a4a50b19c7f1d49001e51409bddc46303966ce89a65af4f4e6004896412" url: "https://pub.dev" source: hosted - version: "1.2.1" + version: "1.6.0" http_multi_server: dependency: transitive description: name: http_multi_server - sha256: "97486f20f9c2f7be8f514851703d0119c3596d14ea63227af6f7a481ef2b2f8b" + sha256: aa6199f908078bb1c5efb8d8638d4ae191aac11b311132c3ef48ce352fb52ef8 url: "https://pub.dev" source: hosted - version: "3.2.1" + version: "3.2.2" http_parser: dependency: transitive description: name: http_parser - sha256: "2aa08ce0341cc9b354a498388e30986515406668dbcc4f7c950c3e715496693b" + sha256: "178d74305e7866013777bab2c3d8726205dc5a4dd935297175b19a23a2e66571" url: "https://pub.dev" source: hosted - version: "4.0.2" + version: "4.1.2" image: dependency: "direct main" description: name: image - sha256: "4c68bfd5ae83e700b5204c1e74451e7bf3cf750e6843c6e158289cf56bda018e" + sha256: f9881ff4998044947ec38d098bc7c8316ae1186fa786eddffdb867b9bc94dfce url: "https://pub.dev" source: hosted - version: "4.1.7" + version: "4.8.0" image_picker: dependency: "direct main" description: name: image_picker - sha256: fe9ee64ccb8d599a5dfb0e21cc6652232c610bcf667af4e79b9eb175cc30a7a5 + sha256: "784210112be18ea55f69d7076e2c656a4e24949fa9e76429fe53af0c0f4fa320" url: "https://pub.dev" source: hosted - version: "1.1.0" + version: "1.2.1" image_picker_android: dependency: transitive description: name: image_picker_android - sha256: "8e75431a62b7feb4fd55cb4a5c6f0ac4564460ec5dc09f9c4a0d50a5ce7c4cb9" + sha256: "518a16108529fc18657a3e6dde4a043dc465d16596d20ab2abd49a4cac2e703d" url: "https://pub.dev" source: hosted - version: "0.8.10" + version: "0.8.13+13" image_picker_for_web: dependency: transitive description: name: image_picker_for_web - sha256: "5d6eb13048cd47b60dbf1a5495424dea226c5faf3950e20bf8120a58efb5b5f3" + sha256: "66257a3191ab360d23a55c8241c91a6e329d31e94efa7be9cf7a212e65850214" url: "https://pub.dev" source: hosted - version: "3.0.4" + version: "3.1.1" image_picker_ios: dependency: transitive description: name: image_picker_ios - sha256: f74064bc548b5164a033ec05638e23c91be1a249c255e0f56319dddffd759794 + sha256: b9c4a438a9ff4f60808c9cf0039b93a42bb6c2211ef6ebb647394b2b3fa84588 url: "https://pub.dev" source: hosted - version: "0.8.10+1" + version: "0.8.13+6" image_picker_linux: dependency: transitive description: name: image_picker_linux - sha256: "4ed1d9bb36f7cd60aa6e6cd479779cc56a4cb4e4de8f49d487b1aaad831300fa" + sha256: "1f81c5f2046b9ab724f85523e4af65be1d47b038160a8c8deed909762c308ed4" url: "https://pub.dev" source: hosted - version: "0.2.1+1" + version: "0.2.2" image_picker_macos: dependency: transitive description: name: image_picker_macos - sha256: "3f5ad1e8112a9a6111c46d0b57a7be2286a9a07fc6e1976fdf5be2bd31d4ff62" + sha256: "86f0f15a309de7e1a552c12df9ce5b59fe927e71385329355aec4776c6a8ec91" url: "https://pub.dev" source: hosted - version: "0.2.1+1" + version: "0.2.2+1" image_picker_platform_interface: dependency: transitive description: name: image_picker_platform_interface - sha256: "9ec26d410ff46f483c5519c29c02ef0e02e13a543f882b152d4bfd2f06802f80" + sha256: "567e056716333a1647c64bb6bd873cff7622233a5c3f694be28a583d4715690c" url: "https://pub.dev" source: hosted - version: "2.10.0" + version: "2.11.1" image_picker_windows: dependency: transitive description: name: image_picker_windows - sha256: "6ad07afc4eb1bc25f3a01084d28520496c4a3bb0cb13685435838167c9dcedeb" + sha256: d248c86554a72b5495a31c56f060cf73a41c7ff541689327b1a7dbccc33adfae url: "https://pub.dev" source: hosted - version: "0.2.1+1" + version: "0.2.2" import_sorter: dependency: "direct dev" description: @@ -1005,30 +964,22 @@ packages: description: flutter source: sdk version: "0.0.0" - intersperse: - dependency: transitive - description: - name: intersperse - sha256: "2f8a905c96f6cbba978644a3d5b31b8d86ddc44917662df7d27a61f3df66a576" - url: "https://pub.dev" - source: hosted - version: "2.0.0" intl: dependency: "direct main" description: name: intl - sha256: d6f56758b7d3014a48af9701c085700aac781a92a87a62b1333b46d8879661cf + sha256: "3df61194eb431efc39c4ceba583b95633a403f46c9fd341e550ce0bfa50e9aa5" url: "https://pub.dev" source: hosted - version: "0.19.0" + version: "0.20.2" io: dependency: transitive description: name: io - sha256: "2ec25704aba361659e10e3e5f5d672068d332fc8ac516421d483a11e5cbd061e" + sha256: dfd5a80599cf0165756e3181807ed3e77daf6dd4137caaad72d0b7931597650b url: "https://pub.dev" source: hosted - version: "1.0.4" + version: "1.0.5" js: dependency: transitive description: @@ -1041,43 +992,34 @@ packages: dependency: transitive description: name: json_annotation - sha256: "1ce844379ca14835a50d2f019a3099f419082cfdd231cd86a142af94dd5c6bb1" + sha256: "805fa86df56383000f640384b282ce0cb8431f1a7a2396de92fb66186d8c57df" url: "https://pub.dev" source: hosted - version: "4.9.0" + version: "4.10.0" just_audio: dependency: "direct main" description: name: just_audio - sha256: b7cb6bbf3750caa924d03f432ba401ec300fd90936b3f73a9b33d58b1e96286b + sha256: "9694e4734f515f2a052493d1d7e0d6de219ee0427c7c29492e246ff32a219908" url: "https://pub.dev" source: hosted - version: "0.9.37" + version: "0.10.5" just_audio_platform_interface: dependency: transitive description: name: just_audio_platform_interface - sha256: c3dee0014248c97c91fe6299edb73dc4d6c6930a2f4f713579cd692d9e47f4a1 + sha256: "2532c8d6702528824445921c5ff10548b518b13f808c2e34c2fd54793b999a6a" url: "https://pub.dev" source: hosted - version: "4.2.2" + version: "4.6.0" just_audio_web: dependency: transitive description: name: just_audio_web - sha256: "134356b0fe3d898293102b33b5fd618831ffdc72bb7a1b726140abdf22772b70" + sha256: "6ba8a2a7e87d57d32f0f7b42856ade3d6a9fbe0f1a11fabae0a4f00bb73f0663" url: "https://pub.dev" source: hosted - version: "0.4.9" - keyboard_shortcuts: - dependency: "direct main" - description: - path: "." - ref: null-safety - resolved-ref: a3d4020911860ff091d90638ab708604b71d2c5a - url: "https://github.com/TheOneWithTheBraid/keyboard_shortcuts.git" - source: git - version: "0.1.4" + version: "0.4.16" latlong2: dependency: "direct main" description: @@ -1090,34 +1032,34 @@ packages: dependency: transitive description: name: leak_tracker - sha256: "7f0df31977cb2c0b88585095d168e689669a2cc9b97c309665e3386f3e9d341a" + sha256: "33e2e26bdd85a0112ec15400c8cbffea70d0f9c3407491f672a2fad47915e2de" url: "https://pub.dev" source: hosted - version: "10.0.4" + version: "11.0.2" leak_tracker_flutter_testing: dependency: transitive description: name: leak_tracker_flutter_testing - sha256: "06e98f569d004c1315b991ded39924b21af84cf14cc94791b8aea337d25b57f8" + sha256: "1dbc140bb5a23c75ea9c4811222756104fbcd1a27173f0c34ca01e16bea473c1" url: "https://pub.dev" source: hosted - version: "3.0.3" + version: "3.0.10" leak_tracker_testing: dependency: transitive description: name: leak_tracker_testing - sha256: "6ba465d5d76e67ddf503e1161d1f4a6bc42306f9d66ca1e8f079a47290fb06d3" + sha256: "8d5a2d49f4a66b49744b23b018848400d23e54caf9463f4eb20df3eb8acb2eb1" url: "https://pub.dev" source: hosted - version: "3.0.1" + version: "3.0.2" license_checker: dependency: "direct dev" description: name: license_checker - sha256: eea27638e42bc98fd91a6a8187eb57e5617e2c3c8b313a5d51b14bec7a8685e1 + sha256: "8a35b6946e50811e070ac6fe4717ee431cd1a334e080df2116956b54b0bb0d0f" url: "https://pub.dev" source: hosted - version: "1.6.0" + version: "1.6.2" linkify: dependency: "direct main" description: @@ -1130,18 +1072,10 @@ packages: dependency: transitive description: name: lints - sha256: cbf8d4b858bb0134ef3ef87841abdf8d63bfc255c266b7bf6b39daa1085c4290 + sha256: "12f842a479589fea194fe5c5a3095abc7be0c1f2ddfa9a0e76aed1dbd26a87df" url: "https://pub.dev" source: hosted - version: "3.0.0" - list_counter: - dependency: transitive - description: - name: list_counter - sha256: c447ae3dfcd1c55f0152867090e67e219d42fe6d4f2807db4bbe8b8d69912237 - url: "https://pub.dev" - source: hosted - version: "1.0.2" + version: "6.1.0" lists: dependency: transitive description: @@ -1154,74 +1088,58 @@ packages: dependency: transitive description: name: logger - sha256: "8c94b8c219e7e50194efc8771cd0e9f10807d8d3e219af473d89b06cc2ee4e04" + sha256: a7967e31b703831a893bbc3c3dd11db08126fe5f369b5c648a36f821979f5be3 url: "https://pub.dev" source: hosted - version: "2.2.0" + version: "2.6.2" logging: dependency: transitive description: name: logging - sha256: "623a88c9594aa774443aa3eb2d41807a48486b5613e67599fb4c41c0ad47c340" + sha256: c8245ada5f1717ed44271ed1c26b8ce85ca3228fd2ffdb75468ab01979309d61 url: "https://pub.dev" source: hosted - version: "1.2.0" - macos_ui: - dependency: transitive - description: - name: macos_ui - sha256: d351f0bada7e5b0cee8cf394299878a6c04e5cfcd784fa1d40e44299501124d8 - url: "https://pub.dev" - source: hosted - version: "2.0.5" - macos_window_utils: - dependency: transitive - description: - name: macos_window_utils - sha256: "230be594d26f6dee92c5a1544f4242d25138a5bfb9f185b27f14de3949ef0be8" - url: "https://pub.dev" - source: hosted - version: "1.5.0" + version: "1.3.0" markdown: dependency: transitive description: name: markdown - sha256: ef2a1298144e3f985cc736b22e0ccdaf188b5b3970648f2d9dc13efd1d9df051 + sha256: "935e23e1ff3bc02d390bad4d4be001208ee92cc217cb5b5a6c19bc14aaa318c1" url: "https://pub.dev" source: hosted - version: "7.2.2" + version: "7.3.0" matcher: dependency: transitive description: name: matcher - sha256: d2323aa2060500f906aa31a895b4030b6da3ebdcc5619d14ce1aada65cd161cb + sha256: "12956d0ad8390bbcc63ca2e1469c0619946ccb52809807067a7020d57e647aa6" url: "https://pub.dev" source: hosted - version: "0.12.16+1" + version: "0.12.18" material_color_utilities: dependency: transitive description: name: material_color_utilities - sha256: "0e0a020085b65b6083975e499759762399b4475f766c21668c4ecca34ea74e5a" + sha256: "9c337007e82b1889149c82ed242ed1cb24a66044e30979c44912381e9be4c48b" url: "https://pub.dev" source: hosted - version: "0.8.0" + version: "0.13.0" matrix: dependency: "direct main" description: name: matrix - sha256: bb6de59d0f69e10bb6893130a967f1ffcbfa3d3ffed3864f0736ce3d968e669c + sha256: c0214ee99a73957d3c02d54a60afcf9acee577b0924749085d6fdf556e8eba42 url: "https://pub.dev" source: hosted - version: "0.29.12" + version: "6.1.1" meta: dependency: transitive description: name: meta - sha256: "7687075e408b093f36e6bbf6c91878cc0d4cd10f409506f7bc996f68220b9136" + sha256: "23f08335362185a5ea2ad3a4e597f1375e78bce8a040df5c600c8d3552ef2394" url: "https://pub.dev" source: hosted - version: "1.12.0" + version: "1.17.0" mgrs_dart: dependency: transitive description: @@ -1231,29 +1149,29 @@ packages: source: hosted version: "2.0.0" mime: - dependency: transitive + dependency: "direct main" description: name: mime - sha256: "2e123074287cc9fd6c09de8336dae606d1ddb88d9ac47358826db698c176a1f2" + sha256: "41a20518f0cb1256669420fdba0cd90d21561e560ac240f26ef8322e45bb7ed6" url: "https://pub.dev" source: hosted - version: "1.0.5" - msix: - dependency: "direct dev" - description: - name: msix - sha256: "519b183d15dc9f9c594f247e2d2339d855cf0eaacc30e19b128e14f3ecc62047" - url: "https://pub.dev" - source: hosted - version: "3.16.7" + version: "2.0.0" native_imaging: dependency: "direct main" description: name: native_imaging - sha256: "182ccd8e0815a8a2158500ef66c828c030f6b9e05783e41e22f33bbcfd46a3d5" + sha256: ced7acb18b80a431578c9068eb9c3ee75f8df39491e8adaf471635bac282d651 url: "https://pub.dev" source: hosted - version: "0.1.1" + version: "0.4.0" + native_toolchain_c: + dependency: transitive + description: + name: native_toolchain_c + sha256: "89e83885ba09da5fdf2cdacc8002a712ca238c28b7f717910b34bcd27b0d03ac" + url: "https://pub.dev" + source: hosted + version: "0.17.4" nested: dependency: transitive description: @@ -1270,94 +1188,94 @@ packages: url: "https://pub.dev" source: hosted version: "2.0.2" - olm: + objective_c: dependency: transitive description: - name: olm - sha256: "37948a6576949256f3ee1d0063d5b408634ff7e452b9a5c2f6410f9d7ced1c20" + name: objective_c + sha256: "100a1c87616ab6ed41ec263b083c0ef3261ee6cd1dc3b0f35f8ddfa4f996fe52" url: "https://pub.dev" source: hosted - version: "2.0.3" + version: "9.3.0" + opus_caf_converter_dart: + dependency: "direct main" + description: + name: opus_caf_converter_dart + sha256: e08156066916f790a54df305e103d6dec4d853ec23147e6a02eda3c06f67ba1a + url: "https://pub.dev" + source: hosted + version: "1.0.1" package_config: dependency: transitive description: name: package_config - sha256: "1c5b77ccc91e4823a5af61ee74e6b972db1ef98c2ff5a18d3161c982a55448bd" + sha256: f096c55ebb7deb7e384101542bfba8c52696c1b56fca2eb62827989ef2353bbc url: "https://pub.dev" source: hosted - version: "2.1.0" + version: "2.2.0" package_info_plus: dependency: "direct main" description: name: package_info_plus - sha256: cb44f49b6e690fa766f023d5b22cac6b9affe741dd792b6ac7ad4fabe0d7b097 + sha256: f69da0d3189a4b4ceaeb1a3defb0f329b3b352517f52bed4290f83d4f06bc08d url: "https://pub.dev" source: hosted - version: "6.0.0" + version: "9.0.0" package_info_plus_platform_interface: dependency: transitive description: name: package_info_plus_platform_interface - sha256: "9bc8ba46813a4cc42c66ab781470711781940780fd8beddd0c3da62506d3a6c6" + sha256: "202a487f08836a592a6bd4f901ac69b3a8f146af552bbd14407b6b41e1c3f086" url: "https://pub.dev" source: hosted - version: "2.0.1" + version: "3.2.1" pana: dependency: transitive description: name: pana - sha256: "3fc3fe8e7a9fd4827fa4d625a423eec95d305b2bc3538a3adf7fd6c49217af97" + sha256: d7bd85f18a14909f0baab69a13895dc4ff163be51c9884f73a506982adeac57d url: "https://pub.dev" source: hosted - version: "0.21.45" - pasteboard: + version: "0.23.10" + particles_network: dependency: "direct main" description: - name: pasteboard - sha256: "1c8b6a8b3f1d12e55d4e9404433cda1b4abe66db6b17bc2d2fb5965772c04674" + name: particles_network + sha256: fbaead7961925946ff83e5b441bdbc8628139ea161ce901547e6f1190a6161de url: "https://pub.dev" source: hosted - version: "0.2.0" + version: "1.9.3" path: dependency: "direct main" description: name: path - sha256: "087ce49c3f0dc39180befefc60fdb4acd8f8620e5682fe2476afd0b3688bb4af" + sha256: "75cca69d1490965be98c73ceaea117e8a04dd21217b37b292c9ddbec0d955bc5" url: "https://pub.dev" source: hosted - version: "1.9.0" - path_parsing: - dependency: transitive - description: - name: path_parsing - sha256: e3e67b1629e6f7e8100b367d3db6ba6af4b1f0bb80f64db18ef1fbabd2fa9ccf - url: "https://pub.dev" - source: hosted - version: "1.0.1" + version: "1.9.1" path_provider: dependency: "direct main" description: name: path_provider - sha256: c9e7d3a4cd1410877472158bee69963a4579f78b68c65a2b7d40d1a7a88bb161 + sha256: "50c5dd5b6e1aaf6fb3a78b33f6aa3afca52bf903a8a5298f53101fdaee55bbcd" url: "https://pub.dev" source: hosted - version: "2.1.3" + version: "2.1.5" path_provider_android: dependency: transitive description: name: path_provider_android - sha256: a248d8146ee5983446bf03ed5ea8f6533129a12b11f12057ad1b4a67a2b3b41d + sha256: f2c65e21139ce2c3dad46922be8272bb5963516045659e71bb16e151c93b580e url: "https://pub.dev" source: hosted - version: "2.2.4" + version: "2.2.22" path_provider_foundation: dependency: transitive description: name: path_provider_foundation - sha256: "5a7999be66e000916500be4f15a3633ebceb8302719b47b9cc49ce924125350f" + sha256: "2a376b7d6392d80cd3705782d2caa734ca4727776db0b6ec36ef3f1855197699" url: "https://pub.dev" source: hosted - version: "2.3.2" + version: "2.6.0" path_provider_linux: dependency: transitive description: @@ -1378,50 +1296,50 @@ packages: dependency: transitive description: name: path_provider_windows - sha256: "8bc9f22eee8690981c22aa7fc602f5c85b497a6fb2ceb35ee5a5e5ed85ad8170" + sha256: bd6f00dbd873bfb70d0761682da2b3a2c2fccc2b9e84c495821639601d81afe7 url: "https://pub.dev" source: hosted - version: "2.2.1" + version: "2.3.0" permission_handler: dependency: "direct main" description: name: permission_handler - sha256: "18bf33f7fefbd812f37e72091a15575e72d5318854877e0e4035a24ac1113ecb" + sha256: bc917da36261b00137bbc8896bf1482169cd76f866282368948f032c8c1caae1 url: "https://pub.dev" source: hosted - version: "11.3.1" + version: "12.0.1" permission_handler_android: dependency: transitive description: name: permission_handler_android - sha256: "1acac6bae58144b442f11e66621c062aead9c99841093c38f5bcdcc24c1c3474" + sha256: "1e3bc410ca1bf84662104b100eb126e066cb55791b7451307f9708d4007350e6" url: "https://pub.dev" source: hosted - version: "12.0.5" + version: "13.0.1" permission_handler_apple: dependency: transitive description: name: permission_handler_apple - sha256: e9ad66020b89ff1b63908f247c2c6f931c6e62699b756ef8b3c4569350cd8662 + sha256: f000131e755c54cf4d84a5d8bd6e4149e262cc31c5a8b1d698de1ac85fa41023 url: "https://pub.dev" source: hosted - version: "9.4.4" + version: "9.4.7" permission_handler_html: dependency: transitive description: name: permission_handler_html - sha256: "54bf176b90f6eddd4ece307e2c06cf977fb3973719c35a93b85cc7093eb6070d" + sha256: "38f000e83355abb3392140f6bc3030660cfaef189e1f87824facb76300b4ff24" url: "https://pub.dev" source: hosted - version: "0.1.1" + version: "0.1.3+5" permission_handler_platform_interface: dependency: transitive description: name: permission_handler_platform_interface - sha256: "48d4fcf201a1dad93ee869ab0d4101d084f49136ec82a8a06ed9cfeacab9fd20" + sha256: eb99b295153abce5d683cac8c02e22faab63e50679b937fa1bf67d58bb282878 url: "https://pub.dev" source: hosted - version: "4.2.1" + version: "4.3.0" permission_handler_windows: dependency: transitive description: @@ -1434,26 +1352,18 @@ packages: dependency: transitive description: name: petitparser - sha256: c15605cd28af66339f8eb6fbe0e541bfe2d1b72d5825efc6598f3e0a31b9ad27 + sha256: "91bd59303e9f769f108f8df05e371341b15d59e995e6806aefab827b58336675" url: "https://pub.dev" source: hosted - version: "6.0.2" + version: "7.0.2" platform: dependency: transitive description: name: platform - sha256: "12220bb4b65720483f8fa9450b4332347737cf8213dd2840d8b2c823e47243ec" + sha256: "5d6b1b0036a5f331ebc77c850ebc8506cbc1e9416c27e59b439f917a902a4984" url: "https://pub.dev" source: hosted - version: "3.1.4" - platform_detect: - dependency: transitive - description: - name: platform_detect - sha256: "08f4ee79c0e1c4858d37e06b22352a3ebdef5466b613749a3adb03e703d4f5b0" - url: "https://pub.dev" - source: hosted - version: "2.0.11" + version: "3.1.6" plugin_platform_interface: dependency: transitive description: @@ -1462,78 +1372,38 @@ packages: url: "https://pub.dev" source: hosted version: "2.1.8" - pointer_interceptor: - dependency: transitive - description: - name: pointer_interceptor - sha256: bd18321519718678d5fa98ad3a3359cbc7a31f018554eab80b73d08a7f0c165a - url: "https://pub.dev" - source: hosted - version: "0.10.1" - pointer_interceptor_ios: - dependency: transitive - description: - name: pointer_interceptor_ios - sha256: "2e73c39452830adc4695757130676a39412a3b7f3c34e3f752791b5384770877" - url: "https://pub.dev" - source: hosted - version: "0.10.0+2" - pointer_interceptor_platform_interface: - dependency: transitive - description: - name: pointer_interceptor_platform_interface - sha256: "0597b0560e14354baeb23f8375cd612e8bd4841bf8306ecb71fcd0bb78552506" - url: "https://pub.dev" - source: hosted - version: "0.10.0+1" - pointer_interceptor_web: - dependency: transitive - description: - name: pointer_interceptor_web - sha256: a6237528b46c411d8d55cdfad8fcb3269fc4cbb26060b14bff94879165887d1e - url: "https://pub.dev" - source: hosted - version: "0.10.2" - pointycastle: - dependency: transitive - description: - name: pointycastle - sha256: "79fbafed02cfdbe85ef3fd06c7f4bc2cbcba0177e61b765264853d4253b21744" - url: "https://pub.dev" - source: hosted - version: "3.9.0" - polylabel: - dependency: transitive - description: - name: polylabel - sha256: "41b9099afb2aa6c1730bdd8a0fab1400d287694ec7615dd8516935fa3144214b" - url: "https://pub.dev" - source: hosted - version: "1.0.1" pool: dependency: transitive description: name: pool - sha256: "20fe868b6314b322ea036ba325e6fc0711a22948856475e2c2b6306e8ab39c2a" + sha256: "978783255c543aa3586a1b3c21f6e9d720eb315376a915872c61ef8b5c20177d" url: "https://pub.dev" source: hosted - version: "1.5.1" + version: "1.5.2" + posix: + dependency: transitive + description: + name: posix + sha256: "6323a5b0fa688b6a010df4905a56b00181479e6d10534cecfecede2aa55add61" + url: "https://pub.dev" + source: hosted + version: "6.0.3" pretty_qr_code: dependency: "direct main" description: name: pretty_qr_code - sha256: cbdb4af29da1c1fa21dd76f809646c591320ab9e435d3b0eab867492d43607d5 + sha256: "474f8a4512113fba06f14a6ec9bbf42353b4e651d7a520e3096f2a9b6bbe7a8a" url: "https://pub.dev" source: hosted - version: "3.3.0" + version: "3.6.0" process: dependency: transitive description: name: process - sha256: "21e54fd2faf1b5bdd5102afd25012184a6793927648ea81eea80552ac9405b32" + sha256: c6248e4526673988586e8c00bb22a49210c258dc91df5227d5da9748ecf79744 url: "https://pub.dev" source: hosted - version: "5.0.2" + version: "5.0.5" proj4dart: dependency: transitive description: @@ -1546,26 +1416,34 @@ packages: dependency: "direct main" description: name: provider - sha256: c8a055ee5ce3fd98d6fc872478b03823ffdb448699c6ebdbbc71d59b596fd48c + sha256: "4e82183fa20e5ca25703ead7e05de9e4cceed1fbd1eadc1ac3cb6f565a09f272" url: "https://pub.dev" source: hosted - version: "6.1.2" + version: "6.1.5+1" pub_semver: dependency: transitive description: name: pub_semver - sha256: "40d3ab1bbd474c4c2328c91e3a7df8c6dd629b79ece4c4bd04bee496a224fb0c" + sha256: "5bfcf68ca79ef689f8990d1160781b4bad40a3bd5e5218ad4076ddb7f4081585" url: "https://pub.dev" source: hosted - version: "2.1.4" + version: "2.2.0" + pub_updater: + dependency: transitive + description: + name: pub_updater + sha256: "739a0161d73a6974c0675b864fb0cf5147305f7b077b7f03a58fa7a9ab3e7e7d" + url: "https://pub.dev" + source: hosted + version: "0.5.0" pubspec_parse: dependency: transitive description: name: pubspec_parse - sha256: c63b2876e58e194e4b0828fcb080ad0e06d051cb607a6be51a9e084f47cb9367 + sha256: "0560ba233314abbed0a48a2956f7f022cce7c3e1e73df540277da7544cad4082" url: "https://pub.dev" source: hosted - version: "1.2.3" + version: "1.5.0" punycode: dependency: "direct main" description: @@ -1578,26 +1456,26 @@ packages: dependency: transitive description: name: qr - sha256: "64957a3930367bf97cc211a5af99551d630f2f4625e38af10edd6b19131b64b3" + sha256: "5a1d2586170e172b8a8c8470bbbffd5eb0cd38a66c0d77155ea138d3af3a4445" url: "https://pub.dev" source: hosted - version: "3.0.1" - qr_code_scanner: + version: "3.0.2" + qr_code_scanner_plus: dependency: "direct main" description: - name: qr_code_scanner - sha256: f23b68d893505a424f0bd2e324ebea71ed88465d572d26bb8d2e78a4749591fd + name: qr_code_scanner_plus + sha256: dae0596b2763c2fd0294f5cfddb1d3a21577ae4dc7fc1449eb5aafc957872f61 url: "https://pub.dev" source: hosted - version: "1.0.1" - quiver: - dependency: transitive + version: "2.1.1" + qr_image: + dependency: "direct main" description: - name: quiver - sha256: b1c1ac5ce6688d77f65f3375a9abb9319b3cb32486bdc7a1e0fdf004d7ba4e47 + name: qr_image + sha256: c3cd2ac2c6cd6b14604c97b45c477b18988b6518f72120fa04418fc54e3b0d76 url: "https://pub.dev" source: hosted - version: "3.2.1" + version: "1.0.0" random_string: dependency: transitive description: @@ -1610,74 +1488,74 @@ packages: dependency: "direct main" description: name: receive_sharing_intent - sha256: "912bebb551bce75a14098891fd750305b30d53eba0d61cc70cd9973be9866e8d" + sha256: ec76056e4d258ad708e76d85591d933678625318e411564dcb9059048ca3a593 url: "https://pub.dev" source: hosted - version: "1.4.5" + version: "1.8.1" record: dependency: "direct main" description: name: record - sha256: "113b368168c49c78902ab37c2b354dea30a0aec5bdeca434073826b6ea73eca1" + sha256: d5b6b334f3ab02460db6544e08583c942dbf23e3504bf1e14fd4cbe3d9409277 url: "https://pub.dev" source: hosted - version: "5.0.5" + version: "6.2.0" record_android: dependency: transitive description: name: record_android - sha256: "0df98e05873b22b443309e289bf1eb3b5b9a60e7779134334e2073eb0763a992" + sha256: "94783f08403aed33ffb68797bf0715b0812eb852f3c7985644c945faea462ba1" url: "https://pub.dev" source: hosted - version: "1.1.0" - record_darwin: + version: "1.5.1" + record_ios: dependency: transitive description: - name: record_darwin - sha256: ee8cb1bb1712d7ce38140ecabe70e5c286c02f05296d66043bee865ace7eb1b9 + name: record_ios + sha256: "8df7c136131bd05efc19256af29b2ba6ccc000ccc2c80d4b6b6d7a8d21a3b5a9" url: "https://pub.dev" source: hosted - version: "1.0.1" + version: "1.2.0" record_linux: dependency: transitive description: name: record_linux - sha256: "7d0e70cd51635128fe9d37d89bafd6011d7cbba9af8dc323079ae60f23546aef" + sha256: c31a35cc158cd666fc6395f7f56fc054f31685571684be6b97670a27649ce5c7 url: "https://pub.dev" source: hosted - version: "0.7.1" + version: "1.3.0" + record_macos: + dependency: transitive + description: + name: record_macos + sha256: "084902e63fc9c0c224c29203d6c75f0bdf9b6a40536c9d916393c8f4c4256488" + url: "https://pub.dev" + source: hosted + version: "1.2.1" record_platform_interface: dependency: transitive description: name: record_platform_interface - sha256: "3a4b56e94ecd2a0b2b43eb1fa6f94c5b8484334f5d38ef43959c4bf97fb374cf" + sha256: "8a81dbc4e14e1272a285bbfef6c9136d070a47d9b0d1f40aa6193516253ee2f6" url: "https://pub.dev" source: hosted - version: "1.0.2" + version: "1.5.0" record_web: dependency: transitive description: name: record_web - sha256: "24847cdbcf999f7a5762170792f622ac844858766becd0f2370ec8ae22f7526e" + sha256: "7e9846981c1f2d111d86f0ae3309071f5bba8b624d1c977316706f08fc31d16d" url: "https://pub.dev" source: hosted - version: "1.0.5" + version: "1.3.0" record_windows: dependency: transitive description: name: record_windows - sha256: "39998b3ea7d8d28b04159d82220e6e5e32a7c357c6fb2794f5736beea272f6c3" + sha256: "223258060a1d25c62bae18282c16783f28581ec19401d17e56b5205b9f039d78" url: "https://pub.dev" source: hosted - version: "1.0.2" - remove_emoji: - dependency: transitive - description: - name: remove_emoji - sha256: ed9e8463e8c9ca05b86fcddd4c0dbd2c2605a50d267f4ffa05496607924809e3 - url: "https://pub.dev" - source: hosted - version: "0.0.10" + version: "1.0.7" retry: dependency: transitive description: @@ -1690,10 +1568,10 @@ packages: dependency: transitive description: name: rxdart - sha256: "0c7c0cedd93788d996e33041ffecda924cc54389199cde4e6a34b440f50044cb" + sha256: "5c3004a4a8dbb94bd4bf5412a4def4acdaa12e12f269737a5751369e12d1a962" url: "https://pub.dev" source: hosted - version: "0.27.7" + version: "0.28.0" safe_url_check: dependency: transitive description: @@ -1702,6 +1580,46 @@ packages: url: "https://pub.dev" source: hosted version: "1.1.2" + screen_retriever: + dependency: transitive + description: + name: screen_retriever + sha256: "570dbc8e4f70bac451e0efc9c9bb19fa2d6799a11e6ef04f946d7886d2e23d0c" + url: "https://pub.dev" + source: hosted + version: "0.2.0" + screen_retriever_linux: + dependency: transitive + description: + name: screen_retriever_linux + sha256: f7f8120c92ef0784e58491ab664d01efda79a922b025ff286e29aa123ea3dd18 + url: "https://pub.dev" + source: hosted + version: "0.2.0" + screen_retriever_macos: + dependency: transitive + description: + name: screen_retriever_macos + sha256: "71f956e65c97315dd661d71f828708bd97b6d358e776f1a30d5aa7d22d78a149" + url: "https://pub.dev" + source: hosted + version: "0.2.0" + screen_retriever_platform_interface: + dependency: transitive + description: + name: screen_retriever_platform_interface + sha256: ee197f4581ff0d5608587819af40490748e1e39e648d7680ecf95c05197240c0 + url: "https://pub.dev" + source: hosted + version: "0.2.0" + screen_retriever_windows: + dependency: transitive + description: + name: screen_retriever_windows + sha256: "449ee257f03ca98a57288ee526a301a430a344a161f9202b4fcc38576716fe13" + url: "https://pub.dev" + source: hosted + version: "0.2.0" scroll_to_index: dependency: "direct main" description: @@ -1718,94 +1636,86 @@ packages: url: "https://pub.dev" source: hosted version: "0.3.2" - sentiment_dart: - dependency: transitive - description: - name: sentiment_dart - sha256: ddac8742cf5141f531eb1510b074ce715b9958cb02a763a4cc0a918768e4a0c8 - url: "https://pub.dev" - source: hosted - version: "0.0.5" share_plus: dependency: "direct main" description: name: share_plus - sha256: ef3489a969683c4f3d0239010cc8b7a2a46543a8d139e111c06c558875083544 + sha256: "14c8860d4de93d3a7e53af51bff479598c4e999605290756bbbe45cf65b37840" url: "https://pub.dev" source: hosted - version: "9.0.0" + version: "12.0.1" share_plus_platform_interface: dependency: transitive description: name: share_plus_platform_interface - sha256: "0f9e4418835d1b2c3ae78fdb918251959106cefdbc4dd43526e182f80e82f6d4" + sha256: "88023e53a13429bd65d8e85e11a9b484f49d4c190abbd96c7932b74d6927cc9a" url: "https://pub.dev" source: hosted - version: "4.0.0" + version: "6.1.0" shared_preferences: dependency: "direct main" description: name: shared_preferences - sha256: d3bbe5553a986e83980916ded2f0b435ef2e1893dfaa29d5a7a790d0eca12180 + sha256: "2939ae520c9024cb197fc20dee269cd8cdbf564c8b5746374ec6cacdc5169e64" url: "https://pub.dev" source: hosted - version: "2.2.3" + version: "2.5.4" shared_preferences_android: dependency: transitive description: name: shared_preferences_android - sha256: "1ee8bf911094a1b592de7ab29add6f826a7331fb854273d55918693d5364a1f2" + sha256: cbc40be9be1c5af4dab4d6e0de4d5d3729e6f3d65b89d21e1815d57705644a6f url: "https://pub.dev" source: hosted - version: "2.2.2" + version: "2.4.20" shared_preferences_foundation: dependency: transitive description: name: shared_preferences_foundation - sha256: "7708d83064f38060c7b39db12aefe449cb8cdc031d6062280087bc4cdb988f5c" + sha256: "4e7eaffc2b17ba398759f1151415869a34771ba11ebbccd1b0145472a619a64f" url: "https://pub.dev" source: hosted - version: "2.3.5" + version: "2.5.6" shared_preferences_linux: dependency: transitive description: name: shared_preferences_linux - sha256: "9f2cbcf46d4270ea8be39fa156d86379077c8a5228d9dfdb1164ae0bb93f1faa" + sha256: "580abfd40f415611503cae30adf626e6656dfb2f0cee8f465ece7b6defb40f2f" url: "https://pub.dev" source: hosted - version: "2.3.2" + version: "2.4.1" shared_preferences_platform_interface: dependency: transitive description: name: shared_preferences_platform_interface - sha256: "22e2ecac9419b4246d7c22bfbbda589e3acf5c0351137d87dd2939d984d37c3b" + sha256: "57cbf196c486bc2cf1f02b85784932c6094376284b3ad5779d1b1c6c6a816b80" url: "https://pub.dev" source: hosted - version: "2.3.2" + version: "2.4.1" shared_preferences_web: dependency: transitive description: name: shared_preferences_web - sha256: "9aee1089b36bd2aafe06582b7d7817fd317ef05fc30e6ba14bff247d0933042a" + sha256: c49bd060261c9a3f0ff445892695d6212ff603ef3115edbb448509d407600019 url: "https://pub.dev" source: hosted - version: "2.3.0" + version: "2.4.3" shared_preferences_windows: dependency: transitive description: name: shared_preferences_windows - sha256: "841ad54f3c8381c480d0c9b508b89a34036f512482c407e6df7a9c4aa2ef8f59" + sha256: "94ef0f72b2d71bc3e700e025db3710911bd51a71cefb65cc609dd0d9a982e3c1" url: "https://pub.dev" source: hosted - version: "2.3.2" + version: "2.4.1" shelf: dependency: transitive description: name: shelf - sha256: ad29c505aee705f41a4d8963641f91ac4cee3c8fad5947e033390a7bd8180fa4 + sha256: e7dd780a7ffb623c57850b33f43309312fc863fb6aa3d276a754bb299839ef12 url: "https://pub.dev" source: hosted - version: "1.4.1" + version: "1.4.2" shelf_packages_handler: dependency: transitive description: @@ -1818,23 +1728,23 @@ packages: dependency: transitive description: name: shelf_static - sha256: a41d3f53c4adf0f57480578c1d61d90342cd617de7fc8077b1304643c2d85c1e + sha256: c87c3875f91262785dade62d135760c2c69cb217ac759485334c5857ad89f6e3 url: "https://pub.dev" source: hosted - version: "1.1.2" + version: "1.1.3" shelf_web_socket: dependency: transitive description: name: shelf_web_socket - sha256: "9ca081be41c60190ebcb4766b2486a7d50261db7bd0f5d9615f2d653637a84c1" + sha256: "3632775c8e90d6c9712f883e633716432a27758216dfb61bd86a8321c0580925" url: "https://pub.dev" source: hosted - version: "1.0.4" + version: "3.0.0" sky_engine: dependency: transitive description: flutter source: sdk - version: "0.0.99" + version: "0.0.0" slugify: dependency: "direct main" description: @@ -1847,98 +1757,82 @@ packages: dependency: transitive description: name: source_map_stack_trace - sha256: "84cf769ad83aa6bb61e0aa5a18e53aea683395f196a6f39c4c881fb90ed4f7ae" + sha256: c0713a43e323c3302c2abe2a1cc89aa057a387101ebd280371d6a6c9fa68516b url: "https://pub.dev" source: hosted - version: "2.1.1" + version: "2.1.2" source_maps: dependency: transitive description: name: source_maps - sha256: "708b3f6b97248e5781f493b765c3337db11c5d2c81c3094f10904bfa8004c703" + sha256: "190222579a448b03896e0ca6eca5998fa810fda630c1d65e2f78b3f638f54812" url: "https://pub.dev" source: hosted - version: "0.10.12" + version: "0.10.13" source_span: dependency: transitive description: name: source_span - sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c" + sha256: "56a02f1f4cd1a2d96303c0144c93bd6d909eea6bee6bf5a0e0b685edbd4c47ab" url: "https://pub.dev" source: hosted - version: "1.10.0" - sprintf: - dependency: transitive - description: - name: sprintf - sha256: "1fc9ffe69d4df602376b52949af107d8f5703b77cda567c4d7d86a0693120f23" - url: "https://pub.dev" - source: hosted - version: "7.0.0" - sqflite: - dependency: transitive - description: - name: sqflite - sha256: "5ce2e1a15e822c3b4bfb5400455775e421da7098eed8adc8f26298ada7c9308c" - url: "https://pub.dev" - source: hosted - version: "2.3.3" + version: "1.10.2" sqflite_common: dependency: transitive description: name: sqflite_common - sha256: "3da423ce7baf868be70e2c0976c28a1bb2f73644268b7ffa7d2e08eab71f16a4" + sha256: "6ef422a4525ecc601db6c0a2233ff448c731307906e92cabc9ba292afaae16a6" url: "https://pub.dev" source: hosted - version: "2.5.4" + version: "2.5.6" sqflite_common_ffi: dependency: "direct main" description: name: sqflite_common_ffi - sha256: "4d6137c29e930d6e4a8ff373989dd9de7bac12e3bc87bce950f6e844e8ad3bb5" + sha256: "8d7b8749a516cbf6e9057f9b480b716ad14fc4f3d3873ca6938919cc626d9025" url: "https://pub.dev" source: hosted - version: "2.3.3" + version: "2.3.7+1" sqlcipher_flutter_libs: dependency: "direct main" description: name: sqlcipher_flutter_libs - sha256: "60fe3444ff5b1b298a9ca3003c6c7f1f7ee4c90aa6035a8647f3aeaf05a073e2" + sha256: dd1fcc74d5baf3c36ad53e2652b2d06c9f8747494a3ccde0076e88b159dfe622 url: "https://pub.dev" source: hosted - version: "0.6.1" + version: "0.6.8" sqlite3: dependency: transitive description: name: sqlite3 - sha256: "1abbeb84bf2b1a10e5e1138c913123c8aa9d83cd64e5f9a0dd847b3c83063202" + sha256: "3145bd74dcdb4fd6f5c6dda4d4e4490a8087d7f286a14dee5d37087290f0f8a2" url: "https://pub.dev" source: hosted - version: "2.4.2" + version: "2.9.4" stack_trace: dependency: transitive description: name: stack_trace - sha256: "73713990125a6d93122541237550ee3352a2d84baad52d375a4cad2eb9b7ce0b" + sha256: "8b27215b45d22309b5cddda1aa2b19bdfec9df0e765f2de506401c071d38d1b1" url: "https://pub.dev" source: hosted - version: "1.11.1" + version: "1.12.1" stream_channel: dependency: transitive description: name: stream_channel - sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7 + sha256: "969e04c80b8bcdf826f8f16579c7b14d780458bd97f56d107d3950fdbeef059d" url: "https://pub.dev" source: hosted - version: "2.1.2" + version: "2.1.4" string_scanner: dependency: transitive description: name: string_scanner - sha256: "556692adab6cfa87322a115640c11f13cb77b3f076ddcc5d6ae3c20242bedcde" + sha256: "921cd31725b72fe181906c6a94d987c78e3b98c2e205b397ea399d4054872b43" url: "https://pub.dev" source: hosted - version: "1.2.0" + version: "1.4.1" string_validator: dependency: transitive description: @@ -1951,10 +1845,10 @@ packages: dependency: "direct main" description: name: swipe_to_action - sha256: "0914f78df07a15b5fd97e800036fd63a2bcd4dbe67a4a514a597303806a361ea" + sha256: "05289a2bff6a0227deeff382afa1c46643d1f077e678d78f76440e153ea1ef7d" url: "https://pub.dev" source: hosted - version: "0.2.0" + version: "0.3.0" sync_http: dependency: transitive description: @@ -1967,58 +1861,50 @@ packages: dependency: transitive description: name: synchronized - sha256: "539ef412b170d65ecdafd780f924e5be3f60032a1128df156adad6c5b373d558" + sha256: c254ade258ec8282947a0acbbc90b9575b4f19673533ee46f2f6e9b3aeefd7c0 url: "https://pub.dev" source: hosted - version: "3.1.0+1" - tar: - dependency: transitive - description: - name: tar - sha256: aca91e93ff9ff2dba4462c6eea6bc260b72f0d7010e748e3397c32190529bd6e - url: "https://pub.dev" - source: hosted - version: "1.0.4" + version: "3.4.0" term_glyph: dependency: transitive description: name: term_glyph - sha256: a29248a84fbb7c79282b40b8c72a1209db169a2e0542bce341da992fe1bc7e84 + sha256: "7f554798625ea768a7518313e58f83891c7f5024f88e46e7182a4558850a4b8e" url: "https://pub.dev" source: hosted - version: "1.2.1" + version: "1.2.2" test: dependency: transitive description: name: test - sha256: "7ee446762c2c50b3bd4ea96fe13ffac69919352bd3b4b17bac3f3465edc58073" + sha256: "54c516bbb7cee2754d327ad4fca637f78abfc3cbcc5ace83b3eda117e42cd71a" url: "https://pub.dev" source: hosted - version: "1.25.2" + version: "1.29.0" test_api: dependency: transitive description: name: test_api - sha256: "9955ae474176f7ac8ee4e989dadfb411a58c30415bcfb648fa04b2b8a03afa7f" + sha256: "93167629bfc610f71560ab9312acdda4959de4df6fac7492c89ff0d3886f6636" url: "https://pub.dev" source: hosted - version: "0.7.0" + version: "0.7.9" test_core: dependency: transitive description: name: test_core - sha256: "2bc4b4ecddd75309300d8096f781c0e3280ca1ef85beda558d33fcbedc2eead4" + sha256: "394f07d21f0f2255ec9e3989f21e54d3c7dc0e6e9dbce160e5a9c1a6be0e2943" url: "https://pub.dev" source: hosted - version: "0.6.0" + version: "0.6.15" timezone: dependency: transitive description: name: timezone - sha256: a6ccda4a69a442098b602c44e61a1e2b4bf6f5516e875bbf0f427d5df14745d5 + sha256: dd14a3b83cfd7cb19e7888f1cbc20f258b8d71b54c06f79ac585f14093a287d1 url: "https://pub.dev" source: hosted - version: "0.9.3" + version: "0.10.1" tint: dependency: transitive description: @@ -2027,62 +1913,22 @@ packages: url: "https://pub.dev" source: hosted version: "2.0.1" - tor_detector_web: - dependency: "direct main" - description: - name: tor_detector_web - sha256: c4acbd6c0fecd2cd0e8fe00b1a37332422e041021a42488dfddcb3e7ec809b3f - url: "https://pub.dev" - source: hosted - version: "1.1.0" translations_cleaner: dependency: "direct dev" description: name: translations_cleaner - sha256: "060f4a8cd782e271509719741dd3540fe81ddaad49bd79e1d8fc4598299a6b84" + sha256: "811f42be32f024fdf083903f198d3625f6ee6927601e3a53a29b85b90508b88c" url: "https://pub.dev" source: hosted - version: "0.0.5" - tuple: - dependency: transitive - description: - name: tuple - sha256: a97ce2013f240b2f3807bcbaf218765b6f301c3eff91092bcfa23a039e7dd151 - url: "https://pub.dev" - source: hosted - version: "2.0.2" + version: "0.1.0" typed_data: dependency: transitive description: name: typed_data - sha256: facc8d6582f16042dd49f2463ff1bd6e2c9ef9f3d5da3d9b087e244a7b564b3c + sha256: f9049c039ebfeb4cf7a7104a675823cd72dba8297f264b6637062516699fa006 url: "https://pub.dev" source: hosted - version: "1.3.2" - uni_links: - dependency: "direct main" - description: - name: uni_links - sha256: "051098acfc9e26a9fde03b487bef5d3d228ca8f67693480c6f33fd4fbb8e2b6e" - url: "https://pub.dev" - source: hosted - version: "0.5.1" - uni_links_platform_interface: - dependency: transitive - description: - name: uni_links_platform_interface - sha256: "929cf1a71b59e3b7c2d8a2605a9cf7e0b125b13bc858e55083d88c62722d4507" - url: "https://pub.dev" - source: hosted - version: "1.0.0" - uni_links_web: - dependency: transitive - description: - name: uni_links_web - sha256: "7539db908e25f67de2438e33cc1020b30ab94e66720b5677ba6763b25f6394df" - url: "https://pub.dev" - source: hosted - version: "0.1.0" + version: "1.4.0" unicode: dependency: transitive description: @@ -2095,42 +1941,74 @@ packages: dependency: "direct main" description: name: unifiedpush - sha256: ef7f3ae6139d27169604e3844379ef7929af573a2be21d9e82187f44ab7b9a32 + sha256: "8ed9767f750a1dc6159a77e2171641d0cb825dc87682d1ce1b8618689b79f58e" url: "https://pub.dev" source: hosted - version: "5.0.1" + version: "6.2.0" unifiedpush_android: dependency: transitive description: name: unifiedpush_android - sha256: "610ad746294541f56d632adf9afba5d1c164c44e23ec0dd2162a41a6ff00a00e" + sha256: "2e6684e0a1a39ad8d6c7bc0d197954d50686acb1b1a7614b18ab0e0126f5492a" url: "https://pub.dev" source: hosted - version: "2.2.3" + version: "3.4.1" + unifiedpush_linux: + dependency: transitive + description: + name: unifiedpush_linux + sha256: c062d5eedd1cec70bcd33270cc4e01ae0ff6501f33d471167c06b34a968adfeb + url: "https://pub.dev" + source: hosted + version: "1.0.0" unifiedpush_platform_interface: dependency: transitive description: name: unifiedpush_platform_interface - sha256: "7782b18a15d22bb184fa766ef1e0c675eef862055ff815453df7041dfd026146" + sha256: "83372bc8d794b8b12ef6993b518d7be907dcfc2191bdf6de0ece5c4445d89880" url: "https://pub.dev" source: hosted - version: "2.0.1" + version: "4.0.0" + unifiedpush_storage_interface: + dependency: transitive + description: + name: unifiedpush_storage_interface + sha256: b8d423a4695efc616aa21d8ab48fb5ef99d6288c68b56282b8faac1579ceabd9 + url: "https://pub.dev" + source: hosted + version: "1.0.0" + unifiedpush_ui: + dependency: "direct main" + description: + name: unifiedpush_ui + sha256: "1b36b2aa0bc6b61577e2661c1183bd3442969ecf77b4c78174796d324f66dd1d" + url: "https://pub.dev" + source: hosted + version: "0.2.0" universal_html: dependency: "direct main" description: name: universal_html - sha256: "56536254004e24d9d8cfdb7dbbf09b74cf8df96729f38a2f5c238163e3d58971" + sha256: c0bcae5c733c60f26c7dfc88b10b0fd27cbcc45cb7492311cdaa6067e21c9cd4 url: "https://pub.dev" source: hosted - version: "2.2.4" + version: "2.3.0" universal_io: dependency: transitive description: name: universal_io - sha256: "1722b2dcc462b4b2f3ee7d188dad008b6eb4c40bbd03a3de451d82c78bba9aad" + sha256: f63cbc48103236abf48e345e07a03ce5757ea86285ed313a6a032596ed9301e2 url: "https://pub.dev" source: hosted - version: "2.2.2" + version: "2.3.1" + universal_platform: + dependency: transitive + description: + name: universal_platform + sha256: "64e16458a0ea9b99260ceb5467a214c1f298d647c659af1bff6d3bf82536b1ec" + url: "https://pub.dev" + source: hosted + version: "1.1.0" unorm_dart: dependency: transitive description: @@ -2143,42 +2021,42 @@ packages: dependency: "direct main" description: name: url_launcher - sha256: "6ce1e04375be4eed30548f10a315826fd933c1e493206eab82eed01f438c8d2e" + sha256: f6a7e5c4835bb4e3026a04793a4199ca2d14c739ec378fdfe23fc8075d0439f8 url: "https://pub.dev" source: hosted - version: "6.2.6" + version: "6.3.2" url_launcher_android: dependency: transitive description: name: url_launcher_android - sha256: "360a6ed2027f18b73c8d98e159dda67a61b7f2e0f6ec26e86c3ada33b0621775" + sha256: "767344bf3063897b5cf0db830e94f904528e6dd50a6dfaf839f0abf509009611" url: "https://pub.dev" source: hosted - version: "6.3.1" + version: "6.3.28" url_launcher_ios: dependency: transitive description: name: url_launcher_ios - sha256: "9149d493b075ed740901f3ee844a38a00b33116c7c5c10d7fb27df8987fb51d5" + sha256: "580fe5dfb51671ae38191d316e027f6b76272b026370708c2d898799750a02b0" url: "https://pub.dev" source: hosted - version: "6.2.5" + version: "6.4.1" url_launcher_linux: dependency: transitive description: name: url_launcher_linux - sha256: ab360eb661f8879369acac07b6bb3ff09d9471155357da8443fd5d3cf7363811 + sha256: d5e14138b3bc193a0f63c10a53c94b91d399df0512b1f29b94a043db7482384a url: "https://pub.dev" source: hosted - version: "3.1.1" + version: "3.2.2" url_launcher_macos: dependency: transitive description: name: url_launcher_macos - sha256: b7244901ea3cf489c5335bdacda07264a6e960b1c1b1a9f91e4bc371d9e68234 + sha256: "368adf46f71ad3c21b8f06614adb38346f193f3a59ba8fe9a2fd74133070ba18" url: "https://pub.dev" source: hosted - version: "3.1.0" + version: "3.2.5" url_launcher_platform_interface: dependency: transitive description: @@ -2191,170 +2069,163 @@ packages: dependency: transitive description: name: url_launcher_web - sha256: "8d9e750d8c9338601e709cd0885f95825086bd8b642547f26bda435aade95d8a" + sha256: d0412fcf4c6b31ecfdb7762359b7206ffba3bbffd396c6d9f9c4616ece476c1f url: "https://pub.dev" source: hosted - version: "2.3.1" + version: "2.4.2" url_launcher_windows: dependency: transitive description: name: url_launcher_windows - sha256: ecf9725510600aa2bb6d7ddabe16357691b6d2805f66216a97d1b881e21beff7 + sha256: "712c70ab1b99744ff066053cbe3e80c73332b38d46e5e945c98689b2e66fc15f" url: "https://pub.dev" source: hosted - version: "3.1.1" + version: "3.1.5" uuid: dependency: transitive description: name: uuid - sha256: "814e9e88f21a176ae1359149021870e87f7cddaf633ab678a5d2b0bff7fd1ba8" + sha256: a11b666489b1954e01d992f3d601b1804a33937b5a8fe677bd26b8a9f96f96e8 url: "https://pub.dev" source: hosted - version: "4.4.0" - vector_graphics: - dependency: transitive - description: - name: vector_graphics - sha256: "32c3c684e02f9bc0afb0ae0aa653337a2fe022e8ab064bcd7ffda27a74e288e3" - url: "https://pub.dev" - source: hosted - version: "1.1.11+1" - vector_graphics_codec: - dependency: transitive - description: - name: vector_graphics_codec - sha256: c86987475f162fadff579e7320c7ddda04cd2fdeffbe1129227a85d9ac9e03da - url: "https://pub.dev" - source: hosted - version: "1.1.11+1" - vector_graphics_compiler: - dependency: transitive - description: - name: vector_graphics_compiler - sha256: "12faff3f73b1741a36ca7e31b292ddeb629af819ca9efe9953b70bd63fc8cd81" - url: "https://pub.dev" - source: hosted - version: "1.1.11+1" + version: "4.5.2" vector_math: dependency: transitive description: name: vector_math - sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803" + sha256: d530bd74fea330e6e364cda7a85019c434070188383e1cd8d9777ee586914c5b url: "https://pub.dev" source: hosted - version: "2.1.4" + version: "2.2.0" video_compress: dependency: "direct main" description: name: video_compress - sha256: "407693726e674a1e1958801deb2d9daf5a5297707ba6d03375007012dae7389a" + sha256: "31bc5cdb9a02ba666456e5e1907393c28e6e0e972980d7d8d619a7beda0d4f20" url: "https://pub.dev" source: hosted - version: "3.1.2" + version: "3.1.4" video_player: dependency: "direct main" description: name: video_player - sha256: db6a72d8f4fd155d0189845678f55ad2fd54b02c10dcafd11c068dbb631286c0 + sha256: "08bfba72e311d48219acad4e191b1f9c27ff8cf928f2c7234874592d9c9d7341" url: "https://pub.dev" source: hosted - version: "2.8.6" + version: "2.11.0" video_player_android: dependency: transitive description: name: video_player_android - sha256: "134e1ad410d67e18a19486ed9512c72dfc6d8ffb284d0e8f2e99e903d1ba8fa3" + sha256: e726b33894526cf96a3eefe61af054b0c3e7d254443b3695b3c142dc277291be url: "https://pub.dev" source: hosted - version: "2.4.14" + version: "2.9.3" video_player_avfoundation: dependency: transitive description: name: video_player_avfoundation - sha256: "00c49b1d68071341397cf760b982c1e26ed9232464c8506ee08378a5cca5070d" + sha256: f93b93a3baa12ca0ff7d00ca8bc60c1ecd96865568a01ff0c18a99853ee201a5 url: "https://pub.dev" source: hosted - version: "2.5.7" + version: "2.9.3" video_player_platform_interface: dependency: transitive description: name: video_player_platform_interface - sha256: "236454725fafcacf98f0f39af0d7c7ab2ce84762e3b63f2cbb3ef9a7e0550bc6" + sha256: "57c5d73173f76d801129d0531c2774052c5a7c11ccb962f1830630decd9f24ec" url: "https://pub.dev" source: hosted - version: "6.2.2" + version: "6.6.0" video_player_web: dependency: transitive description: name: video_player_web - sha256: "41245cef5ef29c4585dbabcbcbe9b209e34376642c7576cabf11b4ad9289d6e4" + sha256: "9f3c00be2ef9b76a95d94ac5119fb843dca6f2c69e6c9968f6f2b6c9e7afbdeb" url: "https://pub.dev" source: hosted - version: "2.3.0" - visibility_detector: - dependency: transitive - description: - name: visibility_detector - sha256: "15c54a459ec2c17b4705450483f3d5a2858e733aee893dcee9d75fd04814940d" - url: "https://pub.dev" - source: hosted - version: "0.3.3" + version: "2.4.0" vm_service: dependency: transitive description: name: vm_service - sha256: "3923c89304b715fb1eb6423f017651664a03bf5f4b29983627c4da791f74a4ec" + sha256: "45caa6c5917fa127b5dbcfbd1fa60b14e583afdc08bfc96dda38886ca252eb60" url: "https://pub.dev" source: hosted - version: "14.2.1" + version: "15.0.2" + vodozemac: + dependency: transitive + description: + name: vodozemac + sha256: bbe7dd31d7f623e2aeedb92e4b71a8b519e6109ce1e2911b5a220f6752b65cda + url: "https://pub.dev" + source: hosted + version: "0.5.0" wakelock_plus: dependency: "direct main" description: name: wakelock_plus - sha256: c8b7cc80f045533b40a0e6c9109905494e3cf32c0fbd5c62616998e0de44003f + sha256: "9296d40c9adbedaba95d1e704f4e0b434be446e2792948d0e4aa977048104228" url: "https://pub.dev" source: hosted - version: "1.2.4" + version: "1.4.0" wakelock_plus_platform_interface: dependency: transitive description: name: wakelock_plus_platform_interface - sha256: "422d1cdbb448079a8a62a5a770b69baa489f8f7ca21aef47800c726d404f9d16" + sha256: "036deb14cd62f558ca3b73006d52ce049fabcdcb2eddfe0bf0fe4e8a943b5cf2" url: "https://pub.dev" source: hosted - version: "1.2.1" + version: "1.3.0" watcher: dependency: transitive description: name: watcher - sha256: "3d2ad6751b3c16cf07c7fca317a1413b3f26530319181b37e3b9039b84fc01d8" + sha256: "1398c9f081a753f9226febe8900fce8f7d0a67163334e1c94a2438339d79d635" url: "https://pub.dev" source: hosted - version: "1.1.0" + version: "1.2.1" web: dependency: transitive description: name: web - sha256: "97da13628db363c635202ad97068d47c5b8aa555808e7a9411963c533b449b27" + sha256: "868d88a33d8a87b18ffc05f9f030ba328ffefba92d6c127917a2ba740f9cfe4a" url: "https://pub.dev" source: hosted - version: "0.5.1" + version: "1.1.1" + web_socket: + dependency: transitive + description: + name: web_socket + sha256: "34d64019aa8e36bf9842ac014bb5d2f5586ca73df5e4d9bf5c936975cae6982c" + url: "https://pub.dev" + source: hosted + version: "1.0.1" web_socket_channel: dependency: transitive description: name: web_socket_channel - sha256: "58c6666b342a38816b2e7e50ed0f1e261959630becd4c879c4f26bfa14aa5a42" + sha256: d645757fb0f4773d602444000a8131ff5d48c9e47adfe9772652dd1a4f2d45c8 url: "https://pub.dev" source: hosted - version: "2.4.5" + version: "3.0.3" + webcrypto: + dependency: "direct overridden" + description: + path: "." + ref: master + resolved-ref: dcc7ba78c9721de56a800fda9a9e2bc759b9cad3 + url: "https://github.com/google/webcrypto.dart.git" + source: git + version: "0.6.0" webdriver: dependency: transitive description: name: webdriver - sha256: "003d7da9519e1e5f329422b36c4dcdf18d7d2978d1ba099ea4e45ba490ed845e" + sha256: "2f3a14ca026957870cfd9c635b83507e0e51d8091568e90129fbf805aba7cade" url: "https://pub.dev" source: hosted - version: "3.0.3" + version: "3.1.0" webkit_inspection_protocol: dependency: transitive description: @@ -2363,30 +2234,46 @@ packages: url: "https://pub.dev" source: hosted version: "1.2.1" + webpush_encryption: + dependency: transitive + description: + name: webpush_encryption + sha256: "5b83272b91acda6ae515fcd980c94f06bf413702282497c5a68f5dfc64fed27f" + url: "https://pub.dev" + source: hosted + version: "1.0.1" webrtc_interface: dependency: "direct main" description: name: webrtc_interface - sha256: abec3ab7956bd5ac539cf34a42fa0c82ea26675847c0966bb85160400eea9388 + sha256: ad0e5786b2acd3be72a3219ef1dde9e1cac071cf4604c685f11b61d63cdd6eb3 url: "https://pub.dev" source: hosted - version: "1.2.0" + version: "1.4.0" win32: dependency: transitive description: name: win32 - sha256: "0eaf06e3446824099858367950a813472af675116bf63f008a4c2a75ae13e9cb" + sha256: d7cb55e04cd34096cd3a79b3330245f54cb96a370a1c27adb3c84b917de8b08e url: "https://pub.dev" source: hosted - version: "5.5.0" + version: "5.15.0" win32_registry: dependency: transitive description: name: win32_registry - sha256: "10589e0d7f4e053f2c61023a31c9ce01146656a70b7b7f0828c0b46d7da2a9bb" + sha256: "6f1b564492d0147b330dd794fee8f512cec4977957f310f9951b5f9d83618dae" url: "https://pub.dev" source: hosted - version: "1.1.3" + version: "2.1.0" + window_manager: + dependency: transitive + description: + name: window_manager + sha256: "7eb6d6c4164ec08e1bf978d6e733f3cebe792e2a23fb07cbca25c2872bfdbdcd" + url: "https://pub.dev" + source: hosted + version: "0.5.1" window_to_front: dependency: transitive description: @@ -2407,26 +2294,26 @@ packages: dependency: transitive description: name: xdg_directories - sha256: faea9dee56b520b55a566385b84f2e8de55e7496104adada9962e0bd11bcff1d + sha256: "7a3f37b05d989967cdddcbb571f1ea834867ae2faa29725fd085180e0883aa15" url: "https://pub.dev" source: hosted - version: "1.0.4" + version: "1.1.0" xml: dependency: transitive description: name: xml - sha256: b015a8ad1c488f66851d762d3090a21c600e479dc75e68328c52774040cf9226 + sha256: "971043b3a0d3da28727e40ed3e0b5d18b742fa5a68665cca88e74b7876d5e025" url: "https://pub.dev" source: hosted - version: "6.5.0" + version: "6.6.1" yaml: dependency: transitive description: name: yaml - sha256: "75769501ea3489fca56601ff33454fe45507ea3bfb014161abc3b43ae25989d5" + sha256: b9da305ac7c39faa3f030eccd175340f968459dae4af175130b3fc47e40d76ce url: "https://pub.dev" source: hosted - version: "3.1.2" + version: "3.1.3" sdks: - dart: ">=3.3.0 <4.0.0" - flutter: ">=3.19.3" + dart: ">=3.10.3 <4.0.0" + flutter: ">=3.38.4" diff --git a/pubspec.yaml b/pubspec.yaml index 7d4febdb2..9ecb47e91 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,110 +1,105 @@ name: fluffychat description: Chat with your friends. publish_to: none -# On version bump also increase the build number for F-Droid -version: 1.21.1+3533 +# On version bump please also increase: +# 1. The build number (for F-Droid) +# 2. The version in /snap/snapcraft.yaml +version: 2.4.0+3546 environment: - sdk: ">=3.0.0 <4.0.0" + sdk: ">=3.10.0 <4.0.0" dependencies: - adaptive_dialog: ^2.1.0 - animations: ^2.0.11 - archive: ^3.4.10 + animations: ^2.1.1 + app_links: ^6.4.1 + archive: ^4.0.7 async: ^2.11.0 badges: ^3.1.2 blurhash_dart: ^1.2.1 - callkeep: ^0.3.2 - chewie: ^1.8.1 + chewie: ^1.13.0 collection: ^1.18.0 + cross_file: ^0.3.5 cupertino_icons: any - desktop_drop: ^0.4.4 + desktop_drop: ^0.7.0 desktop_notifications: ^0.6.3 - device_info_plus: ^10.0.1 - dynamic_color: ^1.7.0 - emoji_picker_flutter: ^2.1.1 - emoji_proposal: ^0.0.1 - emojis: ^0.9.9 - #fcm_shared_isolate: ^0.1.0 - file_picker: ^8.0.1 + device_info_plus: ^12.3.0 + dynamic_color: ^1.8.1 + emoji_picker_flutter: ^4.4.0 + file_picker: ^10.3.10 + file_selector: ^1.1.0 flutter: sdk: flutter - flutter_app_badger: ^1.5.0 - flutter_cache_manager: ^3.3.1 - flutter_foreground_task: ^6.1.3 - flutter_highlighter: ^0.1.1 - flutter_html: ^3.0.0-beta.2 - flutter_html_table: ^3.0.0-beta.2 + flutter_foreground_task: ^9.2.1 flutter_linkify: ^6.0.0 - flutter_local_notifications: ^17.0.0 + flutter_local_notifications: ^20.1.0 flutter_localizations: sdk: flutter - flutter_map: ^6.1.0 - flutter_math_fork: ^0.7.2 - flutter_olm: 1.3.2 # Keep in sync with scripts/prepare-web.sh ! 1.4.0 does currently not build on Android - flutter_openssl_crypto: ^0.3.0 - flutter_ringtone_player: ^4.0.0+2 - flutter_secure_storage: ^9.0.0 - flutter_shortcuts: - git: https://github.com/krille-chan/flutter_shortcuts.git - flutter_typeahead: ^5.2.0 - flutter_web_auth_2: ^3.1.1 - flutter_webrtc: ^0.10.3 - future_loading_dialog: ^0.3.0 - geolocator: ^7.6.2 - go_router: ^14.0.1 - hive: ^2.2.3 - hive_flutter: ^1.1.0 + flutter_map: ^8.2.2 + flutter_new_badger: ^1.1.1 + flutter_secure_storage: ^10.0.0 + flutter_shortcuts_new: ^2.0.0 + flutter_vodozemac: ^0.5.0 + flutter_web_auth_2: ^5.0.1 + flutter_webrtc: ^1.3.1 + geolocator: ^14.0.2 + go_router: ^17.1.0 + handy_window: ^0.4.2 + highlight: ^0.7.0 html: ^0.15.4 - http: ^1.2.0 - image: ^4.1.7 - image_picker: ^1.1.0 + http: ^1.6.0 + image: ^4.7.2 + image_picker: ^1.2.1 intl: any - just_audio: ^0.9.37 - keyboard_shortcuts: ^0.1.4 + just_audio: ^0.10.5 latlong2: ^0.9.1 linkify: ^5.0.0 - matrix: ^0.29.12 - native_imaging: ^0.1.1 - package_info_plus: ^6.0.0 - pasteboard: ^0.2.0 + matrix: ^6.1.1 + mime: ^2.0.0 + native_imaging: ^0.4.0 + opus_caf_converter_dart: ^1.0.1 + package_info_plus: ^9.0.0 + particles_network: ^1.9.3 path: ^1.9.0 path_provider: ^2.1.2 - permission_handler: ^11.0.1 - pretty_qr_code: ^3.2.1 + permission_handler: ^12.0.1 + pretty_qr_code: ^3.6.0 provider: ^6.0.2 punycode: ^1.0.0 - qr_code_scanner: ^1.0.1 - receive_sharing_intent: 1.4.5 # Update needs more work - record: ^5.0.5 + qr_code_scanner_plus: ^2.1.1 + qr_image: ^1.0.0 + receive_sharing_intent: ^1.8.1 + record: ^6.1.2 scroll_to_index: ^3.0.1 - share_plus: ^9.0.0 - shared_preferences: ^2.2.0 # Pinned because https://github.com/flutter/flutter/issues/118401 + share_plus: ^12.0.1 + shared_preferences: ^2.5.4 # Pinned because https://github.com/flutter/flutter/issues/118401 slugify: ^2.0.0 - sqflite_common_ffi: ^2.3.3 - sqlcipher_flutter_libs: ^0.6.1 - swipe_to_action: ^0.2.0 - tor_detector_web: ^1.1.0 - uni_links: ^0.5.1 - unifiedpush: ^5.0.1 - universal_html: ^2.2.4 - url_launcher: ^6.2.5 - video_compress: ^3.1.2 - video_player: ^2.8.5 - wakelock_plus: ^1.2.2 - webrtc_interface: ^1.0.13 + sqflite_common_ffi: ^2.3.7+1 + sqlcipher_flutter_libs: ^0.6.8 + swipe_to_action: ^0.3.0 + unifiedpush: ^6.2.0 + unifiedpush_ui: ^0.2.0 + universal_html: ^2.3.0 + url_launcher: ^6.3.2 + video_compress: ^3.1.4 + video_player: ^2.10.1 + wakelock_plus: ^1.3.3 + webrtc_interface: ^1.3.0 dev_dependencies: - flutter_lints: ^3.0.0 - flutter_native_splash: ^2.0.3+1 + dart_code_linter: ^3.2.1 + flutter_lints: ^6.0.0 + flutter_native_splash: ^2.4.7 flutter_test: sdk: flutter import_sorter: ^4.6.0 integration_test: sdk: flutter - license_checker: ^1.6.0 - msix: ^3.6.2 - translations_cleaner: ^0.0.5 + license_checker: ^1.6.2 + translations_cleaner: ^0.1.0 + +import_sorter: + ignored_files: # Optional, defaults to [] + - \/lib\/l10n flutter_native_splash: color: "#ffffff" @@ -117,46 +112,17 @@ flutter: assets: - assets/ - assets/sounds/ - - assets/js/ - - assets/js/package/ - - fonts: - - family: Roboto - fonts: - - asset: fonts/Roboto/Roboto-Regular.ttf - - asset: fonts/Roboto/Roboto-Italic.ttf - style: italic - - asset: fonts/Roboto/Roboto-Bold.ttf - weight: 700 - - family: RobotoMono - fonts: - - asset: fonts/Roboto/RobotoMono-Regular.ttf - - family: NotoEmoji - fonts: - - asset: fonts/NotoEmoji/NotoColorEmoji.ttf - -msix_config: - display_name: FluffyChat - publisher_display_name: FluffyChat - publisher: CN=FluffyChat, O=Head of bad integration tests, L=Matrix, S=Internet, C=EU - identity_name: chat.fluffy.fluffychat - logo_path: assets\logo.png - capabilities: internetClient, location, microphone, webcam - protocol_activation: https - app_uri_handler_hosts: fluffychat.im, matrix.to - execution_alias: fluffychat - sign_msix: false - install_certificate: false + - assets/vodozemac/ +# Guidelines for adding a dependency override: +# 1. Don't do it if you can avoid it or fix it upstream in a manageable time +# 2. Always link an (upstream?) issue +# 3. Explain how and when this can be removed (overrides must be temporarily) dependency_overrides: - # Until https://github.com/mogol/flutter_secure_storage/issues/616 is fixed - flutter_secure_storage_linux: 1.1.3 - geolocator_android: - hosted: https://hanntech-gmbh.gitlab.io/free2pass/flutter-geolocator-floss - version: ^1.0.1 - # waiting for null safety - # Upstream pull request: https://github.com/AntoineMarcel/keyboard_shortcuts/pull/13 - keyboard_shortcuts: + # To fix 16kb compatiblity in PlayStore. It is fixed in main branch but + # not yet published: + # https://github.com/google/webcrypto.dart/issues/207 + webcrypto: git: - url: https://github.com/TheOneWithTheBraid/keyboard_shortcuts.git - ref: null-safety + url: https://github.com/google/webcrypto.dart.git + ref: master \ No newline at end of file diff --git a/recommended_homeservers.json b/recommended_homeservers.json new file mode 100644 index 000000000..ec2f3dc75 --- /dev/null +++ b/recommended_homeservers.json @@ -0,0 +1,43 @@ +{ + "public_servers": [ + { + "name": "matrix.org", + "website": "https://matrix.org", + "description": "The Matrix.org Foundation offers the matrix.org homeserver as an easy entry point for anyone wanting to try out Matrix.", + "reg_method": "oidc", + "languages": [ + "All", + "English" + ] + }, + { + "name": "converser.eu", + "website": "https://converser.eu", + "description": "A free and decentralized communication server.", + "reg_method": "oidc", + "languages": [ + "All", + "Français" + ] + }, + { + "name": "mozilla.org", + "website": "https://mozilla.org", + "description": "Matrix homeserver hosted by Mozilla.", + "reg_method": "oidc", + "languages": [ + "All", + "English" + ] + }, + { + "name": "magdeburg.jetzt", + "website": "https://magdeburg.jetzt", + "reg_method": "oidc", + "languages": [ + "All", + "Deutsch" + ] + } + ] +} \ No newline at end of file diff --git a/scripts/add-firebase-messaging.sh b/scripts/add-firebase-messaging.sh new file mode 100755 index 000000000..fb845d713 --- /dev/null +++ b/scripts/add-firebase-messaging.sh @@ -0,0 +1,12 @@ +#!/usr/bin/env bash + +flutter pub add fcm_shared_isolate:0.2.0 +flutter pub get + +if [[ "$OSTYPE" == "darwin"* ]]; then + sed -i '' 's,//,,g' lib/utils/background_push.dart + sed -i '' -e 's,^/\*,,' -e 's,\*/$,,' android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt +else + sed -i 's,//,,g' lib/utils/background_push.dart + sed -i -e 's,^/\*,,' -e 's,\*/$,,' android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt +fi diff --git a/scripts/build-macos.sh b/scripts/build-macos.sh index 11d3e4a09..f25711e13 100755 --- a/scripts/build-macos.sh +++ b/scripts/build-macos.sh @@ -30,6 +30,4 @@ FLUFFYCHAT_ORIG_TEAM="4NXF6Z997G" ### Make release build ### flutter build macos --release -cp /usr/local/Cellar/libolm/**/lib/libolm.3.dylib build/macos/Build/Products/Release/FluffyChat.app/Contents/Frameworks/libolm.3.dylib - echo "Build build/macos/Build/Products/Release/FluffyChat.app" diff --git a/scripts/build-olm-windows.sh b/scripts/build-olm-windows.sh deleted file mode 100755 index 003b98eeb..000000000 --- a/scripts/build-olm-windows.sh +++ /dev/null @@ -1,7 +0,0 @@ -#!/usr/bin/env bash - -git clone https://gitlab.matrix.org/matrix-org/olm.git -b 3.2.12 -cd olm -cmake . -Bbuild -DCMAKE_TOOLCHAIN_FILE=Windows64.cmake -cmake --build build -cd .. diff --git a/scripts/enable-android-google-services.patch b/scripts/enable-android-google-services.patch deleted file mode 100644 index 8353553d3..000000000 --- a/scripts/enable-android-google-services.patch +++ /dev/null @@ -1,161 +0,0 @@ -diff --git a/android/app/build.gradle b/android/app/build.gradle -index bf972f30..46cebdc6 100644 ---- a/android/app/build.gradle -+++ b/android/app/build.gradle -@@ -70,6 +70,10 @@ - } - release { - signingConfig signingConfigs.release -+ minifyEnabled false -+ shrinkResources false -+ -+ proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' - } - } - // https://stackoverflow.com/a/77494454/8222484 -@@ -78,8 +82,11 @@ flutter { - - dependencies { - implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" -- //implementation 'com.google.firebase:firebase-messaging:19.0.1' // Workaround for https://github.com/microg/android_packages_apps_GmsCore/issues/313#issuecomment-617651698 -+ implementation 'com.google.firebase:firebase-messaging:19.0.1' // Workaround for https://github.com/microg/android_packages_apps_GmsCore/issues/313#issuecomment-617651698 -+ testImplementation 'junit:junit:4.12' -+ androidTestImplementation 'androidx.test:runner:1.1.1' -+ androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1' - implementation 'androidx.multidex:multidex:2.0.1' - } - --//apply plugin: 'com.google.gms.google-services' -+apply plugin: 'com.google.gms.google-services' -diff --git a/android/app/proguard-rules.pro b/android/app/proguard-rules.pro -index d0e0fbc9..0a546da0 100644 ---- a/android/app/proguard-rules.pro -+++ b/android/app/proguard-rules.pro -@@ -1 +1,42 @@ ---keep class net.sqlcipher.** { *; } -\ No newline at end of file -+-optimizationpasses 5 -+## Flutter wrapper -+-keep class net.sqlcipher.** { *; } -+-keep class io.flutter.app.** { *; } -+-keep class io.flutter.plugin.** { *; } -+-keep class io.flutter.util.** { *; } -+-keep class io.flutter.view.** { *; } -+-keep class io.flutter.** { *; } -+-keep class io.flutter.plugins.** { *; } -+-dontwarn io.flutter.embedding.** -+ -+##---------------Begin: proguard configuration for Gson (Needed for flutter_local_notifications) ---------- -+# Gson uses generic type information stored in a class file when working with fields. Proguard -+# removes such information by default, so configure it to keep all of it. -+-keepattributes Signature -+ -+# For using GSON @Expose annotation -+-keepattributes *Annotation* -+ -+# Gson specific classes -+-dontwarn sun.misc.** -+ -+# Application classes that will be serialized/deserialized over Gson -+-keep class com.google.gson.examples.android.model.** { ; } -+ -+# Prevent proguard from stripping interface information from TypeAdapter, TypeAdapterFactory, -+# JsonSerializer, JsonDeserializer instances (so they can be used in @JsonAdapter) -+-keep class * extends com.google.gson.TypeAdapter -+-keep class * implements com.google.gson.TypeAdapterFactory -+-keep class * implements com.google.gson.JsonSerializer -+-keep class * implements com.google.gson.JsonDeserializer -+ -+# Prevent R8 from leaving Data object members always null -+-keepclassmembers,allowobfuscation class * { -+ @com.google.gson.annotations.SerializedName ; -+} -+ -+# Retain generic signatures of TypeToken and its subclasses with R8 version 3.0 and higher. -+-keep,allowobfuscation,allowshrinking class com.google.gson.reflect.TypeToken -+-keep,allowobfuscation,allowshrinking class * extends com.google.gson.reflect.TypeToken -+ -+##---------------End: proguard configuration for Gson (Needed for flutter_local_notifications) ---------- -\ No newline at end of file -diff --git a/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt b/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt -index d9930f55..510e9845 100644 ---- a/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt -+++ b/android/app/src/main/kotlin/chat/fluffy/fluffychat/FcmPushService.kt -@@ -1,4 +1,4 @@ --/*package chat.fluffy.fluffychat -+package chat.fluffy.fluffychat - - import com.famedly.fcm_shared_isolate.FcmSharedIsolateService - -@@ -33,4 +33,3 @@ class FcmPushService : FcmSharedIsolateService() { - } - } - } --*/ -\ No newline at end of file -diff --git a/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt b/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt -index 1afc4606..894d1571 100644 ---- a/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt -+++ b/android/app/src/main/kotlin/chat/fluffy/fluffychat/MainActivity.kt -@@ -7,13 +7,11 @@ import android.content.Context - import androidx.multidex.MultiDex - - class MainActivity : FlutterActivity() { -- - override fun attachBaseContext(base: Context) { - super.attachBaseContext(base) - MultiDex.install(this) - } - -- - override fun provideFlutterEngine(context: Context): FlutterEngine? { - return provideEngine(this) - } -diff --git a/android/build.gradle b/android/build.gradle -index bd394967..2e9d54de 100644 ---- a/android/build.gradle -+++ b/android/build.gradle -@@ -8,7 +8,7 @@ buildscript { - dependencies { - classpath 'com.android.tools.build:gradle:7.1.2' - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" -- //classpath 'com.google.gms:google-services:4.3.8' -+ classpath 'com.google.gms:google-services:4.3.8' - } - } - -diff --git a/lib/utils/background_push.dart b/lib/utils/background_push.dart -index 8e67ae92..da4da5c3 100644 ---- a/lib/utils/background_push.dart -+++ b/lib/utils/background_push.dart -@@ -39,7 +39,7 @@ import '../config/setting_keys.dart'; - import '../widgets/matrix.dart'; - import 'platform_infos.dart'; - --//import 'package:fcm_shared_isolate/fcm_shared_isolate.dart'; -+import 'package:fcm_shared_isolate/fcm_shared_isolate.dart'; - - class NoTokenException implements Exception { - String get cause => 'Cannot get firebase token'; -@@ -64,7 +64,7 @@ class BackgroundPush { - - final pendingTests = >{}; - -- final dynamic firebase = null; //FcmSharedIsolate(); -+ final dynamic firebase = FcmSharedIsolate(); - - DateTime? lastReceivedPush; - -diff --git a/pubspec.yaml b/pubspec.yaml -index 193e6ed6..f70e48d4 100644 ---- a/pubspec.yaml -+++ b/pubspec.yaml -@@ -26,7 +26,7 @@ dependencies: - emoji_picker_flutter: ^2.1.1 - emoji_proposal: ^0.0.1 - emojis: ^0.9.9 -- #fcm_shared_isolate: ^0.1.0 -+ fcm_shared_isolate: ^0.1.0 - file_picker: ^8.0.1 - flutter: - sdk: flutter diff --git a/scripts/generate-locale-config.sh b/scripts/generate-locale-config.sh new file mode 100755 index 000000000..b697850be --- /dev/null +++ b/scripts/generate-locale-config.sh @@ -0,0 +1,31 @@ +#!/bin/bash + +# Directory containing the ARB files +l10n_dir="./lib/l10n" +# Target directory for the locale_config.xml file +xml_dir="./android/app/src/main/res/xml" + +# Create the target directory if it does not exist +mkdir -p "$xml_dir" + +# Output file name +xml_file="$xml_dir/locale_config.xml" + +rm -rf "$xml_file" + +# XML Header +echo '' > "$xml_file" +echo '' >> "$xml_file" + +# Search for ARB files and extract language codes +for file in "$l10n_dir"/intl_*.arb; do + # Extract language code + language_code=$(basename "$file" | cut -d'_' -f2 | cut -d'.' -f1) + # Write language code to the XML file + echo " " >> "$xml_file" +done + +# XML Footer +echo '' >> "$xml_file" + +echo "locale_config.xml file has been successfully created in the $xml_dir directory." diff --git a/scripts/generate_command_hints_glue.sh b/scripts/generate_command_hints_glue.sh index f0c941cec..292cbdc30 100755 --- a/scripts/generate_command_hints_glue.sh +++ b/scripts/generate_command_hints_glue.sh @@ -9,7 +9,7 @@ # Looking to add descriptions for a new command, but don't know what it does? # It is likely defined here (in registerDefaultCommands()): -# https://gitlab.com/famedly/company/frontend/famedlysdk/-/blob/main/lib/src/utils/commands_extension.dart +# https://github.com/famedly/matrix-dart-sdk/tree/main/lib/src/utils/commands_extension.dart echo "\ // This file is auto-generated using scripts/generate_command_hints_glue.sh. @@ -21,7 +21,7 @@ String commandHint(L10n l10n, String command) { $(sed -n \ 's/[[:blank:]]*\"\(commandHint_\([[:lower:]]*\)\)\".*/ case "\2":\ return l10n.\1;/p' \ - assets/l10n/intl_en.arb + lib/l10n/intl_en.arb ) default: return \"\"; diff --git a/scripts/integration-create-environment-variables.sh b/scripts/integration-create-environment-variables.sh deleted file mode 100755 index d2b3a8fe1..000000000 --- a/scripts/integration-create-environment-variables.sh +++ /dev/null @@ -1,6 +0,0 @@ -#!/usr/bin/env bash - -export USER1_NAME="alice" -export USER1_PW="AliceInWonderland" -export USER2_NAME="bob" -export USER2_PW="JoWirSchaffenDas" diff --git a/scripts/integration-prepare-homeserver.sh b/scripts/integration-prepare-homeserver.sh index 6bbee117b..61c43e07f 100755 --- a/scripts/integration-prepare-homeserver.sh +++ b/scripts/integration-prepare-homeserver.sh @@ -1,60 +1,11 @@ #!/usr/bin/env bash -if [ -z $HOMESERVER ]; then - echo "Please ensure HOMESERVER environment variable is set to the IP or hostname of the homeserver." - exit 1 -fi -if [ -z $USER1_NAME ]; then - echo "Please ensure USER1_NAME environment variable is set to first user name." - exit 1 -fi -if [ -z $USER1_PW ]; then - echo "Please ensure USER1_PW environment variable is set to first user password." - exit 1 -fi -if [ -z $USER2_NAME ]; then - echo "Please ensure USER2_NAME environment variable is set to second user name." - exit 1 -fi -if [ -z $USER2_PW ]; then - echo "Please ensure USER2_PW environment variable is set to second user password." - exit 1 -fi -echo "Waiting for homeserver to be available... (GET http://$HOMESERVER/_matrix/client/v3/login)" - -while ! curl -XGET "http://$HOMESERVER/_matrix/client/v3/login" >/dev/null 2>/dev/null; do +while ! curl -XGET "http://localhost/_matrix/client/v3/login" >/dev/null 2>/dev/null; do + echo "Waiting for homeserver to be available... (GET http://localhost/_matrix/client/v3/login)" sleep 2 done -echo "Homeserver is up." - # create users - -curl -fS --retry 3 -XPOST -d "{\"username\":\"$USER1_NAME\", \"password\":\"$USER1_PW\", \"inhibit_login\":true, \"auth\": {\"type\":\"m.login.dummy\"}}" "http://$HOMESERVER/_matrix/client/r0/register" -curl -fS --retry 3 -XPOST -d "{\"username\":\"$USER2_NAME\", \"password\":\"$USER2_PW\", \"inhibit_login\":true, \"auth\": {\"type\":\"m.login.dummy\"}}" "http://$HOMESERVER/_matrix/client/r0/register" - -usertoken1=$(curl -fS --retry 3 "http://$HOMESERVER/_matrix/client/r0/login" -H "Content-Type: application/json" -d "{\"type\": \"m.login.password\", \"identifier\": {\"type\": \"m.id.user\",\"user\": \"$USER1_NAME\"},\"password\":\"$USER1_PW\"}" | jq -r '.access_token') -usertoken2=$(curl -fS --retry 3 "http://$HOMESERVER/_matrix/client/r0/login" -H "Content-Type: application/json" -d "{\"type\": \"m.login.password\", \"identifier\": {\"type\": \"m.id.user\",\"user\": \"$USER2_NAME\"},\"password\":\"$USER2_PW\"}" | jq -r '.access_token') - - -# get usernames' mxids -mxid1=$(curl -fS --retry 3 "http://$HOMESERVER/_matrix/client/r0/account/whoami" -H "Authorization: Bearer $usertoken1" | jq -r .user_id) -mxid2=$(curl -fS --retry 3 "http://$HOMESERVER/_matrix/client/r0/account/whoami" -H "Authorization: Bearer $usertoken2" | jq -r .user_id) - -# setting the display name to username -curl -fS --retry 3 -XPUT -d "{\"displayname\":\"$USER1_NAME\"}" "http://$HOMESERVER/_matrix/client/v3/profile/$mxid1/displayname" -H "Authorization: Bearer $usertoken1" -curl -fS --retry 3 -XPUT -d "{\"displayname\":\"$USER2_NAME\"}" "http://$HOMESERVER/_matrix/client/v3/profile/$mxid2/displayname" -H "Authorization: Bearer $usertoken2" - -echo "Set display names" - -# create new room to invite user too -roomID=$(curl --retry 3 --silent --fail -XPOST -d "{\"name\":\"$USER2_NAME\", \"is_direct\": true}" "http://$HOMESERVER/_matrix/client/r0/createRoom?access_token=$usertoken2" | jq -r '.room_id') -echo "Created room '$roomID'" - -# send message in created room -curl --retry 3 --fail --silent -XPOST -d '{"msgtype":"m.text", "body":"joined room successfully"}' "http://$HOMESERVER/_matrix/client/r0/rooms/$roomID/send/m.room.message?access_token=$usertoken2" -echo "Sent message" - -curl -fS --retry 3 -XPOST -d "{\"user_id\":\"$mxid1\"}" "http://$HOMESERVER/_matrix/client/r0/rooms/$roomID/invite?access_token=$usertoken2" -echo "Invited $USER1_NAME" +curl -fS --retry 3 -XPOST -d "{\"username\":\"$USER1_NAME\", \"password\":\"$USER1_PW\", \"inhibit_login\":true, \"auth\": {\"type\":\"m.login.dummy\"}}" "http://localhost/_matrix/client/r0/register" +curl -fS --retry 3 -XPOST -d "{\"username\":\"$USER2_NAME\", \"password\":\"$USER2_PW\", \"inhibit_login\":true, \"auth\": {\"type\":\"m.login.dummy\"}}" "http://localhost/_matrix/client/r0/register" diff --git a/scripts/package-windows.ps1 b/scripts/package-windows.ps1 deleted file mode 100644 index b3ba0e70a..000000000 --- a/scripts/package-windows.ps1 +++ /dev/null @@ -1,5 +0,0 @@ -Write-Output "$WINDOWN_PFX" -Move-Item -Path $WINDOWS_PFX -Destination fluffychat.pem -certutil -decode fluffychat.pem fluffychat.pfx - -flutter pub run msix:create -c fluffychat.pfx -p $WINDOWS_PFX_PASS --sign-msix true --install-certificate false diff --git a/scripts/prepare-macos.sh b/scripts/prepare-macos.sh deleted file mode 100755 index 95f2a9cff..000000000 --- a/scripts/prepare-macos.sh +++ /dev/null @@ -1,8 +0,0 @@ -#!/usr/bin/env bash - -if ! type "flutter" > /dev/null; then - brew install flutter -fi - -brew install libolm - diff --git a/scripts/prepare-web.sh b/scripts/prepare-web.sh index 70b15a246..b4ec1889a 100755 --- a/scripts/prepare-web.sh +++ b/scripts/prepare-web.sh @@ -1,10 +1,24 @@ #!/bin/sh -ve -rm -r assets/js/package -OLM_VERSION=$(cat pubspec.yaml | yq .dependencies.flutter_olm) -DOWNLOAD_PATH="https://github.com/famedly/olm/releases/download/v$OLM_VERSION/olm.zip" +# Compile Vodozemac for web +version=$(yq ".dependencies.flutter_vodozemac" < pubspec.yaml) +version=$(expr "$version" : '\^*\(.*\)') +git clone https://github.com/famedly/dart-vodozemac.git -b ${version} .vodozemac +cd .vodozemac +cargo install flutter_rust_bridge_codegen +flutter_rust_bridge_codegen build-web --dart-root dart --rust-root $(readlink -f rust) --release +cd .. +rm -f ./assets/vodozemac/vodozemac_bindings_dart* +mv .vodozemac/dart/web/pkg/vodozemac_bindings_dart* ./assets/vodozemac/ +rm -rf .vodozemac +flutter pub get +dart compile js ./web/native_executor.dart -o ./web/native_executor.js -m -cd assets/js/ && curl -L $DOWNLOAD_PATH > olm.zip && cd ../../ -cd assets/js/ && unzip olm.zip && cd ../../ -cd assets/js/ && rm olm.zip && cd ../../ -cd assets/js/ && mv javascript package && cd ../../ +# Download native_imaging for web: +version=$(yq ".dependencies.native_imaging" < pubspec.yaml) +version=$(expr "$version" : '\^*\(.*\)') +curl -L "https://github.com/famedly/dart_native_imaging/releases/download/v${version}/native_imaging.zip" > native_imaging.zip +unzip native_imaging.zip +mv js/* web/ +rmdir js +rm native_imaging.zip \ No newline at end of file diff --git a/scripts/release-ios-testflight.sh b/scripts/release-ios-testflight.sh index e3f1a109a..5eef16622 100755 --- a/scripts/release-ios-testflight.sh +++ b/scripts/release-ios-testflight.sh @@ -1,14 +1,13 @@ #!/bin/sh -ve -git apply ./scripts/enable-android-google-services.patch -rm -rf fonts/NotoEmoji -yq -i 'del( .flutter.fonts[] | select(.family == "NotoEmoji") )' pubspec.yaml +flutter pub add fcm_shared_isolate:0.2.0 +sed -i '' 's,//,,g' lib/utils/background_push.dart flutter clean flutter pub get cd ios rm -rf Pods rm -f Podfile.lock -arch -x86_64 pod install -arch -x86_64 pod update +pod install +pod update cd .. flutter build ios --release cd ios diff --git a/snap/snapcraft.yaml b/snap/snapcraft.yaml index a32ad5704..ca9a0a16d 100644 --- a/snap/snapcraft.yaml +++ b/snap/snapcraft.yaml @@ -1,7 +1,7 @@ name: fluffychat title: FluffyChat -base: core22 -version: git +base: core24 +version: 2.4.0 license: AGPL-3.0 summary: The cutest messenger in the Matrix network description: | @@ -37,36 +37,23 @@ description: | And a world where apps are made for fluffyness and not for profit. ♥ - Join the community: https://matrix.to/#/#fluffychat:matrix.org - Website: http://fluffychat.im + Join the community: https://matrix.to/#/#fluffy-space:matrix.org + Website: http://fluffy.chat Microblog: https://mastodon.art/@krille grade: stable confinement: strict -architectures: - - build-on: amd64 - - build-on: arm64 +platforms: + amd64: + build-on: amd64 + arm64: + build-on: arm64 parts: - olm: - plugin: cmake - cmake-parameters: - - -DCMAKE_INSTALL_PREFIX=/usr - source: https://gitlab.matrix.org/matrix-org/olm.git - source-type: git - source-tag: '3.2.14' - build-packages: - - g++ - - zenity-integration: - plugin: nil - stage-snaps: - - zenity-integration - flutter-git: source: https://github.com/flutter/flutter.git - source-tag: 3.19.6 + source-tag: 3.41.2 source-depth: 1 plugin: nil override-build: | @@ -85,6 +72,8 @@ parts: - unzip - xz-utils - zip + - lld + - llvm-18 override-prime: '' fluffychat: @@ -99,12 +88,16 @@ parts: mkdir -p $CRAFT_PART_INSTALL/bin/ cp -r build/linux/*/release/bundle/* $CRAFT_PART_INSTALL/bin/ build-packages: - - libjsoncpp-dev - - curl - stage-packages: - libsecret-1-dev - libjsoncpp-dev - - libssl-dev + - curl + - libpciaccess-dev + build-snaps: + - rustup + stage-packages: + - libsecret-1-0 + - libjsoncpp25 + - libpciaccess0 slots: dbus-svc: @@ -136,4 +129,4 @@ apps: XDG_DATA_HOME: $SNAP_USER_DATA XDG_DATA_DIRS: $SNAP/usr/share GDK_GL: gles - LD_LIBRARY_PATH: "$LD_LIBRARY_PATH:$SNAP/lib:$SNAP/usr/lib/$SNAPCRAFT_ARCH_TRIPLET" \ No newline at end of file + LD_LIBRARY_PATH: "$LD_LIBRARY_PATH:$SNAP/lib:$SNAP/usr/lib/$SNAPCRAFT_ARCH_TRIPLET" diff --git a/test/archive_test.dart b/test/archive_test.dart index 25bb090e7..33ff38ab1 100644 --- a/test/archive_test.dart +++ b/test/archive_test.dart @@ -6,5 +6,6 @@ void main() { testWidget: Archive(), testClient: await testClient(loggedIn: true), ));*/ + return; }); } diff --git a/test/command_hint_test.dart b/test/command_hint_test.dart index e56f06052..84f558635 100644 --- a/test/command_hint_test.dart +++ b/test/command_hint_test.dart @@ -8,8 +8,7 @@ import 'utils/test_client.dart'; void main() async { test('Check for missing /command hints', () async { final translated = - jsonDecode(File('assets/l10n/intl_en.arb').readAsStringSync()) - .keys + jsonDecode(File('lib/l10n/intl_en.arb').readAsStringSync()).keys .where((String k) => k.startsWith('commandHint_')) .map((k) => k.replaceFirst('commandHint_', '')); final commands = (await prepareTestClient()).commands.keys; diff --git a/test/homeserver_picker_test.dart b/test/homeserver_picker_test.dart index 054f49cab..3200fdd2f 100644 --- a/test/homeserver_picker_test.dart +++ b/test/homeserver_picker_test.dart @@ -13,5 +13,6 @@ void main() { testWidget: HomeserverPicker(), ), );*/ + return; }); } diff --git a/test/utils/test_client.dart b/test/utils/test_client.dart index 7cbe72f71..720925a21 100644 --- a/test/utils/test_client.dart +++ b/test/utils/test_client.dart @@ -2,8 +2,7 @@ import 'package:matrix/encryption/utils/key_verification.dart'; import 'package:matrix/matrix.dart'; - -import 'package:fluffychat/utils/matrix_sdk_extensions/flutter_hive_collections_database.dart'; +import 'package:sqflite_common_ffi/sqflite_ffi.dart'; Future prepareTestClient({ bool loggedIn = false, @@ -22,7 +21,11 @@ Future prepareTestClient({ importantStateEvents: { 'im.ponies.room_emotes', // we want emotes to work properly }, - databaseBuilder: FlutterHiveCollectionsDatabase.databaseBuilder, + database: await MatrixSdkDatabase.init( + 'test', + database: await databaseFactoryFfi.openDatabase(':memory:'), + sqfliteFactory: databaseFactoryFfi, + ), supportedLoginTypes: { AuthenticationTypes.password, AuthenticationTypes.sso, diff --git a/test/widget_test.dart b/test/widget_test.dart index 7d1d98eb6..beb6cd2a1 100644 --- a/test/widget_test.dart +++ b/test/widget_test.dart @@ -16,5 +16,6 @@ void main() { /* await tester.pumpWidget(FluffyChatApp( client: await prepareTestClient(), ));*/ + return; }); } diff --git a/web/icons/Icon-192.png b/web/icons/Icon-192.png index 3781c0638..6003f5cf7 100644 Binary files a/web/icons/Icon-192.png and b/web/icons/Icon-192.png differ diff --git a/web/icons/Icon-512.png b/web/icons/Icon-512.png index 8b824e807..f652f244a 100644 Binary files a/web/icons/Icon-512.png and b/web/icons/Icon-512.png differ diff --git a/web/index.html b/web/index.html index 3a3fdc773..c593cc057 100644 --- a/web/index.html +++ b/web/index.html @@ -22,7 +22,7 @@ - + @@ -33,29 +33,27 @@ FluffyChat + - - @@ -70,4 +68,4 @@ - \ No newline at end of file + diff --git a/web/native_executor.dart b/web/native_executor.dart new file mode 100644 index 000000000..888af44a9 --- /dev/null +++ b/web/native_executor.dart @@ -0,0 +1,3 @@ +import 'package:matrix/matrix.dart'; + +void main() => startWebWorker(); diff --git a/web/splash/style.css b/web/splash/style.css index 1645ccb87..6654d94e6 100644 --- a/web/splash/style.css +++ b/web/splash/style.css @@ -40,7 +40,6 @@ html { margin: 0; height: 100%; background: #000000; - background-image: url("img/dark-background.png"); background-size: 100% 100%; } } \ No newline at end of file diff --git a/windows/flutter/generated_plugin_registrant.cc b/windows/flutter/generated_plugin_registrant.cc index 1d3cbc895..0e75c6434 100644 --- a/windows/flutter/generated_plugin_registrant.cc +++ b/windows/flutter/generated_plugin_registrant.cc @@ -6,23 +6,32 @@ #include "generated_plugin_registrant.h" +#include #include +#include #include #include #include #include #include -#include +#include #include #include +#include #include #include #include +#include +#include #include void RegisterPlugins(flutter::PluginRegistry* registry) { + AppLinksPluginCApiRegisterWithRegistrar( + registry->GetRegistrarForPlugin("AppLinksPluginCApi")); DesktopDropPluginRegisterWithRegistrar( registry->GetRegistrarForPlugin("DesktopDropPlugin")); + DesktopWebviewWindowPluginRegisterWithRegistrar( + registry->GetRegistrarForPlugin("DesktopWebviewWindowPlugin")); DynamicColorPluginCApiRegisterWithRegistrar( registry->GetRegistrarForPlugin("DynamicColorPluginCApi")); EmojiPickerFlutterPluginCApiRegisterWithRegistrar( @@ -33,18 +42,24 @@ void RegisterPlugins(flutter::PluginRegistry* registry) { registry->GetRegistrarForPlugin("FlutterSecureStorageWindowsPlugin")); FlutterWebRTCPluginRegisterWithRegistrar( registry->GetRegistrarForPlugin("FlutterWebRTCPlugin")); - PasteboardPluginRegisterWithRegistrar( - registry->GetRegistrarForPlugin("PasteboardPlugin")); + GeolocatorWindowsRegisterWithRegistrar( + registry->GetRegistrarForPlugin("GeolocatorWindows")); PermissionHandlerWindowsPluginRegisterWithRegistrar( registry->GetRegistrarForPlugin("PermissionHandlerWindowsPlugin")); RecordWindowsPluginCApiRegisterWithRegistrar( registry->GetRegistrarForPlugin("RecordWindowsPluginCApi")); + ScreenRetrieverWindowsPluginCApiRegisterWithRegistrar( + registry->GetRegistrarForPlugin("ScreenRetrieverWindowsPluginCApi")); SharePlusWindowsPluginCApiRegisterWithRegistrar( registry->GetRegistrarForPlugin("SharePlusWindowsPluginCApi")); Sqlite3FlutterLibsPluginRegisterWithRegistrar( registry->GetRegistrarForPlugin("Sqlite3FlutterLibsPlugin")); UrlLauncherWindowsRegisterWithRegistrar( registry->GetRegistrarForPlugin("UrlLauncherWindows")); + WebcryptoPluginRegisterWithRegistrar( + registry->GetRegistrarForPlugin("WebcryptoPlugin")); + WindowManagerPluginRegisterWithRegistrar( + registry->GetRegistrarForPlugin("WindowManagerPlugin")); WindowToFrontPluginRegisterWithRegistrar( registry->GetRegistrarForPlugin("WindowToFrontPlugin")); } diff --git a/windows/flutter/generated_plugins.cmake b/windows/flutter/generated_plugins.cmake index 1e12e9789..307090774 100644 --- a/windows/flutter/generated_plugins.cmake +++ b/windows/flutter/generated_plugins.cmake @@ -3,22 +3,29 @@ # list(APPEND FLUTTER_PLUGIN_LIST + app_links desktop_drop + desktop_webview_window dynamic_color emoji_picker_flutter file_selector_windows flutter_secure_storage_windows flutter_webrtc - pasteboard + geolocator_windows permission_handler_windows record_windows + screen_retriever_windows share_plus sqlcipher_flutter_libs url_launcher_windows + webcrypto + window_manager window_to_front ) list(APPEND FLUTTER_FFI_PLUGIN_LIST + flutter_local_notifications_windows + flutter_vodozemac ) set(PLUGIN_BUNDLED_LIBRARIES) diff --git a/winuwp/.gitignore b/winuwp/.gitignore deleted file mode 100644 index d492d0d98..000000000 --- a/winuwp/.gitignore +++ /dev/null @@ -1,17 +0,0 @@ -flutter/ephemeral/ - -# Visual Studio user-specific files. -*.suo -*.user -*.userosscache -*.sln.docstates - -# Visual Studio build-related files. -x64/ -x86/ - -# Visual Studio cache files -# files ending in .cache can be ignored -*.[Cc]ache -# but keep track of directories ending in .cache -!*.[Cc]ache/ diff --git a/winuwp/CMakeLists.txt b/winuwp/CMakeLists.txt deleted file mode 100644 index 7530c80c6..000000000 --- a/winuwp/CMakeLists.txt +++ /dev/null @@ -1,64 +0,0 @@ -# Project-level configuration. -cmake_minimum_required(VERSION 3.8) -set(CMAKE_SYSTEM_NAME WindowsStore) -set(CMAKE_SYSTEM_VERSION 10.0) -set(CMAKE_CXX_STANDARD 17) -set(CMAKE_CXX_STANDARD_REQUIRED YES) -project(fluffychat LANGUAGES CXX) - -# Explicitly opt in to modern CMake behaviors to avoid warnings with recent -# versions of CMake. -cmake_policy(SET CMP0079 NEW) - -# The name of the executable created for the application. Change this to change -# the on-disk name of your application. -set(BINARY_NAME "fluffychat") - -# Define build configuration options. -get_property(IS_MULTICONFIG GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG) -if(IS_MULTICONFIG) - set(CMAKE_CONFIGURATION_TYPES "Debug;Profile;Release" - CACHE STRING "" FORCE) -else() - if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES) - set(CMAKE_BUILD_TYPE "Debug" CACHE - STRING "Flutter build mode" FORCE) - set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS - "Debug" "Profile" "Release") - endif() -endif() -# Define settings for the Profile build mode. -set(CMAKE_EXE_LINKER_FLAGS_PROFILE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}") -set(CMAKE_SHARED_LINKER_FLAGS_PROFILE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE}") -set(CMAKE_C_FLAGS_PROFILE "${CMAKE_C_FLAGS_RELEASE}") -set(CMAKE_CXX_FLAGS_PROFILE "${CMAKE_CXX_FLAGS_RELEASE}") - -# Use Unicode for all projects. -add_definitions(-DUNICODE -D_UNICODE) - -# Compilation settings that should be applied to most targets. -# -# Be cautious about adding new options here, as plugins use this function by -# default. In most cases, you should add new options to specific targets instead -# of modifying this function. -function(APPLY_STANDARD_SETTINGS TARGET) - target_compile_features(${TARGET} PUBLIC cxx_std_17) - target_compile_options(${TARGET} PRIVATE /W4 /WX /wd"4100" /await) - target_compile_options(${TARGET} PRIVATE /EHsc) - target_compile_definitions(${TARGET} PRIVATE "_HAS_EXCEPTIONS=0") - target_compile_definitions(${TARGET} PRIVATE "$<$:_DEBUG>") - target_compile_definitions(${TARGET} PRIVATE WINUWP) - set_target_properties(${TARGET} PROPERTIES VS_WINDOWS_TARGET_PLATFORM_MIN_VERSION 10.0.18362.0) -endfunction() - -set(FLUTTER_MANAGED_DIR "${CMAKE_CURRENT_SOURCE_DIR}/flutter") - -# Flutter library and tool build rules. -add_subdirectory(${FLUTTER_MANAGED_DIR}) - -# Application build; see runner/CMakeLists.txt. -add_subdirectory("runner_uwp") - -# Generated plugin build rules, which manage building the plugins and adding -# them to the application. -include(flutter/generated_plugins.cmake) diff --git a/winuwp/flutter/CMakeLists.txt b/winuwp/flutter/CMakeLists.txt deleted file mode 100644 index 9adbd9ddb..000000000 --- a/winuwp/flutter/CMakeLists.txt +++ /dev/null @@ -1,92 +0,0 @@ -# This file controls Flutter-level build steps. It should not be edited. -cmake_minimum_required(VERSION 3.8) -set(CMAKE_SYSTEM_NAME WindowsStore) -set(CMAKE_SYSTEM_VERSION 10.0) -set(EPHEMERAL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/ephemeral") - -include(CMakePrintHelpers) - -# Configuration provided via flutter tool. -include(${EPHEMERAL_DIR}/generated_config.cmake) - -# TODO: Move the rest of this into files in ephemeral. See -# https://github.com/flutter/flutter/issues/57146. -set(WRAPPER_ROOT "${EPHEMERAL_DIR}/cpp_client_wrapper") - -# === Flutter Library === -set(FLUTTER_LIBRARY "${EPHEMERAL_DIR}/flutter_windows_winuwp.dll") - -# === Assets === -set(CMAKE_INSTALL_MANIFEST "${EPHEMERAL_DIR}/install_manifest") -file(STRINGS ${CMAKE_INSTALL_MANIFEST} INSTALL_MANIFEST_CONTENT) - -# Published to parent scope for install step. -set(FLUTTER_LIBRARY ${FLUTTER_LIBRARY} PARENT_SCOPE) -set(INSTALL_MANIFEST_CONTENT ${INSTALL_MANIFEST_CONTENT} PARENT_SCOPE) - -list(APPEND FLUTTER_LIBRARY_HEADERS - "flutter_export.h" - "flutter_windows.h" - "flutter_messenger.h" - "flutter_plugin_registrar.h" - "flutter_texture_registrar.h" -) -list(TRANSFORM FLUTTER_LIBRARY_HEADERS PREPEND "${EPHEMERAL_DIR}/") -add_library(flutter INTERFACE) -target_include_directories(flutter INTERFACE - "${EPHEMERAL_DIR}" -) -target_link_libraries(flutter INTERFACE "${FLUTTER_LIBRARY}.lib") -add_dependencies(flutter flutter_assemble) - -# === Wrapper === -list(APPEND CPP_WRAPPER_SOURCES_CORE - "core_implementations.cc" - "standard_codec.cc" -) -list(TRANSFORM CPP_WRAPPER_SOURCES_CORE PREPEND "${WRAPPER_ROOT}/") -list(APPEND CPP_WRAPPER_SOURCES_PLUGIN - "plugin_registrar.cc" -) -list(TRANSFORM CPP_WRAPPER_SOURCES_PLUGIN PREPEND "${WRAPPER_ROOT}/") -list(APPEND CPP_WRAPPER_SOURCES_APP - "flutter_engine.cc" - "flutter_view_controller.cc" -) -list(TRANSFORM CPP_WRAPPER_SOURCES_APP PREPEND "${WRAPPER_ROOT}/") - -# Wrapper sources needed for a plugin. -add_library(flutter_wrapper_plugin STATIC - ${CPP_WRAPPER_SOURCES_CORE} - ${CPP_WRAPPER_SOURCES_PLUGIN} -) -apply_standard_settings(flutter_wrapper_plugin) -set_target_properties(flutter_wrapper_plugin PROPERTIES - POSITION_INDEPENDENT_CODE ON) -set_target_properties(flutter_wrapper_plugin PROPERTIES - CXX_VISIBILITY_PRESET hidden) -target_link_libraries(flutter_wrapper_plugin PUBLIC flutter) -target_include_directories(flutter_wrapper_plugin PUBLIC - "${WRAPPER_ROOT}/include" -) -add_dependencies(flutter_wrapper_plugin flutter_assemble) - -# Wrapper sources needed for the runner. -add_library(flutter_wrapper_app STATIC - ${CPP_WRAPPER_SOURCES_CORE} - ${CPP_WRAPPER_SOURCES_APP} -) -apply_standard_settings(flutter_wrapper_app) -target_link_libraries(flutter_wrapper_app PUBLIC flutter) -target_include_directories(flutter_wrapper_app PUBLIC - "${WRAPPER_ROOT}/include" -) -add_dependencies(flutter_wrapper_app flutter_assemble) - -add_custom_target(flutter_assemble DEPENDS - "${FLUTTER_LIBRARY}" - ${FLUTTER_LIBRARY_HEADERS} - ${CPP_WRAPPER_SOURCES_CORE} - ${CPP_WRAPPER_SOURCES_PLUGIN} - ${CPP_WRAPPER_SOURCES_APP} -) diff --git a/winuwp/flutter/flutter_windows.h b/winuwp/flutter/flutter_windows.h deleted file mode 100644 index 0aeb6fdc1..000000000 --- a/winuwp/flutter/flutter_windows.h +++ /dev/null @@ -1,270 +0,0 @@ -// Copyright 2013 The Flutter Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef FLUTTER_SHELL_PLATFORM_WINDOWS_PUBLIC_FLUTTER_H_ -#define FLUTTER_SHELL_PLATFORM_WINDOWS_PUBLIC_FLUTTER_H_ - -#include -#include -#include - -#include "flutter_export.h" -#include "flutter_messenger.h" -#include "flutter_plugin_registrar.h" - -#ifdef WINUWP -#include -#include -#endif - -#if defined(__cplusplus) -extern "C" { -#endif - -// Opaque reference to a Flutter window controller. -typedef struct FlutterDesktopViewControllerState* - FlutterDesktopViewControllerRef; - -// Opaque reference to a Flutter window. -struct FlutterDesktopView; -typedef struct FlutterDesktopView* FlutterDesktopViewRef; - -// Opaque reference to a Flutter engine instance. -struct FlutterDesktopEngine; -typedef struct FlutterDesktopEngine* FlutterDesktopEngineRef; - -// Properties for configuring a Flutter engine instance. -typedef struct { - // The path to the flutter_assets folder for the application to be run. - // This can either be an absolute path or a path relative to the directory - // containing the executable. - const wchar_t* assets_path; - - // The path to the icudtl.dat file for the version of Flutter you are using. - // This can either be an absolute path or a path relative to the directory - // containing the executable. - const wchar_t* icu_data_path; - - // The path to the AOT library file for your application, if any. - // This can either be an absolute path or a path relative to the directory - // containing the executable. This can be nullptr for a non-AOT build, as - // it will be ignored in that case. - const wchar_t* aot_library_path; - - // Number of elements in the array passed in as dart_entrypoint_argv. - int dart_entrypoint_argc; - - // Array of Dart entrypoint arguments. This is deep copied during the call - // to FlutterDesktopEngineCreate. - const char** dart_entrypoint_argv; - -} FlutterDesktopEngineProperties; - -// ========== View Controller ========== - -// Creates a view that hosts and displays the given engine instance. -// -// This takes ownership of |engine|, so FlutterDesktopEngineDestroy should no -// longer be called on it, as it will be called internally when the view -// controller is destroyed. If creating the view controller fails, the engine -// will be destroyed immediately. -// -// If |engine| is not already running, the view controller will start running -// it automatically before displaying the window. -// -// The caller owns the returned reference, and is responsible for calling -// FlutterDesktopViewControllerDestroy. Returns a null pointer in the event of -// an error. -#ifdef WINUWP -// The CoreApplicationView implementation accepts a pointer to the host -// CoreApplicationView and view hookup is performed in the construction path. -FLUTTER_EXPORT FlutterDesktopViewControllerRef -FlutterDesktopViewControllerCreateFromCoreApplicationView( - ABI::Windows::ApplicationModel::Core::CoreApplicationView* window, - ABI::Windows::ApplicationModel::Activation::IActivatedEventArgs* args, - FlutterDesktopEngineRef engine); -#else //! WINUWP -// The Win32 implementation accepts width, height -// with view hookup explicitly performed using the caller using HWND parenting. -FLUTTER_EXPORT FlutterDesktopViewControllerRef -FlutterDesktopViewControllerCreate(int width, - int height, - FlutterDesktopEngineRef engine); -#endif - -// Shuts down the engine instance associated with |controller|, and cleans up -// associated state. -// -// |controller| is no longer valid after this call. -FLUTTER_EXPORT void FlutterDesktopViewControllerDestroy( - FlutterDesktopViewControllerRef controller); - -// Returns the handle for the engine running in FlutterDesktopViewControllerRef. -// -// Its lifetime is the same as the |controller|'s. -FLUTTER_EXPORT FlutterDesktopEngineRef FlutterDesktopViewControllerGetEngine( - FlutterDesktopViewControllerRef controller); -// Returns the view managed by the given controller. - -FLUTTER_EXPORT FlutterDesktopViewRef -FlutterDesktopViewControllerGetView(FlutterDesktopViewControllerRef controller); - -// Requests new frame from engine and repaints the view -FLUTTER_EXPORT void FlutterDesktopViewControllerForceRedraw( - FlutterDesktopViewControllerRef controller); - -#ifndef WINUWP -// Allows the Flutter engine and any interested plugins an opportunity to -// handle the given message. -// -// If the WindowProc was handled and further handling should stop, this returns -// true and |result| will be populated. |result| is not set if returning false. -FLUTTER_EXPORT bool FlutterDesktopViewControllerHandleTopLevelWindowProc( - FlutterDesktopViewControllerRef controller, - HWND hwnd, - UINT message, - WPARAM wparam, - LPARAM lparam, - LRESULT* result); -#endif - -// ========== Engine ========== - -// Creates a Flutter engine with the given properties. -// -// The caller owns the returned reference, and is responsible for calling -// FlutterDesktopEngineDestroy. The lifetime of |engine_properties| is required -// to extend only until the end of this call. -FLUTTER_EXPORT FlutterDesktopEngineRef FlutterDesktopEngineCreate( - const FlutterDesktopEngineProperties* engine_properties); - -// Shuts down and destroys the given engine instance. Returns true if the -// shutdown was successful, or if the engine was not running. -// -// |engine| is no longer valid after this call. -FLUTTER_EXPORT bool FlutterDesktopEngineDestroy(FlutterDesktopEngineRef engine); - -// Starts running the given engine instance and optional entry point in the Dart -// project. If the entry point is null, defaults to main(). -// -// If provided, entry_point must be the name of a top-level function from the -// same Dart library that contains the app's main() function, and must be -// decorated with `@pragma(vm:entry-point)` to ensure the method is not -// tree-shaken by the Dart compiler. -// -// Returns false if running the engine failed. -FLUTTER_EXPORT bool FlutterDesktopEngineRun(FlutterDesktopEngineRef engine, - const char* entry_point); - -#ifndef WINUWP -// DEPRECATED: This is no longer necessary to call, Flutter will take care of -// processing engine messages transparently through DispatchMessage. -// -// Processes any pending events in the Flutter engine, and returns the -// number of nanoseconds until the next scheduled event (or max, if none). -// -// This should be called on every run of the application-level runloop, and -// a wait for native events in the runloop should never be longer than the -// last return value from this function. -FLUTTER_EXPORT uint64_t -FlutterDesktopEngineProcessMessages(FlutterDesktopEngineRef engine); -#endif - -FLUTTER_EXPORT void FlutterDesktopEngineReloadSystemFonts( - FlutterDesktopEngineRef engine); - -FLUTTER_EXPORT void FlutterDesktopEngineReloadPlatformBrightness( - FlutterDesktopEngineRef engine); - -// Returns the plugin registrar handle for the plugin with the given name. -// -// The name must be unique across the application. -FLUTTER_EXPORT FlutterDesktopPluginRegistrarRef -FlutterDesktopEngineGetPluginRegistrar(FlutterDesktopEngineRef engine, - const char* plugin_name); - -// Returns the messenger associated with the engine. -FLUTTER_EXPORT FlutterDesktopMessengerRef -FlutterDesktopEngineGetMessenger(FlutterDesktopEngineRef engine); - -// Returns the texture registrar associated with the engine. -FLUTTER_EXPORT FlutterDesktopTextureRegistrarRef -FlutterDesktopEngineGetTextureRegistrar( - FlutterDesktopTextureRegistrarRef texture_registrar); - -// ========== View ========== - -#ifdef WINUWP -// Return backing CoreApplicationView for manipulation of CoreWindow and -// CoreTitleBar in host application. -FLUTTER_EXPORT ABI::Windows::ApplicationModel::Core::CoreApplicationView* -FlutterDesktopViewGetCoreApplicationView(FlutterDesktopViewRef view); -#else -// Return backing HWND for manipulation in host application. -FLUTTER_EXPORT HWND FlutterDesktopViewGetHWND(FlutterDesktopViewRef view); -#endif - -// ========== Plugin Registrar (extensions) ========== -// These are Windows-specific extensions to flutter_plugin_registrar.h - -// Function pointer type for top level WindowProc delegate registration. -// -// The user data will be whatever was passed to -// FlutterDesktopRegisterTopLevelWindowProcHandler. -// -// Implementations should populate |result| and return true if the WindowProc -// was handled and further handling should stop. |result| is ignored if the -// function returns false. -typedef bool (*FlutterDesktopWindowProcCallback)(HWND /* hwnd */, - UINT /* uMsg */, - WPARAM /*wParam*/, - LPARAM /* lParam*/, - void* /* user data */, - LRESULT* result); - -// Returns the view associated with this registrar's engine instance. -FLUTTER_EXPORT FlutterDesktopViewRef FlutterDesktopPluginRegistrarGetView( - FlutterDesktopPluginRegistrarRef registrar); - -#ifndef WINUWP -FLUTTER_EXPORT void -FlutterDesktopPluginRegistrarRegisterTopLevelWindowProcDelegate( - FlutterDesktopPluginRegistrarRef registrar, - FlutterDesktopWindowProcCallback delegate, - void* user_data); - -FLUTTER_EXPORT void -FlutterDesktopPluginRegistrarUnregisterTopLevelWindowProcDelegate( - FlutterDesktopPluginRegistrarRef registrar, - FlutterDesktopWindowProcCallback delegate); -#endif - -// ========== Freestanding Utilities ========== - -// Gets the DPI for a given |hwnd|, depending on the supported APIs per -// windows version and DPI awareness mode. If nullptr is passed, returns the DPI -// of the primary monitor. -// -// This uses the same logic and fallback for older Windows versions that is used -// internally by Flutter to determine the DPI to use for displaying Flutter -// content, so should be used by any code (e.g., in plugins) that translates -// between Windows and Dart sizes/offsets. -FLUTTER_EXPORT UINT FlutterDesktopGetDpiForHWND(HWND hwnd); - -// Gets the DPI for a given |monitor|. If the API is not available, a default -// DPI of 96 is returned. -// -// See FlutterDesktopGetDpiForHWND for more information. -FLUTTER_EXPORT UINT FlutterDesktopGetDpiForMonitor(HMONITOR monitor); - -// Reopens stdout and stderr and resysncs the standard library output streams. -// Should be called if output is being directed somewhere in the runner process -// (e.g., after an AllocConsole call). -FLUTTER_EXPORT void FlutterDesktopResyncOutputStreams(); - -#if defined(__cplusplus) -} // extern "C" -#endif - -#endif // FLUTTER_SHELL_PLATFORM_WINDOWS_PUBLIC_FLUTTER_WINDOWS_H_ diff --git a/winuwp/flutter/generated_plugin_registrant.cc b/winuwp/flutter/generated_plugin_registrant.cc deleted file mode 100644 index 8b6d4680a..000000000 --- a/winuwp/flutter/generated_plugin_registrant.cc +++ /dev/null @@ -1,11 +0,0 @@ -// -// Generated file. Do not edit. -// - -// clang-format off - -#include "generated_plugin_registrant.h" - - -void RegisterPlugins(flutter::PluginRegistry* registry) { -} diff --git a/winuwp/flutter/generated_plugin_registrant.h b/winuwp/flutter/generated_plugin_registrant.h deleted file mode 100644 index dc139d85a..000000000 --- a/winuwp/flutter/generated_plugin_registrant.h +++ /dev/null @@ -1,15 +0,0 @@ -// -// Generated file. Do not edit. -// - -// clang-format off - -#ifndef GENERATED_PLUGIN_REGISTRANT_ -#define GENERATED_PLUGIN_REGISTRANT_ - -#include - -// Registers Flutter plugins. -void RegisterPlugins(flutter::PluginRegistry* registry); - -#endif // GENERATED_PLUGIN_REGISTRANT_ diff --git a/winuwp/flutter/generated_plugins.cmake b/winuwp/flutter/generated_plugins.cmake deleted file mode 100644 index 4d10c2518..000000000 --- a/winuwp/flutter/generated_plugins.cmake +++ /dev/null @@ -1,15 +0,0 @@ -# -# Generated file, do not edit. -# - -list(APPEND FLUTTER_PLUGIN_LIST -) - -set(PLUGIN_BUNDLED_LIBRARIES) - -foreach(plugin ${FLUTTER_PLUGIN_LIST}) - add_subdirectory(flutter/ephemeral/.plugin_symlinks/${plugin}/windows plugins/${plugin}) - target_link_libraries(${BINARY_NAME} PRIVATE ${plugin}_plugin) - list(APPEND PLUGIN_BUNDLED_LIBRARIES $) - list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${plugin}_bundled_libraries}) -endforeach(plugin) diff --git a/winuwp/project_version b/winuwp/project_version deleted file mode 100644 index c22708346..000000000 --- a/winuwp/project_version +++ /dev/null @@ -1 +0,0 @@ -0 \ No newline at end of file diff --git a/winuwp/runner_uwp/Assets/LargeTile.scale-100.png b/winuwp/runner_uwp/Assets/LargeTile.scale-100.png deleted file mode 100644 index fa651eb71..000000000 Binary files a/winuwp/runner_uwp/Assets/LargeTile.scale-100.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/LargeTile.scale-125.png b/winuwp/runner_uwp/Assets/LargeTile.scale-125.png deleted file mode 100644 index 649e07696..000000000 Binary files a/winuwp/runner_uwp/Assets/LargeTile.scale-125.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/LargeTile.scale-150.png b/winuwp/runner_uwp/Assets/LargeTile.scale-150.png deleted file mode 100644 index fd14c60cb..000000000 Binary files a/winuwp/runner_uwp/Assets/LargeTile.scale-150.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/LargeTile.scale-200.png b/winuwp/runner_uwp/Assets/LargeTile.scale-200.png deleted file mode 100644 index 873537f33..000000000 Binary files a/winuwp/runner_uwp/Assets/LargeTile.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/LargeTile.scale-400.png b/winuwp/runner_uwp/Assets/LargeTile.scale-400.png deleted file mode 100644 index 979878f73..000000000 Binary files a/winuwp/runner_uwp/Assets/LargeTile.scale-400.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/LockScreenLogo.scale-200.png b/winuwp/runner_uwp/Assets/LockScreenLogo.scale-200.png deleted file mode 100644 index 735f57adb..000000000 Binary files a/winuwp/runner_uwp/Assets/LockScreenLogo.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SmallTile.scale-100.png b/winuwp/runner_uwp/Assets/SmallTile.scale-100.png deleted file mode 100644 index 35e7f6242..000000000 Binary files a/winuwp/runner_uwp/Assets/SmallTile.scale-100.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SmallTile.scale-125.png b/winuwp/runner_uwp/Assets/SmallTile.scale-125.png deleted file mode 100644 index 2a74cc67e..000000000 Binary files a/winuwp/runner_uwp/Assets/SmallTile.scale-125.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SmallTile.scale-150.png b/winuwp/runner_uwp/Assets/SmallTile.scale-150.png deleted file mode 100644 index 157124823..000000000 Binary files a/winuwp/runner_uwp/Assets/SmallTile.scale-150.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SmallTile.scale-200.png b/winuwp/runner_uwp/Assets/SmallTile.scale-200.png deleted file mode 100644 index 07ec2ddcb..000000000 Binary files a/winuwp/runner_uwp/Assets/SmallTile.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SmallTile.scale-400.png b/winuwp/runner_uwp/Assets/SmallTile.scale-400.png deleted file mode 100644 index c205729b7..000000000 Binary files a/winuwp/runner_uwp/Assets/SmallTile.scale-400.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SplashScreen.scale-100.png b/winuwp/runner_uwp/Assets/SplashScreen.scale-100.png deleted file mode 100644 index 601257981..000000000 Binary files a/winuwp/runner_uwp/Assets/SplashScreen.scale-100.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SplashScreen.scale-125.png b/winuwp/runner_uwp/Assets/SplashScreen.scale-125.png deleted file mode 100644 index 0c35be827..000000000 Binary files a/winuwp/runner_uwp/Assets/SplashScreen.scale-125.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SplashScreen.scale-150.png b/winuwp/runner_uwp/Assets/SplashScreen.scale-150.png deleted file mode 100644 index f1e60f33c..000000000 Binary files a/winuwp/runner_uwp/Assets/SplashScreen.scale-150.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SplashScreen.scale-200.png b/winuwp/runner_uwp/Assets/SplashScreen.scale-200.png deleted file mode 100644 index 73d2461ce..000000000 Binary files a/winuwp/runner_uwp/Assets/SplashScreen.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/SplashScreen.scale-400.png b/winuwp/runner_uwp/Assets/SplashScreen.scale-400.png deleted file mode 100644 index b2b7ca9c4..000000000 Binary files a/winuwp/runner_uwp/Assets/SplashScreen.scale-400.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-100.png b/winuwp/runner_uwp/Assets/Square150x150Logo.scale-100.png deleted file mode 100644 index cdc3e9732..000000000 Binary files a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-100.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-125.png b/winuwp/runner_uwp/Assets/Square150x150Logo.scale-125.png deleted file mode 100644 index 71e5a1153..000000000 Binary files a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-125.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-150.png b/winuwp/runner_uwp/Assets/Square150x150Logo.scale-150.png deleted file mode 100644 index 60f2e1827..000000000 Binary files a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-150.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-200.png b/winuwp/runner_uwp/Assets/Square150x150Logo.scale-200.png deleted file mode 100644 index 20814081d..000000000 Binary files a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-400.png b/winuwp/runner_uwp/Assets/Square150x150Logo.scale-400.png deleted file mode 100644 index 605aacb02..000000000 Binary files a/winuwp/runner_uwp/Assets/Square150x150Logo.scale-400.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-16.png b/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-16.png deleted file mode 100644 index 1c78d96bf..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-16.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-256.png b/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-256.png deleted file mode 100644 index d49d3d899..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-256.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-32.png b/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-32.png deleted file mode 100644 index 889622468..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-32.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-48.png b/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-48.png deleted file mode 100644 index 6389ede5a..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.altform-unplated_targetsize-48.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-100.png b/winuwp/runner_uwp/Assets/Square44x44Logo.scale-100.png deleted file mode 100644 index 47e3cd29b..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-100.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-125.png b/winuwp/runner_uwp/Assets/Square44x44Logo.scale-125.png deleted file mode 100644 index 50faa9328..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-125.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-150.png b/winuwp/runner_uwp/Assets/Square44x44Logo.scale-150.png deleted file mode 100644 index f0293ed81..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-150.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-200.png b/winuwp/runner_uwp/Assets/Square44x44Logo.scale-200.png deleted file mode 100644 index e54a56dbc..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-400.png b/winuwp/runner_uwp/Assets/Square44x44Logo.scale-400.png deleted file mode 100644 index 4b5fb179f..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.scale-400.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-16.png b/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-16.png deleted file mode 100644 index a1a6ec70a..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-16.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-24.png b/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-24.png deleted file mode 100644 index c67a8e12f..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-24.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-24_altform-unplated.png b/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-24_altform-unplated.png deleted file mode 100644 index 47d36f63e..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-24_altform-unplated.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-256.png b/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-256.png deleted file mode 100644 index 50efc008d..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-256.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-32.png b/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-32.png deleted file mode 100644 index f86682c9f..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-32.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-48.png b/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-48.png deleted file mode 100644 index 7561269af..000000000 Binary files a/winuwp/runner_uwp/Assets/Square44x44Logo.targetsize-48.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/StoreLogo.png b/winuwp/runner_uwp/Assets/StoreLogo.png deleted file mode 100644 index 7385b56c0..000000000 Binary files a/winuwp/runner_uwp/Assets/StoreLogo.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/StoreLogo.scale-100.png b/winuwp/runner_uwp/Assets/StoreLogo.scale-100.png deleted file mode 100644 index fcefe81ba..000000000 Binary files a/winuwp/runner_uwp/Assets/StoreLogo.scale-100.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/StoreLogo.scale-125.png b/winuwp/runner_uwp/Assets/StoreLogo.scale-125.png deleted file mode 100644 index 4381be777..000000000 Binary files a/winuwp/runner_uwp/Assets/StoreLogo.scale-125.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/StoreLogo.scale-150.png b/winuwp/runner_uwp/Assets/StoreLogo.scale-150.png deleted file mode 100644 index e49390bf3..000000000 Binary files a/winuwp/runner_uwp/Assets/StoreLogo.scale-150.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/StoreLogo.scale-200.png b/winuwp/runner_uwp/Assets/StoreLogo.scale-200.png deleted file mode 100644 index fb740e846..000000000 Binary files a/winuwp/runner_uwp/Assets/StoreLogo.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/StoreLogo.scale-400.png b/winuwp/runner_uwp/Assets/StoreLogo.scale-400.png deleted file mode 100644 index d1472741e..000000000 Binary files a/winuwp/runner_uwp/Assets/StoreLogo.scale-400.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/Wide310x150Logo.scale-200.png b/winuwp/runner_uwp/Assets/Wide310x150Logo.scale-200.png deleted file mode 100644 index 288995b39..000000000 Binary files a/winuwp/runner_uwp/Assets/Wide310x150Logo.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/WideTile.scale-100.png b/winuwp/runner_uwp/Assets/WideTile.scale-100.png deleted file mode 100644 index 1cb688c7b..000000000 Binary files a/winuwp/runner_uwp/Assets/WideTile.scale-100.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/WideTile.scale-125.png b/winuwp/runner_uwp/Assets/WideTile.scale-125.png deleted file mode 100644 index 729239615..000000000 Binary files a/winuwp/runner_uwp/Assets/WideTile.scale-125.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/WideTile.scale-150.png b/winuwp/runner_uwp/Assets/WideTile.scale-150.png deleted file mode 100644 index d4b275a57..000000000 Binary files a/winuwp/runner_uwp/Assets/WideTile.scale-150.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/WideTile.scale-200.png b/winuwp/runner_uwp/Assets/WideTile.scale-200.png deleted file mode 100644 index 601257981..000000000 Binary files a/winuwp/runner_uwp/Assets/WideTile.scale-200.png and /dev/null differ diff --git a/winuwp/runner_uwp/Assets/WideTile.scale-400.png b/winuwp/runner_uwp/Assets/WideTile.scale-400.png deleted file mode 100644 index 73d2461ce..000000000 Binary files a/winuwp/runner_uwp/Assets/WideTile.scale-400.png and /dev/null differ diff --git a/winuwp/runner_uwp/CMakeLists.txt b/winuwp/runner_uwp/CMakeLists.txt deleted file mode 100644 index b4362a4fc..000000000 --- a/winuwp/runner_uwp/CMakeLists.txt +++ /dev/null @@ -1,141 +0,0 @@ -cmake_minimum_required (VERSION 3.8) -set(CMAKE_SYSTEM_NAME WindowsStore) -set(CMAKE_SYSTEM_VERSION 10.0) -set(CMAKE_CXX_STANDARD 17) -set(CMAKE_CXX_STANDARD_REQUIRED YES) - -include(CMakePrintHelpers) - -project (runner LANGUAGES CXX) - -# UWP tile and icon assets. -set(ASSET_FILES ${ASSET_FILES} - Assets/LargeTile.scale-100.png - Assets/LargeTile.scale-125.png - Assets/LargeTile.scale-150.png - Assets/LargeTile.scale-200.png - Assets/LargeTile.scale-400.png - Assets/LockScreenLogo.scale-200.png - Assets/SmallTile.scale-100.png - Assets/SmallTile.scale-125.png - Assets/SmallTile.scale-150.png - Assets/SmallTile.scale-200.png - Assets/SmallTile.scale-400.png - Assets/SplashScreen.scale-100.png - Assets/SplashScreen.scale-125.png - Assets/SplashScreen.scale-150.png - Assets/SplashScreen.scale-200.png - Assets/SplashScreen.scale-400.png - Assets/Square44x44Logo.altform-unplated_targetsize-16.png - Assets/Square44x44Logo.altform-unplated_targetsize-32.png - Assets/Square44x44Logo.altform-unplated_targetsize-48.png - Assets/Square44x44Logo.altform-unplated_targetsize-256.png - Assets/Square44x44Logo.scale-100.png - Assets/Square44x44Logo.scale-125.png - Assets/Square44x44Logo.scale-150.png - Assets/Square44x44Logo.scale-200.png - Assets/Square44x44Logo.scale-400.png - Assets/Square44x44Logo.targetsize-16.png - Assets/Square44x44Logo.targetsize-24.png - Assets/Square44x44Logo.targetsize-24_altform-unplated.png - Assets/Square44x44Logo.targetsize-32.png - Assets/Square44x44Logo.targetsize-48.png - Assets/Square44x44Logo.targetsize-256.png - Assets/Square150x150Logo.scale-100.png - Assets/Square150x150Logo.scale-125.png - Assets/Square150x150Logo.scale-150.png - Assets/Square150x150Logo.scale-200.png - Assets/Square150x150Logo.scale-400.png - Assets/StoreLogo.png - Assets/StoreLogo.scale-100.png - Assets/StoreLogo.scale-125.png - Assets/StoreLogo.scale-150.png - Assets/StoreLogo.scale-200.png - Assets/StoreLogo.scale-400.png - Assets/Wide310x150Logo.scale-200.png - Assets/WideTile.scale-100.png - Assets/WideTile.scale-125.png - Assets/WideTile.scale-150.png - Assets/WideTile.scale-200.png - Assets/WideTile.scale-400.png -) - -# Configure package manifest file. -set(APP_MANIFEST_NAME Package.appxmanifest) -set(APP_MANIFEST_TARGET_LOCATION ${CMAKE_CURRENT_BINARY_DIR}/${APP_MANIFEST_NAME}) -set(SHORT_NAME ${BINARY_NAME}) -set(PACKAGE_GUID "086F9B60-CB52-4D0B-9B4E-AE891E7859D1") - -configure_file( - appxmanifest.in - ${APP_MANIFEST_TARGET_LOCATION} - @ONLY) - -set(CONTENT_FILES ${APP_MANIFEST_TARGET_LOCATION}) - -# Configure package content files. -set_property(SOURCE ${CONTENT_FILES} PROPERTY VS_DEPLOYMENT_CONTENT 1) - -set(RESOURCE_FILES ${ASSET_FILES} ${CONTENT_FILES} Windows_TemporaryKey.pfx) -set_property(SOURCE ${ASSET_FILES} PROPERTY VS_DEPLOYMENT_CONTENT 1) -set_property(SOURCE ${ASSET_FILES} PROPERTY VS_DEPLOYMENT_LOCATION "Assets") - -set(STRING_FILES Resources.pri) -set_property(SOURCE ${STRING_FILES} PROPERTY VS_TOOL_OVERRIDE "PRIResource") - -source_group("Resource Files" FILES ${RESOURCE_FILES} ${CONTENT_FILES} ${STRING_FILES}) - -# Configure Flutter assets using tool generated install manifest -foreach(ITEM ${INSTALL_MANIFEST_CONTENT}) - get_filename_component(ITEM_REL ${CMAKE_BINARY_DIR} DIRECTORY) - file(RELATIVE_PATH RELPATH ${ITEM_REL} ${ITEM}) - - get_filename_component(RELPATH ${RELPATH} DIRECTORY) - get_filename_component(ITEMEXT ${ITEM} LAST_EXT) - - if("${ITEMEXT}" STREQUAL ".dll" OR "${ITEMEXT}" STREQUAL ".pdb") - string(CONCAT RELPATH "") - elseif ("${ITEMEXT}" STREQUAL ".so") - file(RELATIVE_PATH RELPATH "${ITEM_REL}/winuwp" ${ITEM}) - string(REGEX REPLACE "/" "\\\\" RELPATH ${RELPATH}) - string(CONCAT RELPATH "Assets\\Data") - elseif("${ITEMEXT}" STREQUAL ".dat") - string(CONCAT RELPATH "Assets\\Data") - else() - string(REGEX REPLACE "/" "\\\\" RELPATH ${RELPATH}) - string(CONCAT RELPATH "Assets\\Data\\" ${RELPATH}) - endif() - - cmake_print_variables(${RELPATH}) - - set_property(SOURCE ${ITEM} PROPERTY VS_DEPLOYMENT_CONTENT 1) - set_property(SOURCE ${ITEM} PROPERTY VS_DEPLOYMENT_LOCATION ${RELPATH}) -endforeach() - -# Define the application target. To change its name, change BINARY_NAME in the -# top-level CMakeLists.txt, not the value here, or `flutter run` will no longer -# work. -# -# Any new source files that you add to the application should be added here. -add_executable (${BINARY_NAME} WIN32 - main.cpp - flutter_frameworkview.cpp - "${FLUTTER_MANAGED_DIR}/generated_plugin_registrant.cc" - ${RESOURCE_FILES} - ${INSTALL_MANIFEST_CONTENT} -) - -# Apply the standard set of build settings. This can be removed for applications -# that need different build settings. -apply_standard_settings(${BINARY_NAME}) - -# Disable Windows macros that collide with C++ standard library functions. -target_compile_definitions(${BINARY_NAME} PRIVATE "NOMINMAX") - -# Add dependency libraries and include directories. Add any application-specific -# dependencies here. -target_link_libraries(${BINARY_NAME} PRIVATE WindowsApp flutter flutter_wrapper_app) -target_include_directories(${BINARY_NAME} PRIVATE "${CMAKE_SOURCE_DIR}") - -# Run the Flutter tool portions of the build. This must not be removed. -add_dependencies(${BINARY_NAME} flutter_assemble) diff --git a/winuwp/runner_uwp/CMakeSettings.json b/winuwp/runner_uwp/CMakeSettings.json deleted file mode 100644 index ba63a530d..000000000 --- a/winuwp/runner_uwp/CMakeSettings.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - // See https://go.microsoft.com//fwlink//?linkid=834763 for more information about this file. - "configurations": [ - { - "name": "Debug", - "generator": "Visual Studio 15 2017 Win64", - "configurationType": "Debug", - "inheritEnvironments": [ "msvc_x64_x64" ], - "buildRoot": "${env.USERPROFILE}\\CMakeBuilds\\${workspaceHash}\\build\\${name}", - "installRoot": "${env.USERPROFILE}\\CMakeBuilds\\${workspaceHash}\\install\\${name}", - "cmakeCommandArgs": "", - "buildCommandArgs": "", - "ctestCommandArgs": "" - }, - { - "name": "Release", - "generator": "Visual Studio 15 2017 Win64", - "configurationType": "Release", - "inheritEnvironments": [ "msvc_x64_x64" ], - "buildRoot": "${env.USERPROFILE}\\CMakeBuilds\\${workspaceHash}\\build\\${name}", - "installRoot": "${env.USERPROFILE}\\CMakeBuilds\\${workspaceHash}\\install\\${name}", - "cmakeCommandArgs": "", - "buildCommandArgs": "", - "ctestCommandArgs": "" - } - ] -} diff --git a/winuwp/runner_uwp/Windows_TemporaryKey.pfx b/winuwp/runner_uwp/Windows_TemporaryKey.pfx deleted file mode 100644 index 1cad9993d..000000000 Binary files a/winuwp/runner_uwp/Windows_TemporaryKey.pfx and /dev/null differ diff --git a/winuwp/runner_uwp/appxmanifest.in b/winuwp/runner_uwp/appxmanifest.in deleted file mode 100644 index 570d424ee..000000000 --- a/winuwp/runner_uwp/appxmanifest.in +++ /dev/null @@ -1,42 +0,0 @@ - - - - - - - - @SHORT_NAME@ - CMake Test Cert - Assets/StoreLogo.png - - - - - - - - - - - - - - - - - - - - - - diff --git a/winuwp/runner_uwp/flutter_frameworkview.cpp b/winuwp/runner_uwp/flutter_frameworkview.cpp deleted file mode 100644 index bcdc73adb..000000000 --- a/winuwp/runner_uwp/flutter_frameworkview.cpp +++ /dev/null @@ -1,155 +0,0 @@ -#include "winrt/Windows.ApplicationModel.Core.h" -#include "winrt/Windows.Foundation.h" -#include "winrt/Windows.System.Profile.h" -#include "winrt/Windows.System.Threading.h" -#include "winrt/Windows.UI.Core.h" -#include -#include -#include -#include -#include -#include - -#include -#include -#include - -#include -#include -#include -#include - -struct FlutterFrameworkView - : winrt::implements< - FlutterFrameworkView, - winrt::Windows::ApplicationModel::Core::IFrameworkView> { - // |winrt::Windows::ApplicationModel::Core::IFrameworkView| - void - Initialize(winrt::Windows::ApplicationModel::Core::CoreApplicationView const - &applicationView) { - - // Layout scaling must be disabled in the appinitialization phase in order - // to take effect correctly. - if (winrt::Windows::System::Profile::AnalyticsInfo::VersionInfo() - .DeviceFamily() == L"Windows.Xbox") { - - bool result = winrt::Windows::UI::ViewManagement::ApplicationViewScaling:: - TrySetDisableLayoutScaling(true); - if (!result) { - OutputDebugString(L"Couldn't disable layout scaling"); - } - } - - main_view_ = applicationView; - main_view_.Activated({this, &FlutterFrameworkView::OnActivated}); - } - - // |winrt::Windows::ApplicationModel::Core::IFrameworkView| - void Uninitialize() { - main_view_.Activated(nullptr); - main_view_ = nullptr; - } - - // |winrt::Windows::ApplicationModel::Core::IFrameworkView| - void Load(winrt::hstring const &) {} - - // |winrt::Windows::ApplicationModel::Core::IFrameworkView| - void Run() { - winrt::Windows::UI::Core::CoreWindow window = - winrt::Windows::UI::Core::CoreWindow::GetForCurrentThread(); - - winrt::Windows::UI::Core::CoreDispatcher dispatcher = window.Dispatcher(); - dispatcher.ProcessEvents( - winrt::Windows::UI::Core::CoreProcessEventsOption::ProcessUntilQuit); - } - - // |winrt::Windows::ApplicationModel::Core::IFrameworkView| - winrt::Windows::Foundation::IAsyncAction - SetWindow(winrt::Windows::UI::Core::CoreWindow const &window) { - - // Capture reference to window. - window_ = window; - - // Lay out the window's content within the region occupied by the - // CoreWindow. - auto appView = winrt::Windows::UI::ViewManagement::ApplicationView:: - GetForCurrentView(); - - appView.SetDesiredBoundsMode(winrt::Windows::UI::ViewManagement:: - ApplicationViewBoundsMode::UseCoreWindow); - - // Configure folder paths. - try { - winrt::Windows::Storage::StorageFolder folder = - winrt::Windows::ApplicationModel::Package::Current() - .InstalledLocation(); - - winrt::Windows::Storage::StorageFolder assets = - co_await folder.GetFolderAsync(L"Assets"); - winrt::Windows::Storage::StorageFolder data = - co_await assets.GetFolderAsync(L"data"); - winrt::Windows::Storage::StorageFolder flutter_assets = - co_await data.GetFolderAsync(L"flutter_assets"); - winrt::Windows::Storage::StorageFile icu_data = - co_await data.GetFileAsync(L"icudtl.dat"); - -#if NDEBUG - winrt::Windows::Storage::StorageFile aot_data = - co_await data.GetFileAsync(L"app.so"); -#endif - - std::wstring flutter_assets_path{flutter_assets.Path()}; - std::wstring icu_data_path{icu_data.Path()}; - std::wstring aot_data_path { -#if NDEBUG - aot_data.Path() -#endif - }; - - flutter::DartProject project(flutter_assets_path, icu_data_path, - aot_data_path); - - // Construct viewcontroller using the Window and project - flutter_view_controller_ = std::make_unique( - static_cast(winrt::get_abi(main_view_)), - static_cast(winrt::get_abi(launch_args_)), - project); - - // If plugins present, register them. - RegisterPlugins(flutter_view_controller_.get()->engine()); - } catch (winrt::hresult_error &err) { - winrt::Windows::UI::Popups::MessageDialog md = - winrt::Windows::UI::Popups::MessageDialog::MessageDialog( - L"There was a problem starting the engine: " + err.message()); - md.ShowAsync(); - } - } - - void OnActivated( - winrt::Windows::ApplicationModel::Core::CoreApplicationView const - &applicationView, - winrt::Windows::ApplicationModel::Activation::IActivatedEventArgs const - &args) { - // Activate the application window, making it visible and enabling it to - // receive events. - applicationView.CoreWindow().Activate(); - - // Capture launch args to later pass to Flutter. - launch_args_ = args; - } - - // Current CoreApplicationView. - winrt::Windows::ApplicationModel::Core::CoreApplicationView main_view_{ - nullptr}; - - // Current CoreWindow. - winrt::Windows::UI::Core::CoreWindow window_{nullptr}; - - // Current FlutterViewController. - std::unique_ptr flutter_view_controller_{ - nullptr}; - - // Launch args that were passed in on activation. - winrt::Windows::ApplicationModel::Activation::IActivatedEventArgs - launch_args_; -}; diff --git a/winuwp/runner_uwp/main.cpp b/winuwp/runner_uwp/main.cpp deleted file mode 100644 index 1ce54b1fc..000000000 --- a/winuwp/runner_uwp/main.cpp +++ /dev/null @@ -1,30 +0,0 @@ - -#include - -#include "winrt/Windows.ApplicationModel.Core.h" -#include "winrt/Windows.Foundation.h" -#include -#include -#include - -#include - -#include "flutter_frameworkview.cpp" - -struct App - : winrt::implements< - App, winrt::Windows::ApplicationModel::Core::IFrameworkViewSource> { - App() { view_ = winrt::make_self(); } - - // |winrt::Windows::ApplicationModel::Core::IFrameworkViewSource| - winrt::Windows::ApplicationModel::Core::IFrameworkView CreateView() { - return view_.as(); - } - - winrt::com_ptr view_; -}; - -int __stdcall wWinMain(HINSTANCE, HINSTANCE, PWSTR, int) { - winrt::Windows::ApplicationModel::Core::CoreApplication::Run( - winrt::make()); -} diff --git a/winuwp/runner_uwp/resources.pri b/winuwp/runner_uwp/resources.pri deleted file mode 100644 index 7de03c9dc..000000000 Binary files a/winuwp/runner_uwp/resources.pri and /dev/null differ