Compare commits
	
		
			20 Commits
		
	
	
		
			834ff8fa63
			...
			0.12.5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 331d737796 | |||
| ef81b8adf9 | |||
| 8a7d635cef | |||
| 4c259c1eef | |||
| 5b4ede5e2f | |||
| d0ab3dda78 | |||
| d9cf51b4bb | |||
| aa17f24220 | |||
| cf60edf7d4 | |||
| ffbc243194 | |||
| b6b07cf30c | |||
| 495a6b22bd | |||
| 0acaffbdfa | |||
| 6043bc4517 | |||
| e6ed066e3f | |||
| ee4e8655b8 | |||
| 37970d2be6 | |||
| 1376788016 | |||
| 4cad86cf85 | |||
| 6304116edb | 
							
								
								
									
										39
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@@ -2,8 +2,47 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
All notable changes to this project will be documented in this file. Dates are displayed in UTC.
 | 
					All notable changes to this project will be documented in this file. Dates are displayed in UTC.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#### [0.12.5](https://git.odit.services/lfk/frontend/compare/0.12.4...0.12.5)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Merge pull request 'Added runner team's parentorg name to runenr overciew' (#129) from feature/128-runner_orgs into dev [`ef81b8a`](https://git.odit.services/lfk/frontend/commit/ef81b8adf9bef685a55936d7544bf645c0d6ecbe)
 | 
				
			||||||
 | 
					- Switched to html entity [`8a7d635`](https://git.odit.services/lfk/frontend/commit/8a7d635cef2d465e70c84e1f7a7b90b98a8dbab1)
 | 
				
			||||||
 | 
					- Added runner team's parentorg name to runenr overciew [`4c259c1`](https://git.odit.services/lfk/frontend/commit/4c259c1eef2b0166ce6a8493d0c9e9d5ede11146)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#### [0.12.4](https://git.odit.services/lfk/frontend/compare/0.12.3...0.12.4)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					> 8 April 2021
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- 🚀RELEASE v0.12.4 [`5b4ede5`](https://git.odit.services/lfk/frontend/commit/5b4ede5e2f6a26b475a7a4b430a4146d21fb9671)
 | 
				
			||||||
 | 
					- 🚑 [HOTFIX] - drop "svelte-infinite-loading" [`d0ab3dd`](https://git.odit.services/lfk/frontend/commit/d0ab3dda78bbad2cea18a2491056530897d56607)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#### [0.12.3](https://git.odit.services/lfk/frontend/compare/0.12.2...0.12.3)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					> 8 April 2021
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Merge pull request 'fix' (#126) from bugfix/125-mobile into dev [`#125`](https://git.odit.services/lfk/frontend/issues/125)
 | 
				
			||||||
 | 
					- almost fixed... [`495a6b2`](https://git.odit.services/lfk/frontend/commit/495a6b22bd8036593f390bdb862d325524cefbcc)
 | 
				
			||||||
 | 
					- 🐞 bugfix for svelte x tailwind class names [`b6b07cf`](https://git.odit.services/lfk/frontend/commit/b6b07cf30cc6533bd5dbfec1f813c16fde85634d)
 | 
				
			||||||
 | 
					- fix [`0acaffb`](https://git.odit.services/lfk/frontend/commit/0acaffbdfa359e52654a5afe2788aa59fe6f9036)
 | 
				
			||||||
 | 
					- 🚀RELEASE v0.12.3 [`d9cf51b`](https://git.odit.services/lfk/frontend/commit/d9cf51b4bbc2136594a03c5d0eeb8cb3f3440b2a)
 | 
				
			||||||
 | 
					- custom css fix for collapsed_navigation [`ffbc243`](https://git.odit.services/lfk/frontend/commit/ffbc243194c7faeb4fe61c12711a1c441c3994ef)
 | 
				
			||||||
 | 
					- new license file version [CI SKIP] [`aa17f24`](https://git.odit.services/lfk/frontend/commit/aa17f242209f7e7cecff774ace7a35b581adec1f)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#### [0.12.2](https://git.odit.services/lfk/frontend/compare/0.12.1...0.12.2)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					> 7 April 2021
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- 🚀RELEASE v0.12.2 [`6043bc4`](https://git.odit.services/lfk/frontend/commit/6043bc45174d51ab110b0ed10a8679d96127ab87)
 | 
				
			||||||
 | 
					- Merge pull request 'feature/110-virtual_list' (#124) from feature/110-virtual_list into dev [`e6ed066`](https://git.odit.services/lfk/frontend/commit/e6ed066e3ffabba6519f94d801d21a27819d0492)
 | 
				
			||||||
 | 
					- wip on virtuallist [`6304116`](https://git.odit.services/lfk/frontend/commit/6304116edb7f5e3c7b67c15e0b1740d34c513155)
 | 
				
			||||||
 | 
					- fixed height table [`4cad86c`](https://git.odit.services/lfk/frontend/commit/4cad86cf852468428d77103d052c6974b17c34c3)
 | 
				
			||||||
 | 
					- pre-merge fixes [`37970d2`](https://git.odit.services/lfk/frontend/commit/37970d2be6b6502701914e41e5bfe2c418438480)
 | 
				
			||||||
 | 
					- updated virtual scroll list [`1376788`](https://git.odit.services/lfk/frontend/commit/1376788016e767f006661f8c9e6747781f2dce55)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### [0.12.1](https://git.odit.services/lfk/frontend/compare/0.12.0...0.12.1)
 | 
					#### [0.12.1](https://git.odit.services/lfk/frontend/compare/0.12.0...0.12.1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					> 6 April 2021
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- 🚀RELEASE v0.12.1 [`834ff8f`](https://git.odit.services/lfk/frontend/commit/834ff8fa63178f36dcacf931c128ba67a3e7bd1b)
 | 
				
			||||||
- Merge pull request 'ImportRunnerModal Cancel Button feature/122-import_cancel' (#123) from feature/112-import_cancel into dev [`1f428a5`](https://git.odit.services/lfk/frontend/commit/1f428a535e3ae619cbf8db51d04255aac8dd8614)
 | 
					- Merge pull request 'ImportRunnerModal Cancel Button feature/122-import_cancel' (#123) from feature/112-import_cancel into dev [`1f428a5`](https://git.odit.services/lfk/frontend/commit/1f428a535e3ae619cbf8db51d04255aac8dd8614)
 | 
				
			||||||
- Added cancel button for the first stage of runner import [`0c40966`](https://git.odit.services/lfk/frontend/commit/0c409669700d3a8096cc04716154b0fdca458fe5)
 | 
					- Added cancel button for the first stage of runner import [`0c40966`](https://git.odit.services/lfk/frontend/commit/0c409669700d3a8096cc04716154b0fdca458fe5)
 | 
				
			||||||
- Escape now triggers foll modal close (including reset) instead of just hiding th modal [`9da071f`](https://git.odit.services/lfk/frontend/commit/9da071fe9ba067160334682bf00163e3630fe919)
 | 
					- Escape now triggers foll modal close (including reset) instead of just hiding th modal [`9da071f`](https://git.odit.services/lfk/frontend/commit/9da071fe9ba067160334682bf00163e3630fe919)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -13,7 +13,7 @@
 | 
				
			|||||||
</head>
 | 
					</head>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<body>
 | 
					<body>
 | 
				
			||||||
  <span style="display: none;visibility: hidden;" id="buildinfo">RELEASE_INFO-0.12.1-RELEASE_INFO</span>
 | 
					  <span style="display: none;visibility: hidden;" id="buildinfo">RELEASE_INFO-0.12.5-RELEASE_INFO</span>
 | 
				
			||||||
  <noscript>You need to enable JavaScript to run this app.</noscript>
 | 
					  <noscript>You need to enable JavaScript to run this app.</noscript>
 | 
				
			||||||
  <script src="/env.js"></script>
 | 
					  <script src="/env.js"></script>
 | 
				
			||||||
  <script type="module" src="/src/main.js"></script>
 | 
					  <script type="module" src="/src/main.js"></script>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	"name": "@odit/lfk-frontend",
 | 
						"name": "@odit/lfk-frontend",
 | 
				
			||||||
	"version": "0.12.1",
 | 
						"version": "0.12.5",
 | 
				
			||||||
	"scripts": {
 | 
						"scripts": {
 | 
				
			||||||
		"i18n-order": "node order.js",
 | 
							"i18n-order": "node order.js",
 | 
				
			||||||
		"dev": "vite",
 | 
							"dev": "vite",
 | 
				
			||||||
@@ -13,7 +13,7 @@
 | 
				
			|||||||
		"check-password-strength": "2.0.2",
 | 
							"check-password-strength": "2.0.2",
 | 
				
			||||||
		"@odit/lfk-client-js": "0.10.1",
 | 
							"@odit/lfk-client-js": "0.10.1",
 | 
				
			||||||
		"@odit/license-exporter": "0.0.11",
 | 
							"@odit/license-exporter": "0.0.11",
 | 
				
			||||||
		"@sveltejs/vite-plugin-svelte": "1.0.0-next.5",
 | 
							"@sveltejs/vite-plugin-svelte": "1.0.0-next.6",
 | 
				
			||||||
		"@types/html-minifier": "4.0.0",
 | 
							"@types/html-minifier": "4.0.0",
 | 
				
			||||||
		"auto-changelog": "2.2.1",
 | 
							"auto-changelog": "2.2.1",
 | 
				
			||||||
		"autoprefixer": "10.2.5",
 | 
							"autoprefixer": "10.2.5",
 | 
				
			||||||
@@ -28,12 +28,12 @@
 | 
				
			|||||||
		"svelte-i18n": "3.3.9",
 | 
							"svelte-i18n": "3.3.9",
 | 
				
			||||||
		"svelte-preprocess": "4.7.0",
 | 
							"svelte-preprocess": "4.7.0",
 | 
				
			||||||
		"svelte-select": "3.17.0",
 | 
							"svelte-select": "3.17.0",
 | 
				
			||||||
		"tailwindcss": "2.0.4",
 | 
							"tailwindcss": "2.1.1",
 | 
				
			||||||
		"tinro": "0.6.1",
 | 
							"tinro": "0.6.1",
 | 
				
			||||||
		"toastify-js": "1.10.0",
 | 
							"toastify-js": "1.10.0",
 | 
				
			||||||
		"validator": "13.5.2",
 | 
							"validator": "13.5.2",
 | 
				
			||||||
		"vite": "2.1.5",
 | 
							"vite": "2.1.5",
 | 
				
			||||||
		"vite-plugin-windicss": "0.12.2",
 | 
							"vite-plugin-windicss": "0.12.5",
 | 
				
			||||||
		"xlsx": "0.16.9"
 | 
							"xlsx": "0.16.9"
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	"release-it": {
 | 
						"release-it": {
 | 
				
			||||||
 
 | 
				
			|||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							@@ -1,5 +1,5 @@
 | 
				
			|||||||
<script>
 | 
					<script>
 | 
				
			||||||
  import { getLocaleFromNavigator, json, _ } from "svelte-i18n";
 | 
					  import { _ } from "svelte-i18n";
 | 
				
			||||||
  import { RunnerCardService } from "@odit/lfk-client-js";
 | 
					  import { RunnerCardService } from "@odit/lfk-client-js";
 | 
				
			||||||
  import store from "../../store";
 | 
					  import store from "../../store";
 | 
				
			||||||
  import Toastify from "toastify-js";
 | 
					  import Toastify from "toastify-js";
 | 
				
			||||||
@@ -11,11 +11,21 @@
 | 
				
			|||||||
  export let editable = {};
 | 
					  export let editable = {};
 | 
				
			||||||
  export let original_data = {};
 | 
					  export let original_data = {};
 | 
				
			||||||
  export let current_cards = [];
 | 
					  export let current_cards = [];
 | 
				
			||||||
 | 
					  $: filtered_cards = current_cards.filter(function (c) {
 | 
				
			||||||
 | 
					    if (
 | 
				
			||||||
 | 
					      c.code.toLowerCase().includes(searchvalue_lowercase) ||
 | 
				
			||||||
 | 
					      c.runner?.firstname.toLowerCase().includes(searchvalue_lowercase) ||
 | 
				
			||||||
 | 
					      c.runner?.middlename.toLowerCase().includes(searchvalue_lowercase) ||
 | 
				
			||||||
 | 
					      c.runner?.lastname.toLowerCase().includes(searchvalue_lowercase) ||
 | 
				
			||||||
 | 
					      should_display_based_on_id(c.id)
 | 
				
			||||||
 | 
					    ) {
 | 
				
			||||||
 | 
					      return true;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  });
 | 
				
			||||||
  $: searchvalue = "";
 | 
					  $: searchvalue = "";
 | 
				
			||||||
 | 
					  $: searchvalue_lowercase = searchvalue.toLowerCase();
 | 
				
			||||||
  $: active_deletes = [];
 | 
					  $: active_deletes = [];
 | 
				
			||||||
  $: cards_show = current_cards.some(
 | 
					  $: cards_show = current_cards.some((r) => r.is_selected === true);
 | 
				
			||||||
    (r) => r.is_selected === true
 | 
					 | 
				
			||||||
  );
 | 
					 | 
				
			||||||
  $: generate_cards = current_cards.filter((r) => r.is_selected === true);
 | 
					  $: generate_cards = current_cards.filter((r) => r.is_selected === true);
 | 
				
			||||||
  const cards_promise = RunnerCardService.runnerCardControllerGetAll().then(
 | 
					  const cards_promise = RunnerCardService.runnerCardControllerGetAll().then(
 | 
				
			||||||
    (val) => {
 | 
					    (val) => {
 | 
				
			||||||
@@ -46,8 +56,38 @@
 | 
				
			|||||||
    original_data = Object.assign(original_data, card);
 | 
					    original_data = Object.assign(original_data, card);
 | 
				
			||||||
    edit_modal_open = true;
 | 
					    edit_modal_open = true;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					// -----------------
 | 
				
			||||||
 | 
					  let scrollTop = 0;
 | 
				
			||||||
 | 
					  $: rendered = filtered_cards;
 | 
				
			||||||
 | 
					  let innerHeight = 0;
 | 
				
			||||||
 | 
					  let ele;
 | 
				
			||||||
 | 
					  $: updateSlice(scrollTop);
 | 
				
			||||||
 | 
					  $: innerHeight = `${filtered_cards.length * 25}px`;
 | 
				
			||||||
 | 
					  $: if (ele) updateSlice();
 | 
				
			||||||
 | 
					  function updateSlice() {
 | 
				
			||||||
 | 
					    const height = ele ? parseInt(ele.clientHeight) : 100;
 | 
				
			||||||
 | 
					    const init = scrollTop / 25;
 | 
				
			||||||
 | 
					    const end = Math.ceil((scrollTop + height) / 25);
 | 
				
			||||||
 | 
					    rendered = filtered_cards.slice(init, end + 15);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  function updateScroll($event) {
 | 
				
			||||||
 | 
					    scrollTop = $event.target.scrollTop;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style>
 | 
				
			||||||
 | 
					  table tbody {
 | 
				
			||||||
 | 
					  display: block;
 | 
				
			||||||
 | 
					  overflow-y: scroll;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					table thead, table tbody tr {
 | 
				
			||||||
 | 
					  display: table;
 | 
				
			||||||
 | 
					  width: 100%;
 | 
				
			||||||
 | 
					  table-layout: fixed;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
{#if store.state.jwtinfo.userdetails.permissions.includes('CARD:UPDATE')}
 | 
					{#if store.state.jwtinfo.userdetails.permissions.includes('CARD:UPDATE')}
 | 
				
			||||||
  <CardDetailModal
 | 
					  <CardDetailModal
 | 
				
			||||||
    bind:current_cards
 | 
					    bind:current_cards
 | 
				
			||||||
@@ -121,107 +161,111 @@
 | 
				
			|||||||
              </th>
 | 
					              </th>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
          </thead>
 | 
					          </thead>
 | 
				
			||||||
          <tbody class="divide-y divide-gray-200">
 | 
					          <tbody class="divide-y divide-gray-200 virtual-wrapper"
 | 
				
			||||||
            {#each current_cards as card}
 | 
					  on:scroll={updateScroll}
 | 
				
			||||||
              {#if card.code
 | 
					  style="height: 70vh; width:100%"
 | 
				
			||||||
                .toLowerCase()
 | 
					  bind:this={ele}
 | 
				
			||||||
                .includes(
 | 
					          >
 | 
				
			||||||
                  searchvalue.toLowerCase()
 | 
					    {#each filtered_cards as card, index}
 | 
				
			||||||
                ) || card.runner?.firstname
 | 
					    {#if card.code
 | 
				
			||||||
                  .toLowerCase()
 | 
					      .toLowerCase()
 | 
				
			||||||
                  .includes(
 | 
					      .includes(
 | 
				
			||||||
                    searchvalue.toLowerCase()
 | 
					        searchvalue.toLowerCase()
 | 
				
			||||||
                  ) || card.runner?.middlename
 | 
					      ) || card.runner?.firstname
 | 
				
			||||||
                  .toLowerCase()
 | 
					        .toLowerCase()
 | 
				
			||||||
                  .includes(
 | 
					        .includes(
 | 
				
			||||||
                    searchvalue.toLowerCase()
 | 
					          searchvalue.toLowerCase()
 | 
				
			||||||
                  ) || card.runner?.lastname
 | 
					        ) || card.runner?.middlename
 | 
				
			||||||
                  .toLowerCase()
 | 
					        .toLowerCase()
 | 
				
			||||||
                  .includes(
 | 
					        .includes(
 | 
				
			||||||
                    searchvalue.toLowerCase()
 | 
					          searchvalue.toLowerCase()
 | 
				
			||||||
                  ) || should_display_based_on_id(card.id)}
 | 
					        ) || card.runner?.lastname
 | 
				
			||||||
                <tr data-rowid="card_{card.id}">
 | 
					        .toLowerCase()
 | 
				
			||||||
                  <td class="px-6 py-4 whitespace-nowrap">
 | 
					        .includes(
 | 
				
			||||||
                    <input
 | 
					          searchvalue.toLowerCase()
 | 
				
			||||||
                      bind:checked={card.is_selected}
 | 
					        ) || should_display_based_on_id(card.id)}
 | 
				
			||||||
                      type="checkbox"
 | 
					      <tr data-rowid="card_{card.id}">
 | 
				
			||||||
                      class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" />
 | 
					        <td class="px-6 py-4 whitespace-nowrap">
 | 
				
			||||||
                  </td>
 | 
					          <input
 | 
				
			||||||
                  <td class="px-6 py-4 whitespace-nowrap">
 | 
					            bind:checked={card.is_selected}
 | 
				
			||||||
                    <div class="flex items-center">{card.code}</div>
 | 
					            type="checkbox"
 | 
				
			||||||
                  </td>
 | 
					            class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" />
 | 
				
			||||||
                  <td class="px-6 py-4 whitespace-nowrap">
 | 
					        </td>
 | 
				
			||||||
                    <div class="flex items-center">
 | 
					        <td class="px-6 py-4 whitespace-nowrap">
 | 
				
			||||||
                      {#if card.runner}
 | 
					          <div class="flex items-center">{card.code}</div>
 | 
				
			||||||
                        <a
 | 
					        </td>
 | 
				
			||||||
                          href="../runners/{card.runner.id}"
 | 
					        <td class="px-6 py-4 whitespace-nowrap">
 | 
				
			||||||
                          class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{card.runner.firstname}
 | 
					          <div class="flex items-center">
 | 
				
			||||||
                          {card.runner.middlename || ''}
 | 
					            {#if card.runner}
 | 
				
			||||||
                          {card.runner.lastname}</a>
 | 
					              <a
 | 
				
			||||||
                      {:else}{$_('non-blanko')}{/if}
 | 
					                href="../runners/{card.runner.id}"
 | 
				
			||||||
                    </div>
 | 
					                class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{card.runner.firstname}
 | 
				
			||||||
                  </td>
 | 
					                {card.runner.middlename || ''}
 | 
				
			||||||
                  <td class="px-6 py-4 whitespace-nowrap">
 | 
					                {card.runner.lastname}</a>
 | 
				
			||||||
                    <div class="flex items-center">
 | 
					            {:else}{$_('non-blanko')}{/if}
 | 
				
			||||||
                      {#if card.enabled}
 | 
					          </div>
 | 
				
			||||||
                        <span
 | 
					        </td>
 | 
				
			||||||
                          class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-green-100 text-green-800">{$_('enabled')}</span>
 | 
					        <td class="px-6 py-4 whitespace-nowrap">
 | 
				
			||||||
                      {:else}
 | 
					          <div class="flex items-center">
 | 
				
			||||||
                        <span
 | 
					            {#if card.enabled}
 | 
				
			||||||
                          class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-red-100 text-red-800">{$_('disabled')}</span>
 | 
					              <span
 | 
				
			||||||
                      {/if}
 | 
					                class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-green-100 text-green-800">{$_('enabled')}</span>
 | 
				
			||||||
                    </div>
 | 
					            {:else}
 | 
				
			||||||
                  </td>
 | 
					              <span
 | 
				
			||||||
 | 
					                class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-red-100 text-red-800">{$_('disabled')}</span>
 | 
				
			||||||
 | 
					            {/if}
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </td>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                  {#if active_deletes[card.id] === true}
 | 
					        {#if active_deletes[card.id] === true}
 | 
				
			||||||
                    <td
 | 
					          <td
 | 
				
			||||||
                      class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
 | 
					            class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
 | 
				
			||||||
                      <button
 | 
					            <button
 | 
				
			||||||
                        on:click={() => {
 | 
					              on:click={() => {
 | 
				
			||||||
                          active_deletes[card.id] = false;
 | 
					                active_deletes[card.id] = false;
 | 
				
			||||||
                        }}
 | 
					              }}
 | 
				
			||||||
                        tabindex="0"
 | 
					              tabindex="0"
 | 
				
			||||||
                        class="ml-4 text-indigo-600 hover:text-indigo-900 cursor-pointer">{$_('cancel-delete')}</button>
 | 
					              class="ml-4 text-indigo-600 hover:text-indigo-900 cursor-pointer">{$_('cancel-delete')}</button>
 | 
				
			||||||
                      <button
 | 
					            <button
 | 
				
			||||||
                        on:click={() => {
 | 
					              on:click={() => {
 | 
				
			||||||
                          RunnerCardService.runnerCardControllerRemove(card.id, false).then(
 | 
					                RunnerCardService.runnerCardControllerRemove(card.id, false).then(
 | 
				
			||||||
                            (resp) => {
 | 
					                  (resp) => {
 | 
				
			||||||
                              current_cards = current_cards.filter(
 | 
					                    current_cards = current_cards.filter(
 | 
				
			||||||
                                (obj) => obj.id !== card.id
 | 
					                      (obj) => obj.id !== card.id
 | 
				
			||||||
                              );
 | 
					                    );
 | 
				
			||||||
                              Toastify({
 | 
					                    Toastify({
 | 
				
			||||||
                                text: $_('card-deleted'),
 | 
					                      text: $_('card-deleted'),
 | 
				
			||||||
                                duration: 500,
 | 
					                      duration: 500,
 | 
				
			||||||
                                backgroundColor:
 | 
					                      backgroundColor:
 | 
				
			||||||
                                  'linear-gradient(to right, #00b09b, #96c93d)',
 | 
					                        'linear-gradient(to right, #00b09b, #96c93d)',
 | 
				
			||||||
                              }).showToast();
 | 
					                    }).showToast();
 | 
				
			||||||
                            }
 | 
					                  }
 | 
				
			||||||
                          );
 | 
					                );
 | 
				
			||||||
                        }}
 | 
					              }}
 | 
				
			||||||
                        tabindex="0"
 | 
					              tabindex="0"
 | 
				
			||||||
                        class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('confirm-delete')}</button>
 | 
					              class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('confirm-delete')}</button>
 | 
				
			||||||
                    </td>
 | 
					          </td>
 | 
				
			||||||
                  {:else}
 | 
					        {:else}
 | 
				
			||||||
                    <td
 | 
					          <td
 | 
				
			||||||
                      class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
 | 
					            class="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
 | 
				
			||||||
                      <button
 | 
					            <button
 | 
				
			||||||
                        on:click={() => {
 | 
					              on:click={() => {
 | 
				
			||||||
                          open_edit_modal(card);
 | 
					                open_edit_modal(card);
 | 
				
			||||||
                        }}
 | 
					              }}
 | 
				
			||||||
                        class="text-indigo-600 hover:text-indigo-900">{$_('details')}</button>
 | 
					              class="text-indigo-600 hover:text-indigo-900">{$_('details')}</button>
 | 
				
			||||||
                      {#if store.state.jwtinfo.userdetails.permissions.includes('CARD:DELETE')}
 | 
					            {#if store.state.jwtinfo.userdetails.permissions.includes('CARD:DELETE')}
 | 
				
			||||||
                        <button
 | 
					              <button
 | 
				
			||||||
                          on:click={() => {
 | 
					                on:click={() => {
 | 
				
			||||||
                            active_deletes[card.id] = true;
 | 
					                  active_deletes[card.id] = true;
 | 
				
			||||||
                          }}
 | 
					                }}
 | 
				
			||||||
                          tabindex="0"
 | 
					                tabindex="0"
 | 
				
			||||||
                          class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('delete')}</button>
 | 
					                class="ml-4 text-red-600 hover:text-red-900 cursor-pointer">{$_('delete')}</button>
 | 
				
			||||||
                      {/if}
 | 
					            {/if}
 | 
				
			||||||
                    </td>
 | 
					          </td>
 | 
				
			||||||
                  {/if}
 | 
					        {/if}
 | 
				
			||||||
                </tr>
 | 
					      </tr>
 | 
				
			||||||
              {/if}
 | 
					    {/if}
 | 
				
			||||||
            {/each}
 | 
					    {/each}
 | 
				
			||||||
          </tbody>
 | 
					          </tbody>
 | 
				
			||||||
        </table>
 | 
					        </table>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -12,11 +12,21 @@
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style>
 | 
				
			||||||
 | 
					  .collapsed_navigation {
 | 
				
			||||||
 | 
					    transform: translateX(-100%);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  @media (min-width: 768px) {
 | 
				
			||||||
 | 
					    .collapsed_navigation {
 | 
				
			||||||
 | 
					      transform: translateX(0px);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<section class="min-h-screen bg-gray-50">
 | 
					<section class="min-h-screen bg-gray-50">
 | 
				
			||||||
  <nav
 | 
					  <div
 | 
				
			||||||
    class:-translate-x-full={!navOpen}
 | 
					    class:collapsed_navigation={!navOpen}
 | 
				
			||||||
    class:translate-x-0={navOpen}
 | 
					    class="select-none fixed top-0 left-0 z-20 h-full pb-10 overflow-x-hidden overflow-y-auto transition origin-left transform border-r w-60 bg-gray-50">
 | 
				
			||||||
    class="select-none fixed top-0 left-0 z-20 h-full pb-10 overflow-x-hidden overflow-y-auto transition origin-left transform border-r w-60 md:translate-x-0 bg-gray-50">
 | 
					 | 
				
			||||||
    <a href="/" class="flex items-center px-4 py-5">
 | 
					    <a href="/" class="flex items-center px-4 py-5">
 | 
				
			||||||
      <img src="/lfk-logo.png" alt="Logo" class="h-10" />
 | 
					      <img src="/lfk-logo.png" alt="Logo" class="h-10" />
 | 
				
			||||||
      <h3 class="text-lg">Lauf für Kaya! Admin</h3>
 | 
					      <h3 class="text-lg">Lauf für Kaya! Admin</h3>
 | 
				
			||||||
@@ -297,14 +307,15 @@
 | 
				
			|||||||
        <span>{$_('logout')}</span>
 | 
					        <span>{$_('logout')}</span>
 | 
				
			||||||
      </span>
 | 
					      </span>
 | 
				
			||||||
    </nav>
 | 
					    </nav>
 | 
				
			||||||
  </nav>
 | 
					  </div>
 | 
				
			||||||
  <div class="ml-0 transition md:ml-60">
 | 
					  <div class="ml-0 transition md:ml-60">
 | 
				
			||||||
    <header
 | 
					    <header
 | 
				
			||||||
      on:click={() => {
 | 
					 | 
				
			||||||
        navOpen = true;
 | 
					 | 
				
			||||||
      }}
 | 
					 | 
				
			||||||
      class="flex items-center justify-between w-full px-4 bg-white border-b h-14 md:hidden">
 | 
					      class="flex items-center justify-between w-full px-4 bg-white border-b h-14 md:hidden">
 | 
				
			||||||
      <button class="block btn btn-light md:hidden">
 | 
					      <button
 | 
				
			||||||
 | 
					        on:click={() => {
 | 
				
			||||||
 | 
					          navOpen = true;
 | 
				
			||||||
 | 
					        }}
 | 
				
			||||||
 | 
					        class="block btn btn-light md:hidden">
 | 
				
			||||||
        <span class="sr-only">Menu</span><svg
 | 
					        <span class="sr-only">Menu</span><svg
 | 
				
			||||||
          class="w-4 h-4"
 | 
					          class="w-4 h-4"
 | 
				
			||||||
          xmlns="http://www.w3.org/2000/svg"
 | 
					          xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
@@ -318,10 +329,13 @@
 | 
				
			|||||||
      <NoComponentLoaded />
 | 
					      <NoComponentLoaded />
 | 
				
			||||||
    </slot>
 | 
					    </slot>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
  <div
 | 
					  {#if navOpen === true}
 | 
				
			||||||
    on:click={() => {
 | 
					    <div
 | 
				
			||||||
      navOpen = false;
 | 
					      on:click={() => {
 | 
				
			||||||
    }}
 | 
					        navOpen = false;
 | 
				
			||||||
    class:hidden={!navOpen}
 | 
					        console.log({ navOpen });
 | 
				
			||||||
    class="fixed inset-0 z-10 w-screen h-screen bg-black bg-opacity-25 md:hidden" />
 | 
					      }}
 | 
				
			||||||
 | 
					      class:hidden={!navOpen}
 | 
				
			||||||
 | 
					      class="fixed inset-0 z-10 w-screen h-screen bg-black bg-opacity-25 md:hidden" />
 | 
				
			||||||
 | 
					  {/if}
 | 
				
			||||||
</section>
 | 
					</section>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -197,7 +197,7 @@
 | 
				
			|||||||
                      {#if runner.group.responseType === 'RUNNERTEAM'}
 | 
					                      {#if runner.group.responseType === 'RUNNERTEAM'}
 | 
				
			||||||
                        <a
 | 
					                        <a
 | 
				
			||||||
                          href="../teams/{runner.group.id}"
 | 
					                          href="../teams/{runner.group.id}"
 | 
				
			||||||
                          class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{runner.group.name}</a>
 | 
					                          class="px-2 inline-flex text-xs leading-5 font-semibold rounded-full bg-gray-100 text-gray-800">{runner.group.parentGroup.name} > {runner.group.name}</a>
 | 
				
			||||||
                      {/if}
 | 
					                      {/if}
 | 
				
			||||||
                      {#if runner.group.responseType === 'RUNNERORGANIZATION'}
 | 
					                      {#if runner.group.responseType === 'RUNNERORGANIZATION'}
 | 
				
			||||||
                        <a
 | 
					                        <a
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user