Full Code of ferraridamiano/ConverterNOW for AI

master 4cd9fdf01cb3 cached
244 files
780.7 KB
229.4k tokens
222 symbols
1 requests
Download .txt
Showing preview only (889K chars total). Download the full file or copy to clipboard to get everything.
Repository: ferraridamiano/ConverterNOW
Branch: master
Commit: 4cd9fdf01cb3
Files: 244
Total size: 780.7 KB

Directory structure:
gitextract_nvfewi80/

├── .firebaserc
├── .github/
│   ├── FUNDING.yml
│   ├── ISSUE_TEMPLATE/
│   │   ├── bug_report.md
│   │   └── new_unit_request.md
│   ├── dependabot.yml
│   └── workflows/
│       ├── build_deploy.yml
│       ├── scripts/
│       │   └── build_appimage.sh
│       └── tests.yml
├── .gitignore
├── .vscode/
│   └── settings.json
├── CONTRIBUTING.md
├── Dockerfile
├── LICENSE
├── README.md
├── analysis_options.yaml
├── android/
│   ├── .gitignore
│   ├── app/
│   │   ├── build.gradle.kts
│   │   └── src/
│   │       ├── debug/
│   │       │   └── AndroidManifest.xml
│   │       ├── main/
│   │       │   ├── AndroidManifest.xml
│   │       │   ├── kotlin/
│   │       │   │   └── com/
│   │       │   │       └── ferrarid/
│   │       │   │           └── converterpro/
│   │       │   │               └── MainActivity.kt
│   │       │   └── res/
│   │       │       ├── drawable/
│   │       │       │   ├── ic_launcher_background.xml
│   │       │       │   ├── ic_launcher_foreground.xml
│   │       │       │   └── launch_background.xml
│   │       │       ├── drawable-v21/
│   │       │       │   └── launch_background.xml
│   │       │       ├── mipmap-anydpi-v26/
│   │       │       │   ├── ic_launcher.xml
│   │       │       │   └── ic_launcher_round.xml
│   │       │       ├── values/
│   │       │       │   └── styles.xml
│   │       │       └── values-night/
│   │       │           └── styles.xml
│   │       └── profile/
│   │           └── AndroidManifest.xml
│   ├── build.gradle.kts
│   ├── gradle/
│   │   └── wrapper/
│   │       └── gradle-wrapper.properties
│   ├── gradle.properties
│   ├── gradlew
│   ├── gradlew.bat
│   └── settings.gradle.kts
├── assets/
│   └── fonts/
│       └── OFL.txt
├── cliff.toml
├── fastlane/
│   └── metadata/
│       └── android/
│           ├── ar/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── bn/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── de-DE/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── el/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── en-US/
│           │   ├── changelogs/
│           │   │   ├── 24.txt
│           │   │   ├── 25.txt
│           │   │   ├── 26.txt
│           │   │   ├── 27.txt
│           │   │   ├── 28.txt
│           │   │   ├── 29.txt
│           │   │   ├── 30.txt
│           │   │   ├── 31.txt
│           │   │   ├── 33.txt
│           │   │   ├── 34.txt
│           │   │   ├── 35.txt
│           │   │   ├── 36.txt
│           │   │   ├── 37.txt
│           │   │   ├── 38.txt
│           │   │   ├── 39.txt
│           │   │   ├── 40.txt
│           │   │   ├── 41.txt
│           │   │   ├── 42.txt
│           │   │   ├── 43.txt
│           │   │   ├── 44.txt
│           │   │   ├── 45.txt
│           │   │   ├── 46.txt
│           │   │   ├── 47.txt
│           │   │   ├── 48.txt
│           │   │   ├── 49.txt
│           │   │   ├── 50.txt
│           │   │   ├── 51.txt
│           │   │   └── 52.txt
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── es-ES/
│           │   ├── changelogs/
│           │   │   └── 33.txt
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── fr-FR/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── hr/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── id/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── it-IT/
│           │   ├── changelogs/
│           │   │   ├── 24.txt
│           │   │   ├── 25.txt
│           │   │   ├── 26.txt
│           │   │   ├── 27.txt
│           │   │   ├── 28.txt
│           │   │   ├── 29.txt
│           │   │   ├── 30.txt
│           │   │   ├── 31.txt
│           │   │   ├── 33.txt
│           │   │   ├── 34.txt
│           │   │   ├── 35.txt
│           │   │   ├── 36.txt
│           │   │   ├── 37.txt
│           │   │   ├── 38.txt
│           │   │   ├── 39.txt
│           │   │   ├── 40.txt
│           │   │   ├── 41.txt
│           │   │   ├── 42.txt
│           │   │   ├── 43.txt
│           │   │   ├── 44.txt
│           │   │   ├── 45.txt
│           │   │   ├── 46.txt
│           │   │   ├── 47.txt
│           │   │   ├── 48.txt
│           │   │   ├── 49.txt
│           │   │   ├── 50.txt
│           │   │   ├── 51.txt
│           │   │   └── 52.txt
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── ja/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── nl_NL/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── pl-PL/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── pt-BR/
│           │   ├── full_description.txt
│           │   └── short_description.txt
│           ├── ru-RU/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── tr-TR/
│           │   ├── changelogs/
│           │   │   ├── 24.txt
│           │   │   ├── 25.txt
│           │   │   ├── 26.txt
│           │   │   └── 27.txt
│           │   ├── full_description.txt
│           │   └── short_description.txt
│           ├── zh/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           └── zh-TW/
│               ├── full_description.txt
│               └── short_description.txt
├── firebase.json
├── integration_test/
│   ├── large_display_test.dart
│   ├── small_display_test.dart
│   └── utils.dart
├── lib/
│   ├── app_router.dart
│   ├── data/
│   │   ├── default_order.dart
│   │   └── property_unit_maps.dart
│   ├── helpers/
│   │   └── responsive_helper.dart
│   ├── main.dart
│   ├── models/
│   │   ├── conversions.dart
│   │   ├── currencies.dart
│   │   ├── hide_units.dart
│   │   ├── import_export.dart
│   │   ├── order.dart
│   │   ├── properties_list.dart
│   │   └── settings.dart
│   ├── pages/
│   │   ├── app_scaffold.dart
│   │   ├── choose_property_page.dart
│   │   ├── conversion_page.dart
│   │   ├── custom_drawer.dart
│   │   ├── error_page.dart
│   │   ├── hide_units_page.dart
│   │   ├── initial_page.dart
│   │   ├── reorder_page.dart
│   │   ├── reorder_properties_page.dart
│   │   ├── reorder_units_page.dart
│   │   ├── search_page.dart
│   │   ├── select_units_page.dart
│   │   ├── settings_page.dart
│   │   └── splash_screen.dart
│   ├── styles/
│   │   └── consts.dart
│   └── utils/
│       ├── navigator_utils.dart
│       ├── palette.dart
│       ├── utils.dart
│       └── utils_widgets.dart
├── linux/
│   ├── .gitignore
│   ├── CMakeLists.txt
│   ├── flutter/
│   │   ├── CMakeLists.txt
│   │   ├── generated_plugin_registrant.cc
│   │   ├── generated_plugin_registrant.h
│   │   └── generated_plugins.cmake
│   ├── io.github.ferraridamiano.ConverterNOW.desktop
│   ├── io.github.ferraridamiano.ConverterNOW.metainfo.xml
│   └── runner/
│       ├── CMakeLists.txt
│       ├── main.cc
│       ├── my_application.cc
│       └── my_application.h
├── packages/
│   ├── calculator_widget/
│   │   ├── analysis_options.yaml
│   │   ├── lib/
│   │   │   ├── animated_button.dart
│   │   │   ├── calculator_model.dart
│   │   │   └── calculator_widget.dart
│   │   └── pubspec.yaml
│   └── translations/
│       ├── l10n.yaml
│       ├── lib/
│       │   └── l10n/
│       │       ├── app_ar.arb
│       │       ├── app_bn.arb
│       │       ├── app_ca.arb
│       │       ├── app_de.arb
│       │       ├── app_el.arb
│       │       ├── app_en.arb
│       │       ├── app_es.arb
│       │       ├── app_fr.arb
│       │       ├── app_hr.arb
│       │       ├── app_id.arb
│       │       ├── app_it.arb
│       │       ├── app_ja.arb
│       │       ├── app_nb.arb
│       │       ├── app_nl.arb
│       │       ├── app_pl.arb
│       │       ├── app_pt.arb
│       │       ├── app_ru.arb
│       │       ├── app_tr.arb
│       │       ├── app_zh.arb
│       │       └── app_zh_TW.arb
│       └── pubspec.yaml
├── pubspec.yaml
├── web/
│   ├── index.html
│   └── manifest.json
└── windows/
    ├── .gitignore
    ├── CMakeLists.txt
    ├── flutter/
    │   ├── CMakeLists.txt
    │   ├── generated_plugin_registrant.cc
    │   ├── generated_plugin_registrant.h
    │   └── generated_plugins.cmake
    ├── innosetup.iss
    └── runner/
        ├── CMakeLists.txt
        ├── Runner.rc
        ├── flutter_window.cpp
        ├── flutter_window.h
        ├── main.cpp
        ├── resource.h
        ├── runner.exe.manifest
        ├── utils.cpp
        ├── utils.h
        ├── win32_window.cpp
        └── win32_window.h

================================================
FILE CONTENTS
================================================

================================================
FILE: .firebaserc
================================================
{
  "projects": {
    "default": "converter-now"
  }
}


================================================
FILE: .github/FUNDING.yml
================================================
# These are supported funding model platforms

github: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
patreon: # Replace with a single Patreon username
open_collective: # Replace with a single Open Collective username
ko_fi: # Replace with a single Ko-fi username
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
liberapay: # Replace with a single Liberapay username
issuehunt: # Replace with a single IssueHunt username
otechie: # Replace with a single Otechie username
custom: ['https://www.paypal.com/paypalme/demapps']


================================================
FILE: .github/ISSUE_TEMPLATE/bug_report.md
================================================
---
name: Bug report
about: Create a report to help us improve
title: "[BUG] "
labels: ''
assignees: ''

---

**Describe the bug**
A clear and concise description of what the bug is.

**To Reproduce**
Steps to reproduce the behavior:
1. Go to '...'
2. Click on '....'
3. Scroll down to '....'
4. See error

**Expected behavior**
A clear and concise description of what you expected to happen.

**Screenshots / gif**
If applicable, add screenshots to help explain your problem.

**Device**
- Device type: [e.g. Android, Windows, Linux, Web]
- OS version: [e.g. Android 11]
- Device type: [e.g. Google Pixel 6, Galaxy S21]

**Additional context**
Add any other context about the problem here.

================================================
FILE: .github/ISSUE_TEMPLATE/new_unit_request.md
================================================
---
name: New unit request
about: Suggest a unit of measurement that should be added
title: "[new-unit]"
labels: ''
assignees: ''

---

<!---
⚠️ Are asking about adding a new currency? ⚠️
Converter NOW is a free and open source project. The amount of donations it
receives are too low to pay an exchange rate api service. At the moment we are
using the free exchange rate api of the european central bank, it provides a lot
of conversions (but not all). You can check the supported currencies here:
https://www.ecb.europa.eu/stats/policy_and_exchange_rates/euro_reference_exchange_rates/html/index.en.html
Don't open a new issue if the currency you would like to see is not supported by
this service.
-->

**Description**
Add here a brief explanation to which units should be added and possibly why
(e.g. they are often used in a specific job). We know that there are a ton of
unit of measurement that are not yet added to this app. We want to have just the
most used one.

**Units to be added**
| Unit name | Property | Reference to the conversion formula                |
| ----------| -------- | -------------------------------------------------- |
| Angstrom  | Length   | [link](https://en.wikipedia.org/wiki/Angstrom)     |
| Pound     | Mass     | [link](https://en.wikipedia.org/wiki/Pound_(mass)) |
| Yen       | Currency | /                                                  |


================================================
FILE: .github/dependabot.yml
================================================
version: 2
updates:
- package-ecosystem: "github-actions"
  directory: "/"
  schedule:
    interval: "weekly"

- package-ecosystem: "pub"
  directories:
    - "/"
    - "/packages/calculator_widget"
    - "/packages/translations"
  schedule:
    interval: "monthly"
  ignore:
  - dependency-name: "*"
    update-types:
    - "version-update:semver-patch"
    - "version-update:semver-minor"


================================================
FILE: .github/workflows/build_deploy.yml
================================================
name: "Build & deploy for Android, Linux, Web and Windows"

on:
  push:
    tags: ['v*']

jobs:

  build_linux_x86_64:
    name: Build and release Linux app (x86_64)
    # Use the previous ubuntu version for compatibility (https://github.com/ferraridamiano/ConverterNOW/issues/370)
    runs-on: ubuntu-22.04
    timeout-minutes: 15
    steps:
    - name: Checkout
      uses: actions/checkout@v6

    - name: Install missing packages
      run: |
        sudo add-apt-repository universe
        sudo apt-get update
        sudo apt-get install -y clang cmake ninja-build pkg-config libgtk-3-dev liblzma-dev libstdc++-12-dev desktop-file-utils
    
    - name: Setup Flutter
      uses: subosito/flutter-action@v2
      with:
        channel: stable
        cache: true

    - name: Flutter version
      run: flutter --version

    - name: Bootstrap
      run: |
        flutter pub global activate melos
        melos bootstrap

    - name: Build for linux
      run: flutter build linux --release

    - name: Tar linux package
      run: |
        arch=$(ls build/linux)
        tar -C build/linux/$arch/release/bundle -czf converternow-linux-x86_64.tar.gz .

    - name: Build appimage
      run: |
        chmod +x .github/workflows/scripts/build_appimage.sh
        ./.github/workflows/scripts/build_appimage.sh

    - name: Release to GitHub
      uses: softprops/action-gh-release@v2
      with:
        files: |
          converternow-linux-x86_64.tar.gz
          converternow-x86_64.AppImage
        token: ${{ secrets.GH_TOKEN }}

    - name: Upload compiled icons
      uses: actions/upload-artifact@v7
      with:
        name: assets
        path: assets

  build_linux_aarch64:
    name: Build and release Linux app (aarch64)
    # Use the previous ubuntu version for compatibility (https://github.com/ferraridamiano/ConverterNOW/issues/370)
    runs-on: ubuntu-22.04-arm
    timeout-minutes: 15
    needs: build_linux_x86_64
    steps:

    - name: Checkout
      uses: actions/checkout@v6

    - name: Install missing packages
      run: |
        sudo add-apt-repository universe
        sudo apt-get update
        sudo apt-get install -y clang cmake ninja-build pkg-config libgtk-3-dev liblzma-dev libstdc++-12-dev desktop-file-utils

    # Use git because subosito/flutter-action does not support arm64 yet (https://github.com/subosito/flutter-action/issues/345)
    - name: Setup Flutter
      run: |
        git clone --branch stable https://github.com/flutter/flutter.git $RUNNER_TEMP/flutter
        cd $RUNNER_TEMP/flutter
        echo "$RUNNER_TEMP/flutter/bin" >> $GITHUB_PATH
        echo "$HOME/.pub-cache/bin" >> $GITHUB_PATH

    - name: Flutter version
      run: flutter --version

    # continue-on-error is set because we would receive an error on icon
    # compilation (but we import the compiled icons from previous step)
    - name: Bootstrap
      continue-on-error: true
      run: |
        flutter pub global activate melos
        melos bootstrap

    - name: Remove current assets
      run: rm -rf assets

    - name: Download compiled assets
      uses: actions/download-artifact@v8
      with:
        name: assets
        path: assets

    - name: Build for linux
      run: flutter build linux --release

    - name: Tar linux package
      run: |
        arch=$(ls build/linux)
        tar -C build/linux/$arch/release/bundle -czf converternow-linux-aarch64.tar.gz .

    - name: Build appimage
      run: |
        chmod +x .github/workflows/scripts/build_appimage.sh
        ./.github/workflows/scripts/build_appimage.sh

    - name: Release to GitHub
      uses: softprops/action-gh-release@v2
      with:
        files: |
          converternow-linux-aarch64.tar.gz
          converternow-aarch64.AppImage
        token: ${{ secrets.GH_TOKEN }}

  build_android:
    needs: build_linux_aarch64
    name: Build and release Android app
    runs-on: ubuntu-latest
    timeout-minutes: 15
    steps:
    - name: Checkout
      uses: actions/checkout@v6

    - name: Setup Java
      uses: actions/setup-java@v5
      with:
        distribution: 'temurin'
        java-version: '17'

    - name: Setup Flutter
      uses: subosito/flutter-action@v2
      with:
        channel: stable
        cache: true

    - name: Flutter version
      run: flutter --version

    - name: Bootstrap
      run: |
        dart pub global activate melos
        melos bootstrap

    - name: Download Android keystore
      id: android_keystore
      uses: timheuer/base64-to-file@v1
      with:
        fileName: key.jks
        encodedString: ${{ secrets.ANDROID_KEYSTORE_BASE64 }}
  
    - name: Create key.properties
      run: |
        echo "storeFile=${{ steps.android_keystore.outputs.filePath }}" > android/key.properties
        echo "storePassword=${{ secrets.ANDROID_KEYSTORE_PASSWORD }}" >> android/key.properties
        echo "keyPassword=${{ secrets.ANDROID_KEY_PASSWORD }}" >> android/key.properties
        echo "keyAlias=${{ secrets.ANDROID_KEY_ALIAS }}" >> android/key.properties
  
    - name: Build Android App Bundle
      run: flutter build appbundle --dart-define=IS_PLAYSTORE=true --obfuscate --split-debug-info=/tmp

    - name: Build Android APK files
      run: flutter build apk --release --split-per-abi --obfuscate --split-debug-info=/tmp

    - name: Release to GitHub
      uses: softprops/action-gh-release@v2
      with:
        files: |
          build/app/outputs/flutter-apk/app-*-release.apk
          build/app/outputs/bundle/release/app-release.aab
        token: ${{ secrets.GH_TOKEN }}

  
  build_web:
    needs: build_android
    name: Build and release Web app
    runs-on: ubuntu-latest
    timeout-minutes: 15
    steps:
    - name: Checkout
      uses: actions/checkout@v6

    - name: Setup Flutter
      uses: subosito/flutter-action@v2
      with:
        channel: stable
        cache: true

    - name: Flutter version
      run: flutter --version

    - name: Bootstrap
      run: |
        dart pub global activate melos
        melos bootstrap

    - name: Build for Web
      run: flutter build web --release --wasm

    - name: Upload to Firebase Hosting
      uses: FirebaseExtended/action-hosting-deploy@v0
      with:
        repoToken: '${{ secrets.GITHUB_TOKEN }}'
        firebaseServiceAccount: '${{ secrets.FIREBASE_SERVICE_ACCOUNT_CONVERTER_NOW }}'
        channelId: live
        projectId: converter-now

  build_windows:
    needs: build_web
    name: Build and release Windows app
    runs-on: windows-latest
    timeout-minutes: 20
    steps:
    - name: Checkout
      uses: actions/checkout@v6
    
    - name: Setup Flutter
      uses: subosito/flutter-action@v2
      with:
        channel: stable
        cache: true

    - name: Flutter version
      run: flutter --version

    - name: Bootstrap
      run: |
        dart pub global activate melos
        melos bootstrap

    - name: Build Windows
      run: flutter build windows --release

    - name: Build and create the .msix installer
      run: dart run msix:create --store

    - name: Create the .exe installer
      shell: pwsh
      run: |
        $version = (Select-String -Path pubspec.yaml -Pattern "^version:\s*(.+)").Matches[0].Groups[1].Value.Split("+")[0]
        iscc /DMyAppVersion=$version windows\innosetup.iss

    - name: Release to GitHub
      uses: softprops/action-gh-release@v2
      with:
        files: |
          build/windows/x64/runner/Release/converternow-windows.msix
          windows/converternow-windows-setup.exe
        token: ${{ secrets.GH_TOKEN }}

  build_docker:
    needs: build_windows
    name: Build and release Docker image
    runs-on: ubuntu-latest
    timeout-minutes: 10
    env:
      REGISTRY: ghcr.io
      IMAGE_NAME: ${{ github.repository }}
    permissions:
      contents: read
      packages: write
      attestations: write
      id-token: write
    steps:
      - name: Checkout code
        uses: actions/checkout@v6

      - name: Log in to the Container registry
        uses: docker/login-action@v4
        with:
          registry: ${{ env.REGISTRY }}
          username: ${{ github.actor }}
          password: ${{ secrets.GITHUB_TOKEN }}

      - name: Extract metadata (tags, labels) for Docker
        id: meta
        uses: docker/metadata-action@v6
        with:
          images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}

      - name: Set up QEMU
        uses: docker/setup-qemu-action@v4

      - name: Set up Docker Buildx
        uses: docker/setup-buildx-action@v4

      - name: Build and push Docker image
        id: push
        uses: docker/build-push-action@v7
        with:
          context: .
          push: true
          platforms: linux/amd64,linux/arm64
          tags: ${{ steps.meta.outputs.tags }}
          labels: ${{ steps.meta.outputs.labels }}
          cache-from: type=gha
          cache-to: type=gha,mode=max

      - name: Generate artifact attestation
        uses: actions/attest@v4
        with:
          subject-name: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME}}
          subject-digest: ${{ steps.push.outputs.digest }}
          push-to-registry: true

  create_release:
    needs: build_docker
    name: Create GitHub Release
    runs-on: ubuntu-latest
    timeout-minutes: 5
    permissions:
      contents: write

    steps:
      - name: Checkout repository
        uses: actions/checkout@v6
        with:
          fetch-depth: 0

      - name: Generate Changelog using git-cliff
        uses: orhun/git-cliff-action@v4
        id: git-cliff
        with:
          args: --latest

      - name: Create GitHub Release
        uses: softprops/action-gh-release@v2
        with:
          body: ${{ steps.git-cliff.outputs.content }}


================================================
FILE: .github/workflows/scripts/build_appimage.sh
================================================
#!/bin/bash

# This script needs to be called once the flutter linux app build is finished

arch=$(ls build/linux)
arch_label=""
if [ "$arch" == "x64" ]; then
    arch_label="x86_64"
else
    arch_label="aarch64"
fi
appimagetool="appimagetool-$arch_label.AppImage"
wget "https://github.com/AppImage/appimagetool/releases/latest/download/$appimagetool"
chmod +x "$appimagetool"
mkdir ConverterNOW.AppDir
cp -r build/linux/$arch/release/bundle/* ConverterNOW.AppDir
cp assets/app_icons/logo.svg ConverterNOW.AppDir
echo -e '#!/bin/sh\ncd "$(dirname "$0")"\nexec ./converternow' > ConverterNOW.AppDir/AppRun
chmod +x ConverterNOW.AppDir/AppRun
cp linux/io.github.ferraridamiano.ConverterNOW.desktop ConverterNOW.AppDir
desktop-file-edit --set-icon="logo" --set-key="Exec" --set-value="converternow %u" ConverterNOW.AppDir/io.github.ferraridamiano.ConverterNOW.desktop
APPIMAGETOOL_APP_NAME=converternow ./"$appimagetool" ConverterNOW.AppDir
rm -r ConverterNOW.AppDir "$appimagetool"


================================================
FILE: .github/workflows/tests.yml
================================================
name: Tests

on:
  push:
    branches:
      - master
  pull_request:

jobs:
  # JOB to run change detection
  changes:
    name: Detect changed files
    runs-on: ubuntu-latest
    # Set job outputs to values from filter step
    outputs:
      integration_testing: ${{ steps.filter.outputs.integration_testing }}
    steps:
    - uses: actions/checkout@v6
    - uses: dorny/paths-filter@v4
      id: filter
      with:
        filters: |
          integration_testing:
          - 'lib/**'
          - 'packages/**'
          - 'pubspec.yaml'

  integration_testing:
    needs: changes
    if: ${{ needs.changes.outputs.integration_testing == 'true' }}
    name: Integration testing
    runs-on: ubuntu-latest
    timeout-minutes: 15
    steps:
    - name: Checkout
      uses: actions/checkout@v6

    - name: Install missing packages
      run: |
        sudo apt-get update
        sudo apt-get install -y ninja-build libgtk-3-dev

    - name: Setup Flutter
      uses: subosito/flutter-action@v2
      with:
        cache: true
        channel: stable

    - name: Flutter doctor
      run: flutter doctor --verbose

    - name: Install required dart tools
      run: |
        dart pub global activate melos

    - name: Bootstrap
      run: melos bootstrap
      
    - name: Run large display integration testing
      run: |
        export DISPLAY=:99
        sudo Xvfb -ac :99 -screen 0 1280x1024x24 > /dev/null 2>&1 &
        flutter test integration_test/large_display_test.dart -d linux

    - name: Run small display integration testing
      run: |
        export DISPLAY=:99
        sudo Xvfb -ac :99 -screen 0 1280x1024x24 > /dev/null 2>&1 &
        flutter test integration_test/small_display_test.dart -d linux


================================================
FILE: .gitignore
================================================
.DS_Store
.dart_tool/

.packages
.pub/

build/

.flutter-plugins
*.jks
.flutter-plugins-dependencies
ios/Flutter/flutter_export_environment.sh
android/key.properties
*.iml
.metadata
.idea/
ios/Flutter/flutter_export_environment.sh
debug.log
.snap
packages/translations/lib/app_localizations*.dart
pubspec_overrides.yaml
assets/*/*.svg.vec


================================================
FILE: .vscode/settings.json
================================================
{
  "files.exclude": {
    "packages/translations/lib/app_localizations*.dart": true,
  },
  "cmake.ignoreCMakeListsMissing": true
}


================================================
FILE: CONTRIBUTING.md
================================================
# Welcome

We invite you to join our team! Everyone is welcome to contribute by submitting
code, pull requests, or reporting issues on GitHub. There are many ways to get
involved, and you don't need to be an expert to make a difference. Think you're
not ready to contribute? Let us show you otherwise! Let's get started!

## Translating the app

The app is currently translated into several languages, but if you know another
language and would like to help with further internationalization, please check
out the latest instructions
[here](https://github.com/ferraridamiano/ConverterNOW/wiki/Translations). You
can also contribute by translating the Play Store/F-Droid app page, which can
be found
[here](https://github.com/ferraridamiano/ConverterNOW/tree/master/fastlane/metadata/android/en-US).
If you have any questions, feel free to contact me via email or open a new
issue. I'll handle the rest. Thank you for your support!

## Design a new logo

If you think you can create a better app icon, feel free to open a new issue or
pull request with your proposal. I’ll guide you on how to integrate your idea
into the project. Thank you!

## Submit a PR

If you're confident with Flutter coding, you can help improve the app by submitting a pull request. But first, let me explain how the project is organized.

### Project structure

The project uses [riverpod](https://github.com/rrousselGit/riverpod) for state
management, with providers located in
[`lib/models`](https://github.com/ferraridamiano/ConverterNOW/tree/master/lib/models).
The app is structured as a monorepo and managed with
[`melos`](https://github.com/invertase/melos).

### Add new units

If you want to add new units I wrote a
[wiki page](https://github.com/ferraridamiano/ConverterNOW/wiki/Add-a-new-unit-of-measurement),
it is a step by step guide.

## Donations

This project is a labor of love, managed by a single person. Your
[donations](https://www.paypal.com/paypalme/DemApps) are invaluable — they help
keep the development going and provide the motivation to continue improving the
app. Every contribution, big or small, makes a difference. If you enjoy using
the app and believe in its future, please consider supporting the project.
Thank you!


================================================
FILE: Dockerfile
================================================
FROM --platform=linux/amd64 debian:13-slim AS builder

USER root

ENV HOME="/root"
ARG flutter_version="stable"

ENV FLUTTER_HOME=${HOME}/sdks/flutter \
    FLUTTER_VERSION=$flutter_version
ENV FLUTTER_ROOT=$FLUTTER_HOME
ENV PATH="$FLUTTER_HOME/bin:$FLUTTER_HOME/bin/cache/dart-sdk/bin:$HOME/.pub-cache/bin:${PATH}"

RUN DEBIAN_FRONTEND=noninteractive apt-get update && \
    DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
        bash \
        curl \
        git \
        wget \
        unzip \
        libstdc++6 \
        ca-certificates \
        xz-utils \
        zip \
        libglu1-mesa && \
    DEBIAN_FRONTEND=noninteractive apt-get clean && \
    rm -rf /var/lib/apt/lists/*

RUN git clone --branch ${FLUTTER_VERSION} https://github.com/flutter/flutter.git ${FLUTTER_HOME}

RUN flutter config --no-enable-windows-desktop --no-enable-macos-desktop --no-enable-linux-desktop --no-enable-android --no-enable-ios --enable-web && \
    flutter channel stable && \
    flutter doctor && \
    flutter precache --web --no-ios --no-windows --no-macos --no-linux --no-android && \
    chown -R root:root ${FLUTTER_HOME}

WORKDIR /app
COPY . .

RUN flutter pub global activate melos && \
    melos bootstrap && \
    flutter build web --release --wasm --no-web-resources-cdn

FROM nginx:alpine-slim

COPY --from=builder /app/build/web /usr/share/nginx/html

# Workaround, remove once https://github.com/nginx/nginx/pull/448 has been merged
RUN sed -i -E 's|application/javascript\s+js;|application/javascript       js mjs;|' /etc/nginx/mime.types

EXPOSE 80

HEALTHCHECK --interval=30s --timeout=5s --start-period=10s --retries=3 \
    CMD wget -O /dev/null http://localhost || exit 1

CMD ["nginx", "-g", "daemon off;"]


================================================
FILE: LICENSE
================================================
                    GNU GENERAL PUBLIC LICENSE
                       Version 3, 29 June 2007

 Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
 Everyone is permitted to copy and distribute verbatim copies
 of this license document, but changing it is not allowed.

                            Preamble

  The GNU General Public License is a free, copyleft license for
software and other kinds of works.

  The licenses for most software and other practical works are designed
to take away your freedom to share and change the works.  By contrast,
the GNU General Public License is intended to guarantee your freedom to
share and change all versions of a program--to make sure it remains free
software for all its users.  We, the Free Software Foundation, use the
GNU General Public License for most of our software; it applies also to
any other work released this way by its authors.  You can apply it to
your programs, too.

  When we speak of free software, we are referring to freedom, not
price.  Our General Public Licenses are designed to make sure that you
have the freedom to distribute copies of free software (and charge for
them if you wish), that you receive source code or can get it if you
want it, that you can change the software or use pieces of it in new
free programs, and that you know you can do these things.

  To protect your rights, we need to prevent others from denying you
these rights or asking you to surrender the rights.  Therefore, you have
certain responsibilities if you distribute copies of the software, or if
you modify it: responsibilities to respect the freedom of others.

  For example, if you distribute copies of such a program, whether
gratis or for a fee, you must pass on to the recipients the same
freedoms that you received.  You must make sure that they, too, receive
or can get the source code.  And you must show them these terms so they
know their rights.

  Developers that use the GNU GPL protect your rights with two steps:
(1) assert copyright on the software, and (2) offer you this License
giving you legal permission to copy, distribute and/or modify it.

  For the developers' and authors' protection, the GPL clearly explains
that there is no warranty for this free software.  For both users' and
authors' sake, the GPL requires that modified versions be marked as
changed, so that their problems will not be attributed erroneously to
authors of previous versions.

  Some devices are designed to deny users access to install or run
modified versions of the software inside them, although the manufacturer
can do so.  This is fundamentally incompatible with the aim of
protecting users' freedom to change the software.  The systematic
pattern of such abuse occurs in the area of products for individuals to
use, which is precisely where it is most unacceptable.  Therefore, we
have designed this version of the GPL to prohibit the practice for those
products.  If such problems arise substantially in other domains, we
stand ready to extend this provision to those domains in future versions
of the GPL, as needed to protect the freedom of users.

  Finally, every program is threatened constantly by software patents.
States should not allow patents to restrict development and use of
software on general-purpose computers, but in those that do, we wish to
avoid the special danger that patents applied to a free program could
make it effectively proprietary.  To prevent this, the GPL assures that
patents cannot be used to render the program non-free.

  The precise terms and conditions for copying, distribution and
modification follow.

                       TERMS AND CONDITIONS

  0. Definitions.

  "This License" refers to version 3 of the GNU General Public License.

  "Copyright" also means copyright-like laws that apply to other kinds of
works, such as semiconductor masks.

  "The Program" refers to any copyrightable work licensed under this
License.  Each licensee is addressed as "you".  "Licensees" and
"recipients" may be individuals or organizations.

  To "modify" a work means to copy from or adapt all or part of the work
in a fashion requiring copyright permission, other than the making of an
exact copy.  The resulting work is called a "modified version" of the
earlier work or a work "based on" the earlier work.

  A "covered work" means either the unmodified Program or a work based
on the Program.

  To "propagate" a work means to do anything with it that, without
permission, would make you directly or secondarily liable for
infringement under applicable copyright law, except executing it on a
computer or modifying a private copy.  Propagation includes copying,
distribution (with or without modification), making available to the
public, and in some countries other activities as well.

  To "convey" a work means any kind of propagation that enables other
parties to make or receive copies.  Mere interaction with a user through
a computer network, with no transfer of a copy, is not conveying.

  An interactive user interface displays "Appropriate Legal Notices"
to the extent that it includes a convenient and prominently visible
feature that (1) displays an appropriate copyright notice, and (2)
tells the user that there is no warranty for the work (except to the
extent that warranties are provided), that licensees may convey the
work under this License, and how to view a copy of this License.  If
the interface presents a list of user commands or options, such as a
menu, a prominent item in the list meets this criterion.

  1. Source Code.

  The "source code" for a work means the preferred form of the work
for making modifications to it.  "Object code" means any non-source
form of a work.

  A "Standard Interface" means an interface that either is an official
standard defined by a recognized standards body, or, in the case of
interfaces specified for a particular programming language, one that
is widely used among developers working in that language.

  The "System Libraries" of an executable work include anything, other
than the work as a whole, that (a) is included in the normal form of
packaging a Major Component, but which is not part of that Major
Component, and (b) serves only to enable use of the work with that
Major Component, or to implement a Standard Interface for which an
implementation is available to the public in source code form.  A
"Major Component", in this context, means a major essential component
(kernel, window system, and so on) of the specific operating system
(if any) on which the executable work runs, or a compiler used to
produce the work, or an object code interpreter used to run it.

  The "Corresponding Source" for a work in object code form means all
the source code needed to generate, install, and (for an executable
work) run the object code and to modify the work, including scripts to
control those activities.  However, it does not include the work's
System Libraries, or general-purpose tools or generally available free
programs which are used unmodified in performing those activities but
which are not part of the work.  For example, Corresponding Source
includes interface definition files associated with source files for
the work, and the source code for shared libraries and dynamically
linked subprograms that the work is specifically designed to require,
such as by intimate data communication or control flow between those
subprograms and other parts of the work.

  The Corresponding Source need not include anything that users
can regenerate automatically from other parts of the Corresponding
Source.

  The Corresponding Source for a work in source code form is that
same work.

  2. Basic Permissions.

  All rights granted under this License are granted for the term of
copyright on the Program, and are irrevocable provided the stated
conditions are met.  This License explicitly affirms your unlimited
permission to run the unmodified Program.  The output from running a
covered work is covered by this License only if the output, given its
content, constitutes a covered work.  This License acknowledges your
rights of fair use or other equivalent, as provided by copyright law.

  You may make, run and propagate covered works that you do not
convey, without conditions so long as your license otherwise remains
in force.  You may convey covered works to others for the sole purpose
of having them make modifications exclusively for you, or provide you
with facilities for running those works, provided that you comply with
the terms of this License in conveying all material for which you do
not control copyright.  Those thus making or running the covered works
for you must do so exclusively on your behalf, under your direction
and control, on terms that prohibit them from making any copies of
your copyrighted material outside their relationship with you.

  Conveying under any other circumstances is permitted solely under
the conditions stated below.  Sublicensing is not allowed; section 10
makes it unnecessary.

  3. Protecting Users' Legal Rights From Anti-Circumvention Law.

  No covered work shall be deemed part of an effective technological
measure under any applicable law fulfilling obligations under article
11 of the WIPO copyright treaty adopted on 20 December 1996, or
similar laws prohibiting or restricting circumvention of such
measures.

  When you convey a covered work, you waive any legal power to forbid
circumvention of technological measures to the extent such circumvention
is effected by exercising rights under this License with respect to
the covered work, and you disclaim any intention to limit operation or
modification of the work as a means of enforcing, against the work's
users, your or third parties' legal rights to forbid circumvention of
technological measures.

  4. Conveying Verbatim Copies.

  You may convey verbatim copies of the Program's source code as you
receive it, in any medium, provided that you conspicuously and
appropriately publish on each copy an appropriate copyright notice;
keep intact all notices stating that this License and any
non-permissive terms added in accord with section 7 apply to the code;
keep intact all notices of the absence of any warranty; and give all
recipients a copy of this License along with the Program.

  You may charge any price or no price for each copy that you convey,
and you may offer support or warranty protection for a fee.

  5. Conveying Modified Source Versions.

  You may convey a work based on the Program, or the modifications to
produce it from the Program, in the form of source code under the
terms of section 4, provided that you also meet all of these conditions:

    a) The work must carry prominent notices stating that you modified
    it, and giving a relevant date.

    b) The work must carry prominent notices stating that it is
    released under this License and any conditions added under section
    7.  This requirement modifies the requirement in section 4 to
    "keep intact all notices".

    c) You must license the entire work, as a whole, under this
    License to anyone who comes into possession of a copy.  This
    License will therefore apply, along with any applicable section 7
    additional terms, to the whole of the work, and all its parts,
    regardless of how they are packaged.  This License gives no
    permission to license the work in any other way, but it does not
    invalidate such permission if you have separately received it.

    d) If the work has interactive user interfaces, each must display
    Appropriate Legal Notices; however, if the Program has interactive
    interfaces that do not display Appropriate Legal Notices, your
    work need not make them do so.

  A compilation of a covered work with other separate and independent
works, which are not by their nature extensions of the covered work,
and which are not combined with it such as to form a larger program,
in or on a volume of a storage or distribution medium, is called an
"aggregate" if the compilation and its resulting copyright are not
used to limit the access or legal rights of the compilation's users
beyond what the individual works permit.  Inclusion of a covered work
in an aggregate does not cause this License to apply to the other
parts of the aggregate.

  6. Conveying Non-Source Forms.

  You may convey a covered work in object code form under the terms
of sections 4 and 5, provided that you also convey the
machine-readable Corresponding Source under the terms of this License,
in one of these ways:

    a) Convey the object code in, or embodied in, a physical product
    (including a physical distribution medium), accompanied by the
    Corresponding Source fixed on a durable physical medium
    customarily used for software interchange.

    b) Convey the object code in, or embodied in, a physical product
    (including a physical distribution medium), accompanied by a
    written offer, valid for at least three years and valid for as
    long as you offer spare parts or customer support for that product
    model, to give anyone who possesses the object code either (1) a
    copy of the Corresponding Source for all the software in the
    product that is covered by this License, on a durable physical
    medium customarily used for software interchange, for a price no
    more than your reasonable cost of physically performing this
    conveying of source, or (2) access to copy the
    Corresponding Source from a network server at no charge.

    c) Convey individual copies of the object code with a copy of the
    written offer to provide the Corresponding Source.  This
    alternative is allowed only occasionally and noncommercially, and
    only if you received the object code with such an offer, in accord
    with subsection 6b.

    d) Convey the object code by offering access from a designated
    place (gratis or for a charge), and offer equivalent access to the
    Corresponding Source in the same way through the same place at no
    further charge.  You need not require recipients to copy the
    Corresponding Source along with the object code.  If the place to
    copy the object code is a network server, the Corresponding Source
    may be on a different server (operated by you or a third party)
    that supports equivalent copying facilities, provided you maintain
    clear directions next to the object code saying where to find the
    Corresponding Source.  Regardless of what server hosts the
    Corresponding Source, you remain obligated to ensure that it is
    available for as long as needed to satisfy these requirements.

    e) Convey the object code using peer-to-peer transmission, provided
    you inform other peers where the object code and Corresponding
    Source of the work are being offered to the general public at no
    charge under subsection 6d.

  A separable portion of the object code, whose source code is excluded
from the Corresponding Source as a System Library, need not be
included in conveying the object code work.

  A "User Product" is either (1) a "consumer product", which means any
tangible personal property which is normally used for personal, family,
or household purposes, or (2) anything designed or sold for incorporation
into a dwelling.  In determining whether a product is a consumer product,
doubtful cases shall be resolved in favor of coverage.  For a particular
product received by a particular user, "normally used" refers to a
typical or common use of that class of product, regardless of the status
of the particular user or of the way in which the particular user
actually uses, or expects or is expected to use, the product.  A product
is a consumer product regardless of whether the product has substantial
commercial, industrial or non-consumer uses, unless such uses represent
the only significant mode of use of the product.

  "Installation Information" for a User Product means any methods,
procedures, authorization keys, or other information required to install
and execute modified versions of a covered work in that User Product from
a modified version of its Corresponding Source.  The information must
suffice to ensure that the continued functioning of the modified object
code is in no case prevented or interfered with solely because
modification has been made.

  If you convey an object code work under this section in, or with, or
specifically for use in, a User Product, and the conveying occurs as
part of a transaction in which the right of possession and use of the
User Product is transferred to the recipient in perpetuity or for a
fixed term (regardless of how the transaction is characterized), the
Corresponding Source conveyed under this section must be accompanied
by the Installation Information.  But this requirement does not apply
if neither you nor any third party retains the ability to install
modified object code on the User Product (for example, the work has
been installed in ROM).

  The requirement to provide Installation Information does not include a
requirement to continue to provide support service, warranty, or updates
for a work that has been modified or installed by the recipient, or for
the User Product in which it has been modified or installed.  Access to a
network may be denied when the modification itself materially and
adversely affects the operation of the network or violates the rules and
protocols for communication across the network.

  Corresponding Source conveyed, and Installation Information provided,
in accord with this section must be in a format that is publicly
documented (and with an implementation available to the public in
source code form), and must require no special password or key for
unpacking, reading or copying.

  7. Additional Terms.

  "Additional permissions" are terms that supplement the terms of this
License by making exceptions from one or more of its conditions.
Additional permissions that are applicable to the entire Program shall
be treated as though they were included in this License, to the extent
that they are valid under applicable law.  If additional permissions
apply only to part of the Program, that part may be used separately
under those permissions, but the entire Program remains governed by
this License without regard to the additional permissions.

  When you convey a copy of a covered work, you may at your option
remove any additional permissions from that copy, or from any part of
it.  (Additional permissions may be written to require their own
removal in certain cases when you modify the work.)  You may place
additional permissions on material, added by you to a covered work,
for which you have or can give appropriate copyright permission.

  Notwithstanding any other provision of this License, for material you
add to a covered work, you may (if authorized by the copyright holders of
that material) supplement the terms of this License with terms:

    a) Disclaiming warranty or limiting liability differently from the
    terms of sections 15 and 16 of this License; or

    b) Requiring preservation of specified reasonable legal notices or
    author attributions in that material or in the Appropriate Legal
    Notices displayed by works containing it; or

    c) Prohibiting misrepresentation of the origin of that material, or
    requiring that modified versions of such material be marked in
    reasonable ways as different from the original version; or

    d) Limiting the use for publicity purposes of names of licensors or
    authors of the material; or

    e) Declining to grant rights under trademark law for use of some
    trade names, trademarks, or service marks; or

    f) Requiring indemnification of licensors and authors of that
    material by anyone who conveys the material (or modified versions of
    it) with contractual assumptions of liability to the recipient, for
    any liability that these contractual assumptions directly impose on
    those licensors and authors.

  All other non-permissive additional terms are considered "further
restrictions" within the meaning of section 10.  If the Program as you
received it, or any part of it, contains a notice stating that it is
governed by this License along with a term that is a further
restriction, you may remove that term.  If a license document contains
a further restriction but permits relicensing or conveying under this
License, you may add to a covered work material governed by the terms
of that license document, provided that the further restriction does
not survive such relicensing or conveying.

  If you add terms to a covered work in accord with this section, you
must place, in the relevant source files, a statement of the
additional terms that apply to those files, or a notice indicating
where to find the applicable terms.

  Additional terms, permissive or non-permissive, may be stated in the
form of a separately written license, or stated as exceptions;
the above requirements apply either way.

  8. Termination.

  You may not propagate or modify a covered work except as expressly
provided under this License.  Any attempt otherwise to propagate or
modify it is void, and will automatically terminate your rights under
this License (including any patent licenses granted under the third
paragraph of section 11).

  However, if you cease all violation of this License, then your
license from a particular copyright holder is reinstated (a)
provisionally, unless and until the copyright holder explicitly and
finally terminates your license, and (b) permanently, if the copyright
holder fails to notify you of the violation by some reasonable means
prior to 60 days after the cessation.

  Moreover, your license from a particular copyright holder is
reinstated permanently if the copyright holder notifies you of the
violation by some reasonable means, this is the first time you have
received notice of violation of this License (for any work) from that
copyright holder, and you cure the violation prior to 30 days after
your receipt of the notice.

  Termination of your rights under this section does not terminate the
licenses of parties who have received copies or rights from you under
this License.  If your rights have been terminated and not permanently
reinstated, you do not qualify to receive new licenses for the same
material under section 10.

  9. Acceptance Not Required for Having Copies.

  You are not required to accept this License in order to receive or
run a copy of the Program.  Ancillary propagation of a covered work
occurring solely as a consequence of using peer-to-peer transmission
to receive a copy likewise does not require acceptance.  However,
nothing other than this License grants you permission to propagate or
modify any covered work.  These actions infringe copyright if you do
not accept this License.  Therefore, by modifying or propagating a
covered work, you indicate your acceptance of this License to do so.

  10. Automatic Licensing of Downstream Recipients.

  Each time you convey a covered work, the recipient automatically
receives a license from the original licensors, to run, modify and
propagate that work, subject to this License.  You are not responsible
for enforcing compliance by third parties with this License.

  An "entity transaction" is a transaction transferring control of an
organization, or substantially all assets of one, or subdividing an
organization, or merging organizations.  If propagation of a covered
work results from an entity transaction, each party to that
transaction who receives a copy of the work also receives whatever
licenses to the work the party's predecessor in interest had or could
give under the previous paragraph, plus a right to possession of the
Corresponding Source of the work from the predecessor in interest, if
the predecessor has it or can get it with reasonable efforts.

  You may not impose any further restrictions on the exercise of the
rights granted or affirmed under this License.  For example, you may
not impose a license fee, royalty, or other charge for exercise of
rights granted under this License, and you may not initiate litigation
(including a cross-claim or counterclaim in a lawsuit) alleging that
any patent claim is infringed by making, using, selling, offering for
sale, or importing the Program or any portion of it.

  11. Patents.

  A "contributor" is a copyright holder who authorizes use under this
License of the Program or a work on which the Program is based.  The
work thus licensed is called the contributor's "contributor version".

  A contributor's "essential patent claims" are all patent claims
owned or controlled by the contributor, whether already acquired or
hereafter acquired, that would be infringed by some manner, permitted
by this License, of making, using, or selling its contributor version,
but do not include claims that would be infringed only as a
consequence of further modification of the contributor version.  For
purposes of this definition, "control" includes the right to grant
patent sublicenses in a manner consistent with the requirements of
this License.

  Each contributor grants you a non-exclusive, worldwide, royalty-free
patent license under the contributor's essential patent claims, to
make, use, sell, offer for sale, import and otherwise run, modify and
propagate the contents of its contributor version.

  In the following three paragraphs, a "patent license" is any express
agreement or commitment, however denominated, not to enforce a patent
(such as an express permission to practice a patent or covenant not to
sue for patent infringement).  To "grant" such a patent license to a
party means to make such an agreement or commitment not to enforce a
patent against the party.

  If you convey a covered work, knowingly relying on a patent license,
and the Corresponding Source of the work is not available for anyone
to copy, free of charge and under the terms of this License, through a
publicly available network server or other readily accessible means,
then you must either (1) cause the Corresponding Source to be so
available, or (2) arrange to deprive yourself of the benefit of the
patent license for this particular work, or (3) arrange, in a manner
consistent with the requirements of this License, to extend the patent
license to downstream recipients.  "Knowingly relying" means you have
actual knowledge that, but for the patent license, your conveying the
covered work in a country, or your recipient's use of the covered work
in a country, would infringe one or more identifiable patents in that
country that you have reason to believe are valid.

  If, pursuant to or in connection with a single transaction or
arrangement, you convey, or propagate by procuring conveyance of, a
covered work, and grant a patent license to some of the parties
receiving the covered work authorizing them to use, propagate, modify
or convey a specific copy of the covered work, then the patent license
you grant is automatically extended to all recipients of the covered
work and works based on it.

  A patent license is "discriminatory" if it does not include within
the scope of its coverage, prohibits the exercise of, or is
conditioned on the non-exercise of one or more of the rights that are
specifically granted under this License.  You may not convey a covered
work if you are a party to an arrangement with a third party that is
in the business of distributing software, under which you make payment
to the third party based on the extent of your activity of conveying
the work, and under which the third party grants, to any of the
parties who would receive the covered work from you, a discriminatory
patent license (a) in connection with copies of the covered work
conveyed by you (or copies made from those copies), or (b) primarily
for and in connection with specific products or compilations that
contain the covered work, unless you entered into that arrangement,
or that patent license was granted, prior to 28 March 2007.

  Nothing in this License shall be construed as excluding or limiting
any implied license or other defenses to infringement that may
otherwise be available to you under applicable patent law.

  12. No Surrender of Others' Freedom.

  If conditions are imposed on you (whether by court order, agreement or
otherwise) that contradict the conditions of this License, they do not
excuse you from the conditions of this License.  If you cannot convey a
covered work so as to satisfy simultaneously your obligations under this
License and any other pertinent obligations, then as a consequence you may
not convey it at all.  For example, if you agree to terms that obligate you
to collect a royalty for further conveying from those to whom you convey
the Program, the only way you could satisfy both those terms and this
License would be to refrain entirely from conveying the Program.

  13. Use with the GNU Affero General Public License.

  Notwithstanding any other provision of this License, you have
permission to link or combine any covered work with a work licensed
under version 3 of the GNU Affero General Public License into a single
combined work, and to convey the resulting work.  The terms of this
License will continue to apply to the part which is the covered work,
but the special requirements of the GNU Affero General Public License,
section 13, concerning interaction through a network will apply to the
combination as such.

  14. Revised Versions of this License.

  The Free Software Foundation may publish revised and/or new versions of
the GNU General Public License from time to time.  Such new versions will
be similar in spirit to the present version, but may differ in detail to
address new problems or concerns.

  Each version is given a distinguishing version number.  If the
Program specifies that a certain numbered version of the GNU General
Public License "or any later version" applies to it, you have the
option of following the terms and conditions either of that numbered
version or of any later version published by the Free Software
Foundation.  If the Program does not specify a version number of the
GNU General Public License, you may choose any version ever published
by the Free Software Foundation.

  If the Program specifies that a proxy can decide which future
versions of the GNU General Public License can be used, that proxy's
public statement of acceptance of a version permanently authorizes you
to choose that version for the Program.

  Later license versions may give you additional or different
permissions.  However, no additional obligations are imposed on any
author or copyright holder as a result of your choosing to follow a
later version.

  15. Disclaimer of Warranty.

  THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
APPLICABLE LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
IS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.

  16. Limitation of Liability.

  IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
SUCH DAMAGES.

  17. Interpretation of Sections 15 and 16.

  If the disclaimer of warranty and limitation of liability provided
above cannot be given local legal effect according to their terms,
reviewing courts shall apply local law that most closely approximates
an absolute waiver of all civil liability in connection with the
Program, unless a warranty or assumption of liability accompanies a
copy of the Program in return for a fee.

                     END OF TERMS AND CONDITIONS

            How to Apply These Terms to Your New Programs

  If you develop a new program, and you want it to be of the greatest
possible use to the public, the best way to achieve this is to make it
free software which everyone can redistribute and change under these terms.

  To do so, attach the following notices to the program.  It is safest
to attach them to the start of each source file to most effectively
state the exclusion of warranty; and each file should have at least
the "copyright" line and a pointer to where the full notice is found.

    <one line to give the program's name and a brief idea of what it does.>
    Copyright (C) <year>  <name of author>

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <https://www.gnu.org/licenses/>.

Also add information on how to contact you by electronic and paper mail.

  If the program does terminal interaction, make it output a short
notice like this when it starts in an interactive mode:

    <program>  Copyright (C) <year>  <name of author>
    This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
    This is free software, and you are welcome to redistribute it
    under certain conditions; type `show c' for details.

The hypothetical commands `show w' and `show c' should show the appropriate
parts of the General Public License.  Of course, your program's commands
might be different; for a GUI interface, you would use an "about box".

  You should also get your employer (if you work as a programmer) or school,
if any, to sign a "copyright disclaimer" for the program, if necessary.
For more information on this, and how to apply and follow the GNU GPL, see
<https://www.gnu.org/licenses/>.

  The GNU General Public License does not permit incorporating your program
into proprietary programs.  If your program is a subroutine library, you
may consider it more useful to permit linking proprietary applications with
the library.  If this is what you want to do, use the GNU Lesser General
Public License instead of this License.  But first, please read
<https://www.gnu.org/licenses/why-not-lgpl.html>.

================================================
FILE: README.md
================================================
<div align="center">

# Converter NOW

</div>

<div align="center">
    <img alt="Icon" src="assets/logo.png" height="150px">
</div>

<br/>

<div align="center">
  <a href="https://play.google.com/store/apps/details?id=com.ferrarid.converterpro">
    <img alt="Google Play Badge" src="promotional/banners/play_store.png" height="48px">
  </a>
  <a href="https://apps.microsoft.com/detail/9p0q79hwjh72">
    <img alt="Microsoft store Badge" src="promotional/banners/microsoft_store.png" height="48px">
  </a>
  <a href="https://flathub.org/apps/details/io.github.ferraridamiano.ConverterNOW">
    <img alt="Flathub Badge" src="promotional/banners/flathub.png" height="48px">
  </a>
  <a href="https://github.com/ferraridamiano/ConverterNOW/releases">
    <img alt="GitHub Badge" src="promotional/banners/github.png" height="48px">
  </a>
  <a href="https://f-droid.org/packages/com.ferrarid.converterpro">
    <img alt="F-Droid Badge" src="promotional/banners/fdroid.png" height="48px">
  </a>
  <a href="https://github.com/ferraridamiano/ConverterNOW/releases/latest">
    <img alt="AppImage Badge" src="promotional/banners/appimage.png" height="48px">
  </a>
  <a href="https://converter-now.web.app">
    <img alt="PWA Badge" src="promotional/banners/pwa.png" height="48px">
  </a>
</div>

<br/>

<div align="center">
  <img src="promotional/screenshots/1.png" width="650">
</div>

## Why Converter NOW

Tired of complicated, cluttered, and ad-filled unit converters? Converter NOW
is your perfect solution! A few years ago, we realized that most unit
converters were not only visually unappealing but also lacked functionality,
privacy, and ease of use. So, we created Converter NOW to change that!

🚀 **Fast & Intuitive**: Experience lightning-fast, real-time conversions as
soon as you start typing. No more navigating through confusing menus – just
instant results with all measurement units!

🛠️ **Fully Customizable**: Tailor your experience by reorganizing units based
on your preferences and priorities. Make Converter NOW truly yours!

🔢 **Built-in Calculator**: Perform complex calculations effortlessly on any
page. No need to switch between apps – it's all integrated seamlessly.

💱 **Daily Currency Exchange Updates**: Stay up-to-date with accurate, real-time
currency conversions updated daily, perfect for travelers and global
professionals.

🎨 **Personalize Your Style**: Choose your favorite accent color, matching your
device's theme or your unique style preferences.

⚫⚪ **Light & Dark Modes**: Switch between dark and light themes for a
comfortable experience, day or night.

📱🖥️ **Cross-Platform Support**: Enjoy Converter NOW on Android, Web, Linux, and
Windows. Whether you're on your phone or desktop, we've got you covered!

💯 **Completely Free**: No ads, no data collection, and no intrusive permissions
(just internet access for currency updates). Best of all, it's
**100% open source!**

## Alternative installation sources

### Winget

Run the following command:
```bash
winget install -e 9P0Q79HWJH72
```

### Container self-hosted web app

You can easily self-host the Converter NOW web app on your own machine using
either Docker or Podman. Simply run one of the commands below, depending on your
containerization tool of choice:
```bash
docker run -d -p 8080:80 ghcr.io/ferraridamiano/converternow:latest
podman run -d -p 8080:80 ghcr.io/ferraridamiano/converternow:latest
```
After running the command, the web app will be accessible in your web browser at
`http://localhost:8080`.

## Build from source code
First you need to
[install flutter](https://docs.flutter.dev/get-started/install) and all the
tooling for your target platform (e.g. Android Studio for Android, etc.). Then
you have to install `melos` in order to do some pre-compiling task:

```shell
dart pub global activate melos
```

Then, run `melos bootstrap` in the root of the project in order to get all the
dependencies, generate the translation files and optimize the `svg` icons. Then
follow the instructions for the platform you want to target.

### Android
On Android you should first disable the signing option in
[`android/app/build.gradle.kts`](https://github.com/ferraridamiano/ConverterNOW/blob/master/android/app/build.gradle.kts#L42)
Then you can type `flutter build apk --split-per-abi` to compile the code. You
can find the output in `build/app/outputs/flutter-apk` folder.

### Linux
Type `flutter build linux` to build the Linux app. You can find the output in
`build/linux/x64/release/bundle`.

### Windows
Type `flutter build windows` to build the Windows app. You can find the output
in `build/windows/runner/Release`.

### Web
Type `flutter build web` to build the Web app. You can find the output in
`build/web`.

Note: if you deploy it not on the base path, add `--base-href=/path/` to the command above, change `/path/` with your path.

### Web app on Docker
You can build the Docker image of Converter NOW in your environment with the
following command:
```shell
docker buildx build -t converternow .
```

Then, run the docker container:
```shell
docker run -d -p 80:80 converternow
```

You can access it via browser at `localhost:80`

### iOS and MacOS
The app is not tested against iOS and MacOS, but you should be able to compile
it even for these platforms. You first need to generate the platform specific
code and then compile them.


================================================
FILE: analysis_options.yaml
================================================
include: package:flutter_lints/flutter.yaml

linter:
  rules:
    prefer_const_constructors: true
    prefer_const_declarations: true
    prefer_const_literals_to_create_immutables: true


================================================
FILE: android/.gitignore
================================================
gradle-wrapper.jar
/.gradle
/captures/
/gradlew
/gradlew.bat
/local.properties
GeneratedPluginRegistrant.java
.cxx/

# Remember to never publicly share your keystore.
# See https://flutter.dev/to/reference-keystore
key.properties
**/*.keystore
**/*.jks


================================================
FILE: android/app/build.gradle.kts
================================================
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")
}

val keystoreProperties = Properties()
val keystorePropertiesFile = rootProject.file("key.properties")
if (keystorePropertiesFile.exists()) {
    keystoreProperties.load(FileInputStream(keystorePropertiesFile))
}

android {
    namespace = "com.ferrarid.converterpro"
    compileSdk = flutter.compileSdkVersion
    ndkVersion = flutter.ndkVersion

    compileOptions {
        sourceCompatibility = JavaVersion.VERSION_17
        targetCompatibility = JavaVersion.VERSION_17
    }

    kotlinOptions {
        jvmTarget = JavaVersion.VERSION_17.toString()
    }

    defaultConfig {
        // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
        applicationId = "com.ferrarid.converterpro"
        // You can update the following values to match your application needs.
        // For more information, see: https://flutter.dev/to/review-gradle-config.
        minSdk = flutter.minSdkVersion
        targetSdk = flutter.targetSdkVersion
        versionCode = flutter.versionCode
        versionName = flutter.versionName
    }

    signingConfigs {
        create("release") {
            keyAlias = keystoreProperties["keyAlias"] as String
            keyPassword = keystoreProperties["keyPassword"] as String
            storeFile = keystoreProperties["storeFile"]?.let { file(it) }
            storePassword = keystoreProperties["storePassword"] as String
        }
    }

    buildTypes {
        release {
            signingConfig = signingConfigs.getByName("release")
        }
    }
}

flutter {
    source = "../.."
}


================================================
FILE: android/app/src/debug/AndroidManifest.xml
================================================
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- The INTERNET permission is required for development. Specifically,
         the Flutter tool needs it to communicate with the running application
         to allow setting breakpoints, to provide hot reload, etc.
    -->
    <uses-permission android:name="android.permission.INTERNET"/>
</manifest>


================================================
FILE: android/app/src/main/AndroidManifest.xml
================================================
<manifest xmlns:android="http://schemas.android.com/apk/res/android">

    <!-- The INTERNET permission is required in order to update currencies rates -->
    <uses-permission android:name="android.permission.INTERNET"/>
    <!-- The VIBRATE permission is used for haptic feedback -->
    <uses-permission android:name="android.permission.VIBRATE" />

    <application
        android:label="Converter NOW"
        android:name="${applicationName}"
        android:icon="@mipmap/ic_launcher"
        android:enableOnBackInvokedCallback="true">
        <activity
            android:name=".MainActivity"
            android:exported="true"
            android:launchMode="singleTop"
            android:taskAffinity=""
            android:theme="@style/LaunchTheme"
            android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
            android:hardwareAccelerated="true"
            android:windowSoftInputMode="adjustResize">
            <!-- Specifies an Android theme to apply to this Activity as soon as
                 the Android process has started. This theme is visible to the user
                 while the Flutter UI initializes. After that, this theme continues
                 to determine the Window background behind the Flutter UI. -->
            <meta-data
              android:name="io.flutter.embedding.android.NormalTheme"
              android:resource="@style/NormalTheme"
              />
            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
        </activity>
        <!-- Don't delete the meta-data below.
             This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
        <meta-data
            android:name="flutterEmbedding"
            android:value="2" />
    </application>
    <!-- Required to query activities that can process text, see:
         https://developer.android.com/training/package-visibility and
         https://developer.android.com/reference/android/content/Intent#ACTION_PROCESS_TEXT.

         In particular, this is used by the Flutter engine in io.flutter.plugin.text.ProcessTextPlugin. -->
    <queries>
        <intent>
            <action android:name="android.intent.action.PROCESS_TEXT"/>
            <data android:mimeType="text/plain"/>
        </intent>
    </queries>
</manifest>


================================================
FILE: android/app/src/main/kotlin/com/ferrarid/converterpro/MainActivity.kt
================================================
package com.ferrarid.converterpro

import io.flutter.embedding.android.FlutterActivity

class MainActivity : FlutterActivity()


================================================
FILE: android/app/src/main/res/drawable/ic_launcher_background.xml
================================================
<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="108dp"
    android:height="108dp"
    android:viewportWidth="135.47"
    android:viewportHeight="135.47">
  <path
      android:pathData="M67.73,67.73h67.73v67.73h-67.73z"
      android:strokeWidth="3.49094"
      android:fillColor="#fcae18"
      android:strokeColor="#00000000"/>
  <path
      android:pathData="M0,67.73h67.73v67.73h-67.73z"
      android:strokeWidth="3.5614"
      android:fillColor="#ea5724"
      android:strokeColor="#00000000"/>
  <path
      android:pathData="M67.73,0h67.73v67.73h-67.73z"
      android:strokeWidth="3.43912"
      android:fillColor="#7e4d9f"
      android:strokeColor="#00000000"/>
  <path
      android:pathData="M0,0h67.73v67.73h-67.73z"
      android:strokeWidth="3.54184"
      android:fillColor="#3299d4"
      android:strokeColor="#00000000"/>
</vector>


================================================
FILE: android/app/src/main/res/drawable/ic_launcher_foreground.xml
================================================
<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="108dp"
    android:height="108dp"
    android:viewportWidth="135.47"
    android:viewportHeight="135.47">
  <group android:scaleX="0.63"
      android:scaleY="0.63"
      android:translateX="25.06195"
      android:translateY="25.06195">
    <path
        android:pathData="m33.19,84.93c0,0 11.08,4.27 15.78,15.56C51.74,107.15 52.25,115.8 38.4,116.39 23.6,117.03 20.37,112.17 20.37,112.17c0,0 -4.61,-6.56 3.07,-17.19 7.33,-10.14 11.68,-10.02 11.68,-10.02 0,0 -10.64,-4.43 -7.05,-7.01 3.6,-2.58 1.3,3.9 5.85,2.6 4.55,-1.3 5.94,-4.66 6.01,-2.65 0.07,2 -6.75,7.03 -6.75,7.03z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="m33.19,84.93c0,0 11.08,4.27 15.78,15.56C51.74,107.15 52.25,115.8 38.4,116.39 23.6,117.03 20.37,112.17 20.37,112.17c0,0 -4.61,-6.56 3.07,-17.19 7.33,-10.14 11.68,-10.02 11.68,-10.02 0,0 -10.64,-4.43 -7.05,-7.01 3.6,-2.58 1.3,3.9 5.85,2.6 4.55,-1.3 5.94,-4.66 6.01,-2.65 0.07,2 -6.75,7.03 -6.75,7.03z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="m38.94,98.18c0,0 -0.95,-2.7 -4.47,-2.45C30.98,95.97 30.55,97.83 30.64,99.43 30.72,101.03 33.16,101.49 34.4,101.72 35.92,102.01 38.35,102.26 39.2,104.03 39.74,105.13 38.72,107.59 36.34,108.06 33.93,108.54 31.96,107.61 31.96,107.61c0,0 -1.36,-0.72 -1.83,-2.45"
        android:strokeLineJoin="round"
        android:strokeWidth="2.66"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="m38.94,98.18c0,0 -0.95,-2.7 -4.47,-2.45C30.98,95.97 30.55,97.83 30.64,99.43 30.72,101.03 33.16,101.49 34.4,101.72 35.92,102.01 38.35,102.26 39.2,104.03 39.74,105.13 38.72,107.59 36.34,108.06 33.93,108.54 31.96,107.61 31.96,107.61c0,0 -1.36,-0.72 -1.83,-2.45"
        android:strokeLineJoin="round"
        android:strokeWidth="2.66"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M34.59,93.5L34.59,110.67"
        android:strokeLineJoin="round"
        android:strokeWidth="2.66"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M34.59,93.5L34.59,110.67"
        android:strokeLineJoin="round"
        android:strokeWidth="2.66"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M80.19,53.15L116.02,53.15L111.48,27.04L84.67,27.04Z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M80.19,53.15L116.02,53.15L111.48,27.04L84.67,27.04Z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M98.07,20.32m-5.28,0a5.28,5.28 0,1 1,10.55 0a5.28,5.28 0,1 1,-10.55 0"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M98.07,20.32m-5.28,0a5.28,5.28 0,1 1,10.55 0a5.28,5.28 0,1 1,-10.55 0"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M91.6,76.61L91.6,91.8L80.32,110.92c0,0 -2.98,4.41 1.88,4.41l27.83,0C115.3,115.23 113.24,110.92 113.24,110.92L101.11,91.8L101.11,76.61Z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M91.6,76.61L91.6,91.8L80.32,110.92c0,0 -2.98,4.41 1.88,4.41l27.83,0C115.3,115.23 113.24,110.92 113.24,110.92L101.11,91.8L101.11,76.61Z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M89.89,76.61L102.81,76.61"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M89.89,76.61L102.81,76.61"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M86.92,99.73L106.15,99.73"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M86.92,99.73L106.15,99.73"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M14.51,45.96l31.88,-31.88l7.78,7.78l-31.88,31.88z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M14.51,45.96l31.88,-31.88l7.78,7.78l-31.88,31.88z"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M39.31,21.16 L43.22,25.07"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M39.31,21.16 L43.22,25.07"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M33.3,27.17 L37.21,31.09"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M33.3,27.17 L37.21,31.09"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M27.28,33.19 L31.19,37.1"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M27.28,33.19 L31.19,37.1"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M21.26,39.21 L25.17,43.12"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#ffffff"
        android:strokeLineCap="round"/>
    <path
        android:pathData="M21.26,39.21 L25.17,43.12"
        android:strokeLineJoin="round"
        android:strokeWidth="3.57"
        android:fillColor="#00000000"
        android:strokeColor="#00000000"
        android:strokeLineCap="round"/>
  </group>
</vector>


================================================
FILE: android/app/src/main/res/drawable/launch_background.xml
================================================
<?xml version="1.0" encoding="utf-8"?>
<!-- Modify this file to customize your launch splash screen -->
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@android:color/white" />

    <item>
        <bitmap
            android:gravity="center"
            android:src="@mipmap/launch_image" />
    </item>
</layer-list>


================================================
FILE: android/app/src/main/res/drawable-v21/launch_background.xml
================================================
<?xml version="1.0" encoding="utf-8"?>
<!-- Modify this file to customize your launch splash screen -->
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="?android:colorBackground" />

    <item>
        <bitmap
            android:gravity="center"
            android:src="@mipmap/launch_image" />
    </item>
</layer-list>


================================================
FILE: android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml
================================================
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
    <background android:drawable="@drawable/ic_launcher_background"/>
    <foreground android:drawable="@mipmap/ic_launcher_foreground"/>
    <monochrome android:drawable="@mipmap/ic_launcher_monochrome"/>
</adaptive-icon>

================================================
FILE: android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml
================================================
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
    <background android:drawable="@drawable/ic_launcher_background"/>
    <foreground android:drawable="@mipmap/ic_launcher_foreground"/>
    <monochrome android:drawable="@mipmap/ic_launcher_monochrome"/>
</adaptive-icon>

================================================
FILE: android/app/src/main/res/values/styles.xml
================================================
<?xml version="1.0" encoding="utf-8"?>
<resources>
    <!-- Theme applied to the Android Window while the process is starting when the OS's Dark Mode setting is off -->
    <style name="LaunchTheme" parent="@android:style/Theme.Light.NoTitleBar">
        <!-- Show a splash screen on the activity. Automatically removed when
             the Flutter engine draws its first frame -->
        <item name="android:windowBackground">@drawable/launch_background</item>
    </style>
    <!-- Theme applied to the Android Window as soon as the process has started.
         This theme determines the color of the Android Window while your
         Flutter UI initializes, as well as behind your Flutter UI while its
         running.

         This Theme is only used starting with V2 of Flutter's Android embedding. -->
    <style name="NormalTheme" parent="@android:style/Theme.Light.NoTitleBar">
        <item name="android:windowBackground">?android:colorBackground</item>
    </style>
</resources>


================================================
FILE: android/app/src/main/res/values-night/styles.xml
================================================
<?xml version="1.0" encoding="utf-8"?>
<resources>
    <!-- Theme applied to the Android Window while the process is starting when the OS's Dark Mode setting is on -->
    <style name="LaunchTheme" parent="@android:style/Theme.Black.NoTitleBar">
        <!-- Show a splash screen on the activity. Automatically removed when
             the Flutter engine draws its first frame -->
        <item name="android:windowBackground">@drawable/launch_background</item>
    </style>
    <!-- Theme applied to the Android Window as soon as the process has started.
         This theme determines the color of the Android Window while your
         Flutter UI initializes, as well as behind your Flutter UI while its
         running.

         This Theme is only used starting with V2 of Flutter's Android embedding. -->
    <style name="NormalTheme" parent="@android:style/Theme.Black.NoTitleBar">
        <item name="android:windowBackground">?android:colorBackground</item>
    </style>
</resources>


================================================
FILE: android/app/src/profile/AndroidManifest.xml
================================================
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- The INTERNET permission is required for development. Specifically,
         the Flutter tool needs it to communicate with the running application
         to allow setting breakpoints, to provide hot reload, etc.
    -->
    <uses-permission android:name="android.permission.INTERNET"/>
</manifest>


================================================
FILE: android/build.gradle.kts
================================================
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<Delete>("clean") {
    delete(rootProject.layout.buildDirectory)
}


================================================
FILE: android/gradle/wrapper/gradle-wrapper.properties
================================================
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.14-all.zip


================================================
FILE: android/gradle.properties
================================================
org.gradle.jvmargs=-Xmx8G -XX:MaxMetaspaceSize=4G -XX:ReservedCodeCacheSize=512m -XX:+HeapDumpOnOutOfMemoryError
android.useAndroidX=true


================================================
FILE: android/gradlew
================================================
#!/usr/bin/env bash

##############################################################################
##
##  Gradle start up script for UN*X
##
##############################################################################

# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS=""

APP_NAME="Gradle"
APP_BASE_NAME=`basename "$0"`

# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD="maximum"

warn ( ) {
    echo "$*"
}

die ( ) {
    echo
    echo "$*"
    echo
    exit 1
}

# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
case "`uname`" in
  CYGWIN* )
    cygwin=true
    ;;
  Darwin* )
    darwin=true
    ;;
  MINGW* )
    msys=true
    ;;
esac

# Attempt to set APP_HOME
# Resolve links: $0 may be a link
PRG="$0"
# Need this for relative symlinks.
while [ -h "$PRG" ] ; do
    ls=`ls -ld "$PRG"`
    link=`expr "$ls" : '.*-> \(.*\)$'`
    if expr "$link" : '/.*' > /dev/null; then
        PRG="$link"
    else
        PRG=`dirname "$PRG"`"/$link"
    fi
done
SAVED="`pwd`"
cd "`dirname \"$PRG\"`/" >/dev/null
APP_HOME="`pwd -P`"
cd "$SAVED" >/dev/null

CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar

# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
    if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
        # IBM's JDK on AIX uses strange locations for the executables
        JAVACMD="$JAVA_HOME/jre/sh/java"
    else
        JAVACMD="$JAVA_HOME/bin/java"
    fi
    if [ ! -x "$JAVACMD" ] ; then
        die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME

Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
    fi
else
    JAVACMD="java"
    which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.

Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi

# Increase the maximum file descriptors if we can.
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
    MAX_FD_LIMIT=`ulimit -H -n`
    if [ $? -eq 0 ] ; then
        if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
            MAX_FD="$MAX_FD_LIMIT"
        fi
        ulimit -n $MAX_FD
        if [ $? -ne 0 ] ; then
            warn "Could not set maximum file descriptor limit: $MAX_FD"
        fi
    else
        warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
    fi
fi

# For Darwin, add options to specify how the application appears in the dock
if $darwin; then
    GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
fi

# For Cygwin, switch paths to Windows format before running java
if $cygwin ; then
    APP_HOME=`cygpath --path --mixed "$APP_HOME"`
    CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
    JAVACMD=`cygpath --unix "$JAVACMD"`

    # We build the pattern for arguments to be converted via cygpath
    ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
    SEP=""
    for dir in $ROOTDIRSRAW ; do
        ROOTDIRS="$ROOTDIRS$SEP$dir"
        SEP="|"
    done
    OURCYGPATTERN="(^($ROOTDIRS))"
    # Add a user-defined pattern to the cygpath arguments
    if [ "$GRADLE_CYGPATTERN" != "" ] ; then
        OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
    fi
    # Now convert the arguments - kludge to limit ourselves to /bin/sh
    i=0
    for arg in "$@" ; do
        CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
        CHECK2=`echo "$arg"|egrep -c "^-"`                                 ### Determine if an option

        if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition
            eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
        else
            eval `echo args$i`="\"$arg\""
        fi
        i=$((i+1))
    done
    case $i in
        (0) set -- ;;
        (1) set -- "$args0" ;;
        (2) set -- "$args0" "$args1" ;;
        (3) set -- "$args0" "$args1" "$args2" ;;
        (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
        (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
        (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
        (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
        (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
        (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
    esac
fi

# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
function splitJvmOpts() {
    JVM_OPTS=("$@")
}
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"

exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"


================================================
FILE: android/gradlew.bat
================================================
@if "%DEBUG%" == "" @echo off
@rem ##########################################################################
@rem
@rem  Gradle startup script for Windows
@rem
@rem ##########################################################################

@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal

@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
set DEFAULT_JVM_OPTS=

set DIRNAME=%~dp0
if "%DIRNAME%" == "" set DIRNAME=.
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%

@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome

set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if "%ERRORLEVEL%" == "0" goto init

echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.

goto fail

:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe

if exist "%JAVA_EXE%" goto init

echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.

goto fail

:init
@rem Get command-line arguments, handling Windowz variants

if not "%OS%" == "Windows_NT" goto win9xME_args
if "%@eval[2+2]" == "4" goto 4NT_args

:win9xME_args
@rem Slurp the command line arguments.
set CMD_LINE_ARGS=
set _SKIP=2

:win9xME_args_slurp
if "x%~1" == "x" goto execute

set CMD_LINE_ARGS=%*
goto execute

:4NT_args
@rem Get arguments from the 4NT Shell from JP Software
set CMD_LINE_ARGS=%$

:execute
@rem Setup the command line

set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar

@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%

:end
@rem End local scope for the variables with windows NT shell
if "%ERRORLEVEL%"=="0" goto mainEnd

:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
if  not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
exit /b 1

:mainEnd
if "%OS%"=="Windows_NT" endlocal

:omega


================================================
FILE: android/settings.gradle.kts
================================================
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.11.1" apply false
    id("org.jetbrains.kotlin.android") version "2.2.20" apply false
}

include(":app")


================================================
FILE: assets/fonts/OFL.txt
================================================
Copyright 2010 The Josefin Sans Project Authors (https://github.com/ThomasJockin/JosefinSansFont-master), with Reserved Font Name "Josefin Sans".

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:
https://openfontlicense.org


-----------------------------------------------------------
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.


================================================
FILE: cliff.toml
================================================
[remote.github]
owner = "ferraridamiano"
repo = "ConverterNOW"

[changelog]
header = ""
body = """
{%- macro remote_url() -%}
  https://github.com/{{ remote.github.owner }}/{{ remote.github.repo }}
{%- endmacro -%}
{%- macro github_username(email) -%}
  {%- if email is containing("@users.noreply.github.com") -%}
    {{ email | split(pat="@") | first | split(pat="+") | last }}
  {%- elif email is containing("@") -%}
    {{ email | split(pat="@") | first }}
  {%- else -%}
    {{ email }}
  {%- endif -%}
{%- endmacro -%}
{% for group, commits in commits | group_by(attribute="group") %}
    ### {{ group | upper_first }}
    {% for commit in commits %}
        - {{ commit.message | split(pat="\n") | first | upper_first | trim }} ([`{{ commit.id | truncate(length=7, end="") }}`]({{ self::remote_url() }}/commit/{{ commit.id }}))\
          {% for footer in commit.footers -%}
            , {{ footer.token }}{{ footer.separator }}{{ footer.value }}\
          {% endfor %}\
    {% endfor %}
{% endfor %}

### 👥 Contributors
{% set contributors = commits | unique(attribute="author.email") | sort(attribute="author.email") -%}
{% for contributor in contributors -%}
  - @{{ self::github_username(email=contributor.author.email) }}
{% endfor %}\n
"""

[git]
conventional_commits = true
filter_unconventional = false
commit_parsers = [
    { message = "^feat", group = "🚀 Features" },
    { message = "^fix", group = "🐛 Bug Fixes" },
    { message = "^doc", group = "📝 Documentation" },
    { message = "^perf", group = "⚡ Performance" },
    { message = "^refactor", group = "🧹 Refactor" },
    { message = "^style", group = "🎨 Styling" },
    { message = "^test", group = "🧪 Testing" },
    { message = "^chore\\(deps.*\\)", skip = true },
    { message = "^chore\\(pr\\)", skip = true },
    { message = "^chore\\(pull\\)", skip = true },
    { message = "^chore\\(release\\)", skip = true },
    { message = "^chore|^ci", group = "🧰 Miscellaneous Tasks" },
    { body = ".*security", group = "🔐 Security" },
]
filter_commits = false
topo_order = false
sort_commits = "oldest"


================================================
FILE: fastlane/metadata/android/ar/full_description.txt
================================================
<b>Converter NOW هو محول فعال للوحدات والعُملات </b>
✔️ <b>يقوم بتبسيط</b> عملية التحويل المُملة بين وحدات القياس إلى بِضع نقرات.
🚀<b> سريع وفوري</b>: ما عليك سوى البدء في الكتابة وستحصل على الفور على تحويل في الوقت الفعلي مع جميع وحدات القياس الأخرى.
🖌️<b>قابل للتخصيص</b>: يُمكنك إعادة تنظيم الوحدات وفقًا لأولوياتك واستخدامك الخاصة.
🔢 يأتي مُتكامل مع <b>آلة حاسبة</b> تتيح لك إجراء العمليات الحسابية في كل صفحة.
💰 نحن <b>نقوم بالتحديث بصورة يومية</b>لقيم العملات.
⚫⚪<b>إختر مظهرك المُفضل</b>: بين الوضع فاتح أو المُظلم
 📱<b>دعم كامل</b> للهواتف الذكية و الأجهزة اللوحية.
💯<b>مفتوح المصدر</b> بشكل كامل!

تفقد المستودع على منصة ال Github: https://github.com/ferraridamiano/ConverterNOW

لدينا أيضًا تطبيق ويب! 🖥️ تفقده من خلال هذا الرابط: https://ferraridamiano.github.io/ConverterNOW/

🌍 Converter NOW, بدون إعلانات ، لا يتطلب أي إذن ونحن لا نجمع بياناتك 🌍

<b>Converter NOW يمكن تحويل أكثر من 200 وحدة قياس وأكثر من 30 عملة</b> 🎉🎉

فيما يلي بعض الكميات المادية التي يستطيع Converter Now تحويلها:
-<b>العُمُلات:</b> دولار, يورو, جنيه, روبيه, ين, وما إلى ذلك.
-<b>الطول:</b> الأمتار ، البوصات ، الأميال ، الساحات ، السنوات الضوئية ، وما إلى ذلك.
-<b>المساحة:</b> متر مربع ، هكتار ، فدان ، وما إلى ذلك.
-<b>الكمية:</b> متر مكعب ، لترات ، جالون ، مكاييل ، ملاعق ، وما إلى ذلك.
-<b>الزمن:</b> ثواني ، ساعات ، أيام ، سنوات ، أسابيع ، آلاف السنين ، وما إلى ذلك.
-<b>درجة الحرارة:</b> مئوية ، فهرنهايت ، كيلفن
-<b>السرعة:</b> متر في الثانية ، كيلومترات في الساعة ، عقدة ، وما إلى ذلك.
-<b>الكُتلة:</b> جرامات ، رطل ، طن ، وحدات الكتلة الذرية ، وما إلى ذلك.
-<b>القوة:</b> نيوتن ، داين ، قوة الجنيه ، باوندال ، وما إلى ذلك
-<b>الضغط:</b> باسكال ، بار ، أتومسفير ، رطل ، وما إلى ذلك.
-<b>الطاقة:</b> الجول ، السعرات الحرارية ، كيلو واط ساعة ، وما إلى ذلك.
-<b>القدرة:</b> واط ، كيلووات ، قوة حصان ، وما إلى ذلك.
-<b>إستهلاك الوقود:</b> ميل لكل جالون ، كيلومتر لكل لتر ، وما إلى ذلك.
-<b>الأنظمة العددية:</b> عشري ، ثنائي ، سداسي عشري ، وما إلى ذلك.
-<b>عزم الدوران:</b> نيوتن متر ، قدم قوة الجنيه ، متر باوند ، وما إلى ذلك.
-<b>البيانات الرقمية:</b> نايبل ، بت ، بايت ، كيبيت ، كيبي بايت ، وما إلى ذلك.
-<b>مقياس الحذاء:</b> المملكة المتحدة ، الهند ، أوروبا ، الولايات المتحدة الأمريكية ، اليابان ، وما إلى ذلك.
-<b>الزاوية:</b> الدرجة والراديان والدقائق وما إلى ذلك.
-<b>سوابق SI:</b> كيلو ، ميجا ، جيجا ، تيرا ، ملي ، ميكرو ، نانو ، وما إلى ذلك.

================================================
FILE: fastlane/metadata/android/ar/short_description.txt
================================================
محول وحدات بسيط ،فوري وسريع!

================================================
FILE: fastlane/metadata/android/ar/title.txt
================================================
Converter NOW: مُحول وحدات

================================================
FILE: fastlane/metadata/android/bn/full_description.txt
================================================
<b>কনভার্টার NOW একটি কার্যকরী ইউনিট ও কারেন্সি কনভার্টার </b>
✔️ <b>সহজ</b>  মাত্র কয়েক ক্লিকেই পরিমাপের বিভিন্ন এককে রুপান্তর। 
🚀 এটি <b>দ্রুত ও তাৎক্ষণিক </b>:টাইপ শুরু করার সাথে সাথেই পরিমাপের অন্যান্য এককের রূপান্তর দেখতে পাবেন।
🖌️ এটি <b>কাস্টমাইজযোগ্য</b>: পছন্দ এবং ব্যবহার অনুযায়ী ইউনিটগুলি সাজিয়ে নিতে পারেন।
🔢 বিল্ট ইন<b>ক্যালকুলেটর</b> প্রতিটি পেইজ এ রয়েছে ক্যালকুলেটর ব্যাবহারের সুযোগ।
💰 কারেন্সি এক্সচেঞ্জ রেট <b>প্রতিদিন আপডেট করা হচ্ছে</b>
🎨 <b>ডাইনামিক থীম</b> আপনার ডিভাইস সেটিংস অনুযায়ী নির্বাচিত করা হয়।
⚫⚪ <b>পছন্দের থীম টি ব্যাবহার করুন</b>: ডার্ক এবং লাইট থীম।
📱🖥️ <b>মাল্টিপ্ল্যাটফর্ম</b>: Android, Web, Linux and Windows এ ব্যাবহার করা যাবে।
💯 এটি <b>ফ্রী, বিজ্ঞাপন মুক্ত, ডাটা কালেকশন এবং অনুমতির প্রয়োজন নেই </b> (শুধু মূদ্রার মান আপডেট করার জন্য ইন্টারনেট) এবং সম্পূর্ণ <b>ওপেন সোর্স</b>!
<b>কনভার্টার NOW ২০০ টির বেশি ইউনিট এবং ৩০ টিরও বেশি মূদ্রা রুপান্তর করতে পারে</b> 🎉🎉

যেসব পরিমাপ কনভার্টার NOW রূপান্তর করতে সক্ষমঃ
-<b>মুদ্রা:</b> ডলার, ইউরো, পাউন্ড, রুপি, ইয়েন, ইত্যাদি।
-<b>দৈর্ঘ্য:</b> মিটার, ইঞ্চি, মাইল, গজ, আলোকবর্ষ, ইত্যাদি।
-<b>ক্ষেত্রফল:</b> বর্গ মিটার, হেক্টর, একর, ইত্যাদি।
-<b>আয়তন:</b> ঘন মিটার, লিটার, গ্যালন, পিন্ট, চামচ, ইত্যাদি।
-<b>সময়:</b> সেকেন্ড, ঘণ্টা, দিন, বছর, সপ্তাহ, সহস্রাব্দ, ইত্যাদি।
-<b>তাপমাত্রা:</b> সেলসিয়াস, ফারেনহাইট, কেলভিন।
-<b>গতিবেগ:</b> মিটার প্রতি সেকেন্ড, কিলোমিটার প্রতি ঘণ্টা, নট, ইত্যাদি।
-<b>ভর:</b> গ্রাম, পাউন্ড, টন, পারমাণবিক ভর একক, ইত্যাদি।
-<b>বল:</b> নিউটন, ডাইন, পাউন্ড-ফোর্স, পাউন্ডাল, ইত্যাদি।
-<b>চাপ:</b> প্যাসকেল, বার, বায়ুমণ্ডল, পিএসআই, ইত্যাদি।
-<b>শক্তি:</b> জুল, ক্যালরি, কিলোওয়াট ঘণ্টা, ইত্যাদি।
-<b>ক্ষমতা:</b> ওয়াট, কিলোওয়াট, হর্সপাওয়ার, ইত্যাদি।
-<b>জ্বালানি খরচ:</b> মাইল প্রতি গ্যালন, কিলোমিটার প্রতি লিটার, ইত্যাদি।
-<b>সংখ্যা পদ্ধতি:</b> দশমিক, বাইনারি, হেক্সাডেসিমাল, ইত্যাদি।
-<b>টর্ক:</b> নিউটন মিটার, পাউন্ড-ফোর্স ফুট, পাউন্ডাল মিটার, ইত্যাদি।
-<b>ডিজিটাল ডাটা:</b> নিবল, বিট, বাইট, কিবিবিট, কিবিবাইট, ইত্যাদি।
-<b>জুতার মাপ:</b> ইউকে, ভারত, ইউরোপ, ইউএসএ, জাপান, ইত্যাদি।
-<b>কোণ:</b> ডিগ্রি, রেডিয়ান, মিনিট, ইত্যাদি।
-<b>এসআই উপসর্গ:</b> কিলো, মেগা, গিগা, টেরা, মিলি, মাইক্রো, ন্যানো, ইত্যাদি।

================================================
FILE: fastlane/metadata/android/bn/short_description.txt
================================================
একটি সহজ, তাৎক্ষণিক এবং দ্রুত ইউনিট কনভার্টার

================================================
FILE: fastlane/metadata/android/bn/title.txt
================================================
কনভার্টার NOW: ইউনিট কনভার্ট

================================================
FILE: fastlane/metadata/android/de-DE/full_description.txt
================================================
<b>Converter NOW ist ein leistungsstarker Einheiten- und Währungsumrechner</b>
✔️ <b>Vereinfache</b> den aufwendigen Umrechnungsprozess zwischen den Maßeinheiten mit wenigen Klicks.
🚀 Er ist <b>schnell und unmittelbar</b>: beginne zu tippen und du erhälst prompt die Umrechnung in die anderen Maßeinheiten in Echtzeit.
🖌️ Er ist <b>anpassungsfähig</b>: gestalte die Reihenfolge der Maßeinheiten nach deinen Vorlieben.
🔢 Er besitzt einen eingebauten <b>Taschenrechner</b>, der einfache Berechnungen jederzeit zulässt.
💰 <b>Tägliche Aktualisierung</b> der Währungskurse.
⚫⚪ <b>Wähle dein bevorzugstes Schema</b>: Dunkel, Hell oder Schwarz für AMOLED.
 📱 <b>Vollständige</b> Smartphone- und Tablet-<b>Unterstützung</b>.
💯 Wir sind eine <b>Open-Source-Software</b>!

Schau dir unser Repository auf GitHub an: https://github.com/ferraridamiano/ConverterNOW

Wir haben auch eine Web-App! 🖥️ Schau vorbei: https://ferraridamiano.github.io/ConverterNOW/

🌍 Converter NOW ist frei, ohne Werbung, setzt keinerlei Berechtigungen voraus und wir sammeln keine persönlichen Daten über dich 🌍

<b>Converter NOW kann mehr als 200 Maßeinheiten und 30+ Währungen umwandeln.</b> 🎉🎉

Hier sind einige Beispiele für physikale Größen und Kurse welche Converter NOW beherrscht:
-<b>Währungen:</b> Dollar (USA & Kanada), Euro, Pfund, Rupee, Yen, etc.
-<b>Länge:</b> Meter, Zoll, Meilen, Yards, Lichtjahre, etc.
-<b>Fläche:</b> Quadratmeter, Hektar, Acre, etc.
-<b>Volumen:</b> Kubikmeter, Liter, Gallonen und Pints (US & GB), Teelöfel (US & Australien), etc.
-<b>Zeit:</b> Sekunden, Stunden, Tage, Jahre, Wochen, Jahrtausende, etc.
-<b>Temperatur:</b> Celsius, Fahreneit, Kelvin, etc.
-<b>Geschwindigkeit:</b> Meter pro Sekunde, Kilometer pro Stunde, Knoten, etc.
-<b>Masse:</b> Gramm, Pfund, Tonen, Atomare Masseneinheiten, etc.
-<b>Kraft:</b> Newton, Dyn, Pound-force (Kraftpfund), Poundal, etc
-<b>Druck:</b> Pascal, Bar, Physikalische Atmosphäre (atm), Pfund pro Quadratzoll (PSI), etc.
-<b>Enrgie:</b> Joule, Kalorien, Kilowattstunden (kWh), etc.
-<b>Leistung:</b> Watt, Kilowatt, Pferdestärken (PS), etc.
-<b>Spritverbrauch:</b> Meilen pro Gallone (US und UK), Kilometer pro Liter, etc.
-<b>Zahlensysteme:</b> Dezimal, Binär, Hexadezimal, etc.
-<b>Drehmoment:</b> Newtonmeter, Kilopondmeter, Poundalmeter, etc.
-<b>Digitale Daten:</b> Nibble, Bit, Byte, Kibibit, Kibibyte, etc.
-<b>Schuhgröße:</b> UK, Indien, Europa, USA, Japan, etc.
-<b>Winkel:</b> Grad, Radiant, Minuten, etc.
-<b>SI Präfix:</b> Kilo, Mega, Giga, Tera, Milli, Mikro, Nano, etc.


================================================
FILE: fastlane/metadata/android/de-DE/short_description.txt
================================================
Einfache, unmittelbare und schnelle Umrechnung von Einheiten!

================================================
FILE: fastlane/metadata/android/de-DE/title.txt
================================================
Einheitenumwandler

================================================
FILE: fastlane/metadata/android/el/full_description.txt
================================================
<b>Converter NOW είναι ένα αποτελεσματικό εργαλείο για μετατροπή μονάδων και νομισμάτων </b>
✔️ <b>Απλοποιεί</b> την κουραστική διαδικασία μετατροπής μεταξύ μονάδων μέτρησης με λίγα κλικ.
🚀 Είναι <b>γρήγορο και άμεσο</b>: απλώς αρχίστε να πληκτρολογείτε και έχετε αμέσως τη μετατροπή σε πραγματικό χρόνο με όλες τις άλλες μονάδες μέτρησης.
🖌️ Είναι <b>προσαρμόσιμο</b>: οι μονάδες μπορούν να οργανωθούν σύμφωνα με τις προτεραιότητες και τις ανάγκες σας.
🔢 Ενσωματώνει <b>υπολογιστή</b> που σας επιτρέπει να κάνετε υπολογισμούς σε κάθε σελίδα.
💰 Ισοτιμίες νομισμάτων <b>ενημερώνονται καθημερινά</b>
🎨 <b>Δυναμικό θέμα</b> βασισμένο στις ρυθμίσεις της συσκευής σας
⚫⚪ <b>Επιλέξτε το αγαπημένο σας θέμα</b>: σκοτεινό ή φωτεινό
📱🖥️ <b>Πολλαπλές πλατφόρμες</b>: διαθέσιμο για Android, Web, Linux και Windows
💯 Είναι <b>δωρεάν, χωρίς διαφημίσεις, χωρίς συλλογή δεδομένων, χωρίς απαιτήσεις δικαιωμάτων</b> (μόνο Ίντερνετ για ενημέρωση των ισοτιμιών) και κυρίως είναι <b>ανοιχτού κώδικα</b>!

<b>Το Converter NOW μπορεί να μετατρέψει 200+ μονάδες μέτρησης και 30+ νομίσματα</b> 🎉🎉

Ακολουθούν ορισμένες από τις φυσικές ποσότητες που μπορεί να μετατρέψει το Converter NOW:
-<b>Νομίσματα:</b> Δολάρια, Ευρώ, Λίρα, Ρουπία, Γιεν, κ.λπ.
-<b>Μήκος:</b> μέτρα, ίντσες, μίλια, γιάρδες, έτη φωτός, κ.λπ.
-<b>Επιφάνεια:</b> square meters, hectares, acres, etc.
-<b>Volume:</b> τετραγωνικά μέτρα, εκτάρια, στρέμματα, κ.λπ.
-<b>Χρόνος:</b> δευτερόλεπτα, ώρες, ημέρες, έτη, εβδομάδες, χιλιετίες, κ.λπ.
-<b>Θερμοκρασία:</b> Κελσίου, Φαρενάιτ, Κέλβιν
-<b>Ταχύτητα:</b> μέτρα ανά δευτερόλεπτο, χιλιόμετρα ανά ώρα, κόμβοι, κ.λπ.
-<b>Μάζα:</b> γραμμάρια, λίβρες, τόνοι, ατομικές μάζες, κ.λπ.
-<b>Δύναμη:</b> Νιούτον, dyne, pound-force, Πουντάλ, κ.λπ.
-<b>Πίεση:</b> Πασκάλ, μπαρ, ατμόσφαιρα, psi, κ.λπ.
-<b>Ενέργεια:</b> Τζάουλ, θερμίδες, κιλοβατώρες, κ.λπ.
-<b>Ισχύς:</b> Βατ, κιλοβατ, ίπποι, κ.λπ.
-<b>Κατανάλωση καυσίμου:</b> Μίλια ανά γαλόνι, Χιλιόμετρα ανά λίτρο, κ.λπ.
-<b>Συστήματα αριθμών:</b> δεκαδικό, δυαδικό, εξαδικό, κ.λπ.
-<b>Ροπή:</b> Νιούτον μέτρο, λίβρα-δύναμη πόδι, πουντάλ μέτρο, κ.λπ.
-<b>Ψηφιακά δεδομένα:</b> Νίμπλ, μπίτ, μπάιτ, κιλομπάιτ, etc.
-<b>Μέγεθος παπουτσιών:</b> Ηνωμένο Βασίλειο, Ινδία, Ευρώπη, ΗΠΑ, Ιαπωνία, κ.λπ.
-<b>Γωνίες:</b> μοίρες, ακτίνια, λεπτά, κ.λπ.
-<b>SI προθέματα:</b> κιλό, μέγα, γίγα, τέρα, μίλι, μικρο, νάνο, κ.λπ.


================================================
FILE: fastlane/metadata/android/el/short_description.txt
================================================
Ένας απλός, άμεσος και γρήγορος μετατροπέας μονάδων!


================================================
FILE: fastlane/metadata/android/el/title.txt
================================================
Μετατροπέας Μονάδων

================================================
FILE: fastlane/metadata/android/en-US/changelogs/24.txt
================================================
★ 3 new languages: Portoguese, French and Norwegian 🌐
★ Bugfix of some translation and shoe size conversion 🔧

Thanks to @mezysinc, @Torok42, @FTno, @dizietsma and Andreas 🔝

We also have a web app, check it out here: https://ferraridamiano.github.io/ConverterNOW/#/

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/25.txt
================================================
★ Bugfix of numerical systems conversion 🔧

We also have a web app, check it out here: https://ferraridamiano.github.io/ConverterNOW/#/

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/26.txt
================================================
★ You can now set dark theme on old devices
★ Dark theme get darker with AMOLED mode ⚫
★ Added some units such as: pennyweights, troy ounces, stones, fluid ounces, gill, etc.
★ Added german and russian
★ Bug fix

Thanks to Gena Haltmair and Vadim Young for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/27.txt
================================================
★ Default language fix
★ You can now set dark theme on old devices
★ Dark theme get darker with AMOLED mode ⚫
★ Added some units such as: pennyweights, troy ounces, stones, fluid ounces, gill, etc.
★ Added german and russian
★ Bug fix

Thanks to Gena Haltmair and Vadim Young for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/28.txt
================================================
★ Improved tablet support
★ Added some new units
★ Calculator improvements
★ Bugfix exchange rate update
★ Added Spanish

Thanks to Gena Haltmair and n-berenice for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/29.txt
================================================
★ Huge UI improvement for large screens
★ Support for adaptive icon
★ Added some new units
★ Added a splash screen
★ Change app language from settings
★ Added Croatian
★ Bugfix

Thanks to Giovanni Spitti and @milotype for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/30.txt
================================================
★ Fix the icon bug with Android version below 8.0
★ Huge UI improvement for large screens
★ Support for adaptive icon
★ Added some new units
★ Added a splash screen
★ Change app language from settings
★ Added Croatian
★ Bugfix

Thanks to Giovanni Spitti and @milotype for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/31.txt
================================================
★ Improved the accessibility of the app
★ Added an option to undo a "Clear all" operation
★ Added indonesian and japanese
★ Added more units of measurement
★ Performance improvements
★ Bugfix

Thanks to @the7thNightmare and 匿名 for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/33.txt
================================================
★ Added app shortcut
★ Small graphical tweaks
★ Bugfix

Thanks to @the7thNightmare and 匿名 for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/34.txt
================================================
★ Now the app is available in arabic
★ Small tweaks
★ Bugfix

Thanks to Omer Maki for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/35.txt
================================================
★ Improved the calculator
★ Bugfix

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/36.txt
================================================
★ Migration to Material You
★ Themed icons on Android 13+
★ Added Polish translation
★ Bugfixes

Thanks to @rehork for your contributions!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/37.txt
================================================
★ Unit symbols are now always visible

Thanks to @rehork for your suggestion!

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/38.txt
================================================
Introducing Converter NOW 4.0!
- Finished the migration to Material You
- Dynamic theming support on Android 12+
- New icons
- Translations updates
- Bug fixes and general improvements

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/39.txt
================================================
- Fixed bug with currencies page after v4 update
- Improved polish translations

What do you think about Converter NOW? Rate us! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/40.txt
================================================
- Material you improvements
- The calculator has a new look
- Added dutch, chinese and traditional chinese translations
- Improvements to other translations
- Icons tweaks
- General improvements

Thanks to @David-git-code, @syu-pf-ssy, @plum7x, @HarshMakwana27 for your contributions!

What do you think about Converter NOW? Rate the app! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/41.txt
================================================
- UI improvements
- Improved french translation (credits: @Vsnmrn)
- General improvements
- Bugfix

What do you think about Converter NOW? Rate the app! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/42.txt
================================================
- You can now block the internet access to the app
- Improved the license page
- Added haptic feedback
- Improved the russian translation (@Atrafon)
- Added catalan translation (@pereorga)
- Bugfix and general improvements

What do you think about Converter NOW? Rate the app! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/43.txt
================================================
🎨 <b>Custom Themes!</b> Give your app a unique touch by choosing your favorite theme.
⚙️ <b>Optimized Settings Page!</b> Now even simpler and more intuitive to use.
✨ <b>Graphic Enhancements!</b> Small improvements that make the app even more beautiful and enjoyable to use.
🌍 <b>Improved Translations!</b> Thanks to @rehork and @pereorga, the Polish and Catalan versions are more accurate than ever.
🐞 <b>Bug Fixes and General Improvements!</b> We've worked hard to provide you with an even better experience.

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/44.txt
================================================
🎨 <b>Graphic Enhancements</b> for big screens
🌍 <b>Updated translations</b> Thanks to @rehork, @MajoranaOedipus, @FTno
🐞 <b>Bug Fixes and General Improvements!</b> We've worked hard to provide you with an even better experience

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/45.txt
================================================
⚙️ <b>New features</b>: use comma as decimal separator, paste number into the calculator, search with ctrl+K, Android 15 support and predictive back gesture
🌍 <b>Updated translations</b> Thanks to @solokot, @makishart, @HectorAE
🐞 <b>Bug Fixes and General Improvements!</b> We've worked hard to provide you with an even better experience

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/46.txt
================================================
⚙️ <b>New features</b>: hide unused units, improved default unit sorting, more units, improved conversion speed
🌍 <b>Updated translations</b> Thanks to @albanobattistella, @plum7x, @solokot
🐞 <b>Bug Fixes and General Improvements!</b> We've worked hard to provide you with an even better experience

This version may break your unit sorting. We've made improvements so that this will no longer happen. We apologize for the inconvenience.

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/47.txt
================================================
🐞 <b>Bug Fixes and General Improvements!</b> We've worked hard to provide you with an even better experience

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/48.txt
================================================
⚙️ <b>New units of measure</b>: added density and new pressure units (Thanks to @Kheirlb)
🌍 <b>Translation improvements</b>: added Bengali and updated existing translations. Thanks to @aazmii, @rehork, @solokot
🐞 <b>Bug fixes and general improvements!</b> We've worked hard to give you an ever-better experience

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️


================================================
FILE: fastlane/metadata/android/en-US/changelogs/49.txt
================================================
🐞 Fixed a bug related to the "Hide units" feature.

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️


================================================
FILE: fastlane/metadata/android/en-US/changelogs/50.txt
================================================
🎨 <b>New logo!</b> Thanks to Giovanni Spitti for the suggestions
🖌️ <b>Improved icons in the app</b>
🌍 <b>Translation improvements</b>: thanks to @solokot
🐞 <b>Bug fixes and general improvements!</b> We've worked hard to give you an ever-better experience

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/51.txt
================================================
🔢 View the <b>result preview</b> in the calculator (Thanks to Bisher Asil)
⚙️ <b>Choose the property</b> to convert on startup (mobile only)
🌍 <b>Translation improvements</b>
🐞 <b>Bug fixes and general improvements!</b> We've worked hard to give you an even better experience

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/changelogs/52.txt
================================================
📤 <b>Import / export / delete</b> the app settings
🔢 <b>Added several units of measurement</b>
🌍 <b>Translation improvements</b>. Thanks to @rehork, @solokot, @milotype, @FTno
🐞 <b>Bug fixes and general improvements!</b> We've worked hard to give you an even better experience

<b>Do you like Converter NOW?</b> Leave a review and let us know what you think! ✔️

================================================
FILE: fastlane/metadata/android/en-US/full_description.txt
================================================
<b>Converter NOW is an effective unit and currencies converter </b>
✔️ <b>Simplify</b> the tedious conversion process between units of measurement in a few clicks.
🚀 It is <b>fast and immediate</b>: just start typing and immediately you have the real-time conversion  with all the other units of measurement.
🖌️ It is <b>customizable</b>: the units can be reorganized according to your priorities and your use.
🔢 It integrates a <b>calculator</b> that let you do the calculations in every page.
💰 Currency exchange rates <b>updated daily</b>
🎨 <b>Dynamic theming</b> based on your device settings
⚫⚪ <b>Choose your favorite theme</b>: dark and white theme
📱🖥️ <b>Multiplatform</b>: available for Android, Web, Linux and Windows
💯 It is <b>free, no ads, no data collection, no permissions</b> (just Internet to update currency conversions) and first of all it is <b>open source</b>!

<b>Converter NOW can convert 200+ units of measurement and 30+ currencies</b> 🎉🎉

Here are some of the physical quantity that Converter NOW is able to convert:
-<b>Currencies:</b> Dollars, Euro, Pound, Rupee, Yen, etc
-<b>Length:</b> meters, inches, miles, yards, light years, etc.
-<b>Area:</b> square meters, hectares, acres, etc.
-<b>Volume:</b> cubic meters, liters, gallons, pints, spoons, etc.
-<b>Time:</b> seconds, hours, days, years, weeks, millennia, etc.
-<b>Temperature:</b> Centigrade, Fahrenheit, Kelvin
-<b>Speed:</b> meters per second, kilometers per hour, knots, etc.
-<b>Mass:</b> grams, pounds, tons, atomic mass units, etc.
-<b>Force:</b> Newton, dyne, pound-force, poundal, etc
-<b>Pressure:</b> pascal, bar, atmosphere, psi, etc.
-<b>Energy:</b> Joule, calories, kilowatt hours, etc.
-<b>Power:</b> Watt, kilowatt, horsepower, etc.
-<b>Density:</b>: grams per cubic meter, etc.</li>
-<b>Fuel consumption:</b> Miles per Gallon, Kilometers per liter, etc.
-<b>Numeral systems:</b> decimal, binary, hexadecimal etc.
-<b>Torque:</b> Newton meter, pound-force foot, poundal meter, etc.
-<b>Digital data:</b> Nibble, bit, byte, kibibit, kibibyte, etc.
-<b>Shoes size:</b> UK, India, Europe, USA, Japan, etc.
-<b>Angles:</b> degree, radians, minutes, etc.
-<b>SI prefix:</b> kilo, mega, giga, tera, milli, micro, nano, etc.

================================================
FILE: fastlane/metadata/android/en-US/short_description.txt
================================================
A simple, immediate and fast unit converter!

================================================
FILE: fastlane/metadata/android/en-US/title.txt
================================================
Converter NOW: Unit Converter

================================================
FILE: fastlane/metadata/android/es-ES/changelogs/33.txt
================================================
★ Añadido atajo para aplicación
★ Pequeñas mejoras gráficas
★ Corrección de errores

¡Gracias a @the7thNightmare y 匿名 por sus contribuciones!

¿Qué piensa sobre Converter NOW? ¡Califíquenos! ✔️

================================================
FILE: fastlane/metadata/android/es-ES/full_description.txt
================================================
<b>Converter NOW es un efectivo conversor de unidades y divisas </b>
<b>Simplifique</b> el tedioso proceso de conversión entre unidades de medida con unos pocos clics.
🚀 Es <b>rápido e inmediato</b>: simplemente comience a tipear e inmediatamente tendrá una conversión en tiempo real con todas las unidades de medida.
🖌️ Es <b>personalizable</b>: puede reorganizar las unidades de acuerdo a sus prioridades y uso.
🔢 Contiene una <b>calculadora integrada</b> que le permite realizar operaciones en todas las páginas.
💰 El valor de las divisas es <b>actualizado diariamente</b>
⚫⚪ <b>Escoja su tema favorito</b>: oscuro o claro.
 📱 <b>Compatibilidad completa</b> con teléfonos y tabletas.
💯 Es de <b>código abierto</b>

Revise el repositorio en GitHub: https://github.com/ferraridamiano/ConverterNOW

¡También tenemos sitio web! 🖥️ Visite: https://ferraridamiano.github.io/ConverterNOW/

🌍 Converter NOW es gratuito, sin publicidad, no requiere de ningún permiso y no recopila sus datos 🌍

<b>Converter NOW puede convertir entre más de 200 unidades de medida y 30 divisas</b>🎉🎉

Aquí hay algunas de las unidades que Converter NOW puede convertir:
-<b>Divisas:</b> Dólar, Euro, Libra, Rupia, Yen, etc.
-<b>Longitud:</b> Metros, pulgadas, millas, yardas, años luz, etc.
-<b>Área:</b> Metros cuadrasdos, hectáreas, acres, etc.
-<b>Volumen:</b> Metros cúbicos, litros, galones, pintas, cucharadas, etc.
-<b>Tiempo:</b> Segundos, horas, días, semanas, años, milenios, etc.
-<b>Temperatura:</b> Centígrado, Fahrenheit, Kelvin, y más.
-<b>Velocidad:</b> Metros por segundo, kilómetros por hora, nudos, etc.
-<b>Masa:</b> Gramos, libras, toneladas, unidades de masa atómica, etc.
-<b>Fuerza:</b> Newton, dina, libra, poundal, etc.
-<b>Presión:</b> Pascal, bar, atmósferas, psi, etc.
-<b>Energía:</b> Julios, calorías, kilovatios-hora, etc.
-<b>Potencia:</b> Vatios, kilovatios, caballos de potencia, etc.
-<b>Consumo de combustible:</b> Millas por galón, kilómetros por litro, etc.
-<b>Sistemas de numeración:</b> Decimal, binario, hexadecimal, etc.
-<b>Torsión mecánica:</b> Newton-metro, pie-libra fuerza, poundal-metro, etc.
-<b>Sistema digital:</b> Nibble, bit, byte, kibibit, kibibyte, etc.
-<b>Ángulos:</b> grados, minutos, radianes, etc.
-<b>Prefijos del SI:</b> kilo, mega, giga, tera, mili, micro, nano, etc.


================================================
FILE: fastlane/metadata/android/es-ES/short_description.txt
================================================
¡Un conversor simple, inmediato y rápido!


================================================
FILE: fastlane/metadata/android/es-ES/title.txt
================================================
Conversor de unidades


================================================
FILE: fastlane/metadata/android/fr-FR/full_description.txt
================================================
<b> Converter NOW est un convertisseur efficace d'unités et de devises </b>
✔️ <b> Simplifiez </b> le fastidieux processus de conversion entre unités de mesure en quelques clics.
🚀 C'est <b> rapide et immédiat </b>: il suffit de commencer à taper et immédiatement vous avez la conversion en temps réel avec toutes les autres unités de mesure.
🖌️ Il est <b> personnalisable </b>: les unités peuvent être réorganisées en fonction de vos priorités et de votre utilisation.
🔢 Il intègre une <b> calculatrice </b> qui vous permet de faire les calculs dans chaque page.
💰 Les taux de change des devises sont <b> mis à jour quotidiennement </b>
🎨 <b> Thème dynamique </b> basé sur les paramètres de votre appareil
⚫⚪ <b> Choisissez votre thème préféré </b>: thème sombre et blanc
📱🖥️ <b> Multiplateforme </b>: disponible pour Android, Web, Linux et Windows
💯 C'est <b>libre, sans publicités, sans collecte de données, sans autorisations</b> (seulement l'accès à Internet pour mettre à jour la valeur des devises) et surtout c'est <b>open-source</b> !

<b> Converter NOW peut convertir plus de 200 unités de mesure et plus de 30 devises </b> 🎉🎉

Voici quelques-unes des quantités physiques que Converter NOW est capable de convertir:
- <b> Devises: </b> Dollars, Euro, Livre, Roupie, Yen, etc.
- <b> Longueur: </b> mètres, pouces, miles, yards, années-lumière, etc.
- <b> Superficie: </b> mètres carrés, hectares, acres, etc.
- <b> Volume: </b> mètres cubes, litres, gallons, pintes, cuillères, etc.
- <b> Heure: </b> secondes, heures, jours, années, semaines, millénaires, etc.
- <b> Température: </b> Centigrade, Fahrenheit, Kelvin
- <b> Vitesse: </b> mètres par seconde, kilomètres par heure, nœuds, etc.
- <b> Masse: </b> grammes, livres, tonnes, unités de masse atomique, etc.
- <b> Force: </b> Newton, dyne, livre-force, poundal, etc.
- <b> Pression: </b> pascal, bar, atmosphère, psi, etc.
- <b> Énergie: </b> Joule, calories, kilowattheures, etc.
- <b> Puissance: </b> Watt, kilowatt, puissance, etc.
- <b> Consommation de carburant: </b> Miles par gallon, kilomètres par litre, etc.
- <b> Systèmes numériques: </b> décimal, binaire, hexadécimal etc.
- <b> Couple: </b> Newton mètre, pied livre-force, Poundal mètre, etc.
- <b> Données numériques: </b> Nibble, bit, octet, kibibit, kibioctet, etc.
- <b> Pointure des chaussures: </b> Royaume-Uni, Inde, Europe, USA, Japon, etc.
- <b> Angles: </b> degrés, radians, minutes, etc.
- <b> Préfixe SI: </b> kilo, méga, giga, téra, milli, micro, nano, etc.


================================================
FILE: fastlane/metadata/android/fr-FR/short_description.txt
================================================
Un convertisseur simple, immédiat et rapide!

================================================
FILE: fastlane/metadata/android/fr-FR/title.txt
================================================
Converter NOW : Convertisseur d'unités

================================================
FILE: fastlane/metadata/android/hr/full_description.txt
================================================
<b>Converter NOW je učinkovit konverter mjernih jedinica i valuta</b>
✔️ <b>Pojednostavlja</b> dosadan postupak izračunavanja mjernih jedinica kroz više koraka.
🚀 <b>Računa<b> brzo i trenutno</b>: Jednostavno upiši vrijednost za željenu mjernu jedinicu. Sve ostale jedinice se izračunavaju trenutno.
🖌️ <b>Prilagodljiv prikaz</b>: redoslijed jedinica može se promijeniti prema vlastitim potrebama.
🔢 Integrira <b>kalkulator</b> koji omogućuje računanje na svakoj stranici.
💰 <b>Dnevno aktualiziranje</b> vrijednosti valuta.
🎨 <b>Dinamičke teme</b> na osnovi postavki tvog uređaja
⚫⚪ <b>Odaberi svoju omiljenu temu</b>: tamna i svijetla tema
📱🖥️  <b>Višeplatformski</b>: dostupno za Android, web, Linux i Windows
💯 Besplatan je, bez oglasa, bez prikupljanja podataka, bez dozvola (osim internetske veze za aktualiziranje tečaja valuta), a prije svega je otvorenog koda!

<b>Converter NOW pretvara više od 200 mjernih jedinica i više od 30 valuta</b> 🎉🎉

Fizikalne veličine koje Converter NOW pretvara su:
-<b>Valute:</b> dolar, euro, funta, rupija, jen itd
-<b>Duljina:</b> metar, inč, milja, jard, svjetlosna godina itd.
-<b>Površina:</b> kvadratni metar, hektar, aker itd.
-<b>Volumen:</b> kubični metar, litra, galon, pinta, žlica itd.
-<b>Vrijeme:</b> sekunda, sat, dan, godina, tjedan, tisućljeće itd.
-<b>Temperatura:</b> Celzij, Fahreneit, Kelvin
-<b>Brzina:</b> metara u sekundi, kilometara na sat, čvorovi itd.
-<b>Masa:</b> gram, funta, tona, jedinica atomske mase itd.
-<b>Sila:</b> Newton, din, funta-sila, poundal itd.
-<b>Pritisak:</b> paskal, bar, atomfera, psi itd.
-<b>Energija:</b> džul, kalorija, kilovat-sat itd.
-<b>Snaga:</b> vat, kilovat, konjska snaga itd.
-<b>Gustoća:</b> gram po kubičnom metru, itd.</li>
-<b>Potrošnja goriva:</b> milja na galon, kilometara na litru itd.
-<b>Numerički sustavi:</b> decimalni, binarni, heksadecimalni itd.
-<b>Zakretni moment:</b> njutn metar, funta-sila stopa, poundal metar itd.
-<b>Digitalni podaci:</b> nibble, bit, bajt, kibibit, kibibajt itd.
-<b>Veličina obuće:</b> UK, Indija, Europa, SAD, Japan itd.
-<b>Kutovi:</b> stupanj, radijan, minute itd.
-<b>SI prefiksi:</b> kilo, mega, giga, tera, milli, mikro, nano itd.


================================================
FILE: fastlane/metadata/android/hr/short_description.txt
================================================
Konverter mjernih jedinica


================================================
FILE: fastlane/metadata/android/hr/title.txt
================================================
Konverter mjernih jedinica


================================================
FILE: fastlane/metadata/android/id/full_description.txt
================================================
<b>Converter NOW merupakan alat konversi satuan dan kurs yang efektif </b>
✔️ <b>Persingkat</b> proses konversi yang berbelit antara satuan pengukuran dalam beberapa sentuhan.
🚀 <b>Cepat dan segera</b>: tinggal ketik dan Anda mendapatkan alat konversi waktu nyata dengan satuan pengukuran lainnya.
🖌️ Sangat bisa <b>ditata ulang</b>: satuannya bisa ditata tergantung penggunaan Anda.
🔢 Terdapat <b>kalkulator</b> yang terintegrasi yang bisa membuat Anda melakukan penghitungan.
💰 Kami <b>memperbarui setiap hari</b> valuasi kursnya.
⚫⚪ <b>Pilih tema favorit Anda</b>: tema gelap atau terang.
 📱 <b>Dukungan penuh untuk</b> ponsel pintar and tablet.
💯 <b>Sumber terbuka</b>!

Periksa repositorinya di GitHub: https://github.com/ferraridamiano/ConverterNOW

Kami juga memiliki Aplikasi Web! 🖥️ Cek disini: https://ferraridamiano.github.io/ConverterNOW/

🌍 Converter NOW gratis/bebas, tanpa iklan, dan tidak mengumpulkan data apapun 🌍

<b>Converter NOW bisa mengonversi 200+ satuan pengukuran dan 30+ kurs</b> 🎉🎉

Ini adalah beberapa satuan yang bisa Converter NOW konversikan:
-<b>Kurs:</b> Dolar, Euro, Pound, Rupee, Yen, dll.
-<b>Panjang:</b> meter, inci, mil, yard, tahun cahaya, dll.
-<b>Luas:</b> meter persegi, hektar, ekar, dll.
-<b>Volume:</b> meter kubik, liter, galon, pint, sendok, dll.
-<b>Waktu:</b> detik, jam, hari, tahun, pekan, milenium, dll.
-<b>Temperatur:</b> Centigrade, Fahreneit, Kelvin.
-<b>Kecepatan:</b> meter per detik, kilometers per jam, knot, dll.
-<b>Massa:</b> gram, pon, ton, satuan massa atom terpadu, dll.
-<b>Gaya:</b> Newton, dyne, Pon-Gaya, pondal, dll.
-<b>Tekanan:</b> Pascal, bar, atmosfer, psi, dll.
-<b>Eneri:</b> Joule, kalori, kilowattjam, dll.
-<b>Daya:</b> Watt, kilowatt, horse power, dll.
-<b>Konsumsi Bahan Bakar:</b> mil per galon, kilometer per liter, dll.
-<b>Sistem Numeral:</b> desimal, biner, heksadesimal dll.
-<b>Torsi:</b> Newton meter, pon-gaya kaki, pondal meter, dll.
-<b>Data Digital:</b> Nibel, bit, bita, kibibit, kibibita, dll.
-<b>Ukuran Sepatu:</b> Britania, India, Eropa, AS, Jepang, dll.
-<b>Sudut:</b> derajat, radian, menit, dll.
-<b>Awalan SI:</b> kilo, mega, giga, tera, mili, mikro, nano, dll.

================================================
FILE: fastlane/metadata/android/id/short_description.txt
================================================
Sebuah alat konversi yang simpel, segera, dan cepat!

================================================
FILE: fastlane/metadata/android/id/title.txt
================================================
Alat Konversi Satuan dan Kurs

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/24.txt
================================================
★ 3 nuove lingue: Portoghese, Francese e Norvegese 🌐
★ Fix di traduzioni e della conversione della misura delle scarpe 🔧

Grazie a @mezysinc, @Torok42, @FTno, @dizietsma and Andreas 🔝

Abbiamo anche una web app, guarda qui: https://ferraridamiano.github.io/ConverterNOW/#/

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/25.txt
================================================
★ Fix della conversione delle basi numeriche 🔧

Abbiamo anche una web app, guarda qui: https://ferraridamiano.github.io/ConverterNOW/#/

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/26.txt
================================================
★ Aggiunta la possibilità di impostare il tema scuro anche nei dispositivi più datati
★ Il tema scuro si fa ancora più scuro con la modalità AMOLED ⚫
★ Aggiunte alcune unità come: pennyweight, once troy, pietre, once fluide, gill, ecc.
★ Aggiunto il tedesco e il russo
★ Sistemati alcuni bug grafici

Grazie a Gena Haltmair e a Vadim Young per i vostri contributi!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/27.txt
================================================
★ Fix lingua predefinita
★ Aggiunta la possibilità di impostare il tema scuro anche nei dispositivi più datati
★ Il tema scuro si fa ancora più scuro con la modalità AMOLED ⚫
★ Aggiunte alcune unità come: pennyweight, once troy, pietre, once fluide, gill, ecc.
★ Aggiunto il tedesco e il russo
★ Sistemati alcuni bug grafici

Grazie a Gena Haltmair e a Vadim Young per i vostri contributi!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/28.txt
================================================
★ Supporto tablet migliorato
★ Aggiunte alcune nuove unità
★ Miglioramenti alla calcolatrice
★ Bugfix aggiornamento del tasso di cambio
★ Aggiunto lo spagnolo

Grazie a Gena Haltmair e n-berenice per i vostri contributi!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/29.txt
================================================
★ Migliorato il supporto per i grandi schermi
★ Supporto per l'icona adattiva
★ Aggiunte alcune unità di misura
★ Ora puoi cambiare la lingua dell'app dalle impostazioni
★ Aggiunta la splash screen
★ Aggiunto il croato
★ Bugfix

Grazie a Giovanni Spitti e @milotype per i vostri contributi!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/30.txt
================================================
★ Fix bug icona con versione Android inferiore alla 8.0
★ Migliorato il supporto per i grandi schermi
★ Supporto per l'icona adattiva
★ Aggiunte alcune unità di misura
★ Ora puoi cambiare la lingua dell'app dalle impostazioni
★ Aggiunta la splash screen
★ Aggiunto il croato
★ Bugfix

Grazie a Giovanni Spitti e @milotype per i vostri contributi!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/31.txt
================================================
★ Migliorata l'accessibilità dell'app
★ Aggiunta la possibilità di annullare l'operazione "Cancella tutto"
★ Aggiunto il giapponese e l'indonesiano
★ Aggiunte altre unità di misura
★ Migliorate le performance
★ Bugfix

Grazie a @the7thNightmare e 匿名 per i vostri contributi!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/33.txt
================================================
★ Aggiunte le app shortcut
★ Piccoli miglioramenti grafici
★ Bugfix

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/34.txt
================================================
★ Ora l'app è disponibile in lingua araba
★ Piccoli ritocchi
★ Bugfix

Grazie a Omer Maki per il suo contributo!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/35.txt
================================================
★ Calcolatrice migliorata
★ Bugfix

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/36.txt
================================================
★ Migrazione a Material you
★ Themed icons su Android 13+
★ Aggiunta traduzione in Polacco
★ Bugfixes

Grazie a @rehork per il tuo contributo!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/37.txt
================================================
★ I simboli delle unità sono ora sempre visibili

Grazie a @rehork per il tuo suggerimento!

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/38.txt
================================================
Ecco Converter NOW 4.0!
- Terminata la migrazione al Material You
- Supporto al tema dinamico su Android 12+
- Nuove icone
- Aggiornamenti alle traduzioni
- Bug fix e miglioramenti generali

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/39.txt
================================================
- Fixed bug with currencies page after v4 update
- Improved polish translations

Cosa ne pensi di Converter NOW? Recensiscici! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/40.txt
================================================
- Miglioramenti legati al material you
- La calcolatrice ha un nuovo look
- Aggiunte le seguenti traduzioni: olandese, cinese e cinese tradizionale
- Miglioramenti alle altre traduzioni
- Miglioramenti alle icone
- Miglioramenti generali

Grazie a @David-git-code, @syu-pf-ssy, @plum7x, @HarshMakwana27 per i vostri contributi!

Cosa ne pensi di Converter NOW? Se ti va, recensisci l'app! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/41.txt
================================================
- Piccoli miglioramenti all'interfaccia utente
- Migliorata la traduzione francese (crediti: @Vsnmrn)
- Miglioramenti generali
- Bugfix

Cosa ne pensi di Converter NOW? Se ti va, recensisci l'app! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/42.txt
================================================
- Aggiunta la possibilità di bloccare l'accesso ad internet
- Migliorata la pagina delle licenze
- Aggiunto il feedback della vibrazione
- Migliorata la traduzione in russo (@Atrafon)
- Aggiunta la traduzione in catalano (@pereorga)
- Bugfix e miglioramenti generali

Cosa ne pensi di Converter NOW? Se ti va, recensisci l'app! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/43.txt
================================================
🎨 <b>Temi personalizzati!</b> Dai un tocco unico all'app scegliendo il tema che più ti piace.
⚙️ <b>Pagina delle impostazioni ottimizzata!</b> Ora è ancora più semplice e intuitiva da usare.
✨ </b>Ritocchi grafici!</b> Piccoli miglioramenti che rendono l'app ancora più bella e piacevole da utilizzare.
🌍 <b>Traduzioni migliorate!</b> Grazie a @rehork e @pereorga, le versioni in Polacco e Catalano sono più accurate che mai.
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore.

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/44.txt
================================================
🎨 <b>Ritocchi grafici</b> per i grandi schermi
🌍 <b>Traduzioni aggiornate</b> Grazie a @rehork, @MajoranaOedipus, @FTno
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/45.txt
================================================
⚙️ <b>Nuove funzioni</b>: usa la virgola come separatore decimale, incolla i numeri nella calcolatrice, cerca con ctrl+K, supporto ad android 15 e predictive back gesture
🌍 <b>Traduzioni aggiornate</b> Grazie a @solokot, @makishart, @HectorAE
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/46.txt
================================================
⚙️ <b>Nuove funzioni</b>: nascondi le unità di misura che non usi, ordinamento delle unità di default migliorato, più unità di misura, velocità di conversione migliorata
🌍 <b>Traduzioni aggiornate</b> Grazie a @albanobattistella, @plum7x, @solokot
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

Questa versione potrebbe rompere il tuo ordinamento delle unità di misura. Abbiamo fatto dei miglioramenti in modo che questo non accada più. Ci scusiamo per il diseguido.

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/47.txt
================================================
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/48.txt
================================================
⚙️ <b>Nuove unità di misura</b>: aggiunta la densità e nuove unità di pressione (Grazie a @Kheirlb)
🌍 <b>Miglioramento alle traduzioni</b>: aggiunto bengalese e aggiornato le traduzioni esistenti. Grazie a @aazmii, @rehork, @solokot
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/49.txt
================================================
🐞 Correzione di un bug relativo alla funzione "Nascondi unità"

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/50.txt
================================================
🎨 <b>Nuovo logo!</b> Gazie a Giovanni Spitti per i suggerimenti
🖌️ <b>Migliorate le icone dentro l'app</b>
🌍 <b>Miglioramenti alle traduzioni</b>: grazie a @solokot
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/51.txt
================================================
🔢 Visualizza l'<b>anteprima del risultato</b> nella calcolatrice (Grazie a Bisher Asil)
⚙️ <b>Scegli la proprietà</b> da convertire all'avvio (solo su mobile)
🌍 <b>Miglioramenti alle traduzioni</b>
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/changelogs/52.txt
================================================
📤 <b>Importa / esporta / elimina</b> le impostazioni dell'app
🔢 <b>Aggiunte molte unità di misura</b>
🌍 <b>Miglioramenti alle traduzioni</b>. Grazie a @rehork, @solokot, @milotype, @FTno
🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore

<b>Ti piace Converter NOW?</b> Lascia una recensione e facci sapere cosa ne pensi! ✔️

================================================
FILE: fastlane/metadata/android/it-IT/full_description.txt
================================================
<b>Converter NOW è un efficace convertitore di unità di misura e di valute made in Italy</b>
✔️ <b>Semplifica</b> il noioso processo di conversione tra unità di misura in qualche click
🚀 È <b>veloce e immediato</b>: basta cominciare a digitare e subito si ha la conversione in real-time con tutte le altre unità di misura
🖌️ È <b>personalizzabile</b>: le unità di misura posso essere riorganizzate secondo le proprie priorità e il proprio utilizzo
🔢 Ha una <b>calcolatrice</b> integrata che permette di eseguire velocemente i calcoli in ogni schermata
💰 Tassi di cambio <b>aggiornati quotidianamente</b>
🎨 <b>Tema dinamico</b> in base alle impostazioni del tuo dispositivo
⚫⚪ <b>Scegli il tuo tema preferito</b>: tema chiaro e scuro
📱🖥️ <b>Multipiattaforma</b>: disponibile per Android, Web, Linux e Windows
💯 È <b>gratuito, senza annuni, non raccogliamo dati, non richiede permessi</b> (solo internet per aggiornare i tassi di cambio) e soprattutto è <b>open source</b>!

<b>Converter NOW può convertire 200+ unità di misura e 30+ valute</b> 🎉🎉

Ecco alcune delle grandezze che Converter NOW è in grado di convertire:
-<b>Valute:</b> Dollari, Euro, Sterline, Rupie, Yen, ecc
-<b>Lunghezza:</b> metri, pollici, miglia, yard, anni luce, ecc
-<b>Superficie:</b> metri quadrati, ettari, acri, ecc
-<b>Volume:</b> metri cubi, litri, galloni, pinte, cucchiai, ecc
-<b>Tempo:</b> secondi, ore, giorni, anni, settimane, millenni, ecc
-<b>Temperatura:</b> Centigradi, Fahreneit, Kelvin
-<b>Velocità:</b> metri al secondo, chilometri orari, nodi, ecc
-<b>Massa:</b> grammi, libbre, tonnellate, unità di massa atomica, ecc
-<b>Forza:</b> Newton, dyne, libbre-forza, poundal, ecc
-<b>Pressione:</b> pascal, bar, atomsfere, psi, ecc
-<b>Energia:</b> Joule, calorie, kilowattora, ecc
-<b>Potenza:</b> Watt, kilowatt, cavalli vapore, ecc
-<b>Densità:</b>: Grammi per metro cubo, ecc.</li>
-<b>Consumo carburante:</b> Chilometri con un litro, litro ogni 100 km, ecc
-<b>Basi numeriche:</b> decimale, binario, esadecimale, ecc.
-<b>Momento:</b> Newton metro, libbre-forza piede, poundal metro, ecc
-<b>Dati digitali:</b> Nibble, bit, byte, kibibit, kibibyte, ecc
-<b>Taglia scarpe:</b> UK, India, Europa, USA, Giappone, ecc
-<b>Angoli:</b> gradi, primi, radianti, ecc
-<b>Prefissi SI:</b> kilo, mega, giga,tera, milli, micro, nano, ecc

================================================
FILE: fastlane/metadata/android/it-IT/short_description.txt
================================================
Un convertitore di unità semplice, immediato e veloce!

================================================
FILE: fastlane/metadata/android/it-IT/title.txt
================================================
Convertitore di Unità

================================================
FILE: fastlane/metadata/android/ja/full_description.txt
================================================
<b>Converter NOW は効果的な単位と通貨の変換器です</b>
✔️ <b>簡単</b> 数回クリックするだけで、測定単位間の面倒な変換プロセスが完了します。
🚀 <b>迅速かつ即時</b>: 入力を開始するだけで、すぐに他のすべての測定単位をリアルタイムで変換できます。
🖌️ <b>カスタマイズ可能</b>: ユニットは、優先順位と用途に応じて再編成できます。
🔢 <b>電卓</b>が統合されており、すべてのページで計算を行うことができます。
💰 <b>毎日更新</b>する為替レート
🎨 デバイス設定に基づく<b>動的テーマ</b>
⚫⚪ <b>好きなテーマをお選ぶ</b>: ダークとホワイトのテーマ
📱🖥️ <b>マルチプラットフォーム</b>: Android、Web、Linux、および Windows で利用可能
💯 <b>無料、広告なし、データ収集なし、権限なし</b> (為替レートを更新するためのインターネット権限のみ) そして<b>オープンソース</b>!

<b>Converter NOW は、200 以上の測定単位と 30 以上の通貨を変換できます</b> 🎉🎉

Converter NOW が変換できる単位の一部:
-<b>通貨:</b> ドル、ユーロ、ポンド、ルピー、円 など
-<b>長さ:</b> メートル、インチ、マイル、ヤード、光年 など
-<b>面積:</b> 平方メートル、ヘクタール、エーカー など
-<b>体積:</b> 立方メートル、リットル、ガロン、パイント、スプーン など
-<b>時間:</b> 秒、時間、日、年、週、ミレニアム など
-<b>温度:</b> 摂氏、華氏、ケルビン
-<b>速度:</b> メートル毎秒、キロメートル毎時、ノット など
-<b>質量:</b> グラム、ポンド、トン、原子質量単位 など
-<b>力:</b> ニュートン、ダイン、重量ポンド、パウンダル など
-<b>圧力:</b> パスカル、バール、気圧、重量ポンド毎平方インチ など
-<b>エネルギー:</b> ジュール、カロリー、キロワット時 など
-<b>仕事率:</b> ワット、キロワット、馬力 など
-<b>燃費:</b> マイル毎ガロン、キロメートル毎リットル など
-<b>記数法:</b> 10進数、2進数、16進数 など
-<b>トルク:</b> ニュートンメートル、フィート重量ポンド、パウンダルメートル など
-<b>デジタルデータ:</b> ニブル、ビット、バイト、キビビット、キビバイト など
-<b>靴のサイズ:</b> イギリス、中国、インド、ヨーロッパ、アメリカ、日本 など
-<b>角度:</b> 度、ラジアン、分 など
-<b>国際単位変換:</b> キロ、メガ、ギガ、テラ、ミリ、マイクロ、ナノ など

================================================
FILE: fastlane/metadata/android/ja/short_description.txt
================================================
シンプルで即時かつ高速な単位換算アプリ!

================================================
FILE: fastlane/metadata/android/ja/title.txt
================================================
Converter NOW: 単位換算

================================================
FILE: fastlane/metadata/android/nl_NL/full_description.txt
================================================
<b>Converter NOW is een effectieve eenheden en valuta omrekentool </b>
✔️ <b>Versimpel</b> het omslachtige omrekenen van meeteenheden met een simpele klik op de knop!
🚀 It is <b>Snel en onmiddelijk</b>: begin gewoon met typen en je ziet direct de omgerekende eenheden verschijnen. 
🖌️ It is <b>Aanpasbaar</b>: Eenheden kunnen anders worden geordend aan de hand van wat je vaak gebruikt.
🔢 Integreert een <b>rekenmachine</b> die je bij iedere meeteenheid helpt rekenen.
💰 Valuta wisselkoersen worden <b>dagelijks geüpdate</b>
🎨 <b>Dynamische thema's</b> gebaseerd op jouw apparaatinstellingen
⚫⚪ <b>Kies je favoriete thema</b>: donker en licht thema
📱🖥️ <b>Multiplatform</b>: beschikbaar op Android, Web, Linux and Windows
💯 Het is <b>gratis, geen advertenties, geen dataverzameling, geen toestemmingen nodig</b> (alleen internet om de wisselkoersen te updaten) en bovendien <b>open source</b>!

<b>Converter NOW kan 200+ meeteenheden en 30+ valuta omrekenen</b> 🎉🎉

Dit zijn een aantal van de meeteenheden die Converter NOW kan omrekenen:
-<b>Valuta:</b> Dollars, Euro, Pound, Rupee, Yen, etc.
-<b>Lengte:</b> meters, inches, mijlen, yards, lichtjaren, etc.
-<b>Oppervlakte:</b> vierkante meters, hectares, acres, etc.
-<b>Inhoud:</b> kubieke meters, liters, gallons, pints, eetlepels, etc.
-<b>Tijd:</b> seconden, uren, dagen, jaren, weken, millennia, etc.
-<b>Temperatuur:</b> Celsius, Fahreneit, Kelvin
-<b>Snelheid:</b> meters per seconde, kilometers per uur, knopen, etc.
-<b>Massa:</b> grammen, pond, tonnen, atomic mass units, etc.
-<b>Kracht:</b> Newton, dyne, pound-kracht, poundal, etc
-<b>Druk:</b> pascal, bar, atomsfere, psi, etc.
-<b>Energie:</b> Joule, calorieën, kilowattuur, etc.
-<b>Vermogen:</b> Watt, kilowatt, paardenkracht, etc.
-<b>Brandstofverbruik:</b> Mijl per Gallon, Kilometer per liter, etc.
-<b>Numerieke systemen:</b> decimaal, binair, hexadecimaal, etc.
-<b>Koppel:</b> Newtonmeter, pound-kracht voet, poundal meter, etc.
-<b>Digitale data:</b> Nibble, bit, byte, kibibit, kibibyte, etc.
-<b>Schoenmaten:</b> UK, India, Europe, USA, Japan, etc.
-<b>Hoeken:</b> graden, straal, minuten, etc.
-<b>Decimale voorvoegsels:</b> kilo, mega, giga, tera, milli, micro, nano, etc.


================================================
FILE: fastlane/metadata/android/nl_NL/short_description.txt
================================================
Een simpele, onmiddelijke en snelle manier om eenheden om te rekenen!


================================================
FILE: fastlane/metadata/android/nl_NL/title.txt
================================================
Converter NOW

================================================
FILE: fastlane/metadata/android/pl-PL/full_description.txt
================================================
<b>Converter NOW to skuteczny przelicznik jednostek miar i walut </b>
✔️ <b>Uprość</b> żmudny proces konwersji jednostek miar za pomocą kilku kliknięć..
🚀 Jest <b>szybki i natychmiastowy</b>: po prostu zacznij pisać i natychmiast masz konwersję w czasie rzeczywistym na wszystkie inne jednostki miary.
🖌️ Jest <b>konfigurowalny</b>: jednostki mogą być reorganizowane zgodnie z twoimi upodobaniami i sposobem użytkowania.
🔢 Zawiera w sobie <b>kalkulator</b>, który pozwala wykonywać obliczenia na każdej stronie.
💰 <b>Codziennie aktualizowane</b> kursy walut
⚫⚪ b>Wybierz swój ulubiony motyw</b>: ciemny lub jasny
📱 <b>Pełne</b> <b>wsparcie</b> dla tabletów i telefonów komórkowych
💯 Z <b>otwartym kodem źródłowym</b>!

Sprawdź repozytorium na GitHubie: https://github.com/ferraridamiano/ConverterNOW

Mamy również aplikację internetową! 🖥️ Sprawdź tutaj: https://ferraridamiano.github.io/ConverterNOW/

🌍 Converter NOW jest darmowy, bez reklam, nie wymaga żadnej zgody i nie zbiera twoich danych 🌍

<b>Converter NOW może przeliczać ponad 200 jednostek miary i ponad 30 walut.</b> 🎉🎉

Oto przykładowe miary, które Converter NOW jest w stanie przeliczyć:
-<b>Waluty:</b> dolary, euro, funty, rupie, jeny, itd.
-<b>Długość:</b> metry, cale, mile, jardy, lata świetlne, itd.
-<b>Powierzchnia:</b> metry kwadratowe, hektary, akry, itd.
-<b>Pojemność:</b> metry sześcienne, litry, galony, pinty, łyżki, itd.
-<b>Czas:</b> sekundy, godziny, dni, lata, tygodnie, tysiąclecia, itd.
-<b>Temperatura:</b> stopnie Celsjusza, stopnie Fahrenheita, stopnie Kelwina, itd.
-<b>Prędkość:</b> metry na sekundę, kilometry na godzinę, węzły, itd.
-<b>Masa:</b> gramy, funty, tony, jednostki masy atomowej, itd.
-<b>Siła:</b> niutony, dyny, funt-siła, itd.
-<b>Ciśnienie:</b> paskal, bar, atmosfery, psi, itd.
-<b>Energia:</b> dżule, kalorie, kilowatogodziny, itd.
-<b>Moc:</b> wat, kilowat, konie mechaniczne, itd.
-<b>Zużycie paliwa:</b> Mile z galona, kilometry z litra, itd.
-<b>Systemy liczbowe:</b> dziesiętny, dwójkowy, szesnastkowy, itd.
-<b>Moment obrotowy:</b> Niutonometr, funt na stopę, poundalometr, itd.
-<b>Dane cyfrowe:</b> półjbajt, bit, bajt, kibibit, kibibajt, itd.
-<b>Rozmiar buta:</b> angielski, indyjski, europejski, amerykański, japoński, itd.
-<b>Kąty:</b> stopień, radian, minuta, itd.
-<b>Przedrostek SI:</b> kilo, mega, giga, tera, mili, mikro, nano, itd.


================================================
FILE: fastlane/metadata/android/pl-PL/short_description.txt
================================================
Prosty i szybki przelicznik jednostek miar!

================================================
FILE: fastlane/metadata/android/pl-PL/title.txt
================================================
Przelicznik jednostek miar

================================================
FILE: fastlane/metadata/android/pt-BR/full_description.txt
================================================
<b>Converter NOW é um conversor eficaz de unidades e moedas</b>
✔️ <b>Simplificar</b> em poucos cliques o tedioso processo de conversão entre unidades de medida.
🚀 É <b> rápido e imediato</b>: basta começar a digitar e em tempo real você obtém a conversão com todas as outras unidades de medida.
🖌️ Facilmente <b>personalizável</b>: as unidades podem ser reorganizadas de acordo com suas prioridades e seu uso.
🔢 Integra uma <b>calculadora</b> que permite fazer os cálculos em cada seção.
💰 Nós <b>atualizamos diariamente</b> o valor das moedas.
⚫⚪ <b>Escolha seu tema preferido</b>: tema escuro ou branco.
 📱 <b>O suporte completo</b> para Smartphone e Tablet.
💯 É de <b>código livre</b>!

Visite nosso repositório no GitHub: https://github.com/ferraridamiano/ConverterNOW

Também temos uma versão na Web! 🖥️ Confira aqui: https://ferraridamiano.github.io/ConverterNOW/

🌍 Converter NOW é gratuito, sem anúncios, não requer nenhuma permissão e não coleta nenhum de seus dados 🌍

<b>Converter NOW pode converter mais de 200 unidades de medida e mais de 30 moedas</b> 🎉🎉

Aqui estão algumas unidades que o Converter NOW é capaz de converter:
-<b>Moedas:</b> Dólar, Euro, Libra, Rúpia, Iene, etc
-<b>Comprimento:</b> metros, polegadas, milhas, jardas, anos-luz, etc.
-<b>Área:</b> metros quadrados, hectares, acres, etc.
-<b>Volume:</b> metros cúbicos, litros, galões, pintas, colheres, etc.
-<b>Tempo:</b> segundos, horas, dias, anos, semanas, milénios, etc.
-<b>Temperatura:</b> centígrado, Fahreneit, Kelvin
-<b>Velocidade:</b> metros por segundo, kilómetros por hora, nós, etc.
-<b>Massa:</b> gramas, libras, toneladas, unidade de massa atômica, etc.
-<b>Força:</b> Newton, dyne, libra-força, poundal, etc
-<b>Pressão:</b> pascal, bar, atomsfere, psi, etc.
-<b>Energia:</b> Joule, calorias, quilovate-hora, etc.
-<b>Potência:</b> Watt, kilowatt, cavalo-vapor, etc.
-<b>Consumo de combustível:</b> Milhas por galão, Kilómetros por litro, etc.
-<b>Sistemas numéricos:</b> decimal, binário, hexadecimal etc.
-<b>Torque:</b> Newton metro, libra-força pé, poundal metro, etc.
-<b>Dados digitais:</b> Nibble, bit, byte, kibibit, kibibyte, etc.
-<b>Medida em Pés:</b> UK, Índia, Europa, EUA, Japão, etc.
-<b>Ângulos:</b> grau, radianos, minutos, etc.
-<b>Prefixo SI:</b> kilo, mega, giga, tera, milli, micro, nano, etc.

================================================
FILE: fastlane/metadata/android/pt-BR/short_description.txt
================================================
Um conversor simples, imediato e rápido!

================================================
FILE: fastlane/metadata/android/ru-RU/full_description.txt
================================================
<b>Converter NOW - это эффективный конвертер единиц измерения и валют</b>
✔️ <b>Простой</b>: скучный процесс по переводу единиц измерения теперь доступен в пару нажатий.
🚀 Это очень <b>быстро</b>: просто начните печать, и в миг вы получите результат во всех единицах измерения.
🖌️ Это очень <b>гибкая</b> программа: единицы измерения могут быть определены вашими предпочтениями и сферами деятельности.
🔢 Есть встроенный удобный <b>калькулятор</b>, который поможет в ваших расчётах.
💰 Соотношение курса валют <b>обновляется ежедневно</b>.
🎨 <b>Внешний вид</b> подстраивающийся под настройки вашего устройства.
⚫⚪ <b>Выберите между вашей любимой темой</b>: тёмной или светлой.
📱🖥️ <b>Кроссплатформенность</b>: доступно на Android, в браузере, на системах Linux и Windows.
💯 Это <b>абсолютно бесплатно, без рекламы, подозрительных разрешений и сбора личных данных</b> (за исключением доступа в интернет для обновления курса валют), и конечно же - мы проект с <b>открытым исходным кодом</b>!

<b>Converter NOW может конвертировать больше 200 единиц измерения и более 30 валют</b> 🎉🎉

Вот пример некоторых величин, которые Converter NOW может конвертировать:
-<b>Валюты:</b> доллары, евро, фунты, рупии, иены и др.
-<b>Длина:</b> метры, дюймы, мили, ярды, световые годы и др.
-<b>Площадь:</b> квадратные метры, гектары, сотки и др.
-<b>Объем:</b> кубические метры, литры, галлоны, пинты, ложки и др.
-<b>Время:</b> секунды, часы, дни, годы, недели, тысячелетия и др.
-<b>Температура:</b> градусы Цельсия, Фаренгейта, Кельвина
-<b>Скорость:</b> метры в секунду, километры в час, узлы и др.
-<b>Масса:</b> граммы, фунты, тонны, атомные единицы массы и др.
-<b>Сила:</b> ньютоны, дины, фунт-силы, фунталы и др.
-<b>Давление:</b> паскали, бары, атмосферы, пси и др.
-<b>Энергия:</b> джоули, калории, киловатт-часы и др.
-<b>Мощность:</b> ватт, киловатты, лошадиные силы и др.
-<b>Плотность:</b> граммы на кубический метр и др.
-<b>Потребление топлива:</b> мили на галлон, километры на литр и др.
-<b>Системы счисления:</b> десятичная, двоичная, шестнадцатеричная и др.
-<b>Крутящий момент:</b> ньютон-метры, фунт-сила-футы, фунт-метры и др.
-<b>Цифровые данные:</b> полубайты, биты, байты, кибибиты, кибибайты и др.
-<b>Размер обуви:</b> Великобритания, Индия, Европа, США, Япония и др.
-<b>Углы:</b> градусы, радианы, минуты и др.
-<b>Префиксы Международной системы единиц (СИ):</b> кило, мега, гига, тера, милли, микро, нано и др.


================================================
FILE: fastlane/metadata/android/ru-RU/short_description.txt
================================================
Простой, эффективный и быстрый конвертер!


================================================
FILE: fastlane/metadata/android/ru-RU/title.txt
================================================
Converter NOW: преобразование единиц

================================================
FILE: fastlane/metadata/android/tr-TR/changelogs/24.txt
================================================
★ 3 Yeni Dil: Portekizce, Fransızca ve Norveççe 🌐
★ Bazı çeviriler ve ayakkabı boyutu dönüşüm hatası düzeltildi 🔧

@Mezysinc, @Torok42, @FTno, @dizietsma ve Andreas'a teşekkürler 🔝

Ayrıca bir web uygulamamız da var! 🖥️ Şurada: https://ferraridamiano.github.io/converternow/

Converter NOW hakkında ne düşünüyorsun? Bizi değerlendir! ✔️

================================================
FILE: fastlane/metadata/android/tr-TR/changelogs/25.txt
================================================
★ Sayısal sistem dönüşümleri hatası düzeltildi 🔧

Ayrıca bir web uygulamamız da var! 🖥️ Şurada: https://ferraridamiano.github.io/converternow/

Converter NOW hakkında ne düşünüyorsun? Bizi değerlendir! ✔️

================================================
FILE: fastlane/metadata/android/tr-TR/changelogs/26.txt
================================================
★ Eski cihazlarda karanlık tema seçilebilir
★ Koyu tema, AMOLED moduyla daha da koyu ⚫
★ Pennyweights, ons, taş, sıvı onsu, gill vb. bazı birimler eklendi.
★ Almanca ve Rusça çeviriler eklendi
★ Hata düzeltmesi yapıldı

Katkılarınız için Gena Haltmair ve Vadim Young'a teşekkürler!

Converter NOW hakkında ne düşünüyorsun? Bizi değerlendir! ✔️

================================================
FILE: fastlane/metadata/android/tr-TR/changelogs/27.txt
================================================
★ Varsayılan dil düzeltmesi
★ Eski cihazlarda karanlık tema seçilebilir
★ Koyu tema, AMOLED moduyla daha da koyu ⚫
★ Pennyweights, ons, taş, sıvı onsu, gill vb. bazı birimler eklendi.
★ Almanca ve Rusça çeviriler eklendi
★ Hata düzeltmesi yapıldı

Katkılarınız için Gena Haltmair ve Vadim Young'a teşekkürler!

Converter NOW hakkında ne düşünüyorsun? Bizi değerlendir! ✔️

================================================
FILE: fastlane/metadata/android/tr-TR/full_description.txt
================================================
<b>Converter NOW efektif ölçü ve para birimleri dönüştürücüdür </b>
✔️ Birkaç tıklamayla ölçü birimleri arasındaki sıkıcı dönüşüm işlemlerini <b>basitleştirir</b>.
🚀 <b>Hızlı ve efektif</b>: Yazmaya başladığınız anda diğer tüm ölçü birimlerine gerçek zamanlı çevirim.
🖌️ <b>Özelleştirilebilir</b>: Birimler önceliklerinize ve kullanımınıza göre yeniden düzenlenebilir.
🔢 Her sayfada hesaplama yapmanız için kullanabileceğiniz bir <b>hesap makinesi</b> içerir.
💰 <b>Günlük</b>, para birimi değerleri güncellemeleri
⚫⚪ <b>Tema seçeneği</b>: Koyu ve açık tema seçeneği
📱 Akıllı telefon ve tabletlere <b>tam uyumlu</b>
💯 <b>Özgür yazılım</b>!

Github depomuz: https://github.com/ferraridamiano/converternow

Ayrıca bir web uygulamamız da var! 🖥️ Şurada: https://ferraridamiano.github.io/converternow/

🌍 Converter NOW ücretsiz, reklamsız, herhangi bir izin gerektirmez ve veri toplamaz 🌍

<b>Converter NOW 200+ ölçü birimini ve 30+ para birimini dönüştürebilir</b> 🎉🎉

Converter NOW uygulamasının şimdi dönüştürebileceği fiziksel niceliklerden bazıları:
-<b>Para Birimleri:</b> Dolar, Euro, Pound, Rupi, Yen, vb.
-<b>Uzunluk:</b> metre, inç, mil, yarda, ışık yılı vb.
-<b>Alan:</b> metrekare, hektar, dönüm vb.
-<b>Hacim:</b> metreküp, litre, galon, pint, kaşık vb.
-<b>Zaman:</b> saniye, saat, gün, yıl, hafta, millennia, vb.
-<b>Sıcaklık:</b> Santigrat, Fahreneit, Kelvin
-<b>Hız:</b> saniyede metre, saatte kilometre, knot vb.
-<b>Kütle:</b> gram, pound, ton, dalton vb.
-<b>Kuvvet:</b> Newton, dyn, pound-kuvvet, poundal, vb
-<b>Basınç:</b> pascal, bar, atmosfer, PSI, vb.
-<b>Enerji:</b> Joule, kalori, kilovat saat, vb.
-<b>Güç:</b> Watt, kilowatt, beygir gücü, vb.
-<b>Yakıt tüketimi:</b> Galon başına mil, Litre başına kilometre vb.
-<b>Sayısal sistemler:</b> ondalık, ikili, onaltılık vb.
-<b>Tork:</b> Newton metre, pound-kuvvet fit, poundal metre, vb.
-<b>Dijital veriler:</b> Nibble, bit, bayt, kibibit, kibibyte vb.
-<b>Ayakkabı ölçüleri:</b> İngiltere, Hindistan, Avrupa, ABD, Japonya, vb.
-<b>Açılar:</b> derece, radyan, dakika vb.
-<b>SI öneki:</b> kilo, mega, giga, tera, milli, mikro, nano, vb.

================================================
FILE: fastlane/metadata/android/tr-TR/short_description.txt
================================================
Basit ve efektif bir dönüştürücü!

================================================
FILE: fastlane/metadata/android/zh/full_description.txt
================================================
<b>Converter NOW 是一个有力的单位和货币转换器</b>
✔️ <b>简单</b> 只需点击几下、即可完成计量单位之间繁琐的转换过程。
🚀 它<b>快速且易于使用</b>:只需开始输入、即可立即与所有其他测量单位进行实时转换。
🖌️ 它是<b>可定制</b>的:可以根据您的优先级和用途进行重新组织单元。
🔢 它集成了一个<b>计算器</b>、可让您在每个页面中进行计算。
💰 <b>每日更新</b>货币汇率
🎨 <b>动态主题</b> 基于您的设备配置
⚫⚪ <b>选择你最喜欢的主题</b>:黑暗或明亮主题
📱🖥️ <b>多平台</b>:适用于 Android、Web、Linux 和 Windows
💯 它<b>免费、无广告、无数据收集、无权限</b>(只需互联网用来更新货币汇率)。首先它是<b>开源</b>的!

<b>Converter NOW 可以转换 200 以上的计量单位和 30 种以上的货币</b> 🎉🎉

以下是 Converter NOW 能够转换的一些单位:
-<b>货币</b>:美元、欧元、英镑、卢比、日元 等。
-<b>长度</b>:米、英寸、英里、码、光年 等。
-<b>面积:</b>平方米、公顷、英亩 等。
-<b>体积</b>:立方米、升、加仑、品脱、汤匙 等。
-<b>时间:</b>秒、小时、天、年、周、千年 等。
-<b>温度</b>:摄氏、华氏、开氏
-<b>速度:</b> 米/秒、公里/小时、节 等。
-<b>质量</b>:克、磅、吨、原子质量单位 等。
-<b>力</b>:牛顿、达因、磅力、磅力 等。
-<b>压力</b>:帕斯卡、巴、原子力、psi 等。
-<b>能量:</b>焦耳、卡路里、千瓦时 等。
-<b>功率</b>:瓦特、千瓦、马力 等。
-<b>油耗:</b>每加仑英里数、每升公里数 等。
-<b>数制:</b>十进制、二进制、十六进制 等。
-<b>力矩</b>:牛顿米、磅力英尺、磅米 等。
-<b>数据:</b>比特、字节、kibibit、kibibyte、半字节 等。
-<b>鞋码:</b>英国、印度、欧洲、美国、日本 等。
-<b>角度</b>:度、弧度、分 等。
-<b>SI 前缀</b>:千、兆、千兆、万亿、毫、微米、纳米 等。

================================================
FILE: fastlane/metadata/android/zh/short_description.txt
================================================
一个简单、即时和快速的单位转换器!

================================================
FILE: fastlane/metadata/android/zh/title.txt
================================================
Converter NOW: 单位转换器

================================================
FILE: fastlane/metadata/android/zh-TW/full_description.txt
================================================
<b>Converter NOW 是一個有力的單位與貨幣轉換器</b>
✔️ <b>簡化</b>繁瑣的的轉換處裡,只需點擊幾次即可轉換以下計量的單位。
🚀 <b>快速且即時</b>:只需開始輸入,您就會立即獲得所有計量單位即時轉換。
🖌️ <b>可自訂</b>:這些單位可以依照您的優先順序與用途進行重新安排。
🔢 整合一個<b>計算器</b>以讓您在任何頁面都可以進行計算。
💰 貨幣匯率將會<b>每日更新</b>
🎨 <b>動態主題</b>基於您的裝置設定
⚫⚪ <b>選擇您最愛的主題</b>:深色、白色主題
📱🖥️ <b>多平台</b>:可用於 Android、網頁、Linux 與 Windows
💯 它是<b>免費、無廣告、不蒐集資料、無須權限</b> (就只需網際網路以更新貨幣匯率) 的,首先它是<b>開放原始碼</b>的!

<b>Converter NOW 可以轉換 200 種以上計量單位與 30 種以上貨幣</b> 🎉🎉

Converter NOW 允許轉換以下這些物理量:
-<b>貨幣:</b>美金、歐元、英鎊、盧比、元…等。
-<b>長度:</b>公尺、英吋、英里、碼、光年…等。
-<b>面積:</b>平方公尺、公頃、英畝…等。
-<b>體積:</b>立方公尺、公升、加侖、品脫、湯匙…等。
-<b>時間:</b>秒、時、日、週、年,千年紀…等。
-<b>溫度:</b>攝氏、華氏、克式…等。
-<b>速度:</b>米每秒、公里每小時、節…等。
-<b>質量:</b>公克、磅、噸、原子質量單位…等。
-<b>力:</b>牛頓、達因、磅力、磅達…等。
-<b>壓力:</b>百帕、巴、原子力、磅每平方英吋…等。
-<b>能量:</b>焦耳、卡路里、千瓦小時…等。
-<b>功率:</b>瓦特、千瓦、馬力…等。
-<b>燃油消耗:</b>英里每加侖、公里每加侖…等。
-<b>數值系統:</b>十進位制、二進位制、十六進位制 etc.
-<b>力矩:</b>牛頓公尺、磅力英尺、磅達公尺…等。
-<b>數位資料:</b>半位元組、位元、位元組、Kibibit、KibiByte…等。
-<b>鞋碼:</b>英國、印度、歐洲、美國、日本…等。
-<b>角度:</b>度、弧度、分…等。
-<b>國際單位制前置詞:</b>千、百萬、吉、兆、毫、微、奈…等。


================================================
FILE: fastlane/metadata/android/zh-TW/short_description.txt
================================================
一個簡單、即時且快速的單位轉換器!


================================================
FILE: firebase.json
================================================
{
  "hosting": {
    "public": "build/web",
    "ignore": [
      "firebase.json",
      "**/.*",
      "**/node_modules/**"
    ],
    "rewrites": [
      {
        "source": "**",
        "destination": "/index.html"
      }
    ]
  }
}


================================================
FILE: integration_test/large_display_test.dart
================================================
import 'package:flutter_test/flutter_test.dart';
import 'package:integration_test/integration_test.dart';
import 'package:flutter/material.dart';
import 'package:converterpro/main.dart' as app;
import 'utils.dart';

void main() {
  IntegrationTestWidgetsFlutterBinding.ensureInitialized();

  Future<void> testInit(WidgetTester tester, {bool clearPrefs = true}) async {
    if (clearPrefs) {
      await clearPreferences();
    }
    app.main();
    await tester.pumpAndSettle();
    setWindowSize(800, 700);
    await tester.pumpAndSettle();
  }

  group('Common conversions tasks:', () {
    testWidgets('Change to a new property and perform conversion', (
      WidgetTester tester,
    ) async {
      await testInit(tester);
      await tester.tap(
        find.byKey(const ValueKey('drawerItem_PROPERTYX.currencies')),
      );
      await tester.pumpAndSettle();
      expect(
        find.text('Currencies'),
        findsAtLeastNWidgets(2),
        reason: 'Expected the currencies page',
      );
      await tester.tap(find.byKey(const ValueKey('drawerItem_PROPERTYX.area')));
      await tester.pumpAndSettle();
      expect(
        find.text('Area'),
        findsAtLeastNWidgets(2),
        reason: 'Expected the area page',
      );

      final tffFeet =
          find.byKey(const ValueKey('AREA.squareFeet')).evaluate().single.widget
              as TextFormField;
      final tffHectares =
          find.byKey(const ValueKey('AREA.hectares')).evaluate().single.widget
              as TextFormField;
      final tffMeters =
          find
                  .byKey(const ValueKey('AREA.squareMeters'))
                  .evaluate()
                  .single
                  .widget
              as TextFormField;

      await tester.enterText(
        find.byKey(const ValueKey('AREA.squareFeet')),
        '1000',
      );
      await tester.pumpAndSettle();

      expect(
        tffHectares.controller!.text,
        '0.009290304',
        reason: 'Conversion error',
      );
      expect(
        tffMeters.controller!.text,
        '92.90304',
        reason: 'Conversion error',
      );

      await tester.tap(find.byKey(const ValueKey('clearAll')));
      await tester.pumpAndSettle();
      expect(tffFeet.controller!.text, '', reason: 'Text not cleared');
      expect(tffHectares.controller!.text, '', reason: 'Text not cleared');
      expect(tffMeters.controller!.text, '', reason: 'Text not cleared');
    });
  });

  testWidgets('Perform conversion, clear and undo', (
    WidgetTester tester,
  ) async {
    await testInit(tester);
    final tffMiles =
        find.byKey(const ValueKey('LENGTH.miles')).evaluate().single.widget
            as TextFormField;
    final tffFeet =
        find.byKey(const ValueKey('LENGTH.feet')).evaluate().single.widget
            as TextFormField;
    final tffMeters =
        find.byKey(const ValueKey('LENGTH.meters')).evaluate().single.widget
            as TextFormField;

    expect(
      find.text('Length'),
      findsAtLeastNWidgets(2),
      reason: 'Expected the length page',
    );

    await tester.enterText(find.byKey(const ValueKey('LENGTH.miles')), '1');
    await tester.pumpAndSettle();

    expect(tffFeet.controller!.text, '5280', reason: 'Conversion error');
    expect(tffMeters.controller!.text, '1609.344', reason: 'Conversion error');

    await tester.tap(find.byKey(const ValueKey('clearAll')));
    await tester.pumpAndSettle();
    expect(tffMiles.controller!.text, '', reason: 'Text not cleared');
    expect(tffFeet.controller!.text, '', reason: 'Text not cleared');
    expect(tffMeters.controller!.text, '', reason: 'Text not cleared');

    await tester.tap(find.byKey(const ValueKey('undoClearAll')));
    await tester.pumpAndSettle();
    expect(tffMiles.controller!.text, '1.0', reason: 'Text not restored');
    expect(tffFeet.controller!.text, '5280.0', reason: 'Text not restored');
    expect(tffMeters.controller!.text, '1609.344', reason: 'Text not restored');
  });

  group('Language tasks:', () {
    testWidgets('Change language', (WidgetTester tester) async {
      await testInit(tester);
      await tester.tap(find.byKey(const ValueKey('drawerItem_settings')));
      await tester.pumpAndSettle();
      await tester.tap(find.byKey(const ValueKey('language-dropdown')));
      await tester.pumpAndSettle();
      await tester.tap(find.text('Italiano').last);
      await tester.pumpAndSettle();
      await tester.tap(find.text('Lunghezza'));
      await tester.pumpAndSettle();
      expect(
        find.text('Lunghezza'),
        findsAtLeastNWidgets(2),
        reason: 'Expected translated string',
      );
    });
    testWidgets('Check if language has been saved', (
      WidgetTester tester,
    ) async {
      await testInit(tester, clearPrefs: false);
      expect(
        find.text('Lunghezza'),
        findsAtLeastNWidgets(2),
        reason: 'Expected translated string',
      );
      await clearPreferences();
    });
  });

  group('Reordering tasks:', () {
    testWidgets('Reorder units', (WidgetTester tester) async {
      await testInit(tester);

      // At the beginning the ordering is Meters, Centimeters, Inches, ...
      expect(
        tester.getCenter(find.text('Meters')).dy <
                tester.getCenter(find.text('Feet')).dy &&
            tester.getCenter(find.text('Yards')).dy <
                tester.getCenter(find.text('Kilometers')).dy,
        true,
        reason: 'Initial ordering of length units is not what expected',
      );

      await tester.tap(find.byKey(const ValueKey('drawerItem_settings')));
      await tester.pumpAndSettle();

      await tester.scrollUntilVisible(
        find.byKey(const ValueKey('reorder-units')),
        300,
        scrollable: find.byType(Scrollable).at(1),
        maxScrolls: 2,
      );

      await tester.tap(find.byKey(const ValueKey('reorder-units')));
      await tester.pumpAndSettle();

      await tester.tap(
        find.byKey(const ValueKey('chooseProperty-PROPERTYX.length')),
      );
      await tester.pumpAndSettle();

      final xDragHandle = tester
          .getCenter(find.byIcon(Icons.drag_handle).first)
          .dx;

      await dragGesture(
        tester,
        Offset(xDragHandle, tester.getCenter(find.text('Meters')).dy),
        Offset(xDragHandle, tester.getCenter(find.text('Yards')).dy),
      );
      await tester.pumpAndSettle();

      await dragGesture(
        tester,
        Offset(xDragHandle, tester.getCenter(find.text('Kilometers')).dy),
        Offset(xDragHandle, tester.getCenter(find.text('Feet')).dy),
      );
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('confirm')));
      await tester.pumpAndSettle();

      await tester.tap(
        find.byKey(const ValueKey('drawerItem_PROPERTYX.length')),
      );
      await tester.pumpAndSettle();

      // Now the ordering should be Inches, Centimeters, Meters, ...
      expect(
        tester.getCenter(find.text('Kilometers')).dy <
                tester.getCenter(find.text('Feet')).dy &&
            tester.getCenter(find.text('Feet')).dy <
                tester.getCenter(find.text('Meters')).dy,
        true,
        reason: 'Final ordering of length units is not what expected',
      );
    });

    testWidgets('Check if units ordering has been saved', (
      WidgetTester tester,
    ) async {
      await testInit(tester, clearPrefs: false);

      expect(
        tester.getCenter(find.text('Kilometers')).dy <
                tester.getCenter(find.text('Feet')).dy &&
            tester.getCenter(find.text('Feet')).dy <
                tester.getCenter(find.text('Meters')).dy,
        true,
        reason: 'Ordering of length units is not what expected',
      );
    });

    testWidgets('Reorder properties', (WidgetTester tester) async {
      await testInit(tester);

      // At the beginning the ordering is Length, Area, Volume, ...
      expect(
        tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.length')),
                    )
                    .dy <
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy &&
            tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy <
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.volume')),
                    )
                    .dy,
        true,
        reason: 'Initial ordering of properties is not what expected',
      );

      await tester.tap(find.byKey(const ValueKey('drawerItem_settings')));
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('reorder-properties')));
      await tester.pumpAndSettle();

      final xDragHandle = tester
          .getCenter(find.byIcon(Icons.drag_handle).first)
          .dx;

      await dragGesture(
        tester,
        Offset(xDragHandle, tester.getCenter(find.text('Length').last).dy),
        Offset(xDragHandle, tester.getCenter(find.text('Currencies').last).dy),
      );
      await tester.pumpAndSettle();

      await dragGesture(
        tester,
        Offset(xDragHandle, tester.getCenter(find.text('Volume').last).dy),
        Offset(xDragHandle, tester.getCenter(find.text('Area').last).dy),
      );
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('confirm')));
      await tester.pumpAndSettle();

      // Now the ordering should be Volume, Area, Length, ...
      expect(
        tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.length')),
                    )
                    .dy >
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy &&
            tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy >
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.volume')),
                    )
                    .dy,
        true,
        reason: 'Final ordering the of properties is not what expected',
      );
    });

    testWidgets('Check if properties ordering has been saved', (
      WidgetTester tester,
    ) async {
      await testInit(tester, clearPrefs: false);
      expect(
        tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.length')),
                    )
                    .dy >
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy &&
            tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy >
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.volume')),
                    )
                    .dy,
        true,
        reason: 'Ordering of the properties is not what expected',
      );
    });
  });

  group('Conversion after reorder:', () {
    testWidgets('Change the order of properties and units and convert', (
      WidgetTester tester,
    ) async {
      await testInit(tester);

      await tester.tap(find.byKey(const ValueKey('drawerItem_settings')));
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('reorder-properties')));
      await tester.pumpAndSettle();

      final xDragHandleProperties = tester
          .getCenter(find.byIcon(Icons.drag_handle).first)
          .dx;

      await dragGesture(
        tester,
        Offset(
          xDragHandleProperties,
          tester.getCenter(find.text('Length').last).dy,
        ),
        Offset(
          xDragHandleProperties,
          tester.getCenter(find.text('Currencies').last).dy,
        ),
      );
      await tester.pumpAndSettle();

      await dragGesture(
        tester,
        Offset(
          xDragHandleProperties,
          tester.getCenter(find.text('Volume').last).dy,
        ),
        Offset(
          xDragHandleProperties,
          tester.getCenter(find.text('Area').last).dy,
        ),
      );
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('confirm')));
      await tester.pumpAndSettle();

      await tester.scrollUntilVisible(
        find.byKey(const ValueKey('reorder-units')),
        300,
        scrollable: find.byType(Scrollable).at(1),
        maxScrolls: 2,
      );

      await tester.tap(find.byKey(const ValueKey('reorder-units')));
      await tester.pumpAndSettle();

      await tester.tap(
        find.byKey(const ValueKey('chooseProperty-PROPERTYX.length')),
      );
      await tester.pumpAndSettle();

      final xDragHandleUnits = tester
          .getCenter(find.byIcon(Icons.drag_handle).first)
          .dx;

      await dragGesture(
        tester,
        Offset(xDragHandleUnits, tester.getCenter(find.text('Meters')).dy),
        Offset(xDragHandleUnits, tester.getCenter(find.text('Yards')).dy),
      );
      await tester.pumpAndSettle();

      await dragGesture(
        tester,
        Offset(xDragHandleUnits, tester.getCenter(find.text('Kilometers')).dy),
        Offset(xDragHandleUnits, tester.getCenter(find.text('Feet')).dy),
      );
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('confirm')));
      await tester.pumpAndSettle();

      await tester.tap(
        find.byKey(const ValueKey('drawerItem_PROPERTYX.length')),
      );
      await tester.pumpAndSettle();

      await tester.enterText(find.byKey(const ValueKey('LENGTH.miles')), '1');
      await tester.pumpAndSettle();

      final tffFeet =
          find.byKey(const ValueKey('LENGTH.feet')).evaluate().single.widget
              as TextFormField;
      final tffMeters =
          find.byKey(const ValueKey('LENGTH.meters')).evaluate().single.widget
              as TextFormField;

      expect(tffFeet.controller!.text, '5280', reason: 'Conversion error');
      expect(
        tffMeters.controller!.text,
        '1609.344',
        reason: 'Conversion error',
      );
    });

    testWidgets('Check if it is capable of the same conversion after restart', (
      WidgetTester tester,
    ) async {
      await testInit(tester, clearPrefs: false);

      await tester.tap(find.text('Length'));
      await tester.pumpAndSettle();

      await tester.enterText(find.byKey(const ValueKey('LENGTH.miles')), '1');
      await tester.pumpAndSettle();

      final tffFeet =
          find.byKey(const ValueKey('LENGTH.feet')).evaluate().single.widget
              as TextFormField;
      final tffMeters =
          find.byKey(const ValueKey('LENGTH.meters')).evaluate().single.widget
              as TextFormField;

      expect(tffFeet.controller!.text, '5280', reason: 'Conversion error');
      expect(
        tffMeters.controller!.text,
        '1609.344',
        reason: 'Conversion error',
      );
    });
  });
}


================================================
FILE: integration_test/small_display_test.dart
================================================
import 'package:flutter_test/flutter_test.dart';
import 'package:integration_test/integration_test.dart';
import 'package:flutter/material.dart';
import 'package:converterpro/main.dart' as app;
import 'utils.dart';

void main() {
  IntegrationTestWidgetsFlutterBinding.ensureInitialized();

  Future<void> testInit(
    WidgetTester tester, {
    bool clearPrefs = true,
    bool openFirstProperty = true,
  }) async {
    if (clearPrefs) {
      await clearPreferences();
    }
    app.main();
    await tester.pumpAndSettle();
    setWindowSize(400, 800);
    await tester.pumpAndSettle();
    if (openFirstProperty) {
      await tester.tap(find.byKey(const ValueKey('gridtile-0')));
      await tester.pumpAndSettle();
    }
  }

  group('Common conversions tasks:', () {
    testWidgets('Change to a new property and perform conversion', (
      WidgetTester tester,
    ) async {
      await testInit(tester, openFirstProperty: false);
      await tester.tap(find.byIcon(Icons.menu)); // Open drawer
      await tester.pumpAndSettle();
      await tester.tap(
        find.byKey(const ValueKey('drawerItem_PROPERTYX.currencies')),
      );
      await tester.pumpAndSettle();
      expect(
        find.text('Currencies'),
        findsAtLeastNWidgets(1),
        reason: 'Expected the currencies page',
      );
      await tester.tap(find.byIcon(Icons.menu)); // Open drawer
      await tester.pumpAndSettle();
      await tester.tap(find.byKey(const ValueKey('drawerItem_PROPERTYX.area')));
      await tester.pumpAndSettle();
      expect(
        find.text('Area'),
        findsAtLeastNWidgets(1),
        reason: 'Expected the area page',
      );

      final tffFeet =
          find.byKey(const ValueKey('AREA.squareFeet')).evaluate().single.widget
              as TextFormField;
      final tffHectares =
          find.byKey(const ValueKey('AREA.hectares')).evaluate().single.widget
              as TextFormField;
      final tffMeters =
          find
                  .byKey(const ValueKey('AREA.squareMeters'))
                  .evaluate()
                  .single
                  .widget
              as TextFormField;

      await tester.enterText(
        find.byKey(const ValueKey('AREA.squareFeet')),
        '1000',
      );
      await tester.pumpAndSettle();

      expect(
        tffHectares.controller!.text,
        '0.009290304',
        reason: 'Conversion error',
      );
      expect(
        tffMeters.controller!.text,
        '92.90304',
        reason: 'Conversion error',
      );

      await tester.tap(find.byKey(const ValueKey('clearAll')));
      await tester.pumpAndSettle();
      expect(tffFeet.controller!.text, '', reason: 'Text not cleared');
      expect(tffHectares.controller!.text, '', reason: 'Text not cleared');
      expect(tffMeters.controller!.text, '', reason: 'Text not cleared');
    });
  });

  testWidgets('Perform conversion, clear and undo', (
    WidgetTester tester,
  ) async {
    await testInit(tester);

    final tffMiles =
        find.byKey(const ValueKey('LENGTH.miles')).evaluate().single.widget
            as TextFormField;
    final tffFeet =
        find.byKey(const ValueKey('LENGTH.feet')).evaluate().single.widget
            as TextFormField;
    final tffMeters =
        find.byKey(const ValueKey('LENGTH.meters')).evaluate().single.widget
            as TextFormField;

    expect(
      find.text('Length'),
      findsAtLeastNWidgets(1),
      reason: 'Expected the length page',
    );

    await tester.enterText(find.byKey(const ValueKey('LENGTH.miles')), '1');
    await tester.pumpAndSettle();

    expect(tffFeet.controller!.text, '5280', reason: 'Conversion error');
    expect(tffMeters.controller!.text, '1609.344', reason: 'Conversion error');

    await tester.tap(find.byKey(const ValueKey('clearAll')));
    await tester.pumpAndSettle();
    expect(tffMiles.controller!.text, '', reason: 'Text not cleared');
    expect(tffFeet.controller!.text, '', reason: 'Text not cleared');
    expect(tffMeters.controller!.text, '', reason: 'Text not cleared');

    await tester.tap(find.byKey(const ValueKey('undoClearAll')));
    await tester.pumpAndSettle();
    expect(tffMiles.controller!.text, '1.0', reason: 'Text not restored');
    expect(tffFeet.controller!.text, '5280.0', reason: 'Text not restored');
    expect(tffMeters.controller!.text, '1609.344', reason: 'Text not restored');
  });

  group('Language tasks:', () {
    testWidgets('Change language', (WidgetTester tester) async {
      await testInit(tester);
      await tester.pumpAndSettle();
      await tester.tap(find.byIcon(Icons.menu)); // Open drawer
      await tester.pumpAndSettle();
      await tester.tap(find.byKey(const ValueKey('drawerItem_settings')));
      await tester.pumpAndSettle();
      await tester.tap(find.byKey(const ValueKey('language-dropdown')));
      await tester.pumpAndSettle();
      await tester.tap(find.text('Italiano').last);
      await tester.pumpAndSettle();
      await tester.tap(find.byIcon(Icons.menu)); // Open drawer
      await tester.pumpAndSettle();
      await tester.tap(find.text('Lunghezza'));
      await tester.pumpAndSettle();
      expect(
        find.text('Lunghezza'),
        findsAtLeastNWidgets(1),
        reason: 'Expected translated string',
      );
    });
    testWidgets('Check if language has been saved', (
      WidgetTester tester,
    ) async {
      await testInit(tester, clearPrefs: false);
      expect(
        find.text('Lunghezza'),
        findsAtLeastNWidgets(1),
        reason: 'Expected translated string',
      );
      await clearPreferences();
    });
  });

  group('Reordering tasks:', () {
    testWidgets('Reorder units', (WidgetTester tester) async {
      await testInit(tester);

      // At the beginning the ordering is Meters, Centimeters, Inches, ...
      expect(
        tester.getCenter(find.text('Meters')).dy <
                tester.getCenter(find.text('Feet')).dy &&
            tester.getCenter(find.text('Yards')).dy <
                tester.getCenter(find.text('Kilometers')).dy,
        true,
        reason: 'Initial ordering of length units is not what expected',
      );

      await tester.tap(find.byIcon(Icons.menu)); // Open drawer
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('drawerItem_settings')));
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('reorder-units')));
      await tester.pumpAndSettle();

      await tester.tap(
        find.byKey(const ValueKey('chooseProperty-PROPERTYX.length')),
      );
      await tester.pumpAndSettle();

      final xDragHandle = tester
          .getCenter(find.byIcon(Icons.drag_handle).first)
          .dx;

      await dragGesture(
        tester,
        Offset(xDragHandle, tester.getCenter(find.text('Meters')).dy),
        Offset(xDragHandle, tester.getCenter(find.text('Yards')).dy),
      );
      await tester.pumpAndSettle();

      await dragGesture(
        tester,
        Offset(xDragHandle, tester.getCenter(find.text('Kilometers')).dy),
        Offset(xDragHandle, tester.getCenter(find.text('Feet')).dy),
      );
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('confirm')));
      await tester.pumpAndSettle();

      await tester.tap(find.byIcon(Icons.menu)); // Open drawer
      await tester.pumpAndSettle();

      await tester.tap(
        find.byKey(const ValueKey('drawerItem_PROPERTYX.length')),
      );
      await tester.pumpAndSettle();

      // Now the ordering should be Inches, Centimeters, Meters, ...
      expect(
        tester.getCenter(find.text('Kilometers')).dy <
                tester.getCenter(find.text('Feet')).dy &&
            tester.getCenter(find.text('Feet')).dy <
                tester.getCenter(find.text('Meters')).dy,
        true,
        reason: 'Final ordering of length units is not what expected',
      );
    });

    testWidgets('Check if units ordering has been saved', (
      WidgetTester tester,
    ) async {
      await testInit(tester, clearPrefs: false);

      expect(
        tester.getCenter(find.text('Kilometers')).dy <
                tester.getCenter(find.text('Feet')).dy &&
            tester.getCenter(find.text('Feet')).dy <
                tester.getCenter(find.text('Meters')).dy,
        true,
        reason: 'Ordering of length units is not what expected',
      );
    });

    testWidgets('Reorder properties', (WidgetTester tester) async {
      await testInit(tester);

      await tester.tap(find.byIcon(Icons.menu)); // Open drawer
      await tester.pumpAndSettle();
      // At the beginning the ordering is Length, Area, Volume, ...
      expect(
        tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.length')),
                    )
                    .dy <
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy &&
            tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.area')),
                    )
                    .dy <
                tester
                    .getCenter(
                      find.byKey(const ValueKey('drawerItem_PROPERTYX.volume')),
                    )
                    .dy,
        true,
        reason: 'Initial ordering of properties is not what expected',
      );

      await tester.tap(find.byKey(const ValueKey('drawerItem_settings')));
      await tester.pumpAndSettle();

      await tester.tap(find.byKey(const ValueKey('reorder-properties')));
      await tester.pumpAndSettle();

      final xDragHandle = tester
          .getCenter(find.byIcon(Icons.drag_handle).first)
          .dx;

      await dragGesture(
        tester,
        Offset(xDragHandle, tester.getCenter(fi
Download .txt
gitextract_nvfewi80/

├── .firebaserc
├── .github/
│   ├── FUNDING.yml
│   ├── ISSUE_TEMPLATE/
│   │   ├── bug_report.md
│   │   └── new_unit_request.md
│   ├── dependabot.yml
│   └── workflows/
│       ├── build_deploy.yml
│       ├── scripts/
│       │   └── build_appimage.sh
│       └── tests.yml
├── .gitignore
├── .vscode/
│   └── settings.json
├── CONTRIBUTING.md
├── Dockerfile
├── LICENSE
├── README.md
├── analysis_options.yaml
├── android/
│   ├── .gitignore
│   ├── app/
│   │   ├── build.gradle.kts
│   │   └── src/
│   │       ├── debug/
│   │       │   └── AndroidManifest.xml
│   │       ├── main/
│   │       │   ├── AndroidManifest.xml
│   │       │   ├── kotlin/
│   │       │   │   └── com/
│   │       │   │       └── ferrarid/
│   │       │   │           └── converterpro/
│   │       │   │               └── MainActivity.kt
│   │       │   └── res/
│   │       │       ├── drawable/
│   │       │       │   ├── ic_launcher_background.xml
│   │       │       │   ├── ic_launcher_foreground.xml
│   │       │       │   └── launch_background.xml
│   │       │       ├── drawable-v21/
│   │       │       │   └── launch_background.xml
│   │       │       ├── mipmap-anydpi-v26/
│   │       │       │   ├── ic_launcher.xml
│   │       │       │   └── ic_launcher_round.xml
│   │       │       ├── values/
│   │       │       │   └── styles.xml
│   │       │       └── values-night/
│   │       │           └── styles.xml
│   │       └── profile/
│   │           └── AndroidManifest.xml
│   ├── build.gradle.kts
│   ├── gradle/
│   │   └── wrapper/
│   │       └── gradle-wrapper.properties
│   ├── gradle.properties
│   ├── gradlew
│   ├── gradlew.bat
│   └── settings.gradle.kts
├── assets/
│   └── fonts/
│       └── OFL.txt
├── cliff.toml
├── fastlane/
│   └── metadata/
│       └── android/
│           ├── ar/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── bn/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── de-DE/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── el/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── en-US/
│           │   ├── changelogs/
│           │   │   ├── 24.txt
│           │   │   ├── 25.txt
│           │   │   ├── 26.txt
│           │   │   ├── 27.txt
│           │   │   ├── 28.txt
│           │   │   ├── 29.txt
│           │   │   ├── 30.txt
│           │   │   ├── 31.txt
│           │   │   ├── 33.txt
│           │   │   ├── 34.txt
│           │   │   ├── 35.txt
│           │   │   ├── 36.txt
│           │   │   ├── 37.txt
│           │   │   ├── 38.txt
│           │   │   ├── 39.txt
│           │   │   ├── 40.txt
│           │   │   ├── 41.txt
│           │   │   ├── 42.txt
│           │   │   ├── 43.txt
│           │   │   ├── 44.txt
│           │   │   ├── 45.txt
│           │   │   ├── 46.txt
│           │   │   ├── 47.txt
│           │   │   ├── 48.txt
│           │   │   ├── 49.txt
│           │   │   ├── 50.txt
│           │   │   ├── 51.txt
│           │   │   └── 52.txt
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── es-ES/
│           │   ├── changelogs/
│           │   │   └── 33.txt
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── fr-FR/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── hr/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── id/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── it-IT/
│           │   ├── changelogs/
│           │   │   ├── 24.txt
│           │   │   ├── 25.txt
│           │   │   ├── 26.txt
│           │   │   ├── 27.txt
│           │   │   ├── 28.txt
│           │   │   ├── 29.txt
│           │   │   ├── 30.txt
│           │   │   ├── 31.txt
│           │   │   ├── 33.txt
│           │   │   ├── 34.txt
│           │   │   ├── 35.txt
│           │   │   ├── 36.txt
│           │   │   ├── 37.txt
│           │   │   ├── 38.txt
│           │   │   ├── 39.txt
│           │   │   ├── 40.txt
│           │   │   ├── 41.txt
│           │   │   ├── 42.txt
│           │   │   ├── 43.txt
│           │   │   ├── 44.txt
│           │   │   ├── 45.txt
│           │   │   ├── 46.txt
│           │   │   ├── 47.txt
│           │   │   ├── 48.txt
│           │   │   ├── 49.txt
│           │   │   ├── 50.txt
│           │   │   ├── 51.txt
│           │   │   └── 52.txt
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── ja/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── nl_NL/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── pl-PL/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── pt-BR/
│           │   ├── full_description.txt
│           │   └── short_description.txt
│           ├── ru-RU/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           ├── tr-TR/
│           │   ├── changelogs/
│           │   │   ├── 24.txt
│           │   │   ├── 25.txt
│           │   │   ├── 26.txt
│           │   │   └── 27.txt
│           │   ├── full_description.txt
│           │   └── short_description.txt
│           ├── zh/
│           │   ├── full_description.txt
│           │   ├── short_description.txt
│           │   └── title.txt
│           └── zh-TW/
│               ├── full_description.txt
│               └── short_description.txt
├── firebase.json
├── integration_test/
│   ├── large_display_test.dart
│   ├── small_display_test.dart
│   └── utils.dart
├── lib/
│   ├── app_router.dart
│   ├── data/
│   │   ├── default_order.dart
│   │   └── property_unit_maps.dart
│   ├── helpers/
│   │   └── responsive_helper.dart
│   ├── main.dart
│   ├── models/
│   │   ├── conversions.dart
│   │   ├── currencies.dart
│   │   ├── hide_units.dart
│   │   ├── import_export.dart
│   │   ├── order.dart
│   │   ├── properties_list.dart
│   │   └── settings.dart
│   ├── pages/
│   │   ├── app_scaffold.dart
│   │   ├── choose_property_page.dart
│   │   ├── conversion_page.dart
│   │   ├── custom_drawer.dart
│   │   ├── error_page.dart
│   │   ├── hide_units_page.dart
│   │   ├── initial_page.dart
│   │   ├── reorder_page.dart
│   │   ├── reorder_properties_page.dart
│   │   ├── reorder_units_page.dart
│   │   ├── search_page.dart
│   │   ├── select_units_page.dart
│   │   ├── settings_page.dart
│   │   └── splash_screen.dart
│   ├── styles/
│   │   └── consts.dart
│   └── utils/
│       ├── navigator_utils.dart
│       ├── palette.dart
│       ├── utils.dart
│       └── utils_widgets.dart
├── linux/
│   ├── .gitignore
│   ├── CMakeLists.txt
│   ├── flutter/
│   │   ├── CMakeLists.txt
│   │   ├── generated_plugin_registrant.cc
│   │   ├── generated_plugin_registrant.h
│   │   └── generated_plugins.cmake
│   ├── io.github.ferraridamiano.ConverterNOW.desktop
│   ├── io.github.ferraridamiano.ConverterNOW.metainfo.xml
│   └── runner/
│       ├── CMakeLists.txt
│       ├── main.cc
│       ├── my_application.cc
│       └── my_application.h
├── packages/
│   ├── calculator_widget/
│   │   ├── analysis_options.yaml
│   │   ├── lib/
│   │   │   ├── animated_button.dart
│   │   │   ├── calculator_model.dart
│   │   │   └── calculator_widget.dart
│   │   └── pubspec.yaml
│   └── translations/
│       ├── l10n.yaml
│       ├── lib/
│       │   └── l10n/
│       │       ├── app_ar.arb
│       │       ├── app_bn.arb
│       │       ├── app_ca.arb
│       │       ├── app_de.arb
│       │       ├── app_el.arb
│       │       ├── app_en.arb
│       │       ├── app_es.arb
│       │       ├── app_fr.arb
│       │       ├── app_hr.arb
│       │       ├── app_id.arb
│       │       ├── app_it.arb
│       │       ├── app_ja.arb
│       │       ├── app_nb.arb
│       │       ├── app_nl.arb
│       │       ├── app_pl.arb
│       │       ├── app_pt.arb
│       │       ├── app_ru.arb
│       │       ├── app_tr.arb
│       │       ├── app_zh.arb
│       │       └── app_zh_TW.arb
│       └── pubspec.yaml
├── pubspec.yaml
├── web/
│   ├── index.html
│   └── manifest.json
└── windows/
    ├── .gitignore
    ├── CMakeLists.txt
    ├── flutter/
    │   ├── CMakeLists.txt
    │   ├── generated_plugin_registrant.cc
    │   ├── generated_plugin_registrant.h
    │   └── generated_plugins.cmake
    ├── innosetup.iss
    └── runner/
        ├── CMakeLists.txt
        ├── Runner.rc
        ├── flutter_window.cpp
        ├── flutter_window.h
        ├── main.cpp
        ├── resource.h
        ├── runner.exe.manifest
        ├── utils.cpp
        ├── utils.h
        ├── win32_window.cpp
        └── win32_window.h
Download .txt
SYMBOL INDEX (222 symbols across 43 files)

FILE: integration_test/large_display_test.dart
  function main (line 7) | void main()
  function testInit (line 10) | Future<void> testInit(WidgetTester tester, {bool clearPrefs = true})

FILE: integration_test/small_display_test.dart
  function main (line 7) | void main()
  function testInit (line 10) | Future<void> testInit(

FILE: integration_test/utils.dart
  function clearPreferences (line 8) | Future<void> clearPreferences()
  function dragGesture (line 16) | Future<void> dragGesture(WidgetTester tester, Offset start, Offset end)
  function setWindowSize (line 25) | void setWindowSize(double width, double height)

FILE: lib/data/property_unit_maps.dart
  function getPropertyUiMap (line 8) | Map<PROPERTYX, PropertyUi> getPropertyUiMap(BuildContext context)
  function getUnitUiMap (line 44) | Map<PROPERTYX, Map<dynamic, String>> getUnitUiMap(BuildContext context)

FILE: lib/helpers/responsive_helper.dart
  function responsivePadding (line 3) | double responsivePadding(double displayWidth)
  function responsiveNumCols (line 5) | int responsiveNumCols(double displayWidth)
  function responsiveChildAspectRatio (line 16) | double responsiveChildAspectRatio(double width, int colNumber)
  function isDrawerFixed (line 19) | bool isDrawerFixed(double displayWidth)

FILE: lib/main.dart
  function main (line 10) | void main()
  class MyApp (line 21) | class MyApp extends ConsumerWidget {
    method build (line 25) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/models/conversions.dart
  class ConversionsNotifier (line 8) | class ConversionsNotifier
    method build (line 17) | Future<Map<PROPERTYX, List<UnitData>>> build()
    method _refreshCurrentUnitDataList (line 84) | Future<void> _refreshCurrentUnitDataList(PROPERTYX property)
    method convert (line 104) | Future<void> convert(UnitData unitData, var value, PROPERTYX property)
    method getUnitDataListAtPage (line 113) | List<UnitData> getUnitDataListAtPage(PROPERTYX property)
    method clearAllValues (line 117) | Future<void> clearAllValues(PROPERTYX property)
    method undoClearOperation (line 135) | Future<void> undoClearOperation()
    method shouldShowSnackbar (line 159) | bool shouldShowSnackbar(PROPERTYX property)

FILE: lib/models/currencies.dart
  class Currencies (line 9) | class Currencies {
    method toJson (line 55) | String toJson()
    method copyWith (line 68) | Currencies copyWith({
  class CurrenciesNotifier (line 79) | class CurrenciesNotifier extends AsyncNotifier<Currencies> {
    method build (line 86) | Future<Currencies> build()
    method forceCurrenciesDownload (line 103) | void forceCurrenciesDownload()
    method _readSavedCurrencies (line 107) | Currencies _readSavedCurrencies()
    method _downloadCurrencies (line 120) | Future<Currencies> _downloadCurrencies()

FILE: lib/models/hide_units.dart
  class HiddenUnitsNotifier (line 7) | class HiddenUnitsNotifier extends AsyncNotifier<Map<PROPERTYX, List>> {
    method build (line 14) | Future<Map<PROPERTYX, List>> build()
    method set (line 40) | bool set(List hiddenUnits, PROPERTYX property)
    method storeKey (line 71) | String storeKey(PROPERTYX property)

FILE: lib/models/import_export.dart
  class ImportExportNotifier (line 11) | class ImportExportNotifier extends Notifier<void> {
    method build (line 31) | void build()
    method exportSettings (line 34) | Future<String> exportSettings()
    method importSettings (line 88) | Future<(String?, List<String>)> importSettings(String jsonString)
    method deleteSettings (line 212) | void deleteSettings()

FILE: lib/models/order.dart
  class PropertiesOrderNotifier (line 8) | class PropertiesOrderNotifier extends AsyncNotifier<List<PROPERTYX>> {
    method build (line 17) | Future<List<PROPERTYX>> build()
    method set (line 46) | bool set(List<int> newOrder)
    method _toStorableString (line 76) | List<String> _toStorableString(List<PROPERTYX> listToConvert)
  function inverse (line 82) | Map<PROPERTYX, int> inverse()
  class UnitsOrderNotifier (line 86) | class UnitsOrderNotifier extends AsyncNotifier<Map<PROPERTYX, List>> {
    method build (line 93) | Future<Map<PROPERTYX, List>> build()
    method set (line 128) | bool set(List<int>? newOrder, PROPERTYX property)
    method storeKey (line 163) | String storeKey(PROPERTYX property)
    method _toStorableString (line 166) | List<String> _toStorableString(List listToConvert)

FILE: lib/models/settings.dart
  class SettingsNotifier (line 37) | class SettingsNotifier<T> extends AsyncNotifier<T?> {
    method set (line 43) | bool set(T? value)
    method build (line 69) | Future<T?> build()
  function languageTagToLocale (line 181) | Locale languageTagToLocale(String languageTag)

FILE: lib/pages/app_scaffold.dart
  class AppScaffold (line 16) | class AppScaffold extends ConsumerWidget {
    method build (line 22) | Widget build(BuildContext context, WidgetRef ref)
    method openCalculator (line 25) | void openCalculator()
    method clearAll (line 35) | void clearAll(bool isDrawerFixed)
    method openSearch (line 66) | void openSearch()

FILE: lib/pages/choose_property_page.dart
  class ChoosePropertyPage (line 8) | class ChoosePropertyPage extends ConsumerWidget {
    method build (line 23) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/pages/conversion_page.dart
  class ConversionPage (line 16) | class ConversionPage extends ConsumerWidget {
    method build (line 22) | Widget build(BuildContext context, WidgetRef ref)
    method unitWidgetBuilder (line 70) | UnitWidget unitWidgetBuilder(UnitData unitData)
  function _getLastUpdateString (line 230) | String _getLastUpdateString(BuildContext context, String lastUpdate)

FILE: lib/pages/custom_drawer.dart
  class CustomDrawer (line 12) | class CustomDrawer extends ConsumerWidget {
    method build (line 25) | Widget build(BuildContext context, WidgetRef ref)
  function pathToNavigationIndex (line 194) | int pathToNavigationIndex(

FILE: lib/pages/error_page.dart
  class ErrorPage (line 5) | class ErrorPage extends StatelessWidget {
    method build (line 9) | Widget build(BuildContext context)

FILE: lib/pages/hide_units_page.dart
  class HideUnitsPage (line 13) | class HideUnitsPage extends ConsumerWidget {
    method build (line 28) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/pages/initial_page.dart
  class InitialPage (line 13) | class InitialPage extends ConsumerWidget {
    method build (line 17) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/pages/reorder_page.dart
  type Item (line 4) | typedef Item = ({int id, String title});
  class ReorderPage (line 6) | class ReorderPage extends StatefulWidget {
    method createState (line 19) | State<ReorderPage> createState()
  class _ReorderPageState (line 22) | class _ReorderPageState extends State<ReorderPage> {
    method build (line 27) | Widget build(BuildContext context)
    method _updateItemsOrder (line 97) | void _updateItemsOrder(int oldIndex, int newIndex)

FILE: lib/pages/reorder_properties_page.dart
  class ReorderPropertiesPage (line 12) | class ReorderPropertiesPage extends ConsumerWidget {
    method build (line 16) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/pages/reorder_units_page.dart
  class ReorderUnitsPage (line 15) | class ReorderUnitsPage extends ConsumerWidget {
    method build (line 30) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/pages/search_page.dart
  class CustomSearchDelegate (line 7) | class CustomSearchDelegate extends SearchDelegate<PROPERTYX?> {
    method buildLeading (line 13) | Widget buildLeading(BuildContext context)
    method buildSuggestions (line 27) | Widget buildSuggestions(BuildContext context)
    method buildResults (line 56) | Widget buildResults(BuildContext context)
    method buildActions (line 61) | List<Widget> buildActions(BuildContext context)
  function getSearchUnitsList (line 77) | List<SearchUnit> getSearchUnitsList(

FILE: lib/pages/select_units_page.dart
  class SelectUnitsPage (line 11) | class SelectUnitsPage extends ConsumerStatefulWidget {
    method createState (line 17) | ConsumerState<ConsumerStatefulWidget> createState()
  class _SelectUnitsPageState (line 21) | class _SelectUnitsPageState extends ConsumerState<SelectUnitsPage> {
    method initState (line 25) | void initState()
    method didUpdateWidget (line 31) | void didUpdateWidget(covariant SelectUnitsPage oldWidget)
    method initProvider (line 36) | void initProvider()
    method build (line 43) | Widget build(BuildContext context)

FILE: lib/pages/settings_page.dart
  class SettingsPage (line 22) | class SettingsPage extends ConsumerWidget {
    method build (line 31) | Widget build(BuildContext context, WidgetRef ref)
  class ColorPickerDialog (line 650) | class ColorPickerDialog extends ConsumerWidget {
    method build (line 654) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/pages/splash_screen.dart
  class SplashScreen (line 14) | class SplashScreen extends ConsumerWidget {
    method build (line 18) | Widget build(BuildContext context, WidgetRef ref)

FILE: lib/utils/navigator_utils.dart
  type AppPage (line 5) | enum AppPage { conversions, settings, reorder, reorderDetails }
  function computeSelectedSection (line 7) | AppPage computeSelectedSection(BuildContext context)
  function computeSelectedConversionPage (line 29) | int? computeSelectedConversionPage(

FILE: lib/utils/palette.dart
  class Palette (line 4) | class Palette extends StatefulWidget {
    method createState (line 17) | State<Palette> createState()
  class _PaletteState (line 20) | class _PaletteState extends State<Palette> {
    method initState (line 28) | void initState()
    method build (line 34) | Widget build(BuildContext context)

FILE: lib/utils/utils.dart
  function launchURL (line 10) | Future<void> launchURL(
  function saveSettings (line 18) | void saveSettings(String key, dynamic value)
  type VALIDATOR (line 33) | enum VALIDATOR {
  class UnitData (line 42) | class UnitData {
    method getValidator (line 60) | RegExp getValidator()
  type PROPERTYX (line 72) | enum PROPERTYX {
  type PropertyUi (line 95) | typedef PropertyUi = ({String name, String icon, String selectedIcon});
  function initializeQuickAction (line 97) | void initializeQuickAction({
  function getIconColor (line 121) | Color getIconColor(ThemeData theme)
  function _floatToInt8 (line 124) | int _floatToInt8(double x)
  function color2Int (line 126) | int color2Int(Color color)
  function toKebabCase (line 134) | String toKebabCase()
  function kebabStringToPropertyX (line 143) | PROPERTYX kebabStringToPropertyX(String string)
  function dPrint (line 151) | void dPrint(String Function() message)

FILE: lib/utils/utils_widgets.dart
  class UnitWidget (line 9) | class UnitWidget extends StatefulWidget {
    method createState (line 32) | State<UnitWidget> createState()
  class _UnitWidgetState (line 35) | class _UnitWidgetState extends State<UnitWidget> {
    method dispose (line 39) | void dispose()
    method build (line 45) | Widget build(BuildContext context)
  class SearchUnit (line 131) | class SearchUnit {
  class SearchUnitTile (line 142) | class SearchUnitTile extends StatelessWidget {
    method build (line 147) | Widget build(BuildContext context)
  class SuggestionList (line 163) | class SuggestionList extends StatelessWidget {
    method build (line 168) | Widget build(BuildContext context)
  class PropertyGridTile (line 178) | class PropertyGridTile extends StatelessWidget {
    method build (line 192) | Widget build(BuildContext context)
  class DropdownListTile (line 237) | class DropdownListTile extends StatelessWidget {
    method build (line 260) | Widget build(BuildContext context)
  class SegmentedButtonListTile (line 307) | class SegmentedButtonListTile extends StatelessWidget {
    method build (line 330) | Widget build(BuildContext context)
  function showModalBottomRadioList (line 369) | Future<String?> showModalBottomRadioList({
  class SplashScreenWidget (line 402) | class SplashScreenWidget extends StatelessWidget {
    method build (line 405) | Widget build(BuildContext context)
  class ConstrainedContainer (line 419) | class ConstrainedContainer extends StatelessWidget {
    method build (line 425) | Widget build(BuildContext context)
  function getPropertyGridTiles (line 438) | List<PropertyGridTile> getPropertyGridTiles(

FILE: linux/flutter/generated_plugin_registrant.cc
  function fl_register_plugins (line 14) | void fl_register_plugins(FlPluginRegistry* registry) {

FILE: linux/runner/main.cc
  function main (line 3) | int main(int argc, char** argv) {

FILE: linux/runner/my_application.cc
  type _MyApplication (line 10) | struct _MyApplication {
  function first_frame_cb (line 18) | static void first_frame_cb(MyApplication* self, FlView* view) {
  function my_application_activate (line 23) | static void my_application_activate(GApplication* application) {
  function gboolean (line 83) | static gboolean my_application_local_command_line(GApplication* applicat...
  function my_application_startup (line 104) | static void my_application_startup(GApplication* application) {
  function my_application_shutdown (line 113) | static void my_application_shutdown(GApplication* application) {
  function my_application_dispose (line 122) | static void my_application_dispose(GObject* object) {
  function my_application_class_init (line 128) | static void my_application_class_init(MyApplicationClass* klass) {
  function my_application_init (line 137) | static void my_application_init(MyApplication* self) {}
  function MyApplication (line 139) | MyApplication* my_application_new() {

FILE: packages/calculator_widget/lib/animated_button.dart
  class AnimatedButton (line 5) | class AnimatedButton extends StatefulWidget {
    method createState (line 28) | State<AnimatedButton> createState()
  class _AnimatedButtonState (line 31) | class _AnimatedButtonState extends State<AnimatedButton>
    method initState (line 41) | void initState()
    method build (line 68) | Widget build(BuildContext context)
    method dispose (line 91) | void dispose()
  class _ElevatedButtonTransition (line 98) | class _ElevatedButtonTransition extends AnimatedWidget {
    method build (line 121) | Widget build(BuildContext context)

FILE: packages/calculator_widget/lib/calculator_model.dart
  type OPERATION (line 7) | enum OPERATION {
  class Calculator (line 22) | class Calculator extends Notifier<String> {
    method build (line 32) | String build()
    method submitString (line 37) | void submitString(String string)
    method submitChar (line 45) | void submitChar(String char)
    method _computeResult (line 140) | void _computeResult()
    method _updatePreviewResult (line 159) | void _updatePreviewResult()
    method clearAll (line 189) | void clearAll()
    method deleteLastChar (line 199) | void deleteLastChar()
    method adaptiveDeleteClear (line 207) | void adaptiveDeleteClear()
    method percentage (line 210) | void percentage()
    method squareRoot (line 215) | void squareRoot()
    method log10 (line 220) | void log10()
    method square (line 225) | void square()
    method ln (line 229) | void ln()
    method reciprocal (line 233) | void reciprocal()
    method factorial (line 238) | void factorial()
    method _unaryOperation (line 245) | void _unaryOperation(String Function(Decimal) operation)
  function _getStringFromRational (line 260) | String _getStringFromRational(Rational rational)
  function _getStringFromDecimal (line 268) | String _getStringFromDecimal(Decimal value)
  function _getStringFromNum (line 271) | String _getStringFromNum(num value)
  function _myFactorialFunction (line 279) | int _myFactorialFunction(int x)
  class SelectedOperationNotifier (line 281) | class SelectedOperationNotifier extends Notifier<OPERATION?> {
    method build (line 293) | OPERATION? build()

FILE: packages/calculator_widget/lib/calculator_widget.dart
  type ButtonType (line 8) | enum ButtonType { number, operation, clear }
  class CalculatorWidget (line 12) | class CalculatorWidget extends StatelessWidget {
    method build (line 16) | Widget build(BuildContext context)
  class _CalculatorWidget (line 20) | class _CalculatorWidget extends ConsumerWidget {
    method build (line 26) | Widget build(BuildContext context, WidgetRef ref)
  class CalculatorHeader (line 129) | class CalculatorHeader extends ConsumerWidget {
    method build (line 133) | Widget build(BuildContext context, WidgetRef ref)
  class CalculatorNumpad (line 228) | class CalculatorNumpad extends ConsumerWidget {
    method build (line 236) | Widget build(BuildContext context, WidgetRef ref)
  class CalculatorButton (line 398) | class CalculatorButton extends StatelessWidget {
    method build (line 413) | Widget build(BuildContext context)

FILE: windows/flutter/generated_plugin_registrant.cc
  function RegisterPlugins (line 14) | void RegisterPlugins(flutter::PluginRegistry* registry) {

FILE: windows/runner/flutter_window.cpp
  function LRESULT (line 50) | LRESULT

FILE: windows/runner/flutter_window.h
  function class (line 12) | class FlutterWindow : public Win32Window {

FILE: windows/runner/main.cpp
  function wWinMain (line 8) | int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev,

FILE: windows/runner/utils.cpp
  function CreateAndAttachConsole (line 10) | void CreateAndAttachConsole() {
  function GetCommandLineArguments (line 24) | std::vector<std::string> GetCommandLineArguments() {
  function Utf8FromUtf16 (line 44) | std::string Utf8FromUtf16(const wchar_t* utf16_string) {

FILE: windows/runner/win32_window.cpp
  function Scale (line 36) | int Scale(int source, double scale_factor) {
  function EnableFullDpiSupportIfAvailable (line 42) | void EnableFullDpiSupportIfAvailable(HWND hwnd) {
  class WindowClassRegistrar (line 59) | class WindowClassRegistrar {
    method WindowClassRegistrar (line 64) | static WindowClassRegistrar* GetInstance() {
    method WindowClassRegistrar (line 80) | WindowClassRegistrar() = default;
  function wchar_t (line 89) | const wchar_t* WindowClassRegistrar::GetWindowClass() {
  function LRESULT (line 157) | LRESULT CALLBACK Win32Window::WndProc(HWND const window,
  function LRESULT (line 176) | LRESULT
  function Win32Window (line 236) | Win32Window* Win32Window::GetThisFromHandle(HWND const window) noexcept {
  function RECT (line 252) | RECT Win32Window::GetClientArea() {
  function HWND (line 258) | HWND Win32Window::GetHandle() {

FILE: windows/runner/win32_window.h
  type Size (line 21) | struct Size {
Condensed preview — 244 files, each showing path, character count, and a content snippet. Download the .json file or copy for the full structured content (918K chars).
[
  {
    "path": ".firebaserc",
    "chars": 55,
    "preview": "{\n  \"projects\": {\n    \"default\": \"converter-now\"\n  }\n}\n"
  },
  {
    "path": ".github/FUNDING.yml",
    "chars": 683,
    "preview": "# These are supported funding model platforms\n\ngithub: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [u"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/bug_report.md",
    "chars": 690,
    "preview": "---\nname: Bug report\nabout: Create a report to help us improve\ntitle: \"[BUG] \"\nlabels: ''\nassignees: ''\n\n---\n\n**Describe"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/new_unit_request.md",
    "chars": 1386,
    "preview": "---\nname: New unit request\nabout: Suggest a unit of measurement that should be added\ntitle: \"[new-unit]\"\nlabels: ''\nassi"
  },
  {
    "path": ".github/dependabot.yml",
    "chars": 391,
    "preview": "version: 2\nupdates:\n- package-ecosystem: \"github-actions\"\n  directory: \"/\"\n  schedule:\n    interval: \"weekly\"\n\n- package"
  },
  {
    "path": ".github/workflows/build_deploy.yml",
    "chars": 9719,
    "preview": "name: \"Build & deploy for Android, Linux, Web and Windows\"\n\non:\n  push:\n    tags: ['v*']\n\njobs:\n\n  build_linux_x86_64:\n "
  },
  {
    "path": ".github/workflows/scripts/build_appimage.sh",
    "chars": 980,
    "preview": "#!/bin/bash\n\n# This script needs to be called once the flutter linux app build is finished\n\narch=$(ls build/linux)\narch_"
  },
  {
    "path": ".github/workflows/tests.yml",
    "chars": 1731,
    "preview": "name: Tests\n\non:\n  push:\n    branches:\n      - master\n  pull_request:\n\njobs:\n  # JOB to run change detection\n  changes:\n"
  },
  {
    "path": ".gitignore",
    "chars": 339,
    "preview": ".DS_Store\n.dart_tool/\n\n.packages\n.pub/\n\nbuild/\n\n.flutter-plugins\n*.jks\n.flutter-plugins-dependencies\nios/Flutter/flutter"
  },
  {
    "path": ".vscode/settings.json",
    "chars": 133,
    "preview": "{\n  \"files.exclude\": {\n    \"packages/translations/lib/app_localizations*.dart\": true,\n  },\n  \"cmake.ignoreCMakeListsMiss"
  },
  {
    "path": "CONTRIBUTING.md",
    "chars": 2230,
    "preview": "# Welcome\n\nWe invite you to join our team! Everyone is welcome to contribute by submitting\ncode, pull requests, or repor"
  },
  {
    "path": "Dockerfile",
    "chars": 1755,
    "preview": "FROM --platform=linux/amd64 debian:13-slim AS builder\n\nUSER root\n\nENV HOME=\"/root\"\nARG flutter_version=\"stable\"\n\nENV FLU"
  },
  {
    "path": "LICENSE",
    "chars": 35148,
    "preview": "                    GNU GENERAL PUBLIC LICENSE\n                       Version 3, 29 June 2007\n\n Copyright (C) 2007 Free "
  },
  {
    "path": "README.md",
    "chars": 5367,
    "preview": "<div align=\"center\">\n\n# Converter NOW\n\n</div>\n\n<div align=\"center\">\n    <img alt=\"Icon\" src=\"assets/logo.png\" height=\"15"
  },
  {
    "path": "analysis_options.yaml",
    "chars": 187,
    "preview": "include: package:flutter_lints/flutter.yaml\n\nlinter:\n  rules:\n    prefer_const_constructors: true\n    prefer_const_decla"
  },
  {
    "path": "android/.gitignore",
    "chars": 253,
    "preview": "gradle-wrapper.jar\n/.gradle\n/captures/\n/gradlew\n/gradlew.bat\n/local.properties\nGeneratedPluginRegistrant.java\n.cxx/\n\n# R"
  },
  {
    "path": "android/app/build.gradle.kts",
    "chars": 1863,
    "preview": "import java.util.Properties\nimport java.io.FileInputStream\n\nplugins {\n    id(\"com.android.application\")\n    id(\"kotlin-a"
  },
  {
    "path": "android/app/src/debug/AndroidManifest.xml",
    "chars": 378,
    "preview": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\">\n    <!-- The INTERNET permission is required for d"
  },
  {
    "path": "android/app/src/main/AndroidManifest.xml",
    "chars": 2535,
    "preview": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\">\n\n    <!-- The INTERNET permission is required in o"
  },
  {
    "path": "android/app/src/main/kotlin/com/ferrarid/converterpro/MainActivity.kt",
    "chars": 127,
    "preview": "package com.ferrarid.converterpro\n\nimport io.flutter.embedding.android.FlutterActivity\n\nclass MainActivity : FlutterActi"
  },
  {
    "path": "android/app/src/main/res/drawable/ic_launcher_background.xml",
    "chars": 889,
    "preview": "<vector xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    android:width=\"108dp\"\n    android:height=\"108dp\"\n"
  },
  {
    "path": "android/app/src/main/res/drawable/ic_launcher_foreground.xml",
    "chars": 8359,
    "preview": "<vector xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    android:width=\"108dp\"\n    android:height=\"108dp\"\n"
  },
  {
    "path": "android/app/src/main/res/drawable/launch_background.xml",
    "chars": 370,
    "preview": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<!-- Modify this file to customize your launch splash screen -->\n<layer-list xmln"
  },
  {
    "path": "android/app/src/main/res/drawable-v21/launch_background.xml",
    "chars": 374,
    "preview": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<!-- Modify this file to customize your launch splash screen -->\n<layer-list xmln"
  },
  {
    "path": "android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml",
    "chars": 336,
    "preview": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<adaptive-icon xmlns:android=\"http://schemas.android.com/apk/res/android\">\n    <b"
  },
  {
    "path": "android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml",
    "chars": 336,
    "preview": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<adaptive-icon xmlns:android=\"http://schemas.android.com/apk/res/android\">\n    <b"
  },
  {
    "path": "android/app/src/main/res/values/styles.xml",
    "chars": 996,
    "preview": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n    <!-- Theme applied to the Android Window while the process is sta"
  },
  {
    "path": "android/app/src/main/res/values-night/styles.xml",
    "chars": 995,
    "preview": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n    <!-- Theme applied to the Android Window while the process is sta"
  },
  {
    "path": "android/app/src/profile/AndroidManifest.xml",
    "chars": 378,
    "preview": "<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\">\n    <!-- The INTERNET permission is required for d"
  },
  {
    "path": "android/build.gradle.kts",
    "chars": 537,
    "preview": "allprojects {\n    repositories {\n        google()\n        mavenCentral()\n    }\n}\n\nval newBuildDir: Directory =\n    rootP"
  },
  {
    "path": "android/gradle/wrapper/gradle-wrapper.properties",
    "chars": 201,
    "preview": "distributionBase=GRADLE_USER_HOME\ndistributionPath=wrapper/dists\nzipStoreBase=GRADLE_USER_HOME\nzipStorePath=wrapper/dist"
  },
  {
    "path": "android/gradle.properties",
    "chars": 138,
    "preview": "org.gradle.jvmargs=-Xmx8G -XX:MaxMetaspaceSize=4G -XX:ReservedCodeCacheSize=512m -XX:+HeapDumpOnOutOfMemoryError\nandroid"
  },
  {
    "path": "android/gradlew",
    "chars": 4971,
    "preview": "#!/usr/bin/env bash\n\n##############################################################################\n##\n##  Gradle start "
  },
  {
    "path": "android/gradlew.bat",
    "chars": 2404,
    "preview": "@if \"%DEBUG%\" == \"\" @echo off\r\n@rem ##########################################################################\r\n@rem\r\n@r"
  },
  {
    "path": "android/settings.gradle.kts",
    "chars": 772,
    "preview": "pluginManagement {\n    val flutterSdkPath =\n        run {\n            val properties = java.util.Properties()\n          "
  },
  {
    "path": "assets/fonts/OFL.txt",
    "chars": 4543,
    "preview": "Copyright 2010 The Josefin Sans Project Authors (https://github.com/ThomasJockin/JosefinSansFont-master), with Reserved "
  },
  {
    "path": "cliff.toml",
    "chars": 2082,
    "preview": "[remote.github]\nowner = \"ferraridamiano\"\nrepo = \"ConverterNOW\"\n\n[changelog]\nheader = \"\"\nbody = \"\"\"\n{%- macro remote_url("
  },
  {
    "path": "fastlane/metadata/android/ar/full_description.txt",
    "chars": 2341,
    "preview": "<b>Converter NOW هو محول فعال للوحدات والعُملات </b>\n✔️ <b>يقوم بتبسيط</b> عملية التحويل المُملة بين وحدات القياس إلى بِ"
  },
  {
    "path": "fastlane/metadata/android/ar/short_description.txt",
    "chars": 28,
    "preview": "محول وحدات بسيط ،فوري وسريع!"
  },
  {
    "path": "fastlane/metadata/android/ar/title.txt",
    "chars": 26,
    "preview": "Converter NOW: مُحول وحدات"
  },
  {
    "path": "fastlane/metadata/android/bn/full_description.txt",
    "chars": 2115,
    "preview": "<b>কনভার্টার NOW একটি কার্যকরী ইউনিট ও কারেন্সি কনভার্টার </b>\n✔️ <b>সহজ</b>  মাত্র কয়েক ক্লিকেই পরিমাপের বিভিন্ন এককে র"
  },
  {
    "path": "fastlane/metadata/android/bn/short_description.txt",
    "chars": 45,
    "preview": "একটি সহজ, তাৎক্ষণিক এবং দ্রুত ইউনিট কনভার্টার"
  },
  {
    "path": "fastlane/metadata/android/bn/title.txt",
    "chars": 28,
    "preview": "কনভার্টার NOW: ইউনিট কনভার্ট"
  },
  {
    "path": "fastlane/metadata/android/de-DE/full_description.txt",
    "chars": 2530,
    "preview": "<b>Converter NOW ist ein leistungsstarker Einheiten- und Währungsumrechner</b>\n✔️ <b>Vereinfache</b> den aufwendigen Umr"
  },
  {
    "path": "fastlane/metadata/android/de-DE/short_description.txt",
    "chars": 61,
    "preview": "Einfache, unmittelbare und schnelle Umrechnung von Einheiten!"
  },
  {
    "path": "fastlane/metadata/android/de-DE/title.txt",
    "chars": 18,
    "preview": "Einheitenumwandler"
  },
  {
    "path": "fastlane/metadata/android/el/full_description.txt",
    "chars": 2339,
    "preview": "<b>Converter NOW είναι ένα αποτελεσματικό εργαλείο για μετατροπή μονάδων και νομισμάτων </b>\n✔️ <b>Απλοποιεί</b> την κου"
  },
  {
    "path": "fastlane/metadata/android/el/short_description.txt",
    "chars": 53,
    "preview": "Ένας απλός, άμεσος και γρήγορος μετατροπέας μονάδων!\n"
  },
  {
    "path": "fastlane/metadata/android/el/title.txt",
    "chars": 19,
    "preview": "Μετατροπέας Μονάδων"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/24.txt",
    "chars": 318,
    "preview": "★ 3 new languages: Portoguese, French and Norwegian 🌐\n★ Bugfix of some translation and shoe size conversion 🔧\n\nThanks to"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/25.txt",
    "chars": 187,
    "preview": "★ Bugfix of numerical systems conversion 🔧\n\nWe also have a web app, check it out here: https://ferraridamiano.github.io/"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/26.txt",
    "chars": 328,
    "preview": "★ You can now set dark theme on old devices\n★ Dark theme get darker with AMOLED mode ⚫\n★ Added some units such as: penny"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/27.txt",
    "chars": 351,
    "preview": "★ Default language fix\n★ You can now set dark theme on old devices\n★ Dark theme get darker with AMOLED mode ⚫\n★ Added so"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/28.txt",
    "chars": 236,
    "preview": "★ Improved tablet support\n★ Added some new units\n★ Calculator improvements\n★ Bugfix exchange rate update\n★ Added Spanish"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/29.txt",
    "chars": 293,
    "preview": "★ Huge UI improvement for large screens\n★ Support for adaptive icon\n★ Added some new units\n★ Added a splash screen\n★ Cha"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/30.txt",
    "chars": 343,
    "preview": "★ Fix the icon bug with Android version below 8.0\n★ Huge UI improvement for large screens\n★ Support for adaptive icon\n★ "
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/31.txt",
    "chars": 302,
    "preview": "★ Improved the accessibility of the app\n★ Added an option to undo a \"Clear all\" operation\n★ Added indonesian and japanes"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/33.txt",
    "chars": 165,
    "preview": "★ Added app shortcut\n★ Small graphical tweaks\n★ Bugfix\n\nThanks to @the7thNightmare and 匿名 for your contributions!\n\nWhat "
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/34.txt",
    "chars": 157,
    "preview": "★ Now the app is available in arabic\n★ Small tweaks\n★ Bugfix\n\nThanks to Omer Maki for your contributions!\n\nWhat do you t"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/35.txt",
    "chars": 86,
    "preview": "★ Improved the calculator\n★ Bugfix\n\nWhat do you think about Converter NOW? Rate us! ✔️"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/36.txt",
    "chars": 190,
    "preview": "★ Migration to Material You\n★ Themed icons on Android 13+\n★ Added Polish translation\n★ Bugfixes\n\nThanks to @rehork for y"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/37.txt",
    "chars": 129,
    "preview": "★ Unit symbols are now always visible\n\nThanks to @rehork for your suggestion!\n\nWhat do you think about Converter NOW? Ra"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/38.txt",
    "chars": 236,
    "preview": "Introducing Converter NOW 4.0!\n- Finished the migration to Material You\n- Dynamic theming support on Android 12+\n- New i"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/39.txt",
    "chars": 131,
    "preview": "- Fixed bug with currencies page after v4 update\n- Improved polish translations\n\nWhat do you think about Converter NOW? "
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/40.txt",
    "chars": 341,
    "preview": "- Material you improvements\n- The calculator has a new look\n- Added dutch, chinese and traditional chinese translations\n"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/41.txt",
    "chars": 155,
    "preview": "- UI improvements\n- Improved french translation (credits: @Vsnmrn)\n- General improvements\n- Bugfix\n\nWhat do you think ab"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/42.txt",
    "chars": 279,
    "preview": "- You can now block the internet access to the app\n- Improved the license page\n- Added haptic feedback\n- Improved the ru"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/43.txt",
    "chars": 595,
    "preview": "🎨 <b>Custom Themes!</b> Give your app a unique touch by choosing your favorite theme.\n⚙️ <b>Optimized Settings Page!</b>"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/44.txt",
    "chars": 312,
    "preview": "🎨 <b>Graphic Enhancements</b> for big screens\n🌍 <b>Updated translations</b> Thanks to @rehork, @MajoranaOedipus, @FTno\n🐞"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/45.txt",
    "chars": 422,
    "preview": "⚙️ <b>New features</b>: use comma as decimal separator, paste number into the calculator, search with ctrl+K, Android 15"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/46.txt",
    "chars": 522,
    "preview": "⚙️ <b>New features</b>: hide unused units, improved default unit sorting, more units, improved conversion speed\n🌍 <b>Upd"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/47.txt",
    "chars": 193,
    "preview": "🐞 <b>Bug Fixes and General Improvements!</b> We've worked hard to provide you with an even better experience\n\n<b>Do you "
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/48.txt",
    "chars": 397,
    "preview": "⚙️ <b>New units of measure</b>: added density and new pressure units (Thanks to @Kheirlb)\n🌍 <b>Translation improvements<"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/49.txt",
    "chars": 136,
    "preview": "🐞 Fixed a bug related to the \"Hide units\" feature.\n\n<b>Do you like Converter NOW?</b> Leave a review and let us know wha"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/50.txt",
    "chars": 340,
    "preview": "🎨 <b>New logo!</b> Thanks to Giovanni Spitti for the suggestions\n🖌️ <b>Improved icons in the app</b>\n🌍 <b>Translation im"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/51.txt",
    "chars": 360,
    "preview": "🔢 View the <b>result preview</b> in the calculator (Thanks to Bisher Asil)\n⚙️ <b>Choose the property</b> to convert on s"
  },
  {
    "path": "fastlane/metadata/android/en-US/changelogs/52.txt",
    "chars": 361,
    "preview": "📤 <b>Import / export / delete</b> the app settings\n🔢 <b>Added several units of measurement</b>\n🌍 <b>Translation improvem"
  },
  {
    "path": "fastlane/metadata/android/en-US/full_description.txt",
    "chars": 2221,
    "preview": "<b>Converter NOW is an effective unit and currencies converter </b>\n✔️ <b>Simplify</b> the tedious conversion process be"
  },
  {
    "path": "fastlane/metadata/android/en-US/short_description.txt",
    "chars": 44,
    "preview": "A simple, immediate and fast unit converter!"
  },
  {
    "path": "fastlane/metadata/android/en-US/title.txt",
    "chars": 29,
    "preview": "Converter NOW: Unit Converter"
  },
  {
    "path": "fastlane/metadata/android/es-ES/changelogs/33.txt",
    "chars": 193,
    "preview": "★ Añadido atajo para aplicación\n★ Pequeñas mejoras gráficas\n★ Corrección de errores\n\n¡Gracias a @the7thNightmare y 匿名 po"
  },
  {
    "path": "fastlane/metadata/android/es-ES/full_description.txt",
    "chars": 2308,
    "preview": "<b>Converter NOW es un efectivo conversor de unidades y divisas </b>\n<b>Simplifique</b> el tedioso proceso de conversión"
  },
  {
    "path": "fastlane/metadata/android/es-ES/short_description.txt",
    "chars": 42,
    "preview": "¡Un conversor simple, inmediato y rápido!\n"
  },
  {
    "path": "fastlane/metadata/android/es-ES/title.txt",
    "chars": 22,
    "preview": "Conversor de unidades\n"
  },
  {
    "path": "fastlane/metadata/android/fr-FR/full_description.txt",
    "chars": 2500,
    "preview": "<b> Converter NOW est un convertisseur efficace d'unités et de devises </b>\n✔️ <b> Simplifiez </b> le fastidieux process"
  },
  {
    "path": "fastlane/metadata/android/fr-FR/short_description.txt",
    "chars": 44,
    "preview": "Un convertisseur simple, immédiat et rapide!"
  },
  {
    "path": "fastlane/metadata/android/fr-FR/title.txt",
    "chars": 38,
    "preview": "Converter NOW : Convertisseur d'unités"
  },
  {
    "path": "fastlane/metadata/android/hr/full_description.txt",
    "chars": 2183,
    "preview": "<b>Converter NOW je učinkovit konverter mjernih jedinica i valuta</b>\n✔️ <b>Pojednostavlja</b> dosadan postupak izračuna"
  },
  {
    "path": "fastlane/metadata/android/hr/short_description.txt",
    "chars": 27,
    "preview": "Konverter mjernih jedinica\n"
  },
  {
    "path": "fastlane/metadata/android/hr/title.txt",
    "chars": 27,
    "preview": "Konverter mjernih jedinica\n"
  },
  {
    "path": "fastlane/metadata/android/id/full_description.txt",
    "chars": 2166,
    "preview": "<b>Converter NOW merupakan alat konversi satuan dan kurs yang efektif </b>\n✔️ <b>Persingkat</b> proses konversi yang ber"
  },
  {
    "path": "fastlane/metadata/android/id/short_description.txt",
    "chars": 52,
    "preview": "Sebuah alat konversi yang simpel, segera, dan cepat!"
  },
  {
    "path": "fastlane/metadata/android/id/title.txt",
    "chars": 29,
    "preview": "Alat Konversi Satuan dan Kurs"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/24.txt",
    "chars": 322,
    "preview": "★ 3 nuove lingue: Portoghese, Francese e Norvegese 🌐\n★ Fix di traduzioni e della conversione della misura delle scarpe 🔧"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/25.txt",
    "chars": 185,
    "preview": "★ Fix della conversione delle basi numeriche 🔧\n\nAbbiamo anche una web app, guarda qui: https://ferraridamiano.github.io/"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/26.txt",
    "chars": 414,
    "preview": "★ Aggiunta la possibilità di impostare il tema scuro anche nei dispositivi più datati\n★ Il tema scuro si fa ancora più s"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/27.txt",
    "chars": 439,
    "preview": "★ Fix lingua predefinita\n★ Aggiunta la possibilità di impostare il tema scuro anche nei dispositivi più datati\n★ Il tema"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/28.txt",
    "chars": 270,
    "preview": "★ Supporto tablet migliorato\n★ Aggiunte alcune nuove unità\n★ Miglioramenti alla calcolatrice\n★ Bugfix aggiornamento del "
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/29.txt",
    "chars": 340,
    "preview": "★ Migliorato il supporto per i grandi schermi\n★ Supporto per l'icona adattiva\n★ Aggiunte alcune unità di misura\n★ Ora pu"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/30.txt",
    "chars": 396,
    "preview": "★ Fix bug icona con versione Android inferiore alla 8.0\n★ Migliorato il supporto per i grandi schermi\n★ Supporto per l'i"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/31.txt",
    "chars": 324,
    "preview": "★ Migliorata l'accessibilità dell'app\n★ Aggiunta la possibilità di annullare l'operazione \"Cancella tutto\"\n★ Aggiunto il"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/33.txt",
    "chars": 117,
    "preview": "★ Aggiunte le app shortcut\n★ Piccoli miglioramenti grafici\n★ Bugfix\n\nCosa ne pensi di Converter NOW? Recensiscici! ✔️"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/34.txt",
    "chars": 162,
    "preview": "★ Ora l'app è disponibile in lingua araba\n★ Piccoli ritocchi\n★ Bugfix\n\nGrazie a Omer Maki per il suo contributo!\n\nCosa n"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/35.txt",
    "chars": 84,
    "preview": "★ Calcolatrice migliorata\n★ Bugfix\n\nCosa ne pensi di Converter NOW? Recensiscici! ✔️"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/36.txt",
    "chars": 192,
    "preview": "★ Migrazione a Material you\n★ Themed icons su Android 13+\n★ Aggiunta traduzione in Polacco\n★ Bugfixes\n\nGrazie a @rehork "
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/37.txt",
    "chars": 141,
    "preview": "★ I simboli delle unità sono ora sempre visibili\n\nGrazie a @rehork per il tuo suggerimento!\n\nCosa ne pensi di Converter "
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/38.txt",
    "chars": 239,
    "preview": "Ecco Converter NOW 4.0!\n- Terminata la migrazione al Material You\n- Supporto al tema dinamico su Android 12+\n- Nuove ico"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/39.txt",
    "chars": 129,
    "preview": "- Fixed bug with currencies page after v4 update\n- Improved polish translations\n\nCosa ne pensi di Converter NOW? Recensi"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/40.txt",
    "chars": 391,
    "preview": "- Miglioramenti legati al material you\n- La calcolatrice ha un nuovo look\n- Aggiunte le seguenti traduzioni: olandese, c"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/41.txt",
    "chars": 199,
    "preview": "- Piccoli miglioramenti all'interfaccia utente\n- Migliorata la traduzione francese (crediti: @Vsnmrn)\n- Miglioramenti ge"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/42.txt",
    "chars": 330,
    "preview": "- Aggiunta la possibilità di bloccare l'accesso ad internet\n- Migliorata la pagina delle licenze\n- Aggiunto il feedback "
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/43.txt",
    "chars": 631,
    "preview": "🎨 <b>Temi personalizzati!</b> Dai un tocco unico all'app scegliendo il tema che più ti piace.\n⚙️ <b>Pagina delle imposta"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/44.txt",
    "chars": 324,
    "preview": "🎨 <b>Ritocchi grafici</b> per i grandi schermi\n🌍 <b>Traduzioni aggiornate</b> Grazie a @rehork, @MajoranaOedipus, @FTno\n"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/45.txt",
    "chars": 447,
    "preview": "⚙️ <b>Nuove funzioni</b>: usa la virgola come separatore decimale, incolla i numeri nella calcolatrice, cerca con ctrl+K"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/46.txt",
    "chars": 625,
    "preview": "⚙️ <b>Nuove funzioni</b>: nascondi le unità di misura che non usi, ordinamento delle unità di default migliorato, più un"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/47.txt",
    "chars": 204,
    "preview": "🐞 <b>Correzioni di bug e miglioramenti generali!</b> Abbiamo lavorato sodo per offrirti un'esperienza sempre migliore\n\n<"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/48.txt",
    "chars": 437,
    "preview": "⚙️ <b>Nuove unità di misura</b>: aggiunta la densità e nuove unità di pressione (Grazie a @Kheirlb)\n🌍 <b>Miglioramento a"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/49.txt",
    "chars": 149,
    "preview": "🐞 Correzione di un bug relativo alla funzione \"Nascondi unità\"\n\n<b>Ti piace Converter NOW?</b> Lascia una recensione e f"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/50.txt",
    "chars": 369,
    "preview": "🎨 <b>Nuovo logo!</b> Gazie a Giovanni Spitti per i suggerimenti\n🖌️ <b>Migliorate le icone dentro l'app</b>\n🌍 <b>Migliora"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/51.txt",
    "chars": 402,
    "preview": "🔢 Visualizza l'<b>anteprima del risultato</b> nella calcolatrice (Grazie a Bisher Asil)\n⚙️ <b>Scegli la proprietà</b> da"
  },
  {
    "path": "fastlane/metadata/android/it-IT/changelogs/52.txt",
    "chars": 391,
    "preview": "📤 <b>Importa / esporta / elimina</b> le impostazioni dell'app\n🔢 <b>Aggiunte molte unità di misura</b>\n🌍 <b>Miglioramenti"
  },
  {
    "path": "fastlane/metadata/android/it-IT/full_description.txt",
    "chars": 2319,
    "preview": "<b>Converter NOW è un efficace convertitore di unità di misura e di valute made in Italy</b>\n✔️ <b>Semplifica</b> il noi"
  },
  {
    "path": "fastlane/metadata/android/it-IT/short_description.txt",
    "chars": 54,
    "preview": "Un convertitore di unità semplice, immediato e veloce!"
  },
  {
    "path": "fastlane/metadata/android/it-IT/title.txt",
    "chars": 21,
    "preview": "Convertitore di Unità"
  },
  {
    "path": "fastlane/metadata/android/ja/full_description.txt",
    "chars": 1199,
    "preview": "<b>Converter NOW は効果的な単位と通貨の変換器です</b>\n✔️ <b>簡単</b> 数回クリックするだけで、測定単位間の面倒な変換プロセスが完了します。\n🚀 <b>迅速かつ即時</b>: 入力を開始するだけで、すぐに他のす"
  },
  {
    "path": "fastlane/metadata/android/ja/short_description.txt",
    "chars": 20,
    "preview": "シンプルで即時かつ高速な単位換算アプリ!"
  },
  {
    "path": "fastlane/metadata/android/ja/title.txt",
    "chars": 19,
    "preview": "Converter NOW: 単位換算"
  },
  {
    "path": "fastlane/metadata/android/nl_NL/full_description.txt",
    "chars": 2203,
    "preview": "<b>Converter NOW is een effectieve eenheden en valuta omrekentool </b>\n✔️ <b>Versimpel</b> het omslachtige omrekenen van"
  },
  {
    "path": "fastlane/metadata/android/nl_NL/short_description.txt",
    "chars": 70,
    "preview": "Een simpele, onmiddelijke en snelle manier om eenheden om te rekenen!\n"
  },
  {
    "path": "fastlane/metadata/android/nl_NL/title.txt",
    "chars": 13,
    "preview": "Converter NOW"
  },
  {
    "path": "fastlane/metadata/android/pl-PL/full_description.txt",
    "chars": 2362,
    "preview": "<b>Converter NOW to skuteczny przelicznik jednostek miar i walut </b>\n✔️ <b>Uprość</b> żmudny proces konwersji jednostek"
  },
  {
    "path": "fastlane/metadata/android/pl-PL/short_description.txt",
    "chars": 43,
    "preview": "Prosty i szybki przelicznik jednostek miar!"
  },
  {
    "path": "fastlane/metadata/android/pl-PL/title.txt",
    "chars": 26,
    "preview": "Przelicznik jednostek miar"
  },
  {
    "path": "fastlane/metadata/android/pt-BR/full_description.txt",
    "chars": 2314,
    "preview": "<b>Converter NOW é um conversor eficaz de unidades e moedas</b>\n✔️ <b>Simplificar</b> em poucos cliques o tedioso proces"
  },
  {
    "path": "fastlane/metadata/android/pt-BR/short_description.txt",
    "chars": 40,
    "preview": "Um conversor simples, imediato e rápido!"
  },
  {
    "path": "fastlane/metadata/android/ru-RU/full_description.txt",
    "chars": 2424,
    "preview": "<b>Converter NOW - это эффективный конвертер единиц измерения и валют</b>\n✔️ <b>Простой</b>: скучный процесс по переводу"
  },
  {
    "path": "fastlane/metadata/android/ru-RU/short_description.txt",
    "chars": 42,
    "preview": "Простой, эффективный и быстрый конвертер!\n"
  },
  {
    "path": "fastlane/metadata/android/ru-RU/title.txt",
    "chars": 36,
    "preview": "Converter NOW: преобразование единиц"
  },
  {
    "path": "fastlane/metadata/android/tr-TR/changelogs/24.txt",
    "chars": 336,
    "preview": "★ 3 Yeni Dil: Portekizce, Fransızca ve Norveççe 🌐\n★ Bazı çeviriler ve ayakkabı boyutu dönüşüm hatası düzeltildi 🔧\n\n@Mezy"
  },
  {
    "path": "fastlane/metadata/android/tr-TR/changelogs/25.txt",
    "chars": 204,
    "preview": "★ Sayısal sistem dönüşümleri hatası düzeltildi 🔧\n\nAyrıca bir web uygulamamız da var! 🖥️ Şurada: https://ferraridamiano.g"
  },
  {
    "path": "fastlane/metadata/android/tr-TR/changelogs/26.txt",
    "chars": 343,
    "preview": "★ Eski cihazlarda karanlık tema seçilebilir\n★ Koyu tema, AMOLED moduyla daha da koyu ⚫\n★ Pennyweights, ons, taş, sıvı on"
  },
  {
    "path": "fastlane/metadata/android/tr-TR/changelogs/27.txt",
    "chars": 371,
    "preview": "★ Varsayılan dil düzeltmesi\n★ Eski cihazlarda karanlık tema seçilebilir\n★ Koyu tema, AMOLED moduyla daha da koyu ⚫\n★ Pen"
  },
  {
    "path": "fastlane/metadata/android/tr-TR/full_description.txt",
    "chars": 2108,
    "preview": "<b>Converter NOW efektif ölçü ve para birimleri dönüştürücüdür </b>\n✔️ Birkaç tıklamayla ölçü birimleri arasındaki sıkıc"
  },
  {
    "path": "fastlane/metadata/android/tr-TR/short_description.txt",
    "chars": 33,
    "preview": "Basit ve efektif bir dönüştürücü!"
  },
  {
    "path": "fastlane/metadata/android/zh/full_description.txt",
    "chars": 968,
    "preview": "<b>Converter NOW 是一个有力的单位和货币转换器</b>\n✔️ <b>简单</b> 只需点击几下、即可完成计量单位之间繁琐的转换过程。\n🚀 它<b>快速且易于使用</b>:只需开始输入、即可立即与所有其他测量单位进行实时转换。"
  },
  {
    "path": "fastlane/metadata/android/zh/short_description.txt",
    "chars": 17,
    "preview": "一个简单、即时和快速的单位转换器!"
  },
  {
    "path": "fastlane/metadata/android/zh/title.txt",
    "chars": 20,
    "preview": "Converter NOW: 单位转换器"
  },
  {
    "path": "fastlane/metadata/android/zh-TW/full_description.txt",
    "chars": 993,
    "preview": "<b>Converter NOW 是一個有力的單位與貨幣轉換器</b>\n✔️ <b>簡化</b>繁瑣的的轉換處裡,只需點擊幾次即可轉換以下計量的單位。\n🚀 <b>快速且即時</b>:只需開始輸入,您就會立即獲得所有計量單位即時轉換。\n🖌️ "
  },
  {
    "path": "fastlane/metadata/android/zh-TW/short_description.txt",
    "chars": 18,
    "preview": "一個簡單、即時且快速的單位轉換器!\n"
  },
  {
    "path": "firebase.json",
    "chars": 239,
    "preview": "{\n  \"hosting\": {\n    \"public\": \"build/web\",\n    \"ignore\": [\n      \"firebase.json\",\n      \"**/.*\",\n      \"**/node_modules"
  },
  {
    "path": "integration_test/large_display_test.dart",
    "chars": 15536,
    "preview": "import 'package:flutter_test/flutter_test.dart';\nimport 'package:integration_test/integration_test.dart';\nimport 'packag"
  },
  {
    "path": "integration_test/small_display_test.dart",
    "chars": 16613,
    "preview": "import 'package:flutter_test/flutter_test.dart';\nimport 'package:integration_test/integration_test.dart';\nimport 'packag"
  },
  {
    "path": "integration_test/utils.dart",
    "chars": 961,
    "preview": "import 'package:flutter/gestures.dart';\nimport 'package:flutter/material.dart';\nimport 'package:flutter_test/flutter_tes"
  },
  {
    "path": "lib/app_router.dart",
    "chars": 5731,
    "preview": "import 'package:converterpro/models/conversions.dart';\nimport 'package:converterpro/models/hide_units.dart';\nimport 'pac"
  },
  {
    "path": "lib/data/default_order.dart",
    "chars": 6929,
    "preview": "import 'package:converterpro/utils/utils.dart';\nimport 'package:units_converter/units_converter.dart';\n\nconst defaultPro"
  },
  {
    "path": "lib/data/property_unit_maps.dart",
    "chars": 12654,
    "preview": "import 'package:flutter/cupertino.dart';\nimport 'package:translations/app_localizations.dart';\nimport 'package:units_con"
  },
  {
    "path": "lib/helpers/responsive_helper.dart",
    "chars": 543,
    "preview": "import 'package:converterpro/styles/consts.dart';\n\ndouble responsivePadding(double displayWidth) => displayWidth * 0.03;"
  },
  {
    "path": "lib/main.dart",
    "chars": 3894,
    "preview": "import 'package:converterpro/app_router.dart';\nimport 'package:flutter/foundation.dart';\nimport 'package:flutter/service"
  },
  {
    "path": "lib/models/conversions.dart",
    "chars": 6225,
    "preview": "import 'package:converterpro/models/order.dart';\nimport 'package:converterpro/models/properties_list.dart';\nimport 'pack"
  },
  {
    "path": "lib/models/currencies.dart",
    "chars": 4915,
    "preview": "import 'dart:convert';\nimport 'package:converterpro/models/settings.dart';\nimport 'package:converterpro/utils/utils.dart"
  },
  {
    "path": "lib/models/hide_units.dart",
    "chars": 2397,
    "preview": "import 'package:collection/collection.dart';\nimport 'package:converterpro/data/default_order.dart';\nimport 'package:conv"
  },
  {
    "path": "lib/models/import_export.dart",
    "chars": 7332,
    "preview": "import 'dart:convert';\nimport 'package:collection/collection.dart';\nimport 'package:converterpro/data/default_order.dart"
  },
  {
    "path": "lib/models/order.dart",
    "chars": 5502,
    "preview": "import 'package:collection/collection.dart';\nimport 'package:converterpro/data/default_order.dart';\nimport 'package:conv"
  },
  {
    "path": "lib/models/properties_list.dart",
    "chars": 5403,
    "preview": "import 'package:converterpro/models/currencies.dart';\nimport 'package:converterpro/models/settings.dart';\nimport 'packag"
  },
  {
    "path": "lib/models/settings.dart",
    "chars": 6005,
    "preview": "import 'dart:ui';\nimport 'package:converterpro/styles/consts.dart';\nimport 'package:flutter/material.dart';\nimport 'pack"
  },
  {
    "path": "lib/pages/app_scaffold.dart",
    "chars": 6852,
    "preview": "import 'package:converterpro/app_router.dart';\nimport 'package:converterpro/helpers/responsive_helper.dart';\nimport 'pac"
  },
  {
    "path": "lib/pages/choose_property_page.dart",
    "chars": 4661,
    "preview": "import 'package:converterpro/data/property_unit_maps.dart';\nimport 'package:converterpro/models/order.dart';\nimport 'pac"
  },
  {
    "path": "lib/pages/conversion_page.dart",
    "chars": 8840,
    "preview": "import 'package:converterpro/app_router.dart';\nimport 'package:converterpro/helpers/responsive_helper.dart';\nimport 'pac"
  },
  {
    "path": "lib/pages/custom_drawer.dart",
    "chars": 6737,
    "preview": "import 'package:converterpro/models/order.dart';\nimport 'package:converterpro/utils/navigator_utils.dart';\nimport 'packa"
  },
  {
    "path": "lib/pages/error_page.dart",
    "chars": 1187,
    "preview": "import 'package:flutter/material.dart';\nimport 'package:go_router/go_router.dart';\nimport 'package:translations/app_loca"
  },
  {
    "path": "lib/pages/hide_units_page.dart",
    "chars": 3211,
    "preview": "import 'package:converterpro/app_router.dart';\nimport 'package:converterpro/models/order.dart';\nimport 'package:converte"
  },
  {
    "path": "lib/pages/initial_page.dart",
    "chars": 1767,
    "preview": "import 'package:converterpro/app_router.dart';\nimport 'package:converterpro/models/order.dart';\nimport 'package:converte"
  },
  {
    "path": "lib/pages/reorder_page.dart",
    "chars": 3503,
    "preview": "import 'package:translations/app_localizations.dart';\nimport 'package:flutter/material.dart';\n\ntypedef Item = ({int id, "
  },
  {
    "path": "lib/pages/reorder_properties_page.dart",
    "chars": 1968,
    "preview": "import 'package:converterpro/models/order.dart';\nimport 'package:converterpro/data/default_order.dart';\nimport 'package:"
  },
  {
    "path": "lib/pages/reorder_units_page.dart",
    "chars": 4021,
    "preview": "import 'package:converterpro/app_router.dart';\nimport 'package:converterpro/models/order.dart';\nimport 'package:converte"
  },
  {
    "path": "lib/pages/search_page.dart",
    "chars": 3052,
    "preview": "import 'package:converterpro/data/property_unit_maps.dart';\nimport 'package:converterpro/utils/utils.dart';\nimport 'pack"
  },
  {
    "path": "lib/pages/select_units_page.dart",
    "chars": 4290,
    "preview": "import 'package:converterpro/data/default_order.dart';\nimport 'package:converterpro/data/property_unit_maps.dart';\nimpor"
  },
  {
    "path": "lib/pages/settings_page.dart",
    "chars": 29821,
    "preview": "import 'dart:convert';\nimport 'dart:io';\nimport 'package:converterpro/models/currencies.dart';\nimport 'package:converter"
  },
  {
    "path": "lib/pages/splash_screen.dart",
    "chars": 1779,
    "preview": "import 'package:collection/collection.dart';\nimport 'package:converterpro/app_router.dart';\nimport 'package:converterpro"
  },
  {
    "path": "lib/styles/consts.dart",
    "chars": 822,
    "preview": "import 'package:flutter/material.dart';\n\n/// trigger from classic drawer to drawer fixed open\nconst double pixelFixedDra"
  },
  {
    "path": "lib/utils/navigator_utils.dart",
    "chars": 1167,
    "preview": "import 'package:converterpro/utils/utils.dart';\nimport 'package:flutter/material.dart';\nimport 'package:go_router/go_rou"
  },
  {
    "path": "lib/utils/palette.dart",
    "chars": 3555,
    "preview": "import 'package:converterpro/utils/utils.dart';\nimport 'package:flutter/material.dart';\n\nclass Palette extends StatefulW"
  },
  {
    "path": "lib/utils/utils.dart",
    "chars": 4057,
    "preview": "// ignore_for_file: constant_identifier_names\nimport 'dart:io';\nimport 'package:flutter/foundation.dart';\nimport 'packag"
  },
  {
    "path": "lib/utils/utils_widgets.dart",
    "chars": 13444,
    "preview": "import 'package:converterpro/data/property_unit_maps.dart';\nimport 'package:converterpro/utils/utils.dart';\nimport 'pack"
  },
  {
    "path": "linux/.gitignore",
    "chars": 18,
    "preview": "flutter/ephemeral\n"
  },
  {
    "path": "linux/CMakeLists.txt",
    "chars": 4776,
    "preview": "# Project-level configuration.\ncmake_minimum_required(VERSION 3.13)\nproject(runner LANGUAGES CXX)\n\n# The name of the exe"
  },
  {
    "path": "linux/flutter/CMakeLists.txt",
    "chars": 2815,
    "preview": "# This file controls Flutter-level build steps. It should not be edited.\ncmake_minimum_required(VERSION 3.10)\n\nset(EPHEM"
  },
  {
    "path": "linux/flutter/generated_plugin_registrant.cc",
    "chars": 1199,
    "preview": "//\n//  Generated file. Do not edit.\n//\n\n// clang-format off\n\n#include \"generated_plugin_registrant.h\"\n\n#include <dynamic"
  },
  {
    "path": "linux/flutter/generated_plugin_registrant.h",
    "chars": 303,
    "preview": "//\n//  Generated file. Do not edit.\n//\n\n// clang-format off\n\n#ifndef GENERATED_PLUGIN_REGISTRANT_\n#define GENERATED_PLUG"
  },
  {
    "path": "linux/flutter/generated_plugins.cmake",
    "chars": 805,
    "preview": "#\n# Generated file, do not edit.\n#\n\nlist(APPEND FLUTTER_PLUGIN_LIST\n  dynamic_color\n  handy_window\n  url_launcher_linux\n"
  },
  {
    "path": "linux/io.github.ferraridamiano.ConverterNOW.desktop",
    "chars": 294,
    "preview": "[Desktop Entry]\nName=Converter NOW\nComment=A Unit and Currencies Converter. It is immediate, fast and easy to use!\nExec="
  },
  {
    "path": "linux/io.github.ferraridamiano.ConverterNOW.metainfo.xml",
    "chars": 11961,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<component type=\"desktop-application\">\n  <id>io.github.ferraridamiano.ConverterNO"
  },
  {
    "path": "linux/runner/CMakeLists.txt",
    "chars": 974,
    "preview": "cmake_minimum_required(VERSION 3.13)\nproject(runner LANGUAGES CXX)\n\n# Define the application target. To change its name,"
  },
  {
    "path": "linux/runner/main.cc",
    "chars": 180,
    "preview": "#include \"my_application.h\"\n\nint main(int argc, char** argv) {\n  g_autoptr(MyApplication) app = my_application_new();\n  "
  },
  {
    "path": "linux/runner/my_application.cc",
    "chars": 5533,
    "preview": "#include \"my_application.h\"\n\n#include <flutter_linux/flutter_linux.h>\n#ifdef GDK_WINDOWING_X11\n#include <gdk/gdkx.h>\n#en"
  },
  {
    "path": "linux/runner/my_application.h",
    "chars": 451,
    "preview": "#ifndef FLUTTER_MY_APPLICATION_H_\n#define FLUTTER_MY_APPLICATION_H_\n\n#include <gtk/gtk.h>\n\nG_DECLARE_FINAL_TYPE(MyApplic"
  },
  {
    "path": "packages/calculator_widget/analysis_options.yaml",
    "chars": 62,
    "preview": "include: package:flutter_lints/flutter.yaml\n\nlinter:\n  rules:\n"
  },
  {
    "path": "packages/calculator_widget/lib/animated_button.dart",
    "chars": 4594,
    "preview": "import 'dart:io';\nimport 'package:flutter/foundation.dart';\nimport 'package:flutter/material.dart';\n\nclass AnimatedButto"
  },
  {
    "path": "packages/calculator_widget/lib/calculator_model.dart",
    "chars": 10086,
    "preview": "import 'package:decimal/decimal.dart';\nimport 'package:flutter_riverpod/flutter_riverpod.dart';\nimport 'package:flutter_"
  },
  {
    "path": "packages/calculator_widget/lib/calculator_widget.dart",
    "chars": 16459,
    "preview": "import 'package:calculator_widget/animated_button.dart';\nimport 'package:calculator_widget/calculator_model.dart';\nimpor"
  }
]

// ... and 44 more files (download for full content)

About this extraction

This page contains the full source code of the ferraridamiano/ConverterNOW GitHub repository, extracted and formatted as plain text for AI agents and large language models (LLMs). The extraction includes 244 files (780.7 KB), approximately 229.4k tokens, and a symbol index with 222 extracted functions, classes, methods, constants, and types. Use this with OpenClaw, Claude, ChatGPT, Cursor, Windsurf, or any other AI tool that accepts text input. You can copy the full output to your clipboard or download it as a .txt file.

Extracted by GitExtract — free GitHub repo to text converter for AI. Built by Nikandr Surkov.

Copied to clipboard!