|
|
<script lang="ts"> |
|
|
export let big: boolean = false; |
|
|
export let description: string = ""; |
|
|
</script> |
|
|
|
|
|
<div class="switcher-parent"> |
|
|
<div class="switcher" class:big={big} role="listbox"> |
|
|
<slot></slot> |
|
|
</div> |
|
|
{#if description} |
|
|
<div class="settings-content-description subtext">{description}</div> |
|
|
{/if} |
|
|
</div> |
|
|
|
|
|
<style> |
|
|
.switcher-parent { |
|
|
display: flex; |
|
|
flex-direction: column; |
|
|
gap: 8px; |
|
|
} |
|
|
|
|
|
.switcher { |
|
|
display: flex; |
|
|
width: auto; |
|
|
flex-direction: row; |
|
|
flex-wrap: nowrap; |
|
|
scrollbar-width: none; |
|
|
overflow-x: scroll; |
|
|
border-radius: var(--border-radius); |
|
|
} |
|
|
|
|
|
.switcher :global(.button) { |
|
|
white-space: nowrap; |
|
|
} |
|
|
|
|
|
.switcher:not(.big) :global(.button:first-child) { |
|
|
border-top-right-radius: 0; |
|
|
border-bottom-right-radius: 0; |
|
|
} |
|
|
|
|
|
.switcher:not(.big) :global(.button:last-child) { |
|
|
border-top-left-radius: 0; |
|
|
border-bottom-left-radius: 0; |
|
|
} |
|
|
|
|
|
.switcher:not(.big):dir(rtl) :global(.button:first-child) { |
|
|
border-top-right-radius: inherit; |
|
|
border-bottom-right-radius: inherit; |
|
|
border-top-left-radius: 0; |
|
|
border-bottom-left-radius: 0; |
|
|
} |
|
|
|
|
|
.switcher:not(.big):dir(rtl) :global(.button:last-child) { |
|
|
border-top-left-radius: inherit; |
|
|
border-bottom-left-radius: inherit; |
|
|
border-top-right-radius: 0; |
|
|
border-bottom-right-radius: 0; |
|
|
} |
|
|
|
|
|
.switcher.big { |
|
|
background: var(--button); |
|
|
box-shadow: var(--button-box-shadow); |
|
|
padding: var(--switcher-padding); |
|
|
gap: calc(var(--switcher-padding) - 1.5px); |
|
|
} |
|
|
|
|
|
.switcher :global(.button.active) { |
|
|
pointer-events: none; |
|
|
} |
|
|
|
|
|
.switcher :global(.button.active:hover) { |
|
|
background: var(--secondary); |
|
|
} |
|
|
|
|
|
.switcher.big :global(.button) { |
|
|
width: 100%; |
|
|
|
|
|
height: calc(40px - var(--switcher-padding) * 2); |
|
|
border-radius: calc(var(--border-radius) - var(--switcher-padding)); |
|
|
box-shadow: none; |
|
|
} |
|
|
|
|
|
.switcher.big :global(.button:not(.active, :hover, :active)) { |
|
|
background-color: transparent; |
|
|
} |
|
|
|
|
|
.switcher.big :global(.button:active:not(.active)) { |
|
|
box-shadow: var(--button-box-shadow); |
|
|
} |
|
|
|
|
|
.switcher:not(.big) :global(.button:not(:first-child, :last-child)) { |
|
|
border-radius: 0; |
|
|
} |
|
|
|
|
|
|
|
|
.switcher:not(.big) :global(:not(.button:first-child)) { |
|
|
margin-left: -1px; |
|
|
} |
|
|
</style> |
|
|
|