2021-04-14 14:52:25 +02:00
|
|
|
<script>
|
2021-04-23 11:48:19 +02:00
|
|
|
import "@spectrum-css/tabs/dist/index-vars.css"
|
|
|
|
import { writable } from "svelte/store"
|
|
|
|
import { onMount, setContext, createEventDispatcher } from "svelte"
|
2021-04-15 14:42:39 +02:00
|
|
|
|
2021-04-23 11:48:19 +02:00
|
|
|
export let selected
|
|
|
|
export let vertical = false
|
|
|
|
let _id = id()
|
|
|
|
const tab = writable({ title: selected, id: _id })
|
|
|
|
setContext("tab", tab)
|
2021-04-15 15:39:00 +02:00
|
|
|
|
2021-04-23 11:48:19 +02:00
|
|
|
let container
|
2021-04-15 14:42:39 +02:00
|
|
|
|
2021-04-23 11:48:19 +02:00
|
|
|
const dispatch = createEventDispatcher()
|
2021-04-15 14:42:39 +02:00
|
|
|
|
2021-04-23 11:48:19 +02:00
|
|
|
$: selected = $tab.title
|
|
|
|
$: selected = dispatch("select", selected)
|
|
|
|
|
|
|
|
let top, left, width, height
|
|
|
|
$: calculateIndicatorLength($tab)
|
|
|
|
$: calculateIndicatorOffset($tab)
|
2021-04-15 14:42:39 +02:00
|
|
|
|
2021-04-23 11:48:19 +02:00
|
|
|
function calculateIndicatorLength() {
|
|
|
|
if (!vertical) {
|
|
|
|
width = $tab.info?.width + "px"
|
|
|
|
height = $tab.info?.height
|
|
|
|
} else {
|
|
|
|
height = $tab.info?.height + 4 + "px"
|
|
|
|
width = $tab.info?.width
|
2021-04-15 14:42:39 +02:00
|
|
|
}
|
2021-04-23 11:48:19 +02:00
|
|
|
}
|
2021-04-15 14:42:39 +02:00
|
|
|
|
2021-04-23 11:48:19 +02:00
|
|
|
function calculateIndicatorOffset() {
|
|
|
|
if (!vertical) {
|
|
|
|
left = $tab.info?.left - container?.getBoundingClientRect().left + "px"
|
|
|
|
} else {
|
|
|
|
top = $tab.info?.top - container?.getBoundingClientRect().top + "px"
|
2021-04-15 14:42:39 +02:00
|
|
|
}
|
2021-04-23 11:48:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
onMount(() => {
|
|
|
|
calculateIndicatorLength()
|
|
|
|
calculateIndicatorOffset()
|
|
|
|
})
|
|
|
|
|
|
|
|
function id() {
|
|
|
|
return (
|
|
|
|
"_" +
|
|
|
|
Math.random()
|
|
|
|
.toString(36)
|
|
|
|
.substr(2, 9)
|
|
|
|
)
|
|
|
|
}
|
2021-04-14 14:52:25 +02:00
|
|
|
</script>
|
2021-04-23 11:48:19 +02:00
|
|
|
|
|
|
|
<div
|
|
|
|
bind:this={container}
|
|
|
|
class="selected-border spectrum-Tabs spectrum-Tabs--{vertical ? 'vertical' : 'horizontal'}">
|
|
|
|
<slot />
|
|
|
|
{#if $tab.info}
|
|
|
|
<div
|
|
|
|
class="spectrum-Tabs-selectionIndicator indicator-transition"
|
|
|
|
style="width: {width}; height: {height}; left: {left}; top: {top};" />
|
|
|
|
{/if}
|
2021-04-14 16:07:45 +02:00
|
|
|
</div>
|
|
|
|
|
2021-04-15 14:42:39 +02:00
|
|
|
<div class="spectrum-Tabs-content spectrum-Tabs-content-{_id}" />
|
2021-04-14 16:07:45 +02:00
|
|
|
|
|
|
|
<style>
|
2021-04-23 11:48:19 +02:00
|
|
|
.spectrum-Tabs {
|
|
|
|
padding-left: var(--spacing-xl);
|
|
|
|
padding-right: var(--spacing-xl);
|
2021-04-23 12:30:17 +02:00
|
|
|
position: relative;
|
|
|
|
border-width: 1px !important;
|
2021-04-23 11:48:19 +02:00
|
|
|
}
|
|
|
|
.spectrum-Tabs-content {
|
|
|
|
margin-top: var(--spectrum-global-dimension-static-size-150);
|
|
|
|
}
|
|
|
|
.indicator-transition {
|
|
|
|
transition: all 200ms;
|
|
|
|
}
|
2021-04-23 12:30:17 +02:00
|
|
|
.spectrum-Tabs--horizontal .spectrum-Tabs-selectionIndicator {
|
|
|
|
bottom: 0 !important;
|
|
|
|
}
|
2021-04-23 11:48:19 +02:00
|
|
|
</style>
|