Files
lucent-laravel/front/js/svelte/newPreview/Preview.svelte
T

66 lines
1.9 KiB
Svelte
Raw Normal View History

2024-03-21 22:33:41 +02:00
<script>
2024-03-25 21:26:21 +02:00
import File from "./includes/File.svelte";
import {previewTitle} from "../records/Preview.js";
import {getContext} from "svelte";
import Status from "../records/Status.svelte";
2024-03-21 22:33:41 +02:00
const channel = getContext("channel");
2024-03-25 21:26:21 +02:00
export let record;
2024-03-21 22:33:41 +02:00
2024-03-25 21:26:21 +02:00
export let edge = null;
let schema = channel.schemas.find(s => s.name === record.schema);
let types = ["inline", "card"];
export let type = "inline";
if (!types.includes(type)) {
console.error("unknown preview type")
2024-03-21 22:33:41 +02:00
}
2024-03-25 21:26:21 +02:00
export let editable = false;
2024-03-21 22:33:41 +02:00
2024-03-25 21:26:21 +02:00
</script>
<div class="preview-card">
{#if edge?.data}
<div class="preview-card-edge">Edge Data</div>
{/if}
<div class="d-flex column-gap-3">
{#if record._file}
<div>
<File {record}/>
</div>
2024-03-21 22:33:41 +02:00
{/if}
2024-03-25 21:26:21 +02:00
<div class="d-flex flex-md-column " style="line-height: 22px">
<span class="">{previewTitle(record)}</span>
<span class="d-flex gap-1 text-muted">
{#if record.status === "draft"}
<Status status={record.status}/>
{/if}
{schema.label}
</span>
2024-03-21 22:33:41 +02:00
</div>
2024-03-25 21:26:21 +02:00
</div>
2024-03-21 22:33:41 +02:00
</div>
<style>
2024-03-25 21:26:21 +02:00
.preview-card {
position: relative
2024-03-21 22:33:41 +02:00
}
2024-03-25 21:26:21 +02:00
.preview-card-edge {
position: absolute;
top: -28px;
background: #fff;
padding: 0px 5px;
border: 1px solid #ccc;
border-radius: 7px;
font-size: 14px;
2024-03-21 22:33:41 +02:00
}
2024-03-25 21:26:21 +02:00
</style>
<!--{#if record._file && type === "inline"}-->
<!--&lt;!&ndash; <FilePreviewInline {record} {edge} {editable}/>&ndash;&gt;-->
<!--{:else if record._file && type === "card"}-->
<!-- <FilePreviewCard {record} {edge} {editable}/>-->
<!--{:else if type === "inline"}-->
<!--&lt;!&ndash; <DocPreviewCard {record} {edge} {editable}/>&ndash;&gt;-->
<!--{:else if type === "card"}-->
<!--&lt;!&ndash; <DocPreviewCard {record} {edge} {editable}/>&ndash;&gt;-->
<!--{/if}-->