2021-04-08 16:57:24 +02:00
|
|
|
<script>
|
|
|
|
import "@spectrum-css/label/dist/index-vars.css"
|
2021-04-12 16:12:59 +02:00
|
|
|
import { createEventDispatcher } from "svelte"
|
2021-04-08 16:57:24 +02:00
|
|
|
|
2021-04-12 16:12:59 +02:00
|
|
|
export let row
|
2021-04-08 16:57:24 +02:00
|
|
|
export let value
|
2021-04-12 16:12:59 +02:00
|
|
|
export let schema
|
2021-04-08 16:57:24 +02:00
|
|
|
|
2021-04-12 16:12:59 +02:00
|
|
|
const dispatch = createEventDispatcher()
|
2021-04-08 16:57:24 +02:00
|
|
|
const displayLimit = 5
|
2021-04-12 16:12:59 +02:00
|
|
|
|
2021-04-08 16:57:24 +02:00
|
|
|
$: relationships = value?.slice(0, displayLimit) ?? []
|
|
|
|
$: leftover = (value?.length ?? 0) - relationships.length
|
2021-04-12 16:12:59 +02:00
|
|
|
|
|
|
|
const onClick = e => {
|
|
|
|
e.stopPropagation()
|
|
|
|
dispatch("clickrelationship", {
|
|
|
|
tableId: row.tableId,
|
|
|
|
rowId: row._id,
|
|
|
|
fieldName: schema?.name,
|
|
|
|
})
|
|
|
|
}
|
2021-04-08 16:57:24 +02:00
|
|
|
</script>
|
|
|
|
|
|
|
|
{#each relationships as relationship}
|
|
|
|
{#if relationship?.primaryDisplay}
|
2021-04-12 16:12:59 +02:00
|
|
|
<span class="spectrum-Label spectrum-Label--grey" on:click={onClick}>
|
2021-04-08 16:57:24 +02:00
|
|
|
{relationship.primaryDisplay}
|
|
|
|
</span>
|
|
|
|
{/if}
|
|
|
|
{/each}
|
|
|
|
{#if leftover}
|
|
|
|
<div>+{leftover} more</div>
|
|
|
|
{/if}
|
2021-04-12 16:16:49 +02:00
|
|
|
|
|
|
|
<style>
|
|
|
|
span:hover {
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
</style>
|