2021-09-16 15:28:44 +02:00
|
|
|
<script>
|
2021-09-16 16:08:42 +02:00
|
|
|
import Indicator from "./Indicator.svelte"
|
|
|
|
|
|
|
|
export let dropInfo
|
2021-09-16 15:28:44 +02:00
|
|
|
export let zIndex
|
2021-09-16 16:08:42 +02:00
|
|
|
export let color
|
|
|
|
export let transition
|
2021-09-16 15:28:44 +02:00
|
|
|
|
2021-09-20 09:26:44 +02:00
|
|
|
$: dimensions = getDimensions(dropInfo?.bounds, dropInfo?.mode)
|
2021-09-20 16:35:27 +02:00
|
|
|
$: prefix = dropInfo?.mode === "above" ? "Before" : "After"
|
2021-09-16 16:08:42 +02:00
|
|
|
$: text = `${prefix} ${dropInfo?.name}`
|
2021-09-16 15:28:44 +02:00
|
|
|
|
2021-09-16 16:08:42 +02:00
|
|
|
const getDimensions = (bounds, mode) => {
|
2021-09-16 15:28:44 +02:00
|
|
|
if (!bounds || !mode) {
|
|
|
|
return null
|
|
|
|
}
|
2021-09-16 16:08:42 +02:00
|
|
|
const { left, top, width, height } = bounds
|
|
|
|
return {
|
|
|
|
top: mode === "above" ? top - 4 : top + height,
|
|
|
|
left: left - 2,
|
|
|
|
width: width + 4,
|
|
|
|
}
|
2021-09-16 15:28:44 +02:00
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
2021-09-20 09:26:44 +02:00
|
|
|
{#key `${dropInfo?.target}-${dropInfo?.mode}`}
|
|
|
|
{#if dimensions && dropInfo?.mode !== "inside"}
|
2021-09-16 16:08:42 +02:00
|
|
|
<Indicator
|
|
|
|
left={dimensions.left}
|
|
|
|
top={dimensions.top}
|
|
|
|
width={dimensions.width}
|
|
|
|
height={0}
|
|
|
|
{text}
|
|
|
|
{zIndex}
|
|
|
|
{color}
|
|
|
|
{transition}
|
2021-09-16 17:02:45 +02:00
|
|
|
line
|
2021-09-16 16:08:42 +02:00
|
|
|
/>
|
|
|
|
{/if}
|
|
|
|
{/key}
|