i18n errors, walletCreate i18n

pull/28/head
Laurin Weger 6 months ago
parent 3ad23d8a27
commit 08168a0a33
No known key found for this signature in database
GPG Key ID: 9B372BB0B792770F
  1. 2
      ng-app/src/lib/Install.svelte
  2. 2
      ng-app/src/lib/NoWallet.svelte
  3. 226
      ng-app/src/locales/en.json
  4. 23
      ng-app/src/routes/AccountInfo.svelte
  5. 4
      ng-app/src/routes/User.svelte
  6. 4
      ng-app/src/routes/UserRegistered.svelte
  7. 491
      ng-app/src/routes/WalletCreate.svelte
  8. 4
      ng-app/src/routes/WalletInfo.svelte

@ -38,7 +38,7 @@
<main class="container3" bind:this={top}> <main class="container3" bind:this={top}>
<div class="row"> <div class="row">
<a href="#/"> <a href="#/">
<Logo class="logo block h-40" alt="NextGraph Logo" /> <Logo class="logo block h-40" alt={$t("common.logo")} />
</a> </a>
</div> </div>

@ -25,7 +25,7 @@
<CenteredLayout displayFooter={true}> <CenteredLayout displayFooter={true}>
<div class="container3"> <div class="container3">
<div class="row"> <div class="row">
<Logo class="logo block h-40" alt="NextGraph Logo" /> <Logo class="logo block h-40" alt={$t("common.logo")} />
</div> </div>
<h1 class="text-2xl mb-10">{$t("pages.no_wallet.welcome")}</h1> <h1 class="text-2xl mb-10">{$t("pages.no_wallet.welcome")}</h1>

@ -9,23 +9,22 @@
}, },
"user_panel": { "user_panel": {
"title": "User Panel", "title": "User Panel",
"personal": "Personal", "personal": "Personal"
"already_registered": "The user is already registered with the selected broker.<br />Try logging in instead.",
"error": "An error occured:<br />{error}"
}, },
"user_registered": { "user_registered": {
"already_exists": "The user is already registered with the selected broker.<br />Try logging in instead.",
"error": "An error occured:<br />{error}",
"back_to_homepage": "Go Back to Homepage", "back_to_homepage": "Go Back to Homepage",
"success": "You have been successfully registered{invitation_name, select, null {} other { to {invitationName}}}." "success": "You have been successfully registered.",
"success_with_invitation": "You have been successfully registered to {invitation_name}."
}, },
"wallet": { "wallet_info": {
"title": "Wallet", "title": "Wallet",
"download": "Download Wallet File", "download": "Download Wallet File",
"download_failed": "Download Failed:<br/>{error}", "download_failed": "Download Failed:<br/>{error}",
"download_in_progress": "Download in progress...", "download_in_progress": "Download in progress...",
"download_successful": "You will find the file named \"{wallet_file}\" in your Downloads folder", "download_successful": "You will find the file named \"{wallet_file}\" in your Downloads folder",
"download_file": "Click here to download the wallet file" "download_file_button": "Click here to download the wallet file",
"remove_wallet": "Remove wallet from Device",
"remove_wallet_confirm": "Are you sure you want to remove this wallet from your device?"
}, },
"settings": { "settings": {
"title": "Settings" "title": "Settings"
@ -94,18 +93,210 @@
"select_emoji": "Select your emoji of category:<br />{category}", "select_emoji": "Select your emoji of category:<br />{category}",
"order_emojis": "Select each image in the correct order", "order_emojis": "Select each image in the correct order",
"enter_pin": "Enter your PIN code", "enter_pin": "Enter your PIN code",
"go_back": "Go Back",
"correct": "Correct",
"opening_wallet": "Opening your wallet...<br /> Please wait", "opening_wallet": "Opening your wallet...<br /> Please wait",
"error_occured": "An error occured!", "wallet_opened": "Your wallet is opened! <br />Please wait while the app is loading...",
"try_again": "Try Again", "qr_code": "Wallet QR-Code",
"wallet_opened": "Your wallet is opened! <br />Please wait while the app is loading..." "qr_modal_title": "My Wallet QR-Code",
"qr_modal_description": "Use this QR-Code to log in with your wallet on new devices.",
"copy_wallet_link": "Copy Wallet Link",
"keep_wallet": "Save to Device for Future Logins"
},
"account_info": {
"title": "Account Info",
"site": "{name} account",
"devices": "Devices",
"brokers": "Brokers",
"no_brokers_connected": "No brokers connected"
}, },
"wallet_create": {} "wallet_create": {
"pease_wait": "Please wait",
"redirecting_to_registration_page": "Redirecting to the Broker Service Provider registration page",
"complete_in_popup": "Complete the registration in the popup window",
"own_your_ngbox": "Own your NG-Box",
"self-host_broker": "Self-host a broker",
"tos_ng_one": "Terms of Service NextGraph.one",
"wallet_description": "A <b>NextGraph Wallet</b> is unique to each person. It stores your credentials and authorizations to access documents. You need one in order to start using NextGraph.<br /><br />If you already have a wallet, you should not create a new one. Instead, <a href=\"#/wallet/login\" >login here with your existing wallet.</a > If you never created a NextGraph Wallet before, please follow the instructions below in order to create your unique personal wallet.",
"has_wallet": "Some wallets are saved on this device,<br /> to log in with one of them, <a href=\"#/wallet/login\" use:link>click here.</a>",
"wallet_about": {
"title": "What is a wallet?",
"please_read": "Please read",
"1": "Your wallet is a secure and encrypted small file that contains some important information that only you should have access to.",
"2": "In your wallet, we store all the permissions to access documents you have been granted with, or that you have created yourself.",
"3": "In order to open it, you will need to enter your <b >pazzle</b > and a <b>PIN code</b> of 4 digits. Your personal pazzle (contraction of puzzle and password) is composed of 9 images you should remember. The order of the images is important too.",
"4": "Don't worry, it is easier to remember 9 images than a password like \"69$g&ms%C*%\", and it has the same strength as a complex password. The entropy of your pazzle is <b >66bits</b >, which is considered very high by all standards.",
"5": "You should only create <b>one unique wallet for yourself</b >. All your accounts, identities and permissions will be added to this unique wallet later on. Do not create another wallet if you already have one. Instead, you will <b>import</b> your existing wallet in all the apps and websites where you need it.",
"6": "Your wallet can be imported with the help of a small file that you download, or with a QRcode. In any case, you should never share this file or QRcode with anybody else.",
"7": "We at NextGraph will never see the content of your wallet. It is encrypted and we do not know your pazzle, so we cannot see what is inside.",
"8": "For the same reason, we won't be able to help you if you forget your pazzle or PIN code, or if you loose the wallet file. <span class=\"text-bold\"> There is no \"password recovery\" option</span > in this case. You can note your pazzle down on a piece of paper until you remember it, but don't forget to destroy this note after a while."
},
"create_wallet_now": "I create my wallet now!",
"select_server": "NextGraph is based on an efficient decentralized P2P network, and in order to join this network and start using the app, you need to first select a <b>broker&nbsp;server</b>.",
"broker_about": {
"title": "What is a broker?",
"please_read": "Please read",
"1": "The broker helps you keep all your data in <b>sync</b>, as it is connected to the internet 24/7 and keeps a copy of the updates for you. This way, even if the devices of the other participants are offline, you can still see their changes",
"2": "All your data is secure and <b>end-to-end encrypted</b>, and the broker cannot see the content of the documents as it does not have the keys to decrypt them.",
"3": "The broker helps you enforce your <b>privacy</b> as it hides your internet address (IP) from other users you share documents with.",
"4": "It will be possible in the future to use NextGraph without any broker and to have direct connections between peers, but this will imply a less smooth experience.",
"5": "At anytime you can decide to switch to another broker service provider or host it yourself. Your data is totally <b >portable</b > and can freely move to another broker.",
"6": "Soon we will offer you the opportunity to host your own broker at <b>home</b> or <b>office</b>. Instead of using a \"broker service provider\", you will own a small device that you connect behind your internet router. It is called <b>NG Box</b> and will be available soon.",
"7": "Organizations and companies have the opportunity to host a broker <b>on-premise</b> or in the <b>cloud</b>, as the software is open source. Individuals can also <b>self-host</b> a broker on any VPS server or at home, on their dedicated hardware."
},
"choose_broker": "Please choose one broker among the list",
"register_with_broker": "Register with {broker}",
"for_eu_citizens": "For European Union Citizens",
"for_rest": "For the rest of the world",
"enter_invite_link": "Enter an invitation link",
"scan_invite_qr": "Scan an invitation QR-code",
"self_hosted_broker": "Self-hosted broker",
"ng_box": "NG Box (owned or invited)",
"registration_success": "You have been successfully registered to {broker}",
"choose_pin": {
"title": "Let's start creating your wallet by choosing a PIN code",
"description": "We recommend you to choose a PIN code that you already know very well. <br /> Your credit card PIN, by example, is a good choice.<br />We at NextGraph will never see your PIN.",
"1": "It cannot be a series like 1234 or 8765.",
"2": "The same digit cannot repeat more than once. By example 4484 is invalid.",
"3": "Try to avoid birth date, last digits of phone number, or zip code"
},
"chosen_pin": "You have chosen:",
"confirm_pin": "Please confirm your PIN code.",
"confirm_pin_description": "Enter the same PIN again.",
"pin_confirmed_as": "You PIN is confirmed as: ",
"choose_security_phrase_and_image": {
"title": "Now let's enter a security phrase and a security image",
"description": "As a verification step, this phrase and image will be presented to you every time you are about to enter your pazzle and PIN in order to unlock your wallet.<br /> This security measure will prevent you from entering your pazzle and PIN on malicious sites and apps.",
"warning": "Every time you will use your wallet, if you do not see and recognize your own security phrase and image before entering your pazzle, please stop and DO NOT enter your pazzle, as you would be the victim of a phishing attempt.",
"rules_title": "Here aer the rules for the security phrase and image:",
"1": "The phrase should be at least 10 characters long",
"2": "It should be something you will remember, but not something too personal.",
"3": "Do not enter your full name, nor address, nor phone number.",
"4": "Instead, you can enter a quote, a small sentence that you like, or something meaningless to others, but unique to you.",
"5": "The image should be minimum 150x150px. There is no need to provide more than 400x400px as it will be scaled down anyway.",
"6": "We accept several formats like JPEG, PNG, GIF, WEBP and more.",
"7": "The image should be unique to you. But it should not be too personal neither.",
"8": "Do not upload your face picture, this is not a profile pic.",
"9": "The best would be a landscape you like or any other picture that you will recognize as unique.",
"10": "Please be aware that other people who are sharing this device with you, will be able to see this image and phrase."
},
"save_security_phrase_and_image": "Save security phrase & image",
"tap_to_upload": "Tap to upload an image",
"click_to_upload": "Click to select an image",
"or_drag_drop": "or drag and drop",
"pins_no_match": "You didn't enter the same PIN twice",
"almost_done": "We are almost done!",
"save_wallet_options": {
"description": "There are 4 options to choose before we can create your wallet. Those options can help you to use and keep your wallet. But we also want to be careful with your security and privacy.<br /><br /> Remember that in any case, once your wallet will be created, you will download a file that you should keep privately somewhere on your device, USB key or hard-disk. This is the default way you can use and keep your wallet. Now let's look at some options that can make your life a bit easier.",
"trust": "Do you trust this device?",
"trust_description": "If you do, if this device is yours or is used by few trusted persons of your family or workplace, and you would like to login again from this device in the future, then you can save your wallet on this device. To the contrary, if this device is public and shared by strangers, do not save your wallet here.",
"trust_allow_cookies": "By selecting this option, you agree to saving some cookies on your browser.",
"trust_toggle": "Save my wallet on this device?",
"cloud": "Keep a copy in the cloud?",
"cloud_description": "Are you afraid that you will loose the file containing your wallet? If this would happen, your wallet would be lost forever, together with all your documents. We can keep an encrypted copy of your wallet in our cloud. Only you will be able to download it with a special link. You would have to keep this link safely though. By selecting this option, you agree to the",
"cloud_toggle": "Save my wallet in the cloud?",
"cloud_tos": "Terms of Service of our cloud",
"pdf": "Create a PDF file of your wallet?",
"pdf_description": "We can prepare for you a PDF file containing all the information of your wallet, unencrypted. You should print this file and then delete the PDF (and empty the trash). Keep this printed document in a safe place. It contains all the information to regenerate your wallet in case you lost access to it.",
"pdf_toggle": "Create a PDF of my wallet?",
"link": "Create a link to access your wallet easily?",
"link_descriptions": "When you want to use your wallet on the web or from other devices, we can help you find your wallet by creating a simple link accessible from anywhere. Only you will have access to this link. In order to do so, we will keep your wallet ID and some information about your broker on our cloud servers. If you prefer to opt out, just uncheck this option. By selecting this option, you agree to the",
"link_toggle": "Create a link to my wallet?"
},
"lets_create": "Let's create this wallet",
"creating": "Your wallet is being created",
"ready": "Your wallet is ready!",
"download_wallet_description": "Please download your wallet and keep it in a safe location",
"download_wallet": "Download my wallet",
"download_wallet_done": "Your wallet file has been downloaded into your \"Downloads\" folder, with the name<br /><span class=\"text-black\"> {download_name}</span ><br /> <span class=\"font-bold\" >Please move it to a safe and durable place.</span ><br />",
"your_pazzle": "Here below is your Pazzle. <br /> The <span class=\"font-bold\">order</span> of each image is <span class=\"font-bold\">important</span>!",
"your_mnemonic": "And here is your mnemonic (your alternative passphrase):",
"unlock_tips_1": "You can use both the pazzle or the mnemonic to unlock your wallet. The pazzle is easier to remember. The mnemonic is useful in some special cases. We recommend that you use the pazzle. <span class=\"font-bold text-xl\" >Copy both on a piece of paper.</span > You should try to memorize the pazzle. Once you did, you won't need the paper anymore.",
"unlock_tips_2": "Now click on \"Continue to Login\" and select your new wallet.",
"unlock_tips_3": "It is important that you <span class=\"font-bold\">login</span> with this wallet <span class=\"font-bold\">at least once</span> from this {platform, select, browser {browser tab} other {device}},<br /> while connected to the internet, so your personal site can be created on your broker.",
"continue_to_login": "Continue to Login",
"continue_confirm": "Did you write down your login credentials?",
"continue_confirm_description": "The pazzle and the mnemonic <span class=\"font-bold\"> will not be shown to you again</span >. Please make sure, you have written them down.",
"continue_confirm_go_back": "Take me back",
"continue_confirm_yes": "Yes, I did"
}
}, },
"buttons": { "buttons": {
"ok": "Ok",
"go_back": "Go Back",
"back": "Back", "back": "Back",
"confirm": "Confirm" "confirm": "Confirm",
"cancel": "Cancel",
"remove": "Remove",
"correct": "Correct",
"try_again": "Try Again",
"back_to_homepage": "Go Back to Homepage",
"logout": "Logout",
"login": "Login",
"start_over": "Start over"
},
"errors": {
"an_error_occurred": "An error occurred!",
"error_occurred": "An error occurred:<br />{message}",
"AlreadyExists": "The user is already registered with the selected broker.<br />Try logging in instead.",
"InvalidSignature": "The signature is invalid.",
"IncompleteSignature": "The signature is incomplete.",
"SerializationError": "The object could not be serialized.",
"EncryptionError": "Error with encryption.",
"DecryptionError": "Error with decryption.",
"InvalidValue": "The value is invalid.",
"ConnectionNotFound": "The connection was not found.",
"InvalidKey": "The key is invalid.",
"InvalidInvitation": "The invitation is invalid.",
"InvalidCreateAccount": "An error occurred creating the account.",
"InvalidFileFormat": "The file format is invalid.",
"InvalidArgument": "The parameter is invalid.",
"PermissionDenied": "Permission denied.",
"InvalidPazzle": "The pazzle is not correct.",
"InvalidMnemonic": "The mnemonic is not correct.",
"CommitLoadError": "Error loading commit.",
"ObjectParseError": "Error parsing object.",
"StorageError": "Storage error. ",
"NotFound": "Could not find resource.",
"JsStorageKeyNotFound": "Could not find JavaScript storage key.",
"IoError": "Input/Output error.",
"CommitVerifyError": "Verifying commit failed.",
"LocalBrokerNotInitialized": "The local broker is not initialized.",
"JsStorageReadError": "Could not read from JavaScript Storage.",
"JsStorageWriteError": "Could not write to JavaScript Storage.",
"CannotSaveWhenInMemoryConfig": "Saving in Browser is not possible.",
"WalletNotFound": "The wallet was not found.",
"WalletAlreadyAdded": "The wallet is already added.",
"WalletAlreadyOpened": "The wallet is already open.",
"WalletError": "Error with wallet.",
"BrokerError": "Error with broker.",
"SessionNotFound": "The session cannot be found.",
"SessionAlreadyStarted": "The session is already started.",
"RepoNotFound": "The repository cannot be found.",
"BranchNotFound": "The branch cannot be found.",
"StoreNotFound": "The store cannot be found.",
"UserNotFound": "The user cannot be found.",
"TopicNotFound": "The topic cannot be found.",
"NotConnected": "You are not connected.",
"ActorError": "Actor error.",
"ProtocolError": "Protocol error.",
"ServerError": "Server error.",
"InvalidResponse": "Received an invalid response.",
"BootstrapError": "Error while bootstrapping",
"NotAServerError": "Not a server.",
"VerifierError": "Error during verification.",
"SiteNotFoundOnBroker": "The site cannot be found on the broker",
"BrokerConfigErrorStr": "{error}",
"BrokerConfigError": "Error in the broker configuration",
"MalformedEvent": "The event has an invalid format.",
"InvalidPayload": "The payload is invalid.",
"WrongUploadId": "The upload ID is incorrect.",
"FileError": "Error with file.",
"InternalError": "Internal Error",
"OxiGraphError": "Error in OxiGraph database.",
"ConfigError": "Error in configuration",
"LocalBrokerIsHeadless": "The local broker is headless.",
"LocalBrokerIsNotHeadless": "The local broker is not headless.",
"InvalidNuri": "Invalid NextGraph URI",
"InvalidTarget": "Cannot resolve target"
}, },
"connectivity": { "connectivity": {
"stopped": "Stopped", "stopped": "Stopped",
@ -122,10 +313,7 @@
"logo": "NextGraph Logo", "logo": "NextGraph Logo",
"support_nextgraph": "Support NextGraph", "support_nextgraph": "Support NextGraph",
"about_nextgraph": "About NextGraph", "about_nextgraph": "About NextGraph",
"back_to_homepage": "Go Back to Homepage", "donate_nextgraph": "Donate to NextGraph"
"donate_nextgraph": "Donate to NextGraph",
"logout": "Logout",
"login": "Login"
}, },
"emojis": { "emojis": {
"category": { "category": {

@ -21,7 +21,7 @@
import { ArrowLeft, ServerStack } from "svelte-heros-v2"; import { ArrowLeft, ServerStack } from "svelte-heros-v2";
import { onMount, tick } from "svelte"; import { onMount, tick } from "svelte";
import { Sidebar, SidebarGroup, SidebarWrapper } from "flowbite-svelte"; import { Sidebar, SidebarGroup, SidebarWrapper } from "flowbite-svelte";
import { t } from "svelte-i18n";
import { active_session, active_wallet, connections } from "../store"; import { active_session, active_wallet, connections } from "../store";
import { default as ng } from "../api"; import { default as ng } from "../api";
@ -175,7 +175,7 @@
<!-- Go Back--> <!-- Go Back-->
<SidebarGroup ulClass="space-y-2" role="menu"> <SidebarGroup ulClass="space-y-2" role="menu">
<li> <li>
<h2 class="text-xl mb-6">Account Info</h2> <h2 class="text-xl mb-6">{$t("pages.account_info.title")}</h2>
</li> </li>
<li <li
tabindex="0" tabindex="0"
@ -188,7 +188,7 @@
tabindex="-1" tabindex="-1"
class="w-7 h-7 text-black transition duration-75 dark:text-white group-hover:text-gray-900 dark:group-hover:text-white" class="w-7 h-7 text-black transition duration-75 dark:text-white group-hover:text-gray-900 dark:group-hover:text-white"
/> />
<span class="ml-3">Back</span> <span class="ml-3">{$t("buttons.back")}</span>
</li> </li>
</SidebarGroup> </SidebarGroup>
@ -198,7 +198,7 @@
class="flex items-center p-2 text-base font-normal text-gray-900" class="flex items-center p-2 text-base font-normal text-gray-900"
> >
<h3 class="flex items-center mt-2 text-lg font-normal"> <h3 class="flex items-center mt-2 text-lg font-normal">
{site.name} account {$t("pages.account_info.site", { values: { name: site.name } })}
</h3> </h3>
</li> </li>
@ -210,7 +210,7 @@
<h4 <h4
class="flex items-center mt-2 text-base font-normal text-gray-600" class="flex items-center mt-2 text-base font-normal text-gray-600"
> >
Devices {$t("pages.account_info.devices")}
</h4> </h4>
</li> </li>
{#each site.devices as device, index} {#each site.devices as device, index}
@ -301,7 +301,9 @@
<li <li
class="flex items-center p-2 text-base font-normal text-gray-900" class="flex items-center p-2 text-base font-normal text-gray-900"
> >
<span class="ml-3">No brokers connected</span> <span class="ml-3"
>{$t("pages.account_info.no_brokers_connected")}</span
>
</li> </li>
{/if} {/if}
</SidebarGroup> </SidebarGroup>
@ -328,8 +330,7 @@
</svg> </svg>
{#if error == "AlreadyExists"} {#if error == "AlreadyExists"}
<p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5"> <p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5">
The user is already registered with the selected broker.<br /> Try logging {@html $t("errors.AlreadyExists")}
in instead
</p> </p>
<a use:link href="/"> <a use:link href="/">
<button <button
@ -341,14 +342,16 @@
</a> </a>
{:else} {:else}
<p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5"> <p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5">
An error occurred:<br />{error} {@html $t("errors.error_occurred", {
values: { message: $t("errors." + error) },
})}
</p> </p>
<a use:link href="/"> <a use:link href="/">
<button <button
tabindex="-1" tabindex="-1"
class="text-white bg-primary-700 hover:bg-primary-700/90 focus:ring-4 focus:ring-primary-700/50 font-medium rounded-lg text-lg px-5 py-2.5 text-center inline-flex items-center dark:focus:ring-primary-700/55 mb-2" class="text-white bg-primary-700 hover:bg-primary-700/90 focus:ring-4 focus:ring-primary-700/50 font-medium rounded-lg text-lg px-5 py-2.5 text-center inline-flex items-center dark:focus:ring-primary-700/55 mb-2"
> >
Go back to homepage {$t("buttons.back_to_homepage")}
</button> </button>
</a> </a>
{/if} {/if}

@ -364,7 +364,9 @@
</a> </a>
{:else} {:else}
<p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5"> <p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5">
{@html $t("errors.error_occured", { values: { error } })} {@html $t("errors.error_occurred", {
values: { message: $t("errors." + error) },
})}
</p> </p>
<a use:link href="/"> <a use:link href="/">
<button <button

@ -78,7 +78,9 @@
</a> </a>
{:else} {:else}
<p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5"> <p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5">
{@html $t("errors.error_occured", { values: { error } })} {@html $t("errors.error_occurred", {
values: { message: $t("errors." + error) },
})}
</p> </p>
<a use:link href="/"> <a use:link href="/">
<button <button

@ -20,6 +20,7 @@
<script lang="ts"> <script lang="ts">
import { Button, Alert, Dropzone, Toggle, Modal } from "flowbite-svelte"; import { Button, Alert, Dropzone, Toggle, Modal } from "flowbite-svelte";
import { link, querystring } from "svelte-spa-router"; import { link, querystring } from "svelte-spa-router";
import { t } from "svelte-i18n";
import CenteredLayout from "../lib/CenteredLayout.svelte"; import CenteredLayout from "../lib/CenteredLayout.svelte";
import CopyToClipboard from "../lib/components/CopyToClipboard.svelte"; import CopyToClipboard from "../lib/components/CopyToClipboard.svelte";
// @ts-ignore // @ts-ignore
@ -339,7 +340,7 @@
}, },
}; };
let ca = await ng.encode_create_account(create); let ca = await ng.encode_create_account(create);
wait = "Redirecting to the Broker Service Provider registration page"; wait = $t("pages.wallet_create.redirecting_to_registration_page");
window.location.href = bsp_url + "?ca=" + ca; window.location.href = bsp_url + "?ca=" + ca;
//window.open(), "_self").focus(); //window.open(), "_self").focus();
} else { } else {
@ -348,7 +349,7 @@
redirect_url: undefined, redirect_url: undefined,
}, },
}; };
wait = "Complete the registration in the popup window"; wait = $t("pages.wallet_create.complete_in_popup");
let ca = await ng.encode_create_account(create); let ca = await ng.encode_create_account(create);
await ng.open_window( await ng.open_window(
bsp_url + "?ca=" + ca, bsp_url + "?ca=" + ca,
@ -408,15 +409,18 @@
} }
}; };
const displayNGbox = async (event) => { const displayNGbox = async (event) => {
await displayPopup(LINK_NG_BOX, "Own your NG-Box"); await displayPopup(LINK_NG_BOX, $t("pages.wallet_create.own_your_ngbox"));
}; };
const displaySelfHost = async (event) => { const displaySelfHost = async (event) => {
await displayPopup(LINK_SELF_HOST, "Self-host a broker"); await displayPopup(
LINK_SELF_HOST,
$t("pages.wallet_create.self_host_broker")
);
}; };
const tos = async () => { const tos = async () => {
await displayPopup( await displayPopup(
"https://nextgraph.one/#/tos", "https://nextgraph.one/#/tos",
"Terms of Service NextGraph.one" $t("pages.wallet_create.tos_ng_one")
); );
}; };
@ -520,7 +524,7 @@
{#if wait} {#if wait}
<div class="lg:px-8 text-primary-700"> <div class="lg:px-8 text-primary-700">
{#if wait === true} {#if wait === true}
Please wait... {$t("pages.wallet_create.please_wait")}...
{:else} {:else}
{wait} {wait}
{/if} {/if}
@ -550,7 +554,7 @@
<div class="container3" bind:this={top}> <div class="container3" bind:this={top}>
<div class="row"> <div class="row">
<a href="#/"> <a href="#/">
<Logo class="logo block h-[8em]" alt="NextGraph Logo" /> <Logo class="logo block h-[8em]" alt={$t("common.logo")} />
</a> </a>
</div> </div>
{#if registration_error} {#if registration_error}
@ -572,27 +576,28 @@
</svg> </svg>
{#if registration_error == "AlreadyExists"} {#if registration_error == "AlreadyExists"}
<p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5"> <p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5">
The user is already registered with the selected broker.<br /> Try {@html $t("pages.user_registered.already_exists")}
logging in instead
</p> </p>
<a use:link href="/wallet/login"> <a use:link href="/wallet/login">
<button <button
tabindex="-1" tabindex="-1"
class="text-white bg-primary-700 hover:bg-primary-700/90 focus:ring-4 focus:ring-primary-700/50 font-medium rounded-lg text-lg px-5 py-2.5 text-center inline-flex items-center dark:focus:ring-primary-700/55 mb-2" class="text-white bg-primary-700 hover:bg-primary-700/90 focus:ring-4 focus:ring-primary-700/50 font-medium rounded-lg text-lg px-5 py-2.5 text-center inline-flex items-center dark:focus:ring-primary-700/55 mb-2"
> >
Login {$t("buttons.login")}
</button> </button>
</a> </a>
{:else} {:else}
<p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5"> <p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5">
An error occurred during registration:<br />{registration_error} {@html $t("errors.error_occurred", {
values: { message: $t("errors." + registration_error) },
})}
</p> </p>
<a use:link href="/"> <a use:link href="/">
<button <button
tabindex="-1" tabindex="-1"
class="text-white bg-primary-700 hover:bg-primary-700/90 focus:ring-4 focus:ring-primary-700/50 font-medium rounded-lg text-lg px-5 py-2.5 text-center inline-flex items-center dark:focus:ring-primary-700/55 mb-2" class="text-white bg-primary-700 hover:bg-primary-700/90 focus:ring-4 focus:ring-primary-700/50 font-medium rounded-lg text-lg px-5 py-2.5 text-center inline-flex items-center dark:focus:ring-primary-700/55 mb-2"
> >
Go back to homepage {$t("bottons.back_to_homepage")}
</button> </button>
</a> </a>
{/if} {/if}
@ -600,22 +605,12 @@
{:else if intro} {:else if intro}
<div class=" max-w-6xl lg:px-8 mx-auto px-4"> <div class=" max-w-6xl lg:px-8 mx-auto px-4">
<p class="max-w-xl text-left md:mx-auto lg:max-w-2xl"> <p class="max-w-xl text-left md:mx-auto lg:max-w-2xl">
A <b>NextGraph Wallet</b> is unique to each person. It stores your {@html $t("pages.wallet_create.wallet_description")}
credentials and authorizations to access documents. You need one
in order to start using NextGraph.<br /><br />If you already have
a wallet, you should not create a new one. Instead,
<a href="/wallet/login" use:link
>login here with your existing wallet.</a
>
If you never created a NextGraph Wallet before, please follow the instructions
below in order to create your unique personal wallet.
</p> </p>
</div> </div>
{#if $has_wallets} {#if $has_wallets}
<Alert color="yellow" class="mt-5"> <Alert color="yellow" class="mt-5">
Some wallets are saved on this device,<br /> to log in with one of {@html $t("pages.wallet_create.has_wallet")}
them,
<a href="/wallet/login" use:link>click here.</a>
</Alert> </Alert>
{/if} {/if}
<div <div
@ -623,7 +618,10 @@
> >
<div class="max-w-xl md:mx-auto sm:text-center lg:max-w-2xl"> <div class="max-w-xl md:mx-auto sm:text-center lg:max-w-2xl">
<h2 class="pb-5 text-xl"> <h2 class="pb-5 text-xl">
What is a wallet? <span class="text-sm">Please read</span> {$t("pages.wallet_create.wallet_about.title")}<span
class="text-sm"
>{$t("pages.wallet_create.wallet_about.please_read")}</span
>
</h2> </h2>
<ul <ul
class="mb-8 space-y-4 text-left text-gray-500 dark:text-gray-400" class="mb-8 space-y-4 text-left text-gray-500 dark:text-gray-400"
@ -645,10 +643,7 @@
d="M16.5 10.5V6.75a4.5 4.5 0 10-9 0v3.75m-.75 11.25h10.5a2.25 2.25 0 002.25-2.25v-6.75a2.25 2.25 0 00-2.25-2.25H6.75a2.25 2.25 0 00-2.25 2.25v6.75a2.25 2.25 0 002.25 2.25z" d="M16.5 10.5V6.75a4.5 4.5 0 10-9 0v3.75m-.75 11.25h10.5a2.25 2.25 0 002.25-2.25v-6.75a2.25 2.25 0 00-2.25-2.25H6.75a2.25 2.25 0 00-2.25 2.25v6.75a2.25 2.25 0 002.25 2.25z"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.1")}</span>
>It is a secure and encrypted small file that contains some
important information that only you should have access to.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<!-- Icon --> <!-- Icon -->
@ -667,11 +662,7 @@
d="M15.75 5.25a3 3 0 013 3m3 0a6 6 0 01-7.029 5.912c-.563-.097-1.159.026-1.563.43L10.5 17.25H8.25v2.25H6v2.25H2.25v-2.818c0-.597.237-1.17.659-1.591l6.499-6.499c.404-.404.527-1 .43-1.563A6 6 0 1121.75 8.25z" d="M15.75 5.25a3 3 0 013 3m3 0a6 6 0 01-7.029 5.912c-.563-.097-1.159.026-1.563.43L10.5 17.25H8.25v2.25H6v2.25H2.25v-2.818c0-.597.237-1.17.659-1.591l6.499-6.499c.404-.404.527-1 .43-1.563A6 6 0 1121.75 8.25z"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.2")}</span>
>In your wallet, we store all the permissions to access
documents you have been granted with, or that you have
created yourself.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<!-- Icon --> <!-- Icon -->
@ -690,15 +681,7 @@
d="M14.25 6.087c0-.355.186-.676.401-.959.221-.29.349-.634.349-1.003 0-1.036-1.007-1.875-2.25-1.875s-2.25.84-2.25 1.875c0 .369.128.713.349 1.003.215.283.401.604.401.959v0a.64.64 0 01-.657.643 48.39 48.39 0 01-4.163-.3c.186 1.613.293 3.25.315 4.907a.656.656 0 01-.658.663v0c-.355 0-.676-.186-.959-.401a1.647 1.647 0 00-1.003-.349c-1.036 0-1.875 1.007-1.875 2.25s.84 2.25 1.875 2.25c.369 0 .713-.128 1.003-.349.283-.215.604-.401.959-.401v0c.31 0 .555.26.532.57a48.039 48.039 0 01-.642 5.056c1.518.19 3.058.309 4.616.354a.64.64 0 00.657-.643v0c0-.355-.186-.676-.401-.959a1.647 1.647 0 01-.349-1.003c0-1.035 1.008-1.875 2.25-1.875 1.243 0 2.25.84 2.25 1.875 0 .369-.128.713-.349 1.003-.215.283-.4.604-.4.959v0c0 .333.277.599.61.58a48.1 48.1 0 005.427-.63 48.05 48.05 0 00.582-4.717.532.532 0 00-.533-.57v0c-.355 0-.676.186-.959.401-.29.221-.634.349-1.003.349-1.035 0-1.875-1.007-1.875-2.25s.84-2.25 1.875-2.25c.37 0 .713.128 1.003.349.283.215.604.401.96.401v0a.656.656 0 00.658-.663 48.422 48.422 0 00-.37-5.36c-1.886.342-3.81.574-5.766.689a.578.578 0 01-.61-.58v0z" d="M14.25 6.087c0-.355.186-.676.401-.959.221-.29.349-.634.349-1.003 0-1.036-1.007-1.875-2.25-1.875s-2.25.84-2.25 1.875c0 .369.128.713.349 1.003.215.283.401.604.401.959v0a.64.64 0 01-.657.643 48.39 48.39 0 01-4.163-.3c.186 1.613.293 3.25.315 4.907a.656.656 0 01-.658.663v0c-.355 0-.676-.186-.959-.401a1.647 1.647 0 00-1.003-.349c-1.036 0-1.875 1.007-1.875 2.25s.84 2.25 1.875 2.25c.369 0 .713-.128 1.003-.349.283-.215.604-.401.959-.401v0c.31 0 .555.26.532.57a48.039 48.039 0 01-.642 5.056c1.518.19 3.058.309 4.616.354a.64.64 0 00.657-.643v0c0-.355-.186-.676-.401-.959a1.647 1.647 0 01-.349-1.003c0-1.035 1.008-1.875 2.25-1.875 1.243 0 2.25.84 2.25 1.875 0 .369-.128.713-.349 1.003-.215.283-.4.604-.4.959v0c0 .333.277.599.61.58a48.1 48.1 0 005.427-.63 48.05 48.05 0 00.582-4.717.532.532 0 00-.533-.57v0c-.355 0-.676.186-.959.401-.29.221-.634.349-1.003.349-1.035 0-1.875-1.007-1.875-2.25s.84-2.25 1.875-2.25c.37 0 .713.128 1.003.349.283.215.604.401.96.401v0a.656.656 0 00.658-.663 48.422 48.422 0 00-.37-5.36c-1.886.342-3.81.574-5.766.689a.578.578 0 01-.61-.58v0z"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.3")}</span>
>In order to open it, you will need to enter your <b
>pazzle</b
>
and a
<b>PIN code</b> of 4 digits. Your personal pazzle (contraction
of puzzle and password) is composed of 9 images you should remember.
The order of the images is important too.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<!-- Icon --> <!-- Icon -->
@ -718,13 +701,7 @@
d="M9 12.75L11.25 15 15 9.75m-3-7.036A11.959 11.959 0 013.598 6 11.99 11.99 0 003 9.749c0 5.592 3.824 10.29 9 11.623 5.176-1.332 9-6.03 9-11.622 0-1.31-.21-2.571-.598-3.751h-.152c-3.196 0-6.1-1.248-8.25-3.285z" d="M9 12.75L11.25 15 15 9.75m-3-7.036A11.959 11.959 0 013.598 6 11.99 11.99 0 003 9.749c0 5.592 3.824 10.29 9 11.623 5.176-1.332 9-6.03 9-11.622 0-1.31-.21-2.571-.598-3.751h-.152c-3.196 0-6.1-1.248-8.25-3.285z"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.4")}</span>
>Don't worry, it is easier to remember 9 images than a
password like "69$g&ms%C*%", and it has the same strength as
a complex password. The entropy of your pazzle is <b
>66bits</b
>, which is considered very high by all standards.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
@ -743,14 +720,7 @@
d="M16.5 12a4.5 4.5 0 11-9 0 4.5 4.5 0 019 0zm0 0c0 1.657 1.007 3 2.25 3S21 13.657 21 12a9 9 0 10-2.636 6.364M16.5 12V8.25" d="M16.5 12a4.5 4.5 0 11-9 0 4.5 4.5 0 019 0zm0 0c0 1.657 1.007 3 2.25 3S21 13.657 21 12a9 9 0 10-2.636 6.364M16.5 12V8.25"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.5")}</span>
>You should only create <b>one unique wallet for yourself</b
>. All your accounts, identities and permissions will be
added to this unique wallet later on. Do not create another
wallet if you already have one. Instead, you will
<b>import</b> your existing wallet in all the apps and websites
where you need it</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<!-- Icon --> <!-- Icon -->
@ -769,11 +739,7 @@
d="M15.75 9V5.25A2.25 2.25 0 0013.5 3h-6a2.25 2.25 0 00-2.25 2.25v13.5A2.25 2.25 0 007.5 21h6a2.25 2.25 0 002.25-2.25V15M12 9l-3 3m0 0l3 3m-3-3h12.75" d="M15.75 9V5.25A2.25 2.25 0 0013.5 3h-6a2.25 2.25 0 00-2.25 2.25v13.5A2.25 2.25 0 007.5 21h6a2.25 2.25 0 002.25-2.25V15M12 9l-3 3m0 0l3 3m-3-3h12.75"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.6")}</span>
>Your wallet can be imported with the help of a small file
that you download, or with a QRcode. In any case, you should
never share this file or QRcode with anybody else.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<!-- Icon --> <!-- Icon -->
@ -792,11 +758,7 @@
d="M3.98 8.223A10.477 10.477 0 001.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.45 10.45 0 0112 4.5c4.756 0 8.773 3.162 10.065 7.498a10.523 10.523 0 01-4.293 5.774M6.228 6.228L3 3m3.228 3.228l3.65 3.65m7.894 7.894L21 21m-3.228-3.228l-3.65-3.65m0 0a3 3 0 10-4.243-4.243m4.242 4.242L9.88 9.88" d="M3.98 8.223A10.477 10.477 0 001.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.45 10.45 0 0112 4.5c4.756 0 8.773 3.162 10.065 7.498a10.523 10.523 0 01-4.293 5.774M6.228 6.228L3 3m3.228 3.228l3.65 3.65m7.894 7.894L21 21m-3.228-3.228l-3.65-3.65m0 0a3 3 0 10-4.243-4.243m4.242 4.242L9.88 9.88"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.7")}</span>
>We at NextGraph will never see the content of your wallet.
It is encrypted and we do not know your pazzle, so we cannot
see what is inside.</span
>
</li> </li>
<li class="flex space-x-3 under"> <li class="flex space-x-3 under">
<!-- Icon --> <!-- Icon -->
@ -815,15 +777,7 @@
d="M12 18v-5.25m0 0a6.01 6.01 0 001.5-.189m-1.5.189a6.01 6.01 0 01-1.5-.189m3.75 7.478a12.06 12.06 0 01-4.5 0m3.75 2.383a14.406 14.406 0 01-3 0M14.25 18v-.192c0-.983.658-1.823 1.508-2.316a7.5 7.5 0 10-7.517 0c.85.493 1.509 1.333 1.509 2.316V18" d="M12 18v-5.25m0 0a6.01 6.01 0 001.5-.189m-1.5.189a6.01 6.01 0 01-1.5-.189m3.75 7.478a12.06 12.06 0 01-4.5 0m3.75 2.383a14.406 14.406 0 01-3 0M14.25 18v-.192c0-.983.658-1.823 1.508-2.316a7.5 7.5 0 10-7.517 0c.85.493 1.509 1.333 1.509 2.316V18"
/> />
</svg> </svg>
<span <span>{@html $t("pages.wallet_create.wallet_about.8")}</span>
>For the same reason, we won't be able to help you if you
forget your pazzle or PIN code, or if you loose the wallet
file. <span class="text-bold">
There is no "password recovery" option</span
> in this case. You can note your pazzle down on a piece of paper
until you remember it, but don't forget to destroy this note
after a while.</span
>
</li> </li>
</ul> </ul>
</div> </div>
@ -848,15 +802,13 @@
d="M19 7.5v3m0 0v3m0-3h3m-3 0h-3m-2.25-4.125a3.375 3.375 0 11-6.75 0 3.375 3.375 0 016.75 0zM4 19.235v-.11a6.375 6.375 0 0112.75 0v.109A12.318 12.318 0 0110.374 21c-2.331 0-4.512-.645-6.374-1.766z" d="M19 7.5v3m0 0v3m0-3h3m-3 0h-3m-2.25-4.125a3.375 3.375 0 11-6.75 0 3.375 3.375 0 016.75 0zM4 19.235v-.11a6.375 6.375 0 0112.75 0v.109A12.318 12.318 0 0110.374 21c-2.331 0-4.512-.645-6.374-1.766z"
/> />
</svg> </svg>
I create my wallet now ! {@html $t("pages.wallet_create.create_wallet_now")}
</button> </button>
</div> </div>
{:else if !invitation} {:else if !invitation}
<div class=" max-w-6xl lg:px-8 mx-auto px-4"> <div class=" max-w-6xl lg:px-8 mx-auto px-4">
<p class="max-w-xl md:mx-auto text-left lg:max-w-2xl"> <p class="max-w-xl md:mx-auto text-left lg:max-w-2xl">
NextGraph is based on an efficient decentralized P2P network, and {@html $t("pages.wallet_create.select_server")}
in order to join this network and start using the app, you need to
first select a <b>broker&nbsp;server</b>.
</p> </p>
</div> </div>
<div <div
@ -864,7 +816,12 @@
> >
<div class="max-w-xl md:mx-auto sm:text-center lg:max-w-2xl"> <div class="max-w-xl md:mx-auto sm:text-center lg:max-w-2xl">
<h2 class="pb-5 text-xl"> <h2 class="pb-5 text-xl">
What is a broker? <span class="text-sm">Please read</span> {$t("pages.wallet_create.broker_about.title")}<span
class="text-sm"
>{@html $t(
"pages.wallet_create.broker_about.please_read"
)}</span
>
</h2> </h2>
<ul <ul
class="mb-8 space-y-4 text-left text-gray-500 dark:text-gray-400" class="mb-8 space-y-4 text-left text-gray-500 dark:text-gray-400"
@ -885,12 +842,7 @@
d="M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0l3.181 3.183a8.25 8.25 0 0013.803-3.7M4.031 9.865a8.25 8.25 0 0113.803-3.7l3.181 3.182m0-4.991v4.99" d="M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0l3.181 3.183a8.25 8.25 0 0013.803-3.7M4.031 9.865a8.25 8.25 0 0113.803-3.7l3.181 3.182m0-4.991v4.99"
/> />
</svg> </svg>
<span> <span> {@html $t("pages.wallet_create.broker_about.1")}</span>
The broker helps you keep all your data in <b>sync</b>, as
it is connected to the internet 24/7 and keeps a copy of the
updates for you. This way, even if the devices of the other
participants are offline, you can still see their changes</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<svg <svg
@ -908,11 +860,7 @@
d="M15.75 5.25a3 3 0 013 3m3 0a6 6 0 01-7.029 5.912c-.563-.097-1.159.026-1.563.43L10.5 17.25H8.25v2.25H6v2.25H2.25v-2.818c0-.597.237-1.17.659-1.591l6.499-6.499c.404-.404.527-1 .43-1.563A6 6 0 1121.75 8.25z" d="M15.75 5.25a3 3 0 013 3m3 0a6 6 0 01-7.029 5.912c-.563-.097-1.159.026-1.563.43L10.5 17.25H8.25v2.25H6v2.25H2.25v-2.818c0-.597.237-1.17.659-1.591l6.499-6.499c.404-.404.527-1 .43-1.563A6 6 0 1121.75 8.25z"
/> />
</svg> </svg>
<span> <span> {@html $t("pages.wallet_create.broker_about.2")}</span>
All your data is secure and <b>end-to-end encrypted</b>, and
the broker cannot see the content of the documents as it
does not have the keys to decrypt them.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<svg <svg
@ -930,11 +878,7 @@
d="M3.98 8.223A10.477 10.477 0 001.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.45 10.45 0 0112 4.5c4.756 0 8.773 3.162 10.065 7.498a10.523 10.523 0 01-4.293 5.774M6.228 6.228L3 3m3.228 3.228l3.65 3.65m7.894 7.894L21 21m-3.228-3.228l-3.65-3.65m0 0a3 3 0 10-4.243-4.243m4.242 4.242L9.88 9.88" d="M3.98 8.223A10.477 10.477 0 001.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.45 10.45 0 0112 4.5c4.756 0 8.773 3.162 10.065 7.498a10.523 10.523 0 01-4.293 5.774M6.228 6.228L3 3m3.228 3.228l3.65 3.65m7.894 7.894L21 21m-3.228-3.228l-3.65-3.65m0 0a3 3 0 10-4.243-4.243m4.242 4.242L9.88 9.88"
/> />
</svg> </svg>
<span> <span> {@html $t("pages.wallet_create.broker_about.3")}</span>
The broker helps you enforce your <b>privacy</b> as it hides
your internet address (IP) from other users you share documents
with.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<svg <svg
@ -953,11 +897,7 @@
/> />
</svg> </svg>
<span> <span> {@html $t("pages.wallet_create.broker_about.4")}</span>
It will be possible in the future to use NextGraph without
any broker and to have direct connections between peers, but
this will imply a less smooth experience.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<svg <svg
@ -975,13 +915,7 @@
d="M7.5 21L3 16.5m0 0L7.5 12M3 16.5h13.5m0-13.5L21 7.5m0 0L16.5 12M21 7.5H7.5" d="M7.5 21L3 16.5m0 0L7.5 12M3 16.5h13.5m0-13.5L21 7.5m0 0L16.5 12M21 7.5H7.5"
/> />
</svg> </svg>
<span> <span> {@html $t("pages.wallet_create.broker_about.5")}</span>
At anytime you can decide to switch to another broker
service provider or host it yourself. Your data is totally <b
>portable</b
>
and can freely move to another broker.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<svg <svg
@ -1000,14 +934,7 @@
/> />
</svg> </svg>
<span> <span> {@html $t("pages.wallet_create.broker_about.6")}</span>
Soon we will offer you the opportunity to host your own
broker at <b>home</b>
or <b>office</b>. Instead of using a "broker service
provider", you will own a small device that you connect
behind your internet router. It is called <b>NG Box</b> and will
be available soon.</span
>
</li> </li>
<li class="flex space-x-3"> <li class="flex space-x-3">
<svg <svg
@ -1026,18 +953,11 @@
/> />
</svg> </svg>
<span> <span> {@html $t("pages.wallet_create.broker_about.7")}</span>
Organizations and companies have the opportunity to host a
broker <b>on-premise</b>
or in the <b>cloud</b>, as the software is open source.
Individuals can also
<b>self-host</b> a broker on any VPS server or at home, on their
dedicated hardware.</span
>
</li> </li>
</ul> </ul>
<h2 class="mt-3 text-xl"> <h2 class="mt-3 text-xl">
Please choose one broker among the list {$t("pages.wallet_create.choose_broker")}
</h2> </h2>
</div> </div>
</div> </div>
@ -1067,7 +987,9 @@
d="M12 21a9.004 9.004 0 008.716-6.747M12 21a9.004 9.004 0 01-8.716-6.747M12 21c2.485 0 4.5-4.03 4.5-9S14.485 3 12 3m0 18c-2.485 0-4.5-4.03-4.5-9S9.515 3 12 3m0 0a8.997 8.997 0 017.843 4.582M12 3a8.997 8.997 0 00-7.843 4.582m15.686 0A11.953 11.953 0 0112 10.5c-2.998 0-5.74-1.1-7.843-2.918m15.686 0A8.959 8.959 0 0121 12c0 .778-.099 1.533-.284 2.253m0 0A17.919 17.919 0 0112 16.5c-3.162 0-6.133-.815-8.716-2.247m0 0A9.015 9.015 0 013 12c0-1.605.42-3.113 1.157-4.418" d="M12 21a9.004 9.004 0 008.716-6.747M12 21a9.004 9.004 0 01-8.716-6.747M12 21c2.485 0 4.5-4.03 4.5-9S14.485 3 12 3m0 18c-2.485 0-4.5-4.03-4.5-9S9.515 3 12 3m0 0a8.997 8.997 0 017.843 4.582M12 3a8.997 8.997 0 00-7.843 4.582m15.686 0A11.953 11.953 0 0112 10.5c-2.998 0-5.74-1.1-7.843-2.918m15.686 0A8.959 8.959 0 0121 12c0 .778-.099 1.533-.284 2.253m0 0A17.919 17.919 0 0112 16.5c-3.162 0-6.133-.815-8.716-2.247m0 0A9.015 9.015 0 013 12c0-1.605.42-3.113 1.157-4.418"
/> />
</svg> </svg>
Register with {pre_invitation.V0.name || "this broker"} {$t("pages.wallet_create.register_with", {
values: { broker: pre_invitation.V0.name || "this broker" },
})}
</button> </button>
</div> </div>
{:else} {:else}
@ -1080,7 +1002,7 @@
class="mr-4 block h-10 w-10" class="mr-4 block h-10 w-10"
alt="European Union flag" alt="European Union flag"
/> />
For European Union citizens {$t("pages.wallet_create.for_eu_citizens")}
</button> </button>
</div> </div>
@ -1104,7 +1026,7 @@
d="M12 21a9.004 9.004 0 008.716-6.747M12 21a9.004 9.004 0 01-8.716-6.747M12 21c2.485 0 4.5-4.03 4.5-9S14.485 3 12 3m0 18c-2.485 0-4.5-4.03-4.5-9S9.515 3 12 3m0 0a8.997 8.997 0 017.843 4.582M12 3a8.997 8.997 0 00-7.843 4.582m15.686 0A11.953 11.953 0 0112 10.5c-2.998 0-5.74-1.1-7.843-2.918m15.686 0A8.959 8.959 0 0121 12c0 .778-.099 1.533-.284 2.253m0 0A17.919 17.919 0 0112 16.5c-3.162 0-6.133-.815-8.716-2.247m0 0A9.015 9.015 0 013 12c0-1.605.42-3.113 1.157-4.418" d="M12 21a9.004 9.004 0 008.716-6.747M12 21a9.004 9.004 0 01-8.716-6.747M12 21c2.485 0 4.5-4.03 4.5-9S14.485 3 12 3m0 18c-2.485 0-4.5-4.03-4.5-9S9.515 3 12 3m0 0a8.997 8.997 0 017.843 4.582M12 3a8.997 8.997 0 00-7.843 4.582m15.686 0A11.953 11.953 0 0112 10.5c-2.998 0-5.74-1.1-7.843-2.918m15.686 0A8.959 8.959 0 0121 12c0 .778-.099 1.533-.284 2.253m0 0A17.919 17.919 0 0112 16.5c-3.162 0-6.133-.815-8.716-2.247m0 0A9.015 9.015 0 013 12c0-1.605.42-3.113 1.157-4.418"
/> />
</svg> </svg>
For the rest of the world {$t("pages.wallet_create.for_rest")}
</button> </button>
</div> </div>
{/if} {/if}
@ -1132,7 +1054,7 @@
/> />
</svg> </svg>
Enter an invitation link {$t("pages.wallet_create.enter_invite_link")}
</Button> </Button>
</div> </div>
{#if false && mobile} {#if false && mobile}
@ -1161,7 +1083,7 @@
/> />
</svg> </svg>
Scan an invitation QRcode {$t("pages.wallet_create.scan_invite_qr")}
</button> </button>
</div> </div>
{/if} {/if}
@ -1185,7 +1107,7 @@
d="M5.25 14.25h13.5m-13.5 0a3 3 0 01-3-3m3 3a3 3 0 100 6h13.5a3 3 0 100-6m-16.5-3a3 3 0 013-3h13.5a3 3 0 013 3m-19.5 0a4.5 4.5 0 01.9-2.7L5.737 5.1a3.375 3.375 0 012.7-1.35h7.126c1.062 0 2.062.5 2.7 1.35l2.587 3.45a4.5 4.5 0 01.9 2.7m0 0a3 3 0 01-3 3m0 3h.008v.008h-.008v-.008zm0-6h.008v.008h-.008v-.008zm-3 6h.008v.008h-.008v-.008zm0-6h.008v.008h-.008v-.008z" d="M5.25 14.25h13.5m-13.5 0a3 3 0 01-3-3m3 3a3 3 0 100 6h13.5a3 3 0 100-6m-16.5-3a3 3 0 013-3h13.5a3 3 0 013 3m-19.5 0a4.5 4.5 0 01.9-2.7L5.737 5.1a3.375 3.375 0 012.7-1.35h7.126c1.062 0 2.062.5 2.7 1.35l2.587 3.45a4.5 4.5 0 01.9 2.7m0 0a3 3 0 01-3 3m0 3h.008v.008h-.008v-.008zm0-6h.008v.008h-.008v-.008zm-3 6h.008v.008h-.008v-.008zm0-6h.008v.008h-.008v-.008z"
/> />
</svg> </svg>
Self-hosted broker {$t("pages.wallet_create.self_hosted_broker")}
</button> </button>
</div> </div>
<div class="row mt-5 mb-12"> <div class="row mt-5 mb-12">
@ -1213,7 +1135,7 @@
width="195.79167" width="195.79167"
/> />
</svg> </svg>
NG Box (owned or invited) {$t("pages.wallet_create.ng_box")}
</button> </button>
</div> </div>
{:else if pin.length < 4} {:else if pin.length < 4}
@ -1221,38 +1143,36 @@
{#if registration_success} {#if registration_success}
<Alert color="green" class="mb-5"> <Alert color="green" class="mb-5">
<span class="font-bold text-xl" <span class="font-bold text-xl"
>You have been successfully registered to {registration_success}</span >{$t("pages.wallet_create.registration_success", {
values: { broker: registration_success },
})}</span
> >
</Alert> </Alert>
{/if} {/if}
<p class="max-w-xl md:mx-auto lg:max-w-2xl"> <p class="max-w-xl md:mx-auto lg:max-w-2xl">
<span class="text-xl" <span class="text-xl"
>Let's start creating your wallet by choosing a PIN code</span >{$t("pages.wallet_create.choose_pin.title")}</span
> >
<Alert color="yellow" class="mt-5"> <Alert color="yellow" class="mt-5">
We recommend you to choose a PIN code that you already know very {@html $t("pages.wallet_create.choose_pin.description")}
well.
<br />
Your credit card PIN, by example, is a good choice.<br />We at
NextGraph will never see your PIN.
</Alert> </Alert>
</p> </p>
<p class="text-left mt-5 px-3">Here are the rules for the PIN :</p> <p class="text-left mt-5 px-3">
{$t("pages.wallet_create.chose_pin.rules")}
</p>
<ul class="text-left list-disc list-inside px-3"> <ul class="text-left list-disc list-inside px-3">
<li>It cannot be a series like 1234 or 8765</li> <li>{@html $t("pages.wallet_create.choose_pin.1")}</li>
<li> <li>
The same digit cannot repeat more than once. By example 4484 is {@html $t("pages.wallet_create.choose_pin.2")}
invalid
</li> </li>
<li> <li>
Try to avoid birth date, last digits of phone number, or zip {@html $t("pages.wallet_create.choose_pin.3")}
code
</li> </li>
</ul> </ul>
<Alert color="blue" class="mt-5"> <Alert color="blue" class="mt-5">
You have chosen: {#each pin as digit}<span {$t("pages.wallet_create.chosen_pin")}
class="font-bold text-xl">{digit}</span {#each pin as digit}<span class="font-bold text-xl">{digit}</span
>{/each} >{/each}
</Alert> </Alert>
<div class="w-[295px] mx-auto mb-10"> <div class="w-[295px] mx-auto mb-10">
@ -1282,12 +1202,12 @@
<div class=" max-w-6xl lg:px-8 mx-auto px-3"> <div class=" max-w-6xl lg:px-8 mx-auto px-3">
<p class="max-w-xl md:mx-auto lg:max-w-2xl"> <p class="max-w-xl md:mx-auto lg:max-w-2xl">
<span class="text-red-800 text-xl" <span class="text-red-800 text-xl"
>Please confirm your PIN code.</span >{$t("pages.wallet_create.confirm_pin")}</span
> >
Enter the same PIN again {$t("pages.wallet_create.confirm_pin_description")}
</p> </p>
<Alert color="blue" class="mt-5"> <Alert color="blue" class="mt-5">
You have chosen: {#each pin_confirm as digit}<span {$t("pages.wallet_create.chosen_pin")}: {#each pin_confirm as digit}<span
class="font-bold text-xl">{digit}</span class="font-bold text-xl">{digit}</span
>{/each} >{/each}
</Alert> </Alert>
@ -1318,67 +1238,85 @@
<div class=" max-w-6xl lg:px-8 mx-auto px-4"> <div class=" max-w-6xl lg:px-8 mx-auto px-4">
{#if pin.toString() === pin_confirm.toString()} {#if pin.toString() === pin_confirm.toString()}
<Alert color="green" class="mt-5"> <Alert color="green" class="mt-5">
Your PIN is confirmed as : {#each pin_confirm as digit}<span {$t("pages.wallet_create.pin_confirmed_as")}
class="font-bold text-xl">{digit}</span {#each pin_confirm as digit}<span class="font-bold text-xl"
>{digit}</span
>{/each} >{/each}
</Alert> </Alert>
<h2 class="text-xl my-5"> <h2 class="text-xl my-5">
Now let's enter a security phrase and a security image {@html $t(
"pages.wallet_create.choose_security_phrase_and_image.title"
)}
</h2> </h2>
<p class="max-w-xl md:mx-auto lg:max-w-2xl text-left"> <p class="max-w-xl md:mx-auto lg:max-w-2xl text-left">
As a verification step, this phrase and image will be presented {@html $t(
to you every time you are about to enter your pazzle and PIN in "pages.wallet_create.choose_security_phrase_and_image.description"
order to unlock your wallet.<br /> )}
This security measure will prevent you from entering your pazzle
and PIN on malicious sites and apps.
<Alert color="red" class="mt-5"> <Alert color="red" class="mt-5">
Every time you will use your wallet, if you do not see and {@html $t(
recognize your own security phrase and image before entering "pages.wallet_create.choose_security_phrase_and_image.warning"
your pazzle, please stop and DO NOT enter your pazzle, as you )}
would be the victim of a phishing attempt.
</Alert> </Alert>
</p> </p>
<p <p
class="max-w-xl md:mx-auto lg:max-w-2xl text-left mt-5 text-sm" class="max-w-xl md:mx-auto lg:max-w-2xl text-left mt-5 text-sm"
> >
Here are the rules for the security phrase and image : {$t(
"pages.wallet_create.choose_security_phrase_and_image.rules_title"
)}
</p> </p>
<ul <ul
class="max-w-xl md:mx-auto lg:max-w-2xl text-left mt-5 text-sm list-disc list-inside" class="max-w-xl md:mx-auto lg:max-w-2xl text-left mt-5 text-sm list-disc list-inside"
> >
<li>The phrase should be at least 10 characters long</li>
<li> <li>
It should be something you will remember, but not something {@html $t(
too personal. "pages.wallet_create.choose_security_phrase_and_image.1"
)}
</li>
<li>
{@html $t(
"pages.wallet_create.choose_security_phrase_and_image.2"
)}
</li> </li>
<li> <li>
Do not enter your full name, nor address, nor phone number. {@html $t(
"pages.wallet_create.choose_security_phrase_and_image.3"
)}
</li> </li>
<li> <li>
Instead, you can enter a quote, a small sentence that you {@html $t(
like, or something meaningless to others, but unique to you. "pages.wallet_create.choose_security_phrase_and_image.4"
)}
</li> </li>
<li> <li>
The image should be minimum 150x150px. There is no need to {@html $t(
provide more than 400x400px as it will be scaled down anyway. "pages.wallet_create.choose_security_phrase_and_image.5"
)}
</li> </li>
<li> <li>
We accept several formats like JPEG, PNG, GIF, WEBP and more. {@html $t(
"pages.wallet_create.choose_security_phrase_and_image.6"
)}
</li> </li>
<li> <li>
The image should be unique to you. But it should not be too {@html $t(
personal neither. "pages.wallet_create.choose_security_phrase_and_image.7"
)}
</li> </li>
<li> <li>
Do not upload your face picture, this is not a profile pic. {@html $t(
"pages.wallet_create.choose_security_phrase_and_image.8"
)}
</li> </li>
<li> <li>
The best would be a landscape you like or any other picture {@html $t(
that you will recognize as unique. "pages.wallet_create.choose_security_phrase_and_image.9"
)}
</li> </li>
<li> <li>
Please be aware that other people who are sharing this device {@html $t(
with you, will be able to see this image and phrase. "pages.wallet_create.choose_security_phrase_and_image.10"
)}
</li> </li>
</ul> </ul>
@ -1390,7 +1328,7 @@
bind:value={security_txt} bind:value={security_txt}
on:keypress={security_phrase_ok} on:keypress={security_phrase_ok}
/><button on:click={async () => await security_phrase_ok()}> /><button on:click={async () => await security_phrase_ok()}>
Ok {$t("buttons.ok")}
</button><br /> </button><br />
{#if security_txt && security_img} {#if security_txt && security_img}
<button <button
@ -1414,7 +1352,7 @@
/> />
</svg> </svg>
Save security phrase & image {$t("pages.wallet_create.save_security_phrase_and_image")}
</button> </button>
{/if} {/if}
<Dropzone <Dropzone
@ -1430,10 +1368,13 @@
> >
<p class="mt-2 mb-5 text-gray-500 dark:text-gray-400"> <p class="mt-2 mb-5 text-gray-500 dark:text-gray-400">
{#if is_touch_device} {#if is_touch_device}
<span class="font-semibold">Tap to upload an image</span> <span class="font-semibold"
>{$t("pages.wallet_create.tap_to_upload")}</span
>
{:else} {:else}
<span class="font-semibold">Click to select an image</span> or <span class="font-semibold"
drag and drop >{$t("pages.wallet_create.click_to_upload")}</span
>{$t("pages.wallet_create.or_drag_drop")}
{/if} {/if}
</p> </p>
<svg <svg
@ -1460,7 +1401,7 @@
/> />
{:else} {:else}
<Alert color="red" class="mt-5"> <Alert color="red" class="mt-5">
You didn't enter the same PIN twice {$t("pages.wallet_create.pins_no_match")}
</Alert> </Alert>
<button <button
class="select-none" class="select-none"
@ -1469,90 +1410,100 @@
pin = []; pin = [];
}} }}
> >
Start over {$t("buttons.start_over")}
</button> </button>
{/if} {/if}
</div> </div>
{:else if !creating} {:else if !creating}
<div class=" max-w-6xl lg:px-8 mx-auto px-4" bind:this={info_options}> <div class=" max-w-6xl lg:px-8 mx-auto px-4" bind:this={info_options}>
<p class="max-w-xl mb-10 md:mx-auto lg:max-w-2xl"> <p class="max-w-xl mb-10 md:mx-auto lg:max-w-2xl">
<span class="text-xl">We are almost done !</span><br /> <span class="text-xl"
There are 4 options to choose before we can create your wallet. Those >{$t("pages.wallet_create.almost_done")}</span
options can help you to use and keep your wallet. But we also want ><br />
to be careful with your security and privacy.<br /><br /> {@html $t("pages.wallet_create.save_wallet_options.description")}
Remember that in any case, once your wallet will be created, you will
download a file that you should keep privately somewhere on your device,
USB key or hard-disk. This is the default way you can use and keep
your wallet. Now let's look at some options that can make your life
a bit easier.
</p> </p>
<p class="max-w-xl md:mx-auto lg:max-w-2xl text-left"> <p class="max-w-xl md:mx-auto lg:max-w-2xl text-left">
<span class="text-xl">Do you trust this device? </span> <br /> <span class="text-xl"
If you do, if this device is yours or is used by few trusted persons >{@html $t(
of your family or workplace, and you would like to login again from "pages.wallet_create.save_wallet_options.trust"
this device in the future, then you can save your wallet on this device. )}</span
To the contrary, if this device is public and shared by strangers, > <br />
do not save your wallet here. {#if !tauri_platform}By selecting {@html $t(
this option, you agree to save some cookies on your browser.{/if}<br "pages.wallet_create.save_wallet_options.trust_description"
/> )}
{#if !tauri_platform}{@html $t(
"pages.wallet_create.save_wallet_options.trust_allow_cookies"
)}{/if}<br />
<Toggle class="mt-3" bind:checked={options.trusted} <Toggle class="mt-3" bind:checked={options.trusted}
>Save my wallet on this device?</Toggle >{@html $t(
"pages.wallet_create.save_wallet_options.trust_toggle"
)}</Toggle
> >
</p> </p>
<p class="max-w-xl md:mx-auto mt-10 lg:max-w-2xl text-left"> <p class="max-w-xl md:mx-auto mt-10 lg:max-w-2xl text-left">
<span class="text-xl">Keep a copy in the cloud? </span> <br /> <span class="text-xl"
Are you afraid that you will loose the file containing your wallet? >{@html $t(
If this would happen, your wallet would be lost forever, together with "pages.wallet_create.save_wallet_options.cloud"
all your documents. We can keep an encrypted copy of your wallet in )}</span
our cloud. Only you will be able to download it with a special link. > <br />
You would have to keep this link safely though. By selecting this option, {@html $t(
you agree to the "pages.wallet_create.save_wallet_options.cloud_description"
)}
<span <span
style="font-weight: 500;cursor: pointer; color: #646cff;" style="font-weight: 500;cursor: pointer; color: #646cff;"
tabindex="0" tabindex="0"
role="link" role="link"
on:keypress={tos} on:keypress={tos}
on:click={tos}>Terms of Service of our cloud</span on:click={tos}
>{@html $t(
"pages.wallet_create.save_wallet_options.cloud_tos"
)}</span
>. >.
<br /> <br />
<Toggle disabled class="mt-3" bind:checked={options.cloud} <Toggle disabled class="mt-3" bind:checked={options.cloud}
>Save my wallet in the cloud?</Toggle >{@html $t(
"pages.wallet_create.save_wallet_options.cloud_toggle"
)}</Toggle
> >
</p> </p>
<p class="max-w-xl md:mx-auto mt-10 lg:max-w-2xl text-left"> <p class="max-w-xl md:mx-auto mt-10 lg:max-w-2xl text-left">
<span class="text-xl">Create a PDF file of your wallet? </span> <span class="text-xl"
>{@html $t("pages.wallet_create.save_wallet_options.pdf")}</span
>
<br /> <br />
We can prepare for you a PDF file containing all the information of {@html $t(
your wallet, unencrypted. You should print this file and then delete "pages.wallet_create.save_wallet_options.pdf_description"
the PDF (and empty the trash). Keep this printed document in a safe )}
place. It contains all the information to regenerate your wallet in
case you lost access to it.
<br /> <br />
<Toggle disabled class="mt-3" bind:checked={options.pdf} <Toggle disabled class="mt-3" bind:checked={options.pdf}
>Create a PDF of my wallet?</Toggle >{@html $t(
"pages.wallet_create.save_wallet_options.pdf_toggle"
)}</Toggle
> >
</p> </p>
{#if !options.cloud} {#if !options.cloud}
<p class="max-w-xl md:mx-auto mt-10 lg:max-w-2xl text-left"> <p class="max-w-xl md:mx-auto mt-10 lg:max-w-2xl text-left">
<span class="text-xl" <span class="text-xl"
>Create a link to access your wallet easily? >{@html $t("pages.wallet_create.save_wallet_options.link")}
</span> <br /> </span> <br />
When you want to use your wallet on the web or from other devices, {@html $t(
we can help you find your wallet by creating a simple link accessible "pages.wallet_create.save_wallet_options.link_description"
from anywhere. Only you will have access to this link. In order to )}
do so, we will keep your wallet ID and some information about your
broker on our cloud servers. If you prefer to opt out, just uncheck
this option. By selecting this option, you agree to the
<span <span
style="font-weight: 500;cursor: pointer; color: #646cff;" style="font-weight: 500;cursor: pointer; color: #646cff;"
tabindex="0" tabindex="0"
role="link" role="link"
on:keypress={tos} on:keypress={tos}
on:click={tos}>Terms of Service of our cloud</span on:click={tos}
>{@html $t(
"pages.wallet_create.save_wallet_options.cloud_tos"
)}</span
>. >.
<br /> <br />
<Toggle disabled class="mt-3" bind:checked={options.bootstrap} <Toggle disabled class="mt-3" bind:checked={options.bootstrap}
>Create a link to my wallet?</Toggle >{@html $t(
"pages.wallet_create.save_wallet_options.link_toggle"
)}</Toggle
> >
</p> </p>
{/if} {/if}
@ -1576,13 +1527,13 @@
/> />
</svg> </svg>
Let's create this wallet {$t("pages.wallet_create.lets_create")}
</button> </button>
</div> </div>
{:else if !error} {:else if !error}
{#if !ready} {#if !ready}
<div class=" max-w-6xl lg:px-8 mx-auto px-4 text-primary-700"> <div class=" max-w-6xl lg:px-8 mx-auto px-4 text-primary-700">
Your wallet is being created... {$t("pages.wallet_create.creating")}
<svg <svg
class="animate-spin mt-10 h-6 w-6 mx-auto" class="animate-spin mt-10 h-6 w-6 mx-auto"
xmlns="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg"
@ -1608,7 +1559,7 @@
{:else} {:else}
<div class="text-left mx-4"> <div class="text-left mx-4">
<div class="text-green-800 mx-auto flex flex-col items-center"> <div class="text-green-800 mx-auto flex flex-col items-center">
<div>Your wallet is ready!</div> <div>{$t("pages.wallet_create.ready")}</div>
<svg <svg
class="my-4 h-16 w-16" class="my-4 h-16 w-16"
fill="none" fill="none"
@ -1627,8 +1578,9 @@
</div> </div>
<div class="text-center"> <div class="text-center">
{#if download_link} {#if download_link}
Please download your wallet and keep it in a safe location<br {@html $t(
/> "pages.wallet_create.download_wallet_description"
)}<br />
<a <a
href={download_link} href={download_link}
target="_blank" target="_blank"
@ -1656,25 +1608,18 @@
/> />
</svg> </svg>
Download my wallet {@html $t("pages.wallet_create.download_wallet")}
</button> </button>
</a> </a>
<br /> <br />
{:else if !options.trusted} {:else if !options.trusted}
Your wallet file has been downloaded into your "Downloads" {@html $t("pages.wallet_create.download_wallet_done", {
folder, with the name<br /><span class="text-black"> values: { download_name },
{download_name}</span })}
><br />
<span class="font-bold"
>Please move it to a safe and durable place.</span
><br />
{/if} {/if}
<!-- Pazzle --> <!-- Pazzle -->
Here below is your Pazzle. {@html $t("pages.wallet_create.your_pazzle")}
<br />
The <span class="font-bold">order</span> of each image is
<span class="font-bold">important</span> !
</div> </div>
<div <div
class="mt-2 bg-white shadow-md rounded-lg max-w-2xl w-full mx-auto" class="mt-2 bg-white shadow-md rounded-lg max-w-2xl w-full mx-auto"
@ -1690,7 +1635,7 @@
</div> </div>
<div <div
class="flex justify-center w-[3em] h-[3em]" class="flex justify-center w-[3em] h-[3em]"
title={emoji.code} title={$t("emojis.codes." + emoji.code)}
> >
<svelte:component <svelte:component
this={emoji.svg?.default} this={emoji.svg?.default}
@ -1702,7 +1647,7 @@
<span>{emoji.cat}</span> <span>{emoji.cat}</span>
</div> </div>
<div class="font-bold text-lg h-full content-center"> <div class="font-bold text-lg h-full content-center">
<span>{emoji.code}</span> <span>{$t("emojis.codes." + emoji.code)}</span>
</div> </div>
</div> </div>
</div> </div>
@ -1713,32 +1658,21 @@
<!-- Mnemonic (copy button). TODO: once the component is available--> <!-- Mnemonic (copy button). TODO: once the component is available-->
<label for="mnemonic" <label for="mnemonic"
>And here is your mnemonic (your alternative passphrase):</label >{@html $t("pages.wallet_create.your_mnemonic")}</label
> >
<CopyToClipboard <CopyToClipboard
id="mnemonic" id="mnemonic"
value={ready.mnemonic_str.join(" ")} value={ready.mnemonic_str.join(" ")}
/> />
<br /> <br />
You can use both the pazzle or the mnemonic to unlock your wallet. {@html $t("pages.wallet_create.unlock_tips_1")}
The pazzle is easier to remember. The mnemonic is useful in some special
cases. We recommend that you use the pazzle.
<span class="font-bold text-xl"
>Copy both on a piece of paper.</span
>
You should try to memorize the pazzle. Once you did, you won't need
the paper anymore.
<br /><br /> <br /><br />
Now click on "Continue to Login" and select your new wallet. {@html $t("pages.wallet_create.unlock_tips_2")}
<br /> <br />
It is important that you <span class="font-bold">login</span> with {@html $t("pages.wallet_create.unlock_tips_3", {
this wallet values: { platform: tauri_platform || "browser" },
<span class="font-bold">at least once</span> })}
from this {#if tauri_platform}device{:else}browser tab{/if},<br /> <br /><br />
while connected to the internet, so your personal site can be created
on your broker.<br /><br />
<div class="flex flex-col items-center"> <div class="flex flex-col items-center">
<button <button
tabindex="-1" tabindex="-1"
@ -1760,31 +1694,30 @@
d="M15.75 6a3.75 3.75 0 11-7.5 0 3.75 3.75 0 017.5 0zM4.501 20.118a7.5 7.5 0 0114.998 0A17.933 17.933 0 0112 21.75c-2.676 0-5.216-.584-7.499-1.632z" d="M15.75 6a3.75 3.75 0 11-7.5 0 3.75 3.75 0 017.5 0zM4.501 20.118a7.5 7.5 0 0114.998 0A17.933 17.933 0 0112 21.75c-2.676 0-5.216-.584-7.499-1.632z"
/> />
</svg> </svg>
Continue to Login {$t("pages.wallet_create.continue_to_login")}
</button> </button>
</div> </div>
<Modal <Modal
autoclose autoclose
outsideclose outsideclose
bind:open={confirm_modal_open} bind:open={confirm_modal_open}
title="Did you write down your login credentials?" title={$t("pages.wallet_create.confirm")}
> >
<span class="text-lg text-neutral-950"> <span class="text-lg text-neutral-950">
The pazzle and the mnemonic <span class="font-bold"> {@html $t("pages.wallet_create.continue_confirm_description")}
will not be shown to you again</span
>. Please make sure, you have written them down.
</span> </span>
<div> <div>
<button <button
class="m-2" class="m-2"
on:click={() => (confirm_modal_open = false)} on:click={() => (confirm_modal_open = false)}
>Take me back</button >{$t(
"pages.wallet_create.continue_confirm_go_back"
)}</button
> >
<a href="/wallet/login" use:link> <a href="/wallet/login" use:link>
<button class="m-2 bg-primary-700 text-white" <button class="m-2 bg-primary-700 text-white"
>Yes, I did</button >{$t("pages.wallet_create.continue_confirm_yes")}</button
> >
<!-- todo: blue button-->
</a> </a>
</div> </div>
</Modal> </Modal>
@ -1792,7 +1725,7 @@
{/if} {/if}
{:else} {:else}
<div class=" max-w-6xl lg:px-8 mx-auto px-4 text-red-800"> <div class=" max-w-6xl lg:px-8 mx-auto px-4 text-red-800">
An error occurred ! {$t("errors.an_error_occurred")}
<svg <svg
fill="none" fill="none"
class="animate-bounce mt-10 h-10 w-10 mx-auto" class="animate-bounce mt-10 h-10 w-10 mx-auto"
@ -1809,7 +1742,7 @@
/> />
</svg> </svg>
<Alert color="red" class="mt-5"> <Alert color="red" class="mt-5">
{error} {$t("errors." + error)}
</Alert> </Alert>
<button <button
class="mt-10 select-none" class="mt-10 select-none"
@ -1822,7 +1755,7 @@
animateDownload = true; animateDownload = true;
}} }}
> >
Start over {$t("buttons.start_over")}
</button> </button>
</div> </div>
{/if} {/if}

@ -336,7 +336,9 @@
</a> </a>
{:else} {:else}
<p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5"> <p class="max-w-xl md:mx-auto lg:max-w-2xl mb-5">
{@html $t("errors.error_occurred", { values: { error } })} {@html $t("errors.error_occurred", {
values: { message: $t("errors." + error) },
})}
</p> </p>
<a use:link href="/"> <a use:link href="/">
<button <button

Loading…
Cancel
Save