2021-12-26 19:50:24 +02:00
|
|
|
<script lang="ts">
|
|
|
|
import { _ } from 'svelte-i18n';
|
|
|
|
|
|
|
|
import Configs from '../ts/Configs';
|
|
|
|
|
|
|
|
export let prop: string = '';
|
|
|
|
export let lang: string = '';
|
2021-12-28 14:16:54 +02:00
|
|
|
export let tooltip: string = '';
|
2022-01-25 20:04:08 +02:00
|
|
|
export let tooltip_size: 'medium' | 'large' = 'medium';
|
2021-12-26 22:32:01 +02:00
|
|
|
export let items = {};
|
2021-12-27 23:17:02 +02:00
|
|
|
|
2021-12-26 19:50:24 +02:00
|
|
|
export let valueChanged: (value: string) => void = () => {};
|
|
|
|
|
|
|
|
import Arrow from '../assets/svgs/arrow.svg';
|
|
|
|
|
|
|
|
let selectionOpen = false;
|
|
|
|
let selectedValue;
|
|
|
|
|
|
|
|
const selectionChanged = (e: MouseEvent) => {
|
|
|
|
const li = e.target as HTMLElement;
|
|
|
|
|
|
|
|
if (!li.classList.contains('selected'))
|
|
|
|
{
|
|
|
|
const lis = li.parentElement!.children!;
|
|
|
|
|
|
|
|
for (let i = 0; i < lis.length; i++)
|
|
|
|
lis[i].classList.remove('selected');
|
|
|
|
|
|
|
|
li.classList.add('selected');
|
|
|
|
|
|
|
|
Configs.set(prop, li.getAttribute('data-value'));
|
|
|
|
|
|
|
|
selectionOpen = false;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Configs.get(prop).then((value) => selectedValue = value);
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<div class="select" class:select-active={selectionOpen}>
|
|
|
|
<span>{ $_(lang) }</span>
|
|
|
|
|
|
|
|
<div class="select-options">
|
|
|
|
<ul>
|
|
|
|
{#each Object.keys(items) as itemLang}
|
|
|
|
<li
|
|
|
|
data-value={itemLang}
|
|
|
|
|
|
|
|
on:click={selectionChanged}
|
2021-12-26 22:32:01 +02:00
|
|
|
|
2021-12-26 19:50:24 +02:00
|
|
|
on:click={() => {
|
|
|
|
selectedValue = itemLang;
|
|
|
|
|
|
|
|
valueChanged(selectedValue);
|
|
|
|
}}
|
|
|
|
|
|
|
|
class:selected={itemLang === selectedValue}
|
|
|
|
>{ $_(items[itemLang]) }</li>
|
|
|
|
{/each}
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
|
2021-12-28 14:16:54 +02:00
|
|
|
<div
|
2022-01-25 20:04:08 +02:00
|
|
|
class="selected-item {tooltip !== '' ? `hint--${tooltip_size}` : ''}"
|
2021-12-28 14:16:54 +02:00
|
|
|
class:hint--left={tooltip !== ''}
|
|
|
|
aria-label={$_(tooltip)}
|
|
|
|
on:click={() => selectionOpen = !selectionOpen}
|
|
|
|
>
|
2021-12-26 19:50:24 +02:00
|
|
|
<span>{ $_(items[selectedValue]) }</span>
|
|
|
|
|
2022-01-07 19:45:20 +02:00
|
|
|
<img src={Arrow} alt="" />
|
2021-12-26 19:50:24 +02:00
|
|
|
</div>
|
|
|
|
</div>
|