139 lines
5.0 KiB
Svelte
139 lines
5.0 KiB
Svelte
<script>
|
|
import { _ } from "svelte-i18n";
|
|
|
|
import { tick, createEventDispatcher } from "svelte";
|
|
export let copy_modal_open;
|
|
export let new_client;
|
|
import toast from 'svelte-french-toast'
|
|
const dispatch = createEventDispatcher();
|
|
let valueCopy = null;
|
|
let areaDom;
|
|
let copied = false;
|
|
function close() {
|
|
copy_modal_open = false;
|
|
}
|
|
async function copy() {
|
|
valueCopy = new_client.key;
|
|
await tick();
|
|
areaDom.focus();
|
|
areaDom.select();
|
|
try {
|
|
const successful = document.execCommand("copy");
|
|
if (!successful) {
|
|
throw new Error();
|
|
}
|
|
toast.success($_("copied-token-to-clipboard"));
|
|
copied = true;
|
|
} catch (err) {
|
|
toast.error($_("error-whyile-copying-to-clipboard"));
|
|
}
|
|
|
|
// we can notifi by event or storage about copy status
|
|
valueCopy = null;
|
|
}
|
|
</script>
|
|
|
|
{#if copy_modal_open}
|
|
{#if valueCopy != null}
|
|
<textarea bind:this={areaDom}>{valueCopy}</textarea>
|
|
{/if}
|
|
<div class="fixed z-10 inset-0 overflow-y-hidden">
|
|
<div
|
|
class="flex items-end justify-center h-screen text-center sm:block p-0 lg:p-4"
|
|
>
|
|
<div class="fixed inset-0 transition-opacity" aria-hidden="true">
|
|
<div
|
|
class="absolute inset-0 bg-gray-500 opacity-75"
|
|
data-id="modal_backdrop"
|
|
/>
|
|
</div>
|
|
<span
|
|
class="hidden sm:inline-block sm:align-middle sm:h-screen"
|
|
aria-hidden="true">​</span
|
|
>
|
|
<div
|
|
class="inline-block align-bottom text-left shadow-xl transform transition-all sm:align-middle w-full lg:w-auto min-w-auto lg:min-w-[35vw]"
|
|
role="dialog"
|
|
aria-modal="true"
|
|
aria-labelledby="modal-headline"
|
|
>
|
|
<div class="bg-white px-4 pt-5 pb-4 sm:p-6 sm:pb-4 rounded-t-xl">
|
|
<div class="">
|
|
<div
|
|
class="flex-shrink-0 flex items-center justify-center size-12 rounded-full bg-blue-100 sm:mx-0 sm:h-10 sm:w-10"
|
|
>
|
|
<svg
|
|
class="h-6 w-6 text-blue-600"
|
|
fill="currentColor"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
viewBox="0 0 24 24"
|
|
><path fill="none" d="M0 0h24v24H0z" />
|
|
<path
|
|
d="M4 5v11h16V5H4zM2 4a1 1 0 011-1h18a1 1 0 011 1v14H2V4zM1 19h22v2H1v-2z"
|
|
/></svg
|
|
>
|
|
</div>
|
|
<div class="mt-3 sm:text-left max-h-[75vh] overflow-y-auto">
|
|
<h3 class="text-lg leading-6 font-medium text-gray-900">
|
|
{$_("token")}
|
|
</h3>
|
|
<div class="mb-6">
|
|
<p class="text-sm text-gray-500">
|
|
{$_(
|
|
"the-statsclient-api-token-will-only-get-displayed-once-you-wont-be-able-to-change-or-view-it-again"
|
|
)}
|
|
<br />
|
|
{$_("please-copy-the-token-and-store-it-somewhere-save")}
|
|
</p>
|
|
</div>
|
|
<div class="mb-6">
|
|
<label
|
|
for="token"
|
|
class="block text-sm font-medium text-gray-700"
|
|
>{$_("token")}</label
|
|
>
|
|
<button on:click={copy} class="inline-flex">
|
|
<p
|
|
name="token"
|
|
class:bg-green-200={copied}
|
|
class="mt-1 focus:ring-indigo-500 focus:border-indigo-500 block w-full shadow-sm rounded-l-md sm:text-sm border-gray-300 border bg-gray-50 text-neutral-800 p-2"
|
|
>
|
|
{new_client.key}
|
|
</p>
|
|
<div
|
|
class="bg-gray-200 border-gray-300 border-t border-b border-r text-black rounded-r-md sm:text-sm p-2 mt-1 cursor-pointer"
|
|
>
|
|
<svg
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
viewBox="0 0 24 24"
|
|
width="24"
|
|
height="24"
|
|
><path fill="none" d="M0 0h24v24H0z" />
|
|
<path
|
|
fill="currentColor"
|
|
d="M7 4V2h10v2h3l1 1v16a1 1 0 01-1 1H4a1 1 0 01-1-1V5l1-1h3zm0 2H5v14h14V6h-2v2H7V6zm2-2v2h6V4H9z"
|
|
/></svg
|
|
>
|
|
</div>
|
|
</button>
|
|
<p class="text-gray-500 text-xs">
|
|
{$_("click-to-copy-token-to-clipboard")}
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="bg-gray-50 px-4 lg:py-3 sm:px-6 grid gap-2 lg:rounded-b-xl pt-3 pb-10">
|
|
<button
|
|
on:click={close}
|
|
type="button"
|
|
class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-600 text-base font-medium text-white hover:bg-green-500 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-red-500"
|
|
>
|
|
{$_("yes-i-copied-the-token")}
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{/if}
|