aboutsummaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
Diffstat (limited to 'app')
-rw-r--r--app/_locales/de/messages.json873
-rw-r--r--app/_locales/en/messages.json71
-rw-r--r--app/_locales/es/messages.json886
-rw-r--r--app/_locales/es_419/messages.json10
-rw-r--r--app/_locales/hn/messages.json819
-rw-r--r--app/_locales/it/messages.json819
-rw-r--r--app/_locales/nl/messages.json819
-rw-r--r--app/_locales/ph/messages.json609
-rw-r--r--app/_locales/pt/messages.json819
-rw-r--r--app/_locales/ru/messages.json819
-rw-r--r--app/manifest.json2
-rw-r--r--app/scripts/README.md14
-rw-r--r--app/scripts/background.js9
-rw-r--r--app/scripts/controllers/README.md4
-rw-r--r--app/scripts/controllers/transactions.js53
-rw-r--r--app/scripts/lib/notification-manager.js11
-rw-r--r--app/scripts/lib/setupRaven.js32
-rw-r--r--app/scripts/lib/tx-state-manager.js42
-rw-r--r--app/scripts/metamask-controller.js599
-rw-r--r--app/scripts/migrations/README.md5
-rw-r--r--app/scripts/popup.js1
-rw-r--r--app/scripts/vendor/raven.min.js3
22 files changed, 7015 insertions, 304 deletions
diff --git a/app/_locales/de/messages.json b/app/_locales/de/messages.json
new file mode 100644
index 000000000..0bdce516c
--- /dev/null
+++ b/app/_locales/de/messages.json
@@ -0,0 +1,873 @@
+{
+ "accept": {
+ "message": "Annehmen"
+ },
+ "account": {
+ "message": "Account"
+ },
+ "accountDetails": {
+ "message": "Accountdetails"
+ },
+ "accountName": {
+ "message": "Accountname"
+ },
+ "address": {
+ "message": "Adresse"
+ },
+ "addToken": {
+ "message": "Token hinzufügen"
+ },
+ "amount": {
+ "message": "Betrag"
+ },
+ "amountPlusGas": {
+ "message": "Betrag + Gas"
+ },
+ "appDescription": {
+ "message": "Ethereum Browsererweiterung",
+ "description": "Die Beschreibung der Erweiterung"
+ },
+ "appName": {
+ "message": "MetaMask",
+ "description": "Der Name der Erweiterung"
+ },
+ "attemptingConnect": {
+ "message": "Versuch mit der Blockchain zu verbinden."
+ },
+ "available": {
+ "message": "Verfügbar"
+ },
+ "back": {
+ "message": "Zurück"
+ },
+ "balance": {
+ "message": "Guthaben:"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "Guthaben unzureichend für den aktuellen gesamten Gasbetrag"
+ },
+ "beta": {
+ "message": "BETA"
+ },
+ "betweenMinAndMax": {
+ "message": "Muss größer oder gleich $1 und kleiner oder gleich $2 sein.",
+ "description": "Helfer für die Eingabe von hex als dezimal"
+ },
+ "blockiesIdenticon": {
+ "message": "Blockies Identicon verwenden"
+ },
+ "borrowDharma": {
+ "message": "Mit Dharma ausleihen (Beta)"
+ },
+ "builtInCalifornia": {
+ "message": "MetaMask wurde in Kalifornien entwickelt und gebaut."
+ },
+ "buy": {
+ "message": "Kaufen"
+ },
+ "buyCoinbase": {
+ "message": "Auf Coinbase kaufen"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "Coinbase ist die weltweit bekannteste Möglichkeit bitcoin, ethereum und litecoin zu kaufen und verkaufen."
+ },
+ "ok": {
+ "message": "Ok"
+ },
+ "cancel": {
+ "message": "Abbrechen"
+ },
+ "classicInterface": {
+ "message": "Klassische Oberfläche verwenden"
+ },
+ "clickCopy": {
+ "message": "Klicken um zu kopieren"
+ },
+ "confirm": {
+ "message": "Bestätigen"
+ },
+ "confirmed": {
+ "message": "Bestätigt"
+ },
+ "confirmContract": {
+ "message": "Smart Contract bestätigen"
+ },
+ "confirmPassword": {
+ "message": "Passwort bestätigen"
+ },
+ "confirmTransaction": {
+ "message": "Transaktion bestätigen"
+ },
+ "continue": {
+ "message": "Weiter"
+ },
+ "continueToCoinbase": {
+ "message": "Zu Coinbase fortfahren"
+ },
+ "contractDeployment": {
+ "message": "Smart Contract ausführen"
+ },
+ "conversionProgress": {
+ "message": "Umtausch in Arbeit"
+ },
+ "copiedButton": {
+ "message": "Kopiert"
+ },
+ "copiedClipboard": {
+ "message": "In die Zwischenablage kopiert"
+ },
+ "copiedExclamation": {
+ "message": "Kopiert!"
+ },
+ "copiedSafe": {
+ "message": "Ich habe es an einen sicheren Ort kopiert"
+ },
+ "copy": {
+ "message": "Kopieren"
+ },
+ "copyToClipboard": {
+ "message": "In die Zwischenablage kopieren"
+ },
+ "copyButton": {
+ "message": " Kopieren "
+ },
+ "copyPrivateKey": {
+ "message": "Das ist Ihr Private Key (klicken um zu kopieren)"
+ },
+ "create": {
+ "message": "Erstellen"
+ },
+ "createAccount": {
+ "message": "Account erstellen"
+ },
+ "createDen": {
+ "message": "Erstellen"
+ },
+ "crypto": {
+ "message": "Krypto",
+ "description": "Börsentyp (Kryptowährungen)"
+ },
+ "currentConversion": {
+ "message": "Aktueller Umtausch"
+ },
+ "currentNetwork": {
+ "message": "Aktuelles Netzwerk"
+ },
+ "customGas": {
+ "message": "Gas anpassen"
+ },
+ "customize": {
+ "message": "Anpassen"
+ },
+ "customRPC": {
+ "message": "Spezieller RPC"
+ },
+ "decimalsMustZerotoTen": {
+ "message": "Die Dezimalangabe muss mindestens 0 und nicht höher als 36 sein."
+ },
+ "decimal": {
+ "message": "Dezimalangabe der Präzision"
+ },
+ "defaultNetwork": {
+ "message": "Das Standardnetzwerk für Ether Transaktionen ist das Main Net."
+ },
+ "denExplainer": {
+ "message": "Dein DEN ist dein passwortverschlüsselter Speicher innerhalb von MetaMask."
+ },
+ "deposit": {
+ "message": "Einzahlen"
+ },
+ "depositBTC": {
+ "message": "Zahle dein BTC in die unten stehende Adresse ein:"
+ },
+ "depositCoin": {
+ "message": "Zahle deine $1 in die unten stehende Adresse ein",
+ "description": "Teilt dem Benutzer mit welchen Token er beim Einzahlen mit Shapeshift ausgewählt hat"
+ },
+ "depositEth": {
+ "message": "Eth einzahlen"
+ },
+ "depositEther": {
+ "message": "Ether einzahlen"
+ },
+ "depositFiat": {
+ "message": "Fiat einzahlen"
+ },
+ "depositFromAccount": {
+ "message": "Von einem anderen Account einzahlen"
+ },
+ "depositShapeShift": {
+ "message": "Mit ShapeShift einzahlen"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "Wenn du andere Kryptowährungen besitzt, kannst du diese direkt mit Hilfe deiner MetaMask Wallet handeln und einzahlen. Du benötigst keinen Account."
+ },
+ "details": {
+ "message": "Details"
+ },
+ "directDeposit": {
+ "message": "Sofortige Einzahlung"
+ },
+ "directDepositEther": {
+ "message": "Sofort Ether einzahlen"
+ },
+ "directDepositEtherExplainer": {
+ "message": "Wenn du bereits Ether besitzt, ist die sofortige Einzahlung die schnellste Methode Ether in deine neue Wallet zu bekommen."
+ },
+ "done": {
+ "message": "Fertig"
+ },
+ "downloadStatelogs": {
+ "message": "Statelogs herunterladen"
+ },
+ "dropped": {
+ "message": "Abgewählt"
+ },
+ "edit": {
+ "message": "Editieren"
+ },
+ "editAccountName": {
+ "message": "Namen des Accounts editieren"
+ },
+ "emailUs": {
+ "message": "Schreib uns eine Mail!"
+ },
+ "encryptNewDen": {
+ "message": "Verschlüssele deine neue DEN"
+ },
+ "enterPassword": {
+ "message": "Passwort eingeben"
+ },
+ "enterPasswordConfirm": {
+ "message": "Gib dein neues Passwort zur Bestätigung ein"
+ },
+ "passwordNotLongEnough": {
+ "message": "Passwort ist nicht lang genug"
+ },
+ "passwordsDontMatch": {
+ "message": "Passwörter stimmen nicht überein"
+ },
+ "etherscanView": {
+ "message": "Account auf Etherscan anschauen"
+ },
+ "exchangeRate": {
+ "message": "Wechselrate"
+ },
+ "exportPrivateKey": {
+ "message": "Private Key exportieren"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "Der Export von Private Keys verläuft auf eigene Verantwortung."
+ },
+ "failed": {
+ "message": "Fehlgeschlagen"
+ },
+ "fiat": {
+ "message": "FIAT",
+ "description": "Börsentyp"
+ },
+ "fileImportFail": {
+ "message": "Dateiimport fehlgeschlagen? Bitte hier klicken!",
+ "description": "Hilft dem Benutzer sein Benutzerkonto durch eine JSON Datei zu importieren"
+ },
+ "followTwitter": {
+ "message": "Folge uns auf Twitter"
+ },
+ "from": {
+ "message": "von"
+ },
+ "fromToSame": {
+ "message": "Ziel- und Ursprungsadresse dürfen nicht identisch sein"
+ },
+ "fromShapeShift": {
+ "message": "Von ShapeShift"
+ },
+ "gas": {
+ "message": "Gas",
+ "description": "Kleiner Hinweis bzgl. der Gaskosten"
+ },
+ "gasFee": {
+ "message": "Gasgebühren"
+ },
+ "gasLimit": {
+ "message": "Gaslimit"
+ },
+ "gasLimitCalculation": {
+ "message": "Wir berechnen das empfohlene Gaslimit basierend auf der Erfolgsrate des Netzwerks."
+ },
+ "gasLimitRequired": {
+ "message": "Gaslimit benötigt"
+ },
+ "gasLimitTooLow": {
+ "message": "Gaslimit muss mindestens 21000 betragen"
+ },
+ "generatingSeed": {
+ "message": "Seed generieren..."
+ },
+ "gasPrice": {
+ "message": "Gaspreis (GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "Wir berechnen den empfohlenen Gaspreis basierend auf der Erfolgsrate des Netzwerks."
+ },
+ "gasPriceRequired": {
+ "message": "Gaspreis benötigt"
+ },
+ "getEther": {
+ "message": "Ether holen"
+ },
+ "getEtherFromFaucet": {
+ "message": "Ether für $1 vom Faucet holen",
+ "description": "Zeigt den Netzwerknamen für den Ether Faucet an"
+ },
+ "greaterThanMin": {
+ "message": "Muss größer oder gleich $1 sein.",
+ "description": "Helfer für die Eingabe von hex als dezimal"
+ },
+ "here": {
+ "message": "hier",
+ "description": "z.B. für klick hier für mehr Informationen (in Zusammenhang mit troubleTokenBalances)"
+ },
+ "hereList": {
+ "message": "Hier ist eine Liste!!!!"
+ },
+ "hide": {
+ "message": "Ausblenden"
+ },
+ "hideToken": {
+ "message": "Token ausblenden"
+ },
+ "hideTokenPrompt": {
+ "message": "Token ausblenden?"
+ },
+ "howToDeposit": {
+ "message": "Wie möchtest du Ether einzahlen?"
+ },
+ "holdEther": {
+ "message": "Es erlaubt dir ether & Token zu halten und dient dir als Verbindung zu dezentralisierten Applikationen."
+ },
+ "import": {
+ "message": "Import",
+ "description": "Button um den Account aus einer ausgewählten Datei zu importieren"
+ },
+ "importAccount": {
+ "message": "Account importieren"
+ },
+ "importAccountMsg": {
+ "message":" Importierte Accounts werden nicht mit der Seed Wörterfolge deines ursprünglichen MetaMask Accounts verknüpft. Erfahre mehr über importierte Accounts."
+ },
+ "importAnAccount": {
+ "message": "Einen Account importieren"
+ },
+ "importDen": {
+ "message": "Vorhandenes DEN importieren"
+ },
+ "imported": {
+ "message": "Importiert",
+ "description": "Status der angezeigt wird wenn ein Benutzerkonto vollständig in das Schlüsselbund geladen wurde."
+ },
+ "infoHelp": {
+ "message": "Info & Hilfe"
+ },
+ "insufficientFunds": {
+ "message": "Nicht genügend Guthaben."
+ },
+ "insufficientTokens": {
+ "message": "Nicht genügend Token."
+ },
+ "invalidAddress": {
+ "message": "Ungültige Adresse"
+ },
+ "invalidAddressRecipient": {
+ "message": "Empfängeradresse ist unzulässig"
+ },
+ "invalidGasParams": {
+ "message": "Ungültige Gasparameter"
+ },
+ "invalidInput": {
+ "message": "Ungültige Eingabe."
+ },
+ "invalidRequest": {
+ "message": "Ungültige Abfrage"
+ },
+ "invalidRPC": {
+ "message": "Ungültige RPC URI"
+ },
+ "jsonFail": {
+ "message": "Irgendetwas ist schief gelaufen. Bitte überprüfe ob deine JSON Datei korrekt formatiert ist."
+ },
+ "jsonFile": {
+ "message": "JSON Datei",
+ "description": "Dateiformat für das Importieren eines Accounts"
+ },
+ "kovan": {
+ "message": "Kovan Testnetzwerk"
+ },
+ "knowledgeDataBase": {
+ "message": "Schau in unsere Wissensdatenbank"
+ },
+ "max": {
+ "message": "Max"
+ },
+ "lessThanMax": {
+ "message": "Muss kleiner oder gleich $1 sein.",
+ "description": "Helfer für die Eingabe von hex als dezimal"
+ },
+ "likeToAddTokens": {
+ "message": "Möchtest du diese Token hinzufügen?"
+ },
+ "links": {
+ "message": "Links"
+ },
+ "limit": {
+ "message": "Limit"
+ },
+ "loading": {
+ "message": "Laden..."
+ },
+ "loadingTokens": {
+ "message": "Token laden..."
+ },
+ "localhost": {
+ "message": "Localhost 8545"
+ },
+ "login": {
+ "message": "Login"
+ },
+ "logout": {
+ "message": "Ausloggen"
+ },
+ "loose": {
+ "message": "Frei"
+ },
+ "loweCaseWords": {
+ "message": "Die Wörter der Seed Wörterfolgen sind alle kleingeschrieben"
+ },
+ "mainnet": {
+ "message": "Ethereum Hauptnetzwerk (Main Net)"
+ },
+ "message": {
+ "message": "Nachricht"
+ },
+ "metamaskDescription": {
+ "message": "MetaMask ist ein sicherer Identitätssafe für Ethereum."
+ },
+ "min": {
+ "message": "Minimum"
+ },
+ "myAccounts": {
+ "message": "Meine Accounts"
+ },
+ "mustSelectOne": {
+ "message": "Du musst mindestens 1 Token auswählen."
+ },
+ "needEtherInWallet": {
+ "message": "Um dezentralisierte Applikationen mit MetaMask verwenden zu können, benötigst du Ether in deiner Wallet."
+ },
+ "needImportFile": {
+ "message": "Für den Import musst du eine Datei auswählen.",
+ "description": "Benutzer importiert ein Benutzerkonto und muss eine Datei hinzufügen um fortzufahren"
+ },
+ "needImportPassword": {
+ "message": "Für die ausgewählte Datei muss ein Passwort eingegeben werden.",
+ "description": "Passwort und Datei sind notwendig um einen Account zu importieren"
+ },
+ "negativeETH": {
+ "message": "Negative ETH Beträge können nicht versendet werden."
+ },
+ "networks": {
+ "message": "Netzwerke"
+ },
+ "newAccount": {
+ "message": "Neuer Account"
+ },
+ "newAccountNumberName": {
+ "message": "Account $1",
+ "description": "Standardname für einen weiteren Account der angelegt wird, wenn create account screen geklickt wird"
+ },
+ "newContract": {
+ "message": "Neuer Smart Contract"
+ },
+ "newPassword": {
+ "message": "Neues Passwort (min. 8 Zeichen)"
+ },
+ "newRecipient": {
+ "message": "Neuer Empfänger"
+ },
+ "newRPC": {
+ "message": "Neue RPC URL"
+ },
+ "next": {
+ "message": "Weiter"
+ },
+ "noAddressForName": {
+ "message": "Für den angegebene Namen wurde keine Adresse eingegeben."
+ },
+ "noDeposits": {
+ "message": "Keine Einzahlung erhalten"
+ },
+ "noTransactionHistory": {
+ "message": "Keine Transaktionshistorie."
+ },
+ "noTransactions": {
+ "message": "Keine Transaktionen"
+ },
+ "notStarted": {
+ "message": "Nicht gestartet"
+ },
+ "oldUI": {
+ "message": "Alte Oberfläche"
+ },
+ "oldUIMessage": {
+ "message": "Du bist zur alten Oberfläche zurückgewechselt. Du kannst mit Hilfe der Option im oberen rechten Dropdown Menü zur neuen Oberfläche zurückwechseln."
+ },
+ "or": {
+ "message": "oder",
+ "description": "Wahl zwischen erstellen oder importieren eines Accounts."
+ },
+ "passwordCorrect": {
+ "message": "Bitte überzeuge dich davon, dass dein Passwort korrekt ist."
+ },
+ "passwordMismatch": {
+ "message": "Passwörter stimmen nicht überein",
+ "description": "Im Passwort erstellen Prozess stimmen beide Passwörter nicht miteinander überein"
+ },
+ "passwordShort": {
+ "message": "Passwort ist nicht lang genug",
+ "description": "Im Passwort erstellen Prozess ist das eingegebene Passwort nicht lang genug um sicher zu sein"
+ },
+ "pastePrivateKey": {
+ "message": "Füge deine Private Key Zeichenfolge hier ein:",
+ "description": "Für den Import eine Accounts mit Hilfe eines Private Keys"
+ },
+ "pasteSeed": {
+ "message": "Füge deine Seed Wörterfolge hier ein!"
+ },
+ "personalAddressDetected": {
+ "message": "Personalisierte Adresse identifiziert. Bitte füge die Token Contract Adresse ein."
+ },
+ "pleaseReviewTransaction": {
+ "message": "Bitte überprüfe deine Transaktion."
+ },
+ "privacyMsg": {
+ "message": "Datenschutzrichtlinie"
+ },
+ "privateKey": {
+ "message": "Private Key",
+ "description": "Wähle diesen Dateityp um damit einen Account zu importieren"
+ },
+ "privateKeyWarning": {
+ "message": "Warnung: Niemals jemanden deinen Private Key mitteilen. Jeder der im Besitz deines Private Keys ist, kann jegliches Guthaben deines Accounts stehlen."
+ },
+ "privateNetwork": {
+ "message": "Privates Netzwerk"
+ },
+ "qrCode": {
+ "message": "QR Code anzeigen"
+ },
+ "readdToken": {
+ "message": "Du kannst diesen Token zukünftig wieder hinzufügen indem du in den Menüpunkt \"Token hinzufügen\" in den Einstellungen deines Accounts gehst."
+ },
+ "readMore": {
+ "message": "Hier mehr erfahren."
+ },
+ "readMore2": {
+ "message": "Mehr erfahren."
+ },
+ "receive": {
+ "message": "Erhalten"
+ },
+ "recipientAddress": {
+ "message": "Empfängeradresse"
+ },
+ "refundAddress": {
+ "message": "Rückerstattungsadresse"
+ },
+ "rejected": {
+ "message": "Abgelehnt"
+ },
+ "resetAccount": {
+ "message": "Account zurücksetzten"
+ },
+ "restoreFromSeed": {
+ "message": "Mit Hilfe der Seed Wörterfolge wiederherstellen."
+ },
+ "restoreVault": {
+ "message": "Vault wiederherstellen"
+ },
+ "required": {
+ "message": "Benötigt"
+ },
+ "retryWithMoreGas": {
+ "message": "Versuche es hier mit einem höheren Gaspreis noch einmal"
+ },
+ "walletSeed": {
+ "message": "Wallet Seed"
+ },
+ "revealSeedWords": {
+ "message": "Seed Wörterfolge anzeigen"
+ },
+ "revealSeedWordsWarning": {
+ "message": "Bitte niemals deine Seed Wörterfolge an einem öffentlichen Ort kenntlich machen. Mit diesen Wörtern können alle deine Accounts gestohlen werden."
+ },
+ "revert": {
+ "message": "Zurück gehen"
+ },
+ "rinkeby": {
+ "message": "Rinkeby Testnetzwerk"
+ },
+ "ropsten": {
+ "message": "Ropsten Testnetzwerk"
+ },
+ "currentRpc": {
+ "message": "Aktueller RPC"
+ },
+ "connectingToMainnet": {
+ "message": "Verbinde zum Ethereum Hauptnetzwerk (Main Net)"
+ },
+ "connectingToRopsten": {
+ "message": " Verbinde zum Ropsten Testnetzwerk"
+ },
+ "connectingToKovan": {
+ "message": " Verbinde zum Kovan Testnetzwerk"
+ },
+ "connectingToRinkeby": {
+ "message": " Verbinde zum Rinkeby Testnetzwerk"
+ },
+ "connectingToUnknown": {
+ "message": "Verbinde zu einem unbekanntem Netzwerk"
+ },
+ "sampleAccountName": {
+ "message": "Z.B. mein neuer Account",
+ "description": "Dem Benutzer helfen das Konzept des Hinzufügens eines menschlich lesbaren Namen für den Account hinzuzufügen"
+ },
+ "save": {
+ "message": "Speichern"
+ },
+ "saveAsFile": {
+ "message": "Als Datei speichern",
+ "description": "Prozess des Exportieren eines Accounts"
+ },
+ "saveSeedAsFile": {
+ "message": "Seed Wörterfolge als Datei speichern"
+ },
+ "search": {
+ "message": "Suche"
+ },
+ "secretPhrase": {
+ "message": "Gib die 12 Wörter deiner geheimem Wörterfolge ein um deinen Vault wiederherzustellen."
+ },
+ "newPassword8Chars": {
+ "message": "Neues Passwort (min. 8 Zeichen)"
+ },
+ "seedPhraseReq": {
+ "message": "Seed Wörterfolgen bestehen aus 12 Wörtern"
+ },
+ "select": {
+ "message": "Auswählen"
+ },
+ "selectCurrency": {
+ "message": "Währung auswählen"
+ },
+ "selectService": {
+ "message": "Service auswählen"
+ },
+ "selectType": {
+ "message": "Typ auswählen"
+ },
+ "send": {
+ "message": "Senden"
+ },
+ "sendETH": {
+ "message": "ETH senden"
+ },
+ "sendTokens": {
+ "message": "Token senden"
+ },
+ "onlySendToEtherAddress": {
+ "message": "ETH nur zu einer Ethereum Adresse senden."
+ },
+ "sendTokensAnywhere": {
+ "message": "Token zu einer beliebigen Person mit einem Ethereumaccount senden"
+ },
+ "settings": {
+ "message": "Einstellungen"
+ },
+ "info": {
+ "message": "Info"
+ },
+ "shapeshiftBuy": {
+ "message": "Mit Shapeshift kaufen"
+ },
+ "showPrivateKeys": {
+ "message": "Private Keys anzeigen"
+ },
+ "showQRCode": {
+ "message": "QR Code anzeigen"
+ },
+ "sign": {
+ "message": "Unterschreiben"
+ },
+ "signed": {
+ "message": "Unterschrieben"
+ },
+ "signMessage": {
+ "message": "Nachricht unterschreiben"
+ },
+ "signNotice": {
+ "message": "Das Unterschreiben dieser Nachricht kann gefährliche Nebeneffekte haben. Bitte nur Nachrichten von Webseiten unterschreiben denen du deinen vollständigen Account anvertrauen würdest. Diese gefährliche Variante wird in zukünftigen Versionen entfernt werden."
+ },
+ "sigRequest": {
+ "message": "Unterschriftsanfrage"
+ },
+ "sigRequested": {
+ "message": "Unterschrift angefragt"
+ },
+ "spaceBetween": {
+ "message": "Es darf nur ein Leerzeichen zwischen den Wörtern sein"
+ },
+ "status": {
+ "message": "Status"
+ },
+ "stateLogs": {
+ "message": "Statelogs"
+ },
+ "stateLogsDescription": {
+ "message": "Statelogs zeigen die Public Adresse und die gesendeten Transaktionen deines Accounts."
+ },
+ "stateLogError": {
+ "message": "Fehler beim Abfragen der Statelogs."
+ },
+ "submit": {
+ "message": "Einreichen"
+ },
+ "submitted": {
+ "message": "Eingereicht"
+ },
+ "supportCenter": {
+ "message": "Gehe zu unserem Support Center"
+ },
+ "symbolBetweenZeroTen": {
+ "message": "Das Symbol muss zwischen 0 und 10 Zeichen haben."
+ },
+ "takesTooLong": {
+ "message": "Dauert es zu lang?"
+ },
+ "terms": {
+ "message": "Nutzungsbedingungen"
+ },
+ "testFaucet": {
+ "message": "Testfaucet"
+ },
+ "to": {
+ "message": "An:"
+ },
+ "toETHviaShapeShift": {
+ "message": "$1 an ETH via ShapeShift",
+ "description": "Das System wird den Einzahlungstyp im Beginn der Nachricht eintragen"
+ },
+ "tokenAddress": {
+ "message": "Tokenadresse"
+ },
+ "tokenAlreadyAdded": {
+ "message": "Der Token wurde bereits hinzugefügt."
+ },
+ "tokenBalance": {
+ "message": "Dein Tokenguthaben beträgt:"
+ },
+ "tokenSelection": {
+ "message": "Suche nach Token oder wähle aus einer Liste der beliebtesten Token aus."
+ },
+ "tokenSymbol": {
+ "message": "Tokensymbol"
+ },
+ "tokenWarning1": {
+ "message": "Behalte die Token die du mit deinem MetaMask Account gekauft hast im Auge. Wenn du Token mit einem anderen Account gekauft hast, werden diese hier nicht angezeigt."
+ },
+ "total": {
+ "message": "Gesamt"
+ },
+ "transactions": {
+ "message": "Transaktionen"
+ },
+ "transactionMemo": {
+ "message": "Transaktionsmemo (optional)"
+ },
+ "transactionNumber": {
+ "message": "Transaktionsnummer"
+ },
+ "transfers": {
+ "message": "Transfers"
+ },
+ "troubleTokenBalances": {
+ "message": "Wir haben Schwierigkeiten dein Tokenguthaben zu laden. Du kannst es hier anzeigen lassen",
+ "description": "Gefolgt von einem Link (hier) um die Tokenguthaben anzuzeigen"
+ },
+ "twelveWords": {
+ "message": "Diese 12 Wörter stellen die einzige Möglichkeit dar deinen MetaMask Account wiederherzustellen. Speichere sie daher an einem sicheren und geheimen Ort."
+ },
+ "typePassword": {
+ "message": "Passwort eingeben"
+ },
+ "uiWelcome": {
+ "message": "Willkommen zur neuen Oberfläche (Beta)"
+ },
+ "uiWelcomeMessage": {
+ "message": "Du verwendest nun die neue Metamask Oberfläche. Schau dich um, teste die neuen Features wie z.B. das Senden von Token und lass es uns wissen falls du irgendwelche Probleme hast."
+ },
+ "unapproved": {
+ "message": "Nicht genehmigt"
+ },
+ "unavailable": {
+ "message": "Nicht verfügbar"
+ },
+ "unknown": {
+ "message": "Unbekannt"
+ },
+ "unknownNetwork": {
+ "message": "Unbekanntes privates Netzwerk"
+ },
+ "uriErrorMsg": {
+ "message": "URIs benötigen die korrekten HTTP/HTTPS Präfixe."
+ },
+ "unknownNetworkId": {
+ "message": "Unbekannte Netzwerk ID"
+ },
+ "usaOnly": {
+ "message": "Nur USA ",
+ "description": "Diese Börse ist nur für Einwohner der USA verfügbar"
+ },
+ "usedByClients": {
+ "message": "Verwendet von einer Reihe verschiedenen Kunden"
+ },
+ "useOldUI": {
+ "message": "Alte Oberfläche verwenden"
+ },
+ "validFileImport": {
+ "message": "Du musst eine gültige Datei für den Import auswählen."
+ },
+ "vaultCreated": {
+ "message": "Vault erstellt"
+ },
+ "viewAccount": {
+ "message": " Account einsehen"
+ },
+ "visitWebSite": {
+ "message": "Gehe zu unsere Webseite"
+ },
+ "warning": {
+ "message": "Warnung"
+ },
+ "welcomeBeta": {
+ "message": "Willkommen zu MetaMask Beta"
+ },
+ "whatsThis": {
+ "message": "Was ist das?"
+ },
+ "yourSigRequested": {
+ "message": "Deine Unterschrift wird angefordert"
+ },
+ "youSign": {
+ "message": "Du unterschreibst"
+ }
+}
diff --git a/app/_locales/en/messages.json b/app/_locales/en/messages.json
index 35a360c84..c64b7248b 100644
--- a/app/_locales/en/messages.json
+++ b/app/_locales/en/messages.json
@@ -37,6 +37,9 @@
"message": "MetaMask",
"description": "The name of the application"
},
+ "approved": {
+ "message": "Approved"
+ },
"attemptingConnect": {
"message": "Attempting to connect to blockchain."
},
@@ -83,6 +86,9 @@
"buyCoinbaseExplainer": {
"message": "Coinbase is the world’s most popular way to buy and sell bitcoin, ethereum, and litecoin."
},
+ "ok": {
+ "message": "Ok"
+ },
"cancel": {
"message": "Cancel"
},
@@ -95,6 +101,9 @@
"confirm": {
"message": "Confirm"
},
+ "confirmed": {
+ "message": "Confirmed"
+ },
"confirmContract": {
"message": "Confirm Contract"
},
@@ -226,6 +235,9 @@
"downloadStatelogs": {
"message": "Download State Logs"
},
+ "dropped": {
+ "message": "Dropped"
+ },
"edit": {
"message": "Edit"
},
@@ -244,6 +256,12 @@
"enterPasswordConfirm": {
"message": "Enter your password to confirm"
},
+ "passwordNotLongEnough": {
+ "message": "Password not long enough"
+ },
+ "passwordsDontMatch": {
+ "message": "Passwords Don't Match"
+ },
"etherscanView": {
"message": "View account on Etherscan"
},
@@ -403,6 +421,9 @@
"knowledgeDataBase": {
"message": "Visit our Knowledge Base"
},
+ "max": {
+ "message": "Max"
+ },
"lessThanMax": {
"message": "must be less than or equal to $1.",
"description": "helper for inputting hex as decimal input"
@@ -410,6 +431,9 @@
"likeToAddTokens": {
"message": "Would you like to add these tokens?"
},
+ "links": {
+ "message": "Links"
+ },
"limit": {
"message": "Limit"
},
@@ -583,12 +607,18 @@
"restoreFromSeed": {
"message": "Restore from seed phrase"
},
+ "restoreVault": {
+ "message": "Restore Vault"
+ },
"required": {
"message": "Required"
},
"retryWithMoreGas": {
"message": "Retry with a higher gas price here"
},
+ "walletSeed": {
+ "message": "Wallet Seed"
+ },
"revealSeedWords": {
"message": "Reveal Seed Words"
},
@@ -604,6 +634,24 @@
"ropsten": {
"message": "Ropsten Test Network"
},
+ "currentRpc": {
+ "message": "Current RPC"
+ },
+ "connectingToMainnet": {
+ "message": "Connecting to Main Ethereum Network"
+ },
+ "connectingToRopsten": {
+ "message": "Connecting to Ropsten Test Network"
+ },
+ "connectingToKovan": {
+ "message": "Connecting to Kovan Test Network"
+ },
+ "connectingToRinkeby": {
+ "message": "Connecting to Rinkeby Test Network"
+ },
+ "connectingToUnknown": {
+ "message": "Connecting to Unknown Network"
+ },
"sampleAccountName": {
"message": "E.g. My new account",
"description": "Help user understand concept of adding a human-readable name to their account"
@@ -624,6 +672,9 @@
"secretPhrase": {
"message": "Enter your secret twelve word phrase here to restore your vault."
},
+ "newPassword8Chars": {
+ "message": "New Password (min 8 chars)"
+ },
"seedPhraseReq": {
"message": "seed phrases are 12 words long"
},
@@ -648,12 +699,18 @@
"sendTokens": {
"message": "Send Tokens"
},
+ "onlySendToEtherAddress": {
+ "message": "Only send ETH to an Ethereum address."
+ },
"sendTokensAnywhere": {
"message": "Send Tokens to anyone with an Ethereum account"
},
"settings": {
"message": "Settings"
},
+ "info": {
+ "message": "Info"
+ },
"shapeshiftBuy": {
"message": "Buy with Shapeshift"
},
@@ -666,6 +723,9 @@
"sign": {
"message": "Sign"
},
+ "signed": {
+ "message": "Signed"
+ },
"signMessage": {
"message": "Sign Message"
},
@@ -690,9 +750,15 @@
"stateLogsDescription": {
"message": "State logs contain your public account addresses and sent transactions."
},
+ "stateLogError": {
+ "message": "Error in retrieving state logs."
+ },
"submit": {
"message": "Submit"
},
+ "submitted": {
+ "message": "Submitted"
+ },
"supportCenter": {
"message": "Visit our Support Center"
},
@@ -709,7 +775,7 @@
"message": "Test Faucet"
},
"to": {
- "message": "To"
+ "message": "To: "
},
"toETHviaShapeShift": {
"message": "$1 to ETH via ShapeShift",
@@ -764,6 +830,9 @@
"uiWelcomeMessage": {
"message": "You are now using the new Metamask UI. Take a look around, try out new features like sending tokens, and let us know if you have any issues."
},
+ "unapproved": {
+ "message": "Unapproved"
+ },
"unavailable": {
"message": "Unavailable"
},
diff --git a/app/_locales/es/messages.json b/app/_locales/es/messages.json
index 78fc64dbf..fa28b09da 100644
--- a/app/_locales/es/messages.json
+++ b/app/_locales/es/messages.json
@@ -1,10 +1,888 @@
{
+ "accept": {
+ "message": "Aceptar"
+ },
+ "account": {
+ "message": "Cuenta"
+ },
+ "accountDetails": {
+ "message": "Detalles de la cuenta"
+ },
+ "accountName": {
+ "message": "Nombre de la cuenta"
+ },
+ "addCustomToken": {
+ "message": "Agregar token personalizados"
+ },
+ "addToken": {
+ "message": "Agregar token"
+ },
+ "addTokens": {
+ "message": "Agregar tokens"
+ },
+ "address": {
+ "message": "Dirección"
+ },
+ "amount": {
+ "message": "Cantidad"
+ },
+ "amountPlusGas": {
+ "message": "Cantidad + Gas"
+ },
+ "appDescription": {
+ "message": "Extensión del navegador para Ethereum",
+ "description": "La descripción de la aplicación"
+ },
"appName": {
"message": "MetaMask",
- "description": "The name of the application"
+ "description": "El nombre de la aplicación"
},
- "appDescription": {
- "message": "Administración de identidad en Ethereum",
- "description": "The description of the application"
+ "approved": {
+ "message": "Aprobado"
+ },
+ "attemptingConnect": {
+ "message": "Intentando conectar a la Blockchain"
+ },
+ "attributions": {
+ "message": "Atribuciones"
+ },
+ "available": {
+ "message": "Disponible"
+ },
+ "back": {
+ "message": "Atrás"
+ },
+ "balance": {
+ "message": "Saldo"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "Saldo de gas insuficiente"
+ },
+ "balances": {
+ "message": "Tus saldos"
+ },
+ "beta": {
+ "message": "BETA"
+ },
+ "betweenMinAndMax": {
+ "message": "Debe ser mayor o igual a $1 y menor o igual a $2",
+ "description": "helper para ingresar hex como un ingreso decimal"
+ },
+ "blockiesIdenticon": {
+ "message": "Usar Blockies Identicon (Iconos)"
+ },
+ "borrowDharma": {
+ "message": "Pedir prestado con Dharma (Beta)"
+ },
+ "builtInCalifornia": {
+ "message": "Metamask fue diseñado y construido en California"
+ },
+ "buy": {
+ "message": "Comprar"
+ },
+ "buyCoinbase": {
+ "message": "Comprar en Coinbase"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "Coinbase es la plataforma global más popular para comprar y vender Bitcoin, Ethereum y Litecoin"
+ },
+ "cancel": {
+ "message": "Cancelar"
+ },
+ "classicInterface": {
+ "message": "Usar interfaz clásica"
+ },
+ "clickCopy": {
+ "message": "Click para copiar"
+ },
+ "confirm": {
+ "message": "Confirmar"
+ },
+ "confirmContract": {
+ "message": "Confirmar contrato"
+ },
+ "confirmed": {
+ "message": "Confirmado"
+ },
+ "confirmPassword": {
+ "message": "Confirmar contraseña"
+ },
+ "confirmTransaction": {
+ "message": "Confirmar transacción"
+ },
+ "connectingToMainnet": {
+ "message": "Conectando a la red principal de Ethereum (Main Net)"
+ },
+ "connectingToRopsten": {
+ "message": "Conectando a la red de test Ropsten"
+ },
+ "connectingToKovan": {
+ "message": "Conectando a la red de test Kovan"
+ },
+ "connectingToRinkeby": {
+ "message": "Conectando a la red de test Rinkeby"
+ },
+ "connectingToUnknown": {
+ "message": "Conectando a una red desconocida"
+ },
+ "continue": {
+ "message": "Continuar"
+ },
+ "continueToCoinbase": {
+ "message": "Continuar a Coinbase"
+ },
+ "contractDeployment": {
+ "message": "Desplegar (Deploy) contrato"
+ },
+ "conversionProgress": {
+ "message": "Conversión en progreso"
+ },
+ "copiedButton": {
+ "message": "Copiado"
+ },
+ "copiedClipboard": {
+ "message": "Copiado al portapapeles"
+ },
+ "copiedExclamation": {
+ "message": "¡Copiado!"
+ },
+ "copiedSafe": {
+ "message": "Ya lo guardé en un lugar seguro"
+ },
+ "copy": {
+ "message": "Copiar"
+ },
+ "copyButton": {
+ "message": " Copiar "
+ },
+ "copyPrivateKey": {
+ "message": "Ésta es tu llave privada (haz click para copiar)"
+ },
+ "copyToClipboard": {
+ "message": "Copiar al portapapeles"
+ },
+ "create": {
+ "message": "Crear"
+ },
+ "createAccount": {
+ "message": "Crear cuenta"
+ },
+ "createDen": {
+ "message": "Crear"
+ },
+ "crypto": {
+ "message": "Crypto",
+ "description": "Tipo de cambio (criptomonedas)"
+ },
+ "currentConversion": {
+ "message": "Conversión actual"
+ },
+ "currentNetwork": {
+ "message": "Red actual"
+ },
+ "currentRpc": {
+ "message": "RPC actual"
+ },
+ "customGas": {
+ "message": "Personalizar gas"
+ },
+ "customRPC": {
+ "message": "RPC personalizado"
+ },
+ "customize": {
+ "message": "Personalizar"
+ },
+ "decimal": {
+ "message": "Decimales de precisión"
+ },
+ "decimalsMustZerotoTen": {
+ "message": "Los decimales deben ser al menos 0 y no más de 36"
+ },
+ "defaultNetwork": {
+ "message": "La red por defecto para las transacciones de Ether es MainNet (red principal)"
+ },
+ "denExplainer": {
+ "message": "El DEN es tu contraseña encriptada almacenada dentro de MetaMask"
+ },
+ "deposit": {
+ "message": "Depositar"
+ },
+ "depositBTC": {
+ "message": "Deposita tus BTC a la dirección de abajo:"
+ },
+ "depositCoin": {
+ "message": "Deposita tu $1 a la dirección de abajo",
+ "description": "Informa al usuario que moneda ha elegido para depositar en shapeshift"
+ },
+ "depositEth": {
+ "message": "Depositar Ether"
+ },
+ "depositEther": {
+ "message": "Depositar Ether"
+ },
+ "depositFiat": {
+ "message": "Depositar con fiat (divisa nacional)"
+ },
+ "depositFromAccount": {
+ "message": "Depositar con otra cuenta"
+ },
+ "depositShapeShift": {
+ "message": "Depositar con ShapeShift"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "Si posees otras criptomonedas, puedes intercambiar y depositar Ether directamente en tu billetera de MetaMask. No necesitas tener una cuenta."
+ },
+ "details": {
+ "message": "Detalles"
+ },
+ "directDeposit": {
+ "message": "Depósito directo"
+ },
+ "directDepositEther": {
+ "message": "Depositar Ether directamente"
+ },
+ "directDepositEtherExplainer": {
+ "message": "Si posees Ether, la forma más rápida de transferirlo a tu nueva billetera es depositándolo directamente"
+ },
+ "done": {
+ "message": "Completo"
+ },
+ "downloadStatelogs": {
+ "message": "Descargar logs de estado"
+ },
+ "dropped": {
+ "message": "Caído"
+ },
+ "edit": {
+ "message": "Editar"
+ },
+ "editAccountName": {
+ "message": "Editar el nombre de la cuenta"
+ },
+ "emailUs": {
+ "message": "¡Envíanos un correo!"
+ },
+ "encryptNewDen": {
+ "message": "Encriptar tu nuevo DEN"
+ },
+ "enterPassword": {
+ "message": "Ingresa contraseña"
+ },
+ "enterPasswordConfirm": {
+ "message": "Ingresa tu contraseña para confirmar"
+ },
+ "etherscanView": {
+ "message": "Ver la cuenta en Etherscan"
+ },
+ "exchangeRate": {
+ "message": "Tipo de cambio"
+ },
+ "exportPrivateKey": {
+ "message": "Exportar llave privada"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "Exportar llaves privadas bajo TU PROPIO riesgo"
+ },
+ "failed": {
+ "message": "Fallo"
+ },
+ "fiat": {
+ "message": "FIAT",
+ "description": "Tipo de cambio"
+ },
+ "fileImportFail": {
+ "message": "¿La importación no funcionó? ¡Haz click aquí!",
+ "description": "Ayuda al usuario a importar su cuenta desde un archivo JSON"
+ },
+ "followTwitter": {
+ "message": "Síguenos en Twitter"
+ },
+ "from": {
+ "message": "De:"
+ },
+ "fromShapeShift": {
+ "message": "De ShapeShift"
+ },
+ "fromToSame": {
+ "message": "La dirección de origen y destino no pueden ser la misma"
+ },
+ "gas": {
+ "message": "Gas",
+ "description": "Indicación pequeña del costo de gas"
+ },
+ "gasFee": {
+ "message": "Comisión de gas"
+ },
+ "gasLimit": {
+ "message": "Límite de gas"
+ },
+ "gasLimitCalculation": {
+ "message": "Calculamos el límite de gas sugerido en función de las tasas de éxito de la red"
+ },
+ "gasLimitRequired": {
+ "message": "Límite de gas requerido"
+ },
+ "gasLimitTooLow": {
+ "message": "El límite de gas debe ser de al menos 21000"
+ },
+ "gasPrice": {
+ "message": "Precio del Gas (GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "Calculamos los precios sugeridos del gas en función de las tasas de éxito de la red"
+ },
+ "gasPriceRequired": {
+ "message": "Precio del gas requerido"
+ },
+ "generatingSeed": {
+ "message": "Generando semilla..."
+ },
+ "getEther": {
+ "message": "Conseguir Ether"
+ },
+ "getEtherFromFaucet": {
+ "message": "Obtenga Ether de un faucet (grifo) por $1",
+ "description": "Muestra el nombre de la red para el faucet (grifo) de Ether"
+ },
+ "greaterThanMin": {
+ "message": "Debe ser mayor o igual a $1",
+ "description": "helper para ingresar hex como entrada decimal"
+ },
+ "here": {
+ "message": "Aquí",
+ "description": "como en -haz click aquí- para más información"
+ },
+ "hereList": {
+ "message": "¡¡¡Aquí está una lista!!!"
+ },
+ "hide": {
+ "message": "Ocultar"
+ },
+ "hideToken": {
+ "message": "Ocultar token"
+ },
+ "hideTokenPrompt": {
+ "message": "¿Ocultar token?"
+ },
+ "holdEther": {
+ "message": "Te permite mantener tus ether y tokens, así como puente para aplicaciones descentralizadas"
+ },
+ "howToDeposit": {
+ "message": "¿Cómo te gustaria depositar Ether?"
+ },
+ "import": {
+ "message": "Importar",
+ "description": "Botón para importar una cuenta desde un archivo seleccionado"
+ },
+ "importAccount": {
+ "message": "Importar cuenta"
+ },
+ "importAnAccount": {
+ "message": "Importar una cuenta"
+ },
+ "importDen": {
+ "message": "Importar DEN existente"
+ },
+ "imported": {
+ "message": "Importado",
+ "description": "Estado que muestra que una cuenta ha sido completamente cargada en el llavero"
+ },
+ "importAccountMsg": {
+ "message": "Las cuentas importadas no serán asociadas con tu cuenta original creada con tu MetaMask. Aprende más acerca de importar cuentas."
+ },
+ "info": {
+ "message": "Información"
+ },
+ "infoHelp": {
+ "message": "Informacion y ayuda"
+ },
+ "insufficientFunds": {
+ "message": "Fondos insuficientes"
+ },
+ "insufficientTokens": {
+ "message": "Tokens insuficientes"
+ },
+ "invalidAddress": {
+ "message": "Dirección inválida"
+ },
+ "invalidAddressRecipient": {
+ "message": "Dirección del destinatario invalida"
+ },
+ "invalidGasParams": {
+ "message": "Parametros de gas inválidos"
+ },
+ "invalidInput": {
+ "message": "Entrada inválida"
+ },
+ "invalidRPC": {
+ "message": "Invalida URL del RPC"
+ },
+ "invalidRequest": {
+ "message": "Petición inválida"
+ },
+ "jsonFail": {
+ "message": "Algo falló. Asegúrate que tu JSON tiene el formato correcto"
+ },
+ "jsonFile": {
+ "message": "Archivo JSON",
+ "description": "Formato para importar una cuenta"
+ },
+ "knowledgeDataBase": {
+ "message": "Visita nuestra base de conocimiento"
+ },
+ "kovan": {
+ "message": "Red de pruebas Kovan"
+ },
+ "lessThanMax": {
+ "message": "Debe ser menor o igual a $1",
+ "description": "Helper para ingresar hex como decimal"
+ },
+ "likeToAddTokens": {
+ "message": "¿Te gustaría agregar estos tokens?"
+ },
+ "limit": {
+ "message": "Límite"
+ },
+ "links": {
+ "message": "Enlaces"
+ },
+ "loading": {
+ "message": "Cargando..."
+ },
+ "loadingTokens": {
+ "message": "Cargando tokens..."
+ },
+ "localhost": {
+ "message": "Localhost 8545"
+ },
+ "login": {
+ "message": "Ingresar"
+ },
+ "logout": {
+ "message": "Cerrar sesión"
+ },
+ "loose": {
+ "message": "Suelto"
+ },
+ "loweCaseWords": {
+ "message": "las frases semilla sólo pueden tener minúsculas"
+ },
+ "mainnet": {
+ "message": "Red principal de Ethereum (Main Net)"
+ },
+ "max": {
+ "message": "Max"
+ },
+ "message": {
+ "message": "Mensaje"
+ },
+ "metamaskDescription": {
+ "message": "MetaMask es una identidad segura en Ethereum"
+ },
+ "min": {
+ "message": "Mínimo"
+ },
+ "mustSelectOne": {
+ "message": "Debe seleccionar al menos un (1) token"
+ },
+ "myAccounts": {
+ "message": "Mis cuentas"
+ },
+ "needEtherInWallet": {
+ "message": "Para interactuar con una aplicación descentralizada usando MetaMask, necesitas tener Ether en tu billetera"
+ },
+ "needImportFile": {
+ "message": "Debes seleccionar un archivo para importar",
+ "description": "El usuario está importando una cuenta y necesita agregar un archivo para continuar"
+ },
+ "needImportPassword": {
+ "message": "Debes ingresar una contraseña para el archivo seleccionado",
+ "description": "Contraseña y archivo necesarios para importar una cuenta"
+ },
+ "negativeETH": {
+ "message": "No se pueden mandar cantidades negativas de ETH"
+ },
+ "networks": {
+ "message": "Redes"
+ },
+ "newAccount": {
+ "message": "Nueva cuenta"
+ },
+ "newAccountNumberName": {
+ "message": "Cuenta $1",
+ "description": "Nombre por defecto de la próxima cuenta a ser creada o pantalla de creación de cuenta"
+ },
+ "newContract": {
+ "message": "Nuevo contrato"
+ },
+ "newPassword": {
+ "message": "Nueva contraseña (mínimo [8] caracteres)"
+ },
+ "newPassword8Chars": {
+ "message": "Nueva contraseña (mínimo [8] caracteres)"
+ },
+ "newRPC": {
+ "message": "Nueva URL del RPC"
+ },
+ "newRecipient": {
+ "message": "Nuevo destinatario"
+ },
+ "next": {
+ "message": "Siguiente"
+ },
+ "noAddressForName": {
+ "message": "No se ha establecido ninguna dirección para este nombre"
+ },
+ "noDeposits": {
+ "message": "No hay depósitos recibidos"
+ },
+ "noTransactionHistory": {
+ "message": "Sin historial de transacciones"
+ },
+ "noTransactions": {
+ "message": "Sin transacciones"
+ },
+ "notStarted": {
+ "message": "Sin iniciar"
+ },
+ "ok": {
+ "message": "Ok"
+ },
+ "oldUI": {
+ "message": "Antigua UI (Interfaz de Usuario)"
+ },
+ "oldUIMessage": {
+ "message": "Regresaste a la antigua UI (Interfaz de Usuario). Puedes regresar a la nueva UI mediante la opcion en la barra desplegable del menu de arriba a la derecha."
+ },
+ "onlySendToEtherAddress": {
+ "message": "Sólo envía a una dirección de Ethereum"
+ },
+ "or": {
+ "message": "o",
+ "description": "opción entre crear o importar una cuenta"
+ },
+ "passwordCorrect": {
+ "message": "Asegurate que tu contraseña es correcta"
+ },
+ "passwordMismatch": {
+ "message": "La contraseña no coincide",
+ "description": "En el proceso de creación de contraseña, los dos campos de contraseña no coincidieron"
+ },
+ "passwordNotLongEnough": {
+ "message": "La contraseña no es lo suficientemente larga"
+ },
+ "passwordsDontMatch": {
+ "message": "Las contraseñas no coinciden"
+ },
+ "passwordShort": {
+ "message": "La contraseña no es lo suficientemente larga",
+ "description": "En el proceso de creación de contraseña, esta no es lo suficientemente larga para ser segura"
+ },
+ "pastePrivateKey": {
+ "message": "Pega tu llave privada aqui",
+ "description": "Para importar una cuenta desde una llave privada"
+ },
+ "pasteSeed": {
+ "message": "¡Pega tu frase semilla aquí!"
+ },
+ "personalAddressDetected": {
+ "message": "Dirección personal detectada. Ingresa la dirección del contrato del token"
+ },
+ "pleaseReviewTransaction": {
+ "message": "Por favor, revisa tu transaccion"
+ },
+ "privacyMsg": {
+ "message": "Política de privacidad"
+ },
+ "privateKey": {
+ "message": "Llave privada",
+ "description": "Selecciona este tupo de archivo para importar una cuenta"
+ },
+ "privateKeyWarning": {
+ "message": "Advertencia: NUNCA reveles esta clave. Cualquier persona con tus claves privadas puede robar los activos retenidos en tu cuenta"
+ },
+ "privateNetwork": {
+ "message": "Red privada"
+ },
+ "qrCode": {
+ "message": "Mostrar codigo QR"
+ },
+ "readMore": {
+ "message": "Leer más aquí"
+ },
+ "readMore2": {
+ "message": "Leer más"
+ },
+ "readdToken": {
+ "message": "Puedes volver a agregar este token en el futuro pinchando sobre 'Agregar token' en el menú de opciones de tu cuenta"
+ },
+ "receive": {
+ "message": "Recibir"
+ },
+ "recipientAddress": {
+ "message": "Dirección del receptor"
+ },
+ "refundAddress": {
+ "message": "Tu dirección de reembolso"
+ },
+ "rejected": {
+ "message": "Rechazado"
+ },
+ "required": {
+ "message": "Requerido"
+ },
+ "resetAccount": {
+ "message": "Reiniciar cuenta"
+ },
+ "restoreFromSeed": {
+ "message": "Restaurar desde semilla"
+ },
+ "restoreVault": {
+ "message": "Restaurar Bóveda"
+ },
+ "retryWithMoreGas": {
+ "message": "Vuelva a intentar con un precio de gas más alto aquí"
+ },
+ "revealSeedWords": {
+ "message": "Revelar palabras de semilla"
+ },
+ "revealSeedWordsWarning": {
+ "message": "¡No recuperes tu semilla en un lugar pública! Esas palabras pueden ser usadas para robarte todas tus cuentas"
+ },
+ "revert": {
+ "message": "Revertir"
+ },
+ "rinkeby": {
+ "message": "Red privada Rinkeby"
+ },
+ "ropsten": {
+ "message": "Red privada Ropsten"
+ },
+ "sampleAccountName": {
+ "message": "P.ej. Mi nueva cuenta",
+ "description": "Ayuda al usuario a entender el concepto de agregar un nombre, leíble por humanos, a su cuenta"
+ },
+ "save": {
+ "message": "Guardar"
+ },
+ "saveAsFile": {
+ "message": "Guardar como archivo",
+ "description": "Proceso de exportación de cuenta"
+ },
+ "saveSeedAsFile": {
+ "message": "Guardar la semilla como archivo"
+ },
+ "search": {
+ "message": "Buscar"
+ },
+ "secretPhrase": {
+ "message": "Ingresa tu frase de doce (12) palabras para restaurar tu bóveda"
+ },
+ "seedPhraseReq": {
+ "message": "las frases semilla tienen doce (12) palabras de largo"
+ },
+ "select": {
+ "message": "Seleccionar"
+ },
+ "selectCurrency": {
+ "message": "Seleccionar moneda"
+ },
+ "selectService": {
+ "message": "Seleccionar servicio"
+ },
+ "selectType": {
+ "message": "Seleccionar tipo"
+ },
+ "send": {
+ "message": "Enviar"
+ },
+ "sendETH": {
+ "message": "Enviar Ether"
+ },
+ "sendTokens": {
+ "message": "Enviar tokens"
+ },
+ "sendTokensAnywhere": {
+ "message": "Enviar tokens a cualquiera con una cuenta de Ethereum"
+ },
+ "settings": {
+ "message": "Configuración"
+ },
+ "shapeshiftBuy": {
+ "message": "Comprar con ShapeShift"
+ },
+ "showPrivateKeys": {
+ "message": "Mostrar llaves privadas"
+ },
+ "showQRCode": {
+ "message": "Mostrar codigo QR"
+ },
+ "sigRequest": {
+ "message": "Solicitud de firma"
+ },
+ "sigRequested": {
+ "message": "Firma solicitada"
+ },
+ "sign": {
+ "message": "Firmar"
+ },
+ "signed": {
+ "message": "Firmado"
+ },
+ "signMessage": {
+ "message": "Firmar mensaje"
+ },
+ "signNotice": {
+ "message": "Firmar este mensaje puede tener\n efectos secundarios peligrosos. Firma sólo\nmensajes desde sitios a los que estés plenamente dispuesto a confiar tu cuenta.\nEste método peligroso va a ser \neliminado en una version futura."
+ },
+ "spaceBetween": {
+ "message": "Sólo puede haber un espacio entre las palabras"
+ },
+ "stateLogs": {
+ "message": "Logs de estado"
+ },
+ "stateLogsDescription": {
+ "message": "Los logs de estado contienen tus direcciones de cuentas públicas y transacciones envíadas"
+ },
+ "stateLogError": {
+ "message": "Error en la recogida de logs de estado"
+ },
+ "status": {
+ "message": "Estado"
+ },
+ "submit": {
+ "message": "Enviar"
+ },
+ "submitted": {
+ "message": "Enviado"
+ },
+ "supportCenter": {
+ "message": "Visita nuestro centro de atención"
+ },
+ "symbolBetweenZeroTen": {
+ "message": "Símbolo debe ser entre 0 y 10 caracteres"
+ },
+ "takesTooLong": {
+ "message": "¿Está tardando demasiado?"
+ },
+ "terms": {
+ "message": "Términos de uso"
+ },
+ "testFaucet": {
+ "message": "Probar Faucet"
+ },
+ "to": {
+ "message": "Para:"
+ },
+ "toETHviaShapeShift": {
+ "message": "$1 a ETH via ShapeShift",
+ "description": "el sistema llenará el tipo de depósito al principio del mensaje"
+ },
+ "tokenAddress": {
+ "message": "Dirección del token"
+ },
+ "tokenAlreadyAdded": {
+ "message": "El token está actualmente agregado"
+ },
+ "tokenBalance": {
+ "message": "Tu balance de tokens es:"
+ },
+ "tokenSelection": {
+ "message": "Busca tokens o selecciónalo de nuestra lista de tokens populares"
+ },
+ "tokenSymbol": {
+ "message": "Símbolo del token"
+ },
+ "tokenWarning1": {
+ "message": "Mantén un registro de los tokens que has comprado con tu cuenta de MetaMask. Si compraste tokens usando una cuenta diferente, esos tokens no aparecerán aquí."
+ },
+ "total": {
+ "message": "Total"
+ },
+ "transactionMemo": {
+ "message": "Memo de transacción (opcional)"
+ },
+ "transactionNumber": {
+ "message": "Número de transacción"
+ },
+ "transactions": {
+ "message": "Transacciones"
+ },
+ "transfers": {
+ "message": "Transferencias"
+ },
+ "troubleTokenBalances": {
+ "message": "Tuvimos problemas para cargar tus saldos de tokens. Puedes verlos ",
+ "description": "Seguidos por un enlace (aquí) para ver los saldos de token"
+ },
+ "twelveWords": {
+ "message": "Estas 12 palabras son la única forma de restablecer tus cuentas de MetaMask. \nGuárdalas en un lugar seguro y secreto."
+ },
+ "typePassword": {
+ "message": "Escribe tu contraseña"
+ },
+ "uiWelcome": {
+ "message": "Bienvenido a la nueva UI (Beta)"
+ },
+ "uiWelcomeMessage": {
+ "message": "Estás usando la nueva UI de MetaMask. Echa un vistazo alrededor, prueba las nuevas características, tales como mandar tokens, y háznos saber si tienes algún problema"
+ },
+ "unavailable": {
+ "message": "No disponible"
+ },
+ "unapproved": {
+ "message": "No aprobado"
+ },
+ "unknown": {
+ "message": "Desconocido (a)"
+ },
+ "unknownNetwork": {
+ "message": "Red privada desconocida"
+ },
+ "unknownNetworkId": {
+ "message": "ID (identidad) de red desconocida"
+ },
+ "uriErrorMsg": {
+ "message": "URI necesita el prefijo HTTP/HTTPS apropiado"
+ },
+ "usaOnly": {
+ "message": "Sólo USA (Estados Unidos)",
+ "description": "El uso de este exchange (casa de cambio) está limitado a las personas dentro de los Estados Unidos de América"
+ },
+ "useOldUI": {
+ "message": "Usar UI antigua"
+ },
+ "usedByClients": {
+ "message": "Utilizado por una variedad de clientes diferentes"
+ },
+ "validFileImport": {
+ "message": "Debes selecionar un archivo valido para importar"
+ },
+ "vaultCreated": {
+ "message": "Bóveda creada"
+ },
+ "viewAccount": {
+ "message": "Mirar cuenta"
+ },
+ "visitWebSite": {
+ "message": "Visita nuestro sitio web"
+ },
+ "walletSeed": {
+ "message": "Semilla de la billetera"
+ },
+ "warning": {
+ "message": "Advertencia"
+ },
+ "welcomeBeta": {
+ "message": "Bienvenido a Metamask Beta"
+ },
+ "whatsThis": {
+ "message": "¿Qué es esto?"
+ },
+ "youSign": {
+ "message": "Usted está firmando"
+ },
+ "yourSigRequested": {
+ "message": "Tu firma ya fue solicitada"
}
}
diff --git a/app/_locales/es_419/messages.json b/app/_locales/es_419/messages.json
deleted file mode 100644
index 78fc64dbf..000000000
--- a/app/_locales/es_419/messages.json
+++ /dev/null
@@ -1,10 +0,0 @@
-{
- "appName": {
- "message": "MetaMask",
- "description": "The name of the application"
- },
- "appDescription": {
- "message": "Administración de identidad en Ethereum",
- "description": "The description of the application"
- }
-}
diff --git a/app/_locales/hn/messages.json b/app/_locales/hn/messages.json
new file mode 100644
index 000000000..3703faa13
--- /dev/null
+++ b/app/_locales/hn/messages.json
@@ -0,0 +1,819 @@
+{
+ "accept": {
+ "message": "स्वीकार करें"
+ },
+ "account": {
+ "message": "खाता"
+ },
+ "accountDetails": {
+ "message": "खाता विवरण"
+ },
+ "accountName": {
+ "message": "खाता का नाम"
+ },
+ "address": {
+ "message": "खाते का पता"
+ },
+ "addCustomToken": {
+ "message": "कस्टम टोकन जोड़ें"
+ },
+ "addToken": {
+ "message": "टोकन जोड़ें"
+ },
+ "addTokens": {
+ "message": "टोकनो को जोड़ें"
+ },
+ "amount": {
+ "message": "राशि"
+ },
+ "amountPlusGas": {
+ "message": "राशि + गैस"
+ },
+ "appDescription": {
+ "message": "एथरेम ब्राउज़र एक्सटेंशन",
+ "description": "आवेदन का विवरण"
+ },
+ "appName": {
+ "message": "मेटामास्क/MetaMask",
+ "description": "एप्लिकेशन का नाम"
+ },
+ "attemptingConnect": {
+ "message": "ब्लॉकचैन से कनेक्ट करने का प्रयास करना होगा।सब्र करे।"
+ },
+ "attributions": {
+ "message": "एट्रिब्यूशन"
+ },
+ "available": {
+ "message": "एट्रिब्यूशन उपलब्ध ह्ने"
+ },
+ "back": {
+ "message": "वापस"
+ },
+ "balance": {
+ "message": "उपलब्ध बैलेंस।"
+ },
+ "balances": {
+ "message": "ापके उपलब्ध बैलेंस"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "वर्तमान गैस कुल के लिए अपर्याप्त शेष"
+ },
+ "beta": {
+ "message": "BETA/बीटा"
+ },
+ "betweenMinAndMax": {
+ "message": "$1 के बराबर या ज्यदा या, $2 के बराबर या कम होना चाहिए।",
+ "description": "हेक्स इनपुट के लिए दशमलव इनपुट के रूप में सहायक"
+ },
+ "blockiesIdenticon": {
+ "message": "ब्लॉकीज पहचान का उपयोग करें"
+ },
+ "borrowDharma": {
+ "message": "धर्मा (बीटा) से / के साथ उधार लें"
+ },
+ "builtInCalifornia": {
+ "message": "मेटामास्क कैलिफ़ोर्निया में डिज़ाइन और बनाया गया है।"
+ },
+ "buy": {
+ "message": "खरीदें"
+ },
+ "buyCoinbase": {
+ "message": "कॉनबेस पर खरीदें"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "बिल्टकोइन, एथरेम और लाइटकोइन खरीदने और बेचने के लिए दुनिया का सबसे लोकप्रिय तरीका Coinbase है।"
+ },
+ "cancel": {
+ "message": "रद्द करें"
+ },
+ "classicInterface": {
+ "message": "क्लासिक इंटरफ़ेस का उपयोग क"
+ },
+ "clickCopy": {
+ "message": "कॉपी करने के लिए क्लिक करें"
+ },
+ "confirm": {
+ "message": "पुष्टि करें"
+ },
+ "confirmContract": {
+ "message": "अनुबंध की पुष्टि करें"
+ },
+ "confirmPassword": {
+ "message": "पासवर्ड की पुष्टि करें"
+ },
+ "confirmTransaction": {
+ "message": "लेनदेन की पुष्टि करें"
+ },
+ "continue": {
+ "message": "जारी रखें"
+ },
+ "continueToCoinbase": {
+ "message": "कॉ्ोनबेस को ब्हेजना जारी रखें"
+ },
+ "contractDeployment": {
+ "message": "अनुबंध परिनियोजन व तैनाती"
+ },
+ "conversionProgress": {
+ "message": "रूपांतरण प्रगति में हे।"
+ },
+ "copiedButton": {
+ "message": "कॉपी किया गया"
+ },
+ "copiedClipboard": {
+ "message": "क्लिपबोर्ड पर कॉपी किया गया"
+ },
+ "copiedExclamation": {
+ "message": "कॉपी कर दिया गया!"
+ },
+ "copiedSafe": {
+ "message": "मैंने इसे कहीं सुरक्षित कॉपी कर दिया है"
+ },
+ "copy": {
+ "message": "कॉपी / प्रतिलिपि कर्रे"
+ },
+ "copyToClipboard": {
+ "message": "क्लिपबोर्ड पर कॉपी करें"
+ },
+ "copyButton": {
+ "message": " कॉपी / प्रतिलिपि कर्रे [बत्तन] "
+ },
+ "copyPrivateKey": {
+ "message": "यह आपकी निजी कुंजी है (कॉपी करने के लिए क्लिक करें)।"
+ },
+ "create": {
+ "message": "बनाएं"
+ },
+ "createAccount": {
+ "message": "खाता बनाएं"
+ },
+ "createDen": {
+ "message": "डेन बनाएं"
+ },
+ "crypto": {
+ "message": "क्रिप्टो",
+ "description": "एक्सचेंज टाइप (क्रिप्टोक्यूचरस)"
+ },
+ "currentConversion": {
+ "message": "वर्तमान रूपांतरण"
+ },
+ "currentNetwork": {
+ "message": "वर्तमान नेटवर्क"
+ },
+ "customGas": {
+ "message": "अनुकूलित करें गैस"
+ },
+ "customize": {
+ "message": "अनुकूलित करें"
+ },
+ "customRPC": {
+ "message": "कस्टम RPC"
+ },
+ "decimalsMustZerotoTen": {
+ "message": "दशमलव कम से कम 0 होनी चाहिए, और 36 से अधिक नहीं होनी चाहिए।"
+ },
+ "decimal": {
+ "message": "दशमलव परिशुद्धता"
+ },
+ "defaultNetwork": {
+ "message": "ईथर लेनदेन के लिए डिफ़ॉल्ट नेटवर्क मुख्य नेट है।"
+ },
+ "denExplainer": {
+ "message": "आपका डेन मेटामास्क के भीतर आपका पासवर्ड-एन्क्रिप्टेड स्टोरेज है।"
+ },
+ "deposit": {
+ "message": "जमा"
+ },
+ "depositBTC": {
+ "message": "नीचे दिए गए पते पर अपना बीटीसी जमा करें:"
+ },
+ "depositCoin": {
+ "message": "नीचे दिए गए पते पर अपना $1 जमा करें",
+ "description": "उपयोगकर्ता को बताता है कि उन्होंने सिक्का के साथ जमा करने के लिए किस सिक्का का चयन किया है"
+ },
+ "depositEth": {
+ "message": "Eth जमाआर्थ"
+ },
+ "depositEther": {
+ "message": "जमा - Ether"
+ },
+ "depositFiat": {
+ "message": "फिएट के साथ जमा हो"
+ },
+ "depositFromAccount": {
+ "message": "दूसरे खाते से जमा करें"
+ },
+ "depositShapeShift": {
+ "message": "शेपशिप के साथ जमा करें"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "यदि आप अन्य क्रिप्टोकाउंटरज रखते हैं, तो आप सीधे मेटामास्क वॉलेट में ईथर को व्यापार और जमा कर सकते हैं। कोई खाता आवश्यक नहीं है।"
+ },
+ "details": {
+ "message": "संदेश विवरण"
+ },
+ "directDeposit": {
+ "message": "प्रत्यक्ष जमा"
+ },
+ "directDepositEther": {
+ "message": "सीधे ईथर जमा करें"
+ },
+ "directDepositEtherExplainer": {
+ "message": "यदि आपके पास पहले से कुछ ईथर है, तो सीधे जमा द्वारा अपने नए बटुए में ईथर प्राप्त करने का तेज़ तरीका है।"
+ },
+ "done": {
+ "message": "संपन्न"
+ },
+ "downloadStatelogs": {
+ "message": "राज्य लॉग डाउनलोड करें"
+ },
+ "edit": {
+ "message": "संपादित करें"
+ },
+ "editAccountName": {
+ "message": "खाता नाम संपादित करें"
+ },
+ "emailUs": {
+ "message": "हमें ईमेल करें!"
+ },
+ "encryptNewDen": {
+ "message": "अपना नया डेन एन्क्रिप्ट करें"
+ },
+ "enterPassword": {
+ "message": "पासवर्ड दर्ज करें"
+ },
+ "enterPasswordConfirm": {
+ "message": "पुष्टि करने के लिए अपना पासवर्ड दर्ज करें"
+ },
+ "etherscanView": {
+ "message": "ईथरस्कैन पर खाता देखें"
+ },
+ "exchangeRate": {
+ "message": "विनिमय दरै"
+ },
+ "exportPrivateKey": {
+ "message": "निजी कुंजी निर्यात करें"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "अपने जोखिम पर निजी कुंजी निर्यात करें।"
+ },
+ "failed": {
+ "message": "विफल"
+ },
+ "fiat": {
+ "message": "FIAT एक्सचेंज टाइप",
+ "description": "एक्सचेंज FIAT टाइप"
+ },
+ "fileImportFail": {
+ "message": "फ़ाइल आयात काम नहीं कर रहा है? यहां क्लिक करें!",
+ "description": "यूजर को अपने खाते को जे.एस.ौ.एन फ़ाइल से आयात करने में मदद करता है"
+ },
+ "followTwitter": {
+ "message": "हमें ट्विटर पर अनुसरण करें"
+ },
+ "from": {
+ "message": "की तरफ से - संदेश"
+ },
+ "fromToSame": {
+ "message": "से और पता करने के लिए समान नहीं हो सकता"
+ },
+ "fromShapeShift": {
+ "message": "सेशशशफ्ट का"
+ },
+ "gas": {
+ "message": "गैस की लागत",
+ "description": "गैस की लागत का संक्षिप्त संकेत"
+ },
+ "gasFee": {
+ "message": "गैस शुल्क"
+ },
+ "gasLimit": {
+ "message": "गैस सीमा"
+ },
+ "gasLimitCalculation": {
+ "message": "हम नेटवर्क की सफलता दर के आधार पर सुझाई गई गैस सीमा की गणना करते हैं।"
+ },
+ "gasLimitRequired": {
+ "message": "गैस सीमा आवश्यक"
+ },
+ "gasLimitTooLow": {
+ "message": "२१००० - गैस की सीमा कम से कम 21000 होनी चाहिए"
+ },
+ "generatingSeed": {
+ "message": "सृजन बीज उत्पन्न ... उत्पन्न ...उत्पन्न..."
+ },
+ "gasPrice": {
+ "message": "गैस मूल्य (जीडब्ल्यूईआई),(GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "हम नेटवर्क की सफलता दर के आधार पर सुझाए गए गैस की कीमतों की गणना करते हैं।"
+ },
+ "gasPriceRequired": {
+ "message": "गैस की कीमत आवश्यक है"
+ },
+ "getEther": {
+ "message": "ईथर प्राप्त करें"
+ },
+ "getEtherFromFaucet": {
+ "message": "$1 के लिए एक नल से ईथर प्राप्त करें",
+ "description": "ईथर नल के लिए नेटवर्क नाम प्रदर्शित करता है"
+ },
+ "greaterThanMin": {
+ "message": "$1 के बराबर या बराबर होना चाहिए।",
+ "description": "हेक्स इनपुट के लिए दशमलव इनपुट के रूप में सहायक"
+ },
+ "here": {
+ "message": "यहां",
+ "description": "अधिक जानकारी के लिए यहां क्लिक करें- (परेशानी के साथ जाता है टोकनबैलेंस) (troubleTokenBalances)"
+ },
+ "hereList": {
+ "message": "यहां एक सूची है !!!!"
+ },
+ "hide": {
+ "message": "छुपाएं"
+ },
+ "hideToken": {
+ "message": "टोकन छिपाएं"
+ },
+ "hideTokenPrompt": {
+ "message": "टोकन छिपाएंn?"
+ },
+ "howToDeposit": {
+ "message": "आप ईथर जमा कैसे करना चाहेंगे?"
+ },
+ "holdEther": {
+ "message": "यह आपको आकाश और टोकन रखने की अनुमति देता है, और विकेंद्रीकृत अनुप्रयोगों के लिए आपके पुल के रूप में कार्य करता है।"
+ },
+ "import": {
+ "message": "आयात",
+ "description": "एक चयनित फ़ाइल से एक खाता आयात करने के लिए बटन "
+ },
+ "importAccount": {
+ "message": "खाता आयात"
+ },
+ "importAccountMsg": {
+ "message": "आयात किए गए खाते आपके मूल रूप से बनाए गए मेटामास्क अकाउंट सीडफ्रेज से संबद्ध नहीं होंगे। आयात किए गए खातों के बारे में और जानें"
+ },
+ "importAnAccount": {
+ "message": "खाता आयात करैॉ"
+ },
+ "importDen": {
+ "message": "मौजूदा डेन आयात करें - DEN"
+ },
+ "imported": {
+ "message": "आयातित",
+ "description": "यह स्थिति दिखाती है कि कोई खाता पूरी तरह से कीरिंग में लोड हो चुका है"
+ },
+ "infoHelp": {
+ "message": "जानकारी और सहायता"
+ },
+ "insufficientFunds": {
+ "message": "अपर्याप्त धन"
+ },
+ "insufficientTokens": {
+ "message": "अपर्याप्त टोकन।"
+ },
+ "invalidAddress": {
+ "message": "अमान्य पता"
+ },
+ "invalidAddressRecipient": {
+ "message": "प्राप्तकर्ता का पता अमान्य है"
+ },
+ "invalidGasParams": {
+ "message": "अमान्य गैस पैरामीटर"
+ },
+ "invalidInput": {
+ "message": "अमान्य इनपुट।"
+ },
+ "invalidRequest": {
+ "message": "अमान्य अनुरोध"
+ },
+ "invalidRPC": {
+ "message": "अमान्य RPC कै URI"
+ },
+ "jsonFail": {
+ "message": "कुछ गलत हो गया। कृपया सुनिश्चित करें कि आपकी JSON फ़ाइल ठीक से फ़ॉर्मेट की गई है।"
+ },
+ "jsonFile": {
+ "message": "JSON फ़ाइल",
+ "description": "एक खाता आयात करने के लिए प्रारूप"
+ },
+ "kovan": {
+ "message": "कोवान टेस्ट नेटवर्क"
+ },
+ "knowledgeDataBase": {
+ "message": "हमारे नॉलेज बेस पर जाएं"
+ },
+ "lessThanMax": {
+ "message": "$1 से कम या बराबर होना चाहिए।",
+ "description": "हेक्स इनपुट के लिए दशमलव इनपुट के रूप में सहायक"
+ },
+ "likeToAddTokens": {
+ "message": "क्या आप इन टोकनों को जोड़ना चाहते हैं?"
+ },
+ "limit": {
+ "message": "सीमा"
+ },
+ "loading": {
+ "message": "लोड हो रहा है ....."
+ },
+ "loadingTokens": {
+ "message": "टोकन लोड हो रहा है ....."
+ },
+ "localhost": {
+ "message": "स्थानीयहोस्ट 8545"
+ },
+ "login": {
+ "message": "लॉग इन करें"
+ },
+ "logout": {
+ "message": "लॉग आउट करें"
+ },
+ "loose": {
+ "message": "ढीला"
+ },
+ "loweCaseWords": {
+ "message": "बीज शब्द में केवल लोअरकेस वर्ण होते हैं"
+ },
+ "mainnet": {
+ "message": "मुख्य ईथरम नेटवर्क"
+ },
+ "message": {
+ "message": "संदेश"
+ },
+ "metamaskDescription": {
+ "message": "मेटामास्क एथर्मम के लिए एक सुरक्षित पहचान वॉल्ट है।"
+ },
+ "min": {
+ "message": "न्यूनतम"
+ },
+ "myAccounts": {
+ "message": "मेरे खाते"
+ },
+ "mustSelectOne": {
+ "message": "कम से कम 1 टोकन का चयन करना आवश्यक है।"
+ },
+ "needEtherInWallet": {
+ "message": "मेटामास्क का उपयोग करने वाले विकेन्द्रीकृत अनुप्रयोगों के साथ बातचीत करने के लिए, आपको अपने वॉलेट में ईथर की आवश्यकता होगी।"
+ },
+ "needImportFile": {
+ "message": "आयात करने के लिए आपको एक फ़ाइल का चयन करना होगा।",
+ "description": "प्रयोक्ता महत्वपूर्ण खाता है और उसे जारी रखने के लिए एक फ़ाइल जोड़ने की आवश्यकता है"
+ },
+ "needImportPassword": {
+ "message": "चयनित फ़ाइल के लिए आपको एक पासवर्ड दर्ज करना होगा।",
+ "description": "पासवर्ड और फाइल को एक खाते आयात करने के लिए आवश्यक है"
+ },
+ "negativeETH": {
+ "message": "ईटीएच की नकारात्मक मात्रा नहीं भेज सकते हैं।."
+ },
+ "networks": {
+ "message": "नेटवर्क"
+ },
+ "newAccount": {
+ "message": "नया खाता"
+ },
+ "newAccountNumberName": {
+ "message": "नया खाता $1",
+ "description": "खाते का खाता बनाने पर अगले खाते का डिफ़ॉल्ट नाम"
+ },
+ "newContract": {
+ "message": "नया अनुबंध"
+ },
+ "newPassword": {
+ "message": "नया पासवर्ड (न्यूनतम 8 वर्ण)"
+ },
+ "newRecipient": {
+ "message": "नया प्राप्तकर्ता"
+ },
+ "newRPC": {
+ "message": "नया RPC URL"
+ },
+ "next": {
+ "message": "अगला"
+ },
+ "noAddressForName": {
+ "message": "इस नाम के लिए कोई पता सेट नहीं किया गया है।"
+ },
+ "noDeposits": {
+ "message": "कोई जमा प्राप्त नहीं हुई"
+ },
+ "noTransactionHistory": {
+ "message": "कोई लेनदेन इतिहास नहीं ..."
+ },
+ "noTransactions": {
+ "message": "कोई लेन-देन नहीं"
+ },
+ "notStarted": {
+ "message": "प्रारंभ नहीं किया गया"
+ },
+ "oldUI": {
+ "message": "पुराना UI"
+ },
+ "oldUIMessage": {
+ "message": "आप पुराने UI पर वापस आ गए हैं। आप ऊपर दाईं ओर ड्रॉपडाउन मेनू में विकल्प के माध्यम से नए UI पर वापस स्विच कर सकते हैं।"
+ },
+ "or": {
+ "message": "या",
+ "description": "एक नया खाता बनाने या आयात करने के बीच की पसंद"
+ },
+ "passwordCorrect": {
+ "message": "कृपया सुनिश्चित करें कि आपका पासवर्ड सही है।"
+ },
+ "passwordMismatch": {
+ "message": "पासवर्ड मेल नहीं खाते",
+ "description": "पासवर्ड निर्माण प्रक्रिया में, दो नए पासवर्ड फ़ील्ड मेल नहीं खाते"
+ },
+ "passwordShort": {
+ "message": "पासवर्ड पर्याप्त लंबा नहीं",
+ "description": "पासवर्ड बनाने की प्रक्रिया में, पासवर्ड सुरक्षित होने के लिए पर्याप्त नहीं है"
+ },
+ "pastePrivateKey": {
+ "message": "यहां अपनी निजी कुंजी स्ट्रिंग चिपकाएं:",
+ "description": "किसी निजी कुंजी से किसी खाते को आयात करने के लिए"
+ },
+ "pasteSeed": {
+ "message": "यहां अपने बीज वाक्यांश पेस्ट करें!"
+ },
+ "personalAddressDetected": {
+ "message": "व्यक्तिगत पता मिला। टोकन अनुबंध का पता इनपुट।"
+ },
+ "pleaseReviewTransaction": {
+ "message": "कृपया अपने लेनदेन की समीक्षा करें।"
+ },
+ "privacyMsg": {
+ "message": "गोपनीयता नीति"
+ },
+ "privateKey": {
+ "message": "निजी कुंजी",
+ "description": "खाता आयात करने के लिए उपयोग करने के लिए इस प्रकार की फ़ाइल का चयन करें"
+ },
+ "privateKeyWarning": {
+ "message": "चेतावनी: कभी भी इस कुंजी का खुलासा न करें। आपकी निजी कुंजी वाले कोई भी आपके खाते में रखी किसी भी संपत्ति को चुरा सकता है।"
+ },
+ "privateNetwork": {
+ "message": "निजी नेटवर्क"
+ },
+ "qrCode": {
+ "message": "QR कोड दिखाएं"
+ },
+ "readdToken": {
+ "message": "आप अपने खाता विकल्प मेनू में .टोकन जोड़ें. पर जाकर भविष्य में इस टोकन को वापस जोड़ सकते हैं।"
+ },
+ "readMore": {
+ "message": "यहां और पढ़ें।"
+ },
+ "readMore2": {
+ "message": "हां - और पढ़ें।"
+ },
+ "receive": {
+ "message": "प्राप्त करें"
+ },
+ "recipientAddress": {
+ "message": "प्राप्तकर्ता पता"
+ },
+ "refundAddress": {
+ "message": "आपका रिफंड पता"
+ },
+ "rejected": {
+ "message": "अस्वीकृत"
+ },
+ "resetAccount": {
+ "message": "खाता रीसेट करें"
+ },
+ "restoreFromSeed": {
+ "message": "बीज वाक्यांश से पुनर्स्थापित करें"
+ },
+ "required": {
+ "message": "आवश्यक"
+ },
+ "retryWithMoreGas": {
+ "message": "यहां एक उच्च गैस कीमत के साथ पुन: प्रयास करें"
+ },
+ "revealSeedWords": {
+ "message": "बीज शब्द प्रकट करें"
+ },
+ "revealSeedWordsWarning": {
+ "message": "किसी सार्वजनिक स्थान पर अपने बीज के शब्द ठीक नहीं करें! ये शब्द आपके सभी खातों को चोरी करने के लिए उपयोग किए जा सकते हैं।"
+ },
+ "revert": {
+ "message": "वापस"
+ },
+ "rinkeby": {
+ "message": "रिचीव टेस्ट नेटवर्क"
+ },
+ "ropsten": {
+ "message": "रॉप्स्टेन टेस्ट नेटवर्क"
+ },
+ "sampleAccountName": {
+ "message": "उदाहरण के लिए मेरा नया खाता",
+ "description": "उपयोगकर्ता को अपने खाते में मानव-पठनीय नाम जोड़ने की अवधारणा को समझें."
+ },
+ "save": {
+ "message": "सहेजें"
+ },
+ "saveAsFile": {
+ "message": "फ़ाइल के रूप में सहेजें",
+ "description": "खाता निर्यात प्रक्रिया"
+ },
+ "saveSeedAsFile": {
+ "message": "सेड वर्ड्स - फाईल्स सेव करें"
+ },
+ "search": {
+ "message": "खोज करें"
+ },
+ "secretPhrase": {
+ "message": "अपनी गुप्त बारह शब्द वाक्यांश यहाँ अपनी तिजोरी को पुनर्स्थापित करने के लिए दर्ज करें।"
+ },
+ "seedPhraseReq": {
+ "message": "बीज वाक्यांश 12 शब्द लंबा हैं"
+ },
+ "select": {
+ "message": "चुनें"
+ },
+ "selectCurrency": {
+ "message": "मुद्रा चुनें"
+ },
+ "selectService": {
+ "message": "सेवा चुनें"
+ },
+ "selectType": {
+ "message": "प्रकार चुनें"
+ },
+ "send": {
+ "message": "भेजें"
+ },
+ "sendETH": {
+ "message": "भेजें ETH"
+ },
+ "sendTokens": {
+ "message": "भेजें टोकन"
+ },
+ "sendTokensAnywhere": {
+ "message": "इटोरम खाते वाले किसी को भी टोकन भेजें"
+ },
+ "settings": {
+ "message": "सेटिंग्स"
+ },
+ "shapeshiftBuy": {
+ "message": "शेपेशिस्ट के साथ खरीदें"
+ },
+ "showPrivateKeys": {
+ "message": "निजी कुंजी दिखाएँ"
+ },
+ "showQRCode": {
+ "message": "QR कोड दिखाएं"
+ },
+ "sign": {
+ "message": "हस्ताक्षर"
+ },
+ "signMessage": {
+ "message": "हस्ताक्षर संदेश"
+ },
+ "signNotice": {
+ "message": "इस संदेश पर हस्ताक्षर करने से \n साइड इफेक्ट हो सकते हैं। \n केवल अपने पूरे खाते के साथ पूरी तरह से भरोसेमंद \n साइटों से संदेश पर हस्ताक्षर करें। \n यह खतरनाक विधि भविष्य के संस्करण में निकाल दी जाएगी।"
+ },
+ "sigRequest": {
+ "message": "हस्ताक्षर अनुरोध"
+ },
+ "sigRequested": {
+ "message": "हस्ताक्षर अनुरोधित"
+ },
+ "spaceBetween": {
+ "message": "केवल शब्दों के बीच एक स्थान हो सकता है"
+ },
+ "status": {
+ "message": "स्थिति"
+ },
+ "stateLogs": {
+ "message": "स्थिति संदेश"
+ },
+ "stateLogsDescription": {
+ "message": "स्थिति संदेश में आपका सार्वजनिक खाता, पतों और भेजे गए लेनदेन, होते हैं।"
+ },
+ "submit": {
+ "message": "सबमिट करें"
+ },
+ "supportCenter": {
+ "message": "हमारे सहायता केंद्र पर जाएं"
+ },
+ "symbolBetweenZeroTen": {
+ "message": "प्रतीक 0 और 10 अक्षरों के बीच होना चाहिए"
+ },
+ "takesTooLong": {
+ "message": "बहुत समय ले रहा है?"
+ },
+ "terms": {
+ "message": "उपयोग की शर्तें"
+ },
+ "testFaucet": {
+ "message": "टेस्ट नलि"
+ },
+ "to": {
+ "message": "के लिए"
+ },
+ "toETHviaShapeShift": {
+ "message": "शैपशैफ्ट द्वारा $1 से ETH में जमा",
+ "description": "संदेश की शुरुआत में जमा प्रकार भर जाएगा"
+ },
+ "tokenAddress": {
+ "message": "टोकन पता"
+ },
+ "tokenAlreadyAdded": {
+ "message": "टोकन पहले ही जोड़ा जा चुका है।"
+ },
+ "tokenBalance": {
+ "message": "आपका टोकन बैलेंस है:"
+ },
+ "tokenSelection": {
+ "message": "टोकन के लिए खोजें या हमारी लोकप्रिय टॉकेन्स की सूची से चुनें।"
+ },
+ "tokenSymbol": {
+ "message": "टोकन प्रतीक"
+ },
+ "tokenWarning1": {
+ "message": "अपने मेटामास्क अकाउंट से खरीदे गए टोकनों का नज़र रखें। अगर आप किसी अलग खाते का उपयोग कर टोकन खरीदे हैं, तो ये टोकन यहां दिखाई नहीं देंगे।"
+ },
+ "total": {
+ "message": "कुल"
+ },
+ "transactions": {
+ "message": "लेनदेन"
+ },
+ "transactionMemo": {
+ "message": "लेनदेन मेमो (वैकल्पिक)"
+ },
+ "transactionNumber": {
+ "message": "लेनदेन संख्या"
+ },
+ "transfers": {
+ "message": "स्थानांतरण"
+ },
+ "troubleTokenBalances": {
+ "message": "मुसीबत... आपके टोकन शेष राशि को लोड करने में हमें परेशानी हुई थी। आप उन्हें देख सकते हैं",
+ "description": "टोकन शेष देखने के लिए एक लिंक ... (यहां)"
+ },
+ "twelveWords": {
+ "message": "ये 12 शब्द आपके मेटामास्क खातों को पुनर्स्थापित करने का एकमात्र तरीका है। \n उन्हें कहीं सुरक्षित और गुप्त रूप से सहेजें।"
+ },
+ "typePassword": {
+ "message": "अपना पासवर्ड टाइप करें"
+ },
+ "uiWelcome": {
+ "message": "नया यूआई (बीटा) में आपका स्वागत है"
+ },
+ "uiWelcomeMessage": {
+ "message": "आप अब नए मेटामास्क UI का उपयोग कर रहे हैं। चारों ओर एक नज़र डालें, टोकन भेजने की तरह नई सुविधाएं देखें, और हमें बताएं कि आपके पास कोई समस्या है।"
+ },
+ "unavailable": {
+ "message": "अनुपलब्ध"
+ },
+ "unknown": {
+ "message": "अज्ञात नेटवर्क"
+ },
+ "unknownNetwork": {
+ "message": "अज्ञात निजी नेटवर्क"
+ },
+ "unknownNetworkId": {
+ "message": "अज्ञात नेटवर्क आईडी.य़"
+ },
+ "uriErrorMsg": {
+ "message": "URI-यूआरआई को उपयुक्त HTTP / HTTPS उपसर्ग की आवश्यकता होती है।"
+ },
+ "usaOnly": {
+ "message": "केवल यूएसए - USA",
+ "description": "इस एक्सचेंज का उपयोग करना संयुक्त राज्य अमेरिका के अंदर ही सीमित है"
+ },
+ "usedByClients": {
+ "message": "विभिन्न क्लाइंट्स द्वारा उपयोग किया जाता है"
+ },
+ "useOldUI": {
+ "message": "पुराने UI का उपयोग करें"
+ },
+ "validFileImport": {
+ "message": "आयात करने के लिए आपको एक वैध फ़ाइल चुननी होगी।"
+ },
+ "vaultCreated": {
+ "message": "वॉल्ट बनाया गया"
+ },
+ "viewAccount": {
+ "message": "खाता देखें"
+ },
+ "visitWebSite": {
+ "message": "हमारी वेब साइट पर जाएं"
+ },
+ "warning": {
+ "message": "चेतावनी"
+ },
+ "welcomeBeta": {
+ "message": "मेटामास्क बीटा में आपका स्वागत है"
+ },
+ "whatsThis": {
+ "message": "यह क्या है?"
+ },
+ "yourSigRequested": {
+ "message": "आपका हस्ताक्षर अनुरोध किया जा रहा है"
+ },
+ "youSign": {
+ "message": "आप हस्ताक्षर कर रहे हैं"
+ }
+}
diff --git a/app/_locales/it/messages.json b/app/_locales/it/messages.json
new file mode 100644
index 000000000..f54ef98ca
--- /dev/null
+++ b/app/_locales/it/messages.json
@@ -0,0 +1,819 @@
+{
+ "accept": {
+ "message": "Accetta"
+ },
+ "account": {
+ "message": "Account"
+ },
+ "accountDetails": {
+ "message": "Dettagli Account"
+ },
+ "accountName": {
+ "message": "Nome Account"
+ },
+ "address": {
+ "message": "Indirizzo"
+ },
+ "addCustomToken": {
+ "message": "Aggiungi un token personalizzato"
+ },
+ "addToken": {
+ "message": "Aggiungi Token"
+ },
+ "addTokens": {
+ "message": "Aggiungi più token"
+ },
+ "amount": {
+ "message": "Importo"
+ },
+ "amountPlusGas": {
+ "message": "Importo + Gas"
+ },
+ "appDescription": {
+ "message": "Ethereum Browser Extension",
+ "description": "La descrizione dell'applicazione"
+ },
+ "appName": {
+ "message": "MetaMask",
+ "description": "Il nome dell'applicazione"
+ },
+ "attemptingConnect": {
+ "message": "Tentativo di connessione alla blockchain."
+ },
+ "attributions": {
+ "message": "Attribuzioni"
+ },
+ "available": {
+ "message": "Disponibile"
+ },
+ "back": {
+ "message": "Indietro"
+ },
+ "balance": {
+ "message": "Bilancio:"
+ },
+ "balances": {
+ "message": "I tuoi bilanci"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "Bilancio insufficiente per il gas totale corrente"
+ },
+ "beta": {
+ "message": "BETA"
+ },
+ "betweenMinAndMax": {
+ "message": "deve essere maggiore o uguale a $1 e minore o uguale a $2.",
+ "description": "aiuto per inserire un input esadecimale come decimale"
+ },
+ "blockiesIdenticon": {
+ "message": "Usa le icone Blockie"
+ },
+ "borrowDharma": {
+ "message": "Prendi in presisito con Dharma (Beta)"
+ },
+ "builtInCalifornia": {
+ "message": "MetaMask è progettato e costruito in California."
+ },
+ "buy": {
+ "message": "Compra"
+ },
+ "buyCoinbase": {
+ "message": "Compra su Coinbase"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "Coinbase è il servizio più popolare al mondo per comprare e vendere bitcoin, ethereum e litecoin."
+ },
+ "cancel": {
+ "message": "Cancella"
+ },
+ "classicInterface": {
+ "message": "Usa l'interfaccia classica"
+ },
+ "clickCopy": {
+ "message": "Clicca per Copiare"
+ },
+ "confirm": {
+ "message": "Conferma"
+ },
+ "confirmContract": {
+ "message": "Conferma Contratto"
+ },
+ "confirmPassword": {
+ "message": "Conferma Password"
+ },
+ "confirmTransaction": {
+ "message": "Conferma Transazione"
+ },
+ "continue": {
+ "message": "Continua"
+ },
+ "continueToCoinbase": {
+ "message": "Continua su Coinbase"
+ },
+ "contractDeployment": {
+ "message": "Distribuzione Contratto"
+ },
+ "conversionProgress": {
+ "message": "Conversione in corso"
+ },
+ "copiedButton": {
+ "message": "Copiato"
+ },
+ "copiedClipboard": {
+ "message": "Copiato negli Appunti"
+ },
+ "copiedExclamation": {
+ "message": "Copiato!"
+ },
+ "copiedSafe": {
+ "message": "Le ho copiate in un posto sicuro"
+ },
+ "copy": {
+ "message": "Copia"
+ },
+ "copyToClipboard": {
+ "message": "Copia negli appunti"
+ },
+ "copyButton": {
+ "message": " Copia "
+ },
+ "copyPrivateKey": {
+ "message": "Questa è la tua chiave privata (clicca per copiare)"
+ },
+ "create": {
+ "message": "Crea"
+ },
+ "createAccount": {
+ "message": "Crea Account"
+ },
+ "createDen": {
+ "message": "Crea"
+ },
+ "crypto": {
+ "message": "Crypto",
+ "description": "Tipo di exchange (cryptomonete)"
+ },
+ "currentConversion": {
+ "message": "Cambio Corrente"
+ },
+ "currentNetwork": {
+ "message": "Rete Corrente"
+ },
+ "customGas": {
+ "message": "Personalizza Gas"
+ },
+ "customize": {
+ "message": "Personalizza"
+ },
+ "customRPC": {
+ "message": "RPC Personalizzata"
+ },
+ "decimalsMustZerotoTen": {
+ "message": "Il numero di decimali deve essere almeno 0, e non oltre 36."
+ },
+ "decimal": {
+ "message": "Precisione Decimali"
+ },
+ "defaultNetwork": {
+ "message": "La rete predefinita per transazioni in Ether è la Rete Ethereum Principale."
+ },
+ "denExplainer": {
+ "message": "Il DEN è il tuo archivio crittato con password dentro Metamask."
+ },
+ "deposit": {
+ "message": "Deposita"
+ },
+ "depositBTC": {
+ "message": "Deposita i tuoi BTC all'indirizzo sotto:"
+ },
+ "depositCoin": {
+ "message": "Deposita $1 all'indirizzo sotto",
+ "description": "Dice all'utente quale moneta ha selezionato per depositare con Shapeshift"
+ },
+ "depositEth": {
+ "message": "Deposita Eth"
+ },
+ "depositEther": {
+ "message": "Deposita Ether"
+ },
+ "depositFiat": {
+ "message": "Deposita con moneta Fiat"
+ },
+ "depositFromAccount": {
+ "message": "Deposita da un altro account"
+ },
+ "depositShapeShift": {
+ "message": "Deposita con ShapeShift"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "Se possiedi altre criptomonete, puoi scambiare e depositare Ether direttamente nel tuo portafoglio MetaMask. Nessun account richiesto."
+ },
+ "details": {
+ "message": "Dettagli"
+ },
+ "directDeposit": {
+ "message": "Deposito Diretto"
+ },
+ "directDepositEther": {
+ "message": "Deposita Direttamente Ether"
+ },
+ "directDepositEtherExplainer": {
+ "message": "Se possiedi già degli Ether, questa è la via più veloce per aggiungere Ether al tuo portafoglio con un deposito diretto."
+ },
+ "done": {
+ "message": "Finito"
+ },
+ "downloadStatelogs": {
+ "message": "Scarica i log di Stato"
+ },
+ "edit": {
+ "message": "Modifica"
+ },
+ "editAccountName": {
+ "message": "Modifica Nome Account"
+ },
+ "emailUs": {
+ "message": "Mandaci una mail!"
+ },
+ "encryptNewDen": {
+ "message": "Cripta il tuo nuovo DEN"
+ },
+ "enterPassword": {
+ "message": "Inserisci password"
+ },
+ "enterPasswordConfirm": {
+ "message": "Inserisci la tua password per confermare"
+ },
+ "etherscanView": {
+ "message": "Vedi account su Etherscan"
+ },
+ "exchangeRate": {
+ "message": "Tasso di cambio"
+ },
+ "exportPrivateKey": {
+ "message": "Esporta Chiave Privata"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "Esporta chiave privata a tuo rischio."
+ },
+ "failed": {
+ "message": "Fallito"
+ },
+ "fiat": {
+ "message": "FIAT",
+ "description": "Tipo di scambio"
+ },
+ "fileImportFail": {
+ "message": "Importazione file non funziona? Clicca qui!",
+ "description": "Aiuta gli utenti a importare il loro account da un file JSON"
+ },
+ "followTwitter": {
+ "message": "Seguici su Twitter"
+ },
+ "from": {
+ "message": "Da"
+ },
+ "fromToSame": {
+ "message": "Gli indirizzi Da e A non possono essere uguali"
+ },
+ "fromShapeShift": {
+ "message": "Da ShapeShift"
+ },
+ "gas": {
+ "message": "Gas",
+ "description": "Piccola indicazione del costo del gas"
+ },
+ "gasFee": {
+ "message": "Costo Gas"
+ },
+ "gasLimit": {
+ "message": "Gas Limite"
+ },
+ "gasLimitCalculation": {
+ "message": "Calcoliamo il gas limite suggerito in base al successo delle transazioni in rete."
+ },
+ "gasLimitRequired": {
+ "message": "Gas Limite Richiesto"
+ },
+ "gasLimitTooLow": {
+ "message": "Il Gas Limite deve essere almeno 21000"
+ },
+ "generatingSeed": {
+ "message": "Generando la frase seed..."
+ },
+ "gasPrice": {
+ "message": "Prezzo del Gas (GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "Calcoliamo il gas limite suggerito in base al successo delle transazioni in rete."
+ },
+ "gasPriceRequired": {
+ "message": "Prezzo Gas Richiesto"
+ },
+ "getEther": {
+ "message": "Ottieni Ether"
+ },
+ "getEtherFromFaucet": {
+ "message": "Ottieni Get Ether da un faucet per $1",
+ "description": "Visualizza il nome della rete per il faucet Ether"
+ },
+ "greaterThanMin": {
+ "message": "deve essere maggiore o uguale a $1.",
+ "description": "aiuto per inserire un input esadecimale come decimale"
+ },
+ "here": {
+ "message": "qui",
+ "description": "per intendere -clicca qui- per maggiori informazioni (va con troubleTokenBalances)"
+ },
+ "hereList": {
+ "message": "Questa è una lista!!!!"
+ },
+ "hide": {
+ "message": "Nascondi"
+ },
+ "hideToken": {
+ "message": "Nascondi Token"
+ },
+ "hideTokenPrompt": {
+ "message": "Nascondi Token?"
+ },
+ "howToDeposit": {
+ "message": "Come vuoi depositare Ether?"
+ },
+ "holdEther": {
+ "message": "Ti permette di tenere ether & token, e serve da ponte per le applicazioni decentralizzate."
+ },
+ "import": {
+ "message": "Importa",
+ "description": "Tasto per importare un account da un file selezionato"
+ },
+ "importAccount": {
+ "message": "Importa Account"
+ },
+ "importAccountMsg": {
+ "message":" Gli account importati non saranno associati alla frase seed originariamente creata con MetaMask. Impara di più sugli account importati "
+ },
+ "importAnAccount": {
+ "message": "Importa un account"
+ },
+ "importDen": {
+ "message": "Importa un DEN Esistente"
+ },
+ "imported": {
+ "message": "Importato",
+ "description": "stato che conferma che un account è stato totalmente caricato nel portachiavi"
+ },
+ "infoHelp": {
+ "message": "Informazioni & Aiuto"
+ },
+ "insufficientFunds": {
+ "message": "Fondi non sufficienti."
+ },
+ "insufficientTokens": {
+ "message": "Token non sufficienti."
+ },
+ "invalidAddress": {
+ "message": "Indirizzo non valido"
+ },
+ "invalidAddressRecipient": {
+ "message": "Indirizzo destinatario invalido"
+ },
+ "invalidGasParams": {
+ "message": "Parametri del Gas non validi"
+ },
+ "invalidInput": {
+ "message": "Input non valido."
+ },
+ "invalidRequest": {
+ "message": "Richiesta non Valida"
+ },
+ "invalidRPC": {
+ "message": "URI RPC invalido"
+ },
+ "jsonFail": {
+ "message": "Qualcosa è andato storto. Assicurati che il file JSON sia formattato correttamente."
+ },
+ "jsonFile": {
+ "message": "File JSON",
+ "description": "formato per importare un account"
+ },
+ "kovan": {
+ "message": "Rete di test Kovan"
+ },
+ "knowledgeDataBase": {
+ "message": "Visita la nostra Knowledge Base"
+ },
+ "lessThanMax": {
+ "message": "deve essere minore o uguale a $1.",
+ "description": "aiuto per inserire un input esadecimale come decimale"
+ },
+ "likeToAddTokens": {
+ "message": "Vorresti aggiungere questi token?"
+ },
+ "limit": {
+ "message": "Limite"
+ },
+ "loading": {
+ "message": "Caricamento..."
+ },
+ "loadingTokens": {
+ "message": "Caricamento Tokens..."
+ },
+ "localhost": {
+ "message": "Localhost 8545"
+ },
+ "login": {
+ "message": "Connetti"
+ },
+ "logout": {
+ "message": "Disconnetti"
+ },
+ "loose": {
+ "message": "Libero"
+ },
+ "loweCaseWords": {
+ "message": "le frasi seed hanno solo lettere minuscole"
+ },
+ "mainnet": {
+ "message": "Rete Ethereum Principale"
+ },
+ "message": {
+ "message": "Messaggio"
+ },
+ "metamaskDescription": {
+ "message": "MetaMask è una cassaforte sicura per identità su Ethereum."
+ },
+ "min": {
+ "message": "Minimo"
+ },
+ "myAccounts": {
+ "message": "Account Miei"
+ },
+ "mustSelectOne": {
+ "message": "Devi selezionare almeno un token."
+ },
+ "needEtherInWallet": {
+ "message": "Per interagire con applicazioni decentralizzate con MetaMask, devi possedere Ether nel tuo portafoglio."
+ },
+ "needImportFile": {
+ "message": "Devi selezionare un file da importare.",
+ "description": "L'utente sta importando un account e deve aggiungere un file per continuare"
+ },
+ "needImportPassword": {
+ "message": "Dei inserire una password per il file selezionato.",
+ "description": "Password e file necessari per importare un account"
+ },
+ "negativeETH": {
+ "message": "Non puoi inviare una quantità di ETH negativa."
+ },
+ "networks": {
+ "message": "Reti"
+ },
+ "newAccount": {
+ "message": "Nuovo Account"
+ },
+ "newAccountNumberName": {
+ "message": "Account $1",
+ "description": "Nome predefinito per il prossimo account da creare nella schermata di creazione account"
+ },
+ "newContract": {
+ "message": "Nuovo Contratto"
+ },
+ "newPassword": {
+ "message": "Nuova Password (minimo 8 caratteri)"
+ },
+ "newRecipient": {
+ "message": "Nuovo Destinatario"
+ },
+ "newRPC": {
+ "message": "Nuovo URL RPC"
+ },
+ "next": {
+ "message": "Prossimo"
+ },
+ "noAddressForName": {
+ "message": "Nessun indirizzo è stato impostato per questo nome."
+ },
+ "noDeposits": {
+ "message": "Nessun deposito ricevuto"
+ },
+ "noTransactionHistory": {
+ "message": "Nessuna cronologia delle transazioni."
+ },
+ "noTransactions": {
+ "message": "Nessuna Transazione"
+ },
+ "notStarted": {
+ "message": "Non Iniziato"
+ },
+ "oldUI": {
+ "message": "Vecchia interfaccia"
+ },
+ "oldUIMessage": {
+ "message": "Sei ritornato alla vecchia interfaccia. Puoi ritornare alla nuova interfaccia tramite l'opzione nel menu a discesa in alto a destra."
+ },
+ "or": {
+ "message": "o",
+ "description": "scelta tra creare o importare un nuovo account"
+ },
+ "passwordCorrect": {
+ "message": "Assicurati che la password sia corretta."
+ },
+ "passwordMismatch": {
+ "message": "le password non corrispondono",
+ "description": "nella creazione della password, le due password all'interno dei campi non corrispondono"
+ },
+ "passwordShort": {
+ "message": "password non sufficientemente lunga",
+ "description": "nella creazione della password, la password non è lunga abbastanza"
+ },
+ "pastePrivateKey": {
+ "message": "Incolla la tua chiave privata qui:",
+ "description": "Per importare un account da una chiave privata"
+ },
+ "pasteSeed": {
+ "message": "Incolla la tua frase seed qui!"
+ },
+ "personalAddressDetected": {
+ "message": "Rilevato indirizzo personale. Inserisci l'indirizzo del contratto del token."
+ },
+ "pleaseReviewTransaction": {
+ "message": "Ricontrolla la tua transazione."
+ },
+ "privacyMsg": {
+ "message": "Politica sulla Privacy"
+ },
+ "privateKey": {
+ "message": "Chiave Privata",
+ "description": "seleziona questo tipo di file per importare un account"
+ },
+ "privateKeyWarning": {
+ "message": "Attenzione: non dire a nessuno questa chiave! Chiunque con la tua chiave privata può rubare qualsiasi moneta contenuta nel tuo account."
+ },
+ "privateNetwork": {
+ "message": "Rete Privata"
+ },
+ "qrCode": {
+ "message": "Mostra Codice QR"
+ },
+ "readdToken": {
+ "message": "Puoi aggiungere nuovamente questo token in futuro andando in “Aggiungi token” nel menu delle opzioni del tuo account."
+ },
+ "readMore": {
+ "message": "Leggi di più qui."
+ },
+ "readMore2": {
+ "message": "Leggi di più."
+ },
+ "receive": {
+ "message": "Ricevi"
+ },
+ "recipientAddress": {
+ "message": "Indirizzo Destinatario"
+ },
+ "refundAddress": {
+ "message": "Indirizzo di Rimborso"
+ },
+ "rejected": {
+ "message": "Respinta"
+ },
+ "resetAccount": {
+ "message": "Resetta Account"
+ },
+ "restoreFromSeed": {
+ "message": "Ripristina da una frase seed"
+ },
+ "required": {
+ "message": "Richiesto"
+ },
+ "retryWithMoreGas": {
+ "message": "Riprova con un prezzo del Gas maggiore qui"
+ },
+ "revealSeedWords": {
+ "message": "Rivela Frase Seed"
+ },
+ "revealSeedWordsWarning": {
+ "message": "Non ripristinare la tua frase seed in pubblico!. Queste parole possono essere usate per rubare il tuo account."
+ },
+ "revert": {
+ "message": "Annulla"
+ },
+ "rinkeby": {
+ "message": "Rete di test Rinkeby"
+ },
+ "ropsten": {
+ "message": "Rete di test Ropsten"
+ },
+ "sampleAccountName": {
+ "message": "Es: Il mio nuovo account",
+ "description": "Aiuta l'utente a capire il concetto di aggiungere un nome leggibile al loro account"
+ },
+ "save": {
+ "message": "Salva"
+ },
+ "saveAsFile": {
+ "message": "Salva come File",
+ "description": "Processo per esportare un account"
+ },
+ "saveSeedAsFile": {
+ "message": "Salva la Frase Seed come File"
+ },
+ "search": {
+ "message": "Cerca"
+ },
+ "secretPhrase": {
+ "message": "Inserisci la tua frase segreta di dodici parole per ripristinare la cassaforte."
+ },
+ "seedPhraseReq": {
+ "message": "le frasi seed sono lunghe 12 parole"
+ },
+ "select": {
+ "message": "Seleziona"
+ },
+ "selectCurrency": {
+ "message": "Seleziona Moneta"
+ },
+ "selectService": {
+ "message": "Seleziona Servizio"
+ },
+ "selectType": {
+ "message": "Seleziona Tipo"
+ },
+ "send": {
+ "message": "Invia"
+ },
+ "sendETH": {
+ "message": "Invia ETH"
+ },
+ "sendTokens": {
+ "message": "Invia Tokens"
+ },
+ "sendTokensAnywhere": {
+ "message": "Invia Tokens a chiunque abbia un account Ethereum"
+ },
+ "settings": {
+ "message": "Impostazioni"
+ },
+ "shapeshiftBuy": {
+ "message": "Compra con Shapeshift"
+ },
+ "showPrivateKeys": {
+ "message": "Mostra Chiave Privata"
+ },
+ "showQRCode": {
+ "message": "Mostra Codie QR"
+ },
+ "sign": {
+ "message": "Firma"
+ },
+ "signMessage": {
+ "message": "Firma Messaggio"
+ },
+ "signNotice": {
+ "message": "Firmare questo messaggio può avere effetti collaterali pericolosi. \nFirma messaggi da siti di cui ti fidi totalmente. \nQuesto metodo pericoloso sarà rimosso in versioni future."
+ },
+ "sigRequest": {
+ "message": "Firma Richiesta"
+ },
+ "sigRequested": {
+ "message": "Richiesta Firma"
+ },
+ "spaceBetween": {
+ "message": "ci può essere solo uno spazio tra le parole"
+ },
+ "status": {
+ "message": "Stato"
+ },
+ "stateLogs": {
+ "message": "Log di Stato"
+ },
+ "stateLogsDescription": {
+ "message": "I log di stato contengono i tuoi indirizzi pubblici e le transazioni effettuate."
+ },
+ "submit": {
+ "message": "Invia"
+ },
+ "supportCenter": {
+ "message": "Visita il nostro Centro di Supporto"
+ },
+ "symbolBetweenZeroTen": {
+ "message": "Il simbolo deve essere lungo tra 0 e 10 caratteri."
+ },
+ "takesTooLong": {
+ "message": "Ci sta mettendo troppo?"
+ },
+ "terms": {
+ "message": "Termini di Uso"
+ },
+ "testFaucet": {
+ "message": "Prova Faucet"
+ },
+ "to": {
+ "message": "A"
+ },
+ "toETHviaShapeShift": {
+ "message": "$1 a ETH via ShapeShift",
+ "description": "il sistema riempirà il tipo di deposito all'inizio del messaggio"
+ },
+ "tokenAddress": {
+ "message": "Indirizzo Token"
+ },
+ "tokenAlreadyAdded": {
+ "message": "Il token è già stato aggiunto."
+ },
+ "tokenBalance": {
+ "message": "Bilancio Token:"
+ },
+ "tokenSelection": {
+ "message": "Cerca un token o seleziona dalla lista di token più popolari."
+ },
+ "tokenSymbol": {
+ "message": "Simbolo Token"
+ },
+ "tokenWarning1": {
+ "message": "Tieni traccia dei token che hai acquistato con il tuo account MetaMask. Se hai acquistato token con un account diverso, quei token non appariranno qui."
+ },
+ "total": {
+ "message": "Totale"
+ },
+ "transactions": {
+ "message": "transazioni"
+ },
+ "transactionMemo": {
+ "message": "Promemoria Transazione (opzionale)"
+ },
+ "transactionNumber": {
+ "message": "Numero Transazione"
+ },
+ "transfers": {
+ "message": "Trasferimenti"
+ },
+ "troubleTokenBalances": {
+ "message": "Abbiamo avuto un problema a caricare il bilancio dei tuoi token. Puoi vederlo ",
+ "description": "Seguito da un link (qui) per vedere il bilancio dei token"
+ },
+ "twelveWords": {
+ "message": "Queste 12 parole sono l'unico modo per ripristinare i tuoi account MetaMask. \nSalvale in un posto sicuro e segreto."
+ },
+ "typePassword": {
+ "message": "Inserisci Password"
+ },
+ "uiWelcome": {
+ "message": "Benvenuto alla nuova interfaccia (Beta)"
+ },
+ "uiWelcomeMessage": {
+ "message": "Stai utilizzanto la nuova interfaccia di MetaMask. Guarda in giro, prova nuove funzionalità come inviare token, e facci sapere se hai dei problemi."
+ },
+ "unavailable": {
+ "message": "Non Disponibile"
+ },
+ "unknown": {
+ "message": "Sconosciuto"
+ },
+ "unknownNetwork": {
+ "message": "Rete Privata Sconosciuta"
+ },
+ "unknownNetworkId": {
+ "message": "ID rete sconosciuto"
+ },
+ "uriErrorMsg": {
+ "message": "Gli URI richiedono un prefisso HTTP/HTTPS."
+ },
+ "usaOnly": {
+ "message": "Solo USA",
+ "description": "Usare questo sito di scambio è possibile solo per persone residenti in USA."
+ },
+ "usedByClients": {
+ "message": "Usato da una varietà di clients diversi"
+ },
+ "useOldUI": {
+ "message": "Use la vecchia UI"
+ },
+ "validFileImport": {
+ "message": "Devi selezionare un file valido da importare."
+ },
+ "vaultCreated": {
+ "message": "Cassaforte Creata"
+ },
+ "viewAccount": {
+ "message": "Vedi Account"
+ },
+ "visitWebSite": {
+ "message": "Visita il nostro sito web"
+ },
+ "warning": {
+ "message": "Attenzione"
+ },
+ "welcomeBeta": {
+ "message": "Benvenuto nella Beta di MetaMask"
+ },
+ "whatsThis": {
+ "message": "Cos'è questo?"
+ },
+ "yourSigRequested": {
+ "message": "E' richiesta la tua firma"
+ },
+ "youSign": {
+ "message": "Ti stai connettendo"
+ }
+} \ No newline at end of file
diff --git a/app/_locales/nl/messages.json b/app/_locales/nl/messages.json
new file mode 100644
index 000000000..aacb81fee
--- /dev/null
+++ b/app/_locales/nl/messages.json
@@ -0,0 +1,819 @@
+{
+ "accept": {
+ "message": "Aanvaarden"
+ },
+ "account": {
+ "message": "Account"
+ },
+ "accountDetails": {
+ "message": "Accountgegevens"
+ },
+ "accountName": {
+ "message": "Accountnaam"
+ },
+ "address": {
+ "message": "Adres"
+ },
+ "addCustomToken": {
+ "message": "Aangepaste token toevoegen"
+ },
+ "addToken": {
+ "message": "Voeg token toe"
+ },
+ "addTokens": {
+ "message": "Tokens toevoegen"
+ },
+ "amount": {
+ "message": "Bedrag"
+ },
+ "amountPlusGas": {
+ "message": "Bedrag + gas"
+ },
+ "appDescription": {
+ "message": "Ethereum Browser-extensie",
+ "description": "De beschrijving van de applicatie"
+ },
+ "appName": {
+ "message": "MetaMask",
+ "description": "De naam van de applicatie"
+ },
+ "attemptingConnect": {
+ "message": "Poging om verbinding te maken met blockchain."
+ },
+ "attributions": {
+ "message": "Bevoegdheden"
+ },
+ "available": {
+ "message": "Beschikbaar"
+ },
+ "back": {
+ "message": "Terug"
+ },
+ "balance": {
+ "message": "Balans:"
+ },
+ "balances": {
+ "message": "Je saldo"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "Onvoldoende saldo voor huidig ​​gastotaal"
+ },
+ "beta": {
+ "message": "BETA"
+ },
+ "betweenMinAndMax": {
+ "message": "moet groter zijn dan of gelijk zijn aan $1 en kleiner dan of gelijk aan $2.",
+ "description": "helper voor het invoeren van hex als decimale invoer"
+ },
+ "blockiesIdenticon": {
+ "message": "Gebruik Blockies Identicon"
+ },
+ "borrowDharma": {
+ "message": "Lenen met Dharma (Beta)"
+ },
+ "builtInCalifornia": {
+ "message": "MetaMask is ontworpen en gebouwd in Californië."
+ },
+ "buy": {
+ "message": "Kopen"
+ },
+ "buyCoinbase": {
+ "message": "Koop op Coinbase"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "Coinbase is 's werelds populairste manier om bitcoin, ethereum en litecoin te kopen en verkopen."
+ },
+ "cancel": {
+ "message": "Annuleer"
+ },
+ "classicInterface": {
+ "message": "Gebruik de klassieke interface"
+ },
+ "clickCopy": {
+ "message": "Klik om te kopiëren"
+ },
+ "confirm": {
+ "message": "Bevestigen"
+ },
+ "confirmContract": {
+ "message": "Contract bevestigen"
+ },
+ "confirmPassword": {
+ "message": "bevestig wachtwoord"
+ },
+ "confirmTransaction": {
+ "message": "Bevestig transactie"
+ },
+ "continue": {
+ "message": "Doorgaan met"
+ },
+ "continueToCoinbase": {
+ "message": "Ga verder naar Coinbase"
+ },
+ "contractDeployment": {
+ "message": "Contractimplementatie"
+ },
+ "conversionProgress": {
+ "message": "Bezig met conversie"
+ },
+ "copiedButton": {
+ "message": "gekopieerde"
+ },
+ "copiedClipboard": {
+ "message": "Gekopieerd naar het klembord"
+ },
+ "copiedExclamation": {
+ "message": "Gekopieerde!"
+ },
+ "copiedSafe": {
+ "message": "Ik heb het ergens veilig gekopieerd"
+ },
+ "copy": {
+ "message": "Kopiëren"
+ },
+ "copyToClipboard": {
+ "message": "Kopieer naar klembord"
+ },
+ "copyButton": {
+ "message": " Kopiëren "
+ },
+ "copyPrivateKey": {
+ "message": "Dit is uw privésleutel (klik om te kopiëren)"
+ },
+ "create": {
+ "message": "creëren"
+ },
+ "createAccount": {
+ "message": "Account aanmaken"
+ },
+ "createDen": {
+ "message": "creëren"
+ },
+ "crypto": {
+ "message": "crypto",
+ "description": "Ruiltype (cryptocurrencies)"
+ },
+ "currentConversion": {
+ "message": "Huidige conversie"
+ },
+ "currentNetwork": {
+ "message": "Huidig ​​netwerk"
+ },
+ "customGas": {
+ "message": "Pas Gas aan"
+ },
+ "customize": {
+ "message": "Aanpassen"
+ },
+ "customRPC": {
+ "message": "Aangepaste RPC"
+ },
+ "decimalsMustZerotoTen": {
+ "message": "Decimalen moeten minimaal 0 en niet meer dan 36 zijn."
+ },
+ "decimal": {
+ "message": "Decimalen van precisie"
+ },
+ "defaultNetwork": {
+ "message": "Het standaardnetwerk voor Ether-transacties is Main Net."
+ },
+ "denExplainer": {
+ "message": "Uw DEN is uw wachtwoord-gecodeerde opslag binnen MetaMask."
+ },
+ "deposit": {
+ "message": "Storting"
+ },
+ "depositBTC": {
+ "message": "Stort uw BTC op het onderstaande adres:"
+ },
+ "depositCoin": {
+ "message": "Stort uw $1 op het onderstaande adres",
+ "description": "Laat de gebruiker weten welk muntje ze hebben geselecteerd om te deponeren met shapeshift"
+ },
+ "depositEth": {
+ "message": "Aanbetaling Eth"
+ },
+ "depositEther": {
+ "message": "Stort Ether"
+ },
+ "depositFiat": {
+ "message": "Stort met Fiat"
+ },
+ "depositFromAccount": {
+ "message": "Storten van een ander account"
+ },
+ "depositShapeShift": {
+ "message": "Stort met ShapeShift"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "Als u andere cryptocurrencies bezit, kunt u Ether direct in uw MetaMask-portemonnee ruilen en storten. Geen account nodig."
+ },
+ "details": {
+ "message": "Details"
+ },
+ "directDeposit": {
+ "message": "Directe storting"
+ },
+ "directDepositEther": {
+ "message": "Directe Ether storten"
+ },
+ "directDepositEtherExplainer": {
+ "message": "Als je al wat Ether hebt, de snelste manier om Ether in je nieuwe portemonnee te krijgen door een directe storting."
+ },
+ "done": {
+ "message": "Gedaan"
+ },
+ "downloadStatelogs": {
+ "message": "Staatslogboeken downloaden"
+ },
+ "edit": {
+ "message": "Bewerk"
+ },
+ "editAccountName": {
+ "message": "Bewerk accountnaam"
+ },
+ "emailUs": {
+ "message": "Email ons!"
+ },
+ "encryptNewDen": {
+ "message": "Versleutel je nieuwe DEN"
+ },
+ "enterPassword": {
+ "message": "Voer wachtwoord in"
+ },
+ "enterPasswordConfirm": {
+ "message": "Voer uw wachtwoord in om te bevestigen"
+ },
+ "etherscanView": {
+ "message": "Bekijk account op Etherscan"
+ },
+ "exchangeRate": {
+ "message": "Wisselkoers"
+ },
+ "exportPrivateKey": {
+ "message": "Exporteer privésleutel"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "Exporteer privésleutels op eigen risico."
+ },
+ "failed": {
+ "message": "mislukt"
+ },
+ "fiat": {
+ "message": "FIAT",
+ "description": "Ruiltype"
+ },
+ "fileImportFail": {
+ "message": "Bestandsimport werkt niet? Klik hier!",
+ "description": "Helpt de gebruiker om zijn account vanuit een JSON-bestand te importeren"
+ },
+ "followTwitter": {
+ "message": "Volg ons op Twitter"
+ },
+ "from": {
+ "message": "Van"
+ },
+ "fromToSame": {
+ "message": "Van en naar adres kan niet hetzelfde zijn"
+ },
+ "fromShapeShift": {
+ "message": "Van ShapeShift"
+ },
+ "gas": {
+ "message": "Gas",
+ "description": "Korte indicatie van gaskosten"
+ },
+ "gasFee": {
+ "message": "Gas vergoeding"
+ },
+ "gasLimit": {
+ "message": "Gaslimiet"
+ },
+ "gasLimitCalculation": {
+ "message": "We berekenen de voorgestelde gaslimiet op basis van succespercentages van het netwerk."
+ },
+ "gasLimitRequired": {
+ "message": "Gaslimiet vereist"
+ },
+ "gasLimitTooLow": {
+ "message": "De gaslimiet moet minstens 21000 zijn"
+ },
+ "generatingSeed": {
+ "message": "Zaad produceren ..."
+ },
+ "gasPrice": {
+ "message": "Gasprijs (GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "We berekenen de voorgestelde gasprijzen op basis van succespercentages van het netwerk."
+ },
+ "gasPriceRequired": {
+ "message": "Gasprijs vereist"
+ },
+ "getEther": {
+ "message": "Krijg Ether"
+ },
+ "getEtherFromFaucet": {
+ "message": "Haal Ether uit een kraan voor de $1",
+ "description": "Geeft de netwerknaam voor Ether-kraan weer"
+ },
+ "greaterThanMin": {
+ "message": "moet groter zijn dan of gelijk zijn aan $1.",
+ "description": "helper voor het invoeren van hex als decimale invoer"
+ },
+ "here": {
+ "message": "hier",
+ "description": "zoals in -klik hier- voor meer informatie (gaat met troubleTokenBalances)"
+ },
+ "hereList": {
+ "message": "Hier is een lijst !!!!"
+ },
+ "hide": {
+ "message": "Verbergen"
+ },
+ "hideToken": {
+ "message": "Token verbergen"
+ },
+ "hideTokenPrompt": {
+ "message": "Token verbergen?"
+ },
+ "howToDeposit": {
+ "message": "Hoe zou je Ether willen deponeren?"
+ },
+ "holdEther": {
+ "message": "Hiermee kunt u ether & tokens bewaren en dient u als brug naar gedecentraliseerde applicaties."
+ },
+ "import": {
+ "message": "Importeren",
+ "description": "Knop om een ​​account uit een geselecteerd bestand te importeren"
+ },
+ "importAccount": {
+ "message": "Account importeren"
+ },
+ "importAccountMsg": {
+ "message":" Geïmporteerde accounts worden niet gekoppeld aan de seedphrase van uw oorspronkelijk gemaakte MetaMask-account. Meer informatie over geïmporteerde accounts"
+ },
+ "importAnAccount": {
+ "message": "Importeer een account"
+ },
+ "importDen": {
+ "message": "Bestaande DEN importeren"
+ },
+ "imported": {
+ "message": "geïmporteerde",
+ "description": "status die aantoont dat een account volledig in de sleutelring is geladen"
+ },
+ "infoHelp": {
+ "message": "Info en hulp"
+ },
+ "insufficientFunds": {
+ "message": "Onvoldoende fondsen."
+ },
+ "insufficientTokens": {
+ "message": "Onvoldoende tokens."
+ },
+ "invalidAddress": {
+ "message": "Ongeldig adres"
+ },
+ "invalidAddressRecipient": {
+ "message": "Het adres van de ontvanger is ongeldig"
+ },
+ "invalidGasParams": {
+ "message": "Ongeldige gasparameters"
+ },
+ "invalidInput": {
+ "message": "Ongeldige invoer."
+ },
+ "invalidRequest": {
+ "message": "ongeldig verzoek"
+ },
+ "invalidRPC": {
+ "message": "Ongeldige RPC-URI"
+ },
+ "jsonFail": {
+ "message": "Er is iets fout gegaan. Zorg ervoor dat uw JSON-bestand correct is opgemaakt."
+ },
+ "jsonFile": {
+ "message": "JSON-bestand",
+ "description": "formaat voor het importeren van een account"
+ },
+ "kovan": {
+ "message": "Kovan-testnetwerk"
+ },
+ "knowledgeDataBase": {
+ "message": "Bezoek onze Knowledge Base"
+ },
+ "lessThanMax": {
+ "message": "moet kleiner zijn dan of gelijk zijn aan $1.",
+ "description": "helper voor het invoeren van hex als decimale invoer"
+ },
+ "likeToAddTokens": {
+ "message": "Wil je deze tokens toevoegen?"
+ },
+ "limit": {
+ "message": "Begrenzing"
+ },
+ "loading": {
+ "message": "Bezig met laden..."
+ },
+ "loadingTokens": {
+ "message": "Tokens laden ..."
+ },
+ "localhost": {
+ "message": "Localhost 8545"
+ },
+ "login": {
+ "message": "Log in"
+ },
+ "logout": {
+ "message": "Uitloggen"
+ },
+ "loose": {
+ "message": "Los"
+ },
+ "loweCaseWords": {
+ "message": "zaadwoorden hebben alleen kleine letters"
+ },
+ "mainnet": {
+ "message": "belangrijkste ethereum-netwerk"
+ },
+ "message": {
+ "message": "Bericht"
+ },
+ "metamaskDescription": {
+ "message": "MetaMask is een veilige identiteitskluis voor Ethereum."
+ },
+ "min": {
+ "message": "Minimum"
+ },
+ "myAccounts": {
+ "message": "Mijn accounts"
+ },
+ "mustSelectOne": {
+ "message": "Moet ten minste één token selecteren."
+ },
+ "needEtherInWallet": {
+ "message": "Om te communiceren met gedecentraliseerde applicaties met MetaMask, heb je Ether nodig in je portemonnee."
+ },
+ "needImportFile": {
+ "message": "U moet een bestand selecteren om te importeren.",
+ "description": "Gebruiker is belangrijk een account en moet een bestand toevoegen om door te gaan"
+ },
+ "needImportPassword": {
+ "message": "U moet een wachtwoord invoeren voor het geselecteerde bestand.",
+ "description": "Wachtwoord en bestand nodig om een ​​account te importeren"
+ },
+ "negativeETH": {
+ "message": "Kan geen negatieve hoeveelheden ETH verzenden."
+ },
+ "networks": {
+ "message": "netwerken"
+ },
+ "newAccount": {
+ "message": "Nieuw account"
+ },
+ "newAccountNumberName": {
+ "message": "Account $1",
+ "description": "Standaardnaam van de volgende account die moet worden aangemaakt op het scherm voor het maken van een account"
+ },
+ "newContract": {
+ "message": "Nieuw contract"
+ },
+ "newPassword": {
+ "message": "Nieuw wachtwoord (min 8 tekens)"
+ },
+ "newRecipient": {
+ "message": "Nieuwe ontvanger"
+ },
+ "newRPC": {
+ "message": "Nieuwe RPC-URL"
+ },
+ "next": {
+ "message": "volgende"
+ },
+ "noAddressForName": {
+ "message": "Er is geen adres ingesteld voor deze naam."
+ },
+ "noDeposits": {
+ "message": "Geen aanbetalingen ontvangen"
+ },
+ "noTransactionHistory": {
+ "message": "Geen transactiegeschiedenis."
+ },
+ "noTransactions": {
+ "message": "Geen transacties"
+ },
+ "notStarted": {
+ "message": "Niet begonnen"
+ },
+ "oldUI": {
+ "message": "Oude gebruikersinterface"
+ },
+ "oldUIMessage": {
+ "message": "U bent teruggekeerd naar de oude gebruikersinterface. U kunt terugschakelen naar de nieuwe gebruikersinterface via de optie in het vervolgkeuzemenu in de rechterbovenhoek."
+ },
+ "or": {
+ "message": "of",
+ "description": "keuze tussen het maken of importeren van een nieuw account"
+ },
+ "passwordCorrect": {
+ "message": "Zorg ervoor dat uw wachtwoord correct is."
+ },
+ "passwordMismatch": {
+ "message": "wachtwoorden komen niet overeen",
+ "description": "bij het maken van het wachtwoord kwamen de twee nieuwe wachtwoordvelden niet overeen"
+ },
+ "passwordShort": {
+ "message": "wachtwoord niet lang genoeg",
+ "description": "bij het maken van het wachtwoord is het wachtwoord niet lang genoeg om veilig te zijn"
+ },
+ "pastePrivateKey": {
+ "message": "Plak hier uw privésleutelstring:",
+ "description": "Voor het importeren van een account vanaf een privésleutel"
+ },
+ "pasteSeed": {
+ "message": "Plak je zaadzin hier!"
+ },
+ "personalAddressDetected": {
+ "message": "Persoonlijk adres gedetecteerd. Voer het tokencontractadres in."
+ },
+ "pleaseReviewTransaction": {
+ "message": "Controleer uw transactie."
+ },
+ "privacyMsg": {
+ "message": "Privacybeleid"
+ },
+ "privateKey": {
+ "message": "Prive sleutel",
+ "description": "selecteer dit type bestand om te gebruiken om een ​​account te importeren"
+ },
+ "privateKeyWarning": {
+ "message": "Waarschuwing: open deze sleutel nooit. Iedereen met uw privésleutels kan stelen van alle items in uw account."
+ },
+ "privateNetwork": {
+ "message": "Prive netwerk"
+ },
+ "qrCode": {
+ "message": "QR-code weergeven"
+ },
+ "readdToken": {
+ "message": "U kunt dit token in de toekomst weer toevoegen door naar \"Token toevoegen\" te gaan in het menu met accountopties."
+ },
+ "readMore": {
+ "message": "Lees hier meer."
+ },
+ "readMore2": {
+ "message": "Lees verder."
+ },
+ "receive": {
+ "message": "Te ontvangen"
+ },
+ "recipientAddress": {
+ "message": "Geadresseerde adres"
+ },
+ "refundAddress": {
+ "message": "Uw teruggave adres"
+ },
+ "rejected": {
+ "message": "Verworpen"
+ },
+ "resetAccount": {
+ "message": "Account opnieuw instellen"
+ },
+ "restoreFromSeed": {
+ "message": "Herstel van zaaduitdrukking"
+ },
+ "required": {
+ "message": "Verplicht"
+ },
+ "retryWithMoreGas": {
+ "message": "Probeer hier opnieuw met een hogere gasprijs"
+ },
+ "revealSeedWords": {
+ "message": "Onthul zaadwoorden"
+ },
+ "revealSeedWordsWarning": {
+ "message": "Herstel je zaadwoorden niet op een openbare plaats! Deze woorden kunnen worden gebruikt om al uw accounts te stelen."
+ },
+ "revert": {
+ "message": "terugkeren"
+ },
+ "rinkeby": {
+ "message": "Rinkeby testnetwerk"
+ },
+ "ropsten": {
+ "message": "Ropsten testnetwerk"
+ },
+ "sampleAccountName": {
+ "message": "Bijv. Mijn nieuwe account",
+ "description": "Help de gebruiker begrip te ontwikkelen van het toevoegen van een door mensen leesbare naam aan zijn of haar account"
+ },
+ "save": {
+ "message": "Opslaan"
+ },
+ "saveAsFile": {
+ "message": "Sla op als bestand",
+ "description": "Account export proces"
+ },
+ "saveSeedAsFile": {
+ "message": "Bewaar zaadwoorden als bestand"
+ },
+ "search": {
+ "message": "Zoeken"
+ },
+ "secretPhrase": {
+ "message": "Voer hier je geheime twaalfwoordfrase in om je kluis te herstellen."
+ },
+ "seedPhraseReq": {
+ "message": "zaadzinnen zijn 12 woorden lang"
+ },
+ "select": {
+ "message": "kiezen"
+ },
+ "selectCurrency": {
+ "message": "selecteer valuta"
+ },
+ "selectService": {
+ "message": "Selecteer Service"
+ },
+ "selectType": {
+ "message": "Selecteer type"
+ },
+ "send": {
+ "message": "Sturen"
+ },
+ "sendETH": {
+ "message": "Verzend ETH"
+ },
+ "sendTokens": {
+ "message": "Stuur tokens"
+ },
+ "sendTokensAnywhere": {
+ "message": "Stuur tokens naar iedereen met een Ethereum-account"
+ },
+ "settings": {
+ "message": "instellingen"
+ },
+ "shapeshiftBuy": {
+ "message": "Koop met Shapeshift"
+ },
+ "showPrivateKeys": {
+ "message": "Privésleutels weergeven"
+ },
+ "showQRCode": {
+ "message": "QR-code weergeven"
+ },
+ "sign": {
+ "message": "Teken"
+ },
+ "signMessage": {
+ "message": "Teken bericht"
+ },
+ "signNotice": {
+ "message": "Het ondertekenen van dit bericht kan hebben \ngevaarlijke bijwerkingen. Meld alleen berichten van \nsites die u volledig vertrouwt met uw volledige account.\n Deze gevaarlijke methode wordt in een toekomstige versie verwijderd."
+ },
+ "sigRequest": {
+ "message": "Ondertekeningsverzoek"
+ },
+ "sigRequested": {
+ "message": "Handtekening aangevraagd"
+ },
+ "spaceBetween": {
+ "message": "er kan alleen een spatie tussen woorden zijn"
+ },
+ "status": {
+ "message": "staat"
+ },
+ "stateLogs": {
+ "message": "Staatslogboeken"
+ },
+ "stateLogsDescription": {
+ "message": "Staatslogboeken bevatten uw openbare accountadressen en verzonden transacties."
+ },
+ "submit": {
+ "message": "voorleggen"
+ },
+ "supportCenter": {
+ "message": "Bezoek ons ​​ondersteuningscentrum"
+ },
+ "symbolBetweenZeroTen": {
+ "message": "Het symbool moet tussen 0 en 10 tekens lang zijn."
+ },
+ "takesTooLong": {
+ "message": "Duurt te lang?"
+ },
+ "terms": {
+ "message": "Gebruiksvoorwaarden"
+ },
+ "testFaucet": {
+ "message": "Test de kraan"
+ },
+ "to": {
+ "message": "Naar"
+ },
+ "toETHviaShapeShift": {
+ "message": "$1 tot ETH via ShapeShift",
+ "description": "systeem zal het aanbetalingstype invullen bij het begin van het bericht"
+ },
+ "tokenAddress": {
+ "message": "Token-adres"
+ },
+ "tokenAlreadyAdded": {
+ "message": "Token is al toegevoegd."
+ },
+ "tokenBalance": {
+ "message": "Uw tokensaldo is:"
+ },
+ "tokenSelection": {
+ "message": "Zoek naar tokens of selecteer uit onze lijst met populaire tokens."
+ },
+ "tokenSymbol": {
+ "message": "Token Symbol"
+ },
+ "tokenWarning1": {
+ "message": "Houd de tokens bij die je hebt gekocht met je MetaMask-account. Als je tokens met een ander account hebt gekocht, worden die tokens hier niet weergegeven."
+ },
+ "total": {
+ "message": "Totaal"
+ },
+ "transactions": {
+ "message": "transacties"
+ },
+ "transactionMemo": {
+ "message": "Transactiememo (optioneel)"
+ },
+ "transactionNumber": {
+ "message": "Transactie nummer"
+ },
+ "transfers": {
+ "message": "transfers"
+ },
+ "troubleTokenBalances": {
+ "message": "We hadden problemen bij het laden van uw tokenbalansen. Je kunt ze bekijken",
+ "description": "Gevolgd door een link (hier) om tegensaldi te bekijken"
+ },
+ "twelveWords": {
+ "message": "Deze 12 woorden zijn de enige manier om uw MetaMask-accounts te herstellen.\nBewaar ze ergens veilig en geheim."
+ },
+ "typePassword": {
+ "message": "Typ uw wachtwoord"
+ },
+ "uiWelcome": {
+ "message": "Welkom bij de nieuwe gebruikersinterface (bèta)"
+ },
+ "uiWelcomeMessage": {
+ "message": "U gebruikt nu de nieuwe gebruikersinterface van Metamask. Kijk rond, probeer nieuwe functies uit zoals het verzenden van tokens en laat ons weten of u problemen ondervindt."
+ },
+ "unavailable": {
+ "message": "Niet beschikbaar"
+ },
+ "unknown": {
+ "message": "Onbekend"
+ },
+ "unknownNetwork": {
+ "message": "Onbekend privénetwerk"
+ },
+ "unknownNetworkId": {
+ "message": "Onbekende netwerk-ID"
+ },
+ "uriErrorMsg": {
+ "message": "Voor URI's is het juiste HTTP / HTTPS-voorvoegsel vereist."
+ },
+ "usaOnly": {
+ "message": "Alleen in de VS.",
+ "description": "Het gebruik van deze uitwisseling is beperkt tot mensen in de VS."
+ },
+ "usedByClients": {
+ "message": "Gebruikt door verschillende klanten"
+ },
+ "useOldUI": {
+ "message": "Gebruik de oude gebruikersinterface"
+ },
+ "validFileImport": {
+ "message": "U moet een geldig bestand selecteren om te importeren."
+ },
+ "vaultCreated": {
+ "message": "Vault gemaakt"
+ },
+ "viewAccount": {
+ "message": "Bekijk account"
+ },
+ "visitWebSite": {
+ "message": "Bezoek onze website"
+ },
+ "warning": {
+ "message": "Waarschuwing"
+ },
+ "welcomeBeta": {
+ "message": "Welkom bij MetaMask Beta"
+ },
+ "whatsThis": {
+ "message": "Wat is dit?"
+ },
+ "yourSigRequested": {
+ "message": "Uw handtekening wordt aangevraagd"
+ },
+ "youSign": {
+ "message": "U ondertekent"
+ }
+}
diff --git a/app/_locales/ph/messages.json b/app/_locales/ph/messages.json
new file mode 100644
index 000000000..29d63be02
--- /dev/null
+++ b/app/_locales/ph/messages.json
@@ -0,0 +1,609 @@
+{
+ "accept": {
+ "message": "Tanggapin"
+ },
+ "account": {
+ "message": "Account"
+ },
+ "accountDetails": {
+ "message": "Detalye ng Account"
+ },
+ "accountName": {
+ "message": "Pangalan ng Account"
+ },
+ "address": {
+ "message": "Address"
+ },
+ "addToken": {
+ "message": "Magdagdag ng Token"
+ },
+ "amount": {
+ "message": "Halaga"
+ },
+ "amountPlusGas": {
+ "message": "Halaga + Gas"
+ },
+ "appDescription": {
+ "message": "Ethereum Browser Extension",
+ "description": "Ang deskripsyon ng application"
+ },
+ "appName": {
+ "message": "MetaMask",
+ "description": "Ang pangalan ng application"
+ },
+ "attemptingConnect": {
+ "message": "Sinusubukang kumonekta sa blockchain."
+ },
+ "available": {
+ "message": "Magagamit"
+ },
+ "back": {
+ "message": "Bumalik"
+ },
+ "balance": {
+ "message": "Balanse:"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "Kulang ang balanse para sa kasalukuyang gas total"
+ },
+ "beta": {
+ "message": "BETA"
+ },
+ "betweenMinAndMax": {
+ "message": "dapat mas malaki o katumbas ng $1 at mas mababa o katumbas ng $2.",
+ "description": "helper para sa pag-input ng hex bilang decimal input"
+ },
+ "borrowDharma": {
+ "message": "Humiram sa Dharma (Beta)"
+ },
+ "buy": {
+ "message": "Bumili"
+ },
+ "buyCoinbase": {
+ "message": "Bumili sa Coinbase"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "Ang Coinbase ang pinakasikat na paraan upang bumili at magbenta ng bitcoin, ethereum, at litecoin sa buong mundo."
+ },
+ "cancel": {
+ "message": "Kanselahin"
+ },
+ "clickCopy": {
+ "message": "I-click upang Makopya"
+ },
+ "confirm": {
+ "message": "Tiyakin"
+ },
+ "confirmContract": {
+ "message": "Tiyakin ang Contract"
+ },
+ "confirmPassword": {
+ "message": "Tiyakin ang Password"
+ },
+ "confirmTransaction": {
+ "message": "Tiyakin ang Transaksyon"
+ },
+ "continueToCoinbase": {
+ "message": "Magpatuloy sa Coinbase"
+ },
+ "contractDeployment": {
+ "message": "Pag-deploy ng Contract"
+ },
+ "conversionProgress": {
+ "message": "Isinasagawa ang conversion"
+ },
+ "copiedButton": {
+ "message": "Kinopya"
+ },
+ "copiedClipboard": {
+ "message": "Kinopya sa Clipboard"
+ },
+ "copiedExclamation": {
+ "message": "Kinopya!"
+ },
+ "copy": {
+ "message": "Kinopya"
+ },
+ "copyToClipboard": {
+ "message": "Kinopya sa clipboard"
+ },
+ "copyButton": {
+ "message": " Kinopya "
+ },
+ "copyPrivateKey": {
+ "message": "Ito ang iyong private key (i-click upang makopya)"
+ },
+ "create": {
+ "message": "Gumawa"
+ },
+ "createAccount": {
+ "message": "Gumawa ng Account"
+ },
+ "createDen": {
+ "message": "Gumawa"
+ },
+ "crypto": {
+ "message": "Crypto",
+ "description": "Type ng exchange (cryptocurrencies)"
+ },
+ "customGas": {
+ "message": "I-customize ang Gas"
+ },
+ "customize": {
+ "message": "I-customize"
+ },
+ "customRPC": {
+ "message": "Custom RPC"
+ },
+ "defaultNetwork": {
+ "message": "Ang default network para sa Ether transactions ay ang Main Net."
+ },
+ "denExplainer": {
+ "message": "Ang iyong DEN ang nagsisilbing password-encrypted storage mo sa loob ng MetaMask."
+ },
+ "deposit": {
+ "message": "Deposito"
+ },
+ "depositBTC": {
+ "message": "I-deposito ang iyong BTC sa address na ito:"
+ },
+ "depositCoin": {
+ "message": "I-deposito ang iyong $1 sa address na ito",
+ "description": "Sinasabihan ang user kung ano ang coin na kanilang pinili para I-deposito gamit ang shapeshift"
+ },
+ "depositEth": {
+ "message": "I-deposito ang Eth"
+ },
+ "depositEther": {
+ "message": "I-deposito ang Ether"
+ },
+ "depositFiat": {
+ "message": "I-deposito ang Fiat"
+ },
+ "depositFromAccount": {
+ "message": "I-deposito mula sa ibang account"
+ },
+ "depositShapeShift": {
+ "message": "I-deposito gamit ang ShapeShift"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "Kung ikaw ay nagmamay-ari ng iba pang cryptocurrencies, pwede kang mag-trade at mag-deposito ng Ether diretso sa iyong MetaMask wallet. Hindi mo na kailangan ng account."
+ },
+ "details": {
+ "message": "Detalye"
+ },
+ "directDeposit": {
+ "message": "Direktang Deposito"
+ },
+ "directDepositEther": {
+ "message": "Direktang I-deposito ang Ether"
+ },
+ "directDepositEtherExplainer": {
+ "message": "Kung ika ay mayroon nang Ether, ang pinakamabilis na paraan upang makuha ang Ether sa iyong bagong wallet ay sa pamamagitan ng direktang deposito."
+ },
+ "done": {
+ "message": "Tapos na"
+ },
+ "edit": {
+ "message": "I-edit"
+ },
+ "editAccountName": {
+ "message": "I-edit ang Pangalang ng Account"
+ },
+ "encryptNewDen": {
+ "message": "I-encrypt ang iyong bagong DEN"
+ },
+ "enterPassword": {
+ "message": "I-enter ang password"
+ },
+ "etherscanView": {
+ "message": "Tingnan ang account sa Etherscan"
+ },
+ "exchangeRate": {
+ "message": "Exchange Rate"
+ },
+ "exportPrivateKey": {
+ "message": "I-export ang Private Key"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "I-export ang private keys at intindihin ang panganib na kasama nito."
+ },
+ "failed": {
+ "message": "Nabigo"
+ },
+ "fiat": {
+ "message": "FIAT",
+ "description": "Type ng exchange"
+ },
+ "fileImportFail": {
+ "message": "Hindi gumagana ang file import? I-click ito!",
+ "description": "Tinutulungan ang user na i-import ang kanilang account mula sa JSON file"
+ },
+ "from": {
+ "message": "Mula sa"
+ },
+ "fromShapeShift": {
+ "message": "Mula sa ShapeShift"
+ },
+ "gas": {
+ "message": "Gas",
+ "description": "Maikling indikasyon ng gas cost"
+ },
+ "gasFee": {
+ "message": "Gas Fee"
+ },
+ "gasLimit": {
+ "message": "Gas Limit"
+ },
+ "gasLimitCalculation": {
+ "message": "Kinalkula namin ang iminungkahing gas limit base sa network success rates."
+ },
+ "gasLimitRequired": {
+ "message": "Kailangan ang Gas Limit"
+ },
+ "gasLimitTooLow": {
+ "message": "Ang gas limit ay hindi dabat bababa sa 21000"
+ },
+ "gasPrice": {
+ "message": "Gas Price (GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "Kinalkula namin ang iminungkahing gas prices base sa network success rates."
+ },
+ "gasPriceRequired": {
+ "message": "Kailangan ang Gas Price"
+ },
+ "getEther": {
+ "message": "Kumuha ng Ether"
+ },
+ "getEtherFromFaucet": {
+ "message": "Kumuha ng Ether mula sa faucet para sa $1",
+ "description": "Ipinapakita ang pangalan ng network para sa Ether faucet"
+ },
+ "greaterThanMin": {
+ "message": "dapat mas malaki o katumbas ng $1.",
+ "description": "helper para sa pag-input ng hex bilang decimal input"
+ },
+ "here": {
+ "message": "i-click ito",
+ "description": "tulad ng -i-click dito- para sa mas maraming impormasyon (kasama ng troubleTokenBalances)"
+ },
+ "hide": {
+ "message": "Itago"
+ },
+ "hideToken": {
+ "message": "Itago ang Token"
+ },
+ "hideTokenPrompt": {
+ "message": "Itago ang Token?"
+ },
+ "howToDeposit": {
+ "message": "Paano mo gustong mag-deposito ng Ether?"
+ },
+ "import": {
+ "message": "I-import",
+ "description": "Button para i-import ang account mula sa napiling file"
+ },
+ "importAccount": {
+ "message": "I-import ang Account"
+ },
+ "importAnAccount": {
+ "message": "I-import ang account"
+ },
+ "importDen": {
+ "message": "I-import ang Existing DEN"
+ },
+ "imported": {
+ "message": "Na-import na",
+ "description": "status na nagpapakita na ang account ay lubos na na-load sa keyring"
+ },
+ "infoHelp": {
+ "message": "Impormasyon at Tulong"
+ },
+ "invalidAddress": {
+ "message": "Invalid ang address"
+ },
+ "invalidGasParams": {
+ "message": "Invalid ang Gas Parameters"
+ },
+ "invalidInput": {
+ "message": "Invalid ang input."
+ },
+ "invalidRequest": {
+ "message": "Invalid ang Request"
+ },
+ "jsonFile": {
+ "message": "JSON File",
+ "description": "format para sa pag-import ng account"
+ },
+ "kovan": {
+ "message": "Kovan Test Network"
+ },
+ "lessThanMax": {
+ "message": "dapat mas mababa o katumbas ng $1.",
+ "description": "helper para sa pag-input ng hex bilang decimal input"
+ },
+ "limit": {
+ "message": "Limitasyon"
+ },
+ "loading": {
+ "message": "Naglo-load..."
+ },
+ "loadingTokens": {
+ "message": "Naglo-load ang Tokens..."
+ },
+ "localhost": {
+ "message": "Localhost 8545"
+ },
+ "logout": {
+ "message": "Log out"
+ },
+ "loose": {
+ "message": "Loose"
+ },
+ "mainnet": {
+ "message": "Main Ethereum Network"
+ },
+ "message": {
+ "message": "Mensahe"
+ },
+ "min": {
+ "message": "Minimum"
+ },
+ "myAccounts": {
+ "message": "Aking mga Account"
+ },
+ "needEtherInWallet": {
+ "message": "Upang makipag-ugnayan sa decentralized applications gamit ang MetaMask, kakailanganin mo ng Ether sa iyong wallet."
+ },
+ "needImportFile": {
+ "message": "Dapat kang pumili ng file para i-import.",
+ "description": "Ang user ay nag-iimport ng account at kailangan magdagdag ng file upang tumuloy"
+ },
+ "needImportPassword": {
+ "message": "Dapat mong i-enter ang password para sa napiling file.",
+ "description": "Password at file na kailangan upang ma-import ang account"
+ },
+ "networks": {
+ "message": "Networks"
+ },
+ "newAccount": {
+ "message": "Bagong Account"
+ },
+ "newAccountNumberName": {
+ "message": "Account $1",
+ "description": "Ang default na pangalan ng susunod na account na gagawin sa create account screen"
+ },
+ "newContract": {
+ "message": "Bagong Contract"
+ },
+ "newPassword": {
+ "message": "Bagong Password (min 8 chars)"
+ },
+ "newRecipient": {
+ "message": "Bagong Recipient"
+ },
+ "next": {
+ "message": "Sunod"
+ },
+ "noAddressForName": {
+ "message": "Walang naka-set na address para sa pangalang ito."
+ },
+ "noDeposits": {
+ "message": "Walang natanggap na mga deposito"
+ },
+ "noTransactionHistory": {
+ "message": "Walang kasaysayan ng transaksyon."
+ },
+ "noTransactions": {
+ "message": "Walang mga Transaksyon"
+ },
+ "notStarted": {
+ "message": "Hindi Sinimulan"
+ },
+ "oldUI": {
+ "message": "Lumang UI"
+ },
+ "oldUIMessage": {
+ "message": "Ikaw ay bumalik sa lumang UI. Maaari kang bumalik sa bagong UI mula sa isang opsyon sa dropdown menu na matatagpuan sa bandang taas at kanan."
+ },
+ "or": {
+ "message": "o",
+ "description": "Pagpili sa pagitan ng paggawa of pag-import ng bagong account"
+ },
+ "passwordMismatch": {
+ "message": "hindi nagtugma ang mga password",
+ "description": "Sa proseso ng paggawa ng password, ang dalawang password fields ay hindi nagtugma"
+ },
+ "passwordShort": {
+ "message": "hindi sapat ang haba ng password",
+ "description": "Sa proseso ng paggawa ng password, ang password ay hindi in password creation process, hind sapat ang haba ng password upang maging ligtas"
+ },
+ "pastePrivateKey": {
+ "message": "I-paste dito ang iyong private key string:",
+ "description": "Para sa pag-import ng account mula sa private key"
+ },
+ "pasteSeed": {
+ "message": "I-paste dito ang iyong seed phrase!"
+ },
+ "pleaseReviewTransaction": {
+ "message": "Mangyaring suriin ang iyong transaksyon."
+ },
+ "privateKey": {
+ "message": "Private Key",
+ "description": "Piliin ang ganitong type ng file upang gamitin sa pag-import ng account"
+ },
+ "privateKeyWarning": {
+ "message": "Babala: Huwag sabihin sa kahit na sino ang key na ito. Maaring makuha at manakaw ng sinumang nakakaalam ng iyong private key ang mga assets sa iyong account."
+ },
+ "privateNetwork": {
+ "message": "Pribadong Network"
+ },
+ "qrCode": {
+ "message": "Ipakita ang QR Code"
+ },
+ "readdToken": {
+ "message": "Upang muling idagdag ang token na ito, pumunta sa “Magdagdag ng Token” sa options menu ng iyong account."
+ },
+ "readMore": {
+ "message": "Alamin ang iba pang impormasyon dito."
+ },
+ "receive": {
+ "message": "Tanggapin"
+ },
+ "recipientAddress": {
+ "message": "Address ng Tatanggap"
+ },
+ "refundAddress": {
+ "message": "Ang Iyong Refund Address"
+ },
+ "rejected": {
+ "message": "Tinanggihan"
+ },
+ "required": {
+ "message": "Kailangan"
+ },
+ "retryWithMoreGas": {
+ "message": "Muling subukan ng may mas mataas na gas price dito"
+ },
+ "revert": {
+ "message": "Ibalik"
+ },
+ "rinkeby": {
+ "message": "Rinkeby Test Network"
+ },
+ "ropsten": {
+ "message": "Ropsten Test Network"
+ },
+ "sampleAccountName": {
+ "message": "Halimbawa: Ang aking bagong account",
+ "description": "Tulungan ang user na intindihin ang konsepto ng pagdagdag ng human-readable name sa kanilang account"
+ },
+ "save": {
+ "message": "I-save"
+ },
+ "saveAsFile": {
+ "message": "I-save bilang File",
+ "description": "Proseso sa pag-export ng Account"
+ },
+ "selectService": {
+ "message": "Piliin ang Service"
+ },
+ "send": {
+ "message": "Magpadala"
+ },
+ "sendTokens": {
+ "message": "Magpadala ng Tokens"
+ },
+ "sendTokensAnywhere": {
+ "message": "Magpadala ng Tokens sa sinumang may Ethereum account"
+ },
+ "settings": {
+ "message": "Mga Setting"
+ },
+ "shapeshiftBuy": {
+ "message": "Bumili gamit ang Shapeshift"
+ },
+ "showPrivateKeys": {
+ "message": "Ipakita ang Private Keys"
+ },
+ "showQRCode": {
+ "message": "Ipakita ang QR Code"
+ },
+ "sign": {
+ "message": "I-sign"
+ },
+ "signMessage": {
+ "message": "I-sign ang mensahe"
+ },
+ "signNotice": {
+ "message": "Ang pag-sign ng mensaheng ito ay maaring magdulot ng mapanganib na epekto. I-sign lamang ang mga mensahe mula sa mga site na pinagkakatiwalaan mo ng iyong account. Ang mapanganib na paraang ito ay aalisin sa isa sa mga susunod na bersyon. "
+ },
+ "sigRequest": {
+ "message": "Hiling na Signature"
+ },
+ "sigRequested": {
+ "message": "Hiniling ang Signature"
+ },
+ "status": {
+ "message": "Istado"
+ },
+ "submit": {
+ "message": "I-submit"
+ },
+ "takesTooLong": {
+ "message": "Masyadong matagal?"
+ },
+ "testFaucet": {
+ "message": "Test Faucet"
+ },
+ "to": {
+ "message": "To"
+ },
+ "toETHviaShapeShift": {
+ "message": "$1 sa ETH sa pamamagitan ng ShapeShift",
+ "description": "Pupunan ng system ang deposit type sa simula ng mensahe"
+ },
+ "tokenBalance": {
+ "message": "Ang iyong Token Balance ay:"
+ },
+ "total": {
+ "message": "Kabuuan"
+ },
+ "transactionMemo": {
+ "message": "Memo ng transaksyon (opsyonal)"
+ },
+ "transactionNumber": {
+ "message": "Numero ng Transaksyon"
+ },
+ "transfers": {
+ "message": "Mga Inilipat"
+ },
+ "troubleTokenBalances": {
+ "message": "Nagkaroon kami ng problema sa paglo-load ng iyong mga balanseng token. Tingnan ito dito ",
+ "description": "Susundan ng link (dito) para tingnan ang token balances"
+ },
+ "typePassword": {
+ "message": "I-type ang iyong Password"
+ },
+ "uiWelcome": {
+ "message": "Maligayang pagdating sa Bagong UI (Beta)"
+ },
+ "uiWelcomeMessage": {
+ "message": "Ginagamit mo na ngayon ang bagong MetaMask UI. I-explore at subukan ang mga bagong features tulad ng pagpapadala ng mga token, at ipaalam sa amin kung mayroon kang anumang mga isyu."
+ },
+ "unavailable": {
+ "message": "Hindi Magagamit"
+ },
+ "unknown": {
+ "message": "Hindi Alam"
+ },
+ "unknownNetwork": {
+ "message": "Hindi Alam ang Pribadong Network"
+ },
+ "unknownNetworkId": {
+ "message": "Hindi alam ang network ID"
+ },
+ "usaOnly": {
+ "message": "USA lamang",
+ "description": "Ang paggamit ng exchange na ito ay limitado sa mga tao sa loob ng Estados Unidos"
+ },
+ "usedByClients": {
+ "message": "Ginagamit ng iba't ibang mga clients"
+ },
+ "viewAccount": {
+ "message": "Tingnan ang Account"
+ },
+ "warning": {
+ "message": "Babala"
+ },
+ "whatsThis": {
+ "message": "Ano ito?"
+ },
+ "yourSigRequested": {
+ "message": "Hinihiling ang iyong signature"
+ },
+ "youSign": {
+ "message": "Ikaw ay nagsa-sign"
+ }
+}
diff --git a/app/_locales/pt/messages.json b/app/_locales/pt/messages.json
new file mode 100644
index 000000000..c9eb178f9
--- /dev/null
+++ b/app/_locales/pt/messages.json
@@ -0,0 +1,819 @@
+{
+ "accept": {
+ "message": "Aceitar"
+ },
+ "account": {
+ "message": "Conta"
+ },
+ "accountDetails": {
+ "message": "Detalhes da Conta"
+ },
+ "accountName": {
+ "message": "Nome da Conta"
+ },
+ "address": {
+ "message": "Endereço"
+ },
+ "addCustomToken": {
+ "message": "Adicionar token customizada"
+ },
+ "addToken": {
+ "message": "Adicionar Token"
+ },
+ "addTokens": {
+ "message": "Adicionar Tokens"
+ },
+ "amount": {
+ "message": "Valor"
+ },
+ "amountPlusGas": {
+ "message": "Valor + Gas"
+ },
+ "appDescription": {
+ "message": "Extensão para o browser de Ethereum",
+ "description": "A descrição da aplicação"
+ },
+ "appName": {
+ "message": "MetaMask",
+ "description": "Nome da aplicação"
+ },
+ "attemptingConnect": {
+ "message": "A tentar ligar à blockchain."
+ },
+ "attributions": {
+ "message": "Atribuições"
+ },
+ "available": {
+ "message": "Disponível"
+ },
+ "back": {
+ "message": "Voltar"
+ },
+ "balance": {
+ "message": "Saldo:"
+ },
+ "balances": {
+ "message": "O meu saldo"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "Saldo insuficiente para a quantidade de gas total"
+ },
+ "beta": {
+ "message": "BETA"
+ },
+ "betweenMinAndMax": {
+ "message": "tem de ser maior ou igual a $1 e menor ou igual a $2.",
+ "description": "ajuda para introduzir hexadecimal como decimal"
+ },
+ "blockiesIdenticon": {
+ "message": "Usar Blockies Identicon"
+ },
+ "borrowDharma": {
+ "message": "Pedir Empréstimo Com Dharma (Beta)"
+ },
+ "builtInCalifornia": {
+ "message": "MetaMask é desenhada e construída na California."
+ },
+ "buy": {
+ "message": "Comprar"
+ },
+ "buyCoinbase": {
+ "message": "Comprar no Coinbase"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "Coinbase é a forma mais conhecida para comprar e vender bitcoin, ethereum, e litecoin."
+ },
+ "cancel": {
+ "message": "Cancelar"
+ },
+ "classicInterface": {
+ "message": "Utilizar interface clássico"
+ },
+ "clickCopy": {
+ "message": "Carregue para copiar"
+ },
+ "confirm": {
+ "message": "Confirmar"
+ },
+ "confirmContract": {
+ "message": "Confirmar Contrato"
+ },
+ "confirmPassword": {
+ "message": "Confirmar Palavra-passe"
+ },
+ "confirmTransaction": {
+ "message": "Confirmar Transação"
+ },
+ "continue": {
+ "message": "Continuar"
+ },
+ "continueToCoinbase": {
+ "message": "Continuar para o Coinbase"
+ },
+ "contractDeployment": {
+ "message": "Distribuição do Contrato"
+ },
+ "conversionProgress": {
+ "message": "Conversão em progresso"
+ },
+ "copiedButton": {
+ "message": "Copiado"
+ },
+ "copiedClipboard": {
+ "message": "Copiado para a Área de Transferência"
+ },
+ "copiedExclamation": {
+ "message": "Copiado!"
+ },
+ "copiedSafe": {
+ "message": "Já copiei para um lugar seguro"
+ },
+ "copy": {
+ "message": "Copiar"
+ },
+ "copyToClipboard": {
+ "message": "Copiar para o clipboard"
+ },
+ "copyButton": {
+ "message": " Copiar "
+ },
+ "copyPrivateKey": {
+ "message": "Esta é a sua chave privada (carregue para copiar)"
+ },
+ "create": {
+ "message": "Criar"
+ },
+ "createAccount": {
+ "message": "Criar Conta"
+ },
+ "createDen": {
+ "message": "Criar"
+ },
+ "crypto": {
+ "message": "Cripto",
+ "description": "Tipo de câmbio (criptomoedas)"
+ },
+ "currentConversion": {
+ "message": "Taxa de Conversão Atual"
+ },
+ "currentNetwork": {
+ "message": "Rede Atual"
+ },
+ "customGas": {
+ "message": "Customizar Gas"
+ },
+ "customize": {
+ "message": "Customizar"
+ },
+ "customRPC": {
+ "message": "Customizar RPC"
+ },
+ "decimalsMustZerotoTen": {
+ "message": "Decimais devem ser no mínimo 0 e não passar de 36."
+ },
+ "decimal": {
+ "message": "Precisão em Decimais"
+ },
+ "defaultNetwork": {
+ "message": "A rede pré definida para transações em Ether é a Main Net."
+ },
+ "denExplainer": {
+ "message": " DEN é o armazenamento encriptado da sua palavra-passe no MetaMask."
+ },
+ "deposit": {
+ "message": "Depósito"
+ },
+ "depositBTC": {
+ "message": "Deposite as suas BTC no endereço abaixo:"
+ },
+ "depositCoin": {
+ "message": "Deposite $1 no endereço abaixo",
+ "description": "Diz ao usuário que moeda selecionou para depositar com shapeshift"
+ },
+ "depositEth": {
+ "message": "Depositar Eth"
+ },
+ "depositEther": {
+ "message": "Depositar Ether"
+ },
+ "depositFiat": {
+ "message": "Depositar moeda fiduciária"
+ },
+ "depositFromAccount": {
+ "message": "Depositar de outra conta"
+ },
+ "depositShapeShift": {
+ "message": "Depositar com ShapeShift"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "Se tem criptomoedas, pode trocar e depositar Ether diretamente na sua carteira MetaMask. Não precisa de conta."
+ },
+ "details": {
+ "message": "Detalhes"
+ },
+ "directDeposit": {
+ "message": "Depósito Direto"
+ },
+ "directDepositEther": {
+ "message": "Depositar Diretamente Ether"
+ },
+ "directDepositEtherExplainer": {
+ "message": "Se já tem Ether, a forma mais rápida de ficar com Ether na sua carteira é através de depósito direto."
+ },
+ "done": {
+ "message": "Finalizado"
+ },
+ "downloadStatelogs": {
+ "message": "Descarregar Registos de Estado"
+ },
+ "edit": {
+ "message": "Editar"
+ },
+ "editAccountName": {
+ "message": "Editar Nome da Conta"
+ },
+ "emailUs": {
+ "message": "Fale connosco!"
+ },
+ "encryptNewDen": {
+ "message": "Encripte o seu novo DEN"
+ },
+ "enterPassword": {
+ "message": "Introduza palavra-passe"
+ },
+ "enterPasswordConfirm": {
+ "message": "Introduza a sua palavra-passe para confirmar"
+ },
+ "etherscanView": {
+ "message": "Ver conta no Etherscan"
+ },
+ "exchangeRate": {
+ "message": "Taxa de Câmbio"
+ },
+ "exportPrivateKey": {
+ "message": "Exportar Chave Privada"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "Exportar chaves privadas por sua conta e risco."
+ },
+ "failed": {
+ "message": "Falhou"
+ },
+ "fiat": {
+ "message": "FIAT",
+ "description": "Tipo de câmbio"
+ },
+ "fileImportFail": {
+ "message": "A importação de ficheiro não está a funcionar? Carregue aqui!",
+ "description": "Ajuda usuários a importar as suas contas a partir de um ficheiro JSON"
+ },
+ "followTwitter": {
+ "message": "Siga-nos no Twitter"
+ },
+ "from": {
+ "message": "De"
+ },
+ "fromToSame": {
+ "message": "Endereços De e Para não podem ser iguais"
+ },
+ "fromShapeShift": {
+ "message": "De ShapeShift"
+ },
+ "gas": {
+ "message": "Gas",
+ "description": "Indicação breve do custo de gas"
+ },
+ "gasFee": {
+ "message": "Taxa de Gas"
+ },
+ "gasLimit": {
+ "message": "Limite de Gas"
+ },
+ "gasLimitCalculation": {
+ "message": "Calculamos o limite sugerido do gas com base nas taxas de sucesso da rede."
+ },
+ "gasLimitRequired": {
+ "message": "Limite de Gas Necessário"
+ },
+ "gasLimitTooLow": {
+ "message": "Limite de Gas deve ser no mínimo 21000"
+ },
+ "generatingSeed": {
+ "message": "A gerar Seed..."
+ },
+ "gasPrice": {
+ "message": "Preço Gas (GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "Calculamos o gas sugerido com base nas taxas de sucesso da rede."
+ },
+ "gasPriceRequired": {
+ "message": "Preço Gas Necessário"
+ },
+ "getEther": {
+ "message": "Obter Ether"
+ },
+ "getEtherFromFaucet": {
+ "message": "Obter Ether de um faucet por $1",
+ "description": "Mostra nome da rede para faucet de Ether"
+ },
+ "greaterThanMin": {
+ "message": "tem de ser maior ou igual a $1.",
+ "description": "ajuda para introduzir hexadecimal como decimal"
+ },
+ "here": {
+ "message": "aqui",
+ "description": "como -clicar aqui- para mais informações (associado a troubleTokenBalances)"
+ },
+ "hereList": {
+ "message": "Aqui está uma lista!!!!"
+ },
+ "hide": {
+ "message": "Ocultar"
+ },
+ "hideToken": {
+ "message": "Ocultar Token"
+ },
+ "hideTokenPrompt": {
+ "message": "Ocultar Token?"
+ },
+ "howToDeposit": {
+ "message": "Como gostaria de depositar Ether?"
+ },
+ "holdEther": {
+ "message": "Permite ter ether & tokens, e serve como uma ponte para aplicações descentralizadas."
+ },
+ "import": {
+ "message": "Importar",
+ "description": "Botão para importar uma conta de um ficheiro selecionado"
+ },
+ "importAccount": {
+ "message": "Importar Conta"
+ },
+ "importAccountMsg": {
+ "message":"Contas importadas não irão ser associadas com a frase seed da conta criada originalmente pelo MetaMask. Saiba mais sobre contas importadas."
+ },
+ "importAnAccount": {
+ "message": "Importar uma conta"
+ },
+ "importDen": {
+ "message": "Importar DEN Existente"
+ },
+ "imported": {
+ "message": "Importado",
+ "description": "estado para mostrar que uma conta foi totalmente carregada para o keyring"
+ },
+ "infoHelp": {
+ "message": "Informação & Ajuda"
+ },
+ "insufficientFunds": {
+ "message": "Fundos insuficientes."
+ },
+ "insufficientTokens": {
+ "message": "Tokens insuficientes."
+ },
+ "invalidAddress": {
+ "message": "Endereço inválido"
+ },
+ "invalidAddressRecipient": {
+ "message": "O endereço do destinatário é inválido "
+ },
+ "invalidGasParams": {
+ "message": "Parâmetros para o Gas Inválidos"
+ },
+ "invalidInput": {
+ "message": "Campo inválido."
+ },
+ "invalidRequest": {
+ "message": "Pedido Inválido"
+ },
+ "invalidRPC": {
+ "message": "RPC URI Inválido"
+ },
+ "jsonFail": {
+ "message": "Ocorreu um erro. Por favor confirme que o seu ficheiro JSON está devidamente formatado."
+ },
+ "jsonFile": {
+ "message": "Ficheiro JSON",
+ "description": "Formatar para importar uma conta"
+ },
+ "kovan": {
+ "message": "Rede de Teste Kovan"
+ },
+ "knowledgeDataBase": {
+ "message": "Visite o nosso Centro de Conhecimento"
+ },
+ "lessThanMax": {
+ "message": "tem de ser menor ou igual a $1.",
+ "description": "ajuda para introduzir hexadecimal como decimal"
+ },
+ "likeToAddTokens": {
+ "message": "Gostaria de adicionar estes tokens?"
+ },
+ "limit": {
+ "message": "Limite"
+ },
+ "loading": {
+ "message": "A carregar..."
+ },
+ "loadingTokens": {
+ "message": "A carregar Tokens..."
+ },
+ "localhost": {
+ "message": "Localhost 8545"
+ },
+ "login": {
+ "message": "Entrar"
+ },
+ "logout": {
+ "message": "Sair"
+ },
+ "loose": {
+ "message": "Vago"
+ },
+ "loweCaseWords": {
+ "message": "palavras da seed apenas têm caracteres minúsculos"
+ },
+ "mainnet": {
+ "message": "Rede Principal de Ethereum"
+ },
+ "message": {
+ "message": "Mensagem"
+ },
+ "metamaskDescription": {
+ "message": "O MetaMask é um lugar seguro para guardar a sua identidade em em Ethereum."
+ },
+ "min": {
+ "message": "Mínimo"
+ },
+ "myAccounts": {
+ "message": "As minhas contas"
+ },
+ "mustSelectOne": {
+ "message": "Deve escolher no mínimo 1 token."
+ },
+ "needEtherInWallet": {
+ "message": "Para interagir com applicações descentralizadas usando MetaMask tem de ter Ether na sua carteira."
+ },
+ "needImportFile": {
+ "message": "Deve selecionar um ficheiro para importar.",
+ "description": "O utilizador deve adicionar um ficheiro para continuar"
+ },
+ "needImportPassword": {
+ "message": "Deve introduzir uma palavra-passe para o ficheiro selecionado.",
+ "description": "Palavra-passe e ficheiro necessários para importar uma conta"
+ },
+ "negativeETH": {
+ "message": "Não é possível enviar valores negativos de ETH."
+ },
+ "networks": {
+ "message": "Redes"
+ },
+ "newAccount": {
+ "message": "Conta Nova"
+ },
+ "newAccountNumberName": {
+ "message": "Conta $1",
+ "description": "Nome padrão da próxima conta a ser criado em Criar Conta"
+ },
+ "newContract": {
+ "message": "Contrato Novo"
+ },
+ "newPassword": {
+ "message": "Nova Palavra-passe (min 8 caracteres)"
+ },
+ "newRecipient": {
+ "message": "Recipiente Novo"
+ },
+ "newRPC": {
+ "message": "Novo RPC URL"
+ },
+ "next": {
+ "message": "Próximo"
+ },
+ "noAddressForName": {
+ "message": "Nenhum endereço foi estabelecido para este nome."
+ },
+ "noDeposits": {
+ "message": "Sem depósitos recebidos"
+ },
+ "noTransactionHistory": {
+ "message": "Sem histórico de transações."
+ },
+ "noTransactions": {
+ "message": "Sem Transações"
+ },
+ "notStarted": {
+ "message": "Não Iniciado"
+ },
+ "oldUI": {
+ "message": "UI Antigo"
+ },
+ "oldUIMessage": {
+ "message": "Voltou para o UI antigo. Pode reverter para o Novo UI através da opção no menu do topo direito."
+ },
+ "or": {
+ "message": "ou",
+ "description": "opção entre criar ou importar uma nova conta"
+ },
+ "passwordCorrect": {
+ "message": "Por favor confirme que a sua palavra-passe esteja correta."
+ },
+ "passwordMismatch": {
+ "message": "as palavras-passe não coincidem",
+ "description": "no processo de criação da palavra-passe, as duas palavras-passe não coincidiram"
+ },
+ "passwordShort": {
+ "message": "palavra-passe deve ser mais comprida",
+ "description": "no processo de criação da palavra-passe, a palavra-apasse não é longa o suficiente para ser segura"
+ },
+ "pastePrivateKey": {
+ "message": "Cole aqui a sua chave privada:",
+ "description": "Para importar uma conta através da chave privada"
+ },
+ "pasteSeed": {
+ "message": "Cole aqui a sua frase seed!"
+ },
+ "personalAddressDetected": {
+ "message": "Endereço pessoal detectado. Introduza o endereço do contrato do token."
+ },
+ "pleaseReviewTransaction": {
+ "message": "Por favor reveja a sua transação."
+ },
+ "privacyMsg": {
+ "message": "Política de Privacidade"
+ },
+ "privateKey": {
+ "message": "Chave Privada",
+ "description": "Selecione este tipo de ficheiro para importar uma conta"
+ },
+ "privateKeyWarning": {
+ "message": "Atenção: Nunca revele esta chave. Qualquer pessoa com acesso à sua chave privada pode roubar os bens que esta contém."
+ },
+ "privateNetwork": {
+ "message": "Rede Privada"
+ },
+ "qrCode": {
+ "message": "Mostrar Código QR"
+ },
+ "readdToken": {
+ "message": "Pode adicionar este token de novo clicando na opção “Adicionar token” no menu de opções da sua conta."
+ },
+ "readMore": {
+ "message": "Ler mais aqui."
+ },
+ "readMore2": {
+ "message": "Ler mais."
+ },
+ "receive": {
+ "message": "Receber"
+ },
+ "recipientAddress": {
+ "message": "Endereço do Destinatário"
+ },
+ "refundAddress": {
+ "message": "O seu endereço de reembolso"
+ },
+ "rejected": {
+ "message": "Rejeitado"
+ },
+ "resetAccount": {
+ "message": "Reinicializar Conta"
+ },
+ "restoreFromSeed": {
+ "message": "Restaurar a partir da frase seed"
+ },
+ "required": {
+ "message": "Necessário"
+ },
+ "retryWithMoreGas": {
+ "message": "Tentar novamente com um preço mais elevado aqui"
+ },
+ "revealSeedWords": {
+ "message": "Revelar Palavras Seed"
+ },
+ "revealSeedWordsWarning": {
+ "message": "Não revele as palavras seed num espaço público! Estas palavras podem ser usadas para roubar todas as suas contas."
+ },
+ "revert": {
+ "message": "Reverter"
+ },
+ "rinkeby": {
+ "message": "Rede de Teste Rinkeby"
+ },
+ "ropsten": {
+ "message": "Rede de Teste Ropsten"
+ },
+ "sampleAccountName": {
+ "message": "Ex. A minha conta nova",
+ "description": "Ajuda o utilizador a perceber o conceito de adicionar um nome legível à sua conta"
+ },
+ "save": {
+ "message": "Guardar"
+ },
+ "saveAsFile": {
+ "message": "Guardar como Ficheiro",
+ "description": "Processo de exportação de conta"
+ },
+ "saveSeedAsFile": {
+ "message": "Guardar Palavras Seed como um Ficheiro"
+ },
+ "search": {
+ "message": "Procurar"
+ },
+ "secretPhrase": {
+ "message": "Introduza a sua frase secreta de 12 palavras para recuperar o seu ."
+ },
+ "seedPhraseReq": {
+ "message": "seed phrases are 12 words long"
+ },
+ "select": {
+ "message": "Selecionar"
+ },
+ "selectCurrency": {
+ "message": "Selecionar Moeda"
+ },
+ "selectService": {
+ "message": "Selecionar Serviço"
+ },
+ "selectType": {
+ "message": "Selecionar Tipo"
+ },
+ "send": {
+ "message": "Enviar"
+ },
+ "sendETH": {
+ "message": "Enviar ETH"
+ },
+ "sendTokens": {
+ "message": "Enviar Tokens"
+ },
+ "sendTokensAnywhere": {
+ "message": "Enviar Tokens para qualquer pessoa com uma conta Ethereum"
+ },
+ "settings": {
+ "message": "Definições"
+ },
+ "shapeshiftBuy": {
+ "message": "Comprar com Shapeshift"
+ },
+ "showPrivateKeys": {
+ "message": "Mostrar Chaves Privadas"
+ },
+ "showQRCode": {
+ "message": "Mostrar Código QR"
+ },
+ "sign": {
+ "message": "Assinar"
+ },
+ "signMessage": {
+ "message": "Assinar Mensagem"
+ },
+ "signNotice": {
+ "message": "Assinar esta mensagem pode ter \nefeitos laterais perigosos. Apenas assine mensagens de sites que \ntotalmente confia com a sua conta total.\n Este método perigoso será removido numa versão posterior."
+ },
+ "sigRequest": {
+ "message": "Pedido de Assinatura"
+ },
+ "sigRequested": {
+ "message": "Assinatura Pedida"
+ },
+ "spaceBetween": {
+ "message": "só pode haver um espaço entre palavras"
+ },
+ "status": {
+ "message": "Estado"
+ },
+ "stateLogs": {
+ "message": "Registos de Estado"
+ },
+ "stateLogsDescription": {
+ "message": "Registo de estado podem conter o seu endereço e transações enviadas da sua conta pública."
+ },
+ "submit": {
+ "message": "Submeter"
+ },
+ "supportCenter": {
+ "message": "Visitar o nosso Centro de Suporte"
+ },
+ "symbolBetweenZeroTen": {
+ "message": "Símbolo deve conter entre 0 e 10 characters."
+ },
+ "takesTooLong": {
+ "message": "A demorar muito?"
+ },
+ "terms": {
+ "message": "Termos de Uso"
+ },
+ "testFaucet": {
+ "message": "Faucet de Teste"
+ },
+ "to": {
+ "message": "Para"
+ },
+ "toETHviaShapeShift": {
+ "message": "$1 para ETH via ShapeShift",
+ "description": "o sistema irá preencher o tipo de depósito no início da mensagem"
+ },
+ "tokenAddress": {
+ "message": "Endereço do Token"
+ },
+ "tokenAlreadyAdded": {
+ "message": "Token já foi adicionado."
+ },
+ "tokenBalance": {
+ "message": "O seu balanço é:"
+ },
+ "tokenSelection": {
+ "message": "Procure por tokens ou seleccione da nossa lista de tokens populares."
+ },
+ "tokenSymbol": {
+ "message": "Símbolo do Token"
+ },
+ "tokenWarning1": {
+ "message": "Registe os tokens que comprou com a sua conta MetaMask. Se comprou tokens utilizando uma conta diferente, esses tokens não irão aparecer aqui."
+ },
+ "total": {
+ "message": "Total"
+ },
+ "transactions": {
+ "message": "transações"
+ },
+ "transactionMemo": {
+ "message": "Notas da transação (opcional)"
+ },
+ "transactionNumber": {
+ "message": "Número da Transação"
+ },
+ "transfers": {
+ "message": "Transferências"
+ },
+ "troubleTokenBalances": {
+ "message": "Tivemos um problema a carregar o balanço dos seus tokens. Pode vê-los em ",
+ "description": "Seguido de um link (aqui) para ver o balanço dos seus tokens"
+ },
+ "twelveWords": {
+ "message": "Estas 12 palavras são a única forma de recuperar as suas contas na MetaMask.\nGuarde-as num local seguro e secreto."
+ },
+ "typePassword": {
+ "message": "Digite a sua Palavra-passe"
+ },
+ "uiWelcome": {
+ "message": "Bem-vindo ao seu Novo UI (Beta)"
+ },
+ "uiWelcomeMessage": {
+ "message": "Está agora a usar o novo UI da MetaMask. Dê uma vista de olhos, experimenta as novas funcionalidades como enviar tokens e diga-nos se tiver algum problema."
+ },
+ "unavailable": {
+ "message": "Indisponível"
+ },
+ "unknown": {
+ "message": "Desconhecido"
+ },
+ "unknownNetwork": {
+ "message": "Rede Privada Desconhecida"
+ },
+ "unknownNetworkId": {
+ "message": "Identificador da rede desconhecido"
+ },
+ "uriErrorMsg": {
+ "message": "Links requerem o prefixo HTTP/HTTPS apropriado."
+ },
+ "usaOnly": {
+ "message": "Só nos EUA",
+ "description": "Usar esta taxa de câmbio está limitado a pessoas residentes nos EUA"
+ },
+ "usedByClients": {
+ "message": "Utilizado por vários tipos de clientes"
+ },
+ "useOldUI": {
+ "message": "Utilizar UI antigo"
+ },
+ "validFileImport": {
+ "message": "Deve selecionar um ficheiro válido para importar."
+ },
+ "vaultCreated": {
+ "message": "Cofre Criado"
+ },
+ "viewAccount": {
+ "message": "Ver Conta"
+ },
+ "visitWebSite": {
+ "message": "Visite o nosso site"
+ },
+ "warning": {
+ "message": "Aviso"
+ },
+ "welcomeBeta": {
+ "message": "Bem-vindo ao MetaMask Beta"
+ },
+ "whatsThis": {
+ "message": "O que é isto?"
+ },
+ "yourSigRequested": {
+ "message": "A sua assinatura está a ser pedida"
+ },
+ "youSign": {
+ "message": "Está a assinar"
+ }
+}
diff --git a/app/_locales/ru/messages.json b/app/_locales/ru/messages.json
new file mode 100644
index 000000000..e3a1935f5
--- /dev/null
+++ b/app/_locales/ru/messages.json
@@ -0,0 +1,819 @@
+{
+ "accept": {
+ "message": "Принять"
+ },
+ "account": {
+ "message": "Аккаунт"
+ },
+ "accountDetails": {
+ "message": "Детали Аккаунта"
+ },
+ "accountName": {
+ "message": "Имя Пользователя"
+ },
+ "address": {
+ "message": "Адрес"
+ },
+ "addCustomToken": {
+ "message": "Добавить пользовательский токен"
+ },
+ "addToken": {
+ "message": "Добавить токен"
+ },
+ "addTokens": {
+ "message": "Добавить Токены"
+ },
+ "amount": {
+ "message": "Количество"
+ },
+ "amountPlusGas": {
+ "message": "Количество + газ"
+ },
+ "appDescription": {
+ "message": "Расширение браузера для Ethereum",
+ "description": "The description of the application"
+ },
+ "appName": {
+ "message": "MetaMask",
+ "description": "The name of the application"
+ },
+ "attemptingConnect": {
+ "message": "Попытка подключиться к блокчейн сети."
+ },
+ "attributions": {
+ "message": "Опознания"
+ },
+ "available": {
+ "message": "Доступный"
+ },
+ "back": {
+ "message": "Назад"
+ },
+ "balance": {
+ "message": "Баланс:"
+ },
+ "balances": {
+ "message": "Ваши балансы"
+ },
+ "balanceIsInsufficientGas": {
+ "message": "Недостаточный баланс для текущего объема газа"
+ },
+ "beta": {
+ "message": "БЕТА"
+ },
+ "betweenMinAndMax": {
+ "message": "должно быть больше или равно $1 и меньше или равно $2.",
+ "description": "helper for inputting hex as decimal input"
+ },
+ "blockiesIdenticon": {
+ "message": "Использовать Blockies Identicon"
+ },
+ "borrowDharma": {
+ "message": "Заимствовать с Dharma (бета)"
+ },
+ "builtInCalifornia": {
+ "message": "MetaMask спроектирован и построен в Калифорнии."
+ },
+ "buy": {
+ "message": "Купить"
+ },
+ "buyCoinbase": {
+ "message": "Купить на Coinbase"
+ },
+ "buyCoinbaseExplainer": {
+ "message": "Coinbase - самый популярный в мире способ купить и продать биткойн, ethereum и litecoin."
+ },
+ "cancel": {
+ "message": "Отмена"
+ },
+ "classicInterface": {
+ "message": "Использовать классический интерфейс"
+ },
+ "clickCopy": {
+ "message": "Нажмите, чтобы скопировать"
+ },
+ "confirm": {
+ "message": "Подтвердить"
+ },
+ "confirmContract": {
+ "message": "Подтвердить Контракт"
+ },
+ "confirmPassword": {
+ "message": "Подтвердите Пароль"
+ },
+ "confirmTransaction": {
+ "message": "Подтвердить Транзакцию"
+ },
+ "continue": {
+ "message": "Продолжить"
+ },
+ "continueToCoinbase": {
+ "message": "Продолжить в Coinbase"
+ },
+ "contractDeployment": {
+ "message": "Развертывание контракта"
+ },
+ "conversionProgress": {
+ "message": "Выполняется конверсия"
+ },
+ "copiedButton": {
+ "message": "Скопировано"
+ },
+ "copiedClipboard": {
+ "message": "Скопировано в буфер обмена"
+ },
+ "copiedExclamation": {
+ "message": "Скопировано!"
+ },
+ "copiedSafe": {
+ "message": "Я скопировал его где-то в безопасности"
+ },
+ "copy": {
+ "message": "Скопировать"
+ },
+ "copyToClipboard": {
+ "message": "Скопировать в буфер обмена"
+ },
+ "copyButton": {
+ "message": " Скопировать "
+ },
+ "copyPrivateKey": {
+ "message": "Это ваш личный ключ (нажмите, чтобы скопировать)"
+ },
+ "create": {
+ "message": "Создать"
+ },
+ "createAccount": {
+ "message": "Регистрация"
+ },
+ "createDen": {
+ "message": "Создать"
+ },
+ "crypto": {
+ "message": "Крипто",
+ "description": "Exchange type (cryptocurrencies)"
+ },
+ "currentConversion": {
+ "message": "Текущая конверсия"
+ },
+ "currentNetwork": {
+ "message": "Текущая сеть"
+ },
+ "customGas": {
+ "message": "Настроить Газ"
+ },
+ "customize": {
+ "message": "Настроить"
+ },
+ "customRPC": {
+ "message": "Пользовательский RPC"
+ },
+ "decimalsMustZerotoTen": {
+ "message": "Десятичные числа должны быть не менее 0, и не более 36."
+ },
+ "decimal": {
+ "message": "Десятичные значения точности"
+ },
+ "defaultNetwork": {
+ "message": "Сеть по умолчанию для транзакций Ether - это Main Net."
+ },
+ "denExplainer": {
+ "message": "Ваш DEN - это ваше зашифрованное паролем хранилище в MetaMask."
+ },
+ "deposit": {
+ "message": "Депозит"
+ },
+ "depositBTC": {
+ "message": "Депозит BTC по адресу:"
+ },
+ "depositCoin": {
+ "message": "Депозит $1 по указанному ниже адресу",
+ "description": "Tells the user what coin they have selected to deposit with shapeshift"
+ },
+ "depositEth": {
+ "message": "Депозит Eth"
+ },
+ "depositEther": {
+ "message": "Депозит Эфир"
+ },
+ "depositFiat": {
+ "message": "Депозит с деньгами"
+ },
+ "depositFromAccount": {
+ "message": "Депозит с другого счета"
+ },
+ "depositShapeShift": {
+ "message": "Депозит с ShapeShift"
+ },
+ "depositShapeShiftExplainer": {
+ "message": "Если у вас есть другие крипторесурсы, вы можете торговать и вносить Эфир непосредственно в кошелек MetaMask. Нет необходимости в аккаунте."
+ },
+ "details": {
+ "message": "Детали"
+ },
+ "directDeposit": {
+ "message": "Прямой Депозит"
+ },
+ "directDepositEther": {
+ "message": "Прямой Депозит Эфира"
+ },
+ "directDepositEtherExplainer": {
+ "message": "Если у вас уже есть Эфир, самый быстрый способ получить Эфир в вашем новом кошельке это прямым депозитом."
+ },
+ "done": {
+ "message": "Готово"
+ },
+ "downloadStatelogs": {
+ "message": "Загрузить логи статус"
+ },
+ "edit": {
+ "message": "Редактировать"
+ },
+ "editAccountName": {
+ "message": "Изменить Имя Аккаунта"
+ },
+ "emailUs": {
+ "message": "Свяжитесь с нами по электронной почте!"
+ },
+ "encryptNewDen": {
+ "message": "Шифруйте новый DEN"
+ },
+ "enterPassword": {
+ "message": "Введите пароль"
+ },
+ "enterPasswordConfirm": {
+ "message": "Введите свой пароль для подтверждения"
+ },
+ "etherscanView": {
+ "message": "Просмотреть аккаунт на Etherscan"
+ },
+ "exchangeRate": {
+ "message": "Обменный Курс"
+ },
+ "exportPrivateKey": {
+ "message": "Экспорт закрытого ключа"
+ },
+ "exportPrivateKeyWarning": {
+ "message": "Экспорт секретных ключей на свой страх и риск."
+ },
+ "failed": {
+ "message": "Не смогли"
+ },
+ "fiat": {
+ "message": "Бумажные деньги",
+ "description": "Exchange type"
+ },
+ "fileImportFail": {
+ "message": "Ошибка импорта файлов? Кликните сюда!",
+ "description": "Helps user import their account from a JSON file"
+ },
+ "followTwitter": {
+ "message": "Следуйте за нами на Twitter"
+ },
+ "from": {
+ "message": "Из"
+ },
+ "fromToSame": {
+ "message": "От и до адреса не могут быть одинаковым"
+ },
+ "fromShapeShift": {
+ "message": "Из ShapeShift"
+ },
+ "gas": {
+ "message": "Газ",
+ "description": "Short indication of gas cost"
+ },
+ "gasFee": {
+ "message": "Плата за Газ"
+ },
+ "gasLimit": {
+ "message": "Газовый Предел"
+ },
+ "gasLimitCalculation": {
+ "message": "Мы рассчитываем предполагаемый предел газа на основе коэффициентов успешности сети."
+ },
+ "gasLimitRequired": {
+ "message": "Требуется ограничение на Газ"
+ },
+ "gasLimitTooLow": {
+ "message": "Предел газа должен быть не менее 21000"
+ },
+ "generatingSeed": {
+ "message": "Создание Семян ..."
+ },
+ "gasPrice": {
+ "message": "Цена на Газ (GWEI)"
+ },
+ "gasPriceCalculation": {
+ "message": "Мы вычисляем предлагаемые цены на газ на основе коэффициентов успеха сети."
+ },
+ "gasPriceRequired": {
+ "message": "Требуется цена на Газ"
+ },
+ "getEther": {
+ "message": "Получить Эфир"
+ },
+ "getEtherFromFaucet": {
+ "message": "Получите Эфир из крана $1",
+ "description": "Displays network name for Ether faucet"
+ },
+ "greaterThanMin": {
+ "message": "должно быть больше или равно $1.",
+ "description": "helper for inputting hex as decimal input"
+ },
+ "here": {
+ "message": "здесь",
+ "description": "as in -click here- for more information (goes with troubleTokenBalances)"
+ },
+ "hereList": {
+ "message": "Вот список !!!!"
+ },
+ "hide": {
+ "message": "Спрятать"
+ },
+ "hideToken": {
+ "message": "Скрыть токен"
+ },
+ "hideTokenPrompt": {
+ "message": "Скрыть токен?"
+ },
+ "howToDeposit": {
+ "message": "Как бы вы хотели поместить Эфир?"
+ },
+ "holdEther": {
+ "message": "Это позволяет вам использовать эфир и токены и служит мостом для децентрализованных приложений."
+ },
+ "import": {
+ "message": "Импортировать",
+ "description": "Button to import an account from a selected file"
+ },
+ "importAccount": {
+ "message": "Импорт Аккаунта"
+ },
+ "importAccountMsg": {
+ "message": " Импортированные аккаунты не будут связаны с вашей первоначально созданным аккаунтом MetaMask. Подробнее о импортированных аккаунтах "
+ },
+ "importAnAccount": {
+ "message": "Импортировать аккаунт"
+ },
+ "importDen": {
+ "message": "Импорт существующих DEN"
+ },
+ "imported": {
+ "message": "Импортирован",
+ "description": "status showing that an account has been fully loaded into the keyring"
+ },
+ "infoHelp": {
+ "message": "Информация и Помощь"
+ },
+ "insufficientFunds": {
+ "message": "Недостаточно средств."
+ },
+ "insufficientTokens": {
+ "message": "Недостаточно токенов."
+ },
+ "invalidAddress": {
+ "message": "Недействительный адрес"
+ },
+ "invalidAddressRecipient": {
+ "message": "Недопустимый адрес получателя."
+ },
+ "invalidGasParams": {
+ "message": "Недопустимые параметры Газа"
+ },
+ "invalidInput": {
+ "message": "Неправильный ввод."
+ },
+ "invalidRequest": {
+ "message": "Неверный Запрос"
+ },
+ "invalidRPC": {
+ "message": "Недопустимый URI RPC"
+ },
+ "jsonFail": {
+ "message": "Что-то пошло не так. Убедитесь, что ваш файл JSON правильно отформатирован."
+ },
+ "jsonFile": {
+ "message": "Файл JSON",
+ "description": "format for importing an account"
+ },
+ "kovan": {
+ "message": "Kovan тестовая сеть"
+ },
+ "knowledgeDataBase": {
+ "message": "Посетите нашу базу знаний"
+ },
+ "lessThanMax": {
+ "message": "должно быть меньше или равно $1.",
+ "description": "helper for inputting hex as decimal input"
+ },
+ "likeToAddTokens": {
+ "message": "Вы хотите добавить эти токены?"
+ },
+ "limit": {
+ "message": "Предел"
+ },
+ "loading": {
+ "message": "Загрузка..."
+ },
+ "loadingTokens": {
+ "message": "Загрузка токенов ..."
+ },
+ "localhost": {
+ "message": "Локальный адрес 8545"
+ },
+ "login": {
+ "message": "Авторизоваться"
+ },
+ "logout": {
+ "message": "Выйти"
+ },
+ "loose": {
+ "message": "Рыхлый"
+ },
+ "loweCaseWords": {
+ "message": "семенные слова имеют только символы нижнего регистра"
+ },
+ "mainnet": {
+ "message": "Основная сеть Ethereum"
+ },
+ "message": {
+ "message": "Сообщение"
+ },
+ "metamaskDescription": {
+ "message": "MetaMask - это безопасное хранилище для Ethereum."
+ },
+ "min": {
+ "message": "Минимум"
+ },
+ "myAccounts": {
+ "message": "Мои Аккаунты"
+ },
+ "mustSelectOne": {
+ "message": "Необходимо выбрать не менее 1 токена."
+ },
+ "needEtherInWallet": {
+ "message": "Чтобы взаимодействовать с децентрализованными приложениями с помощью MetaMask, вам понадобится Эфир в вашем кошельке."
+ },
+ "needImportFile": {
+ "message": "Вы должны выбрать файл для импорта.",
+ "description": "User is important an account and needs to add a file to continue"
+ },
+ "needImportPassword": {
+ "message": "Вы должны ввести пароль для выбранного файла.",
+ "description": "Password and file needed to import an account"
+ },
+ "negativeETH": {
+ "message": "Невозможно отправить отрицательные количества ETH."
+ },
+ "networks": {
+ "message": "Сети"
+ },
+ "newAccount": {
+ "message": "Новый Аккаунт"
+ },
+ "newAccountNumberName": {
+ "message": "Аккаунт $1",
+ "description": "Default name of next account to be created on create account screen"
+ },
+ "newContract": {
+ "message": "Новый Контракт"
+ },
+ "newPassword": {
+ "message": "Новый пароль (мин. 8 символов)"
+ },
+ "newRecipient": {
+ "message": "Новый Получатель"
+ },
+ "newRPC": {
+ "message": "Новый URL-адрес RPC"
+ },
+ "next": {
+ "message": "Далее"
+ },
+ "noAddressForName": {
+ "message": "Для этого имени не задан адрес."
+ },
+ "noDeposits": {
+ "message": "Не было получено никаких депозитов"
+ },
+ "noTransactionHistory": {
+ "message": "Нет истории транзакций."
+ },
+ "noTransactions": {
+ "message": "Нет Транзакций"
+ },
+ "notStarted": {
+ "message": "Не Начался"
+ },
+ "oldUI": {
+ "message": "Старый Интерфейс"
+ },
+ "oldUIMessage": {
+ "message": "Вы вернулись к старому интерфейсу. Вы можете вернуться к новому с помощью опции в раскрывающемся меню в правом верхнем углу."
+ },
+ "or": {
+ "message": "или",
+ "description": "choice between creating or importing a new account"
+ },
+ "passwordCorrect": {
+ "message": "Убедитесь, что ваш пароль правильный."
+ },
+ "passwordMismatch": {
+ "message": "пароли не совпадают",
+ "description": "in password creation process, the two new password fields did not match"
+ },
+ "passwordShort": {
+ "message": "пароль недостаточно длинный",
+ "description": "in password creation process, the password is not long enough to be secure"
+ },
+ "pastePrivateKey": {
+ "message": "Вставьте свою личную строку:",
+ "description": "For importing an account from a private key"
+ },
+ "pasteSeed": {
+ "message": "Вставьте здесь свою семенную фразу!"
+ },
+ "personalAddressDetected": {
+ "message": "Персональный адрес обнаружен. Введите адрес контракта токена."
+ },
+ "pleaseReviewTransaction": {
+ "message": "Проверьте транзакцию."
+ },
+ "privacyMsg": {
+ "message": "Политика Конфиденциальности"
+ },
+ "privateKey": {
+ "message": "Закрытый ключ",
+ "description": "select this type of file to use to import an account"
+ },
+ "privateKeyWarning": {
+ "message": "Предупреждение: никогда не раскрывайте этот ключ. Любой, у кого есть ваши личные ключи, может украсть любые активы, хранящиеся в вашем аккаунте."
+ },
+ "privateNetwork": {
+ "message": "Частная сеть"
+ },
+ "qrCode": {
+ "message": "Показать QR-код"
+ },
+ "readdToken": {
+ "message": "Вы можете добавить этот токен в будущем, перейдя в “Добавить токен” в меню параметров вашего аккаунта."
+ },
+ "readMore": {
+ "message": "Подробнее читайте здесь."
+ },
+ "readMore2": {
+ "message": "Прочитайте больше."
+ },
+ "receive": {
+ "message": "Получить"
+ },
+ "recipientAddress": {
+ "message": "Адрес Получателя"
+ },
+ "refundAddress": {
+ "message": "Ваш Адрес Возврата"
+ },
+ "rejected": {
+ "message": "Отклонено"
+ },
+ "resetAccount": {
+ "message": "Сбросить аккаунт"
+ },
+ "restoreFromSeed": {
+ "message": "Восстановить от семенной фразы"
+ },
+ "required": {
+ "message": "Необходимо"
+ },
+ "retryWithMoreGas": {
+ "message": "Повторите попытку с более высокой ценой на газ здесь"
+ },
+ "revealSeedWords": {
+ "message": "Раскрыть семенные слова"
+ },
+ "revealSeedWordsWarning": {
+ "message": "Не восстанавливайте семенные слова в общественном месте! Эти слова могут использоваться для кражи всех ваших аккаунтах."
+ },
+ "revert": {
+ "message": "Откат"
+ },
+ "rinkeby": {
+ "message": "Rinkeby тестовая сеть"
+ },
+ "ropsten": {
+ "message": "Ropsten тестовая сеть"
+ },
+ "sampleAccountName": {
+ "message": "Например, Мой новый аккаунт",
+ "description": "Help user understand concept of adding a human-readable name to their account"
+ },
+ "save": {
+ "message": "Сохранить"
+ },
+ "saveAsFile": {
+ "message": "Сохранить как Файл",
+ "description": "Account export process"
+ },
+ "saveSeedAsFile": {
+ "message": "Сохранить Семенные Слова Как Файл"
+ },
+ "search": {
+ "message": "Поиск"
+ },
+ "secretPhrase": {
+ "message": "Введите свою секретную двенадцатисловную фразу здесь, чтобы восстановить хранилище."
+ },
+ "seedPhraseReq": {
+ "message": "семенные фразы длиной 12 слов"
+ },
+ "select": {
+ "message": "Выбрать"
+ },
+ "selectCurrency": {
+ "message": "Выберите Валюту"
+ },
+ "selectService": {
+ "message": "Выберите Сервис"
+ },
+ "selectType": {
+ "message": "Выберите Тип"
+ },
+ "send": {
+ "message": "Послать"
+ },
+ "sendETH": {
+ "message": "Отправить ETH"
+ },
+ "sendTokens": {
+ "message": "Отправить Токены"
+ },
+ "sendTokensAnywhere": {
+ "message": "Отправить Токены кому-либо с аккаунтом Ethereum"
+ },
+ "settings": {
+ "message": "Настройки"
+ },
+ "shapeshiftBuy": {
+ "message": "Купить с помощью Shapeshift"
+ },
+ "showPrivateKeys": {
+ "message": "Показать приватные ключи"
+ },
+ "showQRCode": {
+ "message": "Показать QR-код"
+ },
+ "sign": {
+ "message": "Знак"
+ },
+ "signMessage": {
+ "message": "Нодписать сообщение"
+ },
+ "signNotice": {
+ "message": "Подписание этого сообщения может иметь \nопасные побочные эффекты. Только подписывайте сообщения \nс сайтов, которым вы полностью доверяете своим аккаунтом. Этот опасный метод будет удален в будущей версии."
+ },
+ "sigRequest": {
+ "message": "Запрос на подпись"
+ },
+ "sigRequested": {
+ "message": "Подпись Запрошена"
+ },
+ "spaceBetween": {
+ "message": "между словами может быть только пробел"
+ },
+ "status": {
+ "message": "Статус"
+ },
+ "stateLogs": {
+ "message": "Логи Статуса"
+ },
+ "stateLogsDescription": {
+ "message": "Логи статуса содержат ваши общедоступные адреса и отправленные транзакции."
+ },
+ "submit": {
+ "message": "Отправить"
+ },
+ "supportCenter": {
+ "message": "Посетите наш Центр поддержки"
+ },
+ "symbolBetweenZeroTen": {
+ "message": "Символ должен быть от 0 до 10 символов."
+ },
+ "takesTooLong": {
+ "message": "Занимает слишком долго?"
+ },
+ "terms": {
+ "message": "Условия Эксплуатации"
+ },
+ "testFaucet": {
+ "message": "Тестовый Кран"
+ },
+ "to": {
+ "message": "К"
+ },
+ "toETHviaShapeShift": {
+ "message": "$1 в ETH через ShapeShift",
+ "description": "system will fill in deposit type in start of message"
+ },
+ "tokenAddress": {
+ "message": "Адрес Токена"
+ },
+ "tokenAlreadyAdded": {
+ "message": "Токен уже добавлен."
+ },
+ "tokenBalance": {
+ "message": "Баланс Вашых Tокенов:"
+ },
+ "tokenSelection": {
+ "message": "Поиск токенов или выбор из нашего списка популярных токенов."
+ },
+ "tokenSymbol": {
+ "message": "Символ Токена"
+ },
+ "tokenWarning1": {
+ "message": "Следите за токенами, которые вы купили с помощью аккаунта MetaMask. Если вы купили токены, используя другой аккаунт, эти токены здесь не появятся."
+ },
+ "total": {
+ "message": "Всего"
+ },
+ "transactions": {
+ "message": "транзакции"
+ },
+ "transactionMemo": {
+ "message": "Транзакционная записка (необязательно)"
+ },
+ "transactionNumber": {
+ "message": "Номер Транзакции"
+ },
+ "transfers": {
+ "message": "Переводы"
+ },
+ "troubleTokenBalances": {
+ "message": "У нас были проблемы с загрузкой ваших токенов. Вы можете просмотреть их ",
+ "description": "Followed by a link (here) to view token balances"
+ },
+ "twelveWords": {
+ "message": "Эти 12 слов - единственный способ восстановить ваши учетные записи MetaMask.\nСохраните их где-нибудь в безопасности и в тайне."
+ },
+ "typePassword": {
+ "message": "Введите Пароль"
+ },
+ "uiWelcome": {
+ "message": "Добро пожаловать в новый интерфейс (бета-версия)"
+ },
+ "uiWelcomeMessage": {
+ "message": "Теперь вы используете новый интерфейс Metamask. Осмотритесь, попробуйте новые функции, такие как отправку токенов, и сообщите нам, есть ли у вас какие-либо проблемы."
+ },
+ "unavailable": {
+ "message": "Недоступен"
+ },
+ "unknown": {
+ "message": "Неизвестный"
+ },
+ "unknownNetwork": {
+ "message": "Неизвестная частная сеть"
+ },
+ "unknownNetworkId": {
+ "message": "Неизвестный идентификатор сети"
+ },
+ "uriErrorMsg": {
+ "message": "Для URI требуется соответствующий префикс HTTP / HTTPS."
+ },
+ "usaOnly": {
+ "message": "Только США",
+ "description": "Using this exchange is limited to people inside the USA"
+ },
+ "usedByClients": {
+ "message": "Используется различными клиентами"
+ },
+ "useOldUI": {
+ "message": "Использовать старый интерфейс"
+ },
+ "validFileImport": {
+ "message": "Вы должны выбрать действительный файл для импорта."
+ },
+ "vaultCreated": {
+ "message": "Создано хранилище"
+ },
+ "viewAccount": {
+ "message": "Посмотреть аккаунт"
+ },
+ "visitWebSite": {
+ "message": "Посетите наш сайт"
+ },
+ "warning": {
+ "message": "Предупреждение"
+ },
+ "welcomeBeta": {
+ "message": "Добро пожаловать в MetaMask Beta"
+ },
+ "whatsThis": {
+ "message": "Что это?"
+ },
+ "yourSigRequested": {
+ "message": "Ваша подпись запрашивается"
+ },
+ "youSign": {
+ "message": "Вы подписываете"
+ }
+}
diff --git a/app/manifest.json b/app/manifest.json
index 6fcf6cd7c..0aac1c8df 100644
--- a/app/manifest.json
+++ b/app/manifest.json
@@ -1,7 +1,7 @@
{
"name": "__MSG_appName__",
"short_name": "__MSG_appName__",
- "version": "4.2.0",
+ "version": "4.3.0",
"manifest_version": 2,
"author": "https://metamask.io",
"description": "__MSG_appDescription__",
diff --git a/app/scripts/README.md b/app/scripts/README.md
new file mode 100644
index 000000000..f5a907244
--- /dev/null
+++ b/app/scripts/README.md
@@ -0,0 +1,14 @@
+# Main MetaMask Code
+
+This folder contains the core-code.
+
+Currently, it is organized mostly based on file category, like:
+
+controllers, migrations, lib
+
+## Ongoing Task
+
+Refactor code-structure, thus the subsystems are reflected on the filesystem.
+
+### Examples
+
diff --git a/app/scripts/background.js b/app/scripts/background.js
index ef5513ec7..8bd7766ad 100644
--- a/app/scripts/background.js
+++ b/app/scripts/background.js
@@ -42,6 +42,7 @@ const isIE = !!document.documentMode
const isEdge = !isIE && !!window.StyleMedia
let popupIsOpen = false
+let notificationIsOpen = false
let openMetamaskTabsIDs = {}
// state persistence
@@ -165,6 +166,11 @@ function setupController (initState) {
}
})
}
+ if (remotePort.name === 'notification') {
+ endOfStream(portStream, () => {
+ notificationIsOpen = false
+ })
+ }
} else {
// communication with page
const originDomain = urlUtil.parse(remotePort.sender.url).hostname
@@ -207,7 +213,8 @@ function setupController (initState) {
function triggerUi () {
extension.tabs.query({ active: true }, (tabs) => {
const currentlyActiveMetamaskTab = tabs.find(tab => openMetamaskTabsIDs[tab.id])
- if (!popupIsOpen && !currentlyActiveMetamaskTab) notificationManager.showPopup()
+ if (!popupIsOpen && !currentlyActiveMetamaskTab && !notificationIsOpen) notificationManager.showPopup()
+ notificationIsOpen = true
})
}
diff --git a/app/scripts/controllers/README.md b/app/scripts/controllers/README.md
new file mode 100644
index 000000000..392c0457d
--- /dev/null
+++ b/app/scripts/controllers/README.md
@@ -0,0 +1,4 @@
+# Controllers
+
+Different controllers (in the sense of *VC *View-Controller).
+
diff --git a/app/scripts/controllers/transactions.js b/app/scripts/controllers/transactions.js
index 9c2ca0dc8..3e3909361 100644
--- a/app/scripts/controllers/transactions.js
+++ b/app/scripts/controllers/transactions.js
@@ -6,7 +6,6 @@ const EthQuery = require('ethjs-query')
const TransactionStateManager = require('../lib/tx-state-manager')
const TxGasUtil = require('../lib/tx-gas-utils')
const PendingTransactionTracker = require('../lib/pending-tx-tracker')
-const createId = require('../lib/random-id')
const NonceTracker = require('../lib/nonce-tracker')
/*
@@ -92,8 +91,8 @@ module.exports = class TransactionController extends EventEmitter {
this.pendingTxTracker.on('tx:warning', (txMeta) => {
this.txStateManager.updateTx(txMeta, 'transactions/pending-tx-tracker#event: tx:warning')
})
+ this.pendingTxTracker.on('tx:confirmed', (txId) => this._markNonceDuplicatesDropped(txId))
this.pendingTxTracker.on('tx:failed', this.txStateManager.setTxStatusFailed.bind(this.txStateManager))
- this.pendingTxTracker.on('tx:confirmed', this.txStateManager.setTxStatusConfirmed.bind(this.txStateManager))
this.pendingTxTracker.on('tx:block-update', (txMeta, latestBlockNumber) => {
if (!txMeta.firstRetryBlockNumber) {
txMeta.firstRetryBlockNumber = latestBlockNumber
@@ -186,14 +185,7 @@ module.exports = class TransactionController extends EventEmitter {
// validate
await this.txGasUtil.validateTxParams(txParams)
// construct txMeta
- const txMeta = {
- id: createId(),
- time: (new Date()).getTime(),
- status: 'unapproved',
- metamaskNetworkId: this.getNetwork(),
- txParams: txParams,
- loadingDefaults: true,
- }
+ const txMeta = this.txStateManager.generateTxMeta({txParams})
this.addTx(txMeta)
this.emit('newUnapprovedTx', txMeta)
// add default tx params
@@ -215,7 +207,6 @@ module.exports = class TransactionController extends EventEmitter {
const txParams = txMeta.txParams
// ensure value
txMeta.gasPriceSpecified = Boolean(txParams.gasPrice)
- txMeta.nonceSpecified = Boolean(txParams.nonce)
let gasPrice = txParams.gasPrice
if (!gasPrice) {
gasPrice = this.getGasPrice ? this.getGasPrice() : await this.query.gasPrice()
@@ -226,11 +217,17 @@ module.exports = class TransactionController extends EventEmitter {
return await this.txGasUtil.analyzeGasUsage(txMeta)
}
- async retryTransaction (txId) {
- this.txStateManager.setTxStatusUnapproved(txId)
- const txMeta = this.txStateManager.getTx(txId)
- txMeta.lastGasPrice = txMeta.txParams.gasPrice
- this.txStateManager.updateTx(txMeta, 'retryTransaction: manual retry')
+ async retryTransaction (originalTxId) {
+ const originalTxMeta = this.txStateManager.getTx(originalTxId)
+ const lastGasPrice = originalTxMeta.txParams.gasPrice
+ const txMeta = this.txStateManager.generateTxMeta({
+ txParams: originalTxMeta.txParams,
+ lastGasPrice,
+ loadingDefaults: false,
+ })
+ this.addTx(txMeta)
+ this.emit('newUnapprovedTx', txMeta)
+ return txMeta
}
async updateTransaction (txMeta) {
@@ -253,11 +250,9 @@ module.exports = class TransactionController extends EventEmitter {
// wait for a nonce
nonceLock = await this.nonceTracker.getNonceLock(fromAddress)
// add nonce to txParams
- const nonce = txMeta.nonceSpecified ? txMeta.txParams.nonce : nonceLock.nextNonce
- if (nonce > nonceLock.nextNonce) {
- const message = `Specified nonce may not be larger than account's next valid nonce.`
- throw new Error(message)
- }
+ // if txMeta has lastGasPrice then it is a retry at same nonce with higher
+ // gas price transaction and their for the nonce should not be calculated
+ const nonce = txMeta.lastGasPrice ? txMeta.txParams.nonce : nonceLock.nextNonce
txMeta.txParams.nonce = ethUtil.addHexPrefix(nonce.toString(16))
// add nonce debugging information to txMeta
txMeta.nonceDetails = nonceLock.nonceDetails
@@ -314,6 +309,22 @@ module.exports = class TransactionController extends EventEmitter {
// PRIVATE METHODS
//
+ _markNonceDuplicatesDropped (txId) {
+ this.txStateManager.setTxStatusConfirmed(txId)
+ // get the confirmed transactions nonce and from address
+ const txMeta = this.txStateManager.getTx(txId)
+ const { nonce, from } = txMeta.txParams
+ const sameNonceTxs = this.txStateManager.getFilteredTxList({nonce, from})
+ if (!sameNonceTxs.length) return
+ // mark all same nonce transactions as dropped and give i a replacedBy hash
+ sameNonceTxs.forEach((otherTxMeta) => {
+ if (otherTxMeta.id === txId) return
+ otherTxMeta.replacedBy = txMeta.hash
+ this.txStateManager.updateTx(txMeta, 'transactions/pending-tx-tracker#event: tx:confirmed reference to confirmed txHash with same nonce')
+ this.txStateManager.setTxStatusDropped(otherTxMeta.id)
+ })
+ }
+
_updateMemstore () {
const unapprovedTxs = this.txStateManager.getUnapprovedTxList()
const selectedAddressTxList = this.txStateManager.getFilteredTxList({
diff --git a/app/scripts/lib/notification-manager.js b/app/scripts/lib/notification-manager.js
index adaf60c65..1fcb7cf69 100644
--- a/app/scripts/lib/notification-manager.js
+++ b/app/scripts/lib/notification-manager.js
@@ -13,11 +13,12 @@ class NotificationManager {
this._getPopup((err, popup) => {
if (err) throw err
+ // Bring focus to chrome popup
if (popup) {
- // bring focus to existing popup
+ // bring focus to existing chrome popup
extension.windows.update(popup.id, { focused: true })
} else {
- // create new popup
+ // create new notification popup
extension.windows.create({
url: 'notification.html',
type: 'popup',
@@ -29,6 +30,7 @@ class NotificationManager {
}
closePopup () {
+ // closes notification popup
this._getPopup((err, popup) => {
if (err) throw err
if (!popup) return
@@ -60,9 +62,8 @@ class NotificationManager {
_getPopupIn (windows) {
return windows ? windows.find((win) => {
- return (win && win.type === 'popup' &&
- win.height === height &&
- win.width === width)
+ // Returns notification popup
+ return (win && win.type === 'popup')
}) : null
}
diff --git a/app/scripts/lib/setupRaven.js b/app/scripts/lib/setupRaven.js
index 42e48cb90..02c01b755 100644
--- a/app/scripts/lib/setupRaven.js
+++ b/app/scripts/lib/setupRaven.js
@@ -1,4 +1,4 @@
-const Raven = require('../vendor/raven.min.js')
+const Raven = require('raven-js')
const METAMASK_DEBUG = 'GULP_METAMASK_DEBUG'
const PROD = 'https://3567c198f8a8412082d32655da2961d0@sentry.io/273505'
const DEV = 'https://f59f3dd640d2429d9d0e2445a87ea8e1@sentry.io/273496'
@@ -18,9 +18,35 @@ function setupRaven(opts) {
ravenTarget = PROD
}
- Raven.config(ravenTarget, {
+ const client = Raven.config(ravenTarget, {
release,
- }).install()
+ transport: function(opts) {
+ // modify report urls
+ const report = opts.data
+ rewriteReportUrls(report)
+ // make request normally
+ client._makeRequest(opts)
+ },
+ })
+ client.install()
return Raven
}
+
+function rewriteReportUrls(report) {
+ // update request url
+ report.request.url = toMetamaskUrl(report.request.url)
+ // update exception stack trace
+ report.exception.values.forEach(item => {
+ item.stacktrace.frames.forEach(frame => {
+ frame.filename = toMetamaskUrl(frame.filename)
+ })
+ })
+}
+
+function toMetamaskUrl(origUrl) {
+ const filePath = origUrl.split(location.origin)[1]
+ if (!filePath) return origUrl
+ const metamaskUrl = `metamask${filePath}`
+ return metamaskUrl
+}
diff --git a/app/scripts/lib/tx-state-manager.js b/app/scripts/lib/tx-state-manager.js
index 2eb006380..ad07c813f 100644
--- a/app/scripts/lib/tx-state-manager.js
+++ b/app/scripts/lib/tx-state-manager.js
@@ -1,9 +1,21 @@
const extend = require('xtend')
const EventEmitter = require('events')
const ObservableStore = require('obs-store')
+const createId = require('./random-id')
const ethUtil = require('ethereumjs-util')
const txStateHistoryHelper = require('./tx-state-history-helper')
+// STATUS METHODS
+ // statuses:
+ // - `'unapproved'` the user has not responded
+ // - `'rejected'` the user has responded no!
+ // - `'approved'` the user has approved the tx
+ // - `'signed'` the tx is signed
+ // - `'submitted'` the tx is sent to a server
+ // - `'confirmed'` the tx has been included in a block.
+ // - `'failed'` the tx failed for some reason, included on tx data.
+ // - `'dropped'` the tx nonce was already used
+
module.exports = class TransactionStateManager extends EventEmitter {
constructor ({ initState, txHistoryLimit, getNetwork }) {
super()
@@ -16,6 +28,16 @@ module.exports = class TransactionStateManager extends EventEmitter {
this.getNetwork = getNetwork
}
+ generateTxMeta (opts) {
+ return extend({
+ id: createId(),
+ time: (new Date()).getTime(),
+ status: 'unapproved',
+ metamaskNetworkId: this.getNetwork(),
+ loadingDefaults: true,
+ }, opts)
+ }
+
// Returns the number of txs for the current network.
getTxCount () {
return this.getTxList().length
@@ -164,16 +186,6 @@ module.exports = class TransactionStateManager extends EventEmitter {
})
}
- // STATUS METHODS
- // statuses:
- // - `'unapproved'` the user has not responded
- // - `'rejected'` the user has responded no!
- // - `'approved'` the user has approved the tx
- // - `'signed'` the tx is signed
- // - `'submitted'` the tx is sent to a server
- // - `'confirmed'` the tx has been included in a block.
- // - `'failed'` the tx failed for some reason, included on tx data.
-
// get::set status
// should return the status of the tx.
@@ -202,7 +214,11 @@ module.exports = class TransactionStateManager extends EventEmitter {
}
// should update the status of the tx to 'submitted'.
+ // and add a time stamp for when it was called
setTxStatusSubmitted (txId) {
+ const txMeta = this.getTx(txId)
+ txMeta.submittedTime = (new Date()).getTime()
+ this.updateTx(txMeta, 'txStateManager - add submitted time stamp')
this._setTxStatus(txId, 'submitted')
}
@@ -211,6 +227,12 @@ module.exports = class TransactionStateManager extends EventEmitter {
this._setTxStatus(txId, 'confirmed')
}
+ // should update the status dropped
+ setTxStatusDropped (txId) {
+ this._setTxStatus(txId, 'dropped')
+ }
+
+
setTxStatusFailed (txId, err) {
const txMeta = this.getTx(txId)
txMeta.err = {
diff --git a/app/scripts/metamask-controller.js b/app/scripts/metamask-controller.js
index 0a5c1d36f..18d71874a 100644
--- a/app/scripts/metamask-controller.js
+++ b/app/scripts/metamask-controller.js
@@ -1,3 +1,9 @@
+/**
+ * @file The central metamask controller. Aggregates other controllers and exports an api.
+ * @copyright Copyright (c) 2018 MetaMask
+ * @license MIT
+ */
+
const EventEmitter = require('events')
const extend = require('xtend')
const pump = require('pump')
@@ -41,7 +47,11 @@ const seedPhraseVerifier = require('./lib/seed-phrase-verifier')
module.exports = class MetamaskController extends EventEmitter {
- constructor (opts) {
+ /**
+ * @constructor
+ * @param {Object} opts
+ */
+ constructor (opts) {
super()
this.defaultMaxListeners = 20
@@ -223,10 +233,9 @@ module.exports = class MetamaskController extends EventEmitter {
this.infuraController.store.subscribe(sendUpdate)
}
- //
- // Constructor helpers
- //
-
+ /**
+ * Constructor helper: initialize a provider.
+ */
initializeProvider () {
const providerOpts = {
static: {
@@ -257,6 +266,9 @@ module.exports = class MetamaskController extends EventEmitter {
return providerProxy
}
+ /**
+ * Constructor helper: initialize a public config store.
+ */
initPublicConfigStore () {
// get init state
const publicConfigStore = new ObservableStore()
@@ -278,10 +290,15 @@ module.exports = class MetamaskController extends EventEmitter {
return publicConfigStore
}
- //
- // State Management
- //
+//=============================================================================
+// EXPOSED TO THE UI SUBSYSTEM
+//=============================================================================
+ /**
+ * The metamask-state of the various controllers, made available to the UI
+ *
+ * @returns {Object} status
+ */
getState () {
const wallet = this.configManager.getWallet()
const vault = this.keyringController.store.getState().vault
@@ -316,10 +333,11 @@ module.exports = class MetamaskController extends EventEmitter {
)
}
- //
- // Remote Features
- //
-
+ /**
+ * Returns an api-object which is consumed by the UI
+ *
+ * @returns {Object}
+ */
getApi () {
const keyringController = this.keyringController
const preferencesController = this.preferencesController
@@ -400,127 +418,24 @@ module.exports = class MetamaskController extends EventEmitter {
}
}
- setupUntrustedCommunication (connectionStream, originDomain) {
- // Check if new connection is blacklisted
- if (this.blacklistController.checkForPhishing(originDomain)) {
- log.debug('MetaMask - sending phishing warning for', originDomain)
- this.sendPhishingWarning(connectionStream, originDomain)
- return
- }
-
- // setup multiplexing
- const mux = setupMultiplex(connectionStream)
- // connect features
- this.setupProviderConnection(mux.createStream('provider'), originDomain)
- this.setupPublicConfig(mux.createStream('publicConfig'))
- }
-
- setupTrustedCommunication (connectionStream, originDomain) {
- // setup multiplexing
- const mux = setupMultiplex(connectionStream)
- // connect features
- this.setupControllerConnection(mux.createStream('controller'))
- this.setupProviderConnection(mux.createStream('provider'), originDomain)
- }
-
- sendPhishingWarning (connectionStream, hostname) {
- const mux = setupMultiplex(connectionStream)
- const phishingStream = mux.createStream('phishing')
- phishingStream.write({ hostname })
- }
-
- setupControllerConnection (outStream) {
- const api = this.getApi()
- const dnode = Dnode(api)
- pump(
- outStream,
- dnode,
- outStream,
- (err) => {
- if (err) log.error(err)
- }
- )
- dnode.on('remote', (remote) => {
- // push updates to popup
- const sendUpdate = remote.sendUpdate.bind(remote)
- this.on('update', sendUpdate)
- })
- }
-
- setupProviderConnection (outStream, origin) {
- // setup json rpc engine stack
- const engine = new RpcEngine()
-
- // create filter polyfill middleware
- const filterMiddleware = createFilterMiddleware({
- provider: this.provider,
- blockTracker: this.provider._blockTracker,
- })
-
- engine.push(createOriginMiddleware({ origin }))
- engine.push(createLoggerMiddleware({ origin }))
- engine.push(filterMiddleware)
- engine.push(createProviderMiddleware({ provider: this.provider }))
-
- // setup connection
- const providerStream = createEngineStream({ engine })
- pump(
- outStream,
- providerStream,
- outStream,
- (err) => {
- // cleanup filter polyfill middleware
- filterMiddleware.destroy()
- if (err) log.error(err)
- }
- )
- }
-
- setupPublicConfig (outStream) {
- pump(
- asStream(this.publicConfigStore),
- outStream,
- (err) => {
- if (err) log.error(err)
- }
- )
- }
- privateSendUpdate () {
- this.emit('update', this.getState())
- }
- getGasPrice () {
- const { recentBlocksController } = this
- const { recentBlocks } = recentBlocksController.store.getState()
-
- // Return 1 gwei if no blocks have been observed:
- if (recentBlocks.length === 0) {
- return '0x' + GWEI_BN.toString(16)
- }
-
- const lowestPrices = recentBlocks.map((block) => {
- if (!block.gasPrices || block.gasPrices.length < 1) {
- return GWEI_BN
- }
- return block.gasPrices
- .map(hexPrefix => hexPrefix.substr(2))
- .map(hex => new BN(hex, 16))
- .sort((a, b) => {
- return a.gt(b) ? 1 : -1
- })[0]
- })
- .map(number => number.div(GWEI_BN).toNumber())
-
- const percentileNum = percentile(50, lowestPrices)
- const percentileNumBn = new BN(percentileNum)
- return '0x' + percentileNumBn.mul(GWEI_BN).toString(16)
- }
-
- //
- // Vault Management
- //
+//=============================================================================
+// VAULT / KEYRING RELATED METHODS
+//=============================================================================
+ /**
+ * Creates a new Vault(?) and create a new keychain(?)
+ *
+ * A vault is ...
+ *
+ * A keychain is ...
+ *
+ *
+ * @param {} password
+ *
+ * @returns {} vault
+ */
async createNewVaultAndKeychain (password) {
const release = await this.createVaultMutex.acquire()
let vault
@@ -544,6 +459,11 @@ module.exports = class MetamaskController extends EventEmitter {
return vault
}
+ /**
+ * Create a new Vault and restore an existent keychain
+ * @param {} password
+ * @param {} seed
+ */
async createNewVaultAndRestore (password, seed) {
const release = await this.createVaultMutex.acquire()
try {
@@ -557,16 +477,28 @@ module.exports = class MetamaskController extends EventEmitter {
}
}
+ /**
+ * Retrieves the first Identiy from the passed Vault and selects the related address
+ *
+ * An Identity is ...
+ *
+ * @param {} vault
+ */
selectFirstIdentity (vault) {
const { identities } = vault
const address = Object.keys(identities)[0]
this.preferencesController.setSelectedAddress(address)
}
- //
+ // ?
// Opinionated Keyring Management
//
+ /**
+ * Adds a new account to ...
+ *
+ * @returns {} keyState
+ */
async addNewAccount () {
const primaryKeyring = this.keyringController.getKeyringsByType('HD Key Tree')[0]
if (!primaryKeyring) {
@@ -588,10 +520,12 @@ module.exports = class MetamaskController extends EventEmitter {
return keyState
}
- // Adds the current vault's seed words to the UI's state tree.
- //
- // Used when creating a first vault, to allow confirmation.
- // Also used when revealing the seed words in the confirmation view.
+ /**
+ * Adds the current vault's seed words to the UI's state tree.
+ *
+ * Used when creating a first vault, to allow confirmation.
+ * Also used when revealing the seed words in the confirmation view.
+ */
placeSeedWords (cb) {
this.verifySeedPhrase()
@@ -604,10 +538,13 @@ module.exports = class MetamaskController extends EventEmitter {
})
}
- // Verifies the current vault's seed words if they can restore the
- // accounts belonging to the current vault.
- //
- // Called when the first account is created and on unlocking the vault.
+ /**
+ * Verifies the validity of the current vault's seed phrase.
+ *
+ * Validity: seed phrase restores the accounts belonging to the current vault.
+ *
+ * Called when the first account is created and on unlocking the vault.
+ */
async verifySeedPhrase () {
const primaryKeyring = this.keyringController.getKeyringsByType('HD Key Tree')[0]
@@ -632,22 +569,33 @@ module.exports = class MetamaskController extends EventEmitter {
}
}
- // ClearSeedWordCache
- //
- // Removes the primary account's seed words from the UI's state tree,
- // ensuring they are only ever available in the background process.
+ /**
+ * Remove the primary account seed phrase from the UI's state tree.
+ *
+ * The seed phrase remains available in the background process.
+ *
+ */
clearSeedWordCache (cb) {
this.configManager.setSeedWords(null)
cb(null, this.preferencesController.getSelectedAddress())
}
-
+
+ /**
+ * ?
+ */
resetAccount (cb) {
const selectedAddress = this.preferencesController.getSelectedAddress()
this.txController.wipeTransactions(selectedAddress)
cb(null, selectedAddress)
}
-
+ /**
+ * Imports an account ... ?
+ *
+ * @param {} strategy
+ * @param {} args
+ * @param {} cb
+ */
importAccountWithStrategy (strategy, args, cb) {
accountImporter.importAccount(strategy, args)
.then((privateKey) => {
@@ -659,11 +607,150 @@ module.exports = class MetamaskController extends EventEmitter {
.catch((reason) => { cb(reason) })
}
+ // ---------------------------------------------------------------------------
+ // Identity Management (sign)
- //
- // Identity Management
- //
- //
+ /**
+ * @param {} msgParams
+ * @param {} cb
+ */
+ signMessage (msgParams, cb) {
+ log.info('MetaMaskController - signMessage')
+ const msgId = msgParams.metamaskId
+
+ // sets the status op the message to 'approved'
+ // and removes the metamaskId for signing
+ return this.messageManager.approveMessage(msgParams)
+ .then((cleanMsgParams) => {
+ // signs the message
+ return this.keyringController.signMessage(cleanMsgParams)
+ })
+ .then((rawSig) => {
+ // tells the listener that the message has been signed
+ // and can be returned to the dapp
+ this.messageManager.setMsgStatusSigned(msgId, rawSig)
+ return this.getState()
+ })
+ }
+
+ // Prefixed Style Message Signing Methods:
+
+ /**
+ *
+ * @param {} msgParams
+ * @param {} cb
+ */
+ approvePersonalMessage (msgParams, cb) {
+ const msgId = this.personalMessageManager.addUnapprovedMessage(msgParams)
+ this.sendUpdate()
+ this.opts.showUnconfirmedMessage()
+ this.personalMessageManager.once(`${msgId}:finished`, (data) => {
+ switch (data.status) {
+ case 'signed':
+ return cb(null, data.rawSig)
+ case 'rejected':
+ return cb(new Error('MetaMask Message Signature: User denied transaction signature.'))
+ default:
+ return cb(new Error(`MetaMask Message Signature: Unknown problem: ${JSON.stringify(msgParams)}`))
+ }
+ })
+ }
+
+ /**
+ * @param {} msgParams
+ */
+ signPersonalMessage (msgParams) {
+ log.info('MetaMaskController - signPersonalMessage')
+ const msgId = msgParams.metamaskId
+ // sets the status op the message to 'approved'
+ // and removes the metamaskId for signing
+ return this.personalMessageManager.approveMessage(msgParams)
+ .then((cleanMsgParams) => {
+ // signs the message
+ return this.keyringController.signPersonalMessage(cleanMsgParams)
+ })
+ .then((rawSig) => {
+ // tells the listener that the message has been signed
+ // and can be returned to the dapp
+ this.personalMessageManager.setMsgStatusSigned(msgId, rawSig)
+ return this.getState()
+ })
+ }
+
+ /**
+ * @param {} msgParams
+ */
+ signTypedMessage (msgParams) {
+ log.info('MetaMaskController - signTypedMessage')
+ const msgId = msgParams.metamaskId
+ // sets the status op the message to 'approved'
+ // and removes the metamaskId for signing
+ return this.typedMessageManager.approveMessage(msgParams)
+ .then((cleanMsgParams) => {
+ // signs the message
+ return this.keyringController.signTypedMessage(cleanMsgParams)
+ })
+ .then((rawSig) => {
+ // tells the listener that the message has been signed
+ // and can be returned to the dapp
+ this.typedMessageManager.setMsgStatusSigned(msgId, rawSig)
+ return this.getState()
+ })
+ }
+
+ // ---------------------------------------------------------------------------
+ // Account Restauration
+
+ /**
+ * ?
+ *
+ * @param {} migratorOutput
+ */
+ restoreOldVaultAccounts (migratorOutput) {
+ const { serialized } = migratorOutput
+ return this.keyringController.restoreKeyring(serialized)
+ .then(() => migratorOutput)
+ }
+
+ /**
+ * ?
+ *
+ * @param {} migratorOutput
+ */
+ restoreOldLostAccounts (migratorOutput) {
+ const { lostAccounts } = migratorOutput
+ if (lostAccounts) {
+ this.configManager.setLostAccounts(lostAccounts.map(acct => acct.address))
+ return this.importLostAccounts(migratorOutput)
+ }
+ return Promise.resolve(migratorOutput)
+ }
+
+ /**
+ * Import (lost) Accounts
+ *
+ * @param {Object} {lostAccounts} @Array accounts <{ address, privateKey }>
+ *
+ * Uses the array's private keys to create a new Simple Key Pair keychain
+ * and add it to the keyring controller.
+ */
+ importLostAccounts ({ lostAccounts }) {
+ const privKeys = lostAccounts.map(acct => acct.privateKey)
+ return this.keyringController.restoreKeyring({
+ type: 'Simple Key Pair',
+ data: privKeys,
+ })
+ }
+
+//=============================================================================
+// END (VAULT / KEYRING RELATED METHODS)
+//=============================================================================
+
+//
+
+//=============================================================================
+// MESSAGES
+//=============================================================================
async retryTransaction (txId, cb) {
await this.txController.retryTransaction(txId)
@@ -730,85 +817,13 @@ module.exports = class MetamaskController extends EventEmitter {
})
}
- signMessage (msgParams, cb) {
- log.info('MetaMaskController - signMessage')
- const msgId = msgParams.metamaskId
-
- // sets the status op the message to 'approved'
- // and removes the metamaskId for signing
- return this.messageManager.approveMessage(msgParams)
- .then((cleanMsgParams) => {
- // signs the message
- return this.keyringController.signMessage(cleanMsgParams)
- })
- .then((rawSig) => {
- // tells the listener that the message has been signed
- // and can be returned to the dapp
- this.messageManager.setMsgStatusSigned(msgId, rawSig)
- return this.getState()
- })
- }
-
cancelMessage (msgId, cb) {
const messageManager = this.messageManager
messageManager.rejectMsg(msgId)
if (cb && typeof cb === 'function') {
cb(null, this.getState())
}
- }
-
- // Prefixed Style Message Signing Methods:
- approvePersonalMessage (msgParams, cb) {
- const msgId = this.personalMessageManager.addUnapprovedMessage(msgParams)
- this.sendUpdate()
- this.opts.showUnconfirmedMessage()
- this.personalMessageManager.once(`${msgId}:finished`, (data) => {
- switch (data.status) {
- case 'signed':
- return cb(null, data.rawSig)
- case 'rejected':
- return cb(new Error('MetaMask Message Signature: User denied transaction signature.'))
- default:
- return cb(new Error(`MetaMask Message Signature: Unknown problem: ${JSON.stringify(msgParams)}`))
- }
- })
- }
-
- signPersonalMessage (msgParams) {
- log.info('MetaMaskController - signPersonalMessage')
- const msgId = msgParams.metamaskId
- // sets the status op the message to 'approved'
- // and removes the metamaskId for signing
- return this.personalMessageManager.approveMessage(msgParams)
- .then((cleanMsgParams) => {
- // signs the message
- return this.keyringController.signPersonalMessage(cleanMsgParams)
- })
- .then((rawSig) => {
- // tells the listener that the message has been signed
- // and can be returned to the dapp
- this.personalMessageManager.setMsgStatusSigned(msgId, rawSig)
- return this.getState()
- })
- }
-
- signTypedMessage (msgParams) {
- log.info('MetaMaskController - signTypedMessage')
- const msgId = msgParams.metamaskId
- // sets the status op the message to 'approved'
- // and removes the metamaskId for signing
- return this.typedMessageManager.approveMessage(msgParams)
- .then((cleanMsgParams) => {
- // signs the message
- return this.keyringController.signTypedMessage(cleanMsgParams)
- })
- .then((rawSig) => {
- // tells the listener that the message has been signed
- // and can be returned to the dapp
- this.typedMessageManager.setMsgStatusSigned(msgId, rawSig)
- return this.getState()
- })
- }
+ }
cancelPersonalMessage (msgId, cb) {
const messageManager = this.personalMessageManager
@@ -844,36 +859,130 @@ module.exports = class MetamaskController extends EventEmitter {
cb()
}
- restoreOldVaultAccounts (migratorOutput) {
- const { serialized } = migratorOutput
- return this.keyringController.restoreKeyring(serialized)
- .then(() => migratorOutput)
- }
+//=============================================================================
+// SETUP
+//=============================================================================
- restoreOldLostAccounts (migratorOutput) {
- const { lostAccounts } = migratorOutput
- if (lostAccounts) {
- this.configManager.setLostAccounts(lostAccounts.map(acct => acct.address))
- return this.importLostAccounts(migratorOutput)
+ setupUntrustedCommunication (connectionStream, originDomain) {
+ // Check if new connection is blacklisted
+ if (this.blacklistController.checkForPhishing(originDomain)) {
+ log.debug('MetaMask - sending phishing warning for', originDomain)
+ this.sendPhishingWarning(connectionStream, originDomain)
+ return
}
- return Promise.resolve(migratorOutput)
+
+ // setup multiplexing
+ const mux = setupMultiplex(connectionStream)
+ // connect features
+ this.setupProviderConnection(mux.createStream('provider'), originDomain)
+ this.setupPublicConfig(mux.createStream('publicConfig'))
}
- // IMPORT LOST ACCOUNTS
- // @Object with key lostAccounts: @Array accounts <{ address, privateKey }>
- // Uses the array's private keys to create a new Simple Key Pair keychain
- // and add it to the keyring controller.
- importLostAccounts ({ lostAccounts }) {
- const privKeys = lostAccounts.map(acct => acct.privateKey)
- return this.keyringController.restoreKeyring({
- type: 'Simple Key Pair',
- data: privKeys,
+ setupTrustedCommunication (connectionStream, originDomain) {
+ // setup multiplexing
+ const mux = setupMultiplex(connectionStream)
+ // connect features
+ this.setupControllerConnection(mux.createStream('controller'))
+ this.setupProviderConnection(mux.createStream('provider'), originDomain)
+ }
+
+ sendPhishingWarning (connectionStream, hostname) {
+ const mux = setupMultiplex(connectionStream)
+ const phishingStream = mux.createStream('phishing')
+ phishingStream.write({ hostname })
+ }
+
+ setupControllerConnection (outStream) {
+ const api = this.getApi()
+ const dnode = Dnode(api)
+ pump(
+ outStream,
+ dnode,
+ outStream,
+ (err) => {
+ if (err) log.error(err)
+ }
+ )
+ dnode.on('remote', (remote) => {
+ // push updates to popup
+ const sendUpdate = remote.sendUpdate.bind(remote)
+ this.on('update', sendUpdate)
})
}
- //
- // config
- //
+ setupProviderConnection (outStream, origin) {
+ // setup json rpc engine stack
+ const engine = new RpcEngine()
+
+ // create filter polyfill middleware
+ const filterMiddleware = createFilterMiddleware({
+ provider: this.provider,
+ blockTracker: this.provider._blockTracker,
+ })
+
+ engine.push(createOriginMiddleware({ origin }))
+ engine.push(createLoggerMiddleware({ origin }))
+ engine.push(filterMiddleware)
+ engine.push(createProviderMiddleware({ provider: this.provider }))
+
+ // setup connection
+ const providerStream = createEngineStream({ engine })
+ pump(
+ outStream,
+ providerStream,
+ outStream,
+ (err) => {
+ // cleanup filter polyfill middleware
+ filterMiddleware.destroy()
+ if (err) log.error(err)
+ }
+ )
+ }
+
+ setupPublicConfig (outStream) {
+ pump(
+ asStream(this.publicConfigStore),
+ outStream,
+ (err) => {
+ if (err) log.error(err)
+ }
+ )
+ }
+
+ privateSendUpdate () {
+ this.emit('update', this.getState())
+ }
+
+ getGasPrice () {
+ const { recentBlocksController } = this
+ const { recentBlocks } = recentBlocksController.store.getState()
+
+ // Return 1 gwei if no blocks have been observed:
+ if (recentBlocks.length === 0) {
+ return '0x' + GWEI_BN.toString(16)
+ }
+
+ const lowestPrices = recentBlocks.map((block) => {
+ if (!block.gasPrices || block.gasPrices.length < 1) {
+ return GWEI_BN
+ }
+ return block.gasPrices
+ .map(hexPrefix => hexPrefix.substr(2))
+ .map(hex => new BN(hex, 16))
+ .sort((a, b) => {
+ return a.gt(b) ? 1 : -1
+ })[0]
+ })
+ .map(number => number.div(GWEI_BN).toNumber())
+
+ const percentileNum = percentile(50, lowestPrices)
+ const percentileNumBn = new BN(percentileNum)
+ return '0x' + percentileNumBn.mul(GWEI_BN).toString(16)
+ }
+
+//=============================================================================
+// CONFIG
+//=============================================================================
// Log blocks
diff --git a/app/scripts/migrations/README.md b/app/scripts/migrations/README.md
new file mode 100644
index 000000000..3a67b08e1
--- /dev/null
+++ b/app/scripts/migrations/README.md
@@ -0,0 +1,5 @@
+# Migrations
+
+Data (user data, config files etc.) is migrated from one version to another.
+
+Migrations are called by {} from {} during {}. \ No newline at end of file
diff --git a/app/scripts/popup.js b/app/scripts/popup.js
index 11d50ee87..e78981f06 100644
--- a/app/scripts/popup.js
+++ b/app/scripts/popup.js
@@ -65,6 +65,7 @@ startPopup({ container, connectionStream }, (err, store) => {
function closePopupIfOpen (windowType) {
if (windowType !== 'notification') {
+ // should close only chrome popup
notificationManager.closePopup()
}
}
diff --git a/app/scripts/vendor/raven.min.js b/app/scripts/vendor/raven.min.js
deleted file mode 100644
index b439aeae6..000000000
--- a/app/scripts/vendor/raven.min.js
+++ /dev/null
@@ -1,3 +0,0 @@
-/*! Raven.js 3.22.1 (7584197) | github.com/getsentry/raven-js */
-!function(a){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=a();else if("function"==typeof define&&define.amd)define([],a);else{var b;b="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,b.Raven=a()}}(function(){return function a(b,c,d){function e(g,h){if(!c[g]){if(!b[g]){var i="function"==typeof require&&require;if(!h&&i)return i(g,!0);if(f)return f(g,!0);var j=new Error("Cannot find module '"+g+"'");throw j.code="MODULE_NOT_FOUND",j}var k=c[g]={exports:{}};b[g][0].call(k.exports,function(a){var c=b[g][1][a];return e(c?c:a)},k,k.exports,a,b,c,d)}return c[g].exports}for(var f="function"==typeof require&&require,g=0;g<d.length;g++)e(d[g]);return e}({1:[function(a,b,c){function d(a){this.name="RavenConfigError",this.message=a}d.prototype=new Error,d.prototype.constructor=d,b.exports=d},{}],2:[function(a,b,c){var d=function(a,b,c){var d=a[b],e=a;if(b in a){var f="warn"===b?"warning":b;a[b]=function(){var a=[].slice.call(arguments),g=""+a.join(" "),h={level:f,logger:"console",extra:{arguments:a}};"assert"===b?a[0]===!1&&(g="Assertion failed: "+(a.slice(1).join(" ")||"console.assert"),h.extra.arguments=a.slice(1),c&&c(g,h)):c&&c(g,h),d&&Function.prototype.apply.call(d,e,a)}}};b.exports={wrapMethod:d}},{}],3:[function(a,b,c){(function(c){function d(){return+new Date}function e(a,b){return o(b)?function(c){return b(c,a)}:b}function f(){this.a=!("object"!=typeof JSON||!JSON.stringify),this.b=!n(K),this.c=!n(L),this.d=null,this.e=null,this.f=null,this.g=null,this.h=null,this.i=null,this.j={},this.k={release:J.SENTRY_RELEASE&&J.SENTRY_RELEASE.id,logger:"javascript",ignoreErrors:[],ignoreUrls:[],whitelistUrls:[],includePaths:[],headers:null,collectWindowErrors:!0,maxMessageLength:0,maxUrlLength:250,stackTraceLimit:50,autoBreadcrumbs:!0,instrument:!0,sampleRate:1},this.l={method:"POST",keepalive:!0,referrerPolicy:"origin"},this.m=0,this.n=!1,this.o=Error.stackTraceLimit,this.p=J.console||{},this.q={},this.r=[],this.s=d(),this.t=[],this.u=[],this.v=null,this.w=J.location,this.x=this.w&&this.w.href,this.y();for(var a in this.p)this.q[a]=this.p[a]}var g=a(6),h=a(7),i=a(1),j=a(5),k=j.isError,l=j.isObject,m=j.isErrorEvent,n=j.isUndefined,o=j.isFunction,p=j.isString,q=j.isArray,r=j.isEmptyObject,s=j.each,t=j.objectMerge,u=j.truncate,v=j.objectFrozen,w=j.hasKey,x=j.joinRegExp,y=j.urlencode,z=j.uuid4,A=j.htmlTreeAsString,B=j.isSameException,C=j.isSameStacktrace,D=j.parseUrl,E=j.fill,F=j.supportsFetch,G=a(2).wrapMethod,H="source protocol user pass host port path".split(" "),I=/^(?:(\w+):)?\/\/(?:(\w+)(:\w+)?@)?([\w\.-]+)(?::(\d+))?(\/.*)/,J="undefined"!=typeof window?window:"undefined"!=typeof c?c:"undefined"!=typeof self?self:{},K=J.document,L=J.navigator;f.prototype={VERSION:"3.22.1",debug:!1,TraceKit:g,config:function(a,b){var c=this;if(c.g)return this.z("error","Error: Raven has already been configured"),c;if(!a)return c;var d=c.k;b&&s(b,function(a,b){"tags"===a||"extra"===a||"user"===a?c.j[a]=b:d[a]=b}),c.setDSN(a),d.ignoreErrors.push(/^Script error\.?$/),d.ignoreErrors.push(/^Javascript error: Script error\.? on line 0$/),d.ignoreErrors=x(d.ignoreErrors),d.ignoreUrls=!!d.ignoreUrls.length&&x(d.ignoreUrls),d.whitelistUrls=!!d.whitelistUrls.length&&x(d.whitelistUrls),d.includePaths=x(d.includePaths),d.maxBreadcrumbs=Math.max(0,Math.min(d.maxBreadcrumbs||100,100));var e={xhr:!0,console:!0,dom:!0,location:!0,sentry:!0},f=d.autoBreadcrumbs;"[object Object]"==={}.toString.call(f)?f=t(e,f):f!==!1&&(f=e),d.autoBreadcrumbs=f;var h={tryCatch:!0},i=d.instrument;return"[object Object]"==={}.toString.call(i)?i=t(h,i):i!==!1&&(i=h),d.instrument=i,g.collectWindowErrors=!!d.collectWindowErrors,c},install:function(){var a=this;return a.isSetup()&&!a.n&&(g.report.subscribe(function(){a.A.apply(a,arguments)}),a.B(),a.k.instrument&&a.k.instrument.tryCatch&&a.C(),a.k.autoBreadcrumbs&&a.D(),a.E(),a.n=!0),Error.stackTraceLimit=a.k.stackTraceLimit,this},setDSN:function(a){var b=this,c=b.F(a),d=c.path.lastIndexOf("/"),e=c.path.substr(1,d);b.G=a,b.h=c.user,b.H=c.pass&&c.pass.substr(1),b.i=c.path.substr(d+1),b.g=b.I(c),b.J=b.g+"/"+e+"api/"+b.i+"/store/",this.y()},context:function(a,b,c){return o(a)&&(c=b||[],b=a,a=void 0),this.wrap(a,b).apply(this,c)},wrap:function(a,b,c){function d(){var d=[],f=arguments.length,g=!a||a&&a.deep!==!1;for(c&&o(c)&&c.apply(this,arguments);f--;)d[f]=g?e.wrap(a,arguments[f]):arguments[f];try{return b.apply(this,d)}catch(h){throw e.K(),e.captureException(h,a),h}}var e=this;if(n(b)&&!o(a))return a;if(o(a)&&(b=a,a=void 0),!o(b))return b;try{if(b.L)return b;if(b.M)return b.M}catch(f){return b}for(var g in b)w(b,g)&&(d[g]=b[g]);return d.prototype=b.prototype,b.M=d,d.L=!0,d.N=b,d},uninstall:function(){return g.report.uninstall(),this.O(),this.P(),Error.stackTraceLimit=this.o,this.n=!1,this},captureException:function(a,b){var c=!k(a),d=!m(a),e=m(a)&&!a.error;if(c&&d||e)return this.captureMessage(a,t({trimHeadFrames:1,stacktrace:!0},b));m(a)&&(a=a.error),this.d=a;try{var f=g.computeStackTrace(a);this.Q(f,b)}catch(h){if(a!==h)throw h}return this},captureMessage:function(a,b){if(!this.k.ignoreErrors.test||!this.k.ignoreErrors.test(a)){b=b||{};var c,d=t({message:a+""},b);try{throw new Error(a)}catch(e){c=e}c.name=null;var f=g.computeStackTrace(c),h=q(f.stack)&&f.stack[1],i=h&&h.url||"";if((!this.k.ignoreUrls.test||!this.k.ignoreUrls.test(i))&&(!this.k.whitelistUrls.test||this.k.whitelistUrls.test(i))){if(this.k.stacktrace||b&&b.stacktrace){b=t({fingerprint:a,trimHeadFrames:(b.trimHeadFrames||0)+1},b);var j=this.R(f,b);d.stacktrace={frames:j.reverse()}}return this.S(d),this}}},captureBreadcrumb:function(a){var b=t({timestamp:d()/1e3},a);if(o(this.k.breadcrumbCallback)){var c=this.k.breadcrumbCallback(b);if(l(c)&&!r(c))b=c;else if(c===!1)return this}return this.u.push(b),this.u.length>this.k.maxBreadcrumbs&&this.u.shift(),this},addPlugin:function(a){var b=[].slice.call(arguments,1);return this.r.push([a,b]),this.n&&this.E(),this},setUserContext:function(a){return this.j.user=a,this},setExtraContext:function(a){return this.T("extra",a),this},setTagsContext:function(a){return this.T("tags",a),this},clearContext:function(){return this.j={},this},getContext:function(){return JSON.parse(h(this.j))},setEnvironment:function(a){return this.k.environment=a,this},setRelease:function(a){return this.k.release=a,this},setDataCallback:function(a){var b=this.k.dataCallback;return this.k.dataCallback=e(b,a),this},setBreadcrumbCallback:function(a){var b=this.k.breadcrumbCallback;return this.k.breadcrumbCallback=e(b,a),this},setShouldSendCallback:function(a){var b=this.k.shouldSendCallback;return this.k.shouldSendCallback=e(b,a),this},setTransport:function(a){return this.k.transport=a,this},lastException:function(){return this.d},lastEventId:function(){return this.f},isSetup:function(){return!!this.a&&(!!this.g||(this.ravenNotConfiguredError||(this.ravenNotConfiguredError=!0,this.z("error","Error: Raven has not been configured.")),!1))},afterLoad:function(){var a=J.RavenConfig;a&&this.config(a.dsn,a.config).install()},showReportDialog:function(a){if(K){a=a||{};var b=a.eventId||this.lastEventId();if(!b)throw new i("Missing eventId");var c=a.dsn||this.G;if(!c)throw new i("Missing DSN");var d=encodeURIComponent,e="";e+="?eventId="+d(b),e+="&dsn="+d(c);var f=a.user||this.j.user;f&&(f.name&&(e+="&name="+d(f.name)),f.email&&(e+="&email="+d(f.email)));var g=this.I(this.F(c)),h=K.createElement("script");h.async=!0,h.src=g+"/api/embed/error-page/"+e,(K.head||K.body).appendChild(h)}},K:function(){var a=this;this.m+=1,setTimeout(function(){a.m-=1})},U:function(a,b){var c,d;if(this.b){b=b||{},a="raven"+a.substr(0,1).toUpperCase()+a.substr(1),K.createEvent?(c=K.createEvent("HTMLEvents"),c.initEvent(a,!0,!0)):(c=K.createEventObject(),c.eventType=a);for(d in b)w(b,d)&&(c[d]=b[d]);if(K.createEvent)K.dispatchEvent(c);else try{K.fireEvent("on"+c.eventType.toLowerCase(),c)}catch(e){}}},V:function(a){var b=this;return function(c){if(b.W=null,b.v!==c){b.v=c;var d;try{d=A(c.target)}catch(e){d="<unknown>"}b.captureBreadcrumb({category:"ui."+a,message:d})}}},X:function(){var a=this,b=1e3;return function(c){var d;try{d=c.target}catch(e){return}var f=d&&d.tagName;if(f&&("INPUT"===f||"TEXTAREA"===f||d.isContentEditable)){var g=a.W;g||a.V("input")(c),clearTimeout(g),a.W=setTimeout(function(){a.W=null},b)}}},Y:function(a,b){var c=D(this.w.href),d=D(b),e=D(a);this.x=b,c.protocol===d.protocol&&c.host===d.host&&(b=d.relative),c.protocol===e.protocol&&c.host===e.host&&(a=e.relative),this.captureBreadcrumb({category:"navigation",data:{to:b,from:a}})},B:function(){var a=this;a.Z=Function.prototype.toString,Function.prototype.toString=function(){return"function"==typeof this&&this.L?a.Z.apply(this.N,arguments):a.Z.apply(this,arguments)}},O:function(){this.Z&&(Function.prototype.toString=this.Z)},C:function(){function a(a){return function(b,d){for(var e=new Array(arguments.length),f=0;f<e.length;++f)e[f]=arguments[f];var g=e[0];return o(g)&&(e[0]=c.wrap(g)),a.apply?a.apply(this,e):a(e[0],e[1])}}function b(a){var b=J[a]&&J[a].prototype;b&&b.hasOwnProperty&&b.hasOwnProperty("addEventListener")&&(E(b,"addEventListener",function(b){return function(d,f,g,h){try{f&&f.handleEvent&&(f.handleEvent=c.wrap(f.handleEvent))}catch(i){}var j,k,l;return e&&e.dom&&("EventTarget"===a||"Node"===a)&&(k=c.V("click"),l=c.X(),j=function(a){if(a){var b;try{b=a.type}catch(c){return}return"click"===b?k(a):"keypress"===b?l(a):void 0}}),b.call(this,d,c.wrap(f,void 0,j),g,h)}},d),E(b,"removeEventListener",function(a){return function(b,c,d,e){try{c=c&&(c.M?c.M:c)}catch(f){}return a.call(this,b,c,d,e)}},d))}var c=this,d=c.t,e=this.k.autoBreadcrumbs;E(J,"setTimeout",a,d),E(J,"setInterval",a,d),J.requestAnimationFrame&&E(J,"requestAnimationFrame",function(a){return function(b){return a(c.wrap(b))}},d);for(var f=["EventTarget","Window","Node","ApplicationCache","AudioTrackList","ChannelMergerNode","CryptoOperation","EventSource","FileReader","HTMLUnknownElement","IDBDatabase","IDBRequest","IDBTransaction","KeyOperation","MediaController","MessagePort","ModalWindow","Notification","SVGElementInstance","Screen","TextTrack","TextTrackCue","TextTrackList","WebSocket","WebSocketWorker","Worker","XMLHttpRequest","XMLHttpRequestEventTarget","XMLHttpRequestUpload"],g=0;g<f.length;g++)b(f[g])},D:function(){function a(a,c){a in c&&o(c[a])&&E(c,a,function(a){return b.wrap(a)})}var b=this,c=this.k.autoBreadcrumbs,d=b.t;if(c.xhr&&"XMLHttpRequest"in J){var e=XMLHttpRequest.prototype;E(e,"open",function(a){return function(c,d){return p(d)&&d.indexOf(b.h)===-1&&(this.$={method:c,url:d,status_code:null}),a.apply(this,arguments)}},d),E(e,"send",function(c){return function(){function d(){if(e.$&&4===e.readyState){try{e.$.status_code=e.status}catch(a){}b.captureBreadcrumb({type:"http",category:"xhr",data:e.$})}}for(var e=this,f=["onload","onerror","onprogress"],g=0;g<f.length;g++)a(f[g],e);return"onreadystatechange"in e&&o(e.onreadystatechange)?E(e,"onreadystatechange",function(a){return b.wrap(a,void 0,d)}):e.onreadystatechange=d,c.apply(this,arguments)}},d)}c.xhr&&F()&&E(J,"fetch",function(a){return function(){for(var c=new Array(arguments.length),d=0;d<c.length;++d)c[d]=arguments[d];var e,f=c[0],g="GET";if("string"==typeof f?e=f:"Request"in J&&f instanceof J.Request?(e=f.url,f.method&&(g=f.method)):e=""+f,e.indexOf(b.h)!==-1)return a.apply(this,c);c[1]&&c[1].method&&(g=c[1].method);var h={method:g,url:e,status_code:null};return a.apply(this,c).then(function(a){return h.status_code=a.status,b.captureBreadcrumb({type:"http",category:"fetch",data:h}),a})}},d),c.dom&&this.b&&(K.addEventListener?(K.addEventListener("click",b.V("click"),!1),K.addEventListener("keypress",b.X(),!1)):(K.attachEvent("onclick",b.V("click")),K.attachEvent("onkeypress",b.X())));var f=J.chrome,g=f&&f.app&&f.app.runtime,h=!g&&J.history&&history.pushState&&history.replaceState;if(c.location&&h){var i=J.onpopstate;J.onpopstate=function(){var a=b.w.href;if(b.Y(b.x,a),i)return i.apply(this,arguments)};var j=function(a){return function(){var c=arguments.length>2?arguments[2]:void 0;return c&&b.Y(b.x,c+""),a.apply(this,arguments)}};E(history,"pushState",j,d),E(history,"replaceState",j,d)}if(c.console&&"console"in J&&console.log){var k=function(a,c){b.captureBreadcrumb({message:a,level:c.level,category:"console"})};s(["debug","info","warn","error","log"],function(a,b){G(console,b,k)})}},P:function(){for(var a;this.t.length;){a=this.t.shift();var b=a[0],c=a[1],d=a[2];b[c]=d}},E:function(){var a=this;s(this.r,function(b,c){var d=c[0],e=c[1];d.apply(a,[a].concat(e))})},F:function(a){var b=I.exec(a),c={},d=7;try{for(;d--;)c[H[d]]=b[d]||""}catch(e){throw new i("Invalid DSN: "+a)}if(c.pass&&!this.k.allowSecretKey)throw new i("Do not specify your secret key in the DSN. See: http://bit.ly/raven-secret-key");return c},I:function(a){var b="//"+a.host+(a.port?":"+a.port:"");return a.protocol&&(b=a.protocol+":"+b),b},A:function(){this.m||this.Q.apply(this,arguments)},Q:function(a,b){var c=this.R(a,b);this.U("handle",{stackInfo:a,options:b}),this._(a.name,a.message,a.url,a.lineno,c,b)},R:function(a,b){var c=this,d=[];if(a.stack&&a.stack.length&&(s(a.stack,function(b,e){var f=c.aa(e,a.url);f&&d.push(f)}),b&&b.trimHeadFrames))for(var e=0;e<b.trimHeadFrames&&e<d.length;e++)d[e].in_app=!1;return d=d.slice(0,this.k.stackTraceLimit)},aa:function(a,b){var c={filename:a.url,lineno:a.line,colno:a.column,"function":a.func||"?"};return a.url||(c.filename=b),c.in_app=!(this.k.includePaths.test&&!this.k.includePaths.test(c.filename)||/(Raven|TraceKit)\./.test(c["function"])||/raven\.(min\.)?js$/.test(c.filename)),c},_:function(a,b,c,d,e,f){var g=(a?a+": ":"")+(b||"");if(!this.k.ignoreErrors.test||!this.k.ignoreErrors.test(b)&&!this.k.ignoreErrors.test(g)){var h;if(e&&e.length?(c=e[0].filename||c,e.reverse(),h={frames:e}):c&&(h={frames:[{filename:c,lineno:d,in_app:!0}]}),(!this.k.ignoreUrls.test||!this.k.ignoreUrls.test(c))&&(!this.k.whitelistUrls.test||this.k.whitelistUrls.test(c))){var i=t({exception:{values:[{type:a,value:b,stacktrace:h}]},culprit:c},f);this.S(i)}}},ba:function(a){var b=this.k.maxMessageLength;if(a.message&&(a.message=u(a.message,b)),a.exception){var c=a.exception.values[0];c.value=u(c.value,b)}var d=a.request;return d&&(d.url&&(d.url=u(d.url,this.k.maxUrlLength)),d.Referer&&(d.Referer=u(d.Referer,this.k.maxUrlLength))),a.breadcrumbs&&a.breadcrumbs.values&&this.ca(a.breadcrumbs),a},ca:function(a){for(var b,c,d,e=["to","from","url"],f=0;f<a.values.length;++f)if(c=a.values[f],c.hasOwnProperty("data")&&l(c.data)&&!v(c.data)){d=t({},c.data);for(var g=0;g<e.length;++g)b=e[g],d.hasOwnProperty(b)&&d[b]&&(d[b]=u(d[b],this.k.maxUrlLength));a.values[f].data=d}},da:function(){if(this.c||this.b){var a={};return this.c&&L.userAgent&&(a.headers={"User-Agent":navigator.userAgent}),J.location&&J.location.href&&(a.url=J.location.href),this.b&&K.referrer&&(a.headers||(a.headers={}),a.headers.Referer=K.referrer),a}},y:function(){this.ea=0,this.fa=null},ga:function(){return this.ea&&d()-this.fa<this.ea},ha:function(a){var b=this.e;return!(!b||a.message!==b.message||a.culprit!==b.culprit)&&(a.stacktrace||b.stacktrace?C(a.stacktrace,b.stacktrace):!a.exception&&!b.exception||B(a.exception,b.exception))},ia:function(a){if(!this.ga()){var b=a.status;if(400===b||401===b||429===b){var c;try{c=F()?a.headers.get("Retry-After"):a.getResponseHeader("Retry-After"),c=1e3*parseInt(c,10)}catch(e){}this.ea=c?c:2*this.ea||1e3,this.fa=d()}}},S:function(a){var b=this.k,c={project:this.i,logger:b.logger,platform:"javascript"},e=this.da();if(e&&(c.request=e),a.trimHeadFrames&&delete a.trimHeadFrames,a=t(c,a),a.tags=t(t({},this.j.tags),a.tags),a.extra=t(t({},this.j.extra),a.extra),a.extra["session:duration"]=d()-this.s,this.u&&this.u.length>0&&(a.breadcrumbs={values:[].slice.call(this.u,0)}),this.j.user&&(a.user=this.j.user),b.environment&&(a.environment=b.environment),b.release&&(a.release=b.release),b.serverName&&(a.server_name=b.serverName),Object.keys(a).forEach(function(b){(null==a[b]||""===a[b]||r(a[b]))&&delete a[b]}),o(b.dataCallback)&&(a=b.dataCallback(a)||a),a&&!r(a)&&(!o(b.shouldSendCallback)||b.shouldSendCallback(a)))return this.ga()?void this.z("warn","Raven dropped error due to backoff: ",a):void("number"==typeof b.sampleRate?Math.random()<b.sampleRate&&this.ja(a):this.ja(a))},ka:function(){return z()},ja:function(a,b){var c=this,d=this.k;if(this.isSetup()){if(a=this.ba(a),!this.k.allowDuplicates&&this.ha(a))return void this.z("warn","Raven dropped repeat event: ",a);this.f=a.event_id||(a.event_id=this.ka()),this.e=a,this.z("debug","Raven about to send:",a);var e={sentry_version:"7",sentry_client:"raven-js/"+this.VERSION,sentry_key:this.h};this.H&&(e.sentry_secret=this.H);var f=a.exception&&a.exception.values[0];this.k.autoBreadcrumbs&&this.k.autoBreadcrumbs.sentry&&this.captureBreadcrumb({category:"sentry",message:f?(f.type?f.type+": ":"")+f.value:a.message,event_id:a.event_id,level:a.level||"error"});var g=this.J;(d.transport||this.la).call(this,{url:g,auth:e,data:a,options:d,onSuccess:function(){c.y(),c.U("success",{data:a,src:g}),b&&b()},onError:function(d){c.z("error","Raven transport failed to send: ",d),d.request&&c.ia(d.request),c.U("failure",{data:a,src:g}),d=d||new Error("Raven send failed (no additional details provided)"),b&&b(d)}})}},la:function(a){var b=a.url+"?"+y(a.auth),c=null,d={};if(a.options.headers&&(c=this.ma(a.options.headers)),a.options.fetchParameters&&(d=this.ma(a.options.fetchParameters)),F()){d.body=h(a.data);var e=t({},this.l),f=t(e,d);return c&&(f.headers=c),J.fetch(b,f).then(function(b){if(b.ok)a.onSuccess&&a.onSuccess();else{var c=new Error("Sentry error code: "+b.status);c.request=b,a.onError&&a.onError(c)}})["catch"](function(){a.onError&&a.onError(new Error("Sentry error code: network unavailable"))})}var g=J.XMLHttpRequest&&new J.XMLHttpRequest;if(g){var i="withCredentials"in g||"undefined"!=typeof XDomainRequest;i&&("withCredentials"in g?g.onreadystatechange=function(){if(4===g.readyState)if(200===g.status)a.onSuccess&&a.onSuccess();else if(a.onError){var b=new Error("Sentry error code: "+g.status);b.request=g,a.onError(b)}}:(g=new XDomainRequest,b=b.replace(/^https?:/,""),a.onSuccess&&(g.onload=a.onSuccess),a.onError&&(g.onerror=function(){var b=new Error("Sentry error code: XDomainRequest");b.request=g,a.onError(b)})),g.open("POST",b),c&&s(c,function(a,b){g.setRequestHeader(a,b)}),g.send(h(a.data)))}},ma:function(a){var b={};for(var c in a)if(a.hasOwnProperty(c)){var d=a[c];b[c]="function"==typeof d?d():d}return b},z:function(a){this.q[a]&&this.debug&&Function.prototype.apply.call(this.q[a],this.p,[].slice.call(arguments,1))},T:function(a,b){n(b)?delete this.j[a]:this.j[a]=t(this.j[a]||{},b)}},f.prototype.setUser=f.prototype.setUserContext,f.prototype.setReleaseContext=f.prototype.setRelease,b.exports=f}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{1:1,2:2,5:5,6:6,7:7}],4:[function(a,b,c){(function(c){var d=a(3),e="undefined"!=typeof window?window:"undefined"!=typeof c?c:"undefined"!=typeof self?self:{},f=e.Raven,g=new d;g.noConflict=function(){return e.Raven=f,g},g.afterLoad(),b.exports=g}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{3:3}],5:[function(a,b,c){(function(a){function c(a){return"object"==typeof a&&null!==a}function d(a){switch({}.toString.call(a)){case"[object Error]":return!0;case"[object Exception]":return!0;case"[object DOMException]":return!0;default:return a instanceof Error}}function e(a){return l()&&"[object ErrorEvent]"==={}.toString.call(a)}function f(a){return void 0===a}function g(a){return"function"==typeof a}function h(a){return"[object Object]"===Object.prototype.toString.call(a)}function i(a){return"[object String]"===Object.prototype.toString.call(a)}function j(a){return"[object Array]"===Object.prototype.toString.call(a)}function k(a){if(!h(a))return!1;for(var b in a)if(a.hasOwnProperty(b))return!1;return!0}function l(){try{return new ErrorEvent(""),!0}catch(a){return!1}}function m(){if(!("fetch"in E))return!1;try{return new Headers,new Request(""),new Response,!0}catch(a){return!1}}function n(a){function b(b,c){var d=a(b)||b;return c?c(d)||d:d}return b}function o(a,b){var c,d;if(f(a.length))for(c in a)s(a,c)&&b.call(null,c,a[c]);else if(d=a.length)for(c=0;c<d;c++)b.call(null,c,a[c])}function p(a,b){return b?(o(b,function(b,c){a[b]=c}),a):a}function q(a){return!!Object.isFrozen&&Object.isFrozen(a)}function r(a,b){return!b||a.length<=b?a:a.substr(0,b)+"…"}function s(a,b){return Object.prototype.hasOwnProperty.call(a,b)}function t(a){for(var b,c=[],d=0,e=a.length;d<e;d++)b=a[d],i(b)?c.push(b.replace(/([.*+?^=!:${}()|\[\]\/\\])/g,"\\$1")):b&&b.source&&c.push(b.source);return new RegExp(c.join("|"),"i")}function u(a){var b=[];return o(a,function(a,c){b.push(encodeURIComponent(a)+"="+encodeURIComponent(c))}),b.join("&")}function v(a){if("string"!=typeof a)return{};var b=a.match(/^(([^:\/?#]+):)?(\/\/([^\/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?$/),c=b[6]||"",d=b[8]||"";return{protocol:b[2],host:b[4],path:b[5],relative:b[5]+c+d}}function w(){var a=E.crypto||E.msCrypto;if(!f(a)&&a.getRandomValues){var b=new Uint16Array(8);a.getRandomValues(b),b[3]=4095&b[3]|16384,b[4]=16383&b[4]|32768;var c=function(a){for(var b=a.toString(16);b.length<4;)b="0"+b;return b};return c(b[0])+c(b[1])+c(b[2])+c(b[3])+c(b[4])+c(b[5])+c(b[6])+c(b[7])}return"xxxxxxxxxxxx4xxxyxxxxxxxxxxxxxxx".replace(/[xy]/g,function(a){var b=16*Math.random()|0,c="x"===a?b:3&b|8;return c.toString(16)})}function x(a){for(var b,c=5,d=80,e=[],f=0,g=0,h=" > ",i=h.length;a&&f++<c&&(b=y(a),!("html"===b||f>1&&g+e.length*i+b.length>=d));)e.push(b),g+=b.length,a=a.parentNode;return e.reverse().join(h)}function y(a){var b,c,d,e,f,g=[];if(!a||!a.tagName)return"";if(g.push(a.tagName.toLowerCase()),a.id&&g.push("#"+a.id),b=a.className,b&&i(b))for(c=b.split(/\s+/),f=0;f<c.length;f++)g.push("."+c[f]);var h=["type","name","title","alt"];for(f=0;f<h.length;f++)d=h[f],e=a.getAttribute(d),e&&g.push("["+d+'="'+e+'"]');return g.join("")}function z(a,b){return!!(!!a^!!b)}function A(a,b){return f(a)&&f(b)}function B(a,b){return!z(a,b)&&(a=a.values[0],b=b.values[0],a.type===b.type&&a.value===b.value&&(!A(a.stacktrace,b.stacktrace)&&C(a.stacktrace,b.stacktrace)))}function C(a,b){if(z(a,b))return!1;var c=a.frames,d=b.frames;if(c.length!==d.length)return!1;for(var e,f,g=0;g<c.length;g++)if(e=c[g],f=d[g],e.filename!==f.filename||e.lineno!==f.lineno||e.colno!==f.colno||e["function"]!==f["function"])return!1;return!0}function D(a,b,c,d){var e=a[b];a[b]=c(e),a[b].L=!0,a[b].N=e,d&&d.push([a,b,e])}var E="undefined"!=typeof window?window:"undefined"!=typeof a?a:"undefined"!=typeof self?self:{};b.exports={isObject:c,isError:d,isErrorEvent:e,isUndefined:f,isFunction:g,isPlainObject:h,isString:i,isArray:j,isEmptyObject:k,supportsErrorEvent:l,supportsFetch:m,wrappedCallback:n,each:o,objectMerge:p,truncate:r,objectFrozen:q,hasKey:s,joinRegExp:t,urlencode:u,uuid4:w,htmlTreeAsString:x,htmlElementAsString:y,isSameException:B,isSameStacktrace:C,parseUrl:v,fill:D}}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{}],6:[function(a,b,c){(function(c){function d(){return"undefined"==typeof document||null==document.location?"":document.location.href}var e=a(5),f={collectWindowErrors:!0,debug:!1},g="undefined"!=typeof window?window:"undefined"!=typeof c?c:"undefined"!=typeof self?self:{},h=[].slice,i="?",j=/^(?:[Uu]ncaught (?:exception: )?)?(?:((?:Eval|Internal|Range|Reference|Syntax|Type|URI|)Error): )?(.*)$/;f.report=function(){function a(a){m(),s.push(a)}function b(a){for(var b=s.length-1;b>=0;--b)s[b]===a&&s.splice(b,1)}function c(){n(),s=[]}function k(a,b){var c=null;if(!b||f.collectWindowErrors){for(var d in s)if(s.hasOwnProperty(d))try{s[d].apply(null,[a].concat(h.call(arguments,2)))}catch(e){c=e}if(c)throw c}}function l(a,b,c,g,h){var l=null,m=e.isErrorEvent(h)?h.error:h,n=e.isErrorEvent(a)?a.message:a;if(v)f.computeStackTrace.augmentStackTraceWithInitialElement(v,b,c,n),o();else if(m&&e.isError(m))l=f.computeStackTrace(m),k(l,!0);else{var p,r={url:b,line:c,column:g},s=void 0;if("[object String]"==={}.toString.call(n)){var p=n.match(j);p&&(s=p[1],n=p[2])}r.func=i,l={name:s,message:n,url:d(),stack:[r]},k(l,!0)}return!!q&&q.apply(this,arguments)}function m(){r||(q=g.onerror,g.onerror=l,r=!0)}function n(){r&&(g.onerror=q,r=!1,q=void 0)}function o(){var a=v,b=t;t=null,v=null,u=null,k.apply(null,[a,!1].concat(b))}function p(a,b){var c=h.call(arguments,1);if(v){if(u===a)return;o()}var d=f.computeStackTrace(a);if(v=d,u=a,t=c,setTimeout(function(){u===a&&o()},d.incomplete?2e3:0),b!==!1)throw a}var q,r,s=[],t=null,u=null,v=null;return p.subscribe=a,p.unsubscribe=b,p.uninstall=c,p}(),f.computeStackTrace=function(){function a(a){if("undefined"!=typeof a.stack&&a.stack){for(var b,c,e,f=/^\s*at (.*?) ?\(((?:file|https?|blob|chrome-extension|native|eval|webpack|<anonymous>|[a-z]:|\/).*?)(?::(\d+))?(?::(\d+))?\)?\s*$/i,g=/^\s*(.*?)(?:\((.*?)\))?(?:^|@)((?:file|https?|blob|chrome|webpack|resource|\[native).*?|[^@]*bundle)(?::(\d+))?(?::(\d+))?\s*$/i,h=/^\s*at (?:((?:\[object object\])?.+) )?\(?((?:file|ms-appx(?:-web)|https?|webpack|blob):.*?):(\d+)(?::(\d+))?\)?\s*$/i,j=/(\S+) line (\d+)(?: > eval line \d+)* > eval/i,k=/\((\S*)(?::(\d+))(?::(\d+))\)/,l=a.stack.split("\n"),m=[],n=(/^(.*) is undefined$/.exec(a.message),0),o=l.length;n<o;++n){if(c=f.exec(l[n])){var p=c[2]&&0===c[2].indexOf("native"),q=c[2]&&0===c[2].indexOf("eval");q&&(b=k.exec(c[2]))&&(c[2]=b[1],c[3]=b[2],c[4]=b[3]),e={url:p?null:c[2],func:c[1]||i,args:p?[c[2]]:[],line:c[3]?+c[3]:null,column:c[4]?+c[4]:null}}else if(c=h.exec(l[n]))e={url:c[2],func:c[1]||i,args:[],line:+c[3],column:c[4]?+c[4]:null};else{if(!(c=g.exec(l[n])))continue;var q=c[3]&&c[3].indexOf(" > eval")>-1;q&&(b=j.exec(c[3]))?(c[3]=b[1],c[4]=b[2],c[5]=null):0!==n||c[5]||"undefined"==typeof a.columnNumber||(m[0].column=a.columnNumber+1),e={url:c[3],func:c[1]||i,args:c[2]?c[2].split(","):[],line:c[4]?+c[4]:null,column:c[5]?+c[5]:null}}!e.func&&e.line&&(e.func=i),m.push(e)}return m.length?{name:a.name,message:a.message,url:d(),stack:m}:null}}function b(a,b,c,d){var e={url:b,line:c};if(e.url&&e.line){if(a.incomplete=!1,e.func||(e.func=i),a.stack.length>0&&a.stack[0].url===e.url){if(a.stack[0].line===e.line)return!1;if(!a.stack[0].line&&a.stack[0].func===e.func)return a.stack[0].line=e.line,!1}return a.stack.unshift(e),a.partial=!0,!0}return a.incomplete=!0,!1}function c(a,g){for(var h,j,k=/function\s+([_$a-zA-Z\xA0-\uFFFF][_$a-zA-Z0-9\xA0-\uFFFF]*)?\s*\(/i,l=[],m={},n=!1,o=c.caller;o&&!n;o=o.caller)if(o!==e&&o!==f.report){if(j={url:null,func:i,line:null,column:null},o.name?j.func=o.name:(h=k.exec(o.toString()))&&(j.func=h[1]),"undefined"==typeof j.func)try{j.func=h.input.substring(0,h.input.indexOf("{"))}catch(p){}m[""+o]?n=!0:m[""+o]=!0,l.push(j)}g&&l.splice(0,g);var q={name:a.name,message:a.message,url:d(),stack:l};return b(q,a.sourceURL||a.fileName,a.line||a.lineNumber,a.message||a.description),q}function e(b,e){var g=null;e=null==e?0:+e;try{if(g=a(b))return g}catch(h){if(f.debug)throw h}try{if(g=c(b,e+1))return g}catch(h){if(f.debug)throw h}return{name:b.name,message:b.message,url:d()}}return e.augmentStackTraceWithInitialElement=b,e.computeStackTraceFromStackProp=a,e}(),b.exports=f}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{5:5}],7:[function(a,b,c){function d(a,b){for(var c=0;c<a.length;++c)if(a[c]===b)return c;return-1}function e(a,b,c,d){return JSON.stringify(a,g(b,d),c)}function f(a){var b={stack:a.stack,message:a.message,name:a.name};for(var c in a)Object.prototype.hasOwnProperty.call(a,c)&&(b[c]=a[c]);return b}function g(a,b){var c=[],e=[];return null==b&&(b=function(a,b){return c[0]===b?"[Circular ~]":"[Circular ~."+e.slice(0,d(c,b)).join(".")+"]"}),function(g,h){if(c.length>0){var i=d(c,this);~i?c.splice(i+1):c.push(this),~i?e.splice(i,1/0,g):e.push(g),~d(c,h)&&(h=b.call(this,g,h))}else c.push(h);return null==a?h instanceof Error?f(h):h:a.call(this,g,h)}}c=b.exports=e,c.getSerialize=g},{}]},{},[4])(4)});
-//# sourceMappingURL=raven.min.js.map \ No newline at end of file