Dusk UI Kit - Organism - Table
npm i -D @dusk-network/table
<script>
import Table, { Row, Datum } from "@dusk-network/table";
import { useQuery } from "@sveltestack/svelte-query";
import { apiData } from "./data.js";
const settings = {
sortable: true,
rowsPerPage: 10,
infinite: true,
limiter: true,
filter: true,
};
let rows;
async function getTransactions() {
return apiData;
}
const transactions = useQuery("content", getTransactions);
</script>
{#if $transactions.isLoading}
<p>Loading...</p>
{:else if $transactions.isError}
<p>Error: {$transactions.error}</p>
{:else}
<Table
data="{$transactions.data}"
bind:dataRows="{rows}"
settings="{settings}"
mobileBreakpoint="lg"
>
<h3 slot="title">Recent transactions</h3>
<thead slot="head">
{#if rows}
{#each $rows as _}
<Row type="head">
<Datum key="id">ID</Datum>
<Datum key="first_name">Status</Datum>
<Datum key="last_name">Time</Datum>
<Datum key="email">Amount</Datum>
</Row>
{/each}
{/if}
</thead>
<tbody>
{#if rows}
{#each $rows as row, i}
<Row
active="{i === 2 ? true : false}"
data="{row}"
on:selected="{(event) => console.log(event.detail)}"
>
<Datum>{row.id}</Datum>
<Datum>
{row.status}
</Datum>
<Datum>
{row.timeStamp}
</Datum>
<Datum>
{row.amount}
</Datum>
</Row>
{/each}
{/if}
</tbody>
</Table>
{/if}