1
0
Fork 0
mirror of synced 2024-08-23 05:51:29 +12:00
budibase/packages/builder/src/components/common/LinkedRecordSelector.svelte

75 lines
1.4 KiB
Svelte
Raw Normal View History

<script>
2020-06-19 04:55:46 +12:00
import { onMount } from "svelte"
import { backendUiStore } from "builderStore"
import api from "builderStore/api"
export let modelId
2020-06-23 08:30:23 +12:00
export let linkName
export let linked = []
let records = []
async function fetchRecords() {
const FETCH_RECORDS_URL = `/api/${$backendUiStore.selectedDatabase._id}/${modelId}/records`
const response = await api.get(FETCH_RECORDS_URL)
records = await response.json()
}
onMount(() => {
fetchRecords()
})
function linkRecord(record) {
2020-06-23 08:30:23 +12:00
linked.push(record._id)
}
</script>
<section>
2020-06-23 08:30:23 +12:00
<h3>{linkName}</h3>
{#each records as record}
2020-06-23 08:30:23 +12:00
<div class="linked-record" on:click={() => linkRecord(record)}>
<div class="fields">
2020-06-23 08:30:23 +12:00
{#each Object.keys(record).slice(0, 2) as key}
<div class="field">
<span>{key}</span>
<p>{record[key]}</p>
</div>
{/each}
</div>
</div>
{/each}
</section>
<style>
2020-06-23 08:30:23 +12:00
h3 {
font-size: 20px;
}
.fields {
2020-06-23 08:30:23 +12:00
padding: 15px;
display: grid;
grid-template-columns: 1fr 1fr 1fr;
grid-gap: 20px;
2020-06-23 08:30:23 +12:00
background: var(--grey);
border: 1px solid var(--grey);
border-radius: 5px;
}
2020-06-23 08:30:23 +12:00
.field:hover {
cursor: pointer;
}
.field span {
color: var(--ink-lighter);
font-size: 12px;
}
.field p {
color: var(--ink);
font-size: 14px;
word-break: break-word;
2020-06-23 08:30:23 +12:00
font-weight: 500;
margin-top: 4px;
}
2020-06-19 04:55:46 +12:00
</style>