reprocess virtual scroll
This commit is contained in:
@@ -55,5 +55,4 @@ useEventListener('keyup', e => {
|
|||||||
.fade-enter-active, .fade-leave-active {
|
.fade-enter-active, .fade-leave-active {
|
||||||
@apply transition-opacity;
|
@apply transition-opacity;
|
||||||
}
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { SortableHeader, useSort } from '@/components/table';
|
import { SortableHeader, useSort, VirtualScrollTable } from '@/components/table';
|
||||||
import { formatIsk, percentFormater } from '@/formaters';
|
import { formatIsk, percentFormater } from '@/formaters';
|
||||||
import { MarketTypeLabel } from '@/market/type';
|
import { MarketTypeLabel } from '@/market/type';
|
||||||
import { useStorage } from '@vueuse/core';
|
import { useStorage } from '@vueuse/core';
|
||||||
@@ -46,24 +46,31 @@ const { sortedArray, headerProps } = useSort(computed(() => props.result.map(r =
|
|||||||
<input type="number" min="-100" max="100" step="1" v-model="threshold" />
|
<input type="number" min="-100" max="100" step="1" v-model="threshold" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<table>
|
<VirtualScrollTable :list="sortedArray" :itemHeight="33" bottom="1rem">
|
||||||
<thead>
|
<template #default="{ list }">
|
||||||
<tr>
|
<thead>
|
||||||
<SortableHeader v-bind="headerProps" sortKey="name">Item</SortableHeader>
|
<tr>
|
||||||
<SortableHeader v-bind="headerProps" sortKey="market">Market</SortableHeader>
|
<SortableHeader v-bind="headerProps" sortKey="name">Item</SortableHeader>
|
||||||
<SortableHeader v-bind="headerProps" sortKey="materials">Materials</SortableHeader>
|
<SortableHeader v-bind="headerProps" sortKey="market">Market</SortableHeader>
|
||||||
<SortableHeader v-bind="headerProps" sortKey="ratio">Percent</SortableHeader>
|
<SortableHeader v-bind="headerProps" sortKey="materials">Materials</SortableHeader>
|
||||||
</tr>
|
<SortableHeader v-bind="headerProps" sortKey="ratio">Percent</SortableHeader>
|
||||||
</thead>
|
</tr>
|
||||||
<tbody>
|
</thead>
|
||||||
<tr v-for="r in sortedArray" :key="r.typeID" :class="{'line-green': r.ratio >= threshold / 100 }">
|
<tbody>
|
||||||
<td>
|
<tr v-for="r in list" :key="r.data.typeID" :class="{'line-green': r.data.ratio >= threshold / 100 }">
|
||||||
<MarketTypeLabel :id="r.typeID" :name="r.name" />
|
<td>
|
||||||
</td>
|
<MarketTypeLabel :id="r.data.typeID" :name="r.data.name" />
|
||||||
<td class="text-right">{{ formatIsk(r.market) }}</td>
|
</td>
|
||||||
<td class="text-right">{{ formatIsk(r.materials) }}</td>
|
<td class="text-right">{{ formatIsk(r.data.market) }}</td>
|
||||||
<td class="text-right">{{ percentFormater.format(r.ratio) }}</td>
|
<td class="text-right">{{ formatIsk(r.data.materials) }}</td>
|
||||||
</tr>
|
<td class="text-right">{{ percentFormater.format(r.data.ratio) }}</td>
|
||||||
</tbody>
|
</tr>
|
||||||
</table>
|
</tbody>
|
||||||
|
</template>
|
||||||
|
<template #empty>
|
||||||
|
<div class="text-center mt-4">
|
||||||
|
<span>No items found</span>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</VirtualScrollTable>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
Reference in New Issue
Block a user