formatting
This commit is contained in:
		@@ -1,16 +1,14 @@
 | 
				
			|||||||
<!DOCTYPE html>
 | 
					<!DOCTYPE html>
 | 
				
			||||||
<html lang="en">
 | 
					<html lang="en">
 | 
				
			||||||
 | 
					  <head>
 | 
				
			||||||
 | 
					    <meta charset="UTF-8" />
 | 
				
			||||||
 | 
					    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
 | 
				
			||||||
 | 
					    <title>LfK!Scan</title>
 | 
				
			||||||
 | 
					    <base href="./" />
 | 
				
			||||||
 | 
					    <link rel="icon" type="image/png" href="./favicon.png" />
 | 
				
			||||||
 | 
					  </head>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<head>
 | 
					  <body class="bg-white font-family-karla h-screen">
 | 
				
			||||||
  <meta charset="UTF-8" />
 | 
					    <script type="module" src="./src/main.js"></script>
 | 
				
			||||||
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
 | 
					  </body>
 | 
				
			||||||
  <title>LfK!Scan</title>
 | 
					</html>
 | 
				
			||||||
  <base href="./">
 | 
					 | 
				
			||||||
  <link rel="icon" type="image/png" href="./favicon.png" />
 | 
					 | 
				
			||||||
</head>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
<body class="bg-white font-family-karla h-screen">
 | 
					 | 
				
			||||||
  <script type="module" src="./src/main.js"></script>
 | 
					 | 
				
			||||||
</body>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
</html>
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,7 +3,8 @@
 | 
				
			|||||||
	"version": "0.0.0",
 | 
						"version": "0.0.0",
 | 
				
			||||||
	"scripts": {
 | 
						"scripts": {
 | 
				
			||||||
		"dev": "vite",
 | 
							"dev": "vite",
 | 
				
			||||||
		"build": "vite build"
 | 
							"build": "vite build",
 | 
				
			||||||
 | 
							"format": "prettier --write --plugin-search-dir=. ./**/*.html ./**/*.svelte"
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	"devDependencies": {
 | 
						"devDependencies": {
 | 
				
			||||||
		"@svitejs/vite-plugin-svelte": "^0.11.0",
 | 
							"@svitejs/vite-plugin-svelte": "^0.11.0",
 | 
				
			||||||
@@ -12,6 +13,8 @@
 | 
				
			|||||||
		"axios": "^0.21.1",
 | 
							"axios": "^0.21.1",
 | 
				
			||||||
		"glob": "^7.1.6",
 | 
							"glob": "^7.1.6",
 | 
				
			||||||
		"html-minifier": "^4.0.0",
 | 
							"html-minifier": "^4.0.0",
 | 
				
			||||||
 | 
							"prettier": "^2.2.1",
 | 
				
			||||||
 | 
							"prettier-plugin-svelte": "^2.2.0",
 | 
				
			||||||
		"svelte": "^3.35.0",
 | 
							"svelte": "^3.35.0",
 | 
				
			||||||
		"svelte-preprocess": "^4.6.9",
 | 
							"svelte-preprocess": "^4.6.9",
 | 
				
			||||||
		"vite": "^2.0.5",
 | 
							"vite": "^2.0.5",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,18 +1,17 @@
 | 
				
			|||||||
{#if settings_open&&is_configured}
 | 
					 | 
				
			||||||
    <Settings/>
 | 
					 | 
				
			||||||
{:else}
 | 
					 | 
				
			||||||
    {#if is_configured}
 | 
					 | 
				
			||||||
        <Scanner/>
 | 
					 | 
				
			||||||
    {:else}
 | 
					 | 
				
			||||||
        <Login/>
 | 
					 | 
				
			||||||
    {/if}
 | 
					 | 
				
			||||||
{/if}
 | 
					 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
    import Scanner from './Scanner.svelte';
 | 
					  import Scanner from "./Scanner.svelte";
 | 
				
			||||||
    import Login from './Login.svelte';
 | 
					  import Login from "./Login.svelte";
 | 
				
			||||||
    import Settings from './Settings.svelte';
 | 
					  import Settings from "./Settings.svelte";
 | 
				
			||||||
    import {apikey,lang,page} from './store.js';
 | 
					  import { apikey, lang, page } from "./store.js";
 | 
				
			||||||
    $: is_configured= $apikey!=="null"&&$apikey!=="";
 | 
					  $: is_configured = $apikey !== "null" && $apikey !== "";
 | 
				
			||||||
    $: settings_open= $page==="settings";
 | 
					  $: settings_open = $page === "settings";
 | 
				
			||||||
    console.log($page);
 | 
					  console.log($page);
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					{#if settings_open && is_configured}
 | 
				
			||||||
 | 
					  <Settings />
 | 
				
			||||||
 | 
					{:else if is_configured}
 | 
				
			||||||
 | 
					  <Scanner />
 | 
				
			||||||
 | 
					{:else}
 | 
				
			||||||
 | 
					  <Login />
 | 
				
			||||||
 | 
					{/if}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,98 +1,166 @@
 | 
				
			|||||||
  <div class="w-full flex flex-wrap">
 | 
					<script>
 | 
				
			||||||
 | 
					  import { apikey, lang } from "./store.js";
 | 
				
			||||||
      <!-- Login Section -->
 | 
					  let token;
 | 
				
			||||||
      <div class="w-full md:w-1/2 flex flex-col">
 | 
					  $: isTokenValid =
 | 
				
			||||||
 | 
					    token?.length === 44 &&
 | 
				
			||||||
          <div class="flex justify-center md:justify-start pt-12 md:pl-12 md:-mb-24">
 | 
					    token.split(".")[0].length === 7 &&
 | 
				
			||||||
              <div class="bg-black text-white font-bold text-xl p-4"><img src="./favicon.png" alt=""
 | 
					    isUUID(token.split(".")[1]);
 | 
				
			||||||
                      style="height: 3rem;display: inline;"> LfK!Scan</div>
 | 
					  function isUUID(uuid) {
 | 
				
			||||||
          </div>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
          <div class="flex flex-col justify-center md:justify-start my-auto pt-8 md:pt-0 px-8 md:px-24 lg:px-32">
 | 
					 | 
				
			||||||
              <p class="text-center text-3xl">Configuration</p>
 | 
					 | 
				
			||||||
              <p class="text-center">Please provide the scan client token.<br><a target="_blank" class="underline"
 | 
					 | 
				
			||||||
                      href="https://docs.lauf-fuer-kaya.de/">See our configuration guide.</a></p>
 | 
					 | 
				
			||||||
              <form class="flex flex-col pt-3 md:pt-8" onsubmit="event.preventDefault();" on:submit={()=>
 | 
					 | 
				
			||||||
              {
 | 
					 | 
				
			||||||
                  // TODO: validate token with backend api
 | 
					 | 
				
			||||||
                  console.log(token);
 | 
					 | 
				
			||||||
                  apikey.set(token)
 | 
					 | 
				
			||||||
              }}>
 | 
					 | 
				
			||||||
                  <div class="flex flex-col pt-4">
 | 
					 | 
				
			||||||
                      <label for="token" class="text-lg">Client Token</label>
 | 
					 | 
				
			||||||
                      <input type="text" id="token" placeholder="Client Token" bind:value={token}
 | 
					 | 
				
			||||||
                      class:border-red-500={!isTokenValid}
 | 
					 | 
				
			||||||
                      class:border-solid={!isTokenValid}
 | 
					 | 
				
			||||||
                      class:border-3={!isTokenValid}
 | 
					 | 
				
			||||||
                          class="shadow appearance-none border rounded w-full py-2 px-3 text-gray-700 mt-1 leading-tight focus:outline-none focus:shadow-outline">
 | 
					 | 
				
			||||||
                  </div>
 | 
					 | 
				
			||||||
                  {#if !isTokenValid}
 | 
					 | 
				
			||||||
                       <span class="text-sm">Please provide a valid client token...</span>
 | 
					 | 
				
			||||||
                  {/if}
 | 
					 | 
				
			||||||
                  <button
 | 
					 | 
				
			||||||
                  disabled={!isTokenValid}
 | 
					 | 
				
			||||||
            class:cursor-pointer={isTokenValid}
 | 
					 | 
				
			||||||
            class:opacity-50={!isTokenValid}
 | 
					 | 
				
			||||||
                  id="configure" type="submit"
 | 
					 | 
				
			||||||
                      class="bg-black text-white font-bold text-lg hover:bg-gray-700 p-2 mt-8 hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black">Configure</button>
 | 
					 | 
				
			||||||
              </form>
 | 
					 | 
				
			||||||
              <div class="text-center pt-12 pb-12">
 | 
					 | 
				
			||||||
                  <p><svg style="height: 1rem;display: inline;" xmlns="http://www.w3.org/2000/svg" fill="none"
 | 
					 | 
				
			||||||
                          stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"
 | 
					 | 
				
			||||||
                          class="feather feather-zap" viewBox="0 0 24 24">
 | 
					 | 
				
			||||||
                          <path d="M13 2L3 14h9l-1 8 10-12h-9l1-8z" />
 | 
					 | 
				
			||||||
                      </svg><span>powered by <a href="https://odit.services" target="_blank"
 | 
					 | 
				
			||||||
                              class="underline">ODIT.Services</a>.</span></p>
 | 
					 | 
				
			||||||
              </div>
 | 
					 | 
				
			||||||
          </div>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
          <div class="w-full p-3">
 | 
					 | 
				
			||||||
            <div class="inline-block mr-2 mt-2">
 | 
					 | 
				
			||||||
                <button on:click={()=>{
 | 
					 | 
				
			||||||
                lang.set("de-DE")
 | 
					 | 
				
			||||||
                }} type="button"
 | 
					 | 
				
			||||||
                class:bg-blue-700={$lang==="de-DE"}
 | 
					 | 
				
			||||||
                    class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700">Deutsch
 | 
					 | 
				
			||||||
                    <svg class="h-4 inline" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path d="M15.923 345.043C52.094 442.527 145.929 512 256 512s203.906-69.473 240.077-166.957L256 322.783l-240.077 22.26z" fill="#ffda44"/><path d="M256 0C145.929 0 52.094 69.472 15.923 166.957L256 189.217l240.077-22.261C459.906 69.472 366.071 0 256 0z"/><path d="M15.923 166.957C5.633 194.69 0 224.686 0 256s5.633 61.31 15.923 89.043h480.155C506.368 317.31 512 287.314 512 256s-5.632-61.31-15.923-89.043H15.923z" fill="#d80027"/></svg></button>
 | 
					 | 
				
			||||||
            </div>
 | 
					 | 
				
			||||||
            <div class="inline-block mr-2 mt-2">
 | 
					 | 
				
			||||||
                <button on:click={()=>{
 | 
					 | 
				
			||||||
                lang.set("en-EN")
 | 
					 | 
				
			||||||
                }} type="button"
 | 
					 | 
				
			||||||
                class:bg-blue-700={$lang==="en-EN"}
 | 
					 | 
				
			||||||
                    class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700">English
 | 
					 | 
				
			||||||
                    <svg class="h-4 inline" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">
 | 
					 | 
				
			||||||
                        <circle cx="256" cy="256" r="256" fill="#f0f0f0"></circle>
 | 
					 | 
				
			||||||
                        <g fill="#d80027">
 | 
					 | 
				
			||||||
                            <path
 | 
					 | 
				
			||||||
                                d="M244.87 256H512c0-23.106-3.08-45.49-8.819-66.783H244.87V256zM244.87 122.435h229.556a257.35 257.35 0 00-59.07-66.783H244.87v66.783zM256 512c60.249 0 115.626-20.824 159.356-55.652H96.644C140.374 491.176 195.751 512 256 512zM37.574 389.565h436.852a254.474 254.474 0 0028.755-66.783H8.819a254.474 254.474 0 0028.755 66.783z">
 | 
					 | 
				
			||||||
                            </path>
 | 
					 | 
				
			||||||
                        </g>
 | 
					 | 
				
			||||||
                        <path
 | 
					 | 
				
			||||||
                            d="M118.584 39.978h23.329l-21.7 15.765 8.289 25.509-21.699-15.765-21.699 15.765 7.16-22.037a257.407 257.407 0 00-49.652 55.337h7.475l-13.813 10.035a255.58 255.58 0 00-6.194 10.938l6.596 20.301-12.306-8.941a253.567 253.567 0 00-8.372 19.873l7.267 22.368h26.822l-21.7 15.765 8.289 25.509-21.699-15.765-12.998 9.444A258.468 258.468 0 000 256h256V0c-50.572 0-97.715 14.67-137.416 39.978zm9.918 190.422l-21.699-15.765L85.104 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zM220.328 230.4l-21.699-15.765L176.93 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zm0-74.574l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765z"
 | 
					 | 
				
			||||||
                            fill="#0052b4"></path>
 | 
					 | 
				
			||||||
                    </svg></button>
 | 
					 | 
				
			||||||
            </div>
 | 
					 | 
				
			||||||
          </div>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      </div>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      <!-- Image Section -->
 | 
					 | 
				
			||||||
      <div class="w-1/2 shadow-2xl">
 | 
					 | 
				
			||||||
          <img alt="" class="object-cover w-full h-screen hidden md:block" src="https://source.unsplash.com/IXUM4cJynP0">
 | 
					 | 
				
			||||||
      </div>
 | 
					 | 
				
			||||||
  </div>
 | 
					 | 
				
			||||||
  <script>
 | 
					 | 
				
			||||||
          import {apikey,lang} from './store.js';
 | 
					 | 
				
			||||||
      let token;
 | 
					 | 
				
			||||||
      $: isTokenValid=token?.length===44&& token.split(".")[0].length===7 &&isUUID(token.split(".")[1]);
 | 
					 | 
				
			||||||
      function isUUID ( uuid ) {
 | 
					 | 
				
			||||||
    let s = "" + uuid;
 | 
					    let s = "" + uuid;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    s = s.match('^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$');
 | 
					    s = s.match(
 | 
				
			||||||
 | 
					      "^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$"
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
    if (s === null) {
 | 
					    if (s === null) {
 | 
				
			||||||
      return false;
 | 
					      return false;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    return true;
 | 
					    return true;
 | 
				
			||||||
}
 | 
					  }
 | 
				
			||||||
  </script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<div class="w-full flex flex-wrap">
 | 
				
			||||||
 | 
					  <!-- Login Section -->
 | 
				
			||||||
 | 
					  <div class="w-full md:w-1/2 flex flex-col">
 | 
				
			||||||
 | 
					    <div class="flex justify-center md:justify-start pt-12 md:pl-12 md:-mb-24">
 | 
				
			||||||
 | 
					      <div class="bg-black text-white font-bold text-xl p-4">
 | 
				
			||||||
 | 
					        <img src="./favicon.png" alt="" style="height: 3rem;display: inline;" />
 | 
				
			||||||
 | 
					        LfK!Scan
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <div
 | 
				
			||||||
 | 
					      class="flex flex-col justify-center md:justify-start my-auto pt-8 md:pt-0 px-8 md:px-24 lg:px-32"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <p class="text-center text-3xl">Configuration</p>
 | 
				
			||||||
 | 
					      <p class="text-center">
 | 
				
			||||||
 | 
					        Please provide the scan client token.<br /><a
 | 
				
			||||||
 | 
					          target="_blank"
 | 
				
			||||||
 | 
					          class="underline"
 | 
				
			||||||
 | 
					          href="https://docs.lauf-fuer-kaya.de/">See our configuration guide.</a
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					      </p>
 | 
				
			||||||
 | 
					      <form
 | 
				
			||||||
 | 
					        class="flex flex-col pt-3 md:pt-8"
 | 
				
			||||||
 | 
					        onsubmit="event.preventDefault();"
 | 
				
			||||||
 | 
					        on:submit={() => {
 | 
				
			||||||
 | 
					          // TODO: validate token with backend api
 | 
				
			||||||
 | 
					          console.log(token);
 | 
				
			||||||
 | 
					          apikey.set(token);
 | 
				
			||||||
 | 
					        }}
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					        <div class="flex flex-col pt-4">
 | 
				
			||||||
 | 
					          <label for="token" class="text-lg">Client Token</label>
 | 
				
			||||||
 | 
					          <input
 | 
				
			||||||
 | 
					            type="text"
 | 
				
			||||||
 | 
					            id="token"
 | 
				
			||||||
 | 
					            placeholder="Client Token"
 | 
				
			||||||
 | 
					            bind:value={token}
 | 
				
			||||||
 | 
					            class:border-red-500={!isTokenValid}
 | 
				
			||||||
 | 
					            class:border-solid={!isTokenValid}
 | 
				
			||||||
 | 
					            class:border-3={!isTokenValid}
 | 
				
			||||||
 | 
					            class="shadow appearance-none border rounded w-full py-2 px-3 text-gray-700 mt-1 leading-tight focus:outline-none focus:shadow-outline"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					        {#if !isTokenValid}
 | 
				
			||||||
 | 
					          <span class="text-sm">Please provide a valid client token...</span>
 | 
				
			||||||
 | 
					        {/if}
 | 
				
			||||||
 | 
					        <button
 | 
				
			||||||
 | 
					          disabled={!isTokenValid}
 | 
				
			||||||
 | 
					          class:cursor-pointer={isTokenValid}
 | 
				
			||||||
 | 
					          class:opacity-50={!isTokenValid}
 | 
				
			||||||
 | 
					          id="configure"
 | 
				
			||||||
 | 
					          type="submit"
 | 
				
			||||||
 | 
					          class="bg-black text-white font-bold text-lg hover:bg-gray-700 p-2 mt-8 hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black"
 | 
				
			||||||
 | 
					          >Configure</button
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					      </form>
 | 
				
			||||||
 | 
					      <div class="text-center pt-12 pb-12">
 | 
				
			||||||
 | 
					        <p>
 | 
				
			||||||
 | 
					          <svg
 | 
				
			||||||
 | 
					            style="height: 1rem;display: inline;"
 | 
				
			||||||
 | 
					            xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					            fill="none"
 | 
				
			||||||
 | 
					            stroke="currentColor"
 | 
				
			||||||
 | 
					            stroke-width="2"
 | 
				
			||||||
 | 
					            stroke-linecap="round"
 | 
				
			||||||
 | 
					            stroke-linejoin="round"
 | 
				
			||||||
 | 
					            class="feather feather-zap"
 | 
				
			||||||
 | 
					            viewBox="0 0 24 24"
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					            <path d="M13 2L3 14h9l-1 8 10-12h-9l1-8z" />
 | 
				
			||||||
 | 
					          </svg><span
 | 
				
			||||||
 | 
					            >powered by <a
 | 
				
			||||||
 | 
					              href="https://odit.services"
 | 
				
			||||||
 | 
					              target="_blank"
 | 
				
			||||||
 | 
					              class="underline">ODIT.Services</a
 | 
				
			||||||
 | 
					            >.</span
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					        </p>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <div class="w-full p-3">
 | 
				
			||||||
 | 
					      <div class="inline-block mr-2 mt-2">
 | 
				
			||||||
 | 
					        <button
 | 
				
			||||||
 | 
					          on:click={() => {
 | 
				
			||||||
 | 
					            lang.set("de-DE");
 | 
				
			||||||
 | 
					          }}
 | 
				
			||||||
 | 
					          type="button"
 | 
				
			||||||
 | 
					          class:bg-blue-700={$lang === "de-DE"}
 | 
				
			||||||
 | 
					          class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700"
 | 
				
			||||||
 | 
					          >Deutsch
 | 
				
			||||||
 | 
					          <svg
 | 
				
			||||||
 | 
					            class="h-4 inline"
 | 
				
			||||||
 | 
					            xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					            viewBox="0 0 512 512"
 | 
				
			||||||
 | 
					            ><path
 | 
				
			||||||
 | 
					              d="M15.923 345.043C52.094 442.527 145.929 512 256 512s203.906-69.473 240.077-166.957L256 322.783l-240.077 22.26z"
 | 
				
			||||||
 | 
					              fill="#ffda44"
 | 
				
			||||||
 | 
					            /><path
 | 
				
			||||||
 | 
					              d="M256 0C145.929 0 52.094 69.472 15.923 166.957L256 189.217l240.077-22.261C459.906 69.472 366.071 0 256 0z"
 | 
				
			||||||
 | 
					            /><path
 | 
				
			||||||
 | 
					              d="M15.923 166.957C5.633 194.69 0 224.686 0 256s5.633 61.31 15.923 89.043h480.155C506.368 317.31 512 287.314 512 256s-5.632-61.31-15.923-89.043H15.923z"
 | 
				
			||||||
 | 
					              fill="#d80027"
 | 
				
			||||||
 | 
					            /></svg
 | 
				
			||||||
 | 
					          ></button
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="inline-block mr-2 mt-2">
 | 
				
			||||||
 | 
					        <button
 | 
				
			||||||
 | 
					          on:click={() => {
 | 
				
			||||||
 | 
					            lang.set("en-EN");
 | 
				
			||||||
 | 
					          }}
 | 
				
			||||||
 | 
					          type="button"
 | 
				
			||||||
 | 
					          class:bg-blue-700={$lang === "en-EN"}
 | 
				
			||||||
 | 
					          class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700"
 | 
				
			||||||
 | 
					          >English
 | 
				
			||||||
 | 
					          <svg
 | 
				
			||||||
 | 
					            class="h-4 inline"
 | 
				
			||||||
 | 
					            xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					            viewBox="0 0 512 512"
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					            <circle cx="256" cy="256" r="256" fill="#f0f0f0" />
 | 
				
			||||||
 | 
					            <g fill="#d80027">
 | 
				
			||||||
 | 
					              <path
 | 
				
			||||||
 | 
					                d="M244.87 256H512c0-23.106-3.08-45.49-8.819-66.783H244.87V256zM244.87 122.435h229.556a257.35 257.35 0 00-59.07-66.783H244.87v66.783zM256 512c60.249 0 115.626-20.824 159.356-55.652H96.644C140.374 491.176 195.751 512 256 512zM37.574 389.565h436.852a254.474 254.474 0 0028.755-66.783H8.819a254.474 254.474 0 0028.755 66.783z"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
 | 
					            </g>
 | 
				
			||||||
 | 
					            <path
 | 
				
			||||||
 | 
					              d="M118.584 39.978h23.329l-21.7 15.765 8.289 25.509-21.699-15.765-21.699 15.765 7.16-22.037a257.407 257.407 0 00-49.652 55.337h7.475l-13.813 10.035a255.58 255.58 0 00-6.194 10.938l6.596 20.301-12.306-8.941a253.567 253.567 0 00-8.372 19.873l7.267 22.368h26.822l-21.7 15.765 8.289 25.509-21.699-15.765-12.998 9.444A258.468 258.468 0 000 256h256V0c-50.572 0-97.715 14.67-137.416 39.978zm9.918 190.422l-21.699-15.765L85.104 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zM220.328 230.4l-21.699-15.765L176.93 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zm0-74.574l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765z"
 | 
				
			||||||
 | 
					              fill="#0052b4"
 | 
				
			||||||
 | 
					            />
 | 
				
			||||||
 | 
					          </svg></button
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  <!-- Image Section -->
 | 
				
			||||||
 | 
					  <div class="w-1/2 shadow-2xl">
 | 
				
			||||||
 | 
					    <img
 | 
				
			||||||
 | 
					      alt=""
 | 
				
			||||||
 | 
					      class="object-cover w-full h-screen hidden md:block"
 | 
				
			||||||
 | 
					      src="https://source.unsplash.com/IXUM4cJynP0"
 | 
				
			||||||
 | 
					    />
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</div>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,61 +1,81 @@
 | 
				
			|||||||
 | 
					<script>
 | 
				
			||||||
 | 
					  import { apikey, lang, page } from "./store.js";
 | 
				
			||||||
 | 
					  function init(el) {
 | 
				
			||||||
 | 
					    el.focus();
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  let lastscan_time = "";
 | 
				
			||||||
 | 
					  let lastscan_laptime = "";
 | 
				
			||||||
 | 
					  let lastscan_totaldistance = "";
 | 
				
			||||||
 | 
					  let card = "";
 | 
				
			||||||
 | 
					  // live clock at the top
 | 
				
			||||||
 | 
					  let time = new Date();
 | 
				
			||||||
 | 
					  $: hours = (time.getHours() + "").padStart(2, "0");
 | 
				
			||||||
 | 
					  $: minutes = (time.getMinutes() + "").padStart(2, "0");
 | 
				
			||||||
 | 
					  $: seconds = (time.getSeconds() + "").padStart(2, "0");
 | 
				
			||||||
 | 
					  const interval = setInterval(() => {
 | 
				
			||||||
 | 
					    time = new Date();
 | 
				
			||||||
 | 
					  }, 1000);
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<div class="p-5 min-h-screen">
 | 
					<div class="p-5 min-h-screen">
 | 
				
			||||||
    <h1 class="font-semibold w-full text-center text-gray-900">Lauf Für Kaya! Scan 📷</h1>
 | 
					  <h1 class="font-semibold w-full text-center text-gray-900">
 | 
				
			||||||
    <h1 class="mr-6 text-6xl font-semibold text-center text-gray-900">{hours}:{minutes}:{seconds}</h1>
 | 
					    Lauf Für Kaya! Scan 📷
 | 
				
			||||||
    <section class="px-4 py-24 mx-auto max-w-7xl">
 | 
					  </h1>
 | 
				
			||||||
        <div class="w-full mx-auto space-y-5 sm:w-8/12 md:w-6/12 lg:w-4/12 xl:w-3/12">
 | 
					  <h1 class="mr-6 text-6xl font-semibold text-center text-gray-900">
 | 
				
			||||||
            <form class="space-y-4" onsubmit="event.preventDefault();" on:submit={()=>
 | 
					    {hours}:{minutes}:{seconds}
 | 
				
			||||||
            {
 | 
					  </h1>
 | 
				
			||||||
                if(card==="cnf"){
 | 
					  <section class="px-4 py-24 mx-auto max-w-7xl">
 | 
				
			||||||
                    page.set("settings");
 | 
					    <div
 | 
				
			||||||
                }else{
 | 
					      class="w-full mx-auto space-y-5 sm:w-8/12 md:w-6/12 lg:w-4/12 xl:w-3/12"
 | 
				
			||||||
                    console.log(card);
 | 
					    >
 | 
				
			||||||
                    //TODO: hit API for scan entry
 | 
					      <form
 | 
				
			||||||
                    lastscan_totaldistance="400m";
 | 
					        class="space-y-4"
 | 
				
			||||||
                let time = new Date();
 | 
					        onsubmit="event.preventDefault();"
 | 
				
			||||||
                const hours = (time.getHours()+"").padStart(2,"0");
 | 
					        on:submit={() => {
 | 
				
			||||||
                const minutes = (time.getMinutes()+"").padStart(2,"0");
 | 
					          if (card === "cnf") {
 | 
				
			||||||
                const seconds = (time.getSeconds()+"").padStart(2,"0");
 | 
					            page.set("settings");
 | 
				
			||||||
                lastscan_time=hours+":"+minutes+":"+seconds;
 | 
					          } else {
 | 
				
			||||||
                lastscan_laptime="1min 30s";
 | 
					            console.log(card);
 | 
				
			||||||
            }
 | 
					            //TODO: hit API for scan entry
 | 
				
			||||||
                card="";
 | 
					            lastscan_totaldistance = "400m";
 | 
				
			||||||
            }}>
 | 
					            let time = new Date();
 | 
				
			||||||
            {#if lastscan_totaldistance}
 | 
					            const hours = (time.getHours() + "").padStart(2, "0");
 | 
				
			||||||
                <h1 class="text-3xl font-bold text-center">last scan</h1>
 | 
					            const minutes = (time.getMinutes() + "").padStart(2, "0");
 | 
				
			||||||
                <h1 class="text-5xl font-bold text-center">{lastscan_time}</h1>
 | 
					            const seconds = (time.getSeconds() + "").padStart(2, "0");
 | 
				
			||||||
                <h1 class="text-3xl font-bold text-center">total distance</h1>
 | 
					            lastscan_time = hours + ":" + minutes + ":" + seconds;
 | 
				
			||||||
                <h1 class="text-9xl font-bold text-center">{lastscan_totaldistance}</h1>
 | 
					            lastscan_laptime = "1min 30s";
 | 
				
			||||||
                <h1 class="text-3xl font-bold text-center">lap time</h1>
 | 
					          }
 | 
				
			||||||
                <h1 class="text-9xl font-bold text-center">{lastscan_laptime}</h1>
 | 
					          card = "";
 | 
				
			||||||
                {:else}
 | 
					        }}
 | 
				
			||||||
                <h1 class="text-3xl font-bold text-center">please scan a card...</h1>
 | 
					      >
 | 
				
			||||||
            {/if}
 | 
					        {#if lastscan_totaldistance}
 | 
				
			||||||
 | 
					          <h1 class="text-3xl font-bold text-center">last scan</h1>
 | 
				
			||||||
 | 
					          <h1 class="text-5xl font-bold text-center">{lastscan_time}</h1>
 | 
				
			||||||
 | 
					          <h1 class="text-3xl font-bold text-center">total distance</h1>
 | 
				
			||||||
 | 
					          <h1 class="text-9xl font-bold text-center">
 | 
				
			||||||
 | 
					            {lastscan_totaldistance}
 | 
				
			||||||
 | 
					          </h1>
 | 
				
			||||||
 | 
					          <h1 class="text-3xl font-bold text-center">lap time</h1>
 | 
				
			||||||
 | 
					          <h1 class="text-9xl font-bold text-center">{lastscan_laptime}</h1>
 | 
				
			||||||
 | 
					        {:else}
 | 
				
			||||||
 | 
					          <h1 class="text-3xl font-bold text-center">please scan a card...</h1>
 | 
				
			||||||
 | 
					        {/if}
 | 
				
			||||||
        <label class="block">
 | 
					        <label class="block">
 | 
				
			||||||
            <span class="block mb-1 text-xs font-medium text-gray-700">Runner Card</span>
 | 
					          <span class="block mb-1 text-xs font-medium text-gray-700"
 | 
				
			||||||
            <input class="shadow appearance-none border rounded w-full py-2 px-3 text-gray-700 mt-1 leading-tight focus:outline-none focus:shadow-outline" type="text" placeholder="123456789" required use:init bind:value={card}/>
 | 
					            >Runner Card</span
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					          <input
 | 
				
			||||||
 | 
					            class="shadow appearance-none border rounded w-full py-2 px-3 text-gray-700 mt-1 leading-tight focus:outline-none focus:shadow-outline"
 | 
				
			||||||
 | 
					            type="text"
 | 
				
			||||||
 | 
					            placeholder="123456789"
 | 
				
			||||||
 | 
					            required
 | 
				
			||||||
 | 
					            use:init
 | 
				
			||||||
 | 
					            bind:value={card}
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
        </label>
 | 
					        </label>
 | 
				
			||||||
        <!-- <button type="submit" class="w-full py-3 bg-black text-white focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black">Scan!</button> -->
 | 
					        <!-- <button type="submit" class="w-full py-3 bg-black text-white focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black">Scan!</button> -->
 | 
				
			||||||
        <button type="submit" class="hidden">Scan!</button>
 | 
					        <button type="submit" class="hidden">Scan!</button>
 | 
				
			||||||
    </form>
 | 
					      </form>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </section>
 | 
				
			||||||
</div>
 | 
					</div>
 | 
				
			||||||
</section>
 | 
					 | 
				
			||||||
</div>
 | 
					 | 
				
			||||||
<!--  -->
 | 
					 | 
				
			||||||
<script>
 | 
					 | 
				
			||||||
    import {apikey,lang,page} from './store.js';
 | 
					 | 
				
			||||||
    function init(el){
 | 
					 | 
				
			||||||
        el.focus()
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    let lastscan_time="";
 | 
					 | 
				
			||||||
    let lastscan_laptime="";
 | 
					 | 
				
			||||||
    let lastscan_totaldistance="";
 | 
					 | 
				
			||||||
    let card="";
 | 
					 | 
				
			||||||
	// live clock at the top
 | 
					 | 
				
			||||||
    let time = new Date();
 | 
					 | 
				
			||||||
	$: hours = (time.getHours()+"").padStart(2,"0");
 | 
					 | 
				
			||||||
	$: minutes = (time.getMinutes()+"").padStart(2,"0");
 | 
					 | 
				
			||||||
	$: seconds = (time.getSeconds()+"").padStart(2,"0");
 | 
					 | 
				
			||||||
    const interval = setInterval(() => {
 | 
					 | 
				
			||||||
        time = new Date();
 | 
					 | 
				
			||||||
    }, 1000);
 | 
					 | 
				
			||||||
</script>
 | 
					 | 
				
			||||||
@@ -1,48 +1,85 @@
 | 
				
			|||||||
<div class="p-5 min-h-screen">
 | 
					 | 
				
			||||||
    <h1 class="font-bold text-3xl w-full text-center text-gray-900">Lauf Für Kaya! Scan 📷</h1>
 | 
					 | 
				
			||||||
    <h1 class="text-3xl w-full text-center text-gray-900">Settings</h1>
 | 
					 | 
				
			||||||
    <p class="block text-sm font-bold text-gray-700">API Key</p>
 | 
					 | 
				
			||||||
    <p class="block text-sm text-gray-700">{$apikey}</p>
 | 
					 | 
				
			||||||
    <br>
 | 
					 | 
				
			||||||
    <p class="block text-sm font-bold text-gray-700">Language</p>
 | 
					 | 
				
			||||||
    <div class="w-full">
 | 
					 | 
				
			||||||
        <div class="inline-block mr-2 mt-2">
 | 
					 | 
				
			||||||
            <button on:click={()=>{
 | 
					 | 
				
			||||||
            lang.set("de-DE")
 | 
					 | 
				
			||||||
            }} type="button"
 | 
					 | 
				
			||||||
            class:bg-blue-700={$lang==="de-DE"}
 | 
					 | 
				
			||||||
                class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700">Deutsch
 | 
					 | 
				
			||||||
                <svg class="h-4 inline" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path d="M15.923 345.043C52.094 442.527 145.929 512 256 512s203.906-69.473 240.077-166.957L256 322.783l-240.077 22.26z" fill="#ffda44"/><path d="M256 0C145.929 0 52.094 69.472 15.923 166.957L256 189.217l240.077-22.261C459.906 69.472 366.071 0 256 0z"/><path d="M15.923 166.957C5.633 194.69 0 224.686 0 256s5.633 61.31 15.923 89.043h480.155C506.368 317.31 512 287.314 512 256s-5.632-61.31-15.923-89.043H15.923z" fill="#d80027"/></svg></button>
 | 
					 | 
				
			||||||
        </div>
 | 
					 | 
				
			||||||
        <div class="inline-block mr-2 mt-2">
 | 
					 | 
				
			||||||
            <button on:click={()=>{
 | 
					 | 
				
			||||||
            lang.set("en-EN")
 | 
					 | 
				
			||||||
            }} type="button"
 | 
					 | 
				
			||||||
            class:bg-blue-700={$lang==="en-EN"}
 | 
					 | 
				
			||||||
                class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700">English
 | 
					 | 
				
			||||||
                <svg class="h-4 inline" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512">
 | 
					 | 
				
			||||||
                    <circle cx="256" cy="256" r="256" fill="#f0f0f0"></circle>
 | 
					 | 
				
			||||||
                    <g fill="#d80027">
 | 
					 | 
				
			||||||
                        <path
 | 
					 | 
				
			||||||
                            d="M244.87 256H512c0-23.106-3.08-45.49-8.819-66.783H244.87V256zM244.87 122.435h229.556a257.35 257.35 0 00-59.07-66.783H244.87v66.783zM256 512c60.249 0 115.626-20.824 159.356-55.652H96.644C140.374 491.176 195.751 512 256 512zM37.574 389.565h436.852a254.474 254.474 0 0028.755-66.783H8.819a254.474 254.474 0 0028.755 66.783z">
 | 
					 | 
				
			||||||
                        </path>
 | 
					 | 
				
			||||||
                    </g>
 | 
					 | 
				
			||||||
                    <path
 | 
					 | 
				
			||||||
                        d="M118.584 39.978h23.329l-21.7 15.765 8.289 25.509-21.699-15.765-21.699 15.765 7.16-22.037a257.407 257.407 0 00-49.652 55.337h7.475l-13.813 10.035a255.58 255.58 0 00-6.194 10.938l6.596 20.301-12.306-8.941a253.567 253.567 0 00-8.372 19.873l7.267 22.368h26.822l-21.7 15.765 8.289 25.509-21.699-15.765-12.998 9.444A258.468 258.468 0 000 256h256V0c-50.572 0-97.715 14.67-137.416 39.978zm9.918 190.422l-21.699-15.765L85.104 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zM220.328 230.4l-21.699-15.765L176.93 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zm0-74.574l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765z"
 | 
					 | 
				
			||||||
                        fill="#0052b4"></path>
 | 
					 | 
				
			||||||
                </svg></button>
 | 
					 | 
				
			||||||
        </div>
 | 
					 | 
				
			||||||
    </div>
 | 
					 | 
				
			||||||
    <br>
 | 
					 | 
				
			||||||
    <button on:click={()=>{
 | 
					 | 
				
			||||||
    page.set("");
 | 
					 | 
				
			||||||
    }} class="mb-3 w-full py-3 border-black border-3 text-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black">Back to Scanner</button>
 | 
					 | 
				
			||||||
    <button on:click={()=>{
 | 
					 | 
				
			||||||
    apikey.set("");
 | 
					 | 
				
			||||||
    page.set("");
 | 
					 | 
				
			||||||
    }} class="w-full py-3 bg-black text-white focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black">Log Out from this Client</button>
 | 
					 | 
				
			||||||
</div>
 | 
					 | 
				
			||||||
<!--  -->
 | 
					<!--  -->
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
    import {apikey,lang, page} from './store.js';
 | 
					  import { apikey, lang, page } from "./store.js";
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<div class="p-5 min-h-screen">
 | 
				
			||||||
 | 
					  <h1 class="font-bold text-3xl w-full text-center text-gray-900">
 | 
				
			||||||
 | 
					    Lauf Für Kaya! Scan 📷
 | 
				
			||||||
 | 
					  </h1>
 | 
				
			||||||
 | 
					  <h1 class="text-3xl w-full text-center text-gray-900">Settings</h1>
 | 
				
			||||||
 | 
					  <p class="block text-sm font-bold text-gray-700">API Key</p>
 | 
				
			||||||
 | 
					  <p class="block text-sm text-gray-700">{$apikey}</p>
 | 
				
			||||||
 | 
					  <br />
 | 
				
			||||||
 | 
					  <p class="block text-sm font-bold text-gray-700">Language</p>
 | 
				
			||||||
 | 
					  <div class="w-full">
 | 
				
			||||||
 | 
					    <div class="inline-block mr-2 mt-2">
 | 
				
			||||||
 | 
					      <button
 | 
				
			||||||
 | 
					        on:click={() => {
 | 
				
			||||||
 | 
					          lang.set("de-DE");
 | 
				
			||||||
 | 
					        }}
 | 
				
			||||||
 | 
					        type="button"
 | 
				
			||||||
 | 
					        class:bg-blue-700={$lang === "de-DE"}
 | 
				
			||||||
 | 
					        class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700"
 | 
				
			||||||
 | 
					        >Deutsch
 | 
				
			||||||
 | 
					        <svg
 | 
				
			||||||
 | 
					          class="h-4 inline"
 | 
				
			||||||
 | 
					          xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					          viewBox="0 0 512 512"
 | 
				
			||||||
 | 
					          ><path
 | 
				
			||||||
 | 
					            d="M15.923 345.043C52.094 442.527 145.929 512 256 512s203.906-69.473 240.077-166.957L256 322.783l-240.077 22.26z"
 | 
				
			||||||
 | 
					            fill="#ffda44"
 | 
				
			||||||
 | 
					          /><path
 | 
				
			||||||
 | 
					            d="M256 0C145.929 0 52.094 69.472 15.923 166.957L256 189.217l240.077-22.261C459.906 69.472 366.071 0 256 0z"
 | 
				
			||||||
 | 
					          /><path
 | 
				
			||||||
 | 
					            d="M15.923 166.957C5.633 194.69 0 224.686 0 256s5.633 61.31 15.923 89.043h480.155C506.368 317.31 512 287.314 512 256s-5.632-61.31-15.923-89.043H15.923z"
 | 
				
			||||||
 | 
					            fill="#d80027"
 | 
				
			||||||
 | 
					          /></svg
 | 
				
			||||||
 | 
					        ></button
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="inline-block mr-2 mt-2">
 | 
				
			||||||
 | 
					      <button
 | 
				
			||||||
 | 
					        on:click={() => {
 | 
				
			||||||
 | 
					          lang.set("en-EN");
 | 
				
			||||||
 | 
					        }}
 | 
				
			||||||
 | 
					        type="button"
 | 
				
			||||||
 | 
					        class:bg-blue-700={$lang === "en-EN"}
 | 
				
			||||||
 | 
					        class="bg-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black text-white text-sm py-2.5 px-5 rounded-md hover:bg-blue-700"
 | 
				
			||||||
 | 
					        >English
 | 
				
			||||||
 | 
					        <svg
 | 
				
			||||||
 | 
					          class="h-4 inline"
 | 
				
			||||||
 | 
					          xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					          viewBox="0 0 512 512"
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					          <circle cx="256" cy="256" r="256" fill="#f0f0f0" />
 | 
				
			||||||
 | 
					          <g fill="#d80027">
 | 
				
			||||||
 | 
					            <path
 | 
				
			||||||
 | 
					              d="M244.87 256H512c0-23.106-3.08-45.49-8.819-66.783H244.87V256zM244.87 122.435h229.556a257.35 257.35 0 00-59.07-66.783H244.87v66.783zM256 512c60.249 0 115.626-20.824 159.356-55.652H96.644C140.374 491.176 195.751 512 256 512zM37.574 389.565h436.852a254.474 254.474 0 0028.755-66.783H8.819a254.474 254.474 0 0028.755 66.783z"
 | 
				
			||||||
 | 
					            />
 | 
				
			||||||
 | 
					          </g>
 | 
				
			||||||
 | 
					          <path
 | 
				
			||||||
 | 
					            d="M118.584 39.978h23.329l-21.7 15.765 8.289 25.509-21.699-15.765-21.699 15.765 7.16-22.037a257.407 257.407 0 00-49.652 55.337h7.475l-13.813 10.035a255.58 255.58 0 00-6.194 10.938l6.596 20.301-12.306-8.941a253.567 253.567 0 00-8.372 19.873l7.267 22.368h26.822l-21.7 15.765 8.289 25.509-21.699-15.765-12.998 9.444A258.468 258.468 0 000 256h256V0c-50.572 0-97.715 14.67-137.416 39.978zm9.918 190.422l-21.699-15.765L85.104 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zM220.328 230.4l-21.699-15.765L176.93 230.4l8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765 8.289 25.509zm-8.289-100.083l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765zm0-74.574l8.289 25.509-21.699-15.765-21.699 15.765 8.289-25.509-21.7-15.765h26.822l8.288-25.509 8.288 25.509h26.822l-21.7 15.765z"
 | 
				
			||||||
 | 
					            fill="#0052b4"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					        </svg></button
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					  <br />
 | 
				
			||||||
 | 
					  <button
 | 
				
			||||||
 | 
					    on:click={() => {
 | 
				
			||||||
 | 
					      page.set("");
 | 
				
			||||||
 | 
					    }}
 | 
				
			||||||
 | 
					    class="mb-3 w-full py-3 border-black border-3 text-black focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black"
 | 
				
			||||||
 | 
					    >Back to Scanner</button
 | 
				
			||||||
 | 
					  >
 | 
				
			||||||
 | 
					  <button
 | 
				
			||||||
 | 
					    on:click={() => {
 | 
				
			||||||
 | 
					      apikey.set("");
 | 
				
			||||||
 | 
					      page.set("");
 | 
				
			||||||
 | 
					    }}
 | 
				
			||||||
 | 
					    class="w-full py-3 bg-black text-white focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black"
 | 
				
			||||||
 | 
					    >Log Out from this Client</button
 | 
				
			||||||
 | 
					  >
 | 
				
			||||||
 | 
					</div>
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user