Compare commits
	
		
			5 Commits
		
	
	
		
			0.12.1
			...
			ee4e8655b8
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| ee4e8655b8 | |||
| 37970d2be6 | |||
| 1376788016 | |||
| 4cad86cf85 | |||
| 6304116edb | 
@@ -1,5 +1,6 @@
 | 
				
			|||||||
<script>
 | 
					<script>
 | 
				
			||||||
  import { getLocaleFromNavigator, json, _ } from "svelte-i18n";
 | 
					  import { getLocaleFromNavigator, json, _ } from "svelte-i18n";
 | 
				
			||||||
 | 
					  import InfiniteLoading from 'svelte-infinite-loading';
 | 
				
			||||||
  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 +12,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 +57,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,8 +162,12 @@
 | 
				
			|||||||
              </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}
 | 
				
			||||||
 | 
					  style="height: 70vh; width:100%"
 | 
				
			||||||
 | 
					  bind:this={ele}
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					    {#each filtered_cards as card, index}
 | 
				
			||||||
    {#if card.code
 | 
					    {#if card.code
 | 
				
			||||||
      .toLowerCase()
 | 
					      .toLowerCase()
 | 
				
			||||||
      .includes(
 | 
					      .includes(
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user