mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-03 17:40:43 +00:00
Merge branch 'main' of https://github.com/cake-tech/cake_wallet into CW-269-research-if-we-can-avoid-re-requesting-camera-permission-on-web-view-in-buy-screen
This commit is contained in:
commit
3cb5e5b2ee
104 changed files with 3037 additions and 1217 deletions
56
.github/workflows/cache_dependencies.yml
vendored
Normal file
56
.github/workflows/cache_dependencies.yml
vendored
Normal file
|
@ -0,0 +1,56 @@
|
|||
name: Cache Dependencies
|
||||
|
||||
on:
|
||||
push:
|
||||
branches: [ main ]
|
||||
|
||||
jobs:
|
||||
test:
|
||||
|
||||
runs-on: ubuntu-18.04
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v2
|
||||
- uses: actions/setup-java@v1
|
||||
with:
|
||||
java-version: '8.x'
|
||||
|
||||
- name: Flutter action
|
||||
uses: subosito/flutter-action@v1
|
||||
with:
|
||||
flutter-version: '3.3.x'
|
||||
channel: stable
|
||||
|
||||
- name: Install package dependencies
|
||||
run: sudo apt-get install -y curl unzip automake build-essential file pkg-config git python libtool libtinfo5 cmake clang
|
||||
|
||||
- name: Execute Build and Setup Commands
|
||||
run: |
|
||||
sudo mkdir -p /opt/android
|
||||
sudo chown $USER /opt/android
|
||||
cd /opt/android
|
||||
git clone https://github.com/cake-tech/cake_wallet.git --branch main
|
||||
cd cake_wallet/scripts/android/
|
||||
./install_ndk.sh
|
||||
source ./app_env.sh cakewallet
|
||||
./app_config.sh
|
||||
|
||||
- name: Cache Externals
|
||||
id: cache-externals
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: |
|
||||
/opt/android/cake_wallet/cw_haven/android/.cxx
|
||||
/opt/android/cake_wallet/cw_haven/ios/External
|
||||
/opt/android/cake_wallet/cw_monero/android/.cxx
|
||||
/opt/android/cake_wallet/cw_monero/ios/External
|
||||
/opt/android/cake_wallet/cw_shared_external/ios/External
|
||||
key: ${{ hashFiles('**/build_monero.sh', '**/build_haven.sh') }}
|
||||
|
||||
- if: ${{ steps.cache-externals.outputs.cache-hit != 'true' }}
|
||||
name: Generate Externals
|
||||
run: |
|
||||
cd /opt/android/cake_wallet/scripts/android/
|
||||
source ./app_env.sh cakewallet
|
||||
./build_all.sh
|
||||
./copy_monero_deps.sh
|
40
.github/workflows/pr_test_build.yml
vendored
40
.github/workflows/pr_test_build.yml
vendored
|
@ -8,6 +8,9 @@ jobs:
|
|||
test:
|
||||
|
||||
runs-on: ubuntu-18.04
|
||||
env:
|
||||
STORE_PASS: test@cake_wallet
|
||||
KEY_PASS: test@cake_wallet
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v2
|
||||
|
@ -34,6 +37,24 @@ jobs:
|
|||
./install_ndk.sh
|
||||
source ./app_env.sh cakewallet
|
||||
./app_config.sh
|
||||
|
||||
- name: Cache Externals
|
||||
id: cache-externals
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: |
|
||||
/opt/android/cake_wallet/cw_haven/android/.cxx
|
||||
/opt/android/cake_wallet/cw_haven/ios/External
|
||||
/opt/android/cake_wallet/cw_monero/android/.cxx
|
||||
/opt/android/cake_wallet/cw_monero/ios/External
|
||||
/opt/android/cake_wallet/cw_shared_external/ios/External
|
||||
key: ${{ hashFiles('**/build_monero.sh', '**/build_haven.sh') }}
|
||||
|
||||
- if: ${{ steps.cache-externals.outputs.cache-hit != 'true' }}
|
||||
name: Generate Externals
|
||||
run: |
|
||||
cd /opt/android/cake_wallet/scripts/android/
|
||||
source ./app_env.sh cakewallet
|
||||
./build_all.sh
|
||||
./copy_monero_deps.sh
|
||||
|
||||
|
@ -45,12 +66,12 @@ jobs:
|
|||
- name: Generate KeyStore
|
||||
run: |
|
||||
cd /opt/android/cake_wallet/android/app
|
||||
keytool -genkey -v -keystore key.jks -keyalg RSA -keysize 2048 -validity 10000 -alias testKey -noprompt -dname "CN=CakeWallet, OU=CakeWallet, O=CakeWallet, L=Florida, S=America, C=USA" -storepass ${{ secrets.STORE_PASS }} -keypass ${{ secrets.KEY_PASS }}
|
||||
keytool -genkey -v -keystore key.jks -keyalg RSA -keysize 2048 -validity 10000 -alias testKey -noprompt -dname "CN=CakeWallet, OU=CakeWallet, O=CakeWallet, L=Florida, S=America, C=USA" -storepass $STORE_PASS -keypass $KEY_PASS
|
||||
|
||||
- name: Generate key properties
|
||||
run: |
|
||||
cd /opt/android/cake_wallet
|
||||
flutter packages pub run tool/generate_android_key_properties.dart keyAlias=testKey storeFile=key.jks storePassword=${{ secrets.STORE_PASS }} keyPassword=${{ secrets.KEY_PASS }}
|
||||
flutter packages pub run tool/generate_android_key_properties.dart keyAlias=testKey storeFile=key.jks storePassword=$STORE_PASS keyPassword=$KEY_PASS
|
||||
|
||||
- name: Generate localization
|
||||
run: |
|
||||
|
@ -111,19 +132,20 @@ jobs:
|
|||
# --token ${{ secrets.APP_CENTER_TOKEN }} \
|
||||
# --quiet
|
||||
|
||||
- name: Send Test APK
|
||||
run: |
|
||||
cd /opt/android/cake_wallet
|
||||
var=$(curl --upload-file build/app/outputs/apk/release/app-release.apk https://transfer.sh/$GITHUB_HEAD_REF.apk -H "Max-Days: 10")
|
||||
curl ${{ secrets.SLACK_WEB_HOOK }} -H "Content-Type: application/json" -d '{"apk_link": "'"$var"'","ticket": "'"$GITHUB_HEAD_REF"'"}'
|
||||
|
||||
- name: Rename apk file
|
||||
run: |
|
||||
cd /opt/android/cake_wallet/build/app/outputs/apk/release
|
||||
mkdir test-apk
|
||||
mv app-release.apk test-apk/$GITHUB_HEAD_REF.apk
|
||||
cp app-release.apk test-apk/$GITHUB_HEAD_REF.apk
|
||||
|
||||
- name: Upload Artifact
|
||||
uses: kittaakos/upload-artifact-as-is@v0
|
||||
with:
|
||||
path: /opt/android/cake_wallet/build/app/outputs/apk/release/test-apk/
|
||||
|
||||
- name: Send Test APK
|
||||
continue-on-error: true
|
||||
run: |
|
||||
cd /opt/android/cake_wallet
|
||||
var=$(curl --upload-file build/app/outputs/apk/release/app-release.apk https://transfer.sh/$GITHUB_HEAD_REF.apk -H "Max-Days: 10")
|
||||
curl ${{ secrets.SLACK_WEB_HOOK }} -H "Content-Type: application/json" -d '{"apk_link": "'"$var"'","ticket": "'"$GITHUB_HEAD_REF"'"}'
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
MIT License
|
||||
|
||||
Copyright (c) 2022 Cake Labs LLC
|
||||
Copyright (c) 2018-2023 Cake Labs LLC
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
|
|
53
README.md
53
README.md
|
@ -76,3 +76,56 @@ We have 24/7 free support. Please contact support@cakewallet.com
|
|||
More instructions to follow
|
||||
|
||||
For instructions on how to build for Android: please view file `howto-build-android.md`
|
||||
|
||||
# Contributing
|
||||
|
||||
## Improving translations
|
||||
|
||||
Edit the applicable `strings_XX.arb` file in `res/values/` and open a pull request with the changes.
|
||||
|
||||
## Current list of language files:
|
||||
|
||||
- English
|
||||
- Spanish
|
||||
- French
|
||||
- German
|
||||
- Italian
|
||||
- Portugese
|
||||
- Dutch
|
||||
- Polish
|
||||
- Croatian
|
||||
- Russian
|
||||
- Ukranian
|
||||
- Hindi
|
||||
- Japanese
|
||||
- Chinese
|
||||
- Korean
|
||||
- Arabic
|
||||
|
||||
## Add a new language
|
||||
|
||||
1. Create a new `strings_XX.arb` file in `res/values/`, replacing XX with the language's [ISO 639-1 code](https://en.wikipedia.org/wiki/ISO_639-1).
|
||||
|
||||
2. Edit the strings in this file, replacing XXX below with the translation for each string.
|
||||
|
||||
`"welcome" : "Welcome to",` -> `"welcome" : "XXX",`
|
||||
|
||||
3. For strings where there is a variable, denoted by a $ symbol and braces, such as ${status}, the string in braces should not be translated. For example, when editing line 106:
|
||||
|
||||
"time" : "${minutes}m ${seconds}s"
|
||||
|
||||
The only parts to be translated, if needed, are the values m and s after the variables.
|
||||
|
||||
4. Add the language to `lib/entities/language_service.dart` under both `supportedLocales` and `localeCountryCode`. Use the name of the language in the local language and in English in parentheses after for `supportedLocales`. Use the [ISO 3166-1 alpha-3 code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3) for `localeCountryCode`. You must choose one country, so choose the country with the most native speakers of this language or is otherwise best associated with this language.
|
||||
|
||||
5. Add a relevant flag to `assets/images/flags/XXXX.png`, replacing XXXX with the 3 digit localeCountryCode. The image must be 42x36 pixels with a 3 pixels of transparent margin on all 4 sides.
|
||||
|
||||
## Add a new fiat currency
|
||||
|
||||
1. Check with [Cake Wallet support](https://guides.cakewallet.com) to see if the desired new fiat currency is available through our fiat API. Not all fiat currencies are.
|
||||
|
||||
2. If the currency is associated strongly with a specific issuing country, map the [ISO 4217](https://en.wikipedia.org/wiki/ISO_4217) currency code with the applicable [ISO 3166-1 alpha-3 code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3) in `lib/entities/fiat_currency.dart`. If the currency is used in a whole region or organization, then map with a reasonable interpretation of this (eg: eur countryCode for EUR symbol).
|
||||
|
||||
3. Add the raw mapping underneath in `lib/entities/fiat_currency.dart` following the same format as the others.
|
||||
|
||||
4. Add a flag of the issuing country or organization to `assets/images/flags/XXXX.png`, replacing XXXX with the ISO 3166-1 alpha-3 code used above (eg: `usa.png`, `eur.png`). Do not add this if the flag with the same name already exists. The image must be 42x36 pixels with a 3 pixels of transparent margin on all 4 sides.
|
||||
|
|
|
@ -17,7 +17,7 @@
|
|||
android:requestLegacyExternalStorage="true">
|
||||
<activity
|
||||
android:name=".MainActivity"
|
||||
android:launchMode="singleTop"
|
||||
android:launchMode="singleInstance"
|
||||
android:theme="@style/LaunchTheme"
|
||||
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
|
||||
android:hardwareAccelerated="true"
|
||||
|
@ -40,6 +40,15 @@
|
|||
android:scheme="cakewallet"
|
||||
android:host="y.at" />
|
||||
</intent-filter>
|
||||
<!-- currencies qr code scheme -->
|
||||
<intent-filter android:autoVerify="true">
|
||||
<action android:name="android.intent.action.VIEW" />
|
||||
<category android:name="android.intent.category.DEFAULT" />
|
||||
<category android:name="android.intent.category.BROWSABLE" />
|
||||
<data android:scheme="bitcoin" />
|
||||
<data android:scheme="monero" />
|
||||
<data android:scheme="litecoin" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
<meta-data
|
||||
android:name="flutterEmbedding"
|
||||
|
|
BIN
assets/images/2.0x/privacy_menu.png
Normal file
BIN
assets/images/2.0x/privacy_menu.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.3 KiB |
BIN
assets/images/3.0x/privacy_menu.png
Normal file
BIN
assets/images/3.0x/privacy_menu.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.9 KiB |
BIN
assets/images/flags/sau.png
Normal file
BIN
assets/images/flags/sau.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 476 B |
Binary file not shown.
Before Width: | Height: | Size: 68 KiB |
BIN
assets/images/privacy_menu.png
Normal file
BIN
assets/images/privacy_menu.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 548 B |
|
@ -303,7 +303,7 @@ class ElectrumClient {
|
|||
Future<List<int>> feeRates() async {
|
||||
try {
|
||||
final topDoubleString = await estimatefee(p: 1);
|
||||
final middleDoubleString = await estimatefee(p: 20);
|
||||
final middleDoubleString = await estimatefee(p: 5);
|
||||
final bottomDoubleString = await estimatefee(p: 100);
|
||||
final top =
|
||||
(stringDoubleToBitcoinAmount(topDoubleString.toString()) / 1000)
|
||||
|
|
|
@ -72,7 +72,7 @@ abstract class ElectrumTransactionHistoryBase
|
|||
txs.entries.forEach((entry) {
|
||||
final val = entry.value;
|
||||
|
||||
if (val is Map<String, Object>) {
|
||||
if (val is Map<String, dynamic>) {
|
||||
final tx = ElectrumTransactionInfo.fromJson(val, walletInfo.type);
|
||||
_updateOrInsert(tx);
|
||||
}
|
||||
|
@ -85,9 +85,6 @@ abstract class ElectrumTransactionHistoryBase
|
|||
}
|
||||
|
||||
void _updateOrInsert(ElectrumTransactionInfo transaction) {
|
||||
if (transaction.id == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (transactions[transaction.id] == null) {
|
||||
transactions[transaction.id] = transaction;
|
||||
|
@ -98,6 +95,7 @@ abstract class ElectrumTransactionHistoryBase
|
|||
originalTx?.height = transaction.height;
|
||||
originalTx?.date ??= transaction.date;
|
||||
originalTx?.isPending = transaction.isPending;
|
||||
originalTx?.direction = transaction.direction;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -228,9 +228,7 @@ class ElectrumTransactionInfo extends TransactionInfo {
|
|||
m['id'] = id;
|
||||
m['height'] = height;
|
||||
m['amount'] = amount;
|
||||
// FIX-ME: Hardcoded value
|
||||
// m['direction'] = direction.index;
|
||||
m['direction'] = 0;
|
||||
m['direction'] = direction.index;
|
||||
m['date'] = date.millisecondsSinceEpoch;
|
||||
m['isPending'] = isPending;
|
||||
m['confirmations'] = confirmations;
|
||||
|
|
|
@ -191,8 +191,10 @@ abstract class ElectrumWalletBase extends WalletBase<ElectrumBalance,
|
|||
throw BitcoinTransactionNoInputsException();
|
||||
}
|
||||
|
||||
final allAmountFee = feeAmountForPriority(
|
||||
transactionCredentials.priority!, inputs.length, outputs.length);
|
||||
final allAmountFee = transactionCredentials.feeRate != null
|
||||
? feeAmountWithFeeRate(transactionCredentials.feeRate!, inputs.length, outputs.length)
|
||||
: feeAmountForPriority(transactionCredentials.priority!, inputs.length, outputs.length);
|
||||
|
||||
final allAmount = allInputsAmount - allAmountFee;
|
||||
|
||||
var credentialsAmount = 0;
|
||||
|
|
|
@ -1,20 +1,18 @@
|
|||
import 'package:cw_core/enumerable_item.dart';
|
||||
import 'package:hive/hive.dart';
|
||||
|
||||
part 'crypto_currency.g.dart';
|
||||
|
||||
@HiveType(typeId: 0)
|
||||
class CryptoCurrency extends EnumerableItem<int> with Serializable<int> {
|
||||
const CryptoCurrency({
|
||||
String title = '',
|
||||
int raw = -1,
|
||||
this.name,
|
||||
required this.name,
|
||||
this.fullName,
|
||||
this.iconPath,
|
||||
this.tag,})
|
||||
this.tag})
|
||||
: super(title: title, raw: raw);
|
||||
|
||||
final String name;
|
||||
final String? tag;
|
||||
final String? name;
|
||||
final String? fullName;
|
||||
final String? iconPath;
|
||||
|
||||
static const all = [
|
||||
|
@ -38,7 +36,7 @@ class CryptoCurrency extends EnumerableItem<int> with Serializable<int> {
|
|||
CryptoCurrency.ape,
|
||||
CryptoCurrency.avaxc,
|
||||
CryptoCurrency.btt,
|
||||
CryptoCurrency.bttbsc,
|
||||
CryptoCurrency.bttc,
|
||||
CryptoCurrency.doge,
|
||||
CryptoCurrency.firo,
|
||||
CryptoCurrency.usdttrc20,
|
||||
|
@ -53,7 +51,6 @@ class CryptoCurrency extends EnumerableItem<int> with Serializable<int> {
|
|||
CryptoCurrency.xvg,
|
||||
CryptoCurrency.usdcpoly,
|
||||
CryptoCurrency.dcr,
|
||||
CryptoCurrency.husd,
|
||||
CryptoCurrency.kmd,
|
||||
CryptoCurrency.mana,
|
||||
CryptoCurrency.maticpoly,
|
||||
|
@ -70,339 +67,116 @@ class CryptoCurrency extends EnumerableItem<int> with Serializable<int> {
|
|||
CryptoCurrency.stx,
|
||||
];
|
||||
|
||||
static const xmr = CryptoCurrency(title: 'XMR', iconPath: 'assets/images/monero_icon.png', name: 'Monero', raw: 0);
|
||||
static const ada = CryptoCurrency(title: 'ADA', iconPath: 'assets/images/ada_icon.png', name: 'Cardano', raw: 1);
|
||||
static const bch = CryptoCurrency(title: 'BCH', iconPath: 'assets/images/bch_icon.png',name: 'Bitcoin Cash', raw: 2);
|
||||
static const bnb = CryptoCurrency(title: 'BNB', iconPath: 'assets/images/bnb_icon.png', tag: 'BSC', name: 'Binance Coin', raw: 3);
|
||||
static const btc = CryptoCurrency(title: 'BTC', iconPath: 'assets/images/btc.png', name: 'Bitcoin', raw: 4);
|
||||
static const dai = CryptoCurrency(title: 'DAI', iconPath: 'assets/images/dai_icon.png', tag: 'ETH', name: 'Dai', raw: 5);
|
||||
static const dash = CryptoCurrency(title: 'DASH', iconPath: 'assets/images/dash_icon.png', name: 'Dash', raw: 6);
|
||||
static const eos = CryptoCurrency(title: 'EOS', iconPath: 'assets/images/eos_icon.png', name: 'EOS', raw: 7);
|
||||
static const eth = CryptoCurrency(title: 'ETH', iconPath: 'assets/images/eth_icon.png', name: 'Ethereum', raw: 8);
|
||||
static const ltc = CryptoCurrency(title: 'LTC', iconPath: 'assets/images/litecoin-ltc_icon.png', name: 'Litecoin', raw: 9);
|
||||
static const nano = CryptoCurrency(title: 'NANO', raw: 10);
|
||||
static const trx = CryptoCurrency(title: 'TRX', iconPath: 'assets/images/trx_icon.png', name: 'TRON', raw: 11);
|
||||
static const usdt = CryptoCurrency(title: 'USDT', iconPath: 'assets/images/usdt_icon.png', tag: 'OMNI', name: 'USDT', raw: 12);
|
||||
static const usdterc20 = CryptoCurrency(title: 'USDT', iconPath: 'assets/images/usdterc20_icon.png', tag: 'ETH', name: 'USDT', raw: 13);
|
||||
static const xlm = CryptoCurrency(title: 'XLM', iconPath: 'assets/images/xlm_icon.png', name: 'Stellar', raw: 14);
|
||||
static const xrp = CryptoCurrency(title: 'XRP', iconPath: 'assets/images/xrp_icon.png', name: 'Ripple', raw: 15);
|
||||
static const xhv = CryptoCurrency(title: 'XHV', iconPath: 'assets/images/xhv_logo.png', name: 'Haven Protocol', raw: 16);
|
||||
static const havenCurrencies = [
|
||||
xag,
|
||||
xau,
|
||||
xaud,
|
||||
xbtc,
|
||||
xcad,
|
||||
xchf,
|
||||
xcny,
|
||||
xeur,
|
||||
xgbp,
|
||||
xjpy,
|
||||
xnok,
|
||||
xnzd,
|
||||
xusd,
|
||||
];
|
||||
|
||||
static const xag = CryptoCurrency(title: 'XAG', tag: 'XHV', raw: 17);
|
||||
static const xau = CryptoCurrency(title: 'XAU', tag: 'XHV', raw: 18);
|
||||
static const xaud = CryptoCurrency(title: 'XAUD', tag: 'XHV', raw: 19);
|
||||
static const xbtc = CryptoCurrency(title: 'XBTC', tag: 'XHV', raw: 20);
|
||||
static const xcad = CryptoCurrency(title: 'XCAD', tag: 'XHV', raw: 21);
|
||||
static const xchf = CryptoCurrency(title: 'XCHF', tag: 'XHV', raw: 22);
|
||||
static const xcny = CryptoCurrency(title: 'XCNY', tag: 'XHV', raw: 23);
|
||||
static const xeur = CryptoCurrency(title: 'XEUR', tag: 'XHV', raw: 24);
|
||||
static const xgbp = CryptoCurrency(title: 'XGBP', tag: 'XHV', raw: 25);
|
||||
static const xjpy = CryptoCurrency(title: 'XJPY', tag: 'XHV', raw: 26);
|
||||
static const xnok = CryptoCurrency(title: 'XNOK', tag: 'XHV', raw: 27);
|
||||
static const xnzd = CryptoCurrency(title: 'XNZD', tag: 'XHV', raw: 28);
|
||||
static const xusd = CryptoCurrency(title: 'XUSD', tag: 'XHV', raw: 29);
|
||||
static const xmr = CryptoCurrency(title: 'XMR', iconPath: 'assets/images/monero_icon.png', fullName: 'Monero', raw: 0, name: 'xmr');
|
||||
static const ada = CryptoCurrency(title: 'ADA', iconPath: 'assets/images/ada_icon.png', fullName: 'Cardano', raw: 1, name: 'ada');
|
||||
static const bch = CryptoCurrency(title: 'BCH', iconPath: 'assets/images/bch_icon.png',fullName: 'Bitcoin Cash', raw: 2, name: 'bch');
|
||||
static const bnb = CryptoCurrency(title: 'BNB', iconPath: 'assets/images/bnb_icon.png', tag: 'BSC', fullName: 'Binance Coin', raw: 3, name: 'bnb');
|
||||
static const btc = CryptoCurrency(title: 'BTC', iconPath: 'assets/images/btc.png', fullName: 'Bitcoin', raw: 4, name: 'btc');
|
||||
static const dai = CryptoCurrency(title: 'DAI', iconPath: 'assets/images/dai_icon.png', tag: 'ETH', fullName: 'Dai', raw: 5, name: 'dai');
|
||||
static const dash = CryptoCurrency(title: 'DASH', iconPath: 'assets/images/dash_icon.png', fullName: 'Dash', raw: 6, name: 'dash');
|
||||
static const eos = CryptoCurrency(title: 'EOS', iconPath: 'assets/images/eos_icon.png', fullName: 'EOS', raw: 7, name: 'eos');
|
||||
static const eth = CryptoCurrency(title: 'ETH', iconPath: 'assets/images/eth_icon.png', fullName: 'Ethereum', raw: 8, name: 'eth');
|
||||
static const ltc = CryptoCurrency(title: 'LTC', iconPath: 'assets/images/litecoin-ltc_icon.png', fullName: 'Litecoin', raw: 9, name: 'ltc');
|
||||
static const nano = CryptoCurrency(title: 'NANO', raw: 10, name: 'nano');
|
||||
static const trx = CryptoCurrency(title: 'TRX', iconPath: 'assets/images/trx_icon.png', fullName: 'TRON', raw: 11, name: 'trx');
|
||||
static const usdt = CryptoCurrency(title: 'USDT', iconPath: 'assets/images/usdt_icon.png', tag: 'OMNI', fullName: 'USDT', raw: 12, name: 'usdt');
|
||||
static const usdterc20 = CryptoCurrency(title: 'USDT', iconPath: 'assets/images/usdterc20_icon.png', tag: 'ETH', fullName: 'USDT', raw: 13, name: 'usdterc20');
|
||||
static const xlm = CryptoCurrency(title: 'XLM', iconPath: 'assets/images/xlm_icon.png', fullName: 'Stellar', raw: 14, name: 'xlm');
|
||||
static const xrp = CryptoCurrency(title: 'XRP', iconPath: 'assets/images/xrp_icon.png', fullName: 'Ripple', raw: 15, name: 'xrp');
|
||||
static const xhv = CryptoCurrency(title: 'XHV', iconPath: 'assets/images/xhv_logo.png', fullName: 'Haven Protocol', raw: 16, name: 'xhv');
|
||||
|
||||
static const ape = CryptoCurrency(title: 'APE', iconPath: 'assets/images/ape_icon.png', tag: 'ETH', raw: 30);
|
||||
static const avaxc = CryptoCurrency(title: 'AVAX', iconPath: 'assets/images/avaxc_icon.png', tag: 'C-CHAIN', raw: 31);
|
||||
static const btt = CryptoCurrency(title: 'BTT', iconPath: 'assets/images/btt_icon.png', raw: 32);
|
||||
static const bttbsc = CryptoCurrency(title: 'BTT', iconPath: 'assets/images/bttbsc_icon.png', tag: 'BSC', raw: 33);
|
||||
static const doge = CryptoCurrency(title: 'DOGE', iconPath: 'assets/images/doge_icon.png', raw: 34);
|
||||
static const firo = CryptoCurrency(title: 'FIRO', iconPath: 'assets/images/firo_icon.png', raw: 35);
|
||||
static const usdttrc20 = CryptoCurrency(title: 'USDT', iconPath: 'assets/images/usdttrc20_icon.png', tag: 'TRX', raw: 36);
|
||||
static const hbar = CryptoCurrency(title: 'HBAR', iconPath: 'assets/images/hbar_icon.png', raw: 37);
|
||||
static const sc = CryptoCurrency(title: 'SC', iconPath: 'assets/images/sc_icon.png', raw: 38);
|
||||
static const sol = CryptoCurrency(title: 'SOL', iconPath: 'assets/images/sol_icon.png', raw: 39);
|
||||
static const usdc = CryptoCurrency(title: 'USDC', iconPath: 'assets/images/usdc_icon.png', tag: 'ETH', raw: 40);
|
||||
static const usdcsol = CryptoCurrency(title: 'USDC', iconPath: 'assets/images/usdcsol_icon.png', tag: 'SOL', raw: 41);
|
||||
static const zaddr = CryptoCurrency(title: 'ZZEC', tag: 'ZEC', name: 'Shielded Zcash', iconPath: 'assets/images/zaddr_icon.png', raw: 42);
|
||||
static const zec = CryptoCurrency(title: 'TZEC', tag: 'ZEC', name: 'Transparent Zcash', iconPath: 'assets/images/zec_icon.png', raw: 43);
|
||||
static const zen = CryptoCurrency(title: 'ZEN', iconPath: 'assets/images/zen_icon.png', raw: 44);
|
||||
static const xvg = CryptoCurrency(title: 'XVG', name: 'Verge', iconPath: 'assets/images/xvg_icon.png', raw: 45);
|
||||
static const xag = CryptoCurrency(title: 'XAG', tag: 'XHV', raw: 17, name: 'xag');
|
||||
static const xau = CryptoCurrency(title: 'XAU', tag: 'XHV', raw: 18, name: 'xau');
|
||||
static const xaud = CryptoCurrency(title: 'XAUD', tag: 'XHV', raw: 19, name: 'xaud');
|
||||
static const xbtc = CryptoCurrency(title: 'XBTC', tag: 'XHV', raw: 20, name: 'xbtc');
|
||||
static const xcad = CryptoCurrency(title: 'XCAD', tag: 'XHV', raw: 21, name: 'xcad');
|
||||
static const xchf = CryptoCurrency(title: 'XCHF', tag: 'XHV', raw: 22, name: 'xchf');
|
||||
static const xcny = CryptoCurrency(title: 'XCNY', tag: 'XHV', raw: 23, name: 'xcny');
|
||||
static const xeur = CryptoCurrency(title: 'XEUR', tag: 'XHV', raw: 24, name: 'xeur');
|
||||
static const xgbp = CryptoCurrency(title: 'XGBP', tag: 'XHV', raw: 25, name: 'xgbp');
|
||||
static const xjpy = CryptoCurrency(title: 'XJPY', tag: 'XHV', raw: 26, name: 'xjpy');
|
||||
static const xnok = CryptoCurrency(title: 'XNOK', tag: 'XHV', raw: 27, name: 'xnok');
|
||||
static const xnzd = CryptoCurrency(title: 'XNZD', tag: 'XHV', raw: 28, name: 'xnzd');
|
||||
static const xusd = CryptoCurrency(title: 'XUSD', tag: 'XHV', raw: 29, name: 'xusd');
|
||||
|
||||
static const usdcpoly = CryptoCurrency(title: 'USDC', iconPath: 'assets/images/usdc_icon.png', tag: 'POLY', raw: 46);
|
||||
static const dcr = CryptoCurrency(title: 'DCR', iconPath: 'assets/images/dcr_icon.png', raw: 47);
|
||||
static const husd = CryptoCurrency(title: 'HUSD', iconPath: 'assets/images/husd_icon.png', tag: 'ETH', raw: 48);
|
||||
static const kmd = CryptoCurrency(title: 'KMD', iconPath: 'assets/images/kmd_icon.png', raw: 49);
|
||||
static const mana = CryptoCurrency(title: 'MANA', iconPath: 'assets/images/mana_icon.png', tag: 'ETH', raw: 50);
|
||||
static const maticpoly = CryptoCurrency(title: 'MATIC', iconPath: 'assets/images/matic_icon.png', tag: 'POLY', raw: 51);
|
||||
static const matic = CryptoCurrency(title: 'MATIC', iconPath: 'assets/images/matic_icon.png', tag: 'ETH', raw: 52);
|
||||
static const mkr = CryptoCurrency(title: 'MKR', iconPath: 'assets/images/mkr_icon.png', tag: 'ETH', raw: 53);
|
||||
static const near = CryptoCurrency(title: 'NEAR', iconPath: 'assets/images/near_icon.png', raw: 54);
|
||||
static const oxt = CryptoCurrency(title: 'OXT', iconPath: 'assets/images/oxt_icon.png', tag: 'ETH', raw: 55);
|
||||
static const paxg = CryptoCurrency(title: 'PAXG', iconPath: 'assets/images/paxg_icon.png', tag: 'ETH', raw: 56);
|
||||
static const pivx = CryptoCurrency(title: 'PIVX', iconPath: 'assets/images/pivx_icon.png', raw: 57);
|
||||
static const rune = CryptoCurrency(title: 'RUNE', iconPath: 'assets/images/rune_icon.png', raw: 58);
|
||||
static const rvn = CryptoCurrency(title: 'RVN', iconPath: 'assets/images/rvn_icon.png', raw: 59);
|
||||
static const scrt = CryptoCurrency(title: 'SCRT', iconPath: 'assets/images/scrt_icon.png', raw: 60);
|
||||
static const uni = CryptoCurrency(title: 'UNI', iconPath: 'assets/images/uni_icon.png', tag: 'ETH', raw: 61);
|
||||
static const stx = CryptoCurrency(title: 'STX', iconPath: 'assets/images/stx_icon.png', raw: 62);
|
||||
static const ape = CryptoCurrency(title: 'APE', iconPath: 'assets/images/ape_icon.png', tag: 'ETH', raw: 30, name: 'ape');
|
||||
static const avaxc = CryptoCurrency(title: 'AVAX', iconPath: 'assets/images/avaxc_icon.png', tag: 'C-CHAIN', raw: 31, name: 'avaxc');
|
||||
static const btt = CryptoCurrency(title: 'BTT', iconPath: 'assets/images/btt_icon.png', raw: 32, name: 'btt');
|
||||
static const bttc = CryptoCurrency(title: 'BTTC', iconPath: 'assets/images/bttbsc_icon.png',fullName: 'BitTorrent-NEW (Binance Smart Chain)', tag: 'BSC', raw: 33, name: 'bttc');
|
||||
static const doge = CryptoCurrency(title: 'DOGE', iconPath: 'assets/images/doge_icon.png', raw: 34, name: 'doge');
|
||||
static const firo = CryptoCurrency(title: 'FIRO', iconPath: 'assets/images/firo_icon.png', raw: 35, name: 'firo');
|
||||
static const usdttrc20 = CryptoCurrency(title: 'USDT', iconPath: 'assets/images/usdttrc20_icon.png', tag: 'TRX', raw: 36, name: 'usdttrc20');
|
||||
static const hbar = CryptoCurrency(title: 'HBAR', iconPath: 'assets/images/hbar_icon.png', raw: 37, name: 'hbar');
|
||||
static const sc = CryptoCurrency(title: 'SC', iconPath: 'assets/images/sc_icon.png', raw: 38, name: 'sc');
|
||||
static const sol = CryptoCurrency(title: 'SOL', iconPath: 'assets/images/sol_icon.png', raw: 39, name: 'sol');
|
||||
static const usdc = CryptoCurrency(title: 'USDC', iconPath: 'assets/images/usdc_icon.png', tag: 'ETH', raw: 40, name: 'usdc');
|
||||
static const usdcsol = CryptoCurrency(title: 'USDC', iconPath: 'assets/images/usdcsol_icon.png', tag: 'SOL', raw: 41, name: 'usdcsol');
|
||||
static const zaddr = CryptoCurrency(title: 'ZZEC', tag: 'ZEC', fullName: 'Shielded Zcash', iconPath: 'assets/images/zaddr_icon.png', raw: 42, name: 'zaddr');
|
||||
static const zec = CryptoCurrency(title: 'TZEC', tag: 'ZEC', fullName: 'Transparent Zcash', iconPath: 'assets/images/zec_icon.png', raw: 43, name: 'zec');
|
||||
static const zen = CryptoCurrency(title: 'ZEN', iconPath: 'assets/images/zen_icon.png', raw: 44, name: 'zen');
|
||||
static const xvg = CryptoCurrency(title: 'XVG', fullName: 'Verge', iconPath: 'assets/images/xvg_icon.png', raw: 45, name: 'xvg');
|
||||
|
||||
static const usdcpoly = CryptoCurrency(title: 'USDC', iconPath: 'assets/images/usdc_icon.png', tag: 'POLY', raw: 46, name: 'usdcpoly');
|
||||
static const dcr = CryptoCurrency(title: 'DCR', iconPath: 'assets/images/dcr_icon.png', raw: 47, name: 'dcr');
|
||||
static const kmd = CryptoCurrency(title: 'KMD', iconPath: 'assets/images/kmd_icon.png', raw: 48, name: 'kmd');
|
||||
static const mana = CryptoCurrency(title: 'MANA', iconPath: 'assets/images/mana_icon.png', tag: 'ETH', raw: 49, name: 'mana');
|
||||
static const maticpoly = CryptoCurrency(title: 'MATIC', iconPath: 'assets/images/matic_icon.png', tag: 'POLY', raw: 50, name: 'maticpoly');
|
||||
static const matic = CryptoCurrency(title: 'MATIC', iconPath: 'assets/images/matic_icon.png', tag: 'ETH', raw: 51, name: 'matic');
|
||||
static const mkr = CryptoCurrency(title: 'MKR', iconPath: 'assets/images/mkr_icon.png', tag: 'ETH', raw: 52, name: 'mkr');
|
||||
static const near = CryptoCurrency(title: 'NEAR', iconPath: 'assets/images/near_icon.png', raw: 53, name: 'near');
|
||||
static const oxt = CryptoCurrency(title: 'OXT', iconPath: 'assets/images/oxt_icon.png', tag: 'ETH', raw: 54, name: 'oxt');
|
||||
static const paxg = CryptoCurrency(title: 'PAXG', iconPath: 'assets/images/paxg_icon.png', tag: 'ETH', raw: 55, name: 'paxg');
|
||||
static const pivx = CryptoCurrency(title: 'PIVX', iconPath: 'assets/images/pivx_icon.png', raw: 56, name: 'pivx');
|
||||
static const rune = CryptoCurrency(title: 'RUNE', iconPath: 'assets/images/rune_icon.png', raw: 57, name: 'rune');
|
||||
static const rvn = CryptoCurrency(title: 'RVN', iconPath: 'assets/images/rvn_icon.png', raw: 58, name: 'rvn');
|
||||
static const scrt = CryptoCurrency(title: 'SCRT', iconPath: 'assets/images/scrt_icon.png', raw: 59, name: 'scrt');
|
||||
static const uni = CryptoCurrency(title: 'UNI', iconPath: 'assets/images/uni_icon.png', tag: 'ETH', raw: 60, name: 'uni');
|
||||
static const stx = CryptoCurrency(title: 'STX', iconPath: 'assets/images/stx_icon.png', raw: 61, name: 'stx');
|
||||
|
||||
static final Map<int, CryptoCurrency> _rawCurrencyMap =
|
||||
[...all, ...havenCurrencies].fold<Map<int, CryptoCurrency>>(<int, CryptoCurrency>{}, (acc, item) {
|
||||
acc.addAll({item.raw: item});
|
||||
return acc;
|
||||
});
|
||||
|
||||
static final Map<String, CryptoCurrency> _nameCurrencyMap =
|
||||
[...all, ...havenCurrencies].fold<Map<String, CryptoCurrency>>(<String, CryptoCurrency>{}, (acc, item) {
|
||||
acc.addAll({item.name: item});
|
||||
return acc;
|
||||
});
|
||||
|
||||
static CryptoCurrency deserialize({required int raw}) {
|
||||
switch (raw) {
|
||||
case 0:
|
||||
return CryptoCurrency.xmr;
|
||||
case 1:
|
||||
return CryptoCurrency.ada;
|
||||
case 2:
|
||||
return CryptoCurrency.bch;
|
||||
case 3:
|
||||
return CryptoCurrency.bnb;
|
||||
case 4:
|
||||
return CryptoCurrency.btc;
|
||||
case 5:
|
||||
return CryptoCurrency.dai;
|
||||
case 6:
|
||||
return CryptoCurrency.dash;
|
||||
case 7:
|
||||
return CryptoCurrency.eos;
|
||||
case 8:
|
||||
return CryptoCurrency.eth;
|
||||
case 9:
|
||||
return CryptoCurrency.ltc;
|
||||
case 10:
|
||||
return CryptoCurrency.nano;
|
||||
case 11:
|
||||
return CryptoCurrency.trx;
|
||||
case 12:
|
||||
return CryptoCurrency.usdt;
|
||||
case 13:
|
||||
return CryptoCurrency.usdterc20;
|
||||
case 14:
|
||||
return CryptoCurrency.xlm;
|
||||
case 15:
|
||||
return CryptoCurrency.xrp;
|
||||
case 16:
|
||||
return CryptoCurrency.xhv;
|
||||
case 17:
|
||||
return CryptoCurrency.xag;
|
||||
case 18:
|
||||
return CryptoCurrency.xau;
|
||||
case 19:
|
||||
return CryptoCurrency.xaud;
|
||||
case 20:
|
||||
return CryptoCurrency.xbtc;
|
||||
case 21:
|
||||
return CryptoCurrency.xcad;
|
||||
case 22:
|
||||
return CryptoCurrency.xchf;
|
||||
case 23:
|
||||
return CryptoCurrency.xcny;
|
||||
case 24:
|
||||
return CryptoCurrency.xeur;
|
||||
case 25:
|
||||
return CryptoCurrency.xgbp;
|
||||
case 26:
|
||||
return CryptoCurrency.xjpy;
|
||||
case 27:
|
||||
return CryptoCurrency.xnok;
|
||||
case 28:
|
||||
return CryptoCurrency.xnzd;
|
||||
case 29:
|
||||
return CryptoCurrency.xusd;
|
||||
case 30:
|
||||
return CryptoCurrency.ape;
|
||||
case 31:
|
||||
return CryptoCurrency.avaxc;
|
||||
case 32:
|
||||
return CryptoCurrency.btt;
|
||||
case 33:
|
||||
return CryptoCurrency.bttbsc;
|
||||
case 34:
|
||||
return CryptoCurrency.doge;
|
||||
case 35:
|
||||
return CryptoCurrency.firo;
|
||||
case 36:
|
||||
return CryptoCurrency.usdttrc20;
|
||||
case 37:
|
||||
return CryptoCurrency.hbar;
|
||||
case 38:
|
||||
return CryptoCurrency.sc;
|
||||
case 39:
|
||||
return CryptoCurrency.sol;
|
||||
case 40:
|
||||
return CryptoCurrency.usdc;
|
||||
case 41:
|
||||
return CryptoCurrency.usdcsol;
|
||||
case 42:
|
||||
return CryptoCurrency.zaddr;
|
||||
case 43:
|
||||
return CryptoCurrency.zec;
|
||||
case 44:
|
||||
return CryptoCurrency.zen;
|
||||
case 45:
|
||||
return CryptoCurrency.xvg;
|
||||
case 46:
|
||||
return CryptoCurrency.usdcpoly;
|
||||
case 47:
|
||||
return CryptoCurrency.dcr;
|
||||
case 48:
|
||||
return CryptoCurrency.husd;
|
||||
case 49:
|
||||
return CryptoCurrency.kmd;
|
||||
case 50:
|
||||
return CryptoCurrency.mana;
|
||||
case 51:
|
||||
return CryptoCurrency.maticpoly;
|
||||
case 52:
|
||||
return CryptoCurrency.matic;
|
||||
case 53:
|
||||
return CryptoCurrency.mkr;
|
||||
case 54:
|
||||
return CryptoCurrency.near;
|
||||
case 55:
|
||||
return CryptoCurrency.oxt;
|
||||
case 56:
|
||||
return CryptoCurrency.paxg;
|
||||
case 57:
|
||||
return CryptoCurrency.pivx;
|
||||
case 58:
|
||||
return CryptoCurrency.rune;
|
||||
case 59:
|
||||
return CryptoCurrency.rvn;
|
||||
case 60:
|
||||
return CryptoCurrency.scrt;
|
||||
case 61:
|
||||
return CryptoCurrency.uni;
|
||||
case 62:
|
||||
return CryptoCurrency.stx;
|
||||
default:
|
||||
throw Exception('Unexpected token: $raw for CryptoCurrency deserialize');
|
||||
|
||||
if (CryptoCurrency._rawCurrencyMap[raw] == null) {
|
||||
final s = 'Unexpected token: $raw for CryptoCurrency deserialize';
|
||||
throw ArgumentError.value(raw, 'raw', s);
|
||||
}
|
||||
return CryptoCurrency._rawCurrencyMap[raw]!;
|
||||
}
|
||||
|
||||
static CryptoCurrency fromString(String raw) {
|
||||
switch (raw.toLowerCase()) {
|
||||
case 'xmr':
|
||||
return CryptoCurrency.xmr;
|
||||
case 'ada':
|
||||
return CryptoCurrency.ada;
|
||||
case 'bch':
|
||||
return CryptoCurrency.bch;
|
||||
case 'bnbmainnet':
|
||||
return CryptoCurrency.bnb;
|
||||
case 'btc':
|
||||
return CryptoCurrency.btc;
|
||||
case 'dai':
|
||||
return CryptoCurrency.dai;
|
||||
case 'dash':
|
||||
return CryptoCurrency.dash;
|
||||
case 'eos':
|
||||
return CryptoCurrency.eos;
|
||||
case 'eth':
|
||||
return CryptoCurrency.eth;
|
||||
case 'ltc':
|
||||
return CryptoCurrency.ltc;
|
||||
case 'nano':
|
||||
return CryptoCurrency.nano;
|
||||
case 'trx':
|
||||
return CryptoCurrency.trx;
|
||||
case 'usdc':
|
||||
return CryptoCurrency.usdc;
|
||||
case 'usdterc20':
|
||||
return CryptoCurrency.usdterc20;
|
||||
case 'xlm':
|
||||
return CryptoCurrency.xlm;
|
||||
case 'xrp':
|
||||
return CryptoCurrency.xrp;
|
||||
case 'xhv':
|
||||
return CryptoCurrency.xhv;
|
||||
case 'xag':
|
||||
return CryptoCurrency.xag;
|
||||
case 'xau':
|
||||
return CryptoCurrency.xau;
|
||||
case 'xaud':
|
||||
return CryptoCurrency.xaud;
|
||||
case 'xbtc':
|
||||
return CryptoCurrency.xbtc;
|
||||
case 'xcad':
|
||||
return CryptoCurrency.xcad;
|
||||
case 'xchf':
|
||||
return CryptoCurrency.xchf;
|
||||
case 'xcny':
|
||||
return CryptoCurrency.xcny;
|
||||
case 'xeur':
|
||||
return CryptoCurrency.xeur;
|
||||
case 'xgbp':
|
||||
return CryptoCurrency.xgbp;
|
||||
case 'xjpy':
|
||||
return CryptoCurrency.xjpy;
|
||||
case 'xnok':
|
||||
return CryptoCurrency.xnok;
|
||||
case 'xnzd':
|
||||
return CryptoCurrency.xnzd;
|
||||
case 'xusd':
|
||||
return CryptoCurrency.xusd;
|
||||
case 'ape':
|
||||
return CryptoCurrency.ape;
|
||||
case 'avax':
|
||||
return CryptoCurrency.avaxc;
|
||||
case 'btt':
|
||||
return CryptoCurrency.btt;
|
||||
case 'bttbsc':
|
||||
return CryptoCurrency.bttbsc;
|
||||
case 'doge':
|
||||
return CryptoCurrency.doge;
|
||||
case 'firo':
|
||||
return CryptoCurrency.firo;
|
||||
case 'usdttrc20':
|
||||
return CryptoCurrency.usdttrc20;
|
||||
case 'hbar':
|
||||
return CryptoCurrency.hbar;
|
||||
case 'sc':
|
||||
return CryptoCurrency.sc;
|
||||
case 'sol':
|
||||
return CryptoCurrency.sol;
|
||||
case 'usdt':
|
||||
return CryptoCurrency.usdt;
|
||||
case 'usdcsol':
|
||||
return CryptoCurrency.usdcsol;
|
||||
case 'zaddr':
|
||||
return CryptoCurrency.zaddr;
|
||||
case 'zec':
|
||||
return CryptoCurrency.zec;
|
||||
case 'zen':
|
||||
return CryptoCurrency.zen;
|
||||
case 'xvg':
|
||||
return CryptoCurrency.xvg;
|
||||
case 'usdcpoly':
|
||||
return CryptoCurrency.usdcpoly;
|
||||
case 'dcr':
|
||||
return CryptoCurrency.dcr;
|
||||
case 'husd':
|
||||
return CryptoCurrency.husd;
|
||||
case 'kmd':
|
||||
return CryptoCurrency.kmd;
|
||||
case 'mana':
|
||||
return CryptoCurrency.mana;
|
||||
case 'maticpoly':
|
||||
return CryptoCurrency.maticpoly;
|
||||
case 'matic':
|
||||
return CryptoCurrency.matic;
|
||||
case 'mkr':
|
||||
return CryptoCurrency.mkr;
|
||||
case 'near':
|
||||
return CryptoCurrency.near;
|
||||
case 'oxt':
|
||||
return CryptoCurrency.oxt;
|
||||
case 'paxg':
|
||||
return CryptoCurrency.paxg;
|
||||
case 'pivx':
|
||||
return CryptoCurrency.pivx;
|
||||
case 'rune':
|
||||
return CryptoCurrency.rune;
|
||||
case 'rvn':
|
||||
return CryptoCurrency.rvn;
|
||||
case 'scrt':
|
||||
return CryptoCurrency.scrt;
|
||||
case 'uni':
|
||||
return CryptoCurrency.uni;
|
||||
case 'stx':
|
||||
return CryptoCurrency.stx;
|
||||
default:
|
||||
throw Exception('Unexpected token: $raw for CryptoCurrency fromString');
|
||||
static CryptoCurrency fromString(String name) {
|
||||
|
||||
if (CryptoCurrency._nameCurrencyMap[name.toLowerCase()] == null) {
|
||||
final s = 'Unexpected token: $name for CryptoCurrency fromString';
|
||||
throw ArgumentError.value(name, 'name', s);
|
||||
}
|
||||
return CryptoCurrency._nameCurrencyMap[name.toLowerCase()]!;
|
||||
}
|
||||
|
||||
@override
|
||||
|
|
|
@ -21,22 +21,6 @@ class MoneroTransactionPriority extends TransactionPriority {
|
|||
static const fastest = MoneroTransactionPriority(title: 'Fastest', raw: 4);
|
||||
static const standard = slow;
|
||||
|
||||
|
||||
static List<MoneroTransactionPriority> forWalletType(WalletType type) {
|
||||
switch (type) {
|
||||
case WalletType.monero:
|
||||
return MoneroTransactionPriority.all;
|
||||
case WalletType.bitcoin:
|
||||
return [
|
||||
MoneroTransactionPriority.slow,
|
||||
MoneroTransactionPriority.automatic,
|
||||
MoneroTransactionPriority.fast
|
||||
];
|
||||
default:
|
||||
return [];
|
||||
}
|
||||
}
|
||||
|
||||
static MoneroTransactionPriority deserialize({required int raw}) {
|
||||
switch (raw) {
|
||||
case 0:
|
||||
|
|
|
@ -53,7 +53,7 @@ class Node extends HiveObject with Keyable {
|
|||
@HiveField(4)
|
||||
bool? useSSL;
|
||||
|
||||
@HiveField(5)
|
||||
@HiveField(5, defaultValue: false)
|
||||
bool trusted;
|
||||
|
||||
bool get isSSL => useSSL ?? false;
|
||||
|
|
|
@ -32,6 +32,36 @@
|
|||
<string>cakewallet</string>
|
||||
</array>
|
||||
</dict>
|
||||
<dict>
|
||||
<key>CFBundleTypeRole</key>
|
||||
<string>Editor</string>
|
||||
<key>CFBundleURLName</key>
|
||||
<string>bitcoin</string>
|
||||
<key>CFBundleURLSchemes</key>
|
||||
<array>
|
||||
<string>bitcoin</string>
|
||||
</array>
|
||||
</dict>
|
||||
<dict>
|
||||
<key>CFBundleTypeRole</key>
|
||||
<string>Editor</string>
|
||||
<key>CFBundleURLName</key>
|
||||
<string>monero</string>
|
||||
<key>CFBundleURLSchemes</key>
|
||||
<array>
|
||||
<string>monero</string>
|
||||
</array>
|
||||
</dict>
|
||||
<dict>
|
||||
<key>CFBundleTypeRole</key>
|
||||
<string>Editor</string>
|
||||
<key>CFBundleURLName</key>
|
||||
<string>litecoin</string>
|
||||
<key>CFBundleURLSchemes</key>
|
||||
<array>
|
||||
<string>litecoin</string>
|
||||
</array>
|
||||
</dict>
|
||||
</array>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>$(CURRENT_PROJECT_VERSION)</string>
|
||||
|
|
|
@ -24,7 +24,6 @@ class AddressValidator extends TextValidator {
|
|||
return '[0-9a-zA-Z_]';
|
||||
case CryptoCurrency.usdc:
|
||||
case CryptoCurrency.usdcpoly:
|
||||
case CryptoCurrency.husd:
|
||||
case CryptoCurrency.ape:
|
||||
case CryptoCurrency.avaxc:
|
||||
case CryptoCurrency.eth:
|
||||
|
@ -156,7 +155,7 @@ class AddressValidator extends TextValidator {
|
|||
return [98, 99, 106];
|
||||
case CryptoCurrency.btt:
|
||||
return [34];
|
||||
case CryptoCurrency.bttbsc:
|
||||
case CryptoCurrency.bttc:
|
||||
return [34];
|
||||
case CryptoCurrency.doge:
|
||||
return [34];
|
||||
|
@ -181,7 +180,6 @@ class AddressValidator extends TextValidator {
|
|||
case CryptoCurrency.stx:
|
||||
return [40, 41, 42];
|
||||
case CryptoCurrency.usdcpoly:
|
||||
case CryptoCurrency.husd:
|
||||
case CryptoCurrency.mana:
|
||||
case CryptoCurrency.matic:
|
||||
case CryptoCurrency.maticpoly:
|
||||
|
|
|
@ -4,12 +4,19 @@ import 'package:shared_preferences/shared_preferences.dart';
|
|||
import 'package:cake_wallet/entities/preferences_key.dart';
|
||||
import 'package:cake_wallet/entities/secret_store_key.dart';
|
||||
import 'package:cake_wallet/entities/encrypt.dart';
|
||||
import 'package:cake_wallet/di.dart';
|
||||
import 'package:cake_wallet/store/settings_store.dart';
|
||||
|
||||
class AuthService with Store {
|
||||
AuthService({required this.secureStorage, required this.sharedPreferences});
|
||||
AuthService({
|
||||
required this.secureStorage,
|
||||
required this.sharedPreferences,
|
||||
required this.settingsStore,
|
||||
});
|
||||
|
||||
final FlutterSecureStorage secureStorage;
|
||||
final SharedPreferences sharedPreferences;
|
||||
final SettingsStore settingsStore;
|
||||
|
||||
Future<void> setPassword(String password) async {
|
||||
final key = generateStoreKeyFor(key: SecretStoreKey.pinCodePassword);
|
||||
|
@ -19,8 +26,7 @@ class AuthService with Store {
|
|||
|
||||
Future<bool> canAuthenticate() async {
|
||||
final key = generateStoreKeyFor(key: SecretStoreKey.pinCodePassword);
|
||||
final walletName =
|
||||
sharedPreferences.getString(PreferencesKey.currentWalletName) ?? '';
|
||||
final walletName = sharedPreferences.getString(PreferencesKey.currentWalletName) ?? '';
|
||||
var password = '';
|
||||
|
||||
try {
|
||||
|
@ -39,4 +45,25 @@ class AuthService with Store {
|
|||
|
||||
return decodedPin == pin;
|
||||
}
|
||||
|
||||
void saveLastAuthTime() {
|
||||
int timestamp = DateTime.now().millisecondsSinceEpoch;
|
||||
sharedPreferences.setInt(PreferencesKey.lastAuthTimeMilliseconds, timestamp);
|
||||
}
|
||||
|
||||
bool requireAuth() {
|
||||
final timestamp = sharedPreferences.getInt(PreferencesKey.lastAuthTimeMilliseconds);
|
||||
final duration = _durationToRequireAuth(timestamp ?? 0);
|
||||
final requiredPinInterval = settingsStore.pinTimeOutDuration;
|
||||
|
||||
return duration >= requiredPinInterval.value;
|
||||
}
|
||||
|
||||
int _durationToRequireAuth(int timestamp) {
|
||||
DateTime before = DateTime.fromMillisecondsSinceEpoch(timestamp);
|
||||
DateTime now = DateTime.now();
|
||||
Duration timeDifference = now.difference(before);
|
||||
|
||||
return timeDifference.inMinutes;
|
||||
}
|
||||
}
|
||||
|
|
23
lib/di.dart
23
lib/di.dart
|
@ -13,6 +13,7 @@ import 'package:cake_wallet/src/screens/ionia/cards/ionia_custom_redeem_page.dar
|
|||
import 'package:cake_wallet/src/screens/ionia/cards/ionia_gift_card_detail_page.dart';
|
||||
import 'package:cake_wallet/src/screens/ionia/cards/ionia_more_options_page.dart';
|
||||
import 'package:cake_wallet/src/screens/settings/connection_sync_page.dart';
|
||||
import 'package:cake_wallet/utils/payment_request.dart';
|
||||
import 'package:cake_wallet/view_model/ionia/ionia_auth_view_model.dart';
|
||||
import 'package:cake_wallet/view_model/ionia/ionia_buy_card_view_model.dart';
|
||||
import 'package:cake_wallet/view_model/ionia/ionia_custom_tip_view_model.dart';
|
||||
|
@ -308,7 +309,10 @@ Future setup(
|
|||
|
||||
getIt.registerFactory<AuthService>(() => AuthService(
|
||||
secureStorage: getIt.get<FlutterSecureStorage>(),
|
||||
sharedPreferences: getIt.get<SharedPreferences>()));
|
||||
sharedPreferences: getIt.get<SharedPreferences>(),
|
||||
settingsStore: getIt.get<SettingsStore>(),
|
||||
),
|
||||
);
|
||||
|
||||
getIt.registerFactory<AuthViewModel>(() => AuthViewModel(
|
||||
getIt.get<AuthService>(),
|
||||
|
@ -384,8 +388,11 @@ Future setup(
|
|||
getIt.get<BalanceViewModel>(),
|
||||
_transactionDescriptionBox));
|
||||
|
||||
getIt.registerFactory(
|
||||
() => SendPage(sendViewModel: getIt.get<SendViewModel>()));
|
||||
getIt.registerFactoryParam<SendPage, PaymentRequest?, void>(
|
||||
(PaymentRequest? initialPaymentRequest, _) => SendPage(
|
||||
sendViewModel: getIt.get<SendViewModel>(),
|
||||
initialPaymentRequest: initialPaymentRequest,
|
||||
));
|
||||
|
||||
getIt.registerFactory(() => SendTemplatePage(
|
||||
sendTemplateViewModel: getIt.get<SendTemplateViewModel>()));
|
||||
|
@ -393,7 +400,10 @@ Future setup(
|
|||
getIt.registerFactory(() => WalletListViewModel(
|
||||
_walletInfoSource,
|
||||
getIt.get<AppStore>(),
|
||||
getIt.get<WalletLoadingService>()));
|
||||
getIt.get<WalletLoadingService>(),
|
||||
getIt.get<AuthService>(),
|
||||
),
|
||||
);
|
||||
|
||||
getIt.registerFactory(() =>
|
||||
WalletListPage(walletListViewModel: getIt.get<WalletListViewModel>()));
|
||||
|
@ -453,7 +463,7 @@ Future setup(
|
|||
});
|
||||
|
||||
getIt.registerFactory(() {
|
||||
return SecuritySettingsViewModel(getIt.get<SettingsStore>());
|
||||
return SecuritySettingsViewModel(getIt.get<SettingsStore>(), getIt.get<AuthService>());
|
||||
});
|
||||
|
||||
getIt
|
||||
|
@ -785,7 +795,8 @@ Future setup(
|
|||
return IoniaMoreOptionsPage(giftCard);
|
||||
});
|
||||
|
||||
getIt.registerFactoryParam<IoniaCustomRedeemViewModel, IoniaGiftCard, void>((IoniaGiftCard giftCard, _) => IoniaCustomRedeemViewModel(giftCard));
|
||||
getIt.registerFactoryParam<IoniaCustomRedeemViewModel, IoniaGiftCard, void>((IoniaGiftCard giftCard, _)
|
||||
=> IoniaCustomRedeemViewModel(giftCard: giftCard, ioniaService: getIt.get<IoniaService>()));
|
||||
|
||||
getIt.registerFactoryParam<IoniaCustomRedeemPage, List, void>((List args, _){
|
||||
final giftCard = args.first as IoniaGiftCard;
|
||||
|
|
|
@ -139,6 +139,10 @@ Future defaultSettingsMigration(
|
|||
await addOnionNode(nodes);
|
||||
break;
|
||||
|
||||
case 19:
|
||||
await validateBitcoinSavedTransactionPriority(sharedPreferences);
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
@ -154,6 +158,18 @@ Future defaultSettingsMigration(
|
|||
PreferencesKey.currentDefaultSettingsMigrationVersion, version);
|
||||
}
|
||||
|
||||
Future<void> validateBitcoinSavedTransactionPriority(SharedPreferences sharedPreferences) async {
|
||||
if (bitcoin == null) {
|
||||
return;
|
||||
}
|
||||
final int? savedBitcoinPriority =
|
||||
sharedPreferences.getInt(PreferencesKey.bitcoinTransactionPriority);
|
||||
if (!bitcoin!.getTransactionPriorities().any((element) => element.raw == savedBitcoinPriority)) {
|
||||
await sharedPreferences.setInt(
|
||||
PreferencesKey.bitcoinTransactionPriority, bitcoin!.getMediumTransactionPriority().serialize());
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> addOnionNode(Box<Node> nodes) async {
|
||||
final onionNodeUri = "cakexmrl7bonq7ovjka5kuwuyd3f7qnkz6z6s6dmsy3uckwra7bvggyd.onion:18081";
|
||||
|
||||
|
|
|
@ -18,7 +18,9 @@ class LanguageService {
|
|||
'uk': 'Українська (Ukrainian)',
|
||||
'zh': '中文 (Chinese)',
|
||||
'hr': 'Hrvatski (Croatian)',
|
||||
'it': 'Italiano (Italian)'
|
||||
'it': 'Italiano (Italian)',
|
||||
'th': 'ภาษาไทย (Thai)',
|
||||
'ar': 'العربية (Arabic)'
|
||||
};
|
||||
|
||||
static const Map<String, String> localeCountryCode = {
|
||||
|
@ -36,7 +38,9 @@ class LanguageService {
|
|||
'uk': 'ukr',
|
||||
'zh': 'chn',
|
||||
'hr': 'hrv',
|
||||
'it': 'ita'
|
||||
'it': 'ita',
|
||||
'th': 'tha',
|
||||
'ar': 'sau'
|
||||
};
|
||||
|
||||
static final list = <String, String> {};
|
||||
|
|
32
lib/entities/pin_code_required_duration.dart
Normal file
32
lib/entities/pin_code_required_duration.dart
Normal file
|
@ -0,0 +1,32 @@
|
|||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
|
||||
enum PinCodeRequiredDuration {
|
||||
always(0),
|
||||
tenminutes(10),
|
||||
onehour(60);
|
||||
|
||||
const PinCodeRequiredDuration(this.value);
|
||||
final int value;
|
||||
|
||||
static PinCodeRequiredDuration deserialize({required int raw}) =>
|
||||
PinCodeRequiredDuration.values.firstWhere((e) => e.value == raw);
|
||||
|
||||
@override
|
||||
String toString(){
|
||||
String label = '';
|
||||
switch (this) {
|
||||
case PinCodeRequiredDuration.always:
|
||||
label = S.current.always;
|
||||
break;
|
||||
case PinCodeRequiredDuration.tenminutes:
|
||||
label = S.current.minutes_to_pin_code('10');
|
||||
break;
|
||||
case PinCodeRequiredDuration.onehour:
|
||||
label = S.current.minutes_to_pin_code('60');
|
||||
break;
|
||||
}
|
||||
return label;
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -27,6 +27,9 @@ class PreferencesKey {
|
|||
static const shouldShowReceiveWarning = 'should_show_receive_warning';
|
||||
static const shouldShowYatPopup = 'should_show_yat_popup';
|
||||
static const moneroWalletPasswordUpdateV1Base = 'monero_wallet_update_v1';
|
||||
static const pinTimeOutDuration = 'pin_timeout_duration';
|
||||
static const lastAuthTimeMilliseconds = 'last_auth_time_milliseconds';
|
||||
|
||||
|
||||
static String moneroWalletUpdateV1Key(String name)
|
||||
=> '${PreferencesKey.moneroWalletPasswordUpdateV1Base}_${name}';
|
||||
|
|
|
@ -24,6 +24,9 @@ class ExchangeProviderDescription extends EnumerableItem<int>
|
|||
static const simpleSwap =
|
||||
ExchangeProviderDescription(title: 'SimpleSwap', raw: 4, image: 'assets/images/simpleSwap.png');
|
||||
|
||||
static const all =
|
||||
ExchangeProviderDescription(title: 'All trades', raw: 5, image:'');
|
||||
|
||||
static ExchangeProviderDescription deserialize({required int raw}) {
|
||||
switch (raw) {
|
||||
case 0:
|
||||
|
@ -36,6 +39,8 @@ class ExchangeProviderDescription extends EnumerableItem<int>
|
|||
return sideShift;
|
||||
case 4:
|
||||
return simpleSwap;
|
||||
case 5:
|
||||
return all;
|
||||
default:
|
||||
throw Exception('Unexpected token: $raw for ExchangeProviderDescription deserialize');
|
||||
}
|
||||
|
|
|
@ -27,7 +27,6 @@ class SideShiftExchangeProvider extends ExchangeProvider {
|
|||
static const List<CryptoCurrency> _notSupported = [
|
||||
CryptoCurrency.xhv,
|
||||
CryptoCurrency.dcr,
|
||||
CryptoCurrency.husd,
|
||||
CryptoCurrency.kmd,
|
||||
CryptoCurrency.mkr,
|
||||
CryptoCurrency.near,
|
||||
|
@ -38,6 +37,7 @@ class SideShiftExchangeProvider extends ExchangeProvider {
|
|||
CryptoCurrency.rvn,
|
||||
CryptoCurrency.scrt,
|
||||
CryptoCurrency.stx,
|
||||
CryptoCurrency.bttc,
|
||||
];
|
||||
|
||||
static List<ExchangePair> _supportedPairs() {
|
||||
|
|
|
@ -37,7 +37,7 @@ class IoniaGiftCard {
|
|||
purchaseAmount: element['PurchaseAmount'] as double,
|
||||
actualAmount: element['ActualAmount'] as double,
|
||||
totalTransactionAmount: element['TotalTransactionAmount'] as double,
|
||||
totalDashTransactionAmount: element['TotalDashTransactionAmount'] as double,
|
||||
totalDashTransactionAmount: (element['TotalDashTransactionAmount'] as double?) ?? 0.0,
|
||||
remainingAmount: element['RemainingAmount'] as double,
|
||||
isActive: element['IsActive'] as bool,
|
||||
isEmpty: element['IsEmpty'] as bool,
|
||||
|
|
|
@ -148,8 +148,8 @@ class IoniaService {
|
|||
|
||||
// Redeem
|
||||
|
||||
Future<void> redeem(IoniaGiftCard giftCard) async {
|
||||
await chargeGiftCard(giftCardId: giftCard.id, amount: giftCard.remainingAmount);
|
||||
Future<void> redeem({required int giftCardId, required double amount}) async {
|
||||
await chargeGiftCard(giftCardId: giftCardId, amount: amount);
|
||||
}
|
||||
|
||||
// Get Gift Card
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
import 'dart:async';
|
||||
import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
||||
import 'package:cake_wallet/core/auth_service.dart';
|
||||
import 'package:cake_wallet/entities/language_service.dart';
|
||||
import 'package:cake_wallet/buy/order.dart';
|
||||
import 'package:cake_wallet/ionia/ionia_category.dart';
|
||||
|
@ -40,6 +41,7 @@ import 'package:cake_wallet/wallet_type_utils.dart';
|
|||
|
||||
final navigatorKey = GlobalKey<NavigatorState>();
|
||||
final rootKey = GlobalKey<RootState>();
|
||||
final RouteObserver<PageRoute> routeObserver = RouteObserver<PageRoute>();
|
||||
|
||||
Future<void> main() async {
|
||||
try {
|
||||
|
@ -127,7 +129,7 @@ Future<void> main() async {
|
|||
exchangeTemplates: exchangeTemplates,
|
||||
transactionDescriptions: transactionDescriptions,
|
||||
secureStorage: secureStorage,
|
||||
initialMigrationVersion: 18);
|
||||
initialMigrationVersion: 19);
|
||||
runApp(App());
|
||||
} catch (e, stacktrace) {
|
||||
runApp(MaterialApp(
|
||||
|
@ -203,12 +205,6 @@ class AppState extends State<App> with SingleTickerProviderStateMixin {
|
|||
//_handleInitialUri();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
stream?.cancel();
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
Future<void> _handleInitialUri() async {
|
||||
try {
|
||||
final uri = await getInitialUri();
|
||||
|
@ -256,6 +252,7 @@ class AppState extends State<App> with SingleTickerProviderStateMixin {
|
|||
Widget build(BuildContext context) {
|
||||
return Observer(builder: (BuildContext context) {
|
||||
final appStore = getIt.get<AppStore>();
|
||||
final authService = getIt.get<AuthService>();
|
||||
final settingsStore = appStore.settingsStore;
|
||||
final statusBarColor = Colors.transparent;
|
||||
final authenticationStore = getIt.get<AuthenticationStore>();
|
||||
|
@ -280,7 +277,9 @@ class AppState extends State<App> with SingleTickerProviderStateMixin {
|
|||
appStore: appStore,
|
||||
authenticationStore: authenticationStore,
|
||||
navigatorKey: navigatorKey,
|
||||
authService: authService,
|
||||
child: MaterialApp(
|
||||
navigatorObservers: [routeObserver],
|
||||
navigatorKey: navigatorKey,
|
||||
debugShowCheckedModeBanner: false,
|
||||
theme: settingsStore.theme,
|
||||
|
|
|
@ -25,6 +25,7 @@ import 'package:cake_wallet/src/screens/settings/connection_sync_page.dart';
|
|||
import 'package:cake_wallet/src/screens/support/support_page.dart';
|
||||
import 'package:cake_wallet/src/screens/unspent_coins/unspent_coins_details_page.dart';
|
||||
import 'package:cake_wallet/src/screens/unspent_coins/unspent_coins_list_page.dart';
|
||||
import 'package:cake_wallet/utils/payment_request.dart';
|
||||
import 'package:cake_wallet/view_model/monero_account_list/account_list_item.dart';
|
||||
import 'package:cake_wallet/view_model/node_list/node_create_or_edit_view_model.dart';
|
||||
import 'package:cake_wallet/view_model/advanced_privacy_settings_view_model.dart';
|
||||
|
@ -216,8 +217,12 @@ Route<dynamic> createRoute(RouteSettings settings) {
|
|||
builder: (_) => getIt.get<DashboardPage>());
|
||||
|
||||
case Routes.send:
|
||||
final initialPaymentRequest = settings.arguments as PaymentRequest?;
|
||||
|
||||
return CupertinoPageRoute<void>(
|
||||
fullscreenDialog: true, builder: (_) => getIt.get<SendPage>());
|
||||
fullscreenDialog: true, builder: (_) => getIt.get<SendPage>(
|
||||
param1: initialPaymentRequest,
|
||||
));
|
||||
|
||||
case Routes.sendTemplate:
|
||||
return CupertinoPageRoute<void>(
|
||||
|
|
|
@ -72,10 +72,10 @@ class ContactListPage extends BasePage {
|
|||
dividerThemeColor:
|
||||
Theme.of(context).primaryTextTheme.caption!.decorationColor!,
|
||||
sectionTitleBuilder: (_, int sectionIndex) {
|
||||
var title = 'Contacts';
|
||||
var title = S.current.contact_list_contacts;
|
||||
|
||||
if (sectionIndex == 0) {
|
||||
title = 'My wallets';
|
||||
title = S.current.contact_list_wallets;
|
||||
}
|
||||
|
||||
return Container(
|
||||
|
|
|
@ -21,6 +21,12 @@ class WalletMenu {
|
|||
height: 16, width: 16),
|
||||
handler: () => Navigator.of(context).pushNamed(Routes.walletList),
|
||||
),
|
||||
WalletMenuItem(
|
||||
title: S.current.address_book_menu,
|
||||
image: Image.asset('assets/images/open_book_menu.png',
|
||||
height: 16, width: 16),
|
||||
handler: () => Navigator.of(context).pushNamed(Routes.addressBook),
|
||||
),
|
||||
WalletMenuItem(
|
||||
title: S.current.security_and_backup,
|
||||
image:
|
||||
|
@ -29,18 +35,12 @@ class WalletMenu {
|
|||
Navigator.of(context).pushNamed(Routes.securityBackupPage);
|
||||
}),
|
||||
WalletMenuItem(
|
||||
title: S.current.privacy,
|
||||
title: S.current.privacy_settings,
|
||||
image:
|
||||
Image.asset('assets/images/eye_menu.png', height: 16, width: 16),
|
||||
Image.asset('assets/images/privacy_menu.png', height: 16, width: 16),
|
||||
handler: () {
|
||||
Navigator.of(context).pushNamed(Routes.privacyPage);
|
||||
}),
|
||||
WalletMenuItem(
|
||||
title: S.current.address_book_menu,
|
||||
image: Image.asset('assets/images/open_book_menu.png',
|
||||
height: 16, width: 16),
|
||||
handler: () => Navigator.of(context).pushNamed(Routes.addressBook),
|
||||
),
|
||||
WalletMenuItem(
|
||||
title: S.current.display_settings,
|
||||
image: Image.asset('assets/images/eye_menu.png',
|
||||
|
|
|
@ -9,12 +9,7 @@ class FilterTile extends StatelessWidget {
|
|||
Widget build(BuildContext context) {
|
||||
return Container(
|
||||
width: double.infinity,
|
||||
padding: EdgeInsets.only(
|
||||
top: 18,
|
||||
bottom: 18,
|
||||
left: 24,
|
||||
right: 24
|
||||
),
|
||||
padding: EdgeInsets.symmetric(vertical: 8.0, horizontal: 24.0),
|
||||
child: child,
|
||||
);
|
||||
}
|
||||
|
|
|
@ -1,25 +1,26 @@
|
|||
import 'dart:ui';
|
||||
import 'package:cake_wallet/palette.dart';
|
||||
import 'package:cake_wallet/src/screens/dashboard/widgets/filter_tile.dart';
|
||||
import 'package:cake_wallet/src/widgets/section_divider.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_checkbox.dart';
|
||||
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/src/widgets/alert_background.dart';
|
||||
import 'package:cake_wallet/src/widgets/alert_close_button.dart';
|
||||
import 'package:cake_wallet/src/widgets/checkbox_widget.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||
//import 'package:date_range_picker/date_range_picker.dart' as date_rage_picker;
|
||||
|
||||
class FilterWidget extends StatelessWidget {
|
||||
FilterWidget({required this.dashboardViewModel});
|
||||
|
||||
final DashboardViewModel dashboardViewModel;
|
||||
final backVector = Image.asset('assets/images/back_vector.png',
|
||||
color: Palette.darkBlueCraiola
|
||||
);
|
||||
final closeIcon = Image.asset('assets/images/close.png', color: Palette.darkBlueCraiola);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
const sectionDivider = const SectionDivider();
|
||||
return AlertBackground(
|
||||
child: Stack(
|
||||
alignment: Alignment.center,
|
||||
|
@ -27,114 +28,66 @@ class FilterWidget extends StatelessWidget {
|
|||
Column(
|
||||
mainAxisSize: MainAxisSize.min,
|
||||
children: <Widget>[
|
||||
Text(
|
||||
S.of(context).filters,
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 24, right: 24, top: 24),
|
||||
child: ClipRRect(
|
||||
borderRadius: BorderRadius.all(Radius.circular(24)),
|
||||
child: Container(
|
||||
color: Theme.of(context).textTheme!.bodyText1!.decorationColor!,
|
||||
child: Column(crossAxisAlignment: CrossAxisAlignment.start, children: [
|
||||
Padding(
|
||||
padding: EdgeInsets.all(24.0),
|
||||
child: Text(
|
||||
S.of(context).filter_by,
|
||||
style: TextStyle(
|
||||
color: Colors.white,
|
||||
fontSize: 18,
|
||||
fontWeight: FontWeight.bold,
|
||||
color: Theme.of(context).primaryTextTheme.overline!.color!,
|
||||
fontSize: 16,
|
||||
fontFamily: 'Lato',
|
||||
decoration: TextDecoration.none,
|
||||
),
|
||||
),
|
||||
Padding(
|
||||
padding: EdgeInsets.only(
|
||||
left: 24,
|
||||
right: 24,
|
||||
top: 24
|
||||
),
|
||||
child: ClipRRect(
|
||||
borderRadius: BorderRadius.all(Radius.circular(14)),
|
||||
child: Container(
|
||||
color: Theme.of(context).textTheme!.bodyText1!.decorationColor!,
|
||||
child: ListView.separated(
|
||||
sectionDivider,
|
||||
ListView.separated(
|
||||
padding: EdgeInsets.zero,
|
||||
shrinkWrap: true,
|
||||
physics: const NeverScrollableScrollPhysics(),
|
||||
itemCount: dashboardViewModel.filterItems.length,
|
||||
separatorBuilder: (context, _) => Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).accentTextTheme!.subtitle1!.backgroundColor!,
|
||||
),
|
||||
separatorBuilder: (context, _) => sectionDivider,
|
||||
itemBuilder: (_, index1) {
|
||||
final title = dashboardViewModel.filterItems.keys.elementAt(index1);
|
||||
final section = dashboardViewModel.filterItems.values.elementAt(index1);
|
||||
|
||||
return Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Padding(
|
||||
padding: EdgeInsets.only(
|
||||
top: 20,
|
||||
left: 24,
|
||||
right: 24
|
||||
),
|
||||
padding: EdgeInsets.only(top: 20, left: 24, right: 24),
|
||||
child: Text(
|
||||
title,
|
||||
style: TextStyle(
|
||||
color: Theme.of(context).accentTextTheme!.subtitle1!.color!,
|
||||
color: Theme.of(context).primaryTextTheme!.headline6!.color!,
|
||||
fontSize: 16,
|
||||
fontWeight: FontWeight.w500,
|
||||
fontFamily: 'Lato',
|
||||
decoration: TextDecoration.none
|
||||
fontWeight: FontWeight.bold,
|
||||
decoration: TextDecoration.none),
|
||||
),
|
||||
),
|
||||
),
|
||||
ListView.separated(
|
||||
ListView.builder(
|
||||
padding: EdgeInsets.symmetric(vertical: 8.0),
|
||||
shrinkWrap: true,
|
||||
physics: const NeverScrollableScrollPhysics(),
|
||||
itemCount: section.length,
|
||||
separatorBuilder: (context, _) => Container(
|
||||
height: 1,
|
||||
padding: EdgeInsets.only(left: 24),
|
||||
color: Theme.of(context).textTheme!.bodyText1!.decorationColor!,
|
||||
child: Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).accentTextTheme!.subtitle1!.backgroundColor!,
|
||||
),
|
||||
),
|
||||
itemBuilder: (_, index2) {
|
||||
|
||||
final item = section[index2];
|
||||
final content = item.onChanged != null
|
||||
? CheckboxWidget(
|
||||
final content = Observer(
|
||||
builder: (_) => StandardCheckbox(
|
||||
value: item.value(),
|
||||
caption: item.caption,
|
||||
onChanged: item.onChanged
|
||||
)
|
||||
: GestureDetector(
|
||||
onTap: () async {
|
||||
//final List<DateTime> picked =
|
||||
//await date_rage_picker.showDatePicker(
|
||||
// context: context,
|
||||
// initialFirstDate: DateTime.now()
|
||||
// .subtract(Duration(days: 1)),
|
||||
// initialLastDate: (DateTime.now()),
|
||||
// firstDate: DateTime(2015),
|
||||
// lastDate: DateTime.now()
|
||||
// .add(Duration(days: 1)));
|
||||
|
||||
//if (picked != null && picked.length == 2) {
|
||||
// dashboardViewModel.transactionFilterStore
|
||||
// .changeStartDate(picked.first);
|
||||
// dashboardViewModel.transactionFilterStore
|
||||
// .changeEndDate(picked.last);
|
||||
//}
|
||||
},
|
||||
child: Padding(
|
||||
padding: EdgeInsets.only(left: 32),
|
||||
child: Text(
|
||||
item.caption,
|
||||
style: TextStyle(
|
||||
color: Theme.of(context).primaryTextTheme!.headline6!.color!,
|
||||
fontSize: 18,
|
||||
fontFamily: 'Lato',
|
||||
fontWeight: FontWeight.w500,
|
||||
decoration: TextDecoration.none
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
gradientBackground: true,
|
||||
borderColor: Theme.of(context).dividerColor,
|
||||
iconColor: Colors.white,
|
||||
onChanged: (value) => item.onChanged(),
|
||||
));
|
||||
return FilterTile(child: content);
|
||||
},
|
||||
)
|
||||
|
@ -142,12 +95,13 @@ class FilterWidget extends StatelessWidget {
|
|||
);
|
||||
},
|
||||
),
|
||||
]),
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
AlertCloseButton(image: backVector)
|
||||
AlertCloseButton(image: closeIcon)
|
||||
],
|
||||
),
|
||||
);
|
||||
|
|
|
@ -6,6 +6,7 @@ import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
|||
import 'package:cw_core/wallet_type.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
import 'package:url_launcher/url_launcher.dart';
|
||||
|
||||
class MarketPlacePage extends StatelessWidget {
|
||||
|
||||
|
@ -48,6 +49,15 @@ class MarketPlacePage extends StatelessWidget {
|
|||
title: S.of(context).cake_pay_title,
|
||||
subTitle: S.of(context).cake_pay_subtitle,
|
||||
),
|
||||
SizedBox(height: 20),
|
||||
MarketPlaceItem(
|
||||
onTap: () => launchUrl(
|
||||
Uri.https("buy.cakepay.com"),
|
||||
mode: LaunchMode.externalApplication,
|
||||
),
|
||||
title: S.of(context).cake_pay_web_cards_title,
|
||||
subTitle: S.of(context).cake_pay_web_cards_subtitle,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
|
|
|
@ -40,7 +40,6 @@ class ExchangePage extends BasePage {
|
|||
final ExchangeViewModel exchangeViewModel;
|
||||
final depositKey = GlobalKey<ExchangeCardState>();
|
||||
final receiveKey = GlobalKey<ExchangeCardState>();
|
||||
final checkBoxKey = GlobalKey<StandardCheckboxState>();
|
||||
final _formKey = GlobalKey<FormState>();
|
||||
final _depositAmountFocus = FocusNode();
|
||||
final _depositAddressFocus = FocusNode();
|
||||
|
@ -339,7 +338,6 @@ class ExchangePage extends BasePage {
|
|||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
StandardCheckbox(
|
||||
key: checkBoxKey,
|
||||
value: exchangeViewModel.isFixedRateMode,
|
||||
caption: S.of(context).fixed_rate,
|
||||
onChanged: (value) =>
|
||||
|
@ -682,12 +680,6 @@ class ExchangePage extends BasePage {
|
|||
}
|
||||
});
|
||||
|
||||
reaction((_) => exchangeViewModel.isFixedRateMode, (bool value) {
|
||||
if (checkBoxKey.currentState!.value != exchangeViewModel.isFixedRateMode) {
|
||||
checkBoxKey.currentState!.value = exchangeViewModel.isFixedRateMode;
|
||||
}
|
||||
});
|
||||
|
||||
depositAddressController.addListener(
|
||||
() => exchangeViewModel.depositAddress = depositAddressController.text);
|
||||
|
||||
|
|
|
@ -56,7 +56,7 @@ class CurrencyPickerState extends State<CurrencyPicker> {
|
|||
.where((element) =>
|
||||
(element.title != null ? element.title.toLowerCase().contains(subString.toLowerCase()) : false) ||
|
||||
(element.tag != null ? element.tag!.toLowerCase().contains(subString.toLowerCase()) : false) ||
|
||||
(element.name != null ? element.name!.toLowerCase().contains(subString.toLowerCase()) : false))
|
||||
(element.fullName != null ? element.fullName!.toLowerCase().contains(subString.toLowerCase()) : false))
|
||||
.toList();
|
||||
return;
|
||||
}
|
||||
|
|
|
@ -8,7 +8,7 @@ import 'package:cake_wallet/generated/i18n.dart';
|
|||
import 'package:cake_wallet/core/execution_state.dart';
|
||||
import 'package:cake_wallet/src/screens/exchange_trade/information_page.dart';
|
||||
import 'package:cake_wallet/src/screens/send/widgets/confirm_sending_alert.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/list_row.dart';
|
||||
import 'package:cake_wallet/utils/show_bar.dart';
|
||||
import 'package:cake_wallet/utils/show_pop_up.dart';
|
||||
import 'package:cake_wallet/view_model/exchange/exchange_trade_view_model.dart';
|
||||
|
@ -194,7 +194,7 @@ class ExchangeTradeState extends State<ExchangeTradeForm> {
|
|||
final item = widget.exchangeTradeViewModel.items[index];
|
||||
final value = item.data ?? fetchingLabel;
|
||||
|
||||
final content = StandartListRow(
|
||||
final content = ListRow(
|
||||
title: item.title,
|
||||
value: value,
|
||||
valueFontSize: 14,
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import 'package:cake_wallet/core/execution_state.dart';
|
||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||
import 'package:cake_wallet/src/screens/ionia/widgets/card_item.dart';
|
||||
import 'package:cake_wallet/src/widgets/base_text_form_field.dart';
|
||||
|
@ -24,7 +25,6 @@ class IoniaCustomRedeemPage extends BasePage {
|
|||
|
||||
final IoniaCustomRedeemViewModel ioniaCustomRedeemViewModel;
|
||||
|
||||
|
||||
@override
|
||||
String get title => S.current.custom_redeem_amount;
|
||||
|
||||
|
@ -50,7 +50,7 @@ class IoniaCustomRedeemPage extends BasePage {
|
|||
disableScroll: true,
|
||||
config: KeyboardActionsConfig(
|
||||
keyboardActionsPlatform: KeyboardActionsPlatform.IOS,
|
||||
keyboardBarColor: Theme.of(context).accentTextTheme!.bodyText1!.backgroundColor!,
|
||||
keyboardBarColor: Theme.of(context).accentTextTheme.bodyText1!.backgroundColor!,
|
||||
nextFocus: false,
|
||||
actions: [
|
||||
KeyboardActionsItem(
|
||||
|
@ -67,10 +67,11 @@ class IoniaCustomRedeemPage extends BasePage {
|
|||
Container(
|
||||
padding: EdgeInsets.symmetric(horizontal: 25),
|
||||
decoration: BoxDecoration(
|
||||
borderRadius: BorderRadius.only(bottomLeft: Radius.circular(24), bottomRight: Radius.circular(24)),
|
||||
borderRadius: BorderRadius.only(
|
||||
bottomLeft: Radius.circular(24), bottomRight: Radius.circular(24)),
|
||||
gradient: LinearGradient(colors: [
|
||||
Theme.of(context).primaryTextTheme!.subtitle1!.color!,
|
||||
Theme.of(context).primaryTextTheme!.subtitle1!.decorationColor!,
|
||||
Theme.of(context).primaryTextTheme.subtitle1!.color!,
|
||||
Theme.of(context).primaryTextTheme.subtitle1!.decorationColor!,
|
||||
], begin: Alignment.topLeft, end: Alignment.bottomRight),
|
||||
),
|
||||
child: Column(
|
||||
|
@ -85,11 +86,11 @@ class IoniaCustomRedeemPage extends BasePage {
|
|||
inputFormatters: [FilteringTextInputFormatter.deny(RegExp('[\-|\ ]'))],
|
||||
hintText: '1000',
|
||||
placeholderTextStyle: TextStyle(
|
||||
color: Theme.of(context).primaryTextTheme!.headline5!.color!,
|
||||
color: Theme.of(context).primaryTextTheme.headline5!.color!,
|
||||
fontWeight: FontWeight.w500,
|
||||
fontSize: 36,
|
||||
),
|
||||
borderColor: Theme.of(context).primaryTextTheme!.headline5!.color!,
|
||||
borderColor: Theme.of(context).primaryTextTheme.headline5!.color!,
|
||||
textColor: Colors.white,
|
||||
textStyle: TextStyle(
|
||||
color: Colors.white,
|
||||
|
@ -114,14 +115,17 @@ class IoniaCustomRedeemPage extends BasePage {
|
|||
),
|
||||
),
|
||||
SizedBox(height: 8),
|
||||
Observer(builder: (_)=>
|
||||
!ioniaCustomRedeemViewModel.disableRedeem ?
|
||||
Center(
|
||||
child: Text('\$${giftCard.remainingAmount} - \$${ioniaCustomRedeemViewModel.amount} = \$${ioniaCustomRedeemViewModel.formattedRemaining} ${S.of(context).remaining}',
|
||||
Observer(
|
||||
builder: (_) => !ioniaCustomRedeemViewModel.disableRedeem
|
||||
? Center(
|
||||
child: Text(
|
||||
'\$${giftCard.remainingAmount} - \$${ioniaCustomRedeemViewModel.amount} = \$${ioniaCustomRedeemViewModel.formattedRemaining} ${S.of(context).remaining}',
|
||||
style: TextStyle(
|
||||
color: Theme.of(context).primaryTextTheme!.headline5!.color!,
|
||||
),),
|
||||
) : SizedBox.shrink(),
|
||||
color: Theme.of(context).primaryTextTheme.headline5!.color!,
|
||||
),
|
||||
),
|
||||
)
|
||||
: SizedBox.shrink(),
|
||||
),
|
||||
SizedBox(height: 24),
|
||||
],
|
||||
|
@ -131,11 +135,15 @@ class IoniaCustomRedeemPage extends BasePage {
|
|||
padding: const EdgeInsets.all(24.0),
|
||||
child: CardItem(
|
||||
title: giftCard.legalName,
|
||||
backgroundColor: Theme.of(context).accentTextTheme!.headline1!.backgroundColor!.withOpacity(0.1),
|
||||
backgroundColor: Theme.of(context)
|
||||
.accentTextTheme
|
||||
.headline1!
|
||||
.backgroundColor!
|
||||
.withOpacity(0.1),
|
||||
discount: giftCard.remainingAmount,
|
||||
isAmount: true,
|
||||
discountBackground: AssetImage('assets/images/red_badge_discount.png'),
|
||||
titleColor: Theme.of(context).accentTextTheme!.headline1!.backgroundColor!,
|
||||
titleColor: Theme.of(context).accentTextTheme.headline1!.backgroundColor!,
|
||||
subtitleColor: Theme.of(context).hintColor,
|
||||
subTitle: S.of(context).online,
|
||||
logoUrl: giftCard.logoUrl,
|
||||
|
@ -145,16 +153,19 @@ class IoniaCustomRedeemPage extends BasePage {
|
|||
),
|
||||
bottomSection: Column(
|
||||
children: [
|
||||
Padding(
|
||||
Observer(
|
||||
builder: (_) => Padding(
|
||||
padding: EdgeInsets.only(bottom: 12),
|
||||
child: PrimaryButton(
|
||||
onPressed: () {
|
||||
Navigator.of(context).pop(_amountController.text);
|
||||
},
|
||||
child: LoadingPrimaryButton(
|
||||
isLoading: ioniaCustomRedeemViewModel.redeemState is IsExecutingState,
|
||||
isDisabled: ioniaCustomRedeemViewModel.disableRedeem,
|
||||
text: S.of(context).add_custom_redemption,
|
||||
color: Theme.of(context).accentTextTheme!.bodyText1!.color!,
|
||||
color: Theme.of(context).accentTextTheme.bodyText1!.color!,
|
||||
textColor: Colors.white,
|
||||
onPressed: () => ioniaCustomRedeemViewModel.addCustomRedeem().then((value) {
|
||||
Navigator.of(context).pop(ioniaCustomRedeemViewModel.remaining.toString());
|
||||
}),
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(height: 30),
|
||||
|
|
|
@ -11,6 +11,7 @@ import 'package:cake_wallet/src/widgets/scollable_with_bottom_section.dart';
|
|||
import 'package:cake_wallet/typography.dart';
|
||||
import 'package:cake_wallet/utils/show_bar.dart';
|
||||
import 'package:cake_wallet/utils/show_pop_up.dart';
|
||||
import 'package:cake_wallet/utils/route_aware.dart';
|
||||
import 'package:cake_wallet/view_model/ionia/ionia_gift_card_details_view_model.dart';
|
||||
import 'package:device_display_brightness/device_display_brightness.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
@ -32,7 +33,7 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
|
||||
final _backButton = Icon(
|
||||
Icons.arrow_back_ios,
|
||||
color: Theme.of(context).primaryTextTheme!.headline6!.color!,
|
||||
color: Theme.of(context).primaryTextTheme.headline6!.color!,
|
||||
size: 16,
|
||||
);
|
||||
return Padding(
|
||||
|
@ -47,10 +48,7 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
//highlightColor: Colors.transparent,
|
||||
//splashColor: Colors.transparent,
|
||||
//padding: EdgeInsets.all(0),
|
||||
onPressed: () {
|
||||
onClose(context);
|
||||
DeviceDisplayBrightness.setBrightness(viewModel.brightness);
|
||||
},
|
||||
onPressed: ()=> onClose(context),
|
||||
child: _backButton),
|
||||
),
|
||||
),
|
||||
|
@ -61,13 +59,13 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
Widget middle(BuildContext context) {
|
||||
return Text(
|
||||
viewModel.giftCard.legalName,
|
||||
style: textMediumSemiBold(color: Theme.of(context).accentTextTheme!.headline1!.backgroundColor!),
|
||||
style:
|
||||
textMediumSemiBold(color: Theme.of(context).accentTextTheme.headline1!.backgroundColor!),
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
Widget body(BuildContext context) {
|
||||
viewModel.increaseBrightness();
|
||||
reaction((_) => viewModel.redeemState, (ExecutionState state) {
|
||||
if (state is FailureState) {
|
||||
WidgetsBinding.instance.addPostFrameCallback((_) {
|
||||
|
@ -84,7 +82,12 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
}
|
||||
});
|
||||
|
||||
return ScrollableWithBottomSection(
|
||||
return RouteAwareWidget(
|
||||
pushToWidget: ()=> viewModel.increaseBrightness(),
|
||||
pushToNextWidget: ()=> DeviceDisplayBrightness.setBrightness(viewModel.brightness),
|
||||
popNextWidget: ()=> viewModel.increaseBrightness(),
|
||||
popWidget: ()=> DeviceDisplayBrightness.setBrightness(viewModel.brightness),
|
||||
child: ScrollableWithBottomSection(
|
||||
contentPadding: EdgeInsets.all(24),
|
||||
content: Column(
|
||||
children: [
|
||||
|
@ -102,19 +105,20 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
title: S.of(context).gift_card_number,
|
||||
subTitle: viewModel.giftCard.cardNumber,
|
||||
),
|
||||
if (viewModel.giftCard.cardPin?.isNotEmpty ?? false)
|
||||
...[Divider(height: 30),
|
||||
if (viewModel.giftCard.cardPin.isNotEmpty) ...[
|
||||
Divider(height: 30),
|
||||
buildIoniaTile(
|
||||
context,
|
||||
title: S.of(context).pin_number,
|
||||
subTitle: viewModel.giftCard.cardPin,
|
||||
)],
|
||||
)
|
||||
],
|
||||
Divider(height: 30),
|
||||
Observer(builder: (_) =>
|
||||
buildIoniaTile(
|
||||
Observer(
|
||||
builder: (_) => buildIoniaTile(
|
||||
context,
|
||||
title: S.of(context).amount,
|
||||
subTitle: viewModel.remainingAmount.toStringAsFixed(2) ?? '0.00',
|
||||
subTitle: viewModel.remainingAmount.toStringAsFixed(2),
|
||||
)),
|
||||
Divider(height: 50),
|
||||
TextIconButton(
|
||||
|
@ -130,29 +134,28 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
if (!viewModel.giftCard.isEmpty) {
|
||||
return Column(
|
||||
children: [
|
||||
//PrimaryButton(
|
||||
// onPressed: () async {
|
||||
// final amount = await Navigator.of(context)
|
||||
// .pushNamed(Routes.ioniaMoreOptionsPage, arguments: [viewModel.giftCard]) as String;
|
||||
// if (amount != null) {
|
||||
// viewModel.updateRemaining(double.parse(amount));
|
||||
// }
|
||||
// },
|
||||
// text: S.of(context).more_options,
|
||||
// color: Theme.of(context).accentTextTheme!.caption!.color!,
|
||||
// textColor: Theme.of(context).primaryTextTheme!.headline6!.color!,
|
||||
//),
|
||||
//SizedBox(height: 12),
|
||||
PrimaryButton(
|
||||
onPressed: () async {
|
||||
await Navigator.of(context).pushNamed(
|
||||
Routes.ioniaMoreOptionsPage,
|
||||
arguments: [viewModel.giftCard]) as String?;
|
||||
viewModel.refeshCard();
|
||||
},
|
||||
text: S.of(context).more_options,
|
||||
color: Theme.of(context).accentTextTheme.caption!.color!,
|
||||
textColor: Theme.of(context).primaryTextTheme.headline6!.color!,
|
||||
),
|
||||
SizedBox(height: 12),
|
||||
LoadingPrimaryButton(
|
||||
isLoading: viewModel.redeemState is IsExecutingState,
|
||||
onPressed: () => viewModel.redeem().then(
|
||||
(_) {
|
||||
Navigator.of(context)
|
||||
.pushNamedAndRemoveUntil(Routes.ioniaManageCardsPage, (route) => route.isFirst);
|
||||
Navigator.of(context).pushNamedAndRemoveUntil(
|
||||
Routes.ioniaManageCardsPage, (route) => route.isFirst);
|
||||
},
|
||||
),
|
||||
text: S.of(context).mark_as_redeemed,
|
||||
color: Theme.of(context).accentTextTheme!.bodyText1!.color!,
|
||||
color: Theme.of(context).accentTextTheme.bodyText1!.color!,
|
||||
textColor: Colors.white,
|
||||
),
|
||||
],
|
||||
|
@ -163,7 +166,7 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
},
|
||||
),
|
||||
),
|
||||
);
|
||||
));
|
||||
}
|
||||
|
||||
Widget buildIoniaTile(BuildContext context, {required String title, required String subTitle}) {
|
||||
|
@ -172,8 +175,7 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
subTitle: subTitle,
|
||||
onTap: () {
|
||||
Clipboard.setData(ClipboardData(text: subTitle));
|
||||
showBar<void>(context,
|
||||
S.of(context).transaction_details_copied(title));
|
||||
showBar<void>(context, S.of(context).transaction_details_copied(title));
|
||||
});
|
||||
}
|
||||
|
||||
|
@ -196,13 +198,13 @@ class IoniaGiftCardDetailPage extends BasePage {
|
|||
child: Text(
|
||||
instruction.header,
|
||||
style: textLargeSemiBold(
|
||||
color: Theme.of(context).textTheme!.headline3!.color!,
|
||||
color: Theme.of(context).textTheme.headline3!.color!,
|
||||
),
|
||||
)),
|
||||
Text(
|
||||
instruction.body,
|
||||
style: textMedium(
|
||||
color: Theme.of(context).textTheme!.headline3!.color!,
|
||||
color: Theme.of(context).textTheme.headline3!.color!,
|
||||
),
|
||||
)
|
||||
];
|
||||
|
|
|
@ -5,7 +5,6 @@ import 'package:cake_wallet/generated/i18n.dart';
|
|||
import 'package:cake_wallet/typography.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
|
||||
class IoniaMoreOptionsPage extends BasePage {
|
||||
IoniaMoreOptionsPage(this.giftCard);
|
||||
|
||||
|
@ -16,7 +15,7 @@ class IoniaMoreOptionsPage extends BasePage {
|
|||
return Text(
|
||||
S.current.more_options,
|
||||
style: textMediumSemiBold(
|
||||
color: Theme.of(context).accentTextTheme!.headline1!.backgroundColor!,
|
||||
color: Theme.of(context).accentTextTheme.headline1!.backgroundColor!,
|
||||
),
|
||||
);
|
||||
}
|
||||
|
@ -28,16 +27,24 @@ class IoniaMoreOptionsPage extends BasePage {
|
|||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.stretch,
|
||||
children: [
|
||||
SizedBox(height: 10,),
|
||||
Center(child: Text(S.of(context).choose_from_available_options, style: textMedium(
|
||||
color: Theme.of(context).primaryTextTheme!.headline6!.color!,
|
||||
),)),
|
||||
SizedBox(height: 40,),
|
||||
SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
Center(
|
||||
child: Text(
|
||||
S.of(context).choose_from_available_options,
|
||||
style: textMedium(
|
||||
color: Theme.of(context).primaryTextTheme.headline6!.color!,
|
||||
),
|
||||
),
|
||||
),
|
||||
SizedBox(height: 40),
|
||||
InkWell(
|
||||
onTap: () async {
|
||||
final amount = await Navigator.of(context).pushNamed(Routes.ioniaCustomRedeemPage, arguments: [giftCard]) as String;
|
||||
if(amount.isNotEmpty){
|
||||
Navigator.pop(context, amount);
|
||||
final amount = await Navigator.of(context)
|
||||
.pushNamed(Routes.ioniaCustomRedeemPage, arguments: [giftCard]) as String?;
|
||||
if (amount != null && amount.isNotEmpty) {
|
||||
Navigator.pop(context);
|
||||
}
|
||||
},
|
||||
child: _GradiantContainer(
|
||||
|
@ -57,10 +64,7 @@ class IoniaMoreOptionsPage extends BasePage {
|
|||
}
|
||||
|
||||
class _GradiantContainer extends StatelessWidget {
|
||||
const _GradiantContainer({
|
||||
Key? key,
|
||||
required this.content
|
||||
}) : super(key: key);
|
||||
const _GradiantContainer({Key? key, required this.content}) : super(key: key);
|
||||
|
||||
final Widget content;
|
||||
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import 'dart:ui';
|
||||
import 'package:cake_wallet/src/widgets/section_divider.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||
|
@ -84,10 +85,7 @@ class MoneroAccountListPage extends StatelessWidget {
|
|||
padding: EdgeInsets.zero,
|
||||
controller: controller,
|
||||
separatorBuilder: (context, index) =>
|
||||
Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).dividerColor,
|
||||
),
|
||||
const SectionDivider(),
|
||||
itemCount: accounts.length ?? 0,
|
||||
itemBuilder: (context, index) {
|
||||
final account = accounts[index];
|
||||
|
|
|
@ -7,7 +7,7 @@ import 'package:flutter/services.dart';
|
|||
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/list_row.dart';
|
||||
import 'package:cake_wallet/src/screens/trade_details/track_trade_list_item.dart';
|
||||
|
||||
class OrderDetailsPage extends BasePage {
|
||||
|
@ -57,7 +57,7 @@ class OrderDetailsPageBodyState extends State<OrderDetailsPageBody> {
|
|||
if (item is TrackTradeListItem) {
|
||||
return GestureDetector(
|
||||
onTap: item.onTap,
|
||||
child: StandartListRow(
|
||||
child: ListRow(
|
||||
title: '${item.title}', value: '${item.value}'));
|
||||
} else {
|
||||
return GestureDetector(
|
||||
|
@ -65,7 +65,7 @@ class OrderDetailsPageBodyState extends State<OrderDetailsPageBody> {
|
|||
Clipboard.setData(ClipboardData(text: '${item.value}'));
|
||||
showBar<void>(context, S.of(context).copied_to_clipboard);
|
||||
},
|
||||
child: StandartListRow(
|
||||
child: ListRow(
|
||||
title: '${item.title}', value: '${item.value}'));
|
||||
}
|
||||
});
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import 'package:cake_wallet/src/widgets/keyboard_done_button.dart';
|
||||
import 'package:cake_wallet/src/widgets/section_divider.dart';
|
||||
import 'package:cake_wallet/themes/theme_base.dart';
|
||||
import 'package:cake_wallet/utils/show_pop_up.dart';
|
||||
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
|
||||
|
@ -135,8 +136,7 @@ class ReceivePage extends BasePage {
|
|||
Observer(
|
||||
builder: (_) => ListView.separated(
|
||||
padding: EdgeInsets.all(0),
|
||||
separatorBuilder: (context, _) => Container(
|
||||
height: 1, color: Theme.of(context).dividerColor),
|
||||
separatorBuilder: (context, _) => const SectionDivider(),
|
||||
shrinkWrap: true,
|
||||
physics: NeverScrollableScrollPhysics(),
|
||||
itemCount: addressListViewModel.items.length,
|
||||
|
|
|
@ -1,23 +1,28 @@
|
|||
import 'dart:async';
|
||||
import 'package:cake_wallet/core/auth_service.dart';
|
||||
import 'package:cake_wallet/utils/payment_request.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/routes.dart';
|
||||
import 'package:cake_wallet/src/screens/auth/auth_page.dart';
|
||||
import 'package:cake_wallet/store/app_store.dart';
|
||||
import 'package:cake_wallet/store/authentication_store.dart';
|
||||
import 'package:cake_wallet/entities/qr_scanner.dart';
|
||||
import 'package:uni_links/uni_links.dart';
|
||||
|
||||
class Root extends StatefulWidget {
|
||||
Root(
|
||||
{required Key key,
|
||||
Root({
|
||||
required Key key,
|
||||
required this.authenticationStore,
|
||||
required this.appStore,
|
||||
required this.child,
|
||||
required this.navigatorKey})
|
||||
: super(key: key);
|
||||
required this.navigatorKey,
|
||||
required this.authService,
|
||||
}) : super(key: key);
|
||||
|
||||
final AuthenticationStore authenticationStore;
|
||||
final AppStore appStore;
|
||||
final GlobalKey<NavigatorState> navigatorKey;
|
||||
final AuthService authService;
|
||||
final Widget child;
|
||||
|
||||
@override
|
||||
|
@ -28,20 +33,54 @@ class RootState extends State<Root> with WidgetsBindingObserver {
|
|||
RootState()
|
||||
: _isInactiveController = StreamController<bool>.broadcast(),
|
||||
_isInactive = false,
|
||||
_requestAuth = true,
|
||||
_postFrameCallback = false;
|
||||
|
||||
Stream<bool> get isInactive => _isInactiveController.stream;
|
||||
StreamController<bool> _isInactiveController;
|
||||
bool _isInactive;
|
||||
bool _postFrameCallback;
|
||||
bool _requestAuth;
|
||||
|
||||
StreamSubscription<Uri?>? stream;
|
||||
Uri? launchUri;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
_requestAuth = widget.authService.requireAuth();
|
||||
_isInactiveController = StreamController<bool>.broadcast();
|
||||
_isInactive = false;
|
||||
_postFrameCallback = false;
|
||||
WidgetsBinding.instance.addObserver(this);
|
||||
super.initState();
|
||||
|
||||
initUniLinks();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
stream?.cancel();
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
/// handle app links while the app is already started
|
||||
/// whether its in the foreground or in the background.
|
||||
Future<void> initUniLinks() async {
|
||||
try {
|
||||
stream = uriLinkStream.listen((Uri? uri) {
|
||||
handleDeepLinking(uri);
|
||||
});
|
||||
|
||||
handleDeepLinking(await getInitialUri());
|
||||
} catch (e) {
|
||||
print(e);
|
||||
}
|
||||
}
|
||||
|
||||
void handleDeepLinking(Uri? uri) {
|
||||
if (uri == null || !mounted) return;
|
||||
|
||||
launchUri = uri;
|
||||
}
|
||||
|
||||
@override
|
||||
|
@ -52,11 +91,15 @@ class RootState extends State<Root> with WidgetsBindingObserver {
|
|||
return;
|
||||
}
|
||||
|
||||
if (!_isInactive &&
|
||||
widget.authenticationStore.state == AuthenticationState.allowed) {
|
||||
if (!_isInactive && widget.authenticationStore.state == AuthenticationState.allowed) {
|
||||
setState(() => _setInactive(true));
|
||||
}
|
||||
|
||||
break;
|
||||
case AppLifecycleState.resumed:
|
||||
setState(() {
|
||||
_requestAuth = widget.authService.requireAuth();
|
||||
});
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
|
@ -65,7 +108,7 @@ class RootState extends State<Root> with WidgetsBindingObserver {
|
|||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
if (_isInactive && !_postFrameCallback) {
|
||||
if (_isInactive && !_postFrameCallback && _requestAuth) {
|
||||
_postFrameCallback = true;
|
||||
WidgetsBinding.instance.addPostFrameCallback((_) {
|
||||
widget.navigatorKey.currentState?.pushNamed(Routes.unlock,
|
||||
|
@ -75,9 +118,19 @@ class RootState extends State<Root> with WidgetsBindingObserver {
|
|||
}
|
||||
|
||||
_reset();
|
||||
auth.close();
|
||||
auth.close(
|
||||
route: launchUri != null ? Routes.send : null,
|
||||
arguments: PaymentRequest.fromUri(launchUri),
|
||||
);
|
||||
launchUri = null;
|
||||
});
|
||||
});
|
||||
} else if (launchUri != null) {
|
||||
widget.navigatorKey.currentState?.pushNamed(
|
||||
Routes.send,
|
||||
arguments: PaymentRequest.fromUri(launchUri),
|
||||
);
|
||||
launchUri = null;
|
||||
}
|
||||
|
||||
return WillPopScope(onWillPop: () async => false, child: widget.child);
|
||||
|
|
|
@ -4,6 +4,7 @@ import 'package:cake_wallet/src/screens/send/widgets/send_card.dart';
|
|||
import 'package:cake_wallet/src/widgets/alert_with_two_actions.dart';
|
||||
import 'package:cake_wallet/src/widgets/picker.dart';
|
||||
import 'package:cake_wallet/src/widgets/template_tile.dart';
|
||||
import 'package:cake_wallet/utils/payment_request.dart';
|
||||
import 'package:cake_wallet/view_model/send/output.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||
|
@ -25,11 +26,15 @@ import 'package:smooth_page_indicator/smooth_page_indicator.dart';
|
|||
import 'package:cw_core/crypto_currency.dart';
|
||||
|
||||
class SendPage extends BasePage {
|
||||
SendPage({required this.sendViewModel}) : _formKey = GlobalKey<FormState>();
|
||||
SendPage({
|
||||
required this.sendViewModel,
|
||||
this.initialPaymentRequest,
|
||||
}) : _formKey = GlobalKey<FormState>();
|
||||
|
||||
final SendViewModel sendViewModel;
|
||||
final GlobalKey<FormState> _formKey;
|
||||
final controller = PageController(initialPage: 0);
|
||||
final PaymentRequest? initialPaymentRequest;
|
||||
|
||||
bool _effectsInstalled = false;
|
||||
|
||||
|
@ -116,6 +121,7 @@ class SendPage extends BasePage {
|
|||
key: output.key,
|
||||
output: output,
|
||||
sendViewModel: sendViewModel,
|
||||
initialPaymentRequest: initialPaymentRequest,
|
||||
);
|
||||
});
|
||||
},
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import 'package:cake_wallet/src/widgets/cake_scrollbar.dart';
|
||||
import 'package:cake_wallet/src/widgets/section_divider.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/src/widgets/base_alert_dialog.dart';
|
||||
|
||||
|
@ -70,10 +71,7 @@ class ChooseYatAddressButtonsState extends State<ChooseYatAddressButtons> {
|
|||
controller: controller,
|
||||
padding: EdgeInsets.all(0),
|
||||
itemCount: itemCount,
|
||||
separatorBuilder: (_, __) => Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).dividerColor,
|
||||
),
|
||||
separatorBuilder: (_, __) => const SectionDivider(),
|
||||
itemBuilder: (context, index) {
|
||||
final address = addresses[index];
|
||||
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import 'package:cake_wallet/entities/priority_for_wallet_type.dart';
|
||||
import 'package:cake_wallet/src/widgets/alert_with_one_action.dart';
|
||||
import 'package:cake_wallet/utils/payment_request.dart';
|
||||
import 'package:cw_core/transaction_priority.dart';
|
||||
import 'package:cake_wallet/routes.dart';
|
||||
|
@ -20,21 +21,28 @@ class SendCard extends StatefulWidget {
|
|||
SendCard({
|
||||
Key? key,
|
||||
required this.output,
|
||||
required this.sendViewModel}) : super(key: key);
|
||||
required this.sendViewModel,
|
||||
this.initialPaymentRequest,
|
||||
}) : super(key: key);
|
||||
|
||||
final Output output;
|
||||
final SendViewModel sendViewModel;
|
||||
final PaymentRequest? initialPaymentRequest;
|
||||
|
||||
@override
|
||||
SendCardState createState() => SendCardState(
|
||||
output: output,
|
||||
sendViewModel: sendViewModel
|
||||
sendViewModel: sendViewModel,
|
||||
initialPaymentRequest: initialPaymentRequest,
|
||||
);
|
||||
}
|
||||
|
||||
class SendCardState extends State<SendCard>
|
||||
with AutomaticKeepAliveClientMixin<SendCard> {
|
||||
SendCardState({required this.output, required this.sendViewModel})
|
||||
SendCardState({
|
||||
required this.output,
|
||||
required this.sendViewModel,
|
||||
this.initialPaymentRequest})
|
||||
: addressController = TextEditingController(),
|
||||
cryptoAmountController = TextEditingController(),
|
||||
fiatAmountController = TextEditingController(),
|
||||
|
@ -49,6 +57,7 @@ class SendCardState extends State<SendCard>
|
|||
|
||||
final Output output;
|
||||
final SendViewModel sendViewModel;
|
||||
final PaymentRequest? initialPaymentRequest;
|
||||
|
||||
final TextEditingController addressController;
|
||||
final TextEditingController cryptoAmountController;
|
||||
|
@ -61,6 +70,27 @@ class SendCardState extends State<SendCard>
|
|||
|
||||
bool _effectsInstalled = false;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
|
||||
/// if the current wallet doesn't match the one in the qr code
|
||||
if (initialPaymentRequest != null &&
|
||||
sendViewModel.walletCurrencyName != initialPaymentRequest!.scheme.toLowerCase()) {
|
||||
WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
|
||||
showPopUp<void>(
|
||||
context: context,
|
||||
builder: (BuildContext context) {
|
||||
return AlertWithOneAction(
|
||||
alertTitle: S.of(context).error,
|
||||
alertContent: S.of(context).unmatched_currencies,
|
||||
buttonText: S.of(context).ok,
|
||||
buttonAction: () => Navigator.of(context).pop());
|
||||
});
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
super.build(context);
|
||||
|
@ -512,8 +542,12 @@ class SendCardState extends State<SendCard>
|
|||
}
|
||||
|
||||
void _setEffects(BuildContext context) {
|
||||
if (output.address.isNotEmpty) {
|
||||
addressController.text = output.address;
|
||||
}
|
||||
if (output.cryptoAmount.isNotEmpty) {
|
||||
cryptoAmountController.text = output.cryptoAmount;
|
||||
}
|
||||
fiatAmountController.text = output.fiatAmount;
|
||||
noteController.text = output.note;
|
||||
extractedAddressController.text = output.extractedAddress;
|
||||
|
@ -605,6 +639,13 @@ class SendCardState extends State<SendCard>
|
|||
extractedAddressController.text = extractedAddress;
|
||||
});
|
||||
|
||||
if (initialPaymentRequest != null &&
|
||||
sendViewModel.walletCurrencyName == initialPaymentRequest!.scheme.toLowerCase()) {
|
||||
addressController.text = initialPaymentRequest!.address;
|
||||
cryptoAmountController.text = initialPaymentRequest!.amount;
|
||||
noteController.text = initialPaymentRequest!.note;
|
||||
}
|
||||
|
||||
_effectsInstalled = true;
|
||||
}
|
||||
|
||||
|
|
|
@ -1,9 +1,11 @@
|
|||
import 'package:cake_wallet/entities/pin_code_required_duration.dart';
|
||||
import 'package:cake_wallet/routes.dart';
|
||||
import 'package:cake_wallet/src/screens/auth/auth_page.dart';
|
||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
import 'package:cake_wallet/src/screens/pin_code/pin_code_widget.dart';
|
||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_cell_with_arrow.dart';
|
||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_picker_cell.dart';
|
||||
import 'package:cake_wallet/src/screens/settings/widgets/settings_switcher_cell.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
||||
import 'package:cake_wallet/view_model/settings/security_settings_view_model.dart';
|
||||
|
@ -25,22 +27,26 @@ class SecurityBackupPage extends BasePage {
|
|||
child: Column(mainAxisSize: MainAxisSize.min, children: [
|
||||
SettingsCellWithArrow(
|
||||
title: S.current.show_keys,
|
||||
handler: (_) => Navigator.of(context).pushNamed(Routes.auth,
|
||||
handler: (_) => _securitySettingsViewModel.checkPinCodeRiquired()
|
||||
? Navigator.of(context).pushNamed(Routes.auth,
|
||||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) {
|
||||
if (isAuthenticatedSuccessfully) {
|
||||
auth.close(route: Routes.showKeys);
|
||||
}
|
||||
}),
|
||||
})
|
||||
: Navigator.of(context).pushNamed(Routes.showKeys),
|
||||
),
|
||||
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
||||
SettingsCellWithArrow(
|
||||
title: S.current.create_backup,
|
||||
handler: (_) => Navigator.of(context).pushNamed(Routes.auth,
|
||||
handler: (_) => _securitySettingsViewModel.checkPinCodeRiquired()
|
||||
? Navigator.of(context).pushNamed(Routes.auth,
|
||||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) {
|
||||
if (isAuthenticatedSuccessfully) {
|
||||
auth.close(route: Routes.backup);
|
||||
}
|
||||
}),
|
||||
})
|
||||
: Navigator.of(context).pushNamed(Routes.backup),
|
||||
),
|
||||
StandardListSeparator(padding: EdgeInsets.symmetric(horizontal: 24)),
|
||||
SettingsCellWithArrow(
|
||||
|
@ -65,10 +71,12 @@ class SecurityBackupPage extends BasePage {
|
|||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) async {
|
||||
if (isAuthenticatedSuccessfully) {
|
||||
if (await _securitySettingsViewModel.biometricAuthenticated()) {
|
||||
_securitySettingsViewModel.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
||||
_securitySettingsViewModel
|
||||
.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
||||
}
|
||||
} else {
|
||||
_securitySettingsViewModel.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
||||
_securitySettingsViewModel
|
||||
.setAllowBiometricalAuthentication(isAuthenticatedSuccessfully);
|
||||
}
|
||||
|
||||
auth.close();
|
||||
|
@ -78,6 +86,16 @@ class SecurityBackupPage extends BasePage {
|
|||
}
|
||||
});
|
||||
}),
|
||||
Observer(builder: (_) {
|
||||
return SettingsPickerCell<PinCodeRequiredDuration>(
|
||||
title: S.current.require_pin_after,
|
||||
items: PinCodeRequiredDuration.values,
|
||||
selectedItem: _securitySettingsViewModel.pinCodeRequiredDuration,
|
||||
onItemSelected: (PinCodeRequiredDuration code) {
|
||||
_securitySettingsViewModel.setPinCodeRequiredDuration(code);
|
||||
},
|
||||
);
|
||||
}),
|
||||
]),
|
||||
);
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@ import 'package:flutter/material.dart';
|
|||
import 'package:cake_wallet/src/widgets/picker.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
||||
|
||||
class SettingsPickerCell<ItemType extends Object> extends StandardListRow {
|
||||
class SettingsPickerCell<ItemType> extends StandardListRow {
|
||||
SettingsPickerCell(
|
||||
{required String title,
|
||||
required this.selectedItem,
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_switch.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_switch.dart';
|
||||
|
||||
class SettingsSwitcherCell extends StandardListRow {
|
||||
SettingsSwitcherCell(
|
||||
|
@ -11,6 +11,6 @@ class SettingsSwitcherCell extends StandardListRow {
|
|||
final void Function(BuildContext context, bool value)? onValueChange;
|
||||
|
||||
@override
|
||||
Widget buildTrailing(BuildContext context) => StandartSwitch(
|
||||
Widget buildTrailing(BuildContext context) => StandardSwitch(
|
||||
value: value, onTaped: () => onValueChange?.call(context, !value));
|
||||
}
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import 'package:cake_wallet/src/widgets/standard_list.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_card.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_status_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_list_card.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_list_status_row.dart';
|
||||
import 'package:cake_wallet/utils/show_bar.dart';
|
||||
import 'package:cake_wallet/view_model/trade_details_view_model.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
@ -9,7 +9,7 @@ import 'package:flutter/services.dart';
|
|||
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/list_row.dart';
|
||||
import 'package:cake_wallet/src/screens/trade_details/track_trade_list_item.dart';
|
||||
import 'package:cake_wallet/src/screens/trade_details/trade_details_list_card.dart';
|
||||
import 'package:cake_wallet/src/screens/trade_details/trade_details_status_item.dart';
|
||||
|
@ -62,18 +62,18 @@ class TradeDetailsPageBodyState extends State<TradeDetailsPageBody> {
|
|||
if (item is TrackTradeListItem) {
|
||||
return GestureDetector(
|
||||
onTap: item.onTap,
|
||||
child: StandartListRow(
|
||||
child: ListRow(
|
||||
title: '${item.title}', value: '${item.value}'));
|
||||
}
|
||||
|
||||
if (item is DetailsListStatusItem) {
|
||||
return StandartListStatusRow(
|
||||
return StandardListStatusRow(
|
||||
title: item.title,
|
||||
value: item.value);
|
||||
}
|
||||
|
||||
if (item is TradeDetailsListCardItem) {
|
||||
return TradeDatailsStandartListCard(
|
||||
return TradeDetailsStandardListCard(
|
||||
id: item.id,
|
||||
create: item.createdAt,
|
||||
pair: item.pair,
|
||||
|
@ -86,7 +86,7 @@ class TradeDetailsPageBodyState extends State<TradeDetailsPageBody> {
|
|||
Clipboard.setData(ClipboardData(text: '${item.value}'));
|
||||
showBar<void>(context, S.of(context).copied_to_clipboard);
|
||||
},
|
||||
child: StandartListRow(
|
||||
child: ListRow(
|
||||
title: '${item.title}', value: '${item.value}'));
|
||||
});
|
||||
});
|
||||
|
|
|
@ -6,7 +6,7 @@ import 'package:cake_wallet/view_model/transaction_details_view_model.dart';
|
|||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/list_row.dart';
|
||||
import 'package:cake_wallet/src/screens/transaction_details/blockexplorer_list_item.dart';
|
||||
import 'package:cake_wallet/src/screens/transaction_details/standart_list_item.dart';
|
||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||
|
@ -42,7 +42,7 @@ class TransactionDetailsPage extends BasePage {
|
|||
S.of(context).transaction_details_copied(item.title));
|
||||
},
|
||||
child:
|
||||
StandartListRow(title: '${item.title}:', value: item.value),
|
||||
ListRow(title: '${item.title}:', value: item.value),
|
||||
);
|
||||
}
|
||||
|
||||
|
@ -50,7 +50,7 @@ class TransactionDetailsPage extends BasePage {
|
|||
return GestureDetector(
|
||||
onTap: item.onTap,
|
||||
child:
|
||||
StandartListRow(title: '${item.title}:', value: item.value),
|
||||
ListRow(title: '${item.title}:', value: item.value),
|
||||
);
|
||||
}
|
||||
|
||||
|
|
|
@ -5,7 +5,7 @@ import 'package:cake_wallet/src/widgets/standard_list.dart';
|
|||
import 'package:cake_wallet/view_model/unspent_coins/unspent_coins_details_view_model.dart';
|
||||
import 'package:cake_wallet/view_model/unspent_coins/unspent_coins_switch_item.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/list_row.dart';
|
||||
import 'package:cake_wallet/src/screens/transaction_details/standart_list_item.dart';
|
||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||
|
@ -30,7 +30,7 @@ class UnspentCoinsDetailsPage extends BasePage {
|
|||
final item = unspentCoinsDetailsViewModel.items[index];
|
||||
|
||||
if (item is StandartListItem) {
|
||||
return StandartListRow(
|
||||
return ListRow(
|
||||
title: '${item.title}:',
|
||||
value: item.value);
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import 'package:cake_wallet/src/widgets/standart_switch.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_switch.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class UnspentCoinsSwitchRow extends StatelessWidget {
|
||||
|
@ -33,7 +33,7 @@ class UnspentCoinsSwitchRow extends StatelessWidget {
|
|||
textAlign: TextAlign.left),
|
||||
Padding(
|
||||
padding: EdgeInsets.only(top: 12),
|
||||
child: StandartSwitch(
|
||||
child: StandardSwitch(
|
||||
value: switchValue,
|
||||
onTaped: () => onSwitchValueChange(!switchValue))
|
||||
)
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import 'package:auto_size_text/auto_size_text.dart';
|
||||
import 'package:cake_wallet/src/widgets/section_divider.dart';
|
||||
import 'package:cake_wallet/utils/show_bar.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
|
@ -6,7 +7,7 @@ import 'package:flutter/services.dart';
|
|||
import 'package:flutter_mobx/flutter_mobx.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
import 'package:cake_wallet/src/screens/base_page.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/list_row.dart';
|
||||
import 'package:cake_wallet/view_model/wallet_keys_view_model.dart';
|
||||
|
||||
class WalletKeysPage extends BasePage {
|
||||
|
@ -57,10 +58,7 @@ class WalletKeysPage extends BasePage {
|
|||
height: 1,
|
||||
padding: EdgeInsets.only(left: 24),
|
||||
color: Theme.of(context).accentTextTheme!.headline6!.backgroundColor!,
|
||||
child: Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).dividerColor,
|
||||
),
|
||||
child: const SectionDivider(),
|
||||
),
|
||||
itemCount: walletKeysViewModel.items.length,
|
||||
itemBuilder: (BuildContext context, int index) {
|
||||
|
@ -71,7 +69,7 @@ class WalletKeysPage extends BasePage {
|
|||
Clipboard.setData(ClipboardData(text: item.value));
|
||||
showBar<void>(context, S.of(context).copied_key_to_clipboard(item.title));
|
||||
},
|
||||
child: StandartListRow(
|
||||
child: ListRow(
|
||||
title: item.title + ':',
|
||||
value: item.value,
|
||||
),
|
||||
|
|
|
@ -220,15 +220,15 @@ class WalletListBodyState extends State<WalletListBody> {
|
|||
}
|
||||
|
||||
Future<void> _loadWallet(WalletListItem wallet) async {
|
||||
await Navigator.of(context).pushNamed(Routes.auth, arguments:
|
||||
(bool isAuthenticatedSuccessfully, AuthPageState auth) async {
|
||||
if (await widget.walletListViewModel.checkIfAuthRequired()) {
|
||||
await Navigator.of(context).pushNamed(Routes.auth,
|
||||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) async {
|
||||
if (!isAuthenticatedSuccessfully) {
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
auth.changeProcessText(
|
||||
S.of(context).wallet_list_loading_wallet(wallet.name));
|
||||
auth.changeProcessText(S.of(context).wallet_list_loading_wallet(wallet.name));
|
||||
await widget.walletListViewModel.loadWallet(wallet);
|
||||
auth.hideProgressText();
|
||||
auth.close();
|
||||
|
@ -236,22 +236,38 @@ class WalletListBodyState extends State<WalletListBody> {
|
|||
Navigator.of(context).pop();
|
||||
});
|
||||
} catch (e) {
|
||||
auth.changeProcessText(S
|
||||
.of(context)
|
||||
.wallet_list_failed_to_load(wallet.name, e.toString()));
|
||||
auth.changeProcessText(
|
||||
S.of(context).wallet_list_failed_to_load(wallet.name, e.toString()));
|
||||
}
|
||||
});
|
||||
} else {
|
||||
try {
|
||||
changeProcessText(S.of(context).wallet_list_loading_wallet(wallet.name));
|
||||
await widget.walletListViewModel.loadWallet(wallet);
|
||||
hideProgressText();
|
||||
Navigator.of(context).pop();
|
||||
} catch (e) {
|
||||
changeProcessText(S.of(context).wallet_list_failed_to_load(wallet.name, e.toString()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> _removeWallet(WalletListItem wallet) async {
|
||||
await Navigator.of(context).pushNamed(Routes.auth, arguments:
|
||||
(bool isAuthenticatedSuccessfully, AuthPageState auth) async {
|
||||
if (widget.walletListViewModel.checkIfAuthRequired()) {
|
||||
await Navigator.of(context).pushNamed(Routes.auth,
|
||||
arguments: (bool isAuthenticatedSuccessfully, AuthPageState auth) async {
|
||||
if (!isAuthenticatedSuccessfully) {
|
||||
return;
|
||||
}
|
||||
_onSuccessfulAuth(wallet, auth);
|
||||
});
|
||||
} else {
|
||||
_onSuccessfulAuth(wallet, null);
|
||||
}
|
||||
}
|
||||
|
||||
void _onSuccessfulAuth(WalletListItem wallet, AuthPageState? auth) async {
|
||||
bool confirmed = false;
|
||||
|
||||
await showPopUp<void>(
|
||||
context: context,
|
||||
builder: (BuildContext context) {
|
||||
|
@ -270,18 +286,22 @@ class WalletListBodyState extends State<WalletListBody> {
|
|||
|
||||
if (confirmed) {
|
||||
try {
|
||||
auth.changeProcessText(
|
||||
S.of(context).wallet_list_removing_wallet(wallet.name));
|
||||
auth != null
|
||||
? auth.changeProcessText(S.of(context).wallet_list_removing_wallet(wallet.name))
|
||||
: changeProcessText(S.of(context).wallet_list_removing_wallet(wallet.name));
|
||||
await widget.walletListViewModel.remove(wallet);
|
||||
} catch (e) {
|
||||
auth.changeProcessText(S
|
||||
.of(context)
|
||||
.wallet_list_failed_to_remove(wallet.name, e.toString()));
|
||||
auth != null
|
||||
? auth.changeProcessText(
|
||||
S.of(context).wallet_list_failed_to_remove(wallet.name, e.toString()),
|
||||
)
|
||||
: changeProcessText(
|
||||
S.of(context).wallet_list_failed_to_remove(wallet.name, e.toString()),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
auth.close();
|
||||
});
|
||||
auth?.close();
|
||||
}
|
||||
|
||||
void changeProcessText(String text) {
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import 'dart:ui';
|
||||
import 'package:cake_wallet/src/widgets/section_divider.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/palette.dart';
|
||||
|
||||
|
@ -76,10 +77,7 @@ class BaseAlertDialog extends StatelessWidget {
|
|||
),
|
||||
)),
|
||||
),
|
||||
Container(
|
||||
width: 1,
|
||||
color: Theme.of(context).dividerColor,
|
||||
),
|
||||
const SectionDivider(),
|
||||
Expanded(
|
||||
child: TextButton(
|
||||
onPressed: actionRight,
|
||||
|
@ -140,10 +138,7 @@ class BaseAlertDialog extends StatelessWidget {
|
|||
isDividerExists
|
||||
? Padding(
|
||||
padding: EdgeInsets.only(top: 16, bottom: 8),
|
||||
child: Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).dividerColor,
|
||||
),
|
||||
child: const SectionDivider(),
|
||||
)
|
||||
: Offstage(),
|
||||
Padding(
|
||||
|
@ -152,10 +147,7 @@ class BaseAlertDialog extends StatelessWidget {
|
|||
)
|
||||
],
|
||||
),
|
||||
Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).dividerColor,
|
||||
),
|
||||
const SectionDivider(),
|
||||
actionButtons(context)
|
||||
],
|
||||
),
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class StandartListRow extends StatelessWidget {
|
||||
StandartListRow(
|
||||
class ListRow extends StatelessWidget {
|
||||
ListRow(
|
||||
{required this.title,
|
||||
required this.value,
|
||||
this.titleFontSize = 14,
|
|
@ -4,7 +4,7 @@ import 'package:flutter/material.dart';
|
|||
import 'package:cake_wallet/src/widgets/alert_background.dart';
|
||||
import 'package:cake_wallet/src/widgets/alert_close_button.dart';
|
||||
|
||||
class Picker<Item extends Object> extends StatefulWidget {
|
||||
class Picker<Item> extends StatefulWidget {
|
||||
Picker({
|
||||
required this.selectedAtIndex,
|
||||
required this.items,
|
||||
|
@ -39,7 +39,7 @@ class Picker<Item extends Object> extends StatefulWidget {
|
|||
_PickerState<Item> createState() => _PickerState<Item>(items, images, onItemSelected);
|
||||
}
|
||||
|
||||
class _PickerState<Item> extends State<Picker> {
|
||||
class _PickerState<Item> extends State<Picker<Item>> {
|
||||
_PickerState(this.items, this.images, this.onItemSelected);
|
||||
|
||||
final Function(Item) onItemSelected;
|
||||
|
@ -59,7 +59,7 @@ class _PickerState<Item> extends State<Picker> {
|
|||
images = [];
|
||||
for (int i=0;i<widget.items.length;i++) {
|
||||
if (widget.matchingCriteria?.call(widget.items[i], searchController.text) ?? true) {
|
||||
items.add(widget.items[i] as Item);
|
||||
items.add(widget.items[i]);
|
||||
images.add(widget.images[i]);
|
||||
}
|
||||
}
|
||||
|
@ -238,8 +238,7 @@ class _PickerState<Item> extends State<Picker> {
|
|||
child: Padding(
|
||||
padding: EdgeInsets.only(left: image != null ? 12 : 0),
|
||||
child: Text(
|
||||
// What a hack (item as) ?
|
||||
widget.displayItem?.call(item as Object) ?? item.toString(),
|
||||
widget.displayItem?.call(item) ?? item.toString(),
|
||||
style: TextStyle(
|
||||
fontSize: 14,
|
||||
fontFamily: 'Lato',
|
||||
|
|
13
lib/src/widgets/section_divider.dart
Normal file
13
lib/src/widgets/section_divider.dart
Normal file
|
@ -0,0 +1,13 @@
|
|||
import 'package:flutter/material.dart';
|
||||
|
||||
class SectionDivider extends StatelessWidget {
|
||||
const SectionDivider();
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Container(
|
||||
height: 1,
|
||||
color: Theme.of(context).dividerColor,
|
||||
);
|
||||
}
|
||||
}
|
|
@ -2,42 +2,42 @@ import 'dart:ui';
|
|||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class StandardCheckbox extends StatefulWidget {
|
||||
StandardCheckbox({
|
||||
Key? key,
|
||||
required this.value,
|
||||
class StandardCheckbox extends StatelessWidget {
|
||||
StandardCheckbox(
|
||||
{required this.value,
|
||||
this.caption = '',
|
||||
required this.onChanged})
|
||||
: super(key: key);
|
||||
this.gradientBackground = false,
|
||||
this.borderColor,
|
||||
this.iconColor,
|
||||
required this.onChanged});
|
||||
|
||||
final bool value;
|
||||
final String caption;
|
||||
final bool gradientBackground;
|
||||
final Color? borderColor;
|
||||
final Color? iconColor;
|
||||
final Function(bool) onChanged;
|
||||
|
||||
@override
|
||||
StandardCheckboxState createState() =>
|
||||
StandardCheckboxState(value, caption, onChanged);
|
||||
}
|
||||
|
||||
class StandardCheckboxState extends State<StandardCheckbox> {
|
||||
StandardCheckboxState(this.value, this.caption, this.onChanged);
|
||||
|
||||
bool value;
|
||||
String caption;
|
||||
Function(bool) onChanged;
|
||||
|
||||
void changeValue(bool newValue) {
|
||||
setState(() => value = newValue);
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
final baseGradient = LinearGradient(colors: [
|
||||
Theme.of(context).primaryTextTheme.subtitle1!.color!,
|
||||
Theme.of(context).primaryTextTheme.subtitle1!.decorationColor!,
|
||||
], begin: Alignment.centerLeft, end: Alignment.centerRight);
|
||||
|
||||
final boxBorder = Border.all(
|
||||
color: borderColor ?? Theme.of(context).primaryTextTheme.caption!.color!, width: 1.0);
|
||||
|
||||
final checkedBoxDecoration = BoxDecoration(
|
||||
gradient: gradientBackground ? baseGradient : null,
|
||||
border: gradientBackground ? null : boxBorder,
|
||||
borderRadius: BorderRadius.all(Radius.circular(8.0)));
|
||||
|
||||
final uncheckedBoxDecoration =
|
||||
BoxDecoration(border: boxBorder, borderRadius: BorderRadius.all(Radius.circular(8.0)));
|
||||
|
||||
return GestureDetector(
|
||||
onTap: () {
|
||||
value = !value;
|
||||
onChanged(value);
|
||||
setState(() {});
|
||||
},
|
||||
onTap: () => onChanged(!value),
|
||||
child: Row(
|
||||
mainAxisSize: MainAxisSize.min,
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
|
@ -45,36 +45,23 @@ class StandardCheckboxState extends State<StandardCheckbox> {
|
|||
Container(
|
||||
height: 24.0,
|
||||
width: 24.0,
|
||||
decoration: BoxDecoration(
|
||||
border: Border.all(
|
||||
color: Theme.of(context)
|
||||
.primaryTextTheme!
|
||||
.caption!
|
||||
.color!,
|
||||
width: 1.0),
|
||||
borderRadius: BorderRadius.all(
|
||||
Radius.circular(8.0)),
|
||||
color: Theme.of(context).backgroundColor),
|
||||
decoration: value ? checkedBoxDecoration : uncheckedBoxDecoration,
|
||||
child: value
|
||||
? Icon(
|
||||
Icons.check,
|
||||
color: Colors.blue,
|
||||
color: iconColor ?? Colors.blue,
|
||||
size: 20.0,
|
||||
)
|
||||
: Offstage(),
|
||||
),
|
||||
if (caption.isNotEmpty) Padding(
|
||||
if (caption.isNotEmpty)
|
||||
Padding(
|
||||
padding: EdgeInsets.only(left: 10),
|
||||
child: Text(
|
||||
caption,
|
||||
style: TextStyle(
|
||||
fontSize: 16.0,
|
||||
color: Theme.of(context)
|
||||
.primaryTextTheme!
|
||||
.headline6!
|
||||
.color!),
|
||||
)
|
||||
)
|
||||
fontSize: 16.0, color: Theme.of(context).primaryTextTheme!.headline6!.color!),
|
||||
))
|
||||
],
|
||||
),
|
||||
);
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import 'package:cake_wallet/palette.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_card.dart';
|
||||
import 'package:cake_wallet/src/widgets/standart_list_status_row.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_list_card.dart';
|
||||
import 'package:cake_wallet/src/widgets/standard_list_status_row.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class StandardListRow extends StatelessWidget {
|
||||
|
@ -217,7 +217,7 @@ class SectionStandardList extends StatelessWidget {
|
|||
return Container();
|
||||
}
|
||||
|
||||
if (row is StandartListStatusRow || row is TradeDatailsStandartListCard) {
|
||||
if (row is StandardListStatusRow || row is TradeDetailsStandardListCard) {
|
||||
return Container();
|
||||
}
|
||||
|
||||
|
|
|
@ -2,8 +2,8 @@ import 'package:cake_wallet/palette.dart';
|
|||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/themes/theme_base.dart';
|
||||
|
||||
class TradeDatailsStandartListCard extends StatelessWidget {
|
||||
TradeDatailsStandartListCard(
|
||||
class TradeDetailsStandardListCard extends StatelessWidget {
|
||||
TradeDetailsStandardListCard(
|
||||
{required this.id,
|
||||
required this.create,
|
||||
required this.pair,
|
|
@ -3,8 +3,8 @@ import 'package:cake_wallet/src/screens/dashboard/widgets/sync_indicator_icon.da
|
|||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class StandartListStatusRow extends StatelessWidget {
|
||||
StandartListStatusRow({required this.title, required this.value});
|
||||
class StandardListStatusRow extends StatelessWidget {
|
||||
StandardListStatusRow({required this.title, required this.value});
|
||||
|
||||
final String title;
|
||||
final String value;
|
|
@ -1,17 +1,17 @@
|
|||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class StandartSwitch extends StatefulWidget {
|
||||
const StandartSwitch({required this.value, required this.onTaped});
|
||||
class StandardSwitch extends StatefulWidget {
|
||||
const StandardSwitch({required this.value, required this.onTaped});
|
||||
|
||||
final bool value;
|
||||
final VoidCallback onTaped;
|
||||
|
||||
@override
|
||||
StandartSwitchState createState() => StandartSwitchState();
|
||||
StandardSwitchState createState() => StandardSwitchState();
|
||||
}
|
||||
|
||||
class StandartSwitchState extends State<StandartSwitch> {
|
||||
class StandardSwitchState extends State<StandardSwitch> {
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return GestureDetector(
|
|
@ -8,12 +8,11 @@ part'trade_filter_store.g.dart';
|
|||
class TradeFilterStore = TradeFilterStoreBase with _$TradeFilterStore;
|
||||
|
||||
abstract class TradeFilterStoreBase with Store {
|
||||
TradeFilterStoreBase(
|
||||
{this.displayXMRTO = true,
|
||||
this.displayChangeNow = true,
|
||||
this.displayMorphToken = true,
|
||||
this.displaySimpleSwap = true,
|
||||
});
|
||||
TradeFilterStoreBase() : displayXMRTO = true,
|
||||
displayChangeNow = true,
|
||||
displaySideShift = true,
|
||||
displayMorphToken = true,
|
||||
displaySimpleSwap = true;
|
||||
|
||||
@observable
|
||||
bool displayXMRTO;
|
||||
|
@ -21,26 +20,50 @@ abstract class TradeFilterStoreBase with Store {
|
|||
@observable
|
||||
bool displayChangeNow;
|
||||
|
||||
@observable
|
||||
bool displaySideShift;
|
||||
|
||||
@observable
|
||||
bool displayMorphToken;
|
||||
|
||||
@observable
|
||||
bool displaySimpleSwap;
|
||||
|
||||
@computed
|
||||
bool get displayAllTrades => displayChangeNow && displaySideShift && displaySimpleSwap;
|
||||
|
||||
@action
|
||||
void toggleDisplayExchange(ExchangeProviderDescription provider) {
|
||||
switch (provider) {
|
||||
case ExchangeProviderDescription.changeNow:
|
||||
displayChangeNow = !displayChangeNow;
|
||||
break;
|
||||
case ExchangeProviderDescription.sideShift:
|
||||
displaySideShift = !displaySideShift;
|
||||
break;
|
||||
case ExchangeProviderDescription.simpleSwap:
|
||||
displaySimpleSwap = !displaySimpleSwap;
|
||||
break;
|
||||
case ExchangeProviderDescription.xmrto:
|
||||
displayXMRTO = !displayXMRTO;
|
||||
break;
|
||||
case ExchangeProviderDescription.morphToken:
|
||||
displayMorphToken = !displayMorphToken;
|
||||
break;
|
||||
case ExchangeProviderDescription.simpleSwap:
|
||||
displaySimpleSwap = !displaySimpleSwap;
|
||||
case ExchangeProviderDescription.all:
|
||||
if (displayAllTrades) {
|
||||
displayChangeNow = false;
|
||||
displaySideShift = false;
|
||||
displayXMRTO = false;
|
||||
displayMorphToken = false;
|
||||
displaySimpleSwap = false;
|
||||
} else {
|
||||
displayChangeNow = true;
|
||||
displaySideShift = true;
|
||||
displayXMRTO = true;
|
||||
displayMorphToken = true;
|
||||
displaySimpleSwap = true;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -48,13 +71,15 @@ abstract class TradeFilterStoreBase with Store {
|
|||
List<TradeListItem> filtered({required List<TradeListItem> trades, required WalletBase wallet}) {
|
||||
final _trades =
|
||||
trades.where((item) => item.trade.walletId == wallet.id).toList();
|
||||
final needToFilter = !displayChangeNow || !displayXMRTO || !displayMorphToken || !displaySimpleSwap;
|
||||
final needToFilter = !displayAllTrades;
|
||||
|
||||
return needToFilter
|
||||
? _trades
|
||||
.where((item) =>
|
||||
(displayXMRTO &&
|
||||
item.trade.provider == ExchangeProviderDescription.xmrto) ||
|
||||
(displaySideShift &&
|
||||
item.trade.provider == ExchangeProviderDescription.sideShift) ||
|
||||
(displayChangeNow &&
|
||||
item.trade.provider ==
|
||||
ExchangeProviderDescription.changeNow) ||
|
||||
|
|
|
@ -31,13 +31,8 @@ abstract class TradesStoreBase with Store {
|
|||
void setTrade(Trade trade) => this.trade = trade;
|
||||
|
||||
@action
|
||||
Future<void> updateTradeList() async {
|
||||
if (trade == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
trades = tradesSource.values.map((trade) => TradeListItem(
|
||||
trade: trade!,
|
||||
Future<void> updateTradeList() async => trades =
|
||||
tradesSource.values.map((trade) => TradeListItem(
|
||||
trade: trade,
|
||||
settingsStore: settingsStore)).toList();
|
||||
}
|
||||
}
|
|
@ -1,6 +1,8 @@
|
|||
import 'package:mobx/mobx.dart';
|
||||
import 'package:cw_core/transaction_direction.dart';
|
||||
import 'package:cake_wallet/view_model/dashboard/transaction_list_item.dart';
|
||||
import 'package:cake_wallet/view_model/dashboard/filter_item.dart';
|
||||
import 'package:cake_wallet/generated/i18n.dart';
|
||||
|
||||
part 'transaction_filter_store.g.dart';
|
||||
|
||||
|
@ -8,8 +10,8 @@ class TransactionFilterStore = TransactionFilterStoreBase
|
|||
with _$TransactionFilterStore;
|
||||
|
||||
abstract class TransactionFilterStoreBase with Store {
|
||||
TransactionFilterStoreBase(
|
||||
{this.displayIncoming = true, this.displayOutgoing = true});
|
||||
TransactionFilterStoreBase() : displayIncoming = true,
|
||||
displayOutgoing = true;
|
||||
|
||||
@observable
|
||||
bool displayIncoming;
|
||||
|
@ -23,11 +25,31 @@ abstract class TransactionFilterStoreBase with Store {
|
|||
@observable
|
||||
DateTime? endDate;
|
||||
|
||||
@action
|
||||
void toggleIncoming() => displayIncoming = !displayIncoming;
|
||||
@computed
|
||||
bool get displayAll => displayIncoming && displayOutgoing;
|
||||
|
||||
@action
|
||||
void toggleOutgoing() => displayOutgoing = !displayOutgoing;
|
||||
void toggleAll() {
|
||||
if (displayAll) {
|
||||
displayOutgoing = false;
|
||||
displayIncoming = false;
|
||||
} else {
|
||||
displayOutgoing = true;
|
||||
displayIncoming = true;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@action
|
||||
void toggleIncoming() {
|
||||
displayIncoming = !displayIncoming;
|
||||
}
|
||||
|
||||
|
||||
@action
|
||||
void toggleOutgoing() {
|
||||
displayOutgoing = !displayOutgoing;
|
||||
}
|
||||
|
||||
@action
|
||||
void changeStartDate(DateTime date) => startDate = date;
|
||||
|
@ -37,8 +59,7 @@ abstract class TransactionFilterStoreBase with Store {
|
|||
|
||||
List<TransactionListItem> filtered({required List<TransactionListItem> transactions}) {
|
||||
var _transactions = <TransactionListItem>[];
|
||||
final needToFilter = !displayOutgoing ||
|
||||
!displayIncoming ||
|
||||
final needToFilter = !displayAll ||
|
||||
(startDate != null && endDate != null);
|
||||
|
||||
if (needToFilter) {
|
||||
|
@ -50,7 +71,7 @@ abstract class TransactionFilterStoreBase with Store {
|
|||
&& (endDate?.isAfter(item.transaction.date) ?? false);
|
||||
}
|
||||
|
||||
if (allowed && (!displayOutgoing || !displayIncoming)) {
|
||||
if (allowed && (!displayAll)) {
|
||||
allowed = (displayOutgoing &&
|
||||
item.transaction.direction ==
|
||||
TransactionDirection.outgoing) ||
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
||||
import 'package:cake_wallet/entities/pin_code_required_duration.dart';
|
||||
import 'package:cake_wallet/entities/preferences_key.dart';
|
||||
import 'package:cw_core/transaction_priority.dart';
|
||||
import 'package:cake_wallet/themes/theme_base.dart';
|
||||
|
@ -17,7 +18,6 @@ import 'package:cw_core/node.dart';
|
|||
import 'package:cake_wallet/monero/monero.dart';
|
||||
import 'package:cake_wallet/entities/action_list_display_mode.dart';
|
||||
import 'package:cake_wallet/entities/fiat_api_mode.dart';
|
||||
import 'package:cake_wallet/.secrets.g.dart' as secrets;
|
||||
|
||||
part 'settings_store.g.dart';
|
||||
|
||||
|
@ -41,6 +41,7 @@ abstract class SettingsStoreBase with Store {
|
|||
required this.shouldShowYatPopup,
|
||||
required this.isBitcoinBuyEnabled,
|
||||
required this.actionlistDisplayMode,
|
||||
required this.pinTimeOutDuration,
|
||||
TransactionPriority? initialBitcoinTransactionPriority,
|
||||
TransactionPriority? initialMoneroTransactionPriority,
|
||||
TransactionPriority? initialHavenTransactionPriority,
|
||||
|
@ -141,6 +142,11 @@ abstract class SettingsStoreBase with Store {
|
|||
(String languageCode) => sharedPreferences.setString(
|
||||
PreferencesKey.currentLanguageCode, languageCode));
|
||||
|
||||
reaction(
|
||||
(_) => pinTimeOutDuration,
|
||||
(PinCodeRequiredDuration pinCodeInterval) => sharedPreferences.setInt(
|
||||
PreferencesKey.pinTimeOutDuration, pinCodeInterval.value));
|
||||
|
||||
reaction(
|
||||
(_) => balanceDisplayMode,
|
||||
(BalanceDisplayMode mode) => sharedPreferences.setInt(
|
||||
|
@ -162,6 +168,7 @@ abstract class SettingsStoreBase with Store {
|
|||
|
||||
static const defaultPinLength = 4;
|
||||
static const defaultActionsMode = 11;
|
||||
static const defaultPinCodeTimeOutDuration = PinCodeRequiredDuration.tenminutes;
|
||||
|
||||
@observable
|
||||
FiatCurrency fiatCurrency;
|
||||
|
@ -193,6 +200,9 @@ abstract class SettingsStoreBase with Store {
|
|||
@observable
|
||||
int pinCodeLength;
|
||||
|
||||
@observable
|
||||
PinCodeRequiredDuration pinTimeOutDuration;
|
||||
|
||||
@computed
|
||||
ThemeData get theme => currentTheme.themeData;
|
||||
|
||||
|
@ -288,6 +298,11 @@ abstract class SettingsStoreBase with Store {
|
|||
sharedPreferences.getInt(PreferencesKey.displayActionListModeKey) ??
|
||||
defaultActionsMode));
|
||||
var pinLength = sharedPreferences.getInt(PreferencesKey.currentPinLength);
|
||||
final timeOutDuration = sharedPreferences.getInt(PreferencesKey.pinTimeOutDuration);
|
||||
final pinCodeTimeOutDuration = timeOutDuration != null
|
||||
? PinCodeRequiredDuration.deserialize(raw: timeOutDuration)
|
||||
: defaultPinCodeTimeOutDuration;
|
||||
|
||||
// If no value
|
||||
if (pinLength == null || pinLength == 0) {
|
||||
pinLength = defaultPinLength;
|
||||
|
@ -343,6 +358,7 @@ abstract class SettingsStoreBase with Store {
|
|||
initialTheme: savedTheme,
|
||||
actionlistDisplayMode: actionListDisplayMode,
|
||||
initialPinLength: pinLength,
|
||||
pinTimeOutDuration: pinCodeTimeOutDuration,
|
||||
initialLanguageCode: savedLanguageCode,
|
||||
initialMoneroTransactionPriority: moneroTransactionPriority,
|
||||
initialBitcoinTransactionPriority: bitcoinTransactionPriority,
|
||||
|
|
|
@ -1,22 +1,25 @@
|
|||
class PaymentRequest {
|
||||
PaymentRequest(this.address, this.amount, this.note);
|
||||
PaymentRequest(this.address, this.amount, this.note, this.scheme);
|
||||
|
||||
factory PaymentRequest.fromUri(Uri uri) {
|
||||
factory PaymentRequest.fromUri(Uri? uri) {
|
||||
var address = "";
|
||||
var amount = "";
|
||||
var note = "";
|
||||
var scheme = "";
|
||||
|
||||
if (uri != null) {
|
||||
address = uri.path;
|
||||
amount = uri.queryParameters['tx_amount'] ?? uri.queryParameters['amount'] ?? "";
|
||||
note = uri.queryParameters['tx_description']
|
||||
?? uri.queryParameters['message'] ?? "";
|
||||
scheme = uri.scheme;
|
||||
}
|
||||
|
||||
return PaymentRequest(address, amount, note);
|
||||
return PaymentRequest(address, amount, note, scheme);
|
||||
}
|
||||
|
||||
final String address;
|
||||
final String amount;
|
||||
final String note;
|
||||
final String scheme;
|
||||
}
|
65
lib/utils/route_aware.dart
Normal file
65
lib/utils/route_aware.dart
Normal file
|
@ -0,0 +1,65 @@
|
|||
import 'package:flutter/material.dart';
|
||||
import 'package:cake_wallet/main.dart';
|
||||
|
||||
class RouteAwareWidget extends StatefulWidget {
|
||||
RouteAwareWidget(
|
||||
{required this.child,
|
||||
this.pushToWidget,
|
||||
this.pushToNextWidget,
|
||||
this.popWidget,
|
||||
this.popNextWidget});
|
||||
|
||||
final Widget child;
|
||||
final Function()? pushToWidget;
|
||||
final Function()? pushToNextWidget;
|
||||
final Function()? popWidget;
|
||||
final Function()? popNextWidget;
|
||||
|
||||
@override
|
||||
State<RouteAwareWidget> createState() => RouteAwareWidgetState();
|
||||
}
|
||||
|
||||
class RouteAwareWidgetState extends State<RouteAwareWidget> with RouteAware {
|
||||
@override
|
||||
void didChangeDependencies() {
|
||||
super.didChangeDependencies();
|
||||
routeObserver.subscribe(this, ModalRoute.of(context) as PageRoute);
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
routeObserver.unsubscribe(this);
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
void didPush() {
|
||||
if (widget.pushToWidget != null) {
|
||||
widget.pushToWidget!();
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
void didPushNext() {
|
||||
if (widget.pushToNextWidget != null) {
|
||||
widget.pushToNextWidget!();
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
void didPop() {
|
||||
if (widget.popWidget != null) {
|
||||
widget.popWidget!();
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
void didPopNext() {
|
||||
if (widget.popNextWidget != null) {
|
||||
widget.popNextWidget!();
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) => widget.child;
|
||||
}
|
|
@ -14,10 +14,12 @@ part 'auth_view_model.g.dart';
|
|||
class AuthViewModel = AuthViewModelBase with _$AuthViewModel;
|
||||
|
||||
abstract class AuthViewModelBase with Store {
|
||||
AuthViewModelBase(this._authService, this._sharedPreferences,
|
||||
this._settingsStore, this._biometricAuth)
|
||||
AuthViewModelBase(
|
||||
this._authService, this._sharedPreferences, this._settingsStore, this._biometricAuth)
|
||||
: _failureCounter = 0,
|
||||
state = InitialExecutionState();
|
||||
state = InitialExecutionState() {
|
||||
reaction((_) => state, _saveLastAuthTime);
|
||||
}
|
||||
|
||||
static const maxFailedLogins = 3;
|
||||
static const banTimeout = 180; // 3 minutes
|
||||
|
@ -28,8 +30,7 @@ abstract class AuthViewModelBase with Store {
|
|||
|
||||
int get pinLength => _settingsStore.pinCodeLength;
|
||||
|
||||
bool get isBiometricalAuthenticationAllowed =>
|
||||
_settingsStore.allowBiometricalAuthentication;
|
||||
bool get isBiometricalAuthenticationAllowed => _settingsStore.allowBiometricalAuthentication;
|
||||
|
||||
@observable
|
||||
int _failureCounter;
|
||||
|
@ -118,4 +119,10 @@ abstract class AuthViewModelBase with Store {
|
|||
state = FailureState(e.toString());
|
||||
}
|
||||
}
|
||||
|
||||
void _saveLastAuthTime(ExecutionState state) {
|
||||
if (state is ExecutedSuccessfullyState) {
|
||||
_authService.saveLastAuthTime();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -58,25 +58,44 @@ abstract class DashboardViewModelBase with Store {
|
|||
isShowThirdYatIntroduction = false,
|
||||
filterItems = {
|
||||
S.current.transactions: [
|
||||
FilterItem(
|
||||
value: () => transactionFilterStore.displayAll,
|
||||
caption: S.current.all_transactions,
|
||||
onChanged: transactionFilterStore.toggleAll),
|
||||
FilterItem(
|
||||
value: () => transactionFilterStore.displayIncoming,
|
||||
caption: S.current.incoming,
|
||||
onChanged: (value) => transactionFilterStore.toggleIncoming()),
|
||||
onChanged:transactionFilterStore.toggleIncoming),
|
||||
FilterItem(
|
||||
value: () => transactionFilterStore.displayOutgoing,
|
||||
caption: S.current.outgoing,
|
||||
onChanged: (value) => transactionFilterStore.toggleOutgoing()),
|
||||
onChanged: transactionFilterStore.toggleOutgoing),
|
||||
// FilterItem(
|
||||
// value: () => false,
|
||||
// caption: S.current.transactions_by_date,
|
||||
// onChanged: null),
|
||||
],
|
||||
S.current.trades: [
|
||||
FilterItem(
|
||||
value: () => tradeFilterStore.displayAllTrades,
|
||||
caption: S.current.all_trades,
|
||||
onChanged: () => tradeFilterStore
|
||||
.toggleDisplayExchange(ExchangeProviderDescription.all)),
|
||||
FilterItem(
|
||||
value: () => tradeFilterStore.displayChangeNow,
|
||||
caption: 'Change.NOW',
|
||||
onChanged: (value) => tradeFilterStore
|
||||
caption: ExchangeProviderDescription.changeNow.title,
|
||||
onChanged: () => tradeFilterStore
|
||||
.toggleDisplayExchange(ExchangeProviderDescription.changeNow)),
|
||||
FilterItem(
|
||||
value: () => tradeFilterStore.displaySideShift,
|
||||
caption: ExchangeProviderDescription.sideShift.title,
|
||||
onChanged: () => tradeFilterStore
|
||||
.toggleDisplayExchange(ExchangeProviderDescription.sideShift)),
|
||||
FilterItem(
|
||||
value: () => tradeFilterStore.displaySimpleSwap,
|
||||
caption: ExchangeProviderDescription.simpleSwap.title,
|
||||
onChanged: () => tradeFilterStore
|
||||
.toggleDisplayExchange(ExchangeProviderDescription.simpleSwap)),
|
||||
]
|
||||
},
|
||||
subname = '',
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import 'package:mobx/mobx.dart';
|
||||
|
||||
class FilterItem {
|
||||
FilterItem({
|
||||
required this.value,
|
||||
|
@ -6,5 +8,5 @@ class FilterItem {
|
|||
|
||||
bool Function() value;
|
||||
String caption;
|
||||
Function(bool) onChanged;
|
||||
Function onChanged;
|
||||
}
|
|
@ -1,19 +1,31 @@
|
|||
import 'package:cake_wallet/core/execution_state.dart';
|
||||
import 'package:cake_wallet/ionia/ionia_gift_card.dart';
|
||||
import 'package:cake_wallet/ionia/ionia_service.dart';
|
||||
import 'package:mobx/mobx.dart';
|
||||
part 'ionia_custom_redeem_view_model.g.dart';
|
||||
|
||||
class IoniaCustomRedeemViewModel = IoniaCustomRedeemViewModelBase with _$IoniaCustomRedeemViewModel;
|
||||
|
||||
abstract class IoniaCustomRedeemViewModelBase with Store {
|
||||
IoniaCustomRedeemViewModelBase(this.giftCard)
|
||||
: amount = 0;
|
||||
IoniaCustomRedeemViewModelBase({
|
||||
required this.giftCard,
|
||||
required this.ioniaService,
|
||||
}) : amount = 0,
|
||||
redeemState = InitialExecutionState();
|
||||
|
||||
final IoniaGiftCard giftCard;
|
||||
|
||||
final IoniaService ioniaService;
|
||||
|
||||
@observable
|
||||
ExecutionState redeemState;
|
||||
|
||||
@observable
|
||||
double amount;
|
||||
|
||||
@computed
|
||||
double get remaining => amount <= giftCard.remainingAmount ? giftCard.remainingAmount - amount : 0;
|
||||
double get remaining =>
|
||||
amount <= giftCard.remainingAmount ? giftCard.remainingAmount - amount : 0;
|
||||
|
||||
@computed
|
||||
String get formattedRemaining => remaining.toStringAsFixed(2);
|
||||
|
@ -23,7 +35,17 @@ abstract class IoniaCustomRedeemViewModelBase with Store {
|
|||
|
||||
@action
|
||||
void updateAmount(String text) {
|
||||
amount = text.isEmpty ? 0 : (double.parse(text.replaceAll(',', '.')) ?? 0);
|
||||
amount = double.tryParse(text.replaceAll(',', '.')) ?? 0;
|
||||
}
|
||||
|
||||
@action
|
||||
Future<void> addCustomRedeem() async {
|
||||
try {
|
||||
redeemState = IsExecutingState();
|
||||
await ioniaService.redeem(giftCardId: giftCard.id, amount: amount);
|
||||
redeemState = ExecutedSuccessfullyState();
|
||||
} catch (e) {
|
||||
redeemState = FailureState(e.toString());
|
||||
}
|
||||
}
|
||||
}
|
|
@ -6,13 +6,11 @@ import 'package:device_display_brightness/device_display_brightness.dart';
|
|||
|
||||
part 'ionia_gift_card_details_view_model.g.dart';
|
||||
|
||||
class IoniaGiftCardDetailsViewModel = IoniaGiftCardDetailsViewModelBase with _$IoniaGiftCardDetailsViewModel;
|
||||
class IoniaGiftCardDetailsViewModel = IoniaGiftCardDetailsViewModelBase
|
||||
with _$IoniaGiftCardDetailsViewModel;
|
||||
|
||||
abstract class IoniaGiftCardDetailsViewModelBase with Store {
|
||||
|
||||
IoniaGiftCardDetailsViewModelBase({
|
||||
required this.ioniaService,
|
||||
required this.giftCard})
|
||||
IoniaGiftCardDetailsViewModelBase({required this.ioniaService, required this.giftCard})
|
||||
: redeemState = InitialExecutionState(),
|
||||
remainingAmount = giftCard.remainingAmount,
|
||||
brightness = 0;
|
||||
|
@ -35,7 +33,7 @@ abstract class IoniaGiftCardDetailsViewModelBase with Store {
|
|||
giftCard.remainingAmount = remainingAmount;
|
||||
try {
|
||||
redeemState = IsExecutingState();
|
||||
await ioniaService.redeem(giftCard);
|
||||
await ioniaService.redeem(giftCardId: giftCard.id, amount: giftCard.remainingAmount);
|
||||
giftCard = await ioniaService.getGiftCard(id: giftCard.id);
|
||||
redeemState = ExecutedSuccessfullyState();
|
||||
} catch (e) {
|
||||
|
@ -44,8 +42,9 @@ abstract class IoniaGiftCardDetailsViewModelBase with Store {
|
|||
}
|
||||
|
||||
@action
|
||||
void updateRemaining(double amount){
|
||||
remainingAmount = amount;
|
||||
Future<void> refeshCard() async {
|
||||
giftCard = await ioniaService.getGiftCard(id: giftCard.id);
|
||||
remainingAmount = giftCard.remainingAmount;
|
||||
}
|
||||
|
||||
void increaseBrightness() async {
|
||||
|
|
|
@ -180,6 +180,8 @@ abstract class SendViewModelBase with Store {
|
|||
|
||||
WalletType get walletType => _wallet.type;
|
||||
|
||||
String? get walletCurrencyName => _wallet.currency.name?.toLowerCase();
|
||||
|
||||
bool get hasCurrecyChanger => walletType == WalletType.haven;
|
||||
|
||||
@computed
|
||||
|
|
|
@ -1,4 +1,6 @@
|
|||
import 'package:cake_wallet/core/auth_service.dart';
|
||||
import 'package:cake_wallet/entities/biometric_auth.dart';
|
||||
import 'package:cake_wallet/entities/pin_code_required_duration.dart';
|
||||
import 'package:cake_wallet/store/settings_store.dart';
|
||||
import 'package:mobx/mobx.dart';
|
||||
|
||||
|
@ -7,19 +9,33 @@ part 'security_settings_view_model.g.dart';
|
|||
class SecuritySettingsViewModel = SecuritySettingsViewModelBase with _$SecuritySettingsViewModel;
|
||||
|
||||
abstract class SecuritySettingsViewModelBase with Store {
|
||||
SecuritySettingsViewModelBase(this._settingsStore) : _biometricAuth = BiometricAuth();
|
||||
SecuritySettingsViewModelBase(
|
||||
this._settingsStore,
|
||||
this._authService,
|
||||
) : _biometricAuth = BiometricAuth();
|
||||
|
||||
final BiometricAuth _biometricAuth;
|
||||
final SettingsStore _settingsStore;
|
||||
final AuthService _authService;
|
||||
|
||||
@computed
|
||||
bool get allowBiometricalAuthentication => _settingsStore.allowBiometricalAuthentication;
|
||||
|
||||
@computed
|
||||
PinCodeRequiredDuration get pinCodeRequiredDuration => _settingsStore.pinTimeOutDuration;
|
||||
|
||||
@action
|
||||
Future<bool> biometricAuthenticated() async {
|
||||
return await _biometricAuth.canCheckBiometrics() && await _biometricAuth.isAuthenticated();
|
||||
}
|
||||
|
||||
@action
|
||||
void setAllowBiometricalAuthentication(bool value) => _settingsStore.allowBiometricalAuthentication = value;
|
||||
void setAllowBiometricalAuthentication(bool value) =>
|
||||
_settingsStore.allowBiometricalAuthentication = value;
|
||||
|
||||
@action
|
||||
setPinCodeRequiredDuration(PinCodeRequiredDuration duration) =>
|
||||
_settingsStore.pinTimeOutDuration = duration;
|
||||
|
||||
bool checkPinCodeRiquired() => _authService.requireAuth();
|
||||
}
|
||||
|
|
|
@ -142,17 +142,5 @@ abstract class TradeDetailsViewModelBase with Store {
|
|||
items.add(TrackTradeListItem(
|
||||
title: 'Track', value: buildURL, onTap: () => launch(buildURL)));
|
||||
}
|
||||
|
||||
if (trade.createdAt != null) {
|
||||
items.add(StandartListItem(
|
||||
title: S.current.trade_details_created_at,
|
||||
value: trade.createdAt != null ? dateFormat.format(trade.createdAt!).toString() : ''));
|
||||
}
|
||||
|
||||
if (trade.from != null && trade.to != null) {
|
||||
items.add(StandartListItem(
|
||||
title: S.current.trade_details_pair,
|
||||
value: '${trade.from.toString()} → ${trade.to.toString()}'));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -30,7 +30,7 @@ abstract class WalletAddressEditOrCreateViewModelBase with Store {
|
|||
{required WalletBase wallet, dynamic item})
|
||||
: isEdit = item != null,
|
||||
state = AddressEditOrCreateStateInitial(),
|
||||
label = item?.name as String? ?? '',
|
||||
label = item?.fullName as String? ?? '',
|
||||
_item = item,
|
||||
_wallet = wallet;
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import 'package:cake_wallet/core/auth_service.dart';
|
||||
import 'package:cake_wallet/core/wallet_loading_service.dart';
|
||||
import 'package:cake_wallet/view_model/wallet_new_vm.dart';
|
||||
import 'package:hive/hive.dart';
|
||||
import 'package:mobx/mobx.dart';
|
||||
import 'package:cake_wallet/di.dart';
|
||||
|
@ -15,9 +15,12 @@ part 'wallet_list_view_model.g.dart';
|
|||
class WalletListViewModel = WalletListViewModelBase with _$WalletListViewModel;
|
||||
|
||||
abstract class WalletListViewModelBase with Store {
|
||||
WalletListViewModelBase(this._walletInfoSource, this._appStore,
|
||||
this._walletLoadingService)
|
||||
: wallets = ObservableList<WalletListItem>() {
|
||||
WalletListViewModelBase(
|
||||
this._walletInfoSource,
|
||||
this._appStore,
|
||||
this._walletLoadingService,
|
||||
this._authService,
|
||||
) : wallets = ObservableList<WalletListItem>() {
|
||||
_updateList();
|
||||
}
|
||||
|
||||
|
@ -27,6 +30,7 @@ abstract class WalletListViewModelBase with Store {
|
|||
final AppStore _appStore;
|
||||
final Box<WalletInfo> _walletInfoSource;
|
||||
final WalletLoadingService _walletLoadingService;
|
||||
final AuthService _authService;
|
||||
|
||||
WalletType get currentWalletType => _appStore.wallet!.type;
|
||||
|
||||
|
@ -47,12 +51,20 @@ abstract class WalletListViewModelBase with Store {
|
|||
|
||||
void _updateList() {
|
||||
wallets.clear();
|
||||
wallets.addAll(_walletInfoSource.values.map((info) => WalletListItem(
|
||||
wallets.addAll(
|
||||
_walletInfoSource.values.map(
|
||||
(info) => WalletListItem(
|
||||
name: info.name,
|
||||
type: info.type,
|
||||
key: info.key,
|
||||
isCurrent: info.name == _appStore.wallet!.name &&
|
||||
info.type == _appStore.wallet!.type,
|
||||
isEnabled: availableWalletTypes.contains(info.type))));
|
||||
isCurrent: info.name == _appStore.wallet!.name && info.type == _appStore.wallet!.type,
|
||||
isEnabled: availableWalletTypes.contains(info.type),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
bool checkIfAuthRequired() {
|
||||
return _authService.requireAuth();
|
||||
}
|
||||
}
|
||||
|
|
681
res/values/strings_ar.arb
Normal file
681
res/values/strings_ar.arb
Normal file
|
@ -0,0 +1,681 @@
|
|||
{
|
||||
"welcome":"مرحبا بك في",
|
||||
"cake_wallet":"Cake Wallet",
|
||||
"first_wallet_text":"محفظة رائعة ل Monero, Bitcoin, Litecoin و Haven",
|
||||
"please_make_selection":"يرجى الأختيار لإنشاء أو استعادة محفظتك.",
|
||||
"create_new":"إنشاء محفظة جديدة",
|
||||
"restore_wallet":"استعادة محفظة",
|
||||
|
||||
"monero_com":"Monero.com بواسطة Cake Wallet",
|
||||
"monero_com_wallet_text":"محفظة رائعة ل Monero",
|
||||
|
||||
"haven_app":"Haven بواسطة Cake Wallet",
|
||||
"haven_app_wallet_text":"محفظة رائعة ل Haven",
|
||||
|
||||
"accounts":"حسابتي",
|
||||
"edit":"تعديل",
|
||||
"account":"حساب",
|
||||
"add":"إضافة",
|
||||
|
||||
|
||||
"address_book":"دليل العناوين",
|
||||
"contact":"تواصل",
|
||||
"please_select":"الرجاء الأختيار:",
|
||||
"cancel":"إلغاء",
|
||||
"ok":"حسناً",
|
||||
"contact_name":"اسم جهة الاتصال",
|
||||
"reset":"إعادة",
|
||||
"save":"حفظ",
|
||||
"address_remove_contact":"ازالة جهة الاتصال",
|
||||
"address_remove_content":"هل أنت متأكد من رغبتك في إزالة جهة الاتصال المحددة؟",
|
||||
|
||||
|
||||
"authenticated":"تم المصادقة",
|
||||
"authentication":"المصادقة",
|
||||
"failed_authentication":"${state_error} فشل المصادقة.",
|
||||
|
||||
|
||||
"wallet_menu":"قائمة",
|
||||
"Blocks_remaining":"بلوك متبقي ${status}",
|
||||
"please_try_to_connect_to_another_node":"الرجاء محاولة الاتصال بعقدة أخرى",
|
||||
"xmr_hidden":"مختفي",
|
||||
"xmr_available_balance":"الرصيد المتوفر",
|
||||
"xmr_full_balance":"الرصيد الكامل",
|
||||
"send":"إرسال",
|
||||
"receive":"استلام",
|
||||
"transactions":"المعاملات",
|
||||
"incoming":"الواردة",
|
||||
"outgoing":"الصادره",
|
||||
"transactions_by_date":"المعاملات حسب التاريخ",
|
||||
"trades":"عمليات التداول",
|
||||
"filter_by":"تصفية حسب",
|
||||
"today":"اليوم",
|
||||
"yesterday":"الامس",
|
||||
"received":"استلام",
|
||||
"sent":"تم الأرسال",
|
||||
"pending":" (في الإنتظار)",
|
||||
"rescan":"إعادة الفحص",
|
||||
"reconnect":"أعد الاتصال",
|
||||
"wallets":"المحافظ",
|
||||
"show_seed":"عرض السييد",
|
||||
"show_keys":"اظهار السييد / المفاتيح",
|
||||
"address_book_menu":"دليل العناوين",
|
||||
"reconnection":"إعادة الاتصال",
|
||||
"reconnect_alert_text":"هل أنت متأكد من رغبتك في إعادة الاتصال؟",
|
||||
|
||||
|
||||
"exchange":"تبادل",
|
||||
"clear":"مسح",
|
||||
"refund_address":"عنوان إعادة المال",
|
||||
"change_exchange_provider":"تغيير مزود الصرف",
|
||||
"you_will_send":"تحويل من",
|
||||
"you_will_get":"حول الى",
|
||||
"amount_is_guaranteed":"مبلغ الاستلام مضمون",
|
||||
"amount_is_estimate":"المبلغ المستلم هو تقدير",
|
||||
"powered_by":"بدعم من ${title}",
|
||||
"error":"خطأ",
|
||||
"estimated":"مُقدَّر",
|
||||
"min_value":"الحد الأدنى: ${value} ${currency}",
|
||||
"max_value":"الحد الأقصى: ${value} ${currency}",
|
||||
"change_currency":"تغيير العملة",
|
||||
"overwrite_amount":"تغير المبلغ",
|
||||
"qr_payment_amount":"يحتوي هذا ال QR على مبلغ الدفع. هل تريد تغير المبلغ فوق القيمة الحالية؟",
|
||||
|
||||
"copy_id":"نسخ معرف العملية",
|
||||
"exchange_result_write_down_trade_id":"يرجى نسخ أو كتابة معرّف العملية للمتابعة.",
|
||||
"trade_id":"معرف عملية التبادل:",
|
||||
"copied_to_clipboard":"نسخ إلى الحافظة",
|
||||
"saved_the_trade_id":"لقد تم حفظ معرف العملية",
|
||||
"fetching":"جار الجلب",
|
||||
"id":"رقم المعرف:",
|
||||
"amount":"مقدار:",
|
||||
"payment_id":"معرف الدفع:",
|
||||
"status":"الحالة:",
|
||||
"offer_expires_in":"ينتهي العرض في:",
|
||||
"trade_is_powered_by":"عملية التبادل مدعومة من ${provider}",
|
||||
"copy_address":"نسخ العنوان",
|
||||
"exchange_result_confirm":"بالضغط على تأكيد ، سترسل ${fetchingLabel} ${from} من محفظتك المسماة ${walletName} إلى العنوان الموضح أدناه. أو يمكنك الإرسال من محفظتك الخارجية إلى العنوان أدناه / QR.\n\nيرجى الضغط على تأكيد للمتابعة أو الرجوع لتغيير المبالغ.",
|
||||
"exchange_result_description":"يجب عليك إرسال ما لا يقل عن ${fetchingLabel} ${from} إلى العنوان المعروض في الصفحة التالية. إذا أرسلت مبلغًا أقل من ${fetchingLabel} ${from} فقد لا يتم تحويله وقد لا يتم رده.",
|
||||
"exchange_result_write_down_ID":"* يرجى نسخ أو كتابة معرف هويتك الأعلى لحفظة.",
|
||||
"confirm":"تأكيد",
|
||||
"confirm_sending":"تأكيد الإرسال",
|
||||
"commit_transaction_amount_fee":"تنفيذ الصفقة\nالمبلغ: ${amount}\nالرسوم: ${fee}",
|
||||
"sending":"يتم الإرسال",
|
||||
"transaction_sent":"تم إرسال المعاملة!",
|
||||
"expired":"منتهي الصلاحية",
|
||||
"time":"${minutes}د ${seconds}س",
|
||||
"send_xmr":"أرسل XMR",
|
||||
"exchange_new_template":"قالب جديد",
|
||||
|
||||
"faq":"الأسئلة الشائعة",
|
||||
|
||||
|
||||
"enter_your_pin":"أدخل كود الرقم السري",
|
||||
"loading_your_wallet":"يتم تحميل محفظتك",
|
||||
|
||||
|
||||
"new_wallet":"إنشاء محفظة جديدة",
|
||||
"wallet_name":"اسم المحفظة",
|
||||
"continue_text":"التالي",
|
||||
"choose_wallet_currency":"الرجاء اختيار عملة المحفظة:",
|
||||
|
||||
|
||||
"node_new":"عقدة جديدة",
|
||||
"node_address":"عنوان العقدة",
|
||||
"node_port":"منفذ العقدة",
|
||||
"login":"تسجيل الدخول",
|
||||
"password":"كلمة المرور",
|
||||
"nodes":"العقد",
|
||||
"node_reset_settings_title":"اعادة الضبط",
|
||||
"nodes_list_reset_to_default_message":"هل أنت متأكد أنك تريد إعادة تعيين الإعدادات إلى الافتراضي؟",
|
||||
"change_current_node":"هل أنت متأكد من تغيير العقدة الحالية إلى ${node}؟",
|
||||
"change":"تغير",
|
||||
"remove_node":"إزالة العقدة",
|
||||
"remove_node_message":"هل أنت متأكد أنك تريد إزالة العقدة المحددة؟",
|
||||
"remove":"إزالة",
|
||||
"delete":"حذف",
|
||||
"add_new_node":"أضافة عقدة جديدة",
|
||||
"change_current_node_title":"تغيير العقدة الحالية",
|
||||
"node_test":"تجربة",
|
||||
"node_connection_successful":"تم الاتصال بنجاح",
|
||||
"node_connection_failed":"فشل الاتصال",
|
||||
"new_node_testing":"تجربة العقدة الجديدة",
|
||||
|
||||
|
||||
"use":"التبديل إلى",
|
||||
"digit_pin":"-رقم PIN",
|
||||
|
||||
|
||||
"share_address":"شارك العنوان",
|
||||
"receive_amount":"المقدار",
|
||||
"subaddresses":"العناوين الفرعية",
|
||||
"addresses":"عناوين",
|
||||
"scan_qr_code":"امسح ال QR للحصول على العنوان",
|
||||
"qr_fullscreen":"انقر لفتح ال QR بملء الشاشة",
|
||||
"rename":"إعادة تسمية",
|
||||
"choose_account":"اختر حساب",
|
||||
"create_new_account":"انشاء حساب جديد",
|
||||
"accounts_subaddresses":"الحسابات والعناوين الفرعية",
|
||||
|
||||
|
||||
"restore_restore_wallet":"استعادة محفظة",
|
||||
"restore_title_from_seed_keys":"استعادة من السييد / المفاتيح",
|
||||
"restore_description_from_seed_keys":"استرجع محفظتك من السييد / المفاتيح التي قمت بحفظها في مكان آمن",
|
||||
"restore_next":"التالي",
|
||||
"restore_title_from_backup":"استعادة من النسخة الاحتياطية",
|
||||
"restore_description_from_backup":"يمكنك استعادة تطبيق Cake Wallet بالكامل من ملف النسخ الاحتياطي",
|
||||
"restore_seed_keys_restore":"استعادة السييد / المفاتيح",
|
||||
"restore_title_from_seed":"استعادة من السييد",
|
||||
"restore_description_from_seed":"قم باستعادة محفظتك من الرمز المكون من 25 كلمة أو 13 كلمة",
|
||||
"restore_title_from_keys":"استعادة من المفاتيح",
|
||||
"restore_description_from_keys":"قم باستعادة محفظتك من ضغطات المفاتيح المولدة المحفوظة من مفاتيحك الخاصة",
|
||||
"restore_wallet_name":"اسم المحفظة",
|
||||
"restore_address":"العنوان",
|
||||
"restore_view_key_private":"مفتاح العرض (خاص)",
|
||||
"restore_spend_key_private":"مفتاح الإنفاق (خاص)",
|
||||
"restore_recover":"استعادة",
|
||||
"restore_wallet_restore_description":"وصف استعادة المحفظة",
|
||||
"restore_new_seed":"سييد جديدة",
|
||||
"restore_active_seed":"السييد النشطة",
|
||||
"restore_bitcoin_description_from_seed":"قم باستعادة محفظتك من كود مكون من 24 كلمة",
|
||||
"restore_bitcoin_description_from_keys":"قم باستعادة محفظتك من سلسلة WIF التي تم إنشاؤها من مفاتيحك الخاصة",
|
||||
"restore_bitcoin_title_from_keys":"استعادة من WIF",
|
||||
"restore_from_date_or_blockheight":"الرجاء إدخال تاريخ قبل إنشاء هذه المحفظة ببضعة أيام. أو إذا كنت تعرف ارتفاع البلوك، فيرجى إدخاله بدلاً من ذلك",
|
||||
|
||||
|
||||
"seed_reminder":"يرجى تدوينها في حالة فقد هاتفك أو مسحه",
|
||||
"seed_title":"سييد",
|
||||
"seed_share":"شارك السييد",
|
||||
"copy":"نسخ",
|
||||
|
||||
|
||||
"seed_language_choose":"الرجاء اختيار لغة السييد:",
|
||||
"seed_choose":"اختر لغة السييد",
|
||||
"seed_language_next":"التالي",
|
||||
"seed_language_english":"إنجليزي",
|
||||
"seed_language_chinese":"صينى",
|
||||
"seed_language_dutch":"هولندي",
|
||||
"seed_language_german":"ألمانية",
|
||||
"seed_language_japanese":"اليابانية",
|
||||
"seed_language_portuguese":"البرتغالية",
|
||||
"seed_language_russian":"الروسية",
|
||||
"seed_language_spanish":"الأسبانية",
|
||||
"seed_language_french":"فرنسي",
|
||||
"seed_language_italian":"إيطالي",
|
||||
|
||||
|
||||
"send_title":"إرسال",
|
||||
"send_your_wallet":"محفظتك",
|
||||
"send_address":"عنوان ${cryptoCurrency}",
|
||||
"send_payment_id":"معرف عملية الدفع (اختياري)",
|
||||
"all":"الكل",
|
||||
"send_error_minimum_value":"الحد الأدنى لقيمة المبلغ هو 0.01",
|
||||
"send_error_currency":"العملة يجب أن تحتوي على أرقام فقط",
|
||||
"send_estimated_fee":"الرسوم المقدرة:",
|
||||
"send_priority":"حاليًا ، تم تحديد الرسوم بأولوية ${transactionPriority}.\nيمكن تعديل أولوية المعاملة في الإعدادات",
|
||||
"send_creating_transaction":" يتم إنشاء المعاملة",
|
||||
"send_templates":"القوالب",
|
||||
"send_new":"جديد",
|
||||
"send_amount":"مقدار:",
|
||||
"send_fee":"الرسوم:",
|
||||
"send_name":"الأسم",
|
||||
"send_got_it":"فهمتك",
|
||||
"send_sending":"يتم الإرسال...",
|
||||
"send_success":"تم إرسال ${crypto} الخاص بك بنجاح",
|
||||
|
||||
|
||||
"settings_title":"إعدادات",
|
||||
"settings_nodes":"العقد",
|
||||
"settings_current_node":"العقدة الحالية",
|
||||
"settings_wallets":"المحافظ",
|
||||
"settings_display_balance":"عرض الرصيد",
|
||||
"settings_currency":"العملة",
|
||||
"settings_fee_priority":"رسوم الأولوية",
|
||||
"settings_save_recipient_address":"حفظ عنوان المستلم",
|
||||
"settings_personal":"شخصي",
|
||||
"settings_change_pin":"تغيير PIN",
|
||||
"settings_change_language":"تغيير اللغة",
|
||||
"settings_allow_biometrical_authentication":"السماح بالمصادقة البيومترية",
|
||||
"settings_dark_mode":"الوضع الداكن",
|
||||
"settings_transactions":"المبادلات",
|
||||
"settings_trades":"الصفقات",
|
||||
"settings_display_on_dashboard_list":"عرض في قائمة لوحة المعلومات",
|
||||
"settings_all":"الكل",
|
||||
"settings_only_trades":"الصفقات فقط",
|
||||
"settings_only_transactions":"المعاملات فقط",
|
||||
"settings_none":"لا شيء",
|
||||
"settings_support":"الدعم",
|
||||
"settings_terms_and_conditions":"الأحكام والشروط",
|
||||
"pin_is_incorrect":"رقم ال PIN غير صحيح",
|
||||
|
||||
|
||||
"setup_pin":"تعيين PIN",
|
||||
"enter_your_pin_again":"أدخل PIN الخاص بك مرة أخرى",
|
||||
"setup_successful":"تم إعداد PIN الخاص بك بنجاح!",
|
||||
|
||||
|
||||
"wallet_keys":"سييد المحفظة / المفاتيح",
|
||||
"wallet_seed":"سييد المحفظة",
|
||||
"private_key":"مفتاح خاص",
|
||||
"public_key":"مفتاح عمومي",
|
||||
"view_key_private":"مفتاح العرض (خاص)",
|
||||
"view_key_public":"مفتاح العرض (عام)",
|
||||
"spend_key_private":"مفتاح الإنفاق (خاص)",
|
||||
"spend_key_public":"مفتاح الإنفاق (عام)",
|
||||
"copied_key_to_clipboard":"تم نسخ ${key} إلى الحافظة",
|
||||
|
||||
|
||||
"new_subaddress_title":"عنوان جديد",
|
||||
"new_subaddress_label_name":"تسمية",
|
||||
"new_subaddress_create":"إنشاء",
|
||||
|
||||
"address_label":"تسمية عنوان",
|
||||
|
||||
"subaddress_title":"قائمة العناوين الفرعية",
|
||||
|
||||
|
||||
"trade_details_title":"تفاصيل الصفقة",
|
||||
"trade_details_id":"معرف (ID)",
|
||||
"trade_details_state":"الحالة",
|
||||
"trade_details_fetching":"جار الجلب",
|
||||
"trade_details_provider":"مزود",
|
||||
"trade_details_created_at":"أنشئت في",
|
||||
"trade_details_pair":"زوج",
|
||||
"trade_details_copied":"تم نسخ ${title} إلى الحافظة",
|
||||
|
||||
|
||||
"trade_history_title":"تاريخ الصفقه",
|
||||
|
||||
|
||||
"transaction_details_title":"تفاصيل المعاملة",
|
||||
"transaction_details_transaction_id":"رقم المعاملة",
|
||||
"transaction_details_date":"تاريخ",
|
||||
"transaction_details_height":"ارتفاع",
|
||||
"transaction_details_amount":"مقدار",
|
||||
"transaction_details_fee":"رسوم",
|
||||
"transaction_details_copied":"تم نسخ ${title} إلى الحافظة",
|
||||
"transaction_details_recipient_address":"عناوين المستلم",
|
||||
|
||||
|
||||
"wallet_list_title":"محفظة Monero",
|
||||
"wallet_list_create_new_wallet":"إنشاء محفظة جديدة",
|
||||
"wallet_list_restore_wallet":"استعادة المحفظة",
|
||||
"wallet_list_load_wallet":"تحميل المحفظة",
|
||||
"wallet_list_loading_wallet":"جار تحميل محفظة ${wallet_name}",
|
||||
"wallet_list_failed_to_load":"فشل تحميل محفظة ${wallet_name}. ${error}",
|
||||
"wallet_list_removing_wallet":"يتم إزالة محفظة ${wallet_name}",
|
||||
"wallet_list_failed_to_remove":"فشلت إزالة محفظة ${wallet_name}. ${error}",
|
||||
|
||||
|
||||
"widgets_address":"عنوان",
|
||||
"widgets_restore_from_blockheight":"استعادة من ارتفاع البلوك",
|
||||
"widgets_restore_from_date":"استعادة من التاريخ",
|
||||
"widgets_or":"أو",
|
||||
"widgets_seed":"سييد",
|
||||
|
||||
|
||||
"router_no_route":"لم يتم تحديد مسار لـ ${name}",
|
||||
|
||||
|
||||
"error_text_account_name":"يجب أن يحتوي اسم الحساب على أحرف وأرقام فقط\nويجب أن يتراوح بين حرف واحد و 15 حرفًا",
|
||||
"error_text_contact_name":"لا يمكن أن يحتوي اسم جهة الاتصال على الرموز ` , ' \"\nويجب أن يتراوح بين حرف و 32 حرفًا",
|
||||
"error_text_address":"يجب أن يتوافق عنوان المحفظة مع نوع\nالعملة المشفرة",
|
||||
"error_text_node_address":"الرجاء إدخال عنوان IPv4",
|
||||
"error_text_node_port":"منفذ العقدة يمكن أن يحتوي فقط على أرقام بين 0 و 65535",
|
||||
"error_text_payment_id":"يمكن أن يحتوي معرّف الدفع فقط من 16 إلى 64 حرفًا hex",
|
||||
"error_text_xmr":"لا يمكن أن تتجاوز قيمة XMR الرصيد المتاح.\nيجب أن يكون عدد الكسور أقل من أو يساوي 12",
|
||||
"error_text_fiat":"لا يمكن أن تتجاوز قيمة المبلغ الرصيد المتاح.\nيجب أن يكون عدد الكسور أقل أو يساوي 2",
|
||||
"error_text_subaddress_name":"لا يمكن أن يحتوي اسم العنوان الفرعي على رموز ` , ' \"\nويجب أن يتراوح طولها بين حرف واحد و 20 حرفًا",
|
||||
"error_text_amount":"يجب أن يحتوي المبلغ على أرقام فقط",
|
||||
"error_text_wallet_name":"يمكن أن يحتوي اسم المحفظة على أحرف وأرقام ورموز _ - فقط\nويجب أن يتراوح طولها بين حرف واحد و 33 حرفًا",
|
||||
"error_text_keys":"يمكن أن تحتوي مفاتيح المحفظة على 64 حرفًا hex",
|
||||
"error_text_crypto_currency":"عدد الكسور\nيجب أن تكون أقل من أو تساوي 12",
|
||||
"error_text_minimal_limit":"لم يتم إنشاء الصفقة لـ ${provider}. المبلغ أقل من الحد الأدنى: ${min} ${currency}",
|
||||
"error_text_maximum_limit":"لم يتم إنشاء الصفقة لـ ${provider}. المبلغ أكبر من الحد الأقصى: ${max} ${currency}",
|
||||
"error_text_limits_loading_failed":"لم يتم إنشاء الصفقة لـ ${provider}. فشل تحميل الحدود",
|
||||
"error_text_template":"لا يمكن أن يحتوي اسم القالب وعنوانه على رموز ` , \"\nويجب أن يتراوح طولها بين 1 و 106 حرفًا",
|
||||
|
||||
|
||||
"auth_store_ban_timeout":"مهلة_الحظر",
|
||||
"auth_store_banned_for":"محظور ل",
|
||||
"auth_store_banned_minutes":" دقيقة",
|
||||
"auth_store_incorrect_password":"PIN خطأ",
|
||||
"wallet_store_monero_wallet":"محفظة Monero",
|
||||
"wallet_restoration_store_incorrect_seed_length":"طول السييد غير صحيح",
|
||||
|
||||
|
||||
"full_balance":"الرصيد الكامل",
|
||||
"available_balance":"الرصيد المتوفر",
|
||||
"hidden_balance":"الميزان الخفي",
|
||||
|
||||
|
||||
"sync_status_syncronizing":"يتم المزامنة",
|
||||
"sync_status_syncronized":"متزامن",
|
||||
"sync_status_not_connected":"غير متصل",
|
||||
"sync_status_starting_sync":"بدء المزامنة",
|
||||
"sync_status_failed_connect":"انقطع الاتصال",
|
||||
"sync_status_connecting":"يتم التوصيل",
|
||||
"sync_status_connected":"متصل",
|
||||
"sync_status_attempting_sync":"جاري محاولة المزامنة",
|
||||
|
||||
|
||||
"transaction_priority_slow":"بطيء",
|
||||
"transaction_priority_regular":"عادي",
|
||||
"transaction_priority_medium":"متوسط",
|
||||
"transaction_priority_fast":"سريع",
|
||||
"transaction_priority_fastest":"أسرع",
|
||||
|
||||
|
||||
"trade_for_not_created":"لم يتم إنشاء التداول للعنصر ${title}.",
|
||||
"trade_not_created":"التداول لم ينشأ",
|
||||
"trade_id_not_found":"تداول ${tradeId} من ${title} غير موجود.",
|
||||
"trade_not_found":"التداول غير موجودة.",
|
||||
|
||||
|
||||
"trade_state_pending":"قيد الانتظار",
|
||||
"trade_state_confirming":"جاري التأكيد",
|
||||
"trade_state_trading":"يتم التداول",
|
||||
"trade_state_traded":"تم التداول بنجاح",
|
||||
"trade_state_complete":"اكتمل",
|
||||
"trade_state_to_be_created":"ليتم انشائه",
|
||||
"trade_state_unpaid":"غير مدفوعة",
|
||||
"trade_state_underpaid":"أجر أقل من اللازم",
|
||||
"trade_state_paid_unconfirmed":"دفع غير مؤكد",
|
||||
"trade_state_paid":"مدفوع",
|
||||
"trade_state_btc_sent":"تم أرسل Btc",
|
||||
"trade_state_timeout":"نفذ الوقت",
|
||||
"trade_state_created":"تم الأنشاء",
|
||||
"trade_state_finished":"تم",
|
||||
|
||||
"change_language":"تغيير اللغة",
|
||||
"change_language_to":"هل تريد تغيير اللغة إلى ${language}؟",
|
||||
|
||||
"paste":"لصق",
|
||||
"restore_from_seed_placeholder":"الرجاء إدخال أو لصق السييد الخاصة بك هنا",
|
||||
"add_new_word":"أضف كلمة جديدة",
|
||||
"incorrect_seed":"النص الذي تم إدخاله غير صالح.",
|
||||
|
||||
"biometric_auth_reason":"امسح بصمة إصبعك للمصادقة",
|
||||
"version":"الإصدار ${currentVersion}",
|
||||
|
||||
"openalias_alert_title":"تم ايجاد العنوان",
|
||||
"openalias_alert_content":"سوف ترسل الأموال إلى\n${recipient_name}",
|
||||
|
||||
"card_address":"العنوان:",
|
||||
"buy":"اشتري",
|
||||
"sell":"بيع",
|
||||
|
||||
"placeholder_transactions":"سيتم عرض معاملاتك هنا",
|
||||
"placeholder_contacts":"سيتم عرض جهات الاتصال الخاصة بك هنا",
|
||||
|
||||
"template":"قالب",
|
||||
"confirm_delete_template":"سيؤدي هذا الإجراء إلى حذف هذا القالب. هل ترغب في الاستمرار؟",
|
||||
"confirm_delete_wallet":"سيؤدي هذا الإجراء إلى حذف هذه المحفظة. هل ترغب في الاستمرار؟",
|
||||
|
||||
"picker_description":"لاختيار ChangeNOW أو MorphToken ، يرجى تغيير زوج التداول الخاص بك أولاً",
|
||||
|
||||
"change_wallet_alert_title":"تغيير المحفظة الحالية",
|
||||
"change_wallet_alert_content":"هل تريد تغيير المحفظة الحالية إلى ${wallet_name}؟",
|
||||
|
||||
"creating_new_wallet":"يتم إنشاء محفظة جديدة",
|
||||
"creating_new_wallet_error":"خطأ: ${description}",
|
||||
|
||||
"seed_alert_title":"انتباه",
|
||||
"seed_alert_content":"السييد هي الطريقة الوحيدة لاسترداد محفظتك. هل كتبتها؟",
|
||||
"seed_alert_back":"العودة إلى الوراء",
|
||||
"seed_alert_yes":"نعم، فعلت ذلك",
|
||||
|
||||
"exchange_sync_alert_content":"يرجى الانتظار حتى تتم مزامنة محفظتك",
|
||||
|
||||
"pre_seed_title":"مهم",
|
||||
"pre_seed_description":"في الصفحة التالية ستشاهد سلسلة من الكلمات ${words}. هذه هي سييد الفريدة والخاصة بك وهي الطريقة الوحيدة لاسترداد محفظتك في حالة فقدها أو عطلها. تقع على عاتقك مسؤولية تدوينها وتخزينها في مكان آمن خارج تطبيق Cake Wallet.",
|
||||
"pre_seed_button_text":"انا أفهم. أرني سييد الخاص بي",
|
||||
|
||||
"xmr_to_error":"خطأ XMR.TO",
|
||||
"xmr_to_error_description":"مبلغ غير صحيح. الحد الأقصى 8 أرقام بعد الفاصلة العشرية",
|
||||
|
||||
"provider_error":"خطأ ${provider}",
|
||||
|
||||
"use_ssl":"استخدم SSL",
|
||||
"trusted":"موثوق به",
|
||||
|
||||
"color_theme":"سمة اللون",
|
||||
"light_theme":"فاتح",
|
||||
"bright_theme":"مشرق",
|
||||
"dark_theme":"داكن",
|
||||
"enter_your_note":"أدخل ملاحظتك ...",
|
||||
"note_optional":"ملاحظة (اختياري)",
|
||||
"note_tap_to_change":"ملاحظة (انقر للتغيير)",
|
||||
"view_in_block_explorer":"عرض في Block Explorer",
|
||||
"view_transaction_on":"عرض العملية على",
|
||||
"transaction_key":"مفتاح العملية",
|
||||
"confirmations":"التأكيدات",
|
||||
"recipient_address":"عنوان المستلم",
|
||||
|
||||
"extra_id":"معرف إضافي:",
|
||||
"destination_tag":"علامة الوجهة:",
|
||||
"memo":"مذكرة:",
|
||||
|
||||
"backup":"نسخ الاحتياطي",
|
||||
"change_password":"تغيير كلمة المرور",
|
||||
"backup_password":"كلمة مرور النسخ الاحتياطي",
|
||||
"write_down_backup_password":"يرجى كتابة كلمة المرور الاحتياطية الخاصة بك ، والتي يتم استخدامها لاستيراد ملفات النسخ الاحتياطي الخاصة بك.",
|
||||
"export_backup":"تصدير نسخة احتياطية",
|
||||
"save_backup_password":"يرجى التأكد من حفظ كلمة المرور الاحتياطية. لن تتمكن من استيراد ملفات النسخ الاحتياطي بدونها.",
|
||||
"backup_file":"ملف النسخ الاحتياطي",
|
||||
|
||||
"edit_backup_password":"تعديل كلمة مرور النسخ الاحتياطي",
|
||||
"save_backup_password_alert":"حفظ كلمة المرور الاحتياطية",
|
||||
"change_backup_password_alert":"لن تكون ملفات النسخ الاحتياطي السابقة متاحة للاستيراد بكلمة مرور نسخ احتياطي جديدة. سيتم استخدام كلمة مرور النسخ الاحتياطي الجديدة لملفات النسخ الاحتياطي الجديدة فقط. هل أنت متأكد أنك تريد تغيير كلمة المرور الاحتياطية؟",
|
||||
|
||||
"enter_backup_password":"أدخل كلمة المرور الاحتياطية هنا",
|
||||
"select_backup_file":"حدد ملف النسخ الاحتياطي",
|
||||
"import":"اختيار ملف",
|
||||
"please_select_backup_file":"الرجاء تحديد ملف النسخ الاحتياطي وإدخال كلمة مرور النسخ الاحتياطي.",
|
||||
|
||||
"fixed_rate":"السعر الثابت",
|
||||
"fixed_rate_alert":"ستتمكن من إدخال مبلغ الاستلام عند تشغيل وضع السعر الثابت. هل تريد التبديل إلى وضع السعر الثابت؟",
|
||||
|
||||
"xlm_extra_info":"من فضلك لا تنس تحديد معرّف المذكرة أثناء إرسال معاملة XLM للتبادل",
|
||||
"xrp_extra_info":"من فضلك لا تنس تحديد علامة الوجهة أثناء إرسال معاملة XRP للتبادل",
|
||||
|
||||
"exchange_incorrect_current_wallet_for_xmr":"إذا كنت ترغب في استبدال XMR من رصيد Cake Wallet Monero ، فيرجى التبديل إلى محفظة Monero أولاً.",
|
||||
"confirmed":"مؤكد",
|
||||
"unconfirmed":"غير مؤكد",
|
||||
"displayable":"قابل للعرض",
|
||||
|
||||
"submit_request":"تقديم طلب",
|
||||
|
||||
"buy_alert_content":"لا ندعم حاليًا سوى شراء Bitcoin و Litecoin. لشراء Bitcoin أو Litecoin ، يرجى إنشاء محفظة Bitcoin أو Litecoin أو التبديل إليها.",
|
||||
"sell_alert_content":"نحن ندعم حاليًا بيع البيتكوين فقط. لبيع Bitcoin ، يرجى إنشاء أو التبديل إلى محفظة Bitcoin الخاصة بك.",
|
||||
|
||||
"outdated_electrum_wallet_description":"محافظ Bitcoin الجديدة التي تم إنشاؤها في Cake الآن سييد مكونة من 24 كلمة. من الضروري أن تقوم بإنشاء محفظة Bitcoin جديدة وتحويل جميع أموالك إلى المحفظة الجديدة المكونة من 24 كلمة ، والتوقف عن استخدام محافظ سييد مكونة من 12 كلمة. يرجى القيام بذلك على الفور لتأمين أموالك.",
|
||||
"understand":"لقد فهمت",
|
||||
|
||||
"apk_update":"تحديث APK",
|
||||
|
||||
"buy_bitcoin":"شراء Bitcoin",
|
||||
"buy_with":"اشتر بواسطة",
|
||||
"moonpay_alert_text":"يجب أن تكون قيمة المبلغ أكبر من أو تساوي ${minAmount} ${fiatCurrency}",
|
||||
|
||||
"outdated_electrum_wallet_receive_warning":"إذا كانت هذه المحفظة تحتوي على سييد مكونة من 12 كلمة وتم إنشاؤها في Cake ، فلا تقم بإيداع Bitcoin في هذه المحفظة. قد يتم فقد أي BTC تم تحويله إلى هذه المحفظة. قم بإنشاء محفظة جديدة مكونة من 24 كلمة (انقر فوق القائمة في الجزء العلوي الأيمن ، وحدد محافظ ، واختر إنشاء محفظة جديدة ، ثم حدد Bitcoin) وقم على الفور بنقل BTC الخاص بك هناك. محافظ BTC الجديدة (24 كلمة) من Cake آمنة",
|
||||
"do_not_show_me":"لا ترني هذا مجددا",
|
||||
|
||||
"unspent_coins_title":"العملات الغير المنفقة",
|
||||
"unspent_coins_details_title":"تفاصيل العملات الغير المنفقة",
|
||||
"freeze":"تجميد",
|
||||
"frozen":"مجمدة",
|
||||
"coin_control":"التحكم في العملة (اختياري)",
|
||||
|
||||
"address_detected":"تم ايجاد العنوان",
|
||||
"address_from_domain":"هذا العنوان من ${domain} من Unstoppable Domains",
|
||||
|
||||
"add_receiver":"أضف مستقبل آخر (اختياري)",
|
||||
|
||||
"manage_yats":"إدارة Yats",
|
||||
"yat_alert_title":"أرسل واستقبل العملات المشفرة بسهولة أكبر مع Yat",
|
||||
"yat_alert_content":"يمكن لمستخدمي Cake Wallet الآن إرسال واستلام جميع عملاتهم المفضلة باستخدام اسم مستخدم فريد من نوعه قائم على الرموز التعبيرية.",
|
||||
"get_your_yat":"احصل على Yat",
|
||||
"connect_an_existing_yat":"توصيل Yat الحالي",
|
||||
"connect_yats":"توصيل Yats",
|
||||
"yat_address":"عنوان Yat",
|
||||
"yat":"Yat",
|
||||
"address_from_yat":"هذا العنوان من ${emoji} على Yat",
|
||||
"yat_error":"خطأ Yat",
|
||||
"yat_error_content":"لا توجد عناوين مرتبطة بهذا Yat. جرب يات آخر",
|
||||
"choose_address":"\n\nالرجاء اختيار عنوان:",
|
||||
"yat_popup_title":"يمكن تحويل عنوان محفظتك إلى رموز تعبيرية.",
|
||||
"yat_popup_content":"يمكنك الآن إرسال واستلام العملات المشفرة في Cake Wallet باستخدام Yat - اسم مستخدم قصير يعتمد على الرموز التعبيرية. إدارة Yats في أي وقت على شاشة الإعدادات",
|
||||
"second_intro_title":"عنوان تعبيري ايموجي واحد يحكمهم جميعا!",
|
||||
"second_intro_content":"Yat الخاص بك هو عنوان تعبيري فريد يحل محل جميع العناوين السداسية العشرية الطويلة لجميع عملاتك.",
|
||||
"third_intro_title":"يتماشي Yat بلطف مع الآخرين",
|
||||
"third_intro_content":"يعيش Yats خارج Cake Wallet أيضًا. يمكن استبدال أي عنوان محفظة على وجه الأرض بـ Yat!",
|
||||
"learn_more":"اعرف المزيد",
|
||||
"search":"بحث",
|
||||
"search_language":"ابحث عن لغة",
|
||||
"search_currency":"ابحث عن عملة",
|
||||
"new_template":"قالب جديد",
|
||||
"electrum_address_disclaimer":"نقوم بإنشاء عناوين جديدة في كل مرة تستخدم فيها عنوانًا ، لكن العناوين السابقة تستمر في العمل",
|
||||
"wallet_name_exists":"توجد بالفعل محفظة بهذا الاسم. الرجاء اختيار اسم مختلف أو إعادة تسمية المحفظة الأخرى أولاً.",
|
||||
"market_place":"منصة التجارة",
|
||||
"cake_pay_title":"بطاقات هدايا Cake Pay",
|
||||
"cake_pay_subtitle":"شراء بطاقات هدايا مخفضة السعر (الولايات المتحدة فقط)",
|
||||
"cake_pay_web_cards_title":"بطاقات Cake Pay Web",
|
||||
"cake_pay_web_cards_subtitle":"اشتري بطاقات مدفوعة مسبقا وبطاقات هدايا في جميع أنحاء العالم",
|
||||
"about_cake_pay":"يتيح لك Cake Pay شراء بطاقات هدايا بأصول افتراضية بسهولة ، ويمكن إنفاقها على الفور لدى أكثر من 150,000 تاجر في الولايات المتحدة.",
|
||||
"cake_pay_account_note":"قم بالتسجيل باستخدام عنوان بريد إلكتروني فقط لمشاهدة البطاقات وشرائها. حتى أن بعضها متوفر بسعر مخفض!",
|
||||
"already_have_account":"لديك حساب؟",
|
||||
"create_account":"إنشاء حساب",
|
||||
"privacy_policy":"سياسة الخصوصية",
|
||||
"welcome_to_cakepay":"مرحبا بكم في Cake Pay!",
|
||||
"sign_up":"اشتراك",
|
||||
"forgot_password":"هل نسيت كلمة السر",
|
||||
"reset_password":"إعادة تعيين كلمة المرور",
|
||||
"gift_cards":"بطاقات الهدايا",
|
||||
"setup_your_debit_card":"قم بإعداد بطاقة ائتمان الخاصة بك",
|
||||
"no_id_required":"لا ID مطلوب. اشحن وانفق في أي مكان",
|
||||
"how_to_use_card":"كيفية استخدام هذه البطاقة",
|
||||
"purchase_gift_card":"شراء بطاقة هدايا",
|
||||
"verification":"تَحَقّق",
|
||||
"fill_code":"يرجى ملء رمز التحقق المرسل إلى بريدك الإلكتروني",
|
||||
"dont_get_code":"لم تحصل على رمز؟",
|
||||
"resend_code":"الرجاء إعادة إرسالها",
|
||||
"debit_card":"بطاقة ائتمان",
|
||||
"cakepay_prepaid_card":"بطاقة ائتمان CakePay مسبقة الدفع",
|
||||
"no_id_needed":"لا حاجة لID!",
|
||||
"frequently_asked_questions":"الأسئلة الشائعة",
|
||||
"debit_card_terms":"يخضع تخزين واستخدام رقم بطاقة الدفع الخاصة بك (وبيانات الاعتماد المقابلة لرقم بطاقة الدفع الخاصة بك) في هذه المحفظة الرقمية لشروط وأحكام اتفاقية حامل البطاقة المعمول بها مع جهة إصدار بطاقة الدفع ، كما هو معمول به من وقت لآخر.",
|
||||
"please_reference_document":"يرجى الرجوع إلى الوثائق أدناه لمزيد من المعلومات.",
|
||||
"cardholder_agreement":"اتفاقية حامل البطاقة",
|
||||
"e_sign_consent":"الموافقة على التوقيع الإلكتروني",
|
||||
"agree_and_continue":"الموافقة ومتابعة",
|
||||
"email_address":"عنوان البريد الالكترونى",
|
||||
"agree_to":"من خلال إنشاء حساب فإنك توافق على",
|
||||
"and":"و",
|
||||
"enter_code":"ادخل الرمز",
|
||||
"congratulations":"تهانينا!",
|
||||
"you_now_have_debit_card":"لديك الآن بطاقة ائتمان",
|
||||
"min_amount":"الحد الأدنى: ${value}",
|
||||
"max_amount":"الحد الأقصى: ${value}",
|
||||
"enter_amount":"أدخل المبلغ",
|
||||
"billing_address_info":"إذا طُلب منك عنوان إرسال فواتير ، فأدخل عنوان الشحن الخاص بك",
|
||||
"order_physical_card":"طلب البطاقة المادية",
|
||||
"add_value":"إضافة قيمة",
|
||||
"activate":"تفعيل",
|
||||
"get_a":"احصل على",
|
||||
"digital_and_physical_card":" بطاقة ائتمان رقمية ومادية مسبقة الدفع",
|
||||
"get_card_note":" يمكنك إعادة تحميلها بالعملات الرقمية. لا توجد معلومات إضافية مطلوبة!",
|
||||
"signup_for_card_accept_terms":"قم بالتسجيل للحصول على البطاقة وقبول الشروط.",
|
||||
"add_fund_to_card":"أضف أموالاً مدفوعة مسبقًا إلى البطاقات (حتى ${value})",
|
||||
"use_card_info_two":"يتم تحويل الأموال إلى الدولار الأمريكي عند الاحتفاظ بها في الحساب المدفوع مسبقًا ، وليس بالعملات الرقمية.",
|
||||
"use_card_info_three":"استخدم البطاقة الرقمية عبر الإنترنت أو مع طرق الدفع غير التلامسية.",
|
||||
"optionally_order_card":"اختياريا اطلب بطاقة فعلية (مادية).",
|
||||
"hide_details":"أخف التفاصيل",
|
||||
"show_details":"اظهر التفاصيل",
|
||||
"upto":"حتى ${value}",
|
||||
"discount":"وفر ${value}٪",
|
||||
"gift_card_amount":"مبلغ بطاقة الهدايا",
|
||||
"bill_amount":"مبلغ الفاتورة",
|
||||
"you_pay":"انت تدفع",
|
||||
"tip":"بقشيش:",
|
||||
"custom":"مخصصة",
|
||||
"by_cake_pay":"عن طريق Cake Pay",
|
||||
"expires":"تنتهي",
|
||||
"mm":"MM",
|
||||
"yy":"YY",
|
||||
"online":"متصل",
|
||||
"offline":"غير متصل على الانترنت",
|
||||
"gift_card_number":"رقم بطاقة الهدية",
|
||||
"pin_number":"الرقم السري",
|
||||
"total_saving":"إجمالي المدخرات",
|
||||
"last_30_days":"آخر 30 يومًا",
|
||||
"avg_savings":"متوسط مدخرات",
|
||||
"view_all":"مشاهدة الكل",
|
||||
"active_cards":"البطاقات النشطة",
|
||||
"delete_account":"حذف الحساب",
|
||||
"cards":"البطاقات",
|
||||
"active":"نشيط",
|
||||
"redeemed":"استردت",
|
||||
"gift_card_balance_note":"ستظهر هنا بطاقات الهدايا ذات الرصيد المتبقي",
|
||||
"gift_card_redeemed_note":"ستظهر هنا بطاقات الهدايا التي استردت قيمتها",
|
||||
"logout":"تسجيل خروج",
|
||||
"add_tip":"أضف بقشيش",
|
||||
"percentageOf":"من ${amount}",
|
||||
"is_percentage":"يكون",
|
||||
"search_category":"فئة البحث",
|
||||
"mark_as_redeemed":"وضع علامة كمسترد",
|
||||
"more_options":"المزيد من الخيارات",
|
||||
"awaiting_payment_confirmation":"في انتظار تأكيد الدفع",
|
||||
"transaction_sent_notice":"إذا لم تستمر الشاشة بعد دقيقة واحدة ، فتحقق من مستكشف البلوك والبريد الإلكتروني.",
|
||||
"agree":"موافق",
|
||||
"in_store":"في المتجر",
|
||||
"generating_gift_card":"يتم توليد بطاقة هدية",
|
||||
"payment_was_received":"تم استلام الدفع الخاص بك.",
|
||||
"proceed_after_one_minute":"إذا لم تستمر الشاشة بعد دقيقة واحدة ، فتحقق من بريدك الإلكتروني.",
|
||||
"order_id":"رقم التعريف الخاص بالطلب",
|
||||
"gift_card_is_generated":"تم إنشاء بطاقة الهدايا",
|
||||
"open_gift_card":"افتح بطاقة الهدية",
|
||||
"contact_support":"اتصل بالدعم",
|
||||
"gift_cards_unavailable":"تتوفر بطاقات الهدايا للشراء فقط باستخدام Monero و Bitcoin و Litecoin في الوقت الحالي",
|
||||
"introducing_cake_pay":"نقدم لكم Cake Pay!",
|
||||
"cake_pay_learn_more":"شراء واسترداد بطاقات الهدايا على الفور في التطبيق!\nاسحب من اليسار إلى اليمين لمعرفة المزيد.",
|
||||
"automatic":"تلقائي",
|
||||
"fixed_pair_not_supported":"هذا الزوج الثابت غير مدعوم في التبادلات المحددة",
|
||||
"variable_pair_not_supported":"هذا الزوج المتغير غير مدعوم في التبادلات المحددة",
|
||||
"none_of_selected_providers_can_exchange":"لا يمكن لأي من مقدمي الخدمة المختارين إجراء هذا التبادل",
|
||||
"choose_one":"اختر واحدة",
|
||||
"choose_from_available_options":"اختر من بين الخيارات المتاحة:",
|
||||
"custom_redeem_amount":"مبلغ الاسترداد مخصص",
|
||||
"add_custom_redemption":"إضافة استرداد مخصص",
|
||||
"remaining":"متبقي",
|
||||
"delete_wallet":"حذف المحفظة",
|
||||
"delete_wallet_confirm_message":"هل أنت متأكد أنك تريد حذف محفظة ${wallet_name}؟",
|
||||
"low_fee":"رسوم منخفضة",
|
||||
"low_fee_alert":"أنت تستخدم حاليًا أولوية منخفضة لرسوم الشبكة. قد يتسبب هذا في فترات انتظار طويلة ، أو أسعار مختلفة ، أو إلغاء صفقات. نوصي بتحديد رسوم أعلى لتجربة أفضل.",
|
||||
"ignor":"تجاهل",
|
||||
"use_suggested":"استخدام المقترح",
|
||||
"do_not_share_warning_text":"لا تشارك هذه مع أي شخص آخر ، بما في ذلك الدعم.\n\nيمكن أن تتم سرقة أموالك!",
|
||||
"help":"مساعده",
|
||||
"all_transactions":"كل التحركات المالية",
|
||||
"all_trades":"جميع عمليات التداول",
|
||||
"connection_sync":"الاتصال والمزامنة",
|
||||
"security_and_backup":"الأمان والنسخ الاحتياطي",
|
||||
"create_backup":"انشئ نسخة احتياطية",
|
||||
"privacy_settings":"إعدادات الخصوصية",
|
||||
"privacy":"خصوصية",
|
||||
"display_settings":"اعدادات العرض",
|
||||
"other_settings":"اعدادات اخرى",
|
||||
"require_pin_after":"طلب PIN بعد",
|
||||
"always":"دائماً",
|
||||
"minutes_to_pin_code":"${minutes} دقيقة",
|
||||
"disable_exchange":"تعطيل التبادل",
|
||||
"advanced_privacy_settings":"إعدادات الخصوصية المتقدمة",
|
||||
"settings_can_be_changed_later":"يمكن تغيير هذه الإعدادات لاحقًا في إعدادات التطبيق",
|
||||
"add_custom_node":"إضافة عقدة مخصصة جديدة",
|
||||
"disable_fiat":"تعطيل fiat",
|
||||
"fiat_api":"Fiat API",
|
||||
"disabled":"معطلة",
|
||||
"enabled":"ممكنة",
|
||||
"tor_only":"Tor فقط",
|
||||
"unmatched_currencies": "عملة محفظتك الحالية لا تتطابق مع عملة QR الممسوحة ضوئيًا"
|
||||
}
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Ausgehend",
|
||||
"transactions_by_date" : "Transaktionen nach Datum",
|
||||
"trades" : "Börsen",
|
||||
"filters" : "Filter",
|
||||
"filter_by": "Filtern nach",
|
||||
"today" : "Heute",
|
||||
"yesterday" : "Gestern",
|
||||
"received" : "Empfangen",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "Wallet mit diesem Namen existiert bereits",
|
||||
"market_place": "Marktplatz",
|
||||
"cake_pay_title": "Cake Pay-Geschenkkarten",
|
||||
"cake_pay_subtitle": "Geschenkkarten kaufen und sofort einlösen",
|
||||
"cake_pay_subtitle": "Kaufen Sie ermäßigte Geschenkkarten (nur USA)",
|
||||
"cake_pay_web_cards_title": "Cake Pay-Webkarten",
|
||||
"cake_pay_web_cards_subtitle": "Kaufen Sie weltweit Prepaid-Karten und Geschenkkarten",
|
||||
"about_cake_pay": "Mit Cake Pay können Sie ganz einfach Geschenkkarten mit virtuellen Vermögenswerten kaufen, die Sie sofort bei über 150.000 Händlern in den Vereinigten Staaten ausgeben können.",
|
||||
"cake_pay_account_note": "Melden Sie sich nur mit einer E-Mail-Adresse an, um Karten anzuzeigen und zu kaufen. Einige sind sogar mit Rabatt erhältlich!",
|
||||
"already_have_account": "Sie haben bereits ein Konto?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "Vorgeschlagen verwenden",
|
||||
"do_not_share_warning_text" : "Teilen Sie diese nicht mit anderen, einschließlich Support.\n\nIhr Geld kann und wird gestohlen werden!",
|
||||
"help": "hilfe",
|
||||
"all_transactions": "Alle Transaktionen",
|
||||
"all_trades": "Alle Gewerke",
|
||||
"connection_sync": "Verbindung und Synchronisierung",
|
||||
"security_and_backup": "Sicherheit und Datensicherung",
|
||||
"create_backup": "Backup erstellen",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "Datenschutz",
|
||||
"display_settings": "Anzeigeeinstellungen",
|
||||
"other_settings": "Andere Einstellungen",
|
||||
"require_pin_after": "PIN anfordern nach",
|
||||
"always": "immer",
|
||||
"minutes_to_pin_code": "${minute} Minuten",
|
||||
"disable_exchange": "Exchange deaktivieren",
|
||||
"advanced_privacy_settings": "Erweiterte Datenschutzeinstellungen",
|
||||
"settings_can_be_changed_later": "Diese Einstellungen können später in den App-Einstellungen geändert werden",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "Fiat API",
|
||||
"disabled": "Deaktiviert",
|
||||
"enabled": "Ermöglicht",
|
||||
"tor_only": "Nur Tor"
|
||||
"tor_only": "Nur Tor",
|
||||
"unmatched_currencies": "Die Währung Ihres aktuellen Wallets stimmt nicht mit der des gescannten QR überein",
|
||||
"contact_list_contacts": "Kontakte",
|
||||
"contact_list_wallets": "Meine Geldbörsen"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Outgoing",
|
||||
"transactions_by_date" : "Transactions by date",
|
||||
"trades" : "Trades",
|
||||
"filters" : "Filter",
|
||||
"filter_by": "Filter by",
|
||||
"today" : "Today",
|
||||
"yesterday" : "Yesterday",
|
||||
"received" : "Received",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "A wallet with that name already exists. Please choose a different name or rename the other wallet first.",
|
||||
"market_place": "Marketplace",
|
||||
"cake_pay_title": "Cake Pay Gift Cards",
|
||||
"cake_pay_subtitle": "Buy gift cards and redeem instantly",
|
||||
"cake_pay_subtitle": "Buy discounted gift cards (USA only)",
|
||||
"cake_pay_web_cards_title": "Cake Pay Web Cards",
|
||||
"cake_pay_web_cards_subtitle": "Buy worldwide prepaid cards and gift cards",
|
||||
"about_cake_pay": "Cake Pay allows you to easily buy gift cards with virtual assets, spendable instantly at over 150,000 merchants in the United States.",
|
||||
"cake_pay_account_note": "Sign up with just an email address to see and purchase cards. Some are even available at a discount!",
|
||||
"already_have_account": "Already have an account?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "Use Suggested",
|
||||
"do_not_share_warning_text" : "Do not share these with anyone else, including support.\n\nYour funds can and will be stolen!",
|
||||
"help": "help",
|
||||
"all_transactions": "All transactions",
|
||||
"all_trades": "All trades",
|
||||
"connection_sync": "Connection and sync",
|
||||
"security_and_backup": "Security and backup",
|
||||
"create_backup": "Create backup",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "Privacy",
|
||||
"display_settings": "Display settings",
|
||||
"other_settings": "Other settings",
|
||||
"require_pin_after": "Require PIN after",
|
||||
"always": "Always",
|
||||
"minutes_to_pin_code": "${minute} minutes",
|
||||
"disable_exchange": "Disable exchange",
|
||||
"advanced_privacy_settings": "Advanced Privacy Settings",
|
||||
"settings_can_be_changed_later": "These settings can be changed later in the app settings",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "Fiat API",
|
||||
"disabled": "Disabled",
|
||||
"enabled": "Enabled",
|
||||
"tor_only": "Tor only"
|
||||
"tor_only": "Tor only",
|
||||
"unmatched_currencies": "Your current wallet's currency does not match that of the scanned QR",
|
||||
"contact_list_contacts": "Contacts",
|
||||
"contact_list_wallets": "My Wallets"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Saliente",
|
||||
"transactions_by_date" : "Transacciones por fecha",
|
||||
"trades" : "Cambios",
|
||||
"filters" : "Filtrar",
|
||||
"filter_by": "Filtrado por",
|
||||
"today" : "Hoy",
|
||||
"yesterday" : "Ayer",
|
||||
"received" : "Recibido",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "Wallet con ese nombre ya ha existido",
|
||||
"market_place": "Mercado",
|
||||
"cake_pay_title": "Tarjetas de regalo Cake Pay",
|
||||
"cake_pay_subtitle": "Compra tarjetas de regalo y canjéalas al instante",
|
||||
"cake_pay_subtitle": "Compre tarjetas de regalo con descuento (solo EE. UU.)",
|
||||
"cake_pay_web_cards_title": "Tarjetas Web Cake Pay",
|
||||
"cake_pay_web_cards_subtitle": "Compre tarjetas de prepago y tarjetas de regalo en todo el mundo",
|
||||
"about_cake_pay": "Cake Pay le permite comprar fácilmente tarjetas de regalo con activos virtuales, gastables instantáneamente en más de 150 000 comerciantes en los Estados Unidos.",
|
||||
"cake_pay_account_note": "Regístrese con solo una dirección de correo electrónico para ver y comprar tarjetas. ¡Algunas incluso están disponibles con descuento!",
|
||||
"already_have_account": "¿Ya tienes una cuenta?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "Usar sugerido",
|
||||
"do_not_share_warning_text" : "No comparta estos con nadie más, incluido el soporte.\n\n¡Sus fondos pueden ser y serán robados!",
|
||||
"help": "ayuda",
|
||||
"all_transactions": "Todas las transacciones",
|
||||
"all_trades": "Todos los oficios",
|
||||
"connection_sync": "Conexión y sincronización",
|
||||
"security_and_backup": "Seguridad y respaldo",
|
||||
"create_backup": "Crear copia de seguridad",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "Privacidad",
|
||||
"display_settings": "Configuración de pantalla",
|
||||
"other_settings": "Otras configuraciones",
|
||||
"require_pin_after": "Requerir PIN después de",
|
||||
"always": "siempre",
|
||||
"minutes_to_pin_code": "${minute} minutos",
|
||||
"disable_exchange": "Deshabilitar intercambio",
|
||||
"advanced_privacy_settings": "Configuración avanzada de privacidad",
|
||||
"settings_can_be_changed_later": "Estas configuraciones se pueden cambiar más tarde en la configuración de la aplicación",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "Fiat API",
|
||||
"disabled": "Desactivado",
|
||||
"enabled": "Activado",
|
||||
"tor_only": "solo Tor"
|
||||
"tor_only": "solo Tor",
|
||||
"unmatched_currencies": "La moneda de su billetera actual no coincide con la del QR escaneado",
|
||||
"contact_list_contacts": "Contactos",
|
||||
"contact_list_wallets": "Mis billeteras"
|
||||
}
|
||||
|
|
|
@ -46,7 +46,7 @@
|
|||
"outgoing" : "Sortantes",
|
||||
"transactions_by_date" : "Transactions par date",
|
||||
"trades" : "Échanges",
|
||||
"filters" : "Filtre",
|
||||
"filter_by": "Filtrer par",
|
||||
"today" : "Aujourd'hui",
|
||||
"yesterday" : "Hier",
|
||||
"received" : "Reçus",
|
||||
|
@ -534,10 +534,12 @@
|
|||
"search_currency": "Rechercher une devise",
|
||||
"new_template" : "Nouveau Modèle",
|
||||
"electrum_address_disclaimer": "Nous générons de nouvelles adresses à chaque fois que vous en utilisez une, mais les adresses précédentes continuent à fonctionner",
|
||||
"wallet_name_exists": "Un portefeuille portant ce nom existe déjà",
|
||||
"wallet_name_exists": "Un portefeuille (wallet) portant ce nom existe déjà",
|
||||
"market_place": "Place de marché",
|
||||
"cake_pay_title": "Cartes cadeaux Cake Pay",
|
||||
"cake_pay_subtitle": "Achetez des cartes-cadeaux et échangez-les instantanément",
|
||||
"cake_pay_subtitle": "Achetez des cartes-cadeaux à prix réduit (États-Unis uniquement)",
|
||||
"cake_pay_web_cards_title": "Cartes Web Cake Pay",
|
||||
"cake_pay_web_cards_subtitle": "Achetez des cartes prépayées et des cartes-cadeaux dans le monde entier",
|
||||
"about_cake_pay": "Cake Pay vous permet d'acheter facilement des cartes-cadeaux avec des actifs virtuels, utilisables instantanément chez plus de 150 000 marchands aux États-Unis.",
|
||||
"cake_pay_account_note": "Inscrivez-vous avec juste une adresse e-mail pour voir et acheter des cartes. Certaines sont même disponibles à prix réduit !",
|
||||
"already_have_account": "Vous avez déjà un compte ?",
|
||||
|
@ -560,7 +562,7 @@
|
|||
"cakepay_prepaid_card": "Carte de débit prépayée Cake Pay",
|
||||
"no_id_needed": "Aucune pièce d'identité nécessaire !",
|
||||
"frequently_asked_questions": "Foire aux questions",
|
||||
"debit_card_terms": "Le stockage et l'utilisation de votre numéro de carte de paiement (et des informations d'identification correspondant à votre numéro de carte de paiement) dans ce portefeuille numérique sont soumis aux conditions générales de l'accord du titulaire de carte applicable avec l'émetteur de la carte de paiement, en vigueur à partir de de temps en temps.",
|
||||
"debit_card_terms": "Le stockage et l'utilisation de votre numéro de carte de paiement (et des informations d'identification correspondant à votre numéro de carte de paiement) dans ce portefeuille numérique peuvent être soumis aux conditions générales de l'accord du titulaire de carte parfois en vigueur avec l'émetteur de la carte de paiement.",
|
||||
"please_reference_document": "Veuillez vous référer aux documents ci-dessous pour plus d'informations.",
|
||||
"cardholder_agreement": "Contrat de titulaire de carte",
|
||||
"e_sign_consent": "Consentement de signature électronique",
|
||||
|
@ -593,7 +595,7 @@
|
|||
"gift_card_amount": "Montant de la carte-cadeau",
|
||||
"bill_amount": "Montant de la facture",
|
||||
"you_pay": "Vous payez",
|
||||
"tip": "Astuce :",
|
||||
"tip": "Pourboire :",
|
||||
"custom": "personnalisé",
|
||||
"by_cake_pay": "par Cake Pay",
|
||||
"expire": "Expire",
|
||||
|
@ -615,7 +617,7 @@
|
|||
"gift_card_balance_note": "Les cartes-cadeaux avec un solde restant apparaîtront ici",
|
||||
"gift_card_redeemed_note": "Les cartes-cadeaux que vous avez utilisées apparaîtront ici",
|
||||
"logout": "Déconnexion",
|
||||
"add_tip": "Ajouter une astuce",
|
||||
"add_tip": "Ajouter un pourboire",
|
||||
"percentageOf": "sur ${amount}",
|
||||
"is_percentage": "est",
|
||||
"search_category": "Catégorie de recherche",
|
||||
|
@ -644,14 +646,16 @@
|
|||
"custom_redeem_amount": "Montant d'échange personnalisé",
|
||||
"add_custom_redemption": "Ajouter un remboursement personnalisé",
|
||||
"remaining": "restant",
|
||||
"delete_wallet": "Supprimer le portefeuille",
|
||||
"delete_wallet_confirm_message" : "Êtes-vous sûr de vouloir supprimer le portefeuille ${wallet_name}?",
|
||||
"delete_wallet": "Supprimer le portefeuille (wallet)",
|
||||
"delete_wallet_confirm_message" : "Êtes-vous sûr de vouloir supprimer le portefeuille (wallet) ${wallet_name}?",
|
||||
"low_fee": "Frais modiques",
|
||||
"low_fee_alert": "Vous utilisez actuellement une priorité de frais de réseau peu élevés. Cela pourrait entraîner de longues attentes, des taux différents ou des transactions annulées. Nous vous recommandons de fixer des frais plus élevés pour une meilleure expérience.",
|
||||
"ignor": "Ignorer",
|
||||
"use_suggested": "Utilisation suggérée",
|
||||
"do_not_share_warning_text" : "Ne les partagez avec personne d'autre, y compris avec l'assistance.\n\nVos fonds peuvent et seront volés!",
|
||||
"help": "aider",
|
||||
"do_not_share_warning_text" : "Ne les partagez avec personne, y compris avec l'assistance.\n\nVos fonds seraient inmanquablement volés !",
|
||||
"help": "aide",
|
||||
"all_transactions": "Toutes transactions",
|
||||
"all_trades": "Tous échanges",
|
||||
"connection_sync": "Connexion et synchronisation",
|
||||
"security_and_backup": "Sécurité et sauvegarde",
|
||||
"create_backup": "Créer une sauvegarde",
|
||||
|
@ -659,13 +663,19 @@
|
|||
"privacy": "Confidentialité",
|
||||
"display_settings": "Paramètres d'affichage",
|
||||
"other_settings": "Autres paramètres",
|
||||
"require_pin_after": "Code PIN requis après",
|
||||
"always": "toujours",
|
||||
"minutes_to_pin_code": "${minute} minutes",
|
||||
"disable_exchange": "Désactiver l'échange",
|
||||
"advanced_privacy_settings": "Paramètres de confidentialité avancés",
|
||||
"settings_can_be_changed_later": "Ces paramètres peuvent être modifiés ultérieurement dans les paramètres de l'application",
|
||||
"add_custom_node": "Ajouter un nouveau nœud personnalisé",
|
||||
"disable_fiat": "Désactiver fiat",
|
||||
"disable_fiat": "Désactiver les montants en fiat",
|
||||
"fiat_api": "Fiat API",
|
||||
"disabled": "Handicapé",
|
||||
"disabled": "Désactivé",
|
||||
"enabled": "Activé",
|
||||
"tor_only": "Tor uniquement"
|
||||
"tor_only": "Tor uniquement",
|
||||
"unmatched_currencies": "La devise de votre portefeuille (wallet) actuel ne correspond pas à celle du QR code scanné",
|
||||
"contact_list_contacts": "Contacts",
|
||||
"contact_list_wallets": "Mes portefeuilles (wallets)"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "निवर्तमान",
|
||||
"transactions_by_date" : "तारीख से लेन-देन",
|
||||
"trades" : "ट्रेडों",
|
||||
"filters" : "फ़िल्टर",
|
||||
"filter_by": "के द्वारा छनित",
|
||||
"today" : "आज",
|
||||
"yesterday" : "बिता कल",
|
||||
"received" : "प्राप्त किया",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "उस नाम वाला वॉलेट पहले से मौजूद है",
|
||||
"market_place": "मार्केटप्लेस",
|
||||
"cake_pay_title": "केक पे गिफ्ट कार्ड्स",
|
||||
"cake_pay_subtitle": "उपहार कार्ड खरीदें और तुरंत रिडीम करें",
|
||||
"cake_pay_subtitle": "रियायती उपहार कार्ड खरीदें (केवल यूएसए)",
|
||||
"cake_pay_web_cards_title": "केक भुगतान वेब कार्ड",
|
||||
"cake_pay_web_cards_subtitle": "दुनिया भर में प्रीपेड कार्ड और गिफ्ट कार्ड खरीदें",
|
||||
"about_cake_pay": "केक पे आपको वर्चुअल संपत्ति के साथ आसानी से उपहार कार्ड खरीदने की अनुमति देता है, जिसे संयुक्त राज्य में 150,000 से अधिक व्यापारियों पर तुरंत खर्च किया जा सकता है।",
|
||||
"cake_pay_account_note": "कार्ड देखने और खरीदने के लिए केवल एक ईमेल पते के साथ साइन अप करें। कुछ छूट पर भी उपलब्ध हैं!",
|
||||
"ready_have_account": "क्या आपके पास पहले से ही एक खाता है?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "सुझाए गए का प्रयोग करें",
|
||||
"do_not_share_warning_text" : "समर्थन सहित, इन्हें किसी और के साथ साझा न करें।\n\nआपके धन की चोरी हो सकती है और होगी!",
|
||||
"help": "मदद करना",
|
||||
"all_transactions": "सभी लेन - देन",
|
||||
"all_trades": "सभी व्यापार",
|
||||
"connection_sync": "कनेक्शन और सिंक",
|
||||
"security_and_backup": "सुरक्षा और बैकअप",
|
||||
"create_backup": "बैकअप बनाएँ",
|
||||
|
@ -661,13 +665,19 @@
|
|||
"privacy": "गोपनीयता",
|
||||
"display_settings": "प्रदर्शन सेटिंग्स",
|
||||
"other_settings": "अन्य सेटिंग्स",
|
||||
"require_pin_after": "इसके बाद पिन आवश्यक है",
|
||||
"always": "हमेशा",
|
||||
"minutes_to_pin_code": "${minute} मिनट",
|
||||
"disable_exchange": "एक्सचेंज अक्षम करें",
|
||||
"advanced_privacy_settings": "उन्नत गोपनीयता सेटिंग्स",
|
||||
"settings_can_be_changed_later": "इन सेटिंग्स को बाद में ऐप सेटिंग में बदला जा सकता है",
|
||||
"add_custom_node": "नया कस्टम नोड जोड़ें",
|
||||
"disable_exchange": "एक्सचेंज अक्षम करें",
|
||||
"disable_fiat": "िएट को अक्षम करें",
|
||||
"fiat_api": "फिएट पैसे API",
|
||||
"disabled": "अक्षम",
|
||||
"enabled": "सक्रिय",
|
||||
"tor_only": "Tor केवल"
|
||||
"tor_only": "Tor केवल",
|
||||
"unmatched_currencies": "आपके वर्तमान वॉलेट की मुद्रा स्कैन किए गए क्यूआर से मेल नहीं खाती" ,
|
||||
"contact_list_contacts": "संपर्क",
|
||||
"contact_list_wallets": "मेरा बटुआ"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Odlazno",
|
||||
"transactions_by_date" : "Transakcije prema datumu",
|
||||
"trades" : "Razmjene",
|
||||
"filters" : "Filter",
|
||||
"filter_by": "Filtrirati po",
|
||||
"today" : "Danas",
|
||||
"yesterday" : "Jučer",
|
||||
"received" : "Primljeno",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "Novčanik s tim nazivom već postoji",
|
||||
"market_place": "Tržnica",
|
||||
"cake_pay_title": "Cake Pay poklon kartice",
|
||||
"cake_pay_subtitle": "Kupite darovne kartice i odmah ih iskoristite",
|
||||
"cake_pay_subtitle": "Kupite darovne kartice s popustom (samo SAD)",
|
||||
"cake_pay_web_cards_title": "Cake Pay Web kartice",
|
||||
"cake_pay_web_cards_subtitle": "Kupujte prepaid kartice i poklon kartice diljem svijeta",
|
||||
"about_cake_pay": "Cake Pay vam omogućuje jednostavnu kupnju darovnih kartica s virtualnim sredstvima, koja se trenutno mogu potrošiti kod više od 150 000 trgovaca u Sjedinjenim Državama.",
|
||||
"cake_pay_account_note": "Prijavite se samo s adresom e-pošte da biste vidjeli i kupili kartice. Neke su čak dostupne uz popust!",
|
||||
"already_have_account": "Već imate račun?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "Koristite predloženo",
|
||||
"do_not_share_warning_text" : "Nemojte ih dijeliti ni s kim, uključujući podršku.\n\nVaša sredstva mogu i bit će ukradena!",
|
||||
"help": "pomozite",
|
||||
"all_transactions": "Sve transakcije",
|
||||
"all_trades": "Svi obrti",
|
||||
"connection_sync": "Povezivanje i sinkronizacija",
|
||||
"security_and_backup": "Sigurnost i sigurnosna kopija",
|
||||
"create_backup": "Stvori sigurnosnu kopiju",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "Privatnost",
|
||||
"display_settings": "Postavke zaslona",
|
||||
"other_settings": "Ostale postavke",
|
||||
"require_pin_after": "Zahtijevaj PIN nakon",
|
||||
"always": "Uvijek",
|
||||
"minutes_to_pin_code": "${minute} minuta",
|
||||
"disable_exchange": "Onemogući exchange",
|
||||
"advanced_privacy_settings": "Napredne postavke privatnosti",
|
||||
"settings_can_be_changed_later": "Te se postavke mogu promijeniti kasnije u postavkama aplikacije",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "Fiat API",
|
||||
"disabled": "Onemogućeno",
|
||||
"enabled": "Omogućeno",
|
||||
"tor_only": "Samo Tor"
|
||||
"tor_only": "Samo Tor",
|
||||
"unmatched_currencies": "Valuta vašeg trenutnog novčanika ne odgovara onoj na skeniranom QR-u",
|
||||
"contact_list_contacts": "Kontakti",
|
||||
"contact_list_wallets": "Moji novčanici"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "In uscita",
|
||||
"transactions_by_date" : "Transazioni per data",
|
||||
"trades" : "Scambi",
|
||||
"filters" : "Filtri",
|
||||
"filter_by": "Filtrirati po",
|
||||
"today" : "Oggi",
|
||||
"yesterday" : "Ieri",
|
||||
"received" : "Ricevuto",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "Il portafoglio con quel nome è già esistito",
|
||||
"market_place": "Mercato",
|
||||
"cake_pay_title": "Carte regalo Cake Pay",
|
||||
"cake_pay_subtitle": "Acquista carte regalo e riscattale all'istante",
|
||||
"cake_pay_subtitle": "Acquista buoni regalo scontati (solo USA)",
|
||||
"cake_pay_web_cards_title": "Carte Web Cake Pay",
|
||||
"cake_pay_web_cards_subtitle": "Acquista carte prepagate e carte regalo in tutto il mondo",
|
||||
"about_cake_pay": "Cake Pay ti consente di acquistare facilmente buoni regalo con asset virtuali, spendibili istantaneamente presso oltre 150.000 commercianti negli Stati Uniti.",
|
||||
"cake_pay_account_note": "Iscriviti con solo un indirizzo email per vedere e acquistare le carte. Alcune sono anche disponibili con uno sconto!",
|
||||
"already_have_account": "Hai già un account?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "Usa suggerito",
|
||||
"do_not_share_warning_text" : "Non condividerli con nessun altro, incluso il supporto.\n\nI tuoi fondi possono e saranno rubati!",
|
||||
"help": "aiuto",
|
||||
"all_transactions": "Sve transakcije",
|
||||
"all_trades": "Svi obrti",
|
||||
"connection_sync": "Connessione e sincronizzazione",
|
||||
"security_and_backup": "Sicurezza e backup",
|
||||
"create_backup": "Crea backup",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "Privacy",
|
||||
"display_settings": "Impostazioni di visualizzazione",
|
||||
"other_settings": "Altre impostazioni",
|
||||
"require_pin_after": "Richiedi PIN dopo",
|
||||
"always": "sempre",
|
||||
"minutes_to_pin_code": "${minute} minuti",
|
||||
"disable_exchange": "Disabilita scambio",
|
||||
"advanced_privacy_settings": "Impostazioni avanzate sulla privacy",
|
||||
"settings_can_be_changed_later": "Queste impostazioni possono essere modificate in seguito nelle impostazioni dell'app",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "Fiat API",
|
||||
"disabled": "Disabilitato",
|
||||
"enabled": "Abilitato",
|
||||
"tor_only": "Solo Tor"
|
||||
"tor_only": "Solo Tor",
|
||||
"unmatched_currencies": "La valuta del tuo portafoglio attuale non corrisponde a quella del QR scansionato",
|
||||
"contact_list_contacts": "Contatti",
|
||||
"contact_list_wallets": "I miei portafogli"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "発信",
|
||||
"transactions_by_date" : "日付ごとの取引",
|
||||
"trades" : "取引",
|
||||
"filters" : "フィルタ",
|
||||
"filter_by": "でフィルタリング",
|
||||
"today" : "今日",
|
||||
"yesterday" : "昨日",
|
||||
"received" : "受け取った",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "その名前のウォレットはすでに存在しています",
|
||||
"market_place": "Marketplace",
|
||||
"cake_pay_title": "ケーキペイギフトカード",
|
||||
"cake_pay_subtitle": "ギフトカードを購入してすぐに利用できます",
|
||||
"cake_pay_subtitle": "割引ギフトカードを購入する (米国のみ)",
|
||||
"cake_pay_web_cards_title": "Cake Pay ウェブカード",
|
||||
"cake_pay_web_cards_subtitle": "世界中のプリペイド カードとギフト カードを購入する",
|
||||
"about_cake_pay": "Cake Payを使用すると、仮想資産を含むギフトカードを簡単に購入でき、米国内の150,000を超える加盟店ですぐに利用できます。",
|
||||
"cake_pay_account_note": "メールアドレスだけでサインアップして、カードを表示して購入できます。割引価格で利用できるカードもあります!",
|
||||
"already_have_account": "すでにアカウントをお持ちですか?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "推奨を使用",
|
||||
"do_not_share_warning_text" : "サポートを含め、これらを他の誰とも共有しないでください。\n\nあなたの資金は盗まれる可能性があります!",
|
||||
"help": "ヘルプ",
|
||||
"all_transactions": "全取引",
|
||||
"all_trades": "すべての取引",
|
||||
"connection_sync": "接続と同期",
|
||||
"security_and_backup": "セキュリティとバックアップ",
|
||||
"create_backup": "バックアップを作成",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "プライバシー",
|
||||
"display_settings": "表示設定",
|
||||
"other_settings": "その他の設定",
|
||||
"require_pin_after": "後に PIN が必要",
|
||||
"always": "いつも",
|
||||
"minutes_to_pin_code": "${minute} 分",
|
||||
"disable_exchange": "交換を無効にする",
|
||||
"advanced_privacy_settings": "高度なプライバシー設定",
|
||||
"settings_can_be_changed_later": "これらの設定は、後でアプリの設定で変更できます",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "不換紙幣 API",
|
||||
"disabled": "無効",
|
||||
"enabled": "有効",
|
||||
"tor_only": "Torのみ"
|
||||
"tor_only": "Torのみ",
|
||||
"unmatched_currencies": "現在のウォレットの通貨がスキャンされたQRの通貨と一致しません",
|
||||
"contact_list_contacts": "連絡先",
|
||||
"contact_list_wallets": "マイウォレット"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "나가는",
|
||||
"transactions_by_date" : "날짜 별 거래",
|
||||
"trades" : "거래",
|
||||
"filters" : "필터",
|
||||
"filter_by": "필터링 기준",
|
||||
"today" : "오늘",
|
||||
"yesterday" : "어제",
|
||||
"received" : "받았습니다",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "해당 이름의 지갑이 이미 존재합니다.",
|
||||
"market_place": "마켓플레이스",
|
||||
"cake_pay_title": "케이크 페이 기프트 카드",
|
||||
"cake_pay_subtitle": "기프트 카드를 구매하고 즉시 사용",
|
||||
"cake_pay_subtitle": "할인된 기프트 카드 구매(미국만 해당)",
|
||||
"cake_pay_web_cards_title": "케이크페이 웹카드",
|
||||
"cake_pay_web_cards_subtitle": "전 세계 선불 카드 및 기프트 카드 구매",
|
||||
"about_cake_pay": "Cake Pay를 사용하면 미국 내 150,000개 이상의 가맹점에서 즉시 사용할 수 있는 가상 자산이 포함된 기프트 카드를 쉽게 구입할 수 있습니다.",
|
||||
"cake_pay_account_note": "이메일 주소로 가입하면 카드를 보고 구매할 수 있습니다. 일부는 할인된 가격으로 사용 가능합니다!",
|
||||
"already_have_account": "이미 계정이 있습니까?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "추천 사용",
|
||||
"do_not_share_warning_text" : "지원을 포함하여 다른 사람과 이러한 정보를 공유하지 마십시오.\n\n귀하의 자금은 도난당할 수 있고 도난당할 수 있습니다!",
|
||||
"help": "돕다",
|
||||
"all_transactions": "모든 거래 창구",
|
||||
"all_trades": "A모든 거래",
|
||||
"connection_sync": "연결 및 동기화",
|
||||
"security_and_backup": "보안 및 백업",
|
||||
"create_backup": "백업 생성",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "프라이버시",
|
||||
"display_settings": "디스플레이 설정",
|
||||
"other_settings": "기타 설정",
|
||||
"require_pin_after": "다음 이후에 PIN 필요",
|
||||
"always": "언제나",
|
||||
"minutes_to_pin_code": "${minute}분",
|
||||
"disable_exchange": "교환 비활성화",
|
||||
"advanced_privacy_settings": "고급 개인 정보 설정",
|
||||
"settings_can_be_changed_later": "이 설정은 나중에 앱 설정에서 변경할 수 있습니다.",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "명목 화폐 API",
|
||||
"disabled": "장애가 있는",
|
||||
"enabled": "사용",
|
||||
"tor_only": "Tor 뿐"
|
||||
"tor_only": "Tor 뿐",
|
||||
"unmatched_currencies": "현재 지갑의 통화가 스캔한 QR의 통화와 일치하지 않습니다.",
|
||||
"contact_list_contacts": "콘택트 렌즈",
|
||||
"contact_list_wallets": "내 지갑"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Uitgaande",
|
||||
"transactions_by_date" : "Transacties op datum",
|
||||
"trades" : "Trades",
|
||||
"filters" : "Filter",
|
||||
"filter_by": "Filteren op",
|
||||
"today" : "Vandaag",
|
||||
"yesterday" : "Gisteren",
|
||||
"received" : "Ontvangen",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "Portemonnee met die naam bestaat al",
|
||||
"market_place": "Marktplaats",
|
||||
"cake_pay_title": "Cake Pay-cadeaubonnen",
|
||||
"cake_pay_subtitle": "Koop cadeaubonnen en wissel ze direct in",
|
||||
"cake_pay_subtitle": "Koop cadeaubonnen met korting (alleen VS)",
|
||||
"cake_pay_web_cards_title": "Cake Pay-webkaarten",
|
||||
"cake_pay_web_cards_subtitle": "Koop wereldwijd prepaidkaarten en cadeaubonnen",
|
||||
"about_cake_pay": "Met Cake Pay kunt u eenvoudig cadeaubonnen kopen met virtuele activa, die direct kunnen worden uitgegeven bij meer dan 150.000 handelaren in de Verenigde Staten.",
|
||||
"cake_pay_account_note": "Meld u aan met alleen een e-mailadres om kaarten te bekijken en te kopen. Sommige zijn zelfs met korting verkrijgbaar!",
|
||||
"already_have_account": "Heb je al een account?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "Gebruik aanbevolen",
|
||||
"do_not_share_warning_text" : "Deel deze met niemand anders, ook niet met support.\n\nUw geld kan en zal worden gestolen!",
|
||||
"help": "helpen",
|
||||
"all_transactions": "Alle transacties",
|
||||
"all_trades": "Alle transacties",
|
||||
"connection_sync": "Verbinding en synchronisatie",
|
||||
"security_and_backup": "Beveiliging en back-up",
|
||||
"create_backup": "Maak een back-up",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "Privacy",
|
||||
"display_settings": "Weergave-instellingen",
|
||||
"other_settings": "Andere instellingen",
|
||||
"require_pin_after": "Pincode vereist na",
|
||||
"always": "altijd",
|
||||
"minutes_to_pin_code": "${minute} minuten",
|
||||
"disable_exchange": "Uitwisseling uitschakelen",
|
||||
"advanced_privacy_settings": "Geavanceerde privacy-instellingen",
|
||||
"settings_can_be_changed_later": "Deze instellingen kunnen later worden gewijzigd in de app-instellingen",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "Fiat API",
|
||||
"disabled": "Gehandicapt",
|
||||
"enabled": "Ingeschakeld",
|
||||
"tor_only": "Alleen Tor"
|
||||
"tor_only": "Alleen Tor",
|
||||
"unmatched_currencies": "De valuta van uw huidige portemonnee komt niet overeen met die van de gescande QR",
|
||||
"contact_list_contacts": "Contacten",
|
||||
"contact_list_wallets": "Mijn portefeuilles"
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
"welcome" : "Witamy w",
|
||||
"cake_wallet" : "Cake Wallet",
|
||||
"first_wallet_text" : "Świetny portfel na Monero, Bitcoin, Litecoin, i Haven",
|
||||
"please_make_selection" : "Wybierz poniżej, aby cutwórz lub odzyskaj swój portfel.",
|
||||
"please_make_selection" : "Wybierz poniżej, aby utworzyć lub przywrócić swój portfel.",
|
||||
"create_new" : "Utwórz nowy portfel",
|
||||
"restore_wallet" : "Przywróć portfel",
|
||||
|
||||
|
@ -13,90 +13,90 @@
|
|||
"haven_app_wallet_text": "Awesome wallet for Haven",
|
||||
|
||||
"accounts" : "Konta",
|
||||
"edit" : "Edytować",
|
||||
"edit" : "Edytuj",
|
||||
"account" : "Konto",
|
||||
"add" : "Dodaj",
|
||||
|
||||
|
||||
"address_book" : "Książka adresowa",
|
||||
"address_book" : "Kontakty",
|
||||
"contact" : "Kontakt",
|
||||
"please_select" : "Proszę wybrać:",
|
||||
"cancel" : "Anulować",
|
||||
"ok" : "Dobrze",
|
||||
"cancel" : "Anuluj",
|
||||
"ok" : "Ok",
|
||||
"contact_name" : "Nazwa Kontaktu",
|
||||
"reset" : "Nastawić",
|
||||
"save" : "Zapisać",
|
||||
"reset" : "Wyczyść",
|
||||
"save" : "Zapisz",
|
||||
"address_remove_contact" : "Usuń kontakt",
|
||||
"address_remove_content" : "Czy na pewno chcesz usunąć wybrany kontakt?",
|
||||
|
||||
|
||||
"authenticated" : "Zalegalizowany",
|
||||
"authentication" : "Poświadczenie",
|
||||
"authenticated" : "Uwierzytelniony",
|
||||
"authentication" : "Uwierzytelnianie",
|
||||
"failed_authentication" : "Nieudane uwierzytelnienie. ${state_error}",
|
||||
|
||||
|
||||
"wallet_menu" : "Menu portfela",
|
||||
"Blocks_remaining" : "${status} Bloki pozostałe",
|
||||
"Blocks_remaining" : "Pozostało ${status} bloków",
|
||||
"please_try_to_connect_to_another_node" : "Spróbuj połączyć się z innym węzłem",
|
||||
"xmr_hidden" : "Ukryty",
|
||||
"xmr_available_balance" : "Dostępne saldo",
|
||||
"xmr_full_balance" : "Pełna równowaga",
|
||||
"send" : "Wysłać",
|
||||
"receive" : "Otrzymać",
|
||||
"xmr_available_balance" : "Dostępne środki",
|
||||
"xmr_full_balance" : "Pełne saldo",
|
||||
"send" : "Wyślij",
|
||||
"receive" : "Otrzymaj",
|
||||
"transactions" : "Transakcje",
|
||||
"incoming" : "Przychodzące",
|
||||
"outgoing" : "Towarzyski",
|
||||
"outgoing" : "Wychodzące",
|
||||
"transactions_by_date" : "Transakcje według daty",
|
||||
"trades" : "Transakcje",
|
||||
"filters" : "Filtr",
|
||||
"filter_by": "Filtruj według",
|
||||
"today" : "Dzisiaj",
|
||||
"yesterday" : "Wczoraj",
|
||||
"received" : "Odebrane",
|
||||
"sent" : "Wysłano",
|
||||
"pending" : " (w oczekiwaniu)",
|
||||
"rescan" : "Skanuj ponownie",
|
||||
"reconnect" : "Na nowo połączyć",
|
||||
"reconnect" : "Połącz ponownie",
|
||||
"wallets" : "Portfele",
|
||||
"show_seed" : "Pokaż nasiona",
|
||||
"show_keys" : "Pokaż nasiona/klucze",
|
||||
"address_book_menu" : "Książka adresowa",
|
||||
"reconnection" : "Ponowne połączenie",
|
||||
"reconnect_alert_text" : "Czy na pewno ponownie się połączysz?",
|
||||
"show_seed" : "Pokaż frazy seed",
|
||||
"show_keys" : "Pokaż seed/klucze",
|
||||
"address_book_menu" : "Kontakty",
|
||||
"reconnection" : "Ponowne łączenie",
|
||||
"reconnect_alert_text" : "Czy na pewno ponownie się ponownie połączysz?",
|
||||
|
||||
|
||||
"exchange" : "Wymieniać się",
|
||||
"exchange" : "Wymień",
|
||||
"clear" : "Wyczyść",
|
||||
"refund_address" : "Adres zwrotu",
|
||||
"change_exchange_provider" : "Zmień dostawcę programu Exchange",
|
||||
"refund_address" : "Adres do zwrotu",
|
||||
"change_exchange_provider" : "Zmień dostawcę wymiany",
|
||||
"you_will_send" : "Konwertuj z",
|
||||
"you_will_get" : "Konwertuj na",
|
||||
"amount_is_guaranteed" : "Otrzymana kwota jest gwarantowana",
|
||||
"amount_is_estimate" : "Otrzymana kwota jest wartością szacunkową",
|
||||
"powered_by" : "Zasilany przez ${title}",
|
||||
"powered_by" : "Obsługiwane przez ${title}",
|
||||
"error" : "Błąd",
|
||||
"estimated" : "Oszacowano",
|
||||
"min_value" : "Min: ${value} ${currency}",
|
||||
"max_value" : "Max: ${value} ${currency}",
|
||||
"change_currency" : "Change Currency",
|
||||
"overwrite_amount" : "Overwrite amount",
|
||||
"qr_payment_amount" : "This QR code contains a payment amount. Do you want to overwrite the current value?",
|
||||
"change_currency" : "Zmień walutę",
|
||||
"overwrite_amount" : "Nadpisz ilość",
|
||||
"qr_payment_amount" : "Ten kod QR zawiera kwotę do zapłaty. Czy chcesz nadpisać obecną wartość?",
|
||||
|
||||
"copy_id" : "ID kopii",
|
||||
"exchange_result_write_down_trade_id" : "Skopiuj lub zanotuj identyfikator transakcji, aby kontynuować.",
|
||||
"trade_id" : "Identyfikator handlu:",
|
||||
"copied_to_clipboard" : "Skopiowane do schowka",
|
||||
"copy_id" : "skopiuj ID",
|
||||
"exchange_result_write_down_trade_id" : "Skopiuj lub zanotuj identyfikator transakcji (ID), aby kontynuować.",
|
||||
"trade_id" : "ID transakcji:",
|
||||
"copied_to_clipboard" : "Skopiowano do schowka",
|
||||
"saved_the_trade_id" : "Zapisałem ID",
|
||||
"fetching" : "Ujmujący",
|
||||
"fetching" : "Pobieranie",
|
||||
"id" : "ID: ",
|
||||
"amount" : "Ilość: ",
|
||||
"payment_id" : "Płatności ID: ",
|
||||
"payment_id" : "ID Płatności: ",
|
||||
"status" : "Status: ",
|
||||
"offer_expires_in" : "Oferta wygasa za ",
|
||||
"trade_is_powered_by" : "Ten handel jest zasilany przez ${provider}",
|
||||
"trade_is_powered_by" : "Ta wymiana jest obsługiwana przez ${provider}",
|
||||
"copy_address" : "Skopiuj adress",
|
||||
"exchange_result_confirm" : "Naciskając Potwierdź, wyślesz ${fetchingLabel} ${from} z twojego portfela ${walletName} na adres podany poniżej. Lub możesz wysłać z zewnętrznego portfela na poniższy adres / kod QR.\n\nNaciśnij Potwierdź, aby kontynuować lub wróć, aby zmienić kwoty.",
|
||||
"exchange_result_description" : "Musisz wysłać co najmniej ${fetchingLabel} ${from} na adres podany na następnej stronie. Jeśli wyślesz kwotę niższą niż ${fetchingLabel} ${from}, może ona nie zostać przeliczona i może nie zostać zwrócona.",
|
||||
"exchange_result_write_down_ID" : "*Skopiuj lub zanotuj swój identyfikator pokazany powyżej.",
|
||||
"exchange_result_description" : "Musisz wysłać co najmniej ${fetchingLabel} ${from} na adres podany na następnej stronie. Jeśli wyślesz kwotę niższą niż ${fetchingLabel} ${from}, może ona nie zostać uwzględniona i może nie zostać zwrócona.",
|
||||
"exchange_result_write_down_ID" : "*Skopiuj lub zanotuj identyfikator transakcji pokazany powyżej.",
|
||||
"confirm" : "Potwierdzać",
|
||||
"confirm_sending" : "Potwierdź wysłanie",
|
||||
"commit_transaction_amount_fee" : "Zatwierdź transakcję\nIlość: ${amount}\nOpłata: ${fee}",
|
||||
|
@ -104,13 +104,13 @@
|
|||
"transaction_sent" : "Transakcja wysłana!",
|
||||
"expired" : "Przedawniony",
|
||||
"time" : "${minutes}m ${seconds}s",
|
||||
"send_xmr" : "Wysłać XMR",
|
||||
"exchange_new_template" : "Nowy szablon",
|
||||
"send_xmr" : "Wyślij XMR",
|
||||
"exchange_new_template" : "Nowy szablon wymiany",
|
||||
|
||||
"faq" : "FAQ",
|
||||
|
||||
|
||||
"enter_your_pin" : "Wpisz Twój kod PIN",
|
||||
"enter_your_pin" : "Wpisz kod PIN",
|
||||
"loading_your_wallet" : "Ładowanie portfela",
|
||||
|
||||
|
||||
|
@ -123,17 +123,17 @@
|
|||
"node_new" : "Nowy węzeł",
|
||||
"node_address" : "Adres węzła",
|
||||
"node_port" : "Port węzła",
|
||||
"login" : "Zaloguj Się",
|
||||
"login" : "Login",
|
||||
"password" : "Hasło",
|
||||
"nodes" : "Węzły",
|
||||
"node_reset_settings_title" : "Resetowanie ustawień",
|
||||
"node_reset_settings_title" : "Zresetuj ustawienia węzłów",
|
||||
"nodes_list_reset_to_default_message" : "Czy na pewno chcesz przywrócić ustawienia domyślne?",
|
||||
"change_current_node" : "Czy na pewno chcesz przywrócić ustawienia domyślne? ${node}?",
|
||||
"change" : "Zmiana",
|
||||
"change_current_node" : "Czy na pewno chcesz wybrać ten węzeł? ${node}?",
|
||||
"change" : "Zmień",
|
||||
"remove_node" : "Usuń węzeł",
|
||||
"remove_node_message" : "Czy na pewno chcesz usunąć wybrany węzeł?",
|
||||
"remove" : "Usunąć",
|
||||
"delete" : "Kasować",
|
||||
"remove" : "Usuń",
|
||||
"delete" : "Skasuj",
|
||||
"add_new_node" : "Dodaj nowy węzeł",
|
||||
"change_current_node_title" : "Zmień bieżący węzeł",
|
||||
"node_test" : "Test",
|
||||
|
@ -142,8 +142,8 @@
|
|||
"new_node_testing" : "Testowanie nowych węzłów",
|
||||
|
||||
|
||||
"use" : "Używać ",
|
||||
"digit_pin" : "-znak PIN",
|
||||
"use" : "Użyj ",
|
||||
"digit_pin" : "-znakowy PIN",
|
||||
|
||||
|
||||
"share_address" : "Udostępnij adres",
|
||||
|
@ -152,46 +152,46 @@
|
|||
"addresses" : "Adresy",
|
||||
"scan_qr_code" : "Zeskanuj kod QR, aby uzyskać adres",
|
||||
"qr_fullscreen" : "Dotknij, aby otworzyć pełnoekranowy kod QR",
|
||||
"rename" : "Przemianować",
|
||||
"rename" : "Zmień nazwę",
|
||||
"choose_account" : "Wybierz konto",
|
||||
"create_new_account" : "Stwórz nowe konto",
|
||||
"accounts_subaddresses" : "Konta i podadresy",
|
||||
|
||||
|
||||
"restore_restore_wallet" : "Przywróć portfel",
|
||||
"restore_title_from_seed_keys" : "Przywróć z nasion / kluczy",
|
||||
"restore_description_from_seed_keys" : "Odzyskaj swój portfel z nasion / kluczy, które zapisałeś w bezpiecznym miejscu",
|
||||
"restore_title_from_seed_keys" : "Przywróć z seedów / kluczy",
|
||||
"restore_description_from_seed_keys" : "Odzyskaj swój portfel z seedów / kluczy, które zapisałeś w bezpiecznym miejscu",
|
||||
"restore_next" : "Kolejny",
|
||||
"restore_title_from_backup" : "Przywróć z pliku kopii zapasowej",
|
||||
"restore_description_from_backup" : "Możesz przywrócić całą aplikację Cake Wallet z plik kopii zapasowej",
|
||||
"restore_seed_keys_restore" : "Przywracanie nasion / kluczy",
|
||||
"restore_title_from_seed" : "Przywróć z nasion",
|
||||
"restore_description_from_seed" : "Przywróć swój portfel z 25 słów lub 13-słowny kod kombinacji",
|
||||
"restore_description_from_backup" : "Możesz przywrócić całą aplikację Cake Wallet z pliku kopii zapasowej",
|
||||
"restore_seed_keys_restore" : "Przywracanie seedów / kluczy",
|
||||
"restore_title_from_seed" : "Przywróć z seedów",
|
||||
"restore_description_from_seed" : "Przywróć swój portfel z 25 lub 13-słownej frazy seed",
|
||||
"restore_title_from_keys" : "Przywróć z kluczy",
|
||||
"restore_description_from_keys" : "Przywróć swój portfel z wygenerowanego naciśnięcia klawiszy zapisane z kluczy prywatnych",
|
||||
"restore_description_from_keys" : "Przywróć swój portfel z kluczy prywatnych",
|
||||
"restore_wallet_name" : "Nazwa portfela",
|
||||
"restore_address" : "Adres",
|
||||
"restore_view_key_private" : "Wyświetl klucz (prywatny)",
|
||||
"restore_spend_key_private" : "Wydaj klucz (prywatny)",
|
||||
"restore_recover" : "Wyzdrowieć",
|
||||
"restore_wallet_restore_description" : "Opis przywracania portfela",
|
||||
"restore_new_seed" : "Nowe nasienie",
|
||||
"restore_active_seed" : "Aktywne nasiona",
|
||||
"restore_bitcoin_description_from_seed" : "Przywróć swój portfel z kodu złożonego z 24 słów",
|
||||
"restore_bitcoin_description_from_keys" : "Przywróć swój portfel z wygenerowanego ciągu WIF z kluczy prywatnych",
|
||||
"restore_bitcoin_title_from_keys" : "Przywróć z WIF",
|
||||
"restore_from_date_or_blockheight" : "Wprowadź datę na kilka dni przed utworzeniem tego portfela. Lub jeśli znasz wysokość bloku, wprowadź go zamiast tego",
|
||||
"restore_view_key_private" : "Podaj klucz prywatny",
|
||||
"restore_spend_key_private" : "Podaj prywatny klucz wglądu (view key)",
|
||||
"restore_recover" : "Przywróć",
|
||||
"restore_wallet_restore_description" : "Przywracanie portfela",
|
||||
"restore_new_seed" : "Nowy seed",
|
||||
"restore_active_seed" : "Aktywne seedy",
|
||||
"restore_bitcoin_description_from_seed" : "Przywróć swój portfel z frazy seed złożonej z 24 słów",
|
||||
"restore_bitcoin_description_from_keys" : "Przywróć swój portfel z klucza prywatnego",
|
||||
"restore_bitcoin_title_from_keys" : "Przywróć z klucza prywatnego",
|
||||
"restore_from_date_or_blockheight" : "Wprowadź datę na kilka dni przed utworzeniem tego portfela, lub jeśli znasz wysokość bloku, wprowadź go zamiast daty",
|
||||
|
||||
|
||||
"seed_reminder" : "Zapisz je na wypadek zgubienia lub wyczyszczenia telefonu",
|
||||
"seed_title" : "Ziarno",
|
||||
"seed_share" : "Udostępnij ziarno",
|
||||
"seed_reminder" : "Musisz zapisać tą fraze, bo bez niej możesz nie odzyskać portfela!",
|
||||
"seed_title" : "Seed",
|
||||
"seed_share" : "Udostępnij seed",
|
||||
"copy" : "Kopiuj",
|
||||
|
||||
|
||||
"seed_language_choose" : "Proszę wybrać język początkowy:",
|
||||
"seed_choose" : "Wybierz język początkowy",
|
||||
"seed_language_next" : "Kolejny",
|
||||
"seed_language_choose" : "Proszę wybrać język słów we frazie seed:",
|
||||
"seed_choose" : "Wybierz język",
|
||||
"seed_language_next" : "Następny",
|
||||
"seed_language_english" : "Angielski",
|
||||
"seed_language_chinese" : "Chiński",
|
||||
"seed_language_dutch" : "Holenderski",
|
||||
|
@ -209,7 +209,7 @@
|
|||
"send_address" : "Adres ${cryptoCurrency}",
|
||||
"send_payment_id" : "Identyfikator płatności (opcjonalny)",
|
||||
"all" : "WSZYSTKO",
|
||||
"send_error_minimum_value" : "Minimalna wartość kwoty to 0,01",
|
||||
"send_error_minimum_value" : "Minimalna wartość to 0,01",
|
||||
"send_error_currency" : "Waluta może zawierać tylko cyfry",
|
||||
"send_estimated_fee" : "Szacowana opłata:",
|
||||
"send_priority" : "Obecnie opłata ustalona jest na ${transactionPriority} priorytet.\nPriorytet transakcji można zmienić w ustawieniach",
|
||||
|
@ -219,7 +219,7 @@
|
|||
"send_amount" : "Ilość:",
|
||||
"send_fee" : "Opłata:",
|
||||
"send_name" : "Imię",
|
||||
"send_got_it" : "Rozumiem",
|
||||
"send_got_it" : "Wysłano",
|
||||
"send_sending" : "Wysyłanie...",
|
||||
"send_success" : "Twoje ${crypto} zostało pomyślnie wysłane",
|
||||
|
||||
|
@ -232,21 +232,21 @@
|
|||
"settings_currency" : "Waluta",
|
||||
"settings_fee_priority" : "Priorytet opłaty",
|
||||
"settings_save_recipient_address" : "Zapisz adres odbiorcy",
|
||||
"settings_personal" : "Osobisty",
|
||||
"settings_personal" : "Osobiste",
|
||||
"settings_change_pin" : "Zmień PIN",
|
||||
"settings_change_language" : "Zmień język",
|
||||
"settings_allow_biometrical_authentication" : "Zezwalaj na uwierzytelnianie biometryczne",
|
||||
"settings_dark_mode" : "Tryb ciemny",
|
||||
"settings_transactions" : "Transakcje",
|
||||
"settings_trades" : "Transakcje",
|
||||
"settings_display_on_dashboard_list" : "Wyświetl na liście kokpitu",
|
||||
"settings_all" : "Cały",
|
||||
"settings_display_on_dashboard_list" : "Wyświetl na pulpicie",
|
||||
"settings_all" : "Wszystkie",
|
||||
"settings_only_trades" : "Tylko transakcje",
|
||||
"settings_only_transactions" : "Tylko transakcje",
|
||||
"settings_none" : "Żaden",
|
||||
"settings_support" : "Wsparcie",
|
||||
"settings_terms_and_conditions" : "Zasady i warunki",
|
||||
"pin_is_incorrect" : "PPIN jest niepoprawny",
|
||||
"pin_is_incorrect" : "PIN jest niepoprawny",
|
||||
|
||||
|
||||
"setup_pin" : "Ustaw PIN",
|
||||
|
@ -254,47 +254,47 @@
|
|||
"setup_successful" : "Twój kod PIN został pomyślnie skonfigurowany!",
|
||||
|
||||
|
||||
"wallet_keys" : "Nasiono portfela/klucze",
|
||||
"wallet_seed" : "Nasiono portfela",
|
||||
"private_key" : "Prywatny klucz",
|
||||
"wallet_keys" : "Klucze portfela",
|
||||
"wallet_seed" : "Seed portfela",
|
||||
"private_key" : "Klucz prywatny",
|
||||
"public_key" : "Klucz publiczny",
|
||||
"view_key_private" : "Wyświetl klucz (prywatny)",
|
||||
"view_key_public" : "Wyświetl klucz (publiczny)",
|
||||
"spend_key_private" : "Wydaj klucz (prywatny)",
|
||||
"spend_key_public" : "Wydaj klucz (publiczny)",
|
||||
"copied_key_to_clipboard" : "Skopiowane ${key} do schowka",
|
||||
"view_key_private" : "Prywatny Klucz Wglądu",
|
||||
"view_key_public" : "Publiczny Klucz Wglądu",
|
||||
"spend_key_private" : "Klucz prywatny",
|
||||
"spend_key_public" : "Klucz publiczny",
|
||||
"copied_key_to_clipboard" : "Skopiowaneo ${key} do schowka",
|
||||
|
||||
|
||||
"new_subaddress_title" : "Nowy adres",
|
||||
"new_subaddress_label_name" : "Nazwa etykiety",
|
||||
"new_subaddress_label_name" : "Etykieta nazwy adresu",
|
||||
"new_subaddress_create" : "Stwórz",
|
||||
|
||||
"address_label" : "Address label",
|
||||
"address_label" : "Etykieta Adresu",
|
||||
|
||||
"subaddress_title" : "Lista podadresów",
|
||||
|
||||
|
||||
"trade_details_title" : "Szczegóły handlu",
|
||||
"trade_details_title" : "Szczegóły transakcji",
|
||||
"trade_details_id" : "ID",
|
||||
"trade_details_state" : "Stan",
|
||||
"trade_details_fetching" : "Ujmujący",
|
||||
"trade_details_state" : "Status",
|
||||
"trade_details_fetching" : "Pobieranie",
|
||||
"trade_details_provider" : "Dostawca",
|
||||
"trade_details_created_at" : "Utworzono w",
|
||||
"trade_details_created_at" : "Utworzono ",
|
||||
"trade_details_pair" : "Para",
|
||||
"trade_details_copied" : "${title} skopiowane do schowka",
|
||||
|
||||
|
||||
"trade_history_title" : "Historia handlu",
|
||||
"trade_history_title" : "Historia wymian",
|
||||
|
||||
|
||||
"transaction_details_title" : "Szczegóły transakcji",
|
||||
"transaction_details_transaction_id" : "Transakcja ID",
|
||||
"transaction_details_transaction_id" : "ID Trancakcji",
|
||||
"transaction_details_date" : "Data",
|
||||
"transaction_details_height" : "Wysokość",
|
||||
"transaction_details_height" : "Wysokość Bloku",
|
||||
"transaction_details_amount" : "Ilość",
|
||||
"transaction_details_fee" : "Opłata",
|
||||
"transaction_details_copied" : "${title} skopiowane do schowka",
|
||||
"transaction_details_recipient_address" : "Adresy odbiorców",
|
||||
"transaction_details_recipient_address" : "Adres odbiorcy",
|
||||
|
||||
|
||||
"wallet_list_title" : "Portfel Monero",
|
||||
|
@ -311,23 +311,23 @@
|
|||
"widgets_restore_from_blockheight" : "Przywróć z wysokości bloku",
|
||||
"widgets_restore_from_date" : "Przywróć od daty",
|
||||
"widgets_or" : "lub",
|
||||
"widgets_seed" : "Ziarno",
|
||||
"widgets_seed" : "Seed",
|
||||
|
||||
|
||||
"router_no_route" : "Brak zdefiniowanej trasy dla ${name}",
|
||||
|
||||
|
||||
"error_text_account_name" : "Nazwa konta może zawierać tylko litery, cyfry\ni musi mieć od 1 do 15 znaków",
|
||||
"error_text_contact_name" : "Nazwa kontaktu nie może zawierać` , ' \" symbolika\ni musi mieć od 1 do 32 znaków ",
|
||||
"error_text_address" : "Wallet address must correspond to the type\nof cryptocurrency",
|
||||
"error_text_contact_name" : "Nazwa kontaktu nie może zawierać symboli ` , ' \"\ni musi mieć od 1 do 32 znaków ",
|
||||
"error_text_address" : "Adres musi odpowiadać typowi kryptowaluty",
|
||||
"error_text_node_address" : "Wpisz adres iPv4",
|
||||
"error_text_node_port" : "Port węzła może zawierać tylko liczby od 0 do 65535",
|
||||
"error_text_payment_id" : "ID może zawierać od 16 do 64 znaków w formacie szesnastkowym",
|
||||
"error_text_xmr" : "Wartość XMR nie może przekraczać dostępnego salda.\nLiczba cyfr ułamkowych musi być mniejsza lub równa 12",
|
||||
"error_text_fiat" : "Wartość kwoty nie może przekroczyć dostępnego salda.\nLiczba cyfr ułamkowych musi być mniejsza lub równa 2",
|
||||
"error_text_subaddress_name" : "Nazwa podadresu nie może zawierać ` , ' \" symbolika\ni musi mieć od 1 do 20 znaków",
|
||||
"error_text_subaddress_name" : "Nazwa podadresu nie może zawierać symboli ` , ' \"\ni musi mieć od 1 do 20 znaków",
|
||||
"error_text_amount" : "Kwota może zawierać tylko liczby",
|
||||
"error_text_wallet_name" : "Nazwa portfela może zawierać tylko litery, cyfry, _ - symbole\ni musi mieć od 1 do 33 znaków",
|
||||
"error_text_wallet_name" : "Nazwa portfela może zawierać tylko litery, cyfry lub symbole _ - \ni musi mieć od 1 do 33 znaków",
|
||||
"error_text_keys" : "Klucze portfela mogą zawierać tylko 64 znaki w systemie szesnastkowym",
|
||||
"error_text_crypto_currency" : "Liczba cyfr ułamkowych\nmusi być mniejsza lub równa 12",
|
||||
"error_text_minimal_limit" : "Wymiana dla ${provider} nie została utworzona. Kwota jest mniejsza niż minimalna: ${min} ${currency}",
|
||||
|
@ -337,69 +337,69 @@
|
|||
|
||||
|
||||
"auth_store_ban_timeout" : "przekroczenie limitu czasu",
|
||||
"auth_store_banned_for" : "Bzbanowany za ",
|
||||
"auth_store_banned_for" : "Zablokowany za ",
|
||||
"auth_store_banned_minutes" : " minuty",
|
||||
"auth_store_incorrect_password" : "Niepoprawny PIN",
|
||||
"wallet_store_monero_wallet" : "Portfel Monero",
|
||||
"wallet_restoration_store_incorrect_seed_length" : "Nieprawidłowa długość nasion",
|
||||
"wallet_restoration_store_incorrect_seed_length" : "Nieprawidłowa długość frazy seed",
|
||||
|
||||
|
||||
"full_balance" : "Pełna równowaga",
|
||||
"available_balance" : "Dostępne saldo",
|
||||
"hidden_balance" : "Ukryta równowaga",
|
||||
"full_balance" : "Pełne saldo",
|
||||
"available_balance" : "Dostępne środki",
|
||||
"hidden_balance" : "Ukryte saldo",
|
||||
|
||||
|
||||
"sync_status_syncronizing" : "SYNCHRONIZACJA",
|
||||
"sync_status_syncronized" : "SYNCHRONIZOWANY",
|
||||
"sync_status_syncronized" : "SYNCHRONIZOWANIE",
|
||||
"sync_status_not_connected" : "NIE POŁĄCZONY",
|
||||
"sync_status_starting_sync" : "ROZPOCZĘCIE SYNCHRONIZACJI",
|
||||
"sync_status_failed_connect" : "NIEPOWIĄZANY",
|
||||
"sync_status_connecting" : "ZŁĄCZONY",
|
||||
"sync_status_failed_connect" : "POŁĄCZENIE NIEUDANE",
|
||||
"sync_status_connecting" : "ŁĄCZENIE",
|
||||
"sync_status_connected" : "POŁĄCZONY",
|
||||
"sync_status_attempting_sync" : "PRÓBA SYNCHRONIZACJI",
|
||||
|
||||
|
||||
"transaction_priority_slow" : "Powolny",
|
||||
"transaction_priority_regular" : "Regularny",
|
||||
"transaction_priority_medium" : "Średni",
|
||||
"transaction_priority_fast" : "Szybki",
|
||||
"transaction_priority_fastest" : "Najszybszy",
|
||||
"transaction_priority_slow" : "Wolna(Zalecane)",
|
||||
"transaction_priority_regular" : "Regularna",
|
||||
"transaction_priority_medium" : "Średnia",
|
||||
"transaction_priority_fast" : "Szybka",
|
||||
"transaction_priority_fastest" : "Najszybsza",
|
||||
|
||||
|
||||
"trade_for_not_created" : "Zamienić się za ${title} nie jest tworzony.",
|
||||
"trade_not_created" : "Handel nie utworzony",
|
||||
"trade_id_not_found" : "Handel ${tradeId} of ${title} nie znaleziono.",
|
||||
"trade_not_found" : "Nie znaleziono handlu.",
|
||||
"trade_for_not_created" : "Wymiana za ${title} nie została utworzona.",
|
||||
"trade_not_created" : "Wymiana nie została utworzona",
|
||||
"trade_id_not_found" : "Transakcja ${tradeId} ${title} nie znaleziona.",
|
||||
"trade_not_found" : "Nie znaleziono transakcji.",
|
||||
|
||||
|
||||
"trade_state_pending" : "W oczekiwaniu",
|
||||
"trade_state_confirming" : "Potwierdzam",
|
||||
"trade_state_trading" : "Handlowy",
|
||||
"trade_state_traded" : "Handlowane",
|
||||
"trade_state_complete" : "Kompletny",
|
||||
"trade_state_to_be_created" : "Zostać stworzonym",
|
||||
"trade_state_unpaid" : "Nie zapłacony",
|
||||
"trade_state_pending" : "Oczekująca",
|
||||
"trade_state_confirming" : "Potwierdzanie",
|
||||
"trade_state_trading" : "Wymiana",
|
||||
"trade_state_traded" : "Wymienione",
|
||||
"trade_state_complete" : "Ukończona",
|
||||
"trade_state_to_be_created" : "Została stworzona",
|
||||
"trade_state_unpaid" : "Nie opłacona",
|
||||
"trade_state_underpaid" : "Niedopłacone",
|
||||
"trade_state_paid_unconfirmed" : "Płatne niepotwierdzone",
|
||||
"trade_state_paid" : "Płatny",
|
||||
"trade_state_btc_sent" : "Wysłane",
|
||||
"trade_state_paid_unconfirmed" : "Transakcja niepotwierdzona",
|
||||
"trade_state_paid" : "Opłacona",
|
||||
"trade_state_btc_sent" : "Wysłanie",
|
||||
"trade_state_timeout" : "Koniec czasu",
|
||||
"trade_state_created" : "Stworzony",
|
||||
"trade_state_finished" : "Skończone",
|
||||
"trade_state_created" : "Stworzona",
|
||||
"trade_state_finished" : "Zakończona",
|
||||
|
||||
"change_language" : "Zmień język",
|
||||
"change_language_to" : "Zmień język na ${language}?",
|
||||
|
||||
"paste" : "Pasta",
|
||||
"restore_from_seed_placeholder" : "Wpisz lub wklej tutaj swoją frazę kodową",
|
||||
"paste" : "Wklej",
|
||||
"restore_from_seed_placeholder" : "Wpisz lub wklej tutaj swoją frazę seed",
|
||||
"add_new_word" : "Dodaj nowe słowo",
|
||||
"incorrect_seed" : "Wprowadzony tekst jest nieprawidłowy.",
|
||||
"incorrect_seed" : "Wprowadzony seed jest nieprawidłowy.",
|
||||
|
||||
"biometric_auth_reason" : "Zeskanuj swój odcisk palca, aby go uwierzytelnić",
|
||||
"biometric_auth_reason" : "Zeskanuj swój odcisk palca, aby uwierzytelnić",
|
||||
"version" : "Wersja ${currentVersion}",
|
||||
|
||||
"openalias_alert_title" : "Wykryto Adres",
|
||||
"openalias_alert_content" : "Będziesz wysyłać środki na\n${recipient_name}",
|
||||
"openalias_alert_content" : "Wysyłasz środki na\n${recipient_name}",
|
||||
|
||||
"card_address" : "Adres:",
|
||||
"buy" : "Kup",
|
||||
|
@ -418,36 +418,36 @@
|
|||
"change_wallet_alert_content" : "Czy chcesz zmienić obecny portfel na ${wallet_name}?",
|
||||
|
||||
"creating_new_wallet" : "Tworzenie nowego portfela",
|
||||
"creating_new_wallet_error" : "Pomyłka: ${description}",
|
||||
"creating_new_wallet_error" : "Błąd: ${description}",
|
||||
|
||||
"seed_alert_title" : "Uwaga",
|
||||
"seed_alert_content" : "Ziarno to jedyny sposób na odzyskanie portfela. Zapisałeś to?",
|
||||
"seed_alert_content" : "Fraza Seed to jedyny sposób na odzyskanie portfela. Zapisałeś ją?",
|
||||
"seed_alert_back" : "Wróć",
|
||||
"seed_alert_yes" : "Tak",
|
||||
|
||||
"exchange_sync_alert_content" : "Poczekaj, aż portfel zostanie zsynchronizowany",
|
||||
|
||||
"pre_seed_title" : "WAŻNY",
|
||||
"pre_seed_description" : "Na następnej stronie zobaczysz serię ${words} słów. To jest Twoje unikalne i prywatne ziarno i jest to JEDYNY sposób na odzyskanie portfela w przypadku utraty lub awarii. Twoim obowiązkiem jest zapisanie go i przechowywanie w bezpiecznym miejscu poza aplikacją Cake Wallet.",
|
||||
"pre_seed_button_text" : "Rozumiem. Pokaż mi moje nasienie",
|
||||
"pre_seed_description" : "Na następnej stronie zobaczysz serię ${words} słów. To jest Twoja unikalna i prywatna fraza seed i jest to JEDYNY sposób na odzyskanie portfela w przypadku utraty lub awarii telefonu. Twoim obowiązkiem jest zapisanie go i przechowywanie w bezpiecznym miejscu (np. na kartce w SEJFIE).",
|
||||
"pre_seed_button_text" : "Rozumiem. Pokaż mi moją fraze seed",
|
||||
|
||||
"xmr_to_error" : "Pomyłka XMR.TO",
|
||||
"xmr_to_error_description" : "Nieprawidłowa kwota. Maksymalny limit 8 cyfr po przecinku",
|
||||
"xmr_to_error" : "Błąd XMR.TO",
|
||||
"xmr_to_error_description" : "Nieprawidłowa kwota. Maksymalny limit to 8 cyfr po przecinku",
|
||||
|
||||
"provider_error" : "${provider} pomyłka",
|
||||
|
||||
"use_ssl" : "Użyj SSL",
|
||||
"trusted" : "zaufany",
|
||||
"trusted" : "Zaufany",
|
||||
|
||||
"color_theme" : "Motyw kolorystyczny",
|
||||
"light_theme" : "Lekki",
|
||||
"bright_theme" : "Jasny",
|
||||
"light_theme" : "Jasny",
|
||||
"bright_theme" : "Biały",
|
||||
"dark_theme" : "Ciemny",
|
||||
"enter_your_note" : "Wpisz notatkę…",
|
||||
"note_optional" : "Notatka (opcjonalnie)",
|
||||
"note_tap_to_change" : "Notatka (dotknij, aby zmienić)",
|
||||
"view_in_block_explorer" : "View in Block Explorer",
|
||||
"view_transaction_on" : "View Transaction on ",
|
||||
"view_in_block_explorer" : "Zobacz w eksploratorze bloków",
|
||||
"view_transaction_on" : "Zobacz transakcje na ",
|
||||
"transaction_key" : "Klucz transakcji",
|
||||
"confirmations" : "Potwierdzenia",
|
||||
"recipient_address" : "Adres odbiorcy",
|
||||
|
@ -456,27 +456,27 @@
|
|||
"destination_tag" : "Tag docelowy:",
|
||||
"memo" : "Notatka:",
|
||||
|
||||
"backup" : "Kopię zapasową",
|
||||
"backup" : "Kopia zapasowa",
|
||||
"change_password" : "Zmień hasło",
|
||||
"backup_password" : "Hasło zapasowe",
|
||||
"write_down_backup_password" : "Zapisz swoje hasło zapasowe, które jest używane do importowania plików kopii zapasowych.",
|
||||
"backup_password" : "Hasło kpoii zapasowej",
|
||||
"write_down_backup_password" : "Zapisz swoje hasło kopii zapasowej, które jest używane do importowania plików kopii zapasowych.",
|
||||
"export_backup" : "Eksportuj kopię zapasową",
|
||||
"save_backup_password" : "Upewnij się, że zapisałeś swoje zapasowe hasło. Bez tego nie będziesz mógł importować plików kopii zapasowej.",
|
||||
"save_backup_password" : "Upewnij się, że zapisałeś swoje hasło kopii zapasowej. Bez tego nie będziesz mógł zaimportować pliku kopii zapasowej.",
|
||||
"backup_file" : "Plik kopii zapasowej",
|
||||
|
||||
"edit_backup_password" : "Edytuj hasło kopii zapasowej",
|
||||
"save_backup_password_alert" : "Zapisz hasło zapasowe",
|
||||
"change_backup_password_alert" : "Twoje poprzednie pliki kopii zapasowej nie będą dostępne do zaimportowania z nowym hasłem kopii zapasowej. Nowe hasło zapasowe będzie używane tylko dla nowych plików kopii zapasowych. Czy na pewno chcesz zmienić hasło zapasowe?",
|
||||
"save_backup_password_alert" : "Zapisz hasło kopii zapasowej",
|
||||
"change_backup_password_alert" : "Twoje poprzednie pliki kopii zapasowej nie będą dostępne do zaimportowania z nowym hasłem kopii zapasowej. Nowe hasło kopii zapasowej będzie używane tylko dla nowych plików kopii zapasowych. Czy na pewno chcesz zmienić hasło zapasowe?",
|
||||
|
||||
"enter_backup_password" : "Wprowadź tutaj hasło zapasowe",
|
||||
"enter_backup_password" : "Wprowadź tutaj hasło kopii zapasowej",
|
||||
"select_backup_file" : "Wybierz plik kopii zapasowej",
|
||||
"import" : "Import",
|
||||
"please_select_backup_file" : "Wybierz plik kopii zapasowej i wprowadź hasło zapasowe.",
|
||||
"import" : "Zaimportuj",
|
||||
"please_select_backup_file" : "Wybierz plik kopii zapasowej i wprowadź hasło.",
|
||||
|
||||
"fixed_rate" : "Stała stawka",
|
||||
"fixed_rate_alert" : "Będziesz mógł wprowadzić kwotę otrzymaną, gdy zaznaczony jest tryb stałej stawki. Czy chcesz przejść do trybu stałej stawki?",
|
||||
"fixed_rate_alert" : "Będziesz mógł wprowadzić kwotę do otrzymania, gdy wybrany bedzie tryb stałego przeliczenia. Czy chcesz przejść do trybu stałej stawki?",
|
||||
|
||||
"xlm_extra_info" : "Nie zapomnij podać identyfikatora notatki podczas wysyłania transakcji XLM do wymiany",
|
||||
"xlm_extra_info" : "Nie zapomnij podać dodatkowego identyfikatora (memo) podczas wysyłania transakcji XLM do wymiany",
|
||||
"xrp_extra_info" : "Nie zapomnij podać tagu docelowego podczas wysyłania transakcji XRP do wymiany",
|
||||
|
||||
"exchange_incorrect_current_wallet_for_xmr" : "Jeśli chcesz wymienić XMR z salda Cake Wallet Monero, najpierw przełącz się na portfel Monero.",
|
||||
|
@ -484,12 +484,12 @@
|
|||
"unconfirmed" : "Niepotwierdzony",
|
||||
"displayable" : "Wyświetlane",
|
||||
|
||||
"submit_request" : "złożyć wniosek",
|
||||
"submit_request" : "Złóż wniosek",
|
||||
|
||||
"buy_alert_content" : "Obecnie obsługujemy tylko zakup Bitcoin i Litecoin. Aby kupić Bitcoin lub Litecoin, utwórz lub przełącz się na swój portfel Bitcoin lub Litecoin.",
|
||||
"buy_alert_content" : "Obecnie obsługujemy tylko zakup Bitcoina i Litecoina. Aby kupić Bitcoin lub Litecoin, utwórz lub przełącz się na swój portfel Bitcoin lub Litecoin.",
|
||||
"sell_alert_content": "Obecnie obsługujemy tylko sprzedaż Bitcoina. Aby sprzedać Bitcoin, utwórz lub przełącz się na swój portfel Bitcoin.",
|
||||
|
||||
"outdated_electrum_wallet_description" : "Nowe portfele Bitcoin utworzone w Cake mają teraz ziarno składające się z 24 słów. Konieczne jest utworzenie nowego portfela Bitcoin i przeniesienie wszystkich środków do nowego portfela na 24 słowa oraz zaprzestanie korzystania z portfeli z zalążkiem na 12 słów. Zrób to natychmiast, aby zabezpieczyć swoje fundusze.",
|
||||
"outdated_electrum_wallet_description" : "Nowe portfele Bitcoin utworzone w Cake mają teraz fraze seed składające się z 24 słów. Konieczne jest utworzenie nowego portfela Bitcoin i przeniesienie wszystkich środków do nowego portfela na 24 słowa oraz zaprzestanie korzystania z portfeli z frazą seed na 12 słów. Zrób to natychmiast, aby zabezpieczyć swoje fundusze.",
|
||||
"understand" : "Rozumiem",
|
||||
|
||||
"apk_update" : "Aktualizacja APK",
|
||||
|
@ -498,19 +498,19 @@
|
|||
"buy_with" : "Kup za pomocą",
|
||||
"moonpay_alert_text" : "Wartość kwoty musi być większa lub równa ${minAmount} ${fiatCurrency}",
|
||||
|
||||
"outdated_electrum_wallet_receive_warning": "Jeśli ten portfel ma 12-wyrazowy seed i został utworzony w Cake, NIE Wpłacaj Bitcoina do tego portfela. Wszelkie BTC przeniesione do tego portfela mogą zostać utracone. Utwórz nowy portfel z 24 słowami (dotknij menu w prawym górnym rogu, wybierz Portfele, wybierz Utwórz nowy portfel, a następnie Bitcoin) i NATYCHMIAST przenieś tam swoje BTC. Nowe (24 słowa) portfele BTC firmy Cake są bezpieczne",
|
||||
"outdated_electrum_wallet_receive_warning": "Jeśli ten portfel ma 12-wyrazowy seed i został utworzony w Cake, NIE Wpłacaj Bitcoina do tego portfela. Wszelkie BTC przeniesione do tego portfela mogą zostać utracone. Utwórz nowy portfel z 24 słowami (dotknij menu w prawym górnym rogu, wybierz Portfele, wybierz Utwórz nowy portfel, a następnie Bitcoin) i NATYCHMIAST przenieś tam swoje BTC. Nowe (24 słowa) portfele BTC Cake Wallet są bezpieczne",
|
||||
"do_not_show_me": "Nie pokazuj mi tego ponownie",
|
||||
|
||||
"unspent_coins_title" : "Niewydane monety",
|
||||
"unspent_coins_details_title" : "Szczegóły niewydanych monet",
|
||||
"freeze" : "Zamrażać",
|
||||
"frozen" : "Mrożony",
|
||||
"freeze" : "Zamróź",
|
||||
"frozen" : "Zamrożone",
|
||||
"coin_control" : "Kontrola monet (opcjonalnie)",
|
||||
|
||||
"address_detected" : "Wykryto adres",
|
||||
"address_from_domain" : "Ten adres jest od ${domain} na Unstoppable Domains",
|
||||
"address_from_domain" : "Ten adres to ${domain} na Unstoppable Domains",
|
||||
|
||||
"add_receiver" : "Dodaj kolejny odbiornik (opcjonalnie)",
|
||||
"add_receiver" : "Dodaj kolejnego odbiorcę (opcjonalnie)",
|
||||
|
||||
"manage_yats" : "Zarządzaj Yats",
|
||||
"yat_alert_title" : "Łatwiejsze wysyłanie i odbieranie kryptowalut dzięki Yat",
|
||||
|
@ -521,25 +521,27 @@
|
|||
"yat" : "Yat",
|
||||
"connect_yats": "Połącz Yats",
|
||||
"address_from_yat" : "Ten adres jest od ${emoji} na Yat",
|
||||
"yat_error" : "Pomyłka Yata",
|
||||
"yat_error" : "Błąd Yat",
|
||||
"yat_error_content" : "Brak adresów powiązanych z tym Yat. Wypróbuj inny Yat",
|
||||
"choose_address" : "\n\nWybierz adres:",
|
||||
"yat_popup_title" : "Twój adres portfela może być emojified.",
|
||||
"yat_popup_title" : "Twój adres portfela może być zemotkowany.",
|
||||
"yat_popup_content" : "Możesz teraz wysyłać i odbierać krypto w Cake Wallet za pomocą swojego Yat – krótkiej nazwy użytkownika opartej na emotikonach. Zarządzaj Yats w dowolnym momencie na ekranie ustawień",
|
||||
"second_intro_title" : "Jeden adres emoji, aby rządzić nimi wszystkimi",
|
||||
"second_intro_title" : "Jeden adres emoji, aby zarzadzać wszystkimi walutami",
|
||||
"second_intro_content" : "Twój Yat to jeden unikalny adres emoji, który zastępuje wszystkie Twoje długie adresy szesnastkowe dla wszystkich Twoich walut.",
|
||||
"third_intro_title" : "Yat ładnie bawi się z innymi",
|
||||
"third_intro_content" : "Yats mieszkają również poza Cake Wallet. Każdy adres portfela na ziemi można zastąpić Yat!",
|
||||
"learn_more" : "Ucz się więcej",
|
||||
"learn_more" : "Dowiedz się więcej",
|
||||
"search": "Szukaj",
|
||||
"search_language": "Wyszukaj język",
|
||||
"search_currency": "Wyszukaj walutę",
|
||||
"new_template" : "Nowy szablon",
|
||||
"electrum_address_disclaimer": "Za każdym razem, gdy korzystasz z jednego z nich, generujemy nowe adresy, ale poprzednie adresy nadal działają",
|
||||
"electrum_address_disclaimer": "Za każdym razem, gdy wykorzystasz adres, dla wiekszej prywatności generujemy nowy, ale poprzednie adresy nadal działają, i moga odbierać środki",
|
||||
"wallet_name_exists": "Portfel o tej nazwie już istnieje",
|
||||
"market_place": "Rynek",
|
||||
"cake_pay_title": "Karty podarunkowe Cake Pay",
|
||||
"cake_pay_subtitle": "Kup karty podarunkowe i wykorzystaj je natychmiast",
|
||||
"cake_pay_subtitle": "Kup karty upominkowe ze zniżką (tylko USA)",
|
||||
"cake_pay_web_cards_title": "Cake Pay Web Cards",
|
||||
"cake_pay_web_cards_subtitle": "Kupuj na całym świecie karty przedpłacone i karty podarunkowe",
|
||||
"about_cake_pay": "Cake Pay umożliwia łatwe kupowanie kart podarunkowych z wirtualnymi aktywami, które można natychmiast wydać u ponad 150 000 sprzedawców w Stanach Zjednoczonych.",
|
||||
"cake_pay_account_note": "Zarejestruj się, używając tylko adresu e-mail, aby przeglądać i kupować karty. Niektóre są nawet dostępne ze zniżką!",
|
||||
"already_have_account": "Masz już konto?",
|
||||
|
@ -551,16 +553,16 @@
|
|||
"reset_password": "Zresetuj hasło",
|
||||
"gift_cards": "Karty podarunkowe",
|
||||
"setup_your_debit_card": "Skonfiguruj swoją kartę debetową",
|
||||
"no_id_required": "Nie wymagamy ID. Doładuj i wydawaj gdziekolwiek",
|
||||
"how_to_use_card": "Jak korzystać z tej karty",
|
||||
"no_id_required": "Nie wymagamy Dowodu. Doładuj i wydawaj gdziekolwiek",
|
||||
"how_to_use_card": "Jak korzystać z tej karty?",
|
||||
"purchase_gift_card": "Kup kartę podarunkową",
|
||||
"verification": "Weryfikacja",
|
||||
"fill_code": "Proszę wpisać kod weryfikacyjny podany w wiadomości e-mail",
|
||||
"dont_get_code": "Nie odbierasz kodu?",
|
||||
"fill_code": "Proszę wpisać kod weryfikacyjny który otrzymałeś w wiadomości e-mail",
|
||||
"dont_get_code": "Nie dostałeś kodu?",
|
||||
"resend_code": "Wyślij go ponownie",
|
||||
"debit_card": "Karta debetowa",
|
||||
"cakepay_prepaid_card": "Przedpłacona karta debetowa CakePay",
|
||||
"no_id_needed": "Nie potrzeba ID!",
|
||||
"no_id_needed": "Nie potrzeba Dowodu!",
|
||||
"frequently_asked_questions": "Często zadawane pytania",
|
||||
"debit_card_terms": "Przechowywanie i używanie numeru karty płatniczej (oraz danych uwierzytelniających odpowiadających numerowi karty płatniczej) w tym portfelu cyfrowym podlega Warunkom odpowiedniej umowy posiadacza karty z wydawcą karty płatniczej, zgodnie z obowiązującym od od czasu do czasu.",
|
||||
"please_reference_document": "Proszę odwołać się do poniższych dokumentów, aby uzyskać więcej informacji.",
|
||||
|
@ -624,7 +626,7 @@
|
|||
"mark_as_redeemed": "Oznacz jako wykorzystany",
|
||||
"more_options": "Więcej opcji",
|
||||
"awaiting_payment_confirmation": "Oczekiwanie na potwierdzenie płatności",
|
||||
"transaction_sent_notice": "Jeśli ekran nie pojawi się po 1 minucie, sprawdź eksplorator bloków i swój e-mail.",
|
||||
"transaction_sent_notice": "Jeśli ekran nie zmieni się po 1 minucie, sprawdź eksplorator bloków i swój e-mail.",
|
||||
"agree": "Zgadzam się",
|
||||
"in_store": "W Sklepie",
|
||||
"generating_gift_card": "Generowanie karty podarunkowej",
|
||||
|
@ -635,7 +637,7 @@
|
|||
"open_gift_card": "Otwórz kartę podarunkową",
|
||||
"contact_support": "Skontaktuj się z pomocą techniczną",
|
||||
"gift_cards_unavailable": "Karty podarunkowe można obecnie kupić tylko za pośrednictwem Monero, Bitcoin i Litecoin",
|
||||
"introducing_cake_pay": "Przedstawiamy Ciasto Pay!",
|
||||
"introducing_cake_pay": "Przedstawiamy Cake Pay!",
|
||||
"cake_pay_learn_more": "Kupuj i wykorzystuj karty podarunkowe od razu w aplikacji!\nPrzesuń od lewej do prawej, aby dowiedzieć się więcej.",
|
||||
"automatic": "Automatyczny",
|
||||
"fixed_pair_not_supported": "Ta stała para nie jest obsługiwana na wybranych giełdach",
|
||||
|
@ -652,8 +654,10 @@
|
|||
"low_fee_alert": "Obecnie korzystasz z niskiego priorytetu opłaty sieciowej. Może to spowodować długie oczekiwanie, różne stawki lub anulowane transakcje. Zalecamy ustawienie wyższej opłaty, aby zapewnić lepsze wrażenia.",
|
||||
"ignor": "Ignorować",
|
||||
"use_suggested": "Użyj sugerowane",
|
||||
"do_not_share_warning_text" : "Nie udostępniaj ich nikomu innemu, w tym pomocy.\n\nTwoje środki mogą i zostaną skradzione!",
|
||||
"do_not_share_warning_text" : "NIE udostępniaj ich nikomu innemu, w tym pomocy technicznej.\n\nTwoje środki wtedy prawdopodobnie zostaną skradzione!",
|
||||
"help": "pomoc",
|
||||
"all_transactions": "Wszystkie transakcje",
|
||||
"all_trades": "Wszystkie operacje",
|
||||
"connection_sync": "Połączenie i synchronizacja",
|
||||
"security_and_backup": "Bezpieczeństwo i kopia zapasowa",
|
||||
"create_backup": "Utwórz kopię zapasową",
|
||||
|
@ -661,13 +665,19 @@
|
|||
"privacy": "Prywatność",
|
||||
"display_settings": "Ustawienia wyświetlania",
|
||||
"other_settings": "Inne ustawienia",
|
||||
"require_pin_after": "Wymagaj kodu PIN po",
|
||||
"always": "zawsze",
|
||||
"minutes_to_pin_code": "${minute} minut",
|
||||
"disable_exchange": "Wyłącz wymianę",
|
||||
"advanced_privacy_settings": "Zaawansowane ustawienia prywatności",
|
||||
"settings_can_be_changed_later": "Te ustawienia można później zmienić w ustawieniach aplikacji",
|
||||
"add_custom_node": "Dodaj nowy węzeł niestandardowy",
|
||||
"disable_fiat": "Wyłącz fiat",
|
||||
"fiat_api": "API Fiata",
|
||||
"disable_fiat": "Wyłącz waluty FIAT",
|
||||
"fiat_api": "API Walut FIAT",
|
||||
"disabled": "Wyłączone",
|
||||
"enabled": "Włączony",
|
||||
"tor_only": "Tylko Tor"
|
||||
"enabled": "Włączone",
|
||||
"tor_only": "Tylko sieć Tor",
|
||||
"unmatched_currencies": "Waluta Twojego obecnego portfela nie zgadza się z waluctą zeskanowanego kodu QR",
|
||||
"contact_list_contacts": "Łączność",
|
||||
"contact_list_wallets": "Moje portfele"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Enviadas",
|
||||
"transactions_by_date" : "Transações por data",
|
||||
"trades" : "Trocas",
|
||||
"filters" : "Filtro",
|
||||
"filter_by": "Filtrar por",
|
||||
"today" : "Hoje",
|
||||
"yesterday" : "Ontem",
|
||||
"received" : "Recebida",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "A carteira com esse nome já existe",
|
||||
"market_place": "Mercado",
|
||||
"cake_pay_title": "Cartões de presente de pagamento de bolo",
|
||||
"cake_pay_subtitle": "Compre vales-presente e resgate instantaneamente",
|
||||
"cake_pay_subtitle": "Compre vales-presente com desconto (somente nos EUA)",
|
||||
"cake_pay_web_cards_title": "Cartões Cake Pay Web",
|
||||
"cake_pay_web_cards_subtitle": "Compre cartões pré-pagos e cartões-presente em todo o mundo",
|
||||
"about_cake_pay": "O Cake Pay permite que você compre facilmente cartões-presente com ativos virtuais, que podem ser gastos instantaneamente em mais de 150.000 comerciantes nos Estados Unidos.",
|
||||
"cake_pay_account_note": "Inscreva-se com apenas um endereço de e-mail para ver e comprar cartões. Alguns estão até com desconto!",
|
||||
"already_have_account": "Já tem uma conta?",
|
||||
|
@ -653,6 +655,8 @@
|
|||
"use_suggested": "Uso sugerido",
|
||||
"do_not_share_warning_text" : "Não os compartilhe com mais ninguém, incluindo suporte.\n\nSeus fundos podem e serão roubados!",
|
||||
"help": "ajuda",
|
||||
"all_transactions": "Todas as transacções",
|
||||
"all_trades": "Todas as negociações",
|
||||
"connection_sync": "Conexão e sincronização",
|
||||
"security_and_backup": "Segurança e backup",
|
||||
"create_backup": "Criar backup",
|
||||
|
@ -660,6 +664,9 @@
|
|||
"privacy": "Privacidade",
|
||||
"display_settings": "Configurações de exibição",
|
||||
"other_settings": "Outras configurações",
|
||||
"require_pin_after": "Exigir PIN após",
|
||||
"always": "sempre",
|
||||
"minutes_to_pin_code": "${minute} minutos",
|
||||
"disable_exchange": "Desativar troca",
|
||||
"advanced_privacy_settings": "Configurações de privacidade avançadas",
|
||||
"settings_can_be_changed_later": "Essas configurações podem ser alteradas posteriormente nas configurações do aplicativo",
|
||||
|
@ -668,5 +675,8 @@
|
|||
"fiat_api": "API da Fiat",
|
||||
"disabled": "Desabilitado",
|
||||
"enabled": "Habilitado",
|
||||
"tor_only": "Tor apenas"
|
||||
"tor_only": "Tor apenas",
|
||||
"unmatched_currencies": "A moeda da sua carteira atual não corresponde à do QR digitalizado",
|
||||
"contact_list_contacts": "Contatos",
|
||||
"contact_list_wallets": "minhas carteiras"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Исходящие",
|
||||
"transactions_by_date" : "Сортировать по дате",
|
||||
"trades" : "Сделки",
|
||||
"filters" : "Фильтр",
|
||||
"filter_by": "Фильтровать по",
|
||||
"today" : "Сегодня",
|
||||
"yesterday" : "Вчера",
|
||||
"received" : "Полученные",
|
||||
|
@ -369,7 +369,7 @@
|
|||
"trade_for_not_created" : "Сделка для ${title} не создана.",
|
||||
"trade_not_created" : "Сделка не создана",
|
||||
"trade_id_not_found" : "Сделка ${tradeId} ${title} не найдена.",
|
||||
"trade_not_found" : "Trade not found.",
|
||||
"trade_not_found" : "Торговля не найдена.",
|
||||
|
||||
|
||||
"trade_state_pending" : "Ожидание",
|
||||
|
@ -539,7 +539,9 @@
|
|||
"wallet_name_exists": "Кошелек с таким именем уже существует",
|
||||
"market_place": "Торговая площадка",
|
||||
"cake_pay_title": "Подарочные карты Cake Pay",
|
||||
"cake_pay_subtitle": "Купите подарочные карты и моментально погасите их",
|
||||
"cake_pay_subtitle": "Покупайте подарочные карты со скидкой (только для США)",
|
||||
"cake_pay_web_cards_title": "Веб-карты Cake Pay",
|
||||
"cake_pay_web_cards_subtitle": "Покупайте карты предоплаты и подарочные карты по всему миру",
|
||||
"about_cake_pay": "Cake Pay позволяет вам легко покупать подарочные карты с виртуальными активами, которые можно мгновенно потратить в более чем 150 000 продавцов в Соединенных Штатах.",
|
||||
"cake_pay_account_note": "Зарегистрируйтесь, указав только адрес электронной почты, чтобы просматривать и покупать карты. Некоторые даже доступны со скидкой!",
|
||||
"already_have_account": "У вас уже есть аккаунт?",
|
||||
|
@ -654,6 +656,8 @@
|
|||
"use_suggested": "Использовать предложенный",
|
||||
"do_not_share_warning_text" : "Не сообщайте их никому, включая техподдержку.\n\nВаши средства могут и будут украдены!",
|
||||
"help": "помощь",
|
||||
"all_transactions": "Все транзакции",
|
||||
"all_trades": "Все сделки",
|
||||
"connection_sync": "Подключение и синхронизация",
|
||||
"security_and_backup": "Безопасность и резервное копирование",
|
||||
"create_backup": "Создать резервную копию",
|
||||
|
@ -661,6 +665,9 @@
|
|||
"privacy": "Конфиденциальность",
|
||||
"display_settings": "Настройки отображения",
|
||||
"other_settings": "Другие настройки",
|
||||
"require_pin_after": "Требовать ПИН после",
|
||||
"always": "всегда",
|
||||
"minutes_to_pin_code": "${minute} минут",
|
||||
"disable_exchange": "Отключить обмен",
|
||||
"advanced_privacy_settings": "Расширенные настройки конфиденциальности",
|
||||
"settings_can_be_changed_later": "Эти настройки можно изменить позже в настройках приложения.",
|
||||
|
@ -669,5 +676,8 @@
|
|||
"fiat_api": "Фиат API",
|
||||
"disabled": "Отключено",
|
||||
"enabled": "Включено",
|
||||
"tor_only": "Только Tor"
|
||||
"tor_only": "Только Tor",
|
||||
"unmatched_currencies": "Валюта вашего текущего кошелька не соответствует валюте отсканированного QR-кода.",
|
||||
"contact_list_contacts": "Контакты",
|
||||
"contact_list_wallets": "Мои кошельки"
|
||||
}
|
||||
|
|
681
res/values/strings_th.arb
Normal file
681
res/values/strings_th.arb
Normal file
|
@ -0,0 +1,681 @@
|
|||
{
|
||||
"welcome" : "ยินดีต้อนรับสู่",
|
||||
"cake_wallet" : "Cake Wallet",
|
||||
"first_wallet_text" : "กระเป๋าสตางค์ที่สวยงามสำหรับ Monero, Bitcoin, Litecoin และ Haven",
|
||||
"please_make_selection" : "โปรดเลือกตามด้านล่างเพื่อสร้างหรือกู้กระเป๋าของคุณ",
|
||||
"create_new" : "สร้างกระเป๋าใหม่",
|
||||
"restore_wallet" : "กู้กระเป๋า",
|
||||
|
||||
"monero_com": "Monero.com ของ Cake Wallet",
|
||||
"monero_com_wallet_text": "กระเป๋าสตางค์ที่สวยงามสำหรับ Monero",
|
||||
|
||||
"haven_app": "Haven ของ Cake Wallet",
|
||||
"haven_app_wallet_text": "กระเป๋าสตางค์ที่สวยงามสำหรับ Haven",
|
||||
|
||||
"accounts" : "บัญชี",
|
||||
"edit" : "แก้ไข",
|
||||
"account" : "บัญชี",
|
||||
"add" : "เพิ่ม",
|
||||
|
||||
|
||||
"address_book" : "สมุดที่อยู่",
|
||||
"contact" : "ผู้ติดต่อ",
|
||||
"please_select" : "โปรดเลือก:",
|
||||
"cancel" : "ยกเลิก",
|
||||
"ok" : "ตกลง",
|
||||
"contact_name" : "ชื่อผู้ติดต่อ",
|
||||
"reset" : "รีเซ็ต",
|
||||
"save" : "บันทึก",
|
||||
"address_remove_contact" : "ลบผู้ติดต่อ",
|
||||
"address_remove_content" : "คุณแน่ใจหรือว่าต้องการลบผู้ติดต่อที่เลือก?",
|
||||
|
||||
|
||||
"authenticated" : "ได้รับการยืนยันสิทธิ์",
|
||||
"authentication" : "การยืนยันสิทธิ์",
|
||||
"failed_authentication" : "การยืนยันสิทธิ์ล้มเหลว ${state_error}",
|
||||
|
||||
|
||||
"wallet_menu" : "เมนู",
|
||||
"Blocks_remaining" : "${status} บล็อกที่เหลืออยู่",
|
||||
"please_try_to_connect_to_another_node" : "โปรดลองเชื่อมต่อกับโหนดอื่น",
|
||||
"xmr_hidden" : "ซ่อน",
|
||||
"xmr_available_balance" : "ยอดคงเหลือที่สามารถใช้งานได้",
|
||||
"xmr_full_balance" : "ยอดคงเหลือแบบเต็ม",
|
||||
"send" : "ส่ง",
|
||||
"receive" : "รับ",
|
||||
"transactions" : "ธุรกรรม",
|
||||
"incoming" : "ขาเข้า",
|
||||
"outgoing" : "ขาออก",
|
||||
"transactions_by_date" : "ธุรกรรมตามวันที่",
|
||||
"trades" : "การซื้อขาย",
|
||||
"filter_by": "กรองตาม",
|
||||
"today" : "วันนี้",
|
||||
"yesterday" : "เมื่อวาน",
|
||||
"received" : "รับ",
|
||||
"sent" : "ส่ง",
|
||||
"pending" : " (อยู่ระหว่างดำเนินการ)",
|
||||
"rescan" : "สแกนใหม่",
|
||||
"reconnect" : "เชื่อมต่อใหม่",
|
||||
"wallets" : "กระเป๋า",
|
||||
"show_seed" : "แสดงซีด",
|
||||
"show_keys" : "แสดงซีด/คีย์",
|
||||
"address_book_menu" : "สมุดที่อยู่",
|
||||
"reconnection" : "เชื่อมต่อใหม่",
|
||||
"reconnect_alert_text" : "คุณแน่ใจหรือไม่ว่าต้องการเชื่อมต่อใหม่?",
|
||||
|
||||
|
||||
"exchange" : "แลกเปลี่ยน",
|
||||
"clear" : "ล้าง",
|
||||
"refund_address" : "ที่อยู่สำหรับส่งคืน",
|
||||
"change_exchange_provider" : "เปลี่ยนผู้ให้บริการแลกเปลี่ยน",
|
||||
"you_will_send" : "แปลงจาก",
|
||||
"you_will_get" : "แปลงเป็น",
|
||||
"amount_is_guaranteed" : "จำนวนที่จะได้รับมีการรับประกัน",
|
||||
"amount_is_estimate" : "จำนวนที่จะได้รับเป็นการประมาณการ",
|
||||
"powered_by" : "พัฒนาขึ้นโดย ${title}",
|
||||
"error" : "ข้อผิดพลาด",
|
||||
"estimated" : "ประมาณการ",
|
||||
"min_value" : "ขั้นต่ำ: ${value} ${currency}",
|
||||
"max_value" : "ขั้นสูง: ${value} ${currency}",
|
||||
"change_currency" : "เปลี่ยนสกุลเงิน",
|
||||
"overwrite_amount" : "เขียนทับจำนวน",
|
||||
"qr_payment_amount" : "QR code นี้มีจำนวนการชำระเงิน คุณต้องการเขียนทับค่าปัจจุบันหรือไม่?",
|
||||
|
||||
"copy_id" : "คัดลอก ID",
|
||||
"exchange_result_write_down_trade_id" : "โปรดคัดลอกหรือบันทึก ID ของการซื้อขายเพื่อดำเนินการต่อไป",
|
||||
"trade_id" : "ID การซื้อขาย:",
|
||||
"copied_to_clipboard" : "คัดลอกไปยังหน่วยความจำของคอมพิวเตอร์",
|
||||
"saved_the_trade_id" : "ฉันได้บันทึก ID ของการซื้อขายแล้ว",
|
||||
"fetching" : "กำลังโหลด",
|
||||
"id" : "ID: ",
|
||||
"amount" : "จำนวน: ",
|
||||
"payment_id" : "ID การชำระเงิน: ",
|
||||
"status" : "สถานะ: ",
|
||||
"offer_expires_in" : "ข้อเสนอจะหมดอายุใน: ",
|
||||
"trade_is_powered_by" : "การซื้อขายนี้จัดสร้างโดย ${provider}",
|
||||
"copy_address" : "คัดลอกที่อยู่",
|
||||
"exchange_result_confirm" : "โดยกดปุ่มยืนยัน, คุณจะส่ง ${fetchingLabel} ${from} จากกระเป๋าของคุณที่เรียกว่า ${walletName} ไปยังที่อยู่ที่แสดงข้างล่าง หรือคุณสามารถส่งจากกระเป๋าภายนอกไปยังที่อยู่/รหัส QR ด้านล่าง\n\nโปรดกดปุ่มยืนยันเพื่อดำเนินการต่อหรือกลับไปเปลี่ยนจำนวน",
|
||||
"exchange_result_description" : "คุณต้องส่งอย่างน้อย ${fetchingLabel} ${from} ไปยังที่อยู่ที่แสดงบนหน้าถัดไป หากคุณส่งจำนวนน้อยกว่า ${fetchingLabel} ${from} อาจจะไม่ถูกแปลงและอาจไม่ถูกเรียกคืน",
|
||||
"exchange_result_write_down_ID" : "*โปรดคัดลอกหรือเขียนรหัสของคุณด้านบน",
|
||||
"confirm" : "ยืนยัน",
|
||||
"confirm_sending" : "ยืนยันการส่ง",
|
||||
"commit_transaction_amount_fee" : "ยืนยันธุรกรรม\nจำนวน: ${amount}\nค่าธรรมเนียม: ${fee}",
|
||||
"sending" : "กำลังส่ง",
|
||||
"transaction_sent" : "ธุรกรรมถูกส่ง!",
|
||||
"expired" : "หมดอายุ",
|
||||
"time" : "${minutes}m ${seconds}s",
|
||||
"send_xmr" : "ส่ง XMR",
|
||||
"exchange_new_template" : "เทมเพลทใหม่",
|
||||
|
||||
"faq" : "คำถามที่พบบ่อย",
|
||||
|
||||
|
||||
"enter_your_pin" : "ใส่ PIN ของคุณ",
|
||||
"loading_your_wallet" : "กำลังโหลดกระเป๋าของคุณ",
|
||||
|
||||
|
||||
"new_wallet" : "กระเป๋าใหม่",
|
||||
"wallet_name" : "ชื่อกระเป๋า",
|
||||
"continue_text" : "ดำเนินการต่อ",
|
||||
"choose_wallet_currency" : "โปรดเลือกสกุลเงินของกระเป๋า:",
|
||||
|
||||
|
||||
"node_new" : "โหนดใหม่",
|
||||
"node_address" : "ที่อยู่โหนด",
|
||||
"node_port" : "พอร์ตโหนด",
|
||||
"login" : "เข้าสู่ระบบ",
|
||||
"password" : "รหัสผ่าน",
|
||||
"nodes" : "โหนด",
|
||||
"node_reset_settings_title" : "รีเซ็ตการตั้งค่า",
|
||||
"nodes_list_reset_to_default_message" : "คุณแน่ใจหรือว่าต้องการรีเซ็ตการตั้งค่าเป็นค่าเริ่มต้น?",
|
||||
"change_current_node" : "คุณแน่ใจหรือว่าต้องการเปลี่ยนโหนดปัจจุบันเป็น ${node}?",
|
||||
"change" : "เปลี่ยน",
|
||||
"remove_node" : "ลบโหนด",
|
||||
"remove_node_message" : "คุณแน่ใจหรือว่าต้องการลบโหนดที่เลือก?",
|
||||
"remove" : "ลบ",
|
||||
"delete" : "ลบ",
|
||||
"add_new_node" : "เพิ่มโหนดใหม่",
|
||||
"change_current_node_title" : "เปลี่ยนโหนดปัจจุบัน",
|
||||
"node_test" : "ทดสอบ",
|
||||
"node_connection_successful" : "เชื่อมต่อสำเร็จ",
|
||||
"node_connection_failed" : "เชื่อมต่อล้มเหลว",
|
||||
"new_node_testing" : "การทดสอบโหนดใหม่",
|
||||
|
||||
|
||||
"use" : "สลับไปที่ ",
|
||||
"digit_pin" : "-หลัก PIN",
|
||||
|
||||
|
||||
"share_address" : "แชร์ที่อยู่",
|
||||
"receive_amount" : "จำนวน",
|
||||
"subaddresses" : "ที่อยู่ย่อย",
|
||||
"addresses" : "ที่อยู่",
|
||||
"scan_qr_code" : "สแกน QR code เพื่อรับที่อยู่",
|
||||
"qr_fullscreen" : "แตะเพื่อเปิดหน้าจอ QR code แบบเต็มจอ",
|
||||
"rename" : "เปลี่ยนชื่อ",
|
||||
"choose_account" : "เลือกบัญชี",
|
||||
"create_new_account" : "สร้างบัญชีใหม่",
|
||||
"accounts_subaddresses" : "บัญชีและที่อยู่ย่อย",
|
||||
|
||||
|
||||
"restore_restore_wallet" : "กู้กระเป๋า",
|
||||
"restore_title_from_seed_keys" : "กู้จาก seed/keys",
|
||||
"restore_description_from_seed_keys" : "เรียกกระเป๋าของคุณกลับมาจาก seed/keys ที่คุณได้บันทึกไว้ในที่ปลอดภัย",
|
||||
"restore_next" : "ถัดไป",
|
||||
"restore_title_from_backup" : "กู้จากการสำรองข้อมูล",
|
||||
"restore_description_from_backup" : "คุณสามารถกู้แอพ Cake Wallet ทั้งหมดจากไฟล์สำรองข้อมูลของคุณ",
|
||||
"restore_seed_keys_restore" : "กู้จาก Seed/Keys",
|
||||
"restore_title_from_seed" : "กู้จาก seed",
|
||||
"restore_description_from_seed" : "กู้กระเป๋าของคุณจากรหัสผสมของ 25 คำหรือ 13 คำ",
|
||||
"restore_title_from_keys" : "กู้จาก keys",
|
||||
"restore_description_from_keys" : "กู้กระเป๋าของคุณจากการกดปุ่มที่สร้างขึ้นจาก private keys ของคุณที่บันทึกไว้",
|
||||
"restore_wallet_name" : "ชื่อกระเป๋า",
|
||||
"restore_address" : "ที่อยู่",
|
||||
"restore_view_key_private" : "คีย์สำหรับดู (ส่วนตัว)",
|
||||
"restore_spend_key_private" : "คีย์สำหรับใช้ (ส่วนตัว)",
|
||||
"restore_recover" : "กู้",
|
||||
"restore_wallet_restore_description" : "คำอธิบายการกู้กระเป๋า",
|
||||
"restore_new_seed" : "ซีดใหม่",
|
||||
"restore_active_seed" : "ซีดที่ใช้งานอยู่",
|
||||
"restore_bitcoin_description_from_seed" : "กู้กระเป๋าของคุณจากรหัสผสมของ 24 คำ",
|
||||
"restore_bitcoin_description_from_keys" : "กู้กระเป๋าของคุณจากสตริง WIF ที่สร้างขึ้นจากคีย์ส่วนตัวของคุณ",
|
||||
"restore_bitcoin_title_from_keys" : "กู้จาก WIF",
|
||||
"restore_from_date_or_blockheight" : "โปรดป้อนวันที่หลายวันก่อนที่คุณสร้างกระเป๋านี้ หรือหากคุณรู้ความสูงของบล็อก (blockheight) โปรดป้อนมันแทน",
|
||||
|
||||
|
||||
"seed_reminder" : "โปรดเขียนข้อมูลนี้ลงสมุดเพื่อความปลอดภัยหากคุณสูญเสียหรือล้างโทรศัพท์ของคุณ",
|
||||
"seed_title" : "Seed",
|
||||
"seed_share" : "แบ่งปัน seed",
|
||||
"copy" : "คัดลอก",
|
||||
|
||||
|
||||
"seed_language_choose" : "โปรดเลือกภาษาของ seed:",
|
||||
"seed_choose" : "เลือกภาษาของ seed",
|
||||
"seed_language_next" : "ถัดไป",
|
||||
"seed_language_english" : "อังกฤษ",
|
||||
"seed_language_chinese" : "จีน",
|
||||
"seed_language_dutch" : "ดัตช์",
|
||||
"seed_language_german" : "เยอรมัน",
|
||||
"seed_language_japanese" : "ญี่ปุ่น",
|
||||
"seed_language_portuguese" : "โปรตุเกส",
|
||||
"seed_language_russian" : "รัสเซีย",
|
||||
"seed_language_spanish" : "สเปน",
|
||||
"seed_language_french" : "ฝรั่งเศส",
|
||||
"seed_language_italian" : "อิตาลี",
|
||||
|
||||
|
||||
"send_title" : "ส่ง",
|
||||
"send_your_wallet" : "กระเป๋าของคุณ",
|
||||
"send_address" : "ที่อยู่ ${cryptoCurrency}",
|
||||
"send_payment_id" : "ID การชำระเงิน (ไม่จำเป็น)",
|
||||
"all" : "ทั้งหมด",
|
||||
"send_error_minimum_value" : "จำนวนขั้นต่ำของจำนวนเงินคือ 0.01",
|
||||
"send_error_currency" : "สกุลเงินสามารถเป็นเลขเท่านั้น",
|
||||
"send_estimated_fee" : "ค่าธรรมเนียมที่คาดการณ์:",
|
||||
"send_priority" : "ในขณะนี้ค่าธรรมเนียมถูกตั้งค่าเป็นความสำคัญ ${transactionPriority} \nความสำคัญของธุรกรรมสามารถปรับได้ในการตั้งค่า",
|
||||
"send_creating_transaction" : "กำลังสร้างธุรกรรม",
|
||||
"send_templates" : "แม่แบบ",
|
||||
"send_new" : "ใหม่",
|
||||
"send_amount" : "จำนวน:",
|
||||
"send_fee" : "ค่าธรรมเนียม:",
|
||||
"send_name" : "ชื่อ",
|
||||
"send_got_it" : "เข้าใจ",
|
||||
"send_sending" : "กำลังส่ง...",
|
||||
"send_success" : "คุณได้ส่ง ${crypto} เรียบร้อยแล้ว",
|
||||
|
||||
|
||||
"settings_title" : "การตั้งค่า",
|
||||
"settings_nodes" : "จุดเชื่อมต่อ",
|
||||
"settings_current_node" : "จุดเชื่อมต่อปัจจุบัน",
|
||||
"settings_wallets" : "กระเป๋าสตางค์",
|
||||
"settings_display_balance" : "แสดงยอดคงเหลือ",
|
||||
"settings_currency" : "สกุลเงิน",
|
||||
"settings_fee_priority" : "ความสำคัญของค่าธรรมเนียม",
|
||||
"settings_save_recipient_address" : "บันทึกที่อยู่ผู้รับ",
|
||||
"settings_personal" : "ส่วนตัว",
|
||||
"settings_change_pin" : "เปลี่ยน PIN",
|
||||
"settings_change_language" : "เปลี่ยนภาษา",
|
||||
"settings_allow_biometrical_authentication" : "อนุญาตให้ใช้การยืนยันตัวตนทางระบบชีวภาพ",
|
||||
"settings_dark_mode" : "โหมดดำ",
|
||||
"settings_transactions" : "ธุรกรรม",
|
||||
"settings_trades" : "การซื้อขาย",
|
||||
"settings_display_on_dashboard_list" : "แสดงบนรายการแดชบอร์ด",
|
||||
"settings_all" : "ทั้งหมด",
|
||||
"settings_only_trades" : "เฉพาะการซื้อขาย",
|
||||
"settings_only_transactions" : "เฉพาะธุรกรรม",
|
||||
"settings_none" : "ไม่มี",
|
||||
"settings_support" : "สนับสนุน",
|
||||
"settings_terms_and_conditions" : "ข้อกำหนดและเงื่อนไข",
|
||||
"pin_is_incorrect" : "PIN ไม่ถูกต้อง",
|
||||
|
||||
|
||||
"setup_pin" : "ตั้งค่า PIN",
|
||||
"enter_your_pin_again" : "ใส่ PIN ของคุณอีกครั้ง",
|
||||
"setup_successful" : "การตั้งค่า PIN ของคุณสำเร็จแล้ว!",
|
||||
|
||||
"wallet_keys" : "ซีดของกระเป๋า/คีย์",
|
||||
"wallet_seed" : "ซีดของกระเป๋า",
|
||||
"private_key" : "คีย์ส่วนตัว",
|
||||
"public_key" : "คีย์สาธารณะ",
|
||||
"view_key_private" : "คีย์มุมมอง (ส่วนตัว)",
|
||||
"view_key_public" : "คีย์มุมมอง (สาธารณะ)",
|
||||
"spend_key_private" : "คีย์จ่าย (ส่วนตัว)",
|
||||
"spend_key_public" : "คีย์จ่าย (สาธารณะ)",
|
||||
"copied_key_to_clipboard" : "คัดลอก ${key} ไปยัง Clipboard แล้ว",
|
||||
|
||||
|
||||
"new_subaddress_title" : "ที่อยู่ใหม่",
|
||||
"new_subaddress_label_name" : "ชื่อป้ายกำกับ",
|
||||
"new_subaddress_create" : "สร้าง",
|
||||
|
||||
"address_label" : "ป้ายกำกับที่อยู่",
|
||||
|
||||
"subaddress_title" : "รายการที่อยู่ย่อย",
|
||||
|
||||
"trade_details_title" : "รายละเอียดการแลกเปลี่ยน",
|
||||
"trade_details_id" : "รหัส",
|
||||
"trade_details_state" : "สถานะ",
|
||||
"trade_details_fetching" : "กำลังเรียกข้อมูล",
|
||||
"trade_details_provider" : "ผู้ให้บริการ",
|
||||
"trade_details_created_at" : "สร้างเมื่อ",
|
||||
"trade_details_pair" : "คู่",
|
||||
"trade_details_copied" : "${title} คัดลอกไปยัง Clipboard",
|
||||
|
||||
|
||||
"trade_history_title" : "ประวัติการซื้อขาย",
|
||||
|
||||
|
||||
"transaction_details_title" : "รายละเอียดการทำรายการ",
|
||||
"transaction_details_transaction_id" : "ไอดีการทำรายการ",
|
||||
"transaction_details_date" : "วันที่",
|
||||
"transaction_details_height" : "ความสูง",
|
||||
"transaction_details_amount" : "จำนวน",
|
||||
"transaction_details_fee" : "ค่าธรรมเนียม",
|
||||
"transaction_details_copied" : "${title} ถูกคัดลอกไปยังคลิปบอร์ด",
|
||||
"transaction_details_recipient_address" : "ที่อยู่ผู้รับ",
|
||||
|
||||
|
||||
"wallet_list_title" : "กระเป๋า Monero",
|
||||
"wallet_list_create_new_wallet" : "สร้างกระเป๋าใหม่",
|
||||
"wallet_list_restore_wallet" : "กู้กระเป๋า",
|
||||
"wallet_list_load_wallet" : "โหลดกระเป๋า",
|
||||
"wallet_list_loading_wallet" : "กำลังโหลดกระเป๋า ${wallet_name}",
|
||||
"wallet_list_failed_to_load" : "ไม่สามารถโหลดกระเป๋า ${wallet_name} ได้ ${error}",
|
||||
"wallet_list_removing_wallet" : "กำลังลบกระเป๋า ${wallet_name}",
|
||||
"wallet_list_failed_to_remove" : "ไม่สามารถลบกระเป๋า ${wallet_name} ได้ ${error}",
|
||||
|
||||
|
||||
"widgets_address" : "ที่อยู่",
|
||||
"widgets_restore_from_blockheight" : "กู้คืนจากระดับบล็อก",
|
||||
"widgets_restore_from_date" : "กู้คืนจากวันที่",
|
||||
"widgets_or" : "หรือ",
|
||||
"widgets_seed" : "ซีด",
|
||||
|
||||
|
||||
"router_no_route" : "ไม่มีเส้นทางที่กำหนดไว้สำหรับ ${name}",
|
||||
|
||||
|
||||
"error_text_account_name" : "ชื่อบัญชีสามารถเป็นเพียงตัวอักษรหรือตัวเลขเท่านั้น\nและต้องมีความยาวระหว่าง 1 ถึง 15 ตัวอักษร",
|
||||
"error_text_contact_name" : "ชื่อผู้ติดต่อไม่สามารถมีสัญลักษณ์ ` , '\" ได้\nและต้องมีความยาวระหว่าง 1 ถึง 32 ตัวอักษร",
|
||||
"error_text_address" : "ที่อยู่กระเป๋าจะต้องสอดคล้องกับประเภท\nของเหรียญคริปโตเนียม",
|
||||
"error_text_node_address" : "โปรดป้อนที่อยู่ iPv4",
|
||||
"error_text_node_port" : "พอร์ตโหนดสามารถมีตัวเลขเท่านั้นระหว่าง 0 ถึง 65535",
|
||||
"error_text_payment_id" : "Payment ID สามารถมีขนาดระหว่าง 16 ถึง 64 ตัวอักษรตามแบบ hex",
|
||||
"error_text_xmr" : "มูลค่า XMR ไม่สามารถเกินยอดคงเหลือได้\nจำนวนสตริงทศนิยมต้องน้อยกว่าหรือเท่ากับ 12",
|
||||
"error_text_fiat" : "มูลค่าของจำนวนเงินไม่สามารถเกินยอดคงเหลือได้\nจำนวนสตริงทศนิยมต้องน้อยกว่าหรือเท่ากับ 2",
|
||||
"error_text_subaddress_name" : "ชื่อสำหรับที่อยู่ย่อยจะต้องประกอบด้วยตัวอักษร ตัวเลข และสัญลักษณ์ _ - และมีความยาวระหว่าง 1 ถึง 20 ตัวอักษร",
|
||||
"error_text_amount" : "จำนวนจะต้องประกอบด้วยตัวเลขเท่านั้น",
|
||||
"error_text_wallet_name" : "ชื่อกระเป๋าสตางค์จะต้องประกอบด้วยตัวอักษร ตัวเลข และสัญลักษณ์ _ - และมีความยาวระหว่าง 1 ถึง 33 ตัวอักษร",
|
||||
"error_text_keys" : "คีย์ของกระเป๋าสตางค์จะต้องประกอบด้วยตัวอักษรฐาน 16 จำนวน 64 ตัว",
|
||||
"error_text_crypto_currency" : "จำนวนทศนิยมจะต้องน้อยกว่าหรือเท่ากับ 12",
|
||||
"error_text_minimal_limit" : "การซื้อขายกับ ${provider} ไม่สามารถดำเนินการได้ จำนวนน้อยกว่าขั้นต่ำ: ${min} ${currency}",
|
||||
"error_text_maximum_limit" : "การซื้อขายกับ ${provider} ไม่สามารถดำเนินการได้ จำนวนมากกว่าขั้นสูง: ${max} ${currency}",
|
||||
"error_text_limits_loading_failed" : "การซื้อขายกับ ${provider} ไม่สามารถดำเนินการได้ ไม่สามารถโหลดขอบเขตได้",
|
||||
"error_text_template" : "ชื่อแม่แบบและที่อยู่ไม่สามารถมีสัญลักษณ์ ` , '\" และต้องมีความยาวระหว่าง 1 ถึง 106 ตัวอักษร",
|
||||
|
||||
|
||||
"auth_store_ban_timeout" : "หมดเวลาห้าม",
|
||||
"auth_store_banned_for" : "ถูกห้ามสำหรับ ",
|
||||
"auth_store_banned_minutes" : " นาที",
|
||||
"auth_store_incorrect_password" : "รหัสผ่านไม่ถูกต้อง",
|
||||
"wallet_store_monero_wallet" : "กระเป๋า Monero",
|
||||
"wallet_restoration_store_incorrect_seed_length" : "ความยาวของซีดไม่ถูกต้อง",
|
||||
|
||||
|
||||
"full_balance" : "ยอดคงเหลือทั้งหมด",
|
||||
"available_balance" : "ยอดคงเหลือที่ใช้งานได้",
|
||||
"hidden_balance" : "ยอดคงเหลือซ่อนอยู่",
|
||||
|
||||
|
||||
"sync_status_syncronizing" : "กำลังซิงโครไนซ์",
|
||||
"sync_status_syncronized" : "ซิงโครไนซ์แล้ว",
|
||||
"sync_status_not_connected" : "ไม่ได้เชื่อมต่อ",
|
||||
"sync_status_starting_sync" : "กำลังเริ่มซิงโครไนซ์",
|
||||
"sync_status_failed_connect" : "การเชื่อมต่อล้มเหลว",
|
||||
"sync_status_connecting" : "กำลังเชื่อมต่อ",
|
||||
"sync_status_connected" : "เชื่อมต่อแล้ว",
|
||||
"sync_status_attempting_sync" : "พยายามซิงโครไนซ์",
|
||||
|
||||
|
||||
"transaction_priority_slow" : "ช้า",
|
||||
"transaction_priority_regular" : "ปกติ",
|
||||
"transaction_priority_medium" : "ปานกลาง",
|
||||
"transaction_priority_fast" : "เร็ว",
|
||||
"transaction_priority_fastest" : "เร็วที่สุด",
|
||||
|
||||
|
||||
"trade_for_not_created" : "การแลกเปลี่ยนสำหรับ ${title} ยังไม่ได้ถูกสร้างขึ้น",
|
||||
"trade_not_created" : "การแลกเปลี่ยนยังไม่ได้ถูกสร้าง",
|
||||
"trade_id_not_found" : "ไม่พบการแลกเปลี่ยน ${tradeId} ของ ${title}",
|
||||
"trade_not_found" : "ไม่พบการแลกเปลี่ยน",
|
||||
|
||||
|
||||
"trade_state_pending" : "รอดำเนินการ",
|
||||
"trade_state_confirming" : "กำลังยืนยัน",
|
||||
"trade_state_trading" : "กำลังแลกเปลี่ยน",
|
||||
"trade_state_traded" : "ถูกแลกเปลี่ยน",
|
||||
"trade_state_complete" : "เสร็จสมบูรณ์",
|
||||
"trade_state_to_be_created" : "จะถูกสร้าง",
|
||||
"trade_state_unpaid" : "ยังไม่ได้จ่าย",
|
||||
"trade_state_underpaid" : "จ่ายไม่ครบ",
|
||||
"trade_state_paid_unconfirmed" : "จ่ายแล้วแต่ยังไม่ได้ยืนยัน",
|
||||
"trade_state_paid" : "จ่ายแล้ว",
|
||||
"trade_state_btc_sent" : "ส่ง BTC แล้ว",
|
||||
"trade_state_timeout" : "เวลาหมด",
|
||||
"trade_state_created" : "ถูกสร้าง",
|
||||
"trade_state_finished" : "เสร็จสิ้น",
|
||||
|
||||
"change_language" : "เปลี่ยนภาษา",
|
||||
"change_language_to" : "เปลี่ยนภาษาเป็น ${language}?",
|
||||
|
||||
"paste" : "วาง",
|
||||
"restore_from_seed_placeholder" : "โปรดป้อนหรือวาง seed ของคุณที่นี่",
|
||||
"add_new_word" : "เพิ่มคำใหม่",
|
||||
"incorrect_seed" : "ข้อความที่ป้อนไม่ถูกต้อง",
|
||||
|
||||
"biometric_auth_reason" : "สแกนลายนิ้วมือของคุณเพื่อยืนยันตัวตน",
|
||||
"version" : "เวอร์ชัน ${currentVersion}",
|
||||
|
||||
"openalias_alert_title" : "พบที่อยู่",
|
||||
"openalias_alert_content" : "คุณกำลังจะส่งเงินไปยัง\n${recipient_name}",
|
||||
|
||||
"card_address" : "ที่อยู่:",
|
||||
"buy" : "ซื้อ",
|
||||
"sell": "ขาย",
|
||||
|
||||
"placeholder_transactions" : "ธุรกรรมของคุณจะปรากฏที่นี่",
|
||||
"placeholder_contacts" : "รายชื่อผู้ติดต่อของคุณจะปรากฏที่นี่",
|
||||
|
||||
"template" : "แบบฟอร์ม",
|
||||
"confirm_delete_template" : "การดำเนินการนี้จะลบแบบฟอร์มนี้ คุณต้องการดำเนินการต่อหรือไม่?",
|
||||
"confirm_delete_wallet" : "การดำเนินการนี้จะลบกระเป๋านี้ คุณต้องการดำเนินการต่อหรือไม่?",
|
||||
|
||||
"picker_description" : "ในการเลือก ChangeNOW หรือ MorphToken โปรดเปลี่ยนคู่แลกเปลี่ยนก่อน",
|
||||
|
||||
"change_wallet_alert_title" : "เปลี่ยนกระเป๋าปัจจุบัน",
|
||||
"change_wallet_alert_content" : "คุณต้องการเปลี่ยนกระเป๋าปัจจุบันเป็น ${wallet_name} หรือไม่?",
|
||||
|
||||
"creating_new_wallet" : "กำลังสร้างกระเป๋าใหม่",
|
||||
"creating_new_wallet_error" : "ข้อผิดพลาด: ${description}",
|
||||
|
||||
"seed_alert_title" : "ความสนใจ",
|
||||
"seed_alert_content" : "Seed เป็นเพียงวิธีเดียวที่จะกู้กระเป๋าของคุณ คุณได้เขียนมันขึ้นลงกระดาษหรือไม่?",
|
||||
"seed_alert_back" : "กลับ",
|
||||
"seed_alert_yes" : "ใช่ ฉันได้เขียน",
|
||||
|
||||
"exchange_sync_alert_content" : "โปรดรอจนกว่ากระเป๋าของคุณจะถูกซิงค์",
|
||||
|
||||
"pre_seed_title" : "สำคัญ",
|
||||
"pre_seed_description" : "บนหน้าถัดไปคุณจะเห็นชุดของคำ ${words} คำ นี่คือ seed ของคุณที่ไม่ซ้ำใดๆ และเป็นความลับเพียงของคุณ และนี่คือเพียงวิธีเดียวที่จะกู้กระเป๋าของคุณในกรณีที่สูญหายหรือมีปัญหา มันเป็นความรับผิดชอบของคุณเพื่อเขียนมันลงบนกระดาษและจัดเก็บไว้ในที่ปลอดภัยนอกแอป Cake Wallet",
|
||||
"pre_seed_button_text" : "ฉันเข้าใจ แสดง seed ของฉัน",
|
||||
|
||||
"xmr_to_error" : "ข้อผิดพลาด XMR.TO",
|
||||
"xmr_to_error_description" : "จำนวนไม่ถูกต้อง จำกัดขั้นสูง 8 หลักหลังจุดทศนิยม",
|
||||
|
||||
"provider_error" : "ข้อผิดพลาด ${provider}",
|
||||
|
||||
"use_ssl" : "ใช้ SSL",
|
||||
"trusted" : "มั่นคง",
|
||||
|
||||
"color_theme" : "ธีมสี",
|
||||
"light_theme" : "สว่าง",
|
||||
"bright_theme" : "สดใส",
|
||||
"dark_theme" : "เข้ม",
|
||||
"enter_your_note" : "ใส่บันทึกของคุณ...",
|
||||
"note_optional" : "บันทึก (ไม่จำเป็น)",
|
||||
"note_tap_to_change" : "หมายเหตุ (กดเพื่อเปลี่ยน)",
|
||||
"view_in_block_explorer" : "ดูใน Block Explorer",
|
||||
"view_transaction_on" : "ดูการทำธุรกรรมบน ",
|
||||
"transaction_key" : "รหัสธุรกรรม",
|
||||
"confirmations" : "การยืนยัน",
|
||||
"recipient_address" : "ที่อยู่ผู้รับ",
|
||||
|
||||
"extra_id" : "ไอดีเพิ่มเติม:",
|
||||
"destination_tag" : "แท็กปลายทาง:",
|
||||
"memo" : "หมายเหตุ:",
|
||||
|
||||
"backup" : "สำรองข้อมูล",
|
||||
"change_password" : "เปลี่ยนรหัสผ่าน",
|
||||
"backup_password" : "รหัสผ่านสำรองข้อมูล",
|
||||
"write_down_backup_password" : "โปรดจดรหัสผ่านสำรองข้อมูลของคุณลงบนกระดาษ ซึ่งจะใช้ในการนำเข้าไฟล์สำรองข้อมูลของคุณ",
|
||||
"export_backup" : "ส่งออกข้อมูลสำรอง",
|
||||
"save_backup_password" : "โปรดตรวจสอบให้แน่ใจว่าคุณได้บันทึกรหัสผ่านสำรองข้อมูลแล้ว คุณจะไม่สามารถนำเข้าไฟล์สำรองข้อมูลของคุณโดยไม่ใช้รหัสผ่านนั้น",
|
||||
"backup_file" : "ไฟล์สำรองข้อมูล",
|
||||
|
||||
"edit_backup_password" : "แก้ไขรหัสผ่านสำรอง",
|
||||
"save_backup_password_alert" : "บันทึกรหัสผ่านสำรอง",
|
||||
"change_backup_password_alert" : "ไฟล์สำรองที่ผ่านมาจะไม่สามารถนำเข้าด้วยรหัสผ่านสำรองใหม่ได้ รหัสผ่านสำรองใหม่จะถูกใช้เฉพาะสำหรับไฟล์สำรองใหม่ คุณแน่ใจหรือว่าต้องการเปลี่ยนรหัสผ่านสำรอง?",
|
||||
|
||||
"enter_backup_password" : "ป้อนรหัสผ่านสำรองที่นี่",
|
||||
"select_backup_file" : "เลือกไฟล์สำรอง",
|
||||
"import" : "นำเข้า",
|
||||
"please_select_backup_file" : "โปรดเลือกไฟล์สำรองและป้อนรหัสผ่านสำรอง",
|
||||
|
||||
"fixed_rate": "อัตราคงที่",
|
||||
"fixed_rate_alert": "คุณจะสามารถป้อนจำนวนที่ได้รับเมื่อเลือกโหมดอัตราคงที่ คุณต้องการสลับไปที่โหมดอัตราคงที่?",
|
||||
|
||||
"xlm_extra_info": "โปรดอย่าลืมระบุ Memo ID ในขณะที่ส่งธุรกรรม XLM สำหรับการแลกเปลี่ยน",
|
||||
"xrp_extra_info": "โปรดอย่าลืมระบุ Destination Tag ในขณะที่ส่งธุรกรรม XRP สำหรับการแลกเปลี่ยน",
|
||||
|
||||
"exchange_incorrect_current_wallet_for_xmr" : "หากคุณต้องการแลกเปลี่ยน XMR จากยอดคงเหลือ Monero ใน Cake Wallet ของคุณ กรุณาเปลี่ยนเป็นกระเป๋า Monero ก่อน",
|
||||
"confirmed" : "ได้รับการยืนยัน",
|
||||
"unconfirmed" : "ยังไม่ได้รับการยืนยัน",
|
||||
"displayable" : "สามารถแสดงได้",
|
||||
|
||||
"submit_request" : "ส่งคำขอ",
|
||||
|
||||
"buy_alert_content" : "ในปัจจุบันเรารองรับการซื้อ Bitcoin และ Litecoin เท่านั้น หากต้องการซื้อ Bitcoin หรือ Litecoin โปรดสร้างหรือเปลี่ยนเป็นกระเป๋า Bitcoin หรือ Litecoin ของคุณ",
|
||||
"sell_alert_content" : "ในปัจจุบันเรารองรับการขาย Bitcoin เท่านั้น หากต้องการขาย Bitcoin โปรดสร้างหรือเปลี่ยนเป็นกระเป๋า Bitcoin ของคุณ",
|
||||
|
||||
"outdated_electrum_wallet_description" : "กระเป๋า Bitcoin ใหม่ที่สร้างใน Cake มี seed ขนาด 24 คำ ซึ่งจำเป็นต้องสร้างกระเป๋า Bitcoin ใหม่และโอนทุกเงินของคุณไปยังกระเป๋าใหม่ขนาด 24 คำ และหยุดใช้กระเป๋าที่มี seed ขนาด 12 คำ กรุณาทำด่วนเพื่อรักษาเงินของคุณ",
|
||||
"understand" : "ฉันเข้าใจ",
|
||||
|
||||
"apk_update" : "ปรับปรุง APK",
|
||||
|
||||
"buy_bitcoin" : "ซื้อ Bitcoin",
|
||||
"buy_with" : "ซื้อด้วย",
|
||||
"moonpay_alert_text" : "มูลค่าของจำนวนต้องมากกว่าหรือเท่ากับ ${minAmount} ${fiatCurrency}",
|
||||
|
||||
"outdated_electrum_wallet_receive_warning": "หากกระเป๋านี้มีซีดีที่มี 12 คำและถูกสร้างขึ้นใน Cake อย่าโอน Bitcoin เข้ากระเป๋านี้ ทุกจำนวน BTC ที่โอนเข้ากระเป๋านี้อาจสูญหาย สร้างกระเป๋าใหม่ที่มีซีดีที่มี 24 คำ (กดที่เมนูที่มุมขวาบนแล้วเลือก Wallets และเลือก Create New Wallet จากนั้นเลือก Bitcoin) และย้าย BTC ไปที่นั้นทันที กระเป๋า BTC ที่มีซีดีที่มี 24 คำของ Cake ปลอดภัย",
|
||||
"do_not_show_me": "อย่าแสดงข้อความนี้อีก",
|
||||
|
||||
"unspent_coins_title" : "เหรียญที่ไม่ได้ใช้",
|
||||
"unspent_coins_details_title" : "รายละเอียดเหรียญที่ไม่ได้ใช้",
|
||||
"freeze" : "ดักจับ",
|
||||
"frozen" : "ถูกดักจับ",
|
||||
"coin_control" : "การควบคุมเหรียญ (ตัวเลือก)",
|
||||
|
||||
"address_detected" : "ตรวจพบที่อยู่",
|
||||
"address_from_domain" : "ที่อยู่นี้มาจาก ${domain} บน Unstoppable Domains",
|
||||
|
||||
"add_receiver" : "เพิ่มผู้รับอื่น ๆ (ตัวเลือก)",
|
||||
|
||||
"manage_yats" : "จัดการ Yats",
|
||||
"yat_alert_title" : "ส่งและรับเหรียญออนไลน์ง่ายขึ้นด้วย Yat",
|
||||
"yat_alert_content" : "ผู้ใช้งาน Cake Wallet สามารถส่งและรับเหรียญออนไลน์ทุกเหรียญที่ชื่นชอบของพวกเขาได้ง่ายขึ้นด้วยชื่อผู้ใช้งานที่พิเศษที่ระบุด้วยอีโมจิ",
|
||||
"get_your_yat" : "รับ Yat ของคุณ",
|
||||
"connect_an_existing_yat" : "เชื่อมต่อ Yat ที่มีอยู่",
|
||||
"connect_yats": "เชื่อมต่อ Yats",
|
||||
"yat_address" : "ที่อยู่ Yat",
|
||||
"yat" : "Yat",
|
||||
"address_from_yat" : "ที่อยู่นี้มาจาก ${emoji} บน Yat",
|
||||
"yat_error" : "ข้อผิดพลาดของ Yat",
|
||||
"yat_error_content" : "ไม่มีที่อยู่ที่เชื่อมต่อกับ Yat นี้ ลองใช้ Yat อื่น",
|
||||
"choose_address" : "\n\nโปรดเลือกที่อยู่:",
|
||||
"yat_popup_title" : "ที่อยู่กระเป๋าของคุณสามารถถูกอัปโหลดเป็นอิโมจิ",
|
||||
"yat_popup_content" : "ขณะนี้คุณสามารถส่งและรับเหรียญคริปโตใน Cake Wallet ด้วย Yat ของคุณ - ชื่อผู้ใช้ที่สั้นมีอิโมจิ คุณสามารถจัดการ Yat ได้ทุกเวลาบนหน้าจอการตั้งค่า",
|
||||
"second_intro_title" : "อิโมจิที่อยู่เดียวที่จะควบคุมพวกเขาทั้งหมด",
|
||||
"second_intro_content" : "Yat ของคุณเป็นอิโมจิที่อยู่เดียวที่จะแทนที่ทุกที่อยู่และเลขฐานสิบหกของคุณสำหรับเหรียญคริปโตทุกชนิด",
|
||||
"third_intro_title" : "Yat ปฏิบัติตนอย่างดีกับผู้อื่น",
|
||||
"third_intro_content" : "Yat อาศัยอยู่นอก Cake Wallet ด้วย ที่อยู่กระเป๋าใดๆ ทั่วโลกสามารถแทนด้วย Yat ได้อีกด้วย!",
|
||||
"learn_more" : "ศึกษาเพิ่มเติม",
|
||||
"search": "ค้นหา",
|
||||
"search_language": "ค้นหาภาษา",
|
||||
"search_currency": "ค้นหาสกุลเงิน",
|
||||
"new_template" : "แม่แบบใหม่",
|
||||
"electrum_address_disclaimer": "เราสร้างที่อยู่ใหม่ทุกครั้งที่คุณใช้หนึ่งอย่าง แต่ที่อยู่เก่ายังสามารถใช้ได้ต่อไป",
|
||||
"wallet_name_exists": "กระเป๋าที่มีชื่อนี้มีอยู่แล้ว โปรดเลือกชื่ออื่นหรือเปลี่ยนชื่อกระเป๋าอื่นก่อน",
|
||||
"market_place": "ตลาดพื้นที่",
|
||||
"cake_pay_title": "บัตรของขวัญ Cake Pay",
|
||||
"cake_pay_subtitle": "ซื้อบัตรของขวัญราคาถูก (สำหรับสหรัฐอเมริกาเท่านั้น)",
|
||||
"cake_pay_web_cards_title": "Cake Pay Web Cards",
|
||||
"cake_pay_web_cards_subtitle": "ซื้อบัตรพร้อมเงินระดับโลกและบัตรของขวัญ",
|
||||
"about_cake_pay": "Cake Pay ช่วยให้คุณสามารถซื้อบัตรของขวัญง่ายๆ ด้วยการใช้สินทรัพย์อนุกรม ซื้อใช้ได้ทันทีกับมากกว่า 150,000 ร้านค้าในสหรัฐอเมริกา",
|
||||
"cake_pay_account_note": "ลงทะเบียนด้วยอีเมลเพียงอย่างเดียวเพื่อดูและซื้อบัตร บางบัตรอาจมีส่วนลด!",
|
||||
"already_have_account": "มีบัญชีอยู่แล้ว?",
|
||||
"create_account": "สร้างบัญชี",
|
||||
"privacy_policy": "นโยบายความเป็นส่วนตัว",
|
||||
"welcome_to_cakepay": "ยินดีต้อนรับสู่ Cake Pay!",
|
||||
"sign_up": "สมัครสมาชิก",
|
||||
"forgot_password": "ลืมรหัสผ่าน",
|
||||
"reset_password": "รีเซ็ตรหัสผ่าน",
|
||||
"gift_cards": "บัตรของขวัญ",
|
||||
"setup_your_debit_card": "ตั้งค่าบัตรเดบิตของคุณ",
|
||||
"no_id_required": "ไม่จำเป็นต้องใช้บัตรประจำตัว ฝากเงินและใช้งานได้ทุกที่",
|
||||
"how_to_use_card": "วิธีใช้บัตรนี้",
|
||||
"purchase_gift_card": "ซื้อบัตรของขวัญ",
|
||||
"verification": "การตรวจสอบ",
|
||||
"fill_code": "โปรดกรอกรหัสยืนยันที่ส่งไปยังอีเมลของคุณ",
|
||||
"dont_get_code": "ไม่ได้รับรหัส?",
|
||||
"resend_code": "โปรดส่งอีกครั้ง",
|
||||
"debit_card": "บัตรเดบิต",
|
||||
"cakepay_prepaid_card": "บัตรเดบิตเติมเงินของ CakePay",
|
||||
"no_id_needed": "ไม่จำเป็นต้องใช้บัตรประชาชน!",
|
||||
"frequently_asked_questions": "คำถามที่พบบ่อย",
|
||||
"debit_card_terms": "การเก็บรักษาและใช้หมายเลขบัตรจ่ายเงิน (และข้อมูลประจำตัวที่เกี่ยวข้องกับหมายเลขบัตรจ่ายเงิน) ในกระเป๋าดิจิทัลนี้ จะต้องยึดถือข้อกำหนดและเงื่อนไขของข้อตกลงผู้ใช้บัตรของผู้ถือบัตรที่เกี่ยวข้องกับบัตรผู้ถือบัตร ซึ่งจะมีผลตั้งแต่เวลานั้น",
|
||||
"please_reference_document": "โปรดอ้างอิงเอกสารด้านล่างสำหรับข้อมูลเพิ่มเติม",
|
||||
"cardholder_agreement": "ข้อตกลงผู้ใช้บัตร",
|
||||
"e_sign_consent": "การยอมรับ E-Sign",
|
||||
"agree_and_continue": "ยอมรับและดำเนินการต่อ",
|
||||
"email_address": "ที่อยู่อีเมล",
|
||||
"agree_to": "การสร้างบัญชีของคุณยอมรับเงื่อนไขของ",
|
||||
"and": "และ",
|
||||
"enter_code": "กรอกรหัส",
|
||||
"congratulations": "ขอแสดงความยินดี!",
|
||||
"you_now_have_debit_card": "ขณะนี้คุณมีบัตรเดบิต",
|
||||
"min_amount": "จำนวนขั้นต่ำ: ${value}",
|
||||
"max_amount": "จำนวนสูงสุด: ${value}",
|
||||
"enter_amount": "กรอกจำนวน",
|
||||
"billing_address_info": "ถ้าถูกร้องขอที่อยู่สำหรับการวางบิล ให้ใช้ที่อยู่จัดส่งของคุณ",
|
||||
"order_physical_card": "สั่งซื้อบัตรดิบิต",
|
||||
"add_value": "เพิ่มมูลค่า",
|
||||
"activate": "เปิดใช้งาน",
|
||||
"get_a": "รับ ",
|
||||
"digital_and_physical_card": "บัตรเดบิตดิจิตอลและบัตรพื้นฐาน",
|
||||
"get_card_note": "ที่คุณสามารถเติมเงินด้วยสกุลเงินดิจิตอล ไม่จำเป็นต้องใส่ข้อมูลเพิ่มเติม!",
|
||||
"signup_for_card_accept_terms": "ลงทะเบียนสำหรับบัตรและยอมรับเงื่อนไข",
|
||||
"add_fund_to_card": "เพิ่มเงินสำรองไว้บนบัตร (ถึง ${value})",
|
||||
"use_card_info_two": "เงินจะถูกแปลงค่าเป็นดอลลาร์สหรัฐเมื่อถือไว้ในบัญชีสำรองเงิน ไม่ใช่สกุลเงินดิจิตอล",
|
||||
"use_card_info_three": "ใช้บัตรดิจิตอลออนไลน์หรือผ่านวิธีการชำระเงินแบบไม่ต้องใช้บัตรกระดาษ",
|
||||
"optionally_order_card": "เลือกเพิ่มสั่งการ์ดจริง",
|
||||
"hide_details" : "ซ่อนรายละเอียด",
|
||||
"show_details" : "แสดงรายละเอียด",
|
||||
"upto": "สูงสุด ${value}",
|
||||
"discount": "ประหยัด ${value}%",
|
||||
"gift_card_amount": "จำนวนบัตรของขวัญ",
|
||||
"bill_amount": "จำนวนบิล",
|
||||
"you_pay": "คุณจ่าย",
|
||||
"tip": "เพิ่มค่าตอบแทน:",
|
||||
"custom": "กำหนดเอง",
|
||||
"by_cake_pay": "โดย Cake Pay",
|
||||
"expires": "หมดอายุ",
|
||||
"mm": "เดือน",
|
||||
"yy": "ปี",
|
||||
"online": "ออนไลน์",
|
||||
"offline": "ออฟไลน์",
|
||||
"gift_card_number": "หมายเลขบัตรของขวัญ",
|
||||
"pin_number": "หมายเลข PIN",
|
||||
"total_saving": "ประหยัดรวม",
|
||||
"last_30_days": "30 วันล่าสุด",
|
||||
"avg_savings": "ประหยัดเฉลี่ย",
|
||||
"view_all": "ดูทั้งหมด",
|
||||
"active_cards": "บัตรที่ใช้งานได้",
|
||||
"delete_account": "ลบบัญชี",
|
||||
"cards": "บัตร",
|
||||
"active": "ทำงาน",
|
||||
"redeemed": "แลกของขวัญ",
|
||||
"gift_card_balance_note": "บัตรของขวัญที่มียอดคงเหลือจะปรากฏที่นี่",
|
||||
"gift_card_redeemed_note": "บัตรของขวัญที่คุณแลกไปแล้วจะปรากฏที่นี่",
|
||||
"logout": "ออกจากระบบ",
|
||||
"add_tip": "เพิ่มคำแนะนำ",
|
||||
"percentageOf": "${amount} ของ",
|
||||
"is_percentage": "เป็น",
|
||||
"search_category": "ค้นหาหมวดหมู่",
|
||||
"mark_as_redeemed": "ทำเครื่องหมายว่าเคยใช้แล้ว",
|
||||
"more_options": "ตัวเลือกเพิ่มเติม",
|
||||
"awaiting_payment_confirmation": "รอการยืนยันการชำระเงิน",
|
||||
"transaction_sent_notice": "ถ้าหน้าจอไม่ขึ้นหลังจาก 1 นาทีแล้ว ให้ตรวจสอบ block explorer และอีเมลของคุณ",
|
||||
"agree": "ยอมรับ",
|
||||
"in_store": "ในร้าน",
|
||||
"generating_gift_card": "กำลังสร้างบัตรของขวัญ",
|
||||
"payment_was_received": "การชำระเงินของคุณได้รับการรับทราบแล้ว",
|
||||
"proceed_after_one_minute": "หากหน้าจอไม่ดำเนินการหลังจาก 1 นาทีโปรดตรวจสอบอีเมลของคุณ",
|
||||
"order_id": "เลขที่ออร์เดอร์",
|
||||
"gift_card_is_generated": "บัตรของขวัญถูกสร้างขึ้น",
|
||||
"open_gift_card": "เปิดบัตรของขวัญ",
|
||||
"contact_support": "ติดต่อฝ่ายสนับสนุน",
|
||||
"gift_cards_unavailable": "บัตรของขวัญจะมีจำหน่ายเฉพาะกับ Monero, Bitcoin, และ Litecoin เท่านั้นในขณะนี้",
|
||||
"introducing_cake_pay": "ยินดีต้อนรับสู่ Cake Pay!",
|
||||
"cake_pay_learn_more": "ซื้อและเบิกบัตรของขวัญในแอพพลิเคชันทันที!\nกระแทกขวาไปซ้ายเพื่อเรียนรู้เพิ่มเติม",
|
||||
"automatic": "อัตโนมัติ",
|
||||
"fixed_pair_not_supported": "คู่ความสัมพันธ์ที่ถูกกำหนดไว้นี้ไม่สนับสนุนกับหุ้นที่เลือก",
|
||||
"variable_pair_not_supported": "คู่ความสัมพันธ์ที่เปลี่ยนแปลงได้นี้ไม่สนับสนุนกับหุ้นที่เลือก",
|
||||
"none_of_selected_providers_can_exchange": "ไม่มีผู้ให้บริการที่เลือกที่สามารถแลกเปลี่ยนนี้ได้",
|
||||
"choose_one": "เลือกหนึ่งรายการ",
|
||||
"choose_from_available_options": "เลือกจากตัวเลือกที่มีอยู่:",
|
||||
"custom_redeem_amount": "จำนวนรับคืนที่กำหนดเอง",
|
||||
"add_custom_redemption": "เพิ่มการรับคืนที่กำหนดเอง",
|
||||
"remaining": "เหลืออยู่",
|
||||
"delete_wallet": "ลบกระเป๋า",
|
||||
"delete_wallet_confirm_message" : "คุณแน่ใจหรือว่าต้องการลบกระเป๋า${wallet_name}?",
|
||||
"low_fee": "ค่าธรรมเนียมต่ำ",
|
||||
"low_fee_alert": "ขณะนี้คุณกำลังใช้ค่าธรรมเนียมของเครือข่ายที่มีความสำคัญต่ำ ซึ่งอาจทำให้เกิดการรอนาน ราคาที่แตกต่างกัน หรือยกเลิกการซื้อขาย เราแนะนำให้กำหนดค่าธรรมเนียมที่สูงขึ้นเพื่อประสบการณ์ที่ดีขึ้น",
|
||||
"ignor": "ละเว้น",
|
||||
"use_suggested": "ใช้ที่แนะนำ",
|
||||
"do_not_share_warning_text" : "อย่าแชร์ข้อมูลนี้กับใครอื่น รวมถึงฝ่ายสนับสนุนด้วย\n\nการเงินของคุณอาจถูกขโมยโดยไม่หวังดี!",
|
||||
"help": "ช่วยเหลือ",
|
||||
"all_transactions": "การทำธุรกรรมทั้งหมด",
|
||||
"all_trades": "การซื้อขายทั้งหมด",
|
||||
"connection_sync": "การเชื่อมต่อและการซิงค์",
|
||||
"security_and_backup": "ความปลอดภัยและการสำรองข้อมูล",
|
||||
"create_backup": "สร้างการสำรองข้อมูล",
|
||||
"privacy_settings": "การตั้งค่าความเป็นส่วนตัว",
|
||||
"privacy": "ความเป็นส่วนตัว",
|
||||
"display_settings": "การตั้งค่าการแสดงผล",
|
||||
"other_settings": "การตั้งค่าอื่น ๆ",
|
||||
"require_pin_after": "ต้องการ PIN หลังจาก",
|
||||
"always": "เสมอ",
|
||||
"minutes_to_pin_code": "${minute} นาที",
|
||||
"disable_exchange": "ปิดใช้งานการแลกเปลี่ยน",
|
||||
"advanced_privacy_settings": "การตั้งค่าความเป็นส่วนตัวขั้นสูง",
|
||||
"settings_can_be_changed_later" : "การตั้งค่านี้สามารถเปลี่ยนแปลงได้ภายหลังในการตั้งค่าแอพฯ",
|
||||
"add_custom_node" : "เพิ่มจุดโหนดแบบกำหนดเอง",
|
||||
"disable_fiat" : "ปิดใช้งานสกุลเงินตรา",
|
||||
"fiat_api" : "API สกุลเงินตรา",
|
||||
"disabled" : "ปิดใช้งาน",
|
||||
"enabled" : "เปิดใช้งาน",
|
||||
"tor_only" : "Tor เท่านั้น",
|
||||
"unmatched_currencies" : "สกุลเงินของกระเป๋าปัจจุบันของคุณไม่ตรงกับของ QR ที่สแกน",
|
||||
"contact_list_contacts": "ติดต่อ",
|
||||
"contact_list_wallets": "กระเป๋าเงินของฉัน"
|
||||
}
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "Вихідні",
|
||||
"transactions_by_date" : "Сортувати по даті",
|
||||
"trades" : "Торгові операції",
|
||||
"filters" : "Фільтр",
|
||||
"filter_by": "Фільтрувати по",
|
||||
"today" : "Сьогодні",
|
||||
"yesterday" : "Вчора",
|
||||
"received" : "Отримані",
|
||||
|
@ -538,7 +538,9 @@
|
|||
"wallet_name_exists": "Гаманець з такою назвою вже існує",
|
||||
"market_place": "Ринок",
|
||||
"cake_pay_title": "Подарункові картки Cake Pay",
|
||||
"cake_pay_subtitle": "Купуйте подарункові картки та використовуйте їх миттєво",
|
||||
"cake_pay_subtitle": "Купуйте подарункові картки зі знижкою (тільки для США)",
|
||||
"cake_pay_web_cards_title": "Веб-картки Cake Pay",
|
||||
"cake_pay_web_cards_subtitle": "Купуйте передоплачені та подарункові картки по всьому світу",
|
||||
"about_cake_pay": "Cake Pay дозволяє вам легко купувати подарункові картки з віртуальними активами, які можна миттєво витратити в понад 150 000 продавців у Сполучених Штатах.",
|
||||
"cake_pay_account_note": "Зареєструйтеся, використовуючи лише адресу електронної пошти, щоб переглядати та купувати картки. Деякі навіть доступні зі знижкою!",
|
||||
"already_have_account": "Вже є обліковий запис?",
|
||||
|
@ -653,6 +655,8 @@
|
|||
"use_suggested": "Використати запропоноване",
|
||||
"do_not_share_warning_text" : "Не діліться цим нікому, включно зі службою підтримки.\n\nВаші кошти можуть і будуть вкрадені!",
|
||||
"help": "допомога",
|
||||
"all_transactions": "Всі транзакції",
|
||||
"all_trades": "Всі операції",
|
||||
"connection_sync": "Підключення та синхронізація",
|
||||
"security_and_backup": "Безпека та резервне копіювання",
|
||||
"create_backup": "Створити резервну копію",
|
||||
|
@ -660,6 +664,9 @@
|
|||
"privacy": "Конфіденційність",
|
||||
"display_settings": "Налаштування дисплея",
|
||||
"other_settings": "Інші налаштування",
|
||||
"require_pin_after": "Вимагати PIN після",
|
||||
"always": "Завжди",
|
||||
"minutes_to_pin_code": "${minute} хвилин",
|
||||
"disable_exchange": "Вимкнути exchange",
|
||||
"advanced_privacy_settings": "Розширені налаштування конфіденційності",
|
||||
"settings_can_be_changed_later": "Ці параметри можна змінити пізніше в налаштуваннях програми",
|
||||
|
@ -668,6 +675,8 @@
|
|||
"fiat_api": "Фіат API",
|
||||
"disabled": "Вимкнено",
|
||||
"enabled": "Увімкнено",
|
||||
"tor_only": "Тільки Tor"
|
||||
|
||||
"tor_only": "Тільки Tor",
|
||||
"unmatched_currencies": "Валюта вашого гаманця не збігається з валютою сканованого QR-коду",
|
||||
"contact_list_contacts": "Контакти",
|
||||
"contact_list_wallets": "Мої гаманці"
|
||||
}
|
||||
|
|
|
@ -48,7 +48,7 @@
|
|||
"outgoing" : "发送",
|
||||
"transactions_by_date" : "按日期交易",
|
||||
"trades" : "交易",
|
||||
"filters" : "过滤",
|
||||
"filter_by": "过滤",
|
||||
"today" : "今天",
|
||||
"yesterday" : "昨天",
|
||||
"received" : "已收到",
|
||||
|
@ -537,7 +537,9 @@
|
|||
"wallet_name_exists": "同名的钱包已经存在",
|
||||
"market_place": "市场",
|
||||
"cake_pay_title": "Cake Pay 礼品卡",
|
||||
"cake_pay_subtitle": "购买礼品卡并立即兑换",
|
||||
"cake_pay_subtitle": "购买打折礼品卡(仅限美国)",
|
||||
"cake_pay_web_cards_title": "蛋糕支付网络卡",
|
||||
"cake_pay_web_cards_subtitle": "购买全球预付卡和礼品卡",
|
||||
"about_cake_pay": "Cake Pay 让您可以轻松购买带有虚拟资产的礼品卡,可立即在美国超过 150,000 家商家消费。",
|
||||
"cake_pay_account_note": "只需使用電子郵件地址註冊即可查看和購買卡片。有些甚至可以打折!",
|
||||
"already_have_account": "已经有账号了?",
|
||||
|
@ -652,6 +654,8 @@
|
|||
"use_suggested": "使用建议",
|
||||
"do_not_share_warning_text" : "请勿与其他任何人分享这些信息,包括支持人员。\n\n您的资金可能而且将会被盗!",
|
||||
"help": "帮助",
|
||||
"all_transactions": "所有交易",
|
||||
"all_trades": "所有的变化",
|
||||
"connection_sync": "连接和同步",
|
||||
"security_and_backup": "安全和备份",
|
||||
"create_backup": "创建备份",
|
||||
|
@ -659,6 +663,9 @@
|
|||
"privacy":"隐私",
|
||||
"display_settings": "显示设置",
|
||||
"other_settings": "其他设置",
|
||||
"require_pin_after": "之后需要 PIN",
|
||||
"always": "总是",
|
||||
"minutes_to_pin_code": "${minute} 分钟",
|
||||
"disable_exchange": "禁用交换",
|
||||
"advanced_privacy_settings": "高级隐私设置",
|
||||
"settings_can_be_changed_later": "稍后可以在应用设置中更改这些设置",
|
||||
|
@ -667,5 +674,8 @@
|
|||
"fiat_api": "法币API",
|
||||
"disabled": "禁用",
|
||||
"enabled": "启用",
|
||||
"tor_only": "仅限 Tor"
|
||||
"tor_only": "仅限 Tor",
|
||||
"unmatched_currencies": "您当前钱包的货币与扫描的 QR 的货币不匹配",
|
||||
"contact_list_contacts": "联系人",
|
||||
"contact_list_wallets": "我的钱包"
|
||||
}
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue