@@ -5,13 +5,18 @@
 | 
			
		||||
  import Toastify from "toastify-js";
 | 
			
		||||
  import CardsEmptyState from "./CardsEmptyState.svelte";
 | 
			
		||||
  import CardDetailModal from "./CardDetailModal.svelte";
 | 
			
		||||
  import GenerateRunnerCards from "../pdf_generation/GenerateRunnerCards.svelte";
 | 
			
		||||
  export let edit_modal_open = false;
 | 
			
		||||
  export let runner = {};
 | 
			
		||||
  export let editable = {};
 | 
			
		||||
  export let original_data = {};
 | 
			
		||||
  export let current_cards = [];
 | 
			
		||||
  $: searchvalue = "";
 | 
			
		||||
  $: active_deletes = [];
 | 
			
		||||
  export let current_cards = [];
 | 
			
		||||
  $: cards_show = current_cards.some(
 | 
			
		||||
    (r) => r.is_selected === true
 | 
			
		||||
  );
 | 
			
		||||
  $: generate_cards = current_cards.filter((r) => r.is_selected === true);
 | 
			
		||||
  const cards_promise = RunnerCardService.runnerCardControllerGetAll().then(
 | 
			
		||||
    (val) => {
 | 
			
		||||
      current_cards = val;
 | 
			
		||||
@@ -53,6 +58,7 @@
 | 
			
		||||
{/if}
 | 
			
		||||
 | 
			
		||||
{#if store.state.jwtinfo.userdetails.permissions.includes('CARD:GET')}
 | 
			
		||||
{JSON.stringify(generate_cards)}
 | 
			
		||||
  {#await cards_promise}
 | 
			
		||||
    <div
 | 
			
		||||
      class="bg-teal-lightest border-t-4 border-teal rounded-b text-teal-darkest px-4 py-3 shadow-md my-2"
 | 
			
		||||
@@ -70,11 +76,32 @@
 | 
			
		||||
        placeholder={$_('datatable.search')}
 | 
			
		||||
        aria-label={$_('datatable.search')}
 | 
			
		||||
        class="gridjs-input gridjs-search-input mb-4" />
 | 
			
		||||
        <div class="h-12">
 | 
			
		||||
          <GenerateRunnerCards
 | 
			
		||||
            bind:cards_show
 | 
			
		||||
            bind:generate_cards />
 | 
			
		||||
        </div>
 | 
			
		||||
      <div
 | 
			
		||||
        class="shadow border-b border-gray-200 sm:rounded-lg overflow-x-scroll">
 | 
			
		||||
        <table class="divide-y divide-gray-200 w-full">
 | 
			
		||||
          <thead class="bg-gray-50">
 | 
			
		||||
            <tr>
 | 
			
		||||
              <th
 | 
			
		||||
                scope="col"
 | 
			
		||||
                class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
 | 
			
		||||
                <span
 | 
			
		||||
                  on:click={() => {
 | 
			
		||||
                    const newstate = !current_cards.some((r) => r.is_selected === true);
 | 
			
		||||
                    current_cards = current_cards.map((r) => {
 | 
			
		||||
                      r.is_selected = newstate;
 | 
			
		||||
                      return r;
 | 
			
		||||
                    });
 | 
			
		||||
                  }}
 | 
			
		||||
                  class="underline cursor-pointer select-none">{#if current_cards.some((r) => r.is_selected === true)}
 | 
			
		||||
                    {$_('deselect-all')}
 | 
			
		||||
                  {:else}{$_('select-all')}{/if}
 | 
			
		||||
                </span>
 | 
			
		||||
              </th>
 | 
			
		||||
              <th
 | 
			
		||||
                scope="col"
 | 
			
		||||
                class="px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider">
 | 
			
		||||
@@ -115,6 +142,12 @@
 | 
			
		||||
                    searchvalue.toLowerCase()
 | 
			
		||||
                  ) || should_display_based_on_id(card.id)}
 | 
			
		||||
                <tr data-rowid="card_{card.id}">
 | 
			
		||||
                  <td class="px-6 py-4 whitespace-nowrap">
 | 
			
		||||
                    <input
 | 
			
		||||
                      bind:checked={card.is_selected}
 | 
			
		||||
                      type="checkbox"
 | 
			
		||||
                      class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" />
 | 
			
		||||
                  </td>
 | 
			
		||||
                  <td class="px-6 py-4 whitespace-nowrap">
 | 
			
		||||
                    <div class="flex items-center">{card.code}</div>
 | 
			
		||||
                  </td>
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										305
									
								
								src/components/pdf_generation/GenerateRunnerCards.svelte
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										305
									
								
								src/components/pdf_generation/GenerateRunnerCards.svelte
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,305 @@
 | 
			
		||||
<script>
 | 
			
		||||
    import { getLocaleFromNavigator, _ } from "svelte-i18n";
 | 
			
		||||
    import { RunnerOrganizationService, RunnerTeamService } from "@odit/lfk-client-js";
 | 
			
		||||
    import Toastify from "toastify-js";
 | 
			
		||||
    export let cards_show = false;
 | 
			
		||||
    export let generate_cards = [];
 | 
			
		||||
    export let generate_runners = [];
 | 
			
		||||
    export let generate_orgs = [];
 | 
			
		||||
    export let generate_teams = [];
 | 
			
		||||
    $: cards_dropdown_open = false;
 | 
			
		||||
    document.addEventListener("click", function (e) {
 | 
			
		||||
        if (
 | 
			
		||||
            e.target.parentNode?.parentNode?.id != "cards:dropdown" &&
 | 
			
		||||
            e.target.parentNode?.parentNode?.id != "cards:dropdown:menu"
 | 
			
		||||
        ) {
 | 
			
		||||
            cards_dropdown_open = false;
 | 
			
		||||
        }
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    function generateRunnerCards(locale) {
 | 
			
		||||
        cards_dropdown_open = false;
 | 
			
		||||
 | 
			
		||||
        if (generate_orgs.length > 0) {
 | 
			
		||||
            generateOrgCards(locale);
 | 
			
		||||
        } else if (generate_teams.length > 0) {
 | 
			
		||||
            generateTeamCards(locale);
 | 
			
		||||
        } else if (generate_runners.length > 0){
 | 
			
		||||
            generateRunnersContracts(locale);
 | 
			
		||||
        }
 | 
			
		||||
        else{
 | 
			
		||||
            generateCards(locale)
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function generateCards(locale) {
 | 
			
		||||
        const toast = Toastify({
 | 
			
		||||
            text: $_("generating-pdf"),
 | 
			
		||||
            duration: -1,
 | 
			
		||||
        }).showToast();
 | 
			
		||||
        fetch(
 | 
			
		||||
            `${config.baseurl}/documents/cards?locale=${locale}&download=true&key=${config.documentserver_key}`,
 | 
			
		||||
            {
 | 
			
		||||
                method: "POST",
 | 
			
		||||
                headers: {
 | 
			
		||||
                    "Content-Type": "application/json",
 | 
			
		||||
                },
 | 
			
		||||
                body: JSON.stringify(generate_cards),
 | 
			
		||||
            }
 | 
			
		||||
        )
 | 
			
		||||
            .then((response) => {
 | 
			
		||||
                if (response.status != "200") {
 | 
			
		||||
                    toast.hideToast();
 | 
			
		||||
                    Toastify({
 | 
			
		||||
                        text: $_("pdf-generation-failed"),
 | 
			
		||||
                        duration: 3500,
 | 
			
		||||
                        backgroundColor:
 | 
			
		||||
                            "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)",
 | 
			
		||||
                    }).showToast();
 | 
			
		||||
                } else {
 | 
			
		||||
                    return response.blob();
 | 
			
		||||
                }
 | 
			
		||||
            })
 | 
			
		||||
            .then((blob) => {
 | 
			
		||||
                const url = window.URL.createObjectURL(blob);
 | 
			
		||||
                let a = document.createElement("a");
 | 
			
		||||
                a.href = url;
 | 
			
		||||
                a.download = "Runnercards.pdf";
 | 
			
		||||
                document.body.appendChild(a);
 | 
			
		||||
                a.click();
 | 
			
		||||
                a.remove();
 | 
			
		||||
                toast.hideToast();
 | 
			
		||||
                Toastify({
 | 
			
		||||
                    text: $_("pdf-successfully-generated"),
 | 
			
		||||
                    duration: 3500,
 | 
			
		||||
                    backgroundColor:
 | 
			
		||||
                        "linear-gradient(to right, #00b09b, #96c93d)",
 | 
			
		||||
                }).showToast();
 | 
			
		||||
            })
 | 
			
		||||
            .catch((err) => {
 | 
			
		||||
                console.error(err);
 | 
			
		||||
            });
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    async function generateTeamCards(locale) {
 | 
			
		||||
        const toast = Toastify({
 | 
			
		||||
            text: $_("generating-pdfs"),
 | 
			
		||||
            duration: -1,
 | 
			
		||||
        }).showToast();
 | 
			
		||||
        let count = 0;
 | 
			
		||||
        for await (const t of generate_teams) {
 | 
			
		||||
            count++;
 | 
			
		||||
            const runners = await RunnerTeamService.runnerTeamControllerGetRunners(
 | 
			
		||||
                t.id
 | 
			
		||||
            );
 | 
			
		||||
            fetch(
 | 
			
		||||
                `${config.baseurl}/documents/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`,
 | 
			
		||||
                {
 | 
			
		||||
                    method: "POST",
 | 
			
		||||
                    headers: {
 | 
			
		||||
                        "Content-Type": "application/json",
 | 
			
		||||
                    },
 | 
			
		||||
                    body: JSON.stringify(runners),
 | 
			
		||||
                }
 | 
			
		||||
            )
 | 
			
		||||
                .then((response) => {
 | 
			
		||||
                    if (response.status != "200") {
 | 
			
		||||
                        toast.hideToast();
 | 
			
		||||
                        Toastify({
 | 
			
		||||
                            text: $_("pdf-generation-failed"),
 | 
			
		||||
                            duration: 3500,
 | 
			
		||||
                            backgroundColor:
 | 
			
		||||
                                "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)",
 | 
			
		||||
                        }).showToast();
 | 
			
		||||
                    } else {
 | 
			
		||||
                        return response.blob();
 | 
			
		||||
                    }
 | 
			
		||||
                })
 | 
			
		||||
                .then((blob) => {
 | 
			
		||||
                    const url = window.URL.createObjectURL(blob);
 | 
			
		||||
                    let a = document.createElement("a");
 | 
			
		||||
                    a.href = url;
 | 
			
		||||
                    a.download = "Sponsorings_" + t.name + ".pdf";
 | 
			
		||||
                    document.body.appendChild(a);
 | 
			
		||||
                    a.click();
 | 
			
		||||
                    a.remove();
 | 
			
		||||
                    if (count === generate_teams.length) {
 | 
			
		||||
                        toast.hideToast();
 | 
			
		||||
                        Toastify({
 | 
			
		||||
                            text: $_("pdfs-successfully-generated"),
 | 
			
		||||
                            duration: 3500,
 | 
			
		||||
                            backgroundColor:
 | 
			
		||||
                                "linear-gradient(to right, #00b09b, #96c93d)",
 | 
			
		||||
                        }).showToast();
 | 
			
		||||
                    }
 | 
			
		||||
                })
 | 
			
		||||
                .catch((err) => {});
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    async function generateOrgCards(locale) {
 | 
			
		||||
        const toast = Toastify({
 | 
			
		||||
            text: $_("generating-pdf"),
 | 
			
		||||
            duration: -1,
 | 
			
		||||
        }).showToast();
 | 
			
		||||
        let count = 0;
 | 
			
		||||
        for await (const o of generate_orgs) {
 | 
			
		||||
            const runners = await RunnerOrganizationService.runnerOrganizationControllerGetRunners(
 | 
			
		||||
                o.id
 | 
			
		||||
            );
 | 
			
		||||
            fetch(
 | 
			
		||||
                `${config.baseurl}/documents/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`,
 | 
			
		||||
                {
 | 
			
		||||
                    method: "POST",
 | 
			
		||||
                    headers: {
 | 
			
		||||
                        "Content-Type": "application/json",
 | 
			
		||||
                    },
 | 
			
		||||
                    body: JSON.stringify(runners),
 | 
			
		||||
                }
 | 
			
		||||
            )
 | 
			
		||||
                .then((response) => {
 | 
			
		||||
                    if (response.status != "200") {
 | 
			
		||||
                        toast.hideToast();
 | 
			
		||||
                        Toastify({
 | 
			
		||||
                            text: $_("pdf-generation-failed"),
 | 
			
		||||
                            duration: 3500,
 | 
			
		||||
                            backgroundColor:
 | 
			
		||||
                                "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)",
 | 
			
		||||
                        }).showToast();
 | 
			
		||||
                    } else {
 | 
			
		||||
                        return response.blob();
 | 
			
		||||
                    }
 | 
			
		||||
                })
 | 
			
		||||
                .then((blob) => {
 | 
			
		||||
                    count++;
 | 
			
		||||
                    const url = window.URL.createObjectURL(blob);
 | 
			
		||||
                    let a = document.createElement("a");
 | 
			
		||||
                    a.href = url;
 | 
			
		||||
                    a.download = "Sponsorings_" + o.name + ".pdf";
 | 
			
		||||
                    document.body.appendChild(a);
 | 
			
		||||
                    a.click();
 | 
			
		||||
                    a.remove();
 | 
			
		||||
                    if (count === generate_orgs.length) {
 | 
			
		||||
                        toast.hideToast();
 | 
			
		||||
                        Toastify({
 | 
			
		||||
                            text: $_("pdfs-successfully-generated"),
 | 
			
		||||
                            duration: 3500,
 | 
			
		||||
                            backgroundColor:
 | 
			
		||||
                                "linear-gradient(to right, #00b09b, #96c93d)",
 | 
			
		||||
                        }).showToast();
 | 
			
		||||
                    }
 | 
			
		||||
                })
 | 
			
		||||
                .catch((err) => {});
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function generateRunnersContracts(locale) {
 | 
			
		||||
        const toast = Toastify({
 | 
			
		||||
            text: $_("generating-pdf"),
 | 
			
		||||
            duration: -1,
 | 
			
		||||
        }).showToast();
 | 
			
		||||
        fetch(
 | 
			
		||||
            `${config.baseurl}/documents/contracts?locale=${locale}&download=true&key=${config.documentserver_key}`,
 | 
			
		||||
            {
 | 
			
		||||
                method: "POST",
 | 
			
		||||
                headers: {
 | 
			
		||||
                    "Content-Type": "application/json",
 | 
			
		||||
                },
 | 
			
		||||
                body: JSON.stringify(generate_runners),
 | 
			
		||||
            }
 | 
			
		||||
        )
 | 
			
		||||
            .then((response) => {
 | 
			
		||||
                if (response.status != "200") {
 | 
			
		||||
                    toast.hideToast();
 | 
			
		||||
                    Toastify({
 | 
			
		||||
                        text: $_("pdf-generation-failed"),
 | 
			
		||||
                        duration: 3500,
 | 
			
		||||
                        backgroundColor:
 | 
			
		||||
                            "linear-gradient(90deg, hsla(281, 37%, 45%, 1) 0%, hsla(1, 62%, 48%, 1) 100%)",
 | 
			
		||||
                    }).showToast();
 | 
			
		||||
                } else {
 | 
			
		||||
                    return response.blob();
 | 
			
		||||
                }
 | 
			
		||||
            })
 | 
			
		||||
            .then((blob) => {
 | 
			
		||||
                const url = window.URL.createObjectURL(blob);
 | 
			
		||||
                let a = document.createElement("a");
 | 
			
		||||
                a.href = url;
 | 
			
		||||
                a.download = "Sponsoring.pdf";
 | 
			
		||||
                document.body.appendChild(a);
 | 
			
		||||
                a.click();
 | 
			
		||||
                a.remove();
 | 
			
		||||
                toast.hideToast();
 | 
			
		||||
                Toastify({
 | 
			
		||||
                    text: $_("pdf-successfully-generated"),
 | 
			
		||||
                    duration: 3500,
 | 
			
		||||
                    backgroundColor:
 | 
			
		||||
                        "linear-gradient(to right, #00b09b, #96c93d)",
 | 
			
		||||
                }).showToast();
 | 
			
		||||
            })
 | 
			
		||||
            .catch((err) => {
 | 
			
		||||
                console.error(err);
 | 
			
		||||
            });
 | 
			
		||||
    }
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
{#if cards_show}
 | 
			
		||||
    <div id="cards:dropdown" class="relative inline-block">
 | 
			
		||||
        <div>
 | 
			
		||||
            <button
 | 
			
		||||
                on:click={() => {
 | 
			
		||||
                    cards_dropdown_open = !cards_dropdown_open;
 | 
			
		||||
                }}
 | 
			
		||||
                type="button"
 | 
			
		||||
                class="w-full justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-gray-600 text-base font-medium text-white hover:bg-gray-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-gray-500 sm:ml-3 sm:w-auto sm:text-sm inline-flex"
 | 
			
		||||
                id="options-menu"
 | 
			
		||||
                aria-haspopup="true"
 | 
			
		||||
                aria-expanded="true">
 | 
			
		||||
                {$_('generate-sponsoring-contracts')}
 | 
			
		||||
                <svg
 | 
			
		||||
                    xmlns="http://www.w3.org/2000/svg"
 | 
			
		||||
                    width="24"
 | 
			
		||||
                    height="24"
 | 
			
		||||
                    viewBox="0 0 24 24"
 | 
			
		||||
                    class="-mr-1 ml-2 h-5 w-5"><path
 | 
			
		||||
                        fill="none"
 | 
			
		||||
                        d="M0 0h24v24H0z" />
 | 
			
		||||
                    <path
 | 
			
		||||
                        fill="currentColor"
 | 
			
		||||
                        d="M3 19h18v2H3v-2zm10-5.83l6.07-6.07 1.42 1.41L12 17 3.52 8.52l1.4-1.42L11 13.17V2h2v11.17z" /></svg>
 | 
			
		||||
            </button>
 | 
			
		||||
        </div>
 | 
			
		||||
        {#if cards_dropdown_open}
 | 
			
		||||
            <div
 | 
			
		||||
                class="origin-top-right absolute right-0 mt-2 w-56 rounded-md shadow-lg bg-white ring-1 ring-black ring-opacity-5"
 | 
			
		||||
                id="cards:dropdown:menu">
 | 
			
		||||
                <div
 | 
			
		||||
                    class="py-1"
 | 
			
		||||
                    role="menu"
 | 
			
		||||
                    aria-orientation="vertical"
 | 
			
		||||
                    aria-labelledby="options-menu">
 | 
			
		||||
                    <span
 | 
			
		||||
                        class="block w-full text-left px-4 py-2 text-sm text-gray-700">{$_('select-language')}</span>
 | 
			
		||||
                    <button
 | 
			
		||||
                        on:click={() => {
 | 
			
		||||
                            generateRunnerCards('de');
 | 
			
		||||
                        }}
 | 
			
		||||
                        type="submit"
 | 
			
		||||
                        class="block w-full text-left px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-900 focus:outline-none focus:bg-gray-100 focus:text-gray-900"
 | 
			
		||||
                        role="menuitem">
 | 
			
		||||
                        {$_('german')}
 | 
			
		||||
                    </button>
 | 
			
		||||
                    <button
 | 
			
		||||
                        on:click={() => {
 | 
			
		||||
                            generateRunnerCards('en');
 | 
			
		||||
                        }}
 | 
			
		||||
                        type="submit"
 | 
			
		||||
                        class="block w-full text-left px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-900 focus:outline-none focus:bg-gray-100 focus:text-gray-900"
 | 
			
		||||
                        role="menuitem">
 | 
			
		||||
                        {$_('english')}
 | 
			
		||||
                    </button>
 | 
			
		||||
                </div>
 | 
			
		||||
            </div>
 | 
			
		||||
        {/if}
 | 
			
		||||
    </div>
 | 
			
		||||
{/if}
 | 
			
		||||
		Reference in New Issue
	
	Block a user