sortable with multidrag

This commit is contained in:
vcoppe
2024-04-20 15:38:17 +02:00
parent 0b3057f122
commit 3cb1547dce
2 changed files with 24 additions and 7 deletions

View File

@@ -1,17 +1,23 @@
<script lang="ts"> <script lang="ts">
import { files, selectedFiles, addSelectFile, selectFile } from '$lib/stores'; import { files, selectedFiles, addSelectFile, selectFile, removeSelectFile } from '$lib/stores';
import { ScrollArea } from '$lib/components/ui/scroll-area/index.js'; import { ScrollArea } from '$lib/components/ui/scroll-area/index.js';
import Sortable from 'sortablejs';
import { onMount } from 'svelte'; import { onMount } from 'svelte';
let tabs: HTMLDivElement; let tabs: HTMLDivElement;
onMount(() => { onMount(async () => {
const sortablejs = await import('sortablejs');
const Sortable = sortablejs.default;
const MultiDrag = sortablejs.MultiDrag;
Sortable.mount(new MultiDrag());
Sortable.create(tabs, { Sortable.create(tabs, {
forceAutoScrollFallback: true forceAutoScrollFallback: true,
multiDrag: true,
multiDragKey: 'shift'
}); });
}); });
</script> </script>
@@ -23,10 +29,14 @@
<button <button
class="my-1 px-1.5 py-1 rounded {$selectedFiles.has(file) class="my-1 px-1.5 py-1 rounded {$selectedFiles.has(file)
? 'bg-background shadow' ? 'bg-background shadow'
: 'bg-secondary'} first:ml-1 last:mr-1" : 'bg-secondary hover:bg-gray-200'} first:ml-1 last:mr-1"
on:click={(e) => { on:click={(e) => {
if (e.shiftKey) { if (e.shiftKey) {
addSelectFile(file); if ($selectedFiles.has(file)) {
removeSelectFile(file);
} else {
addSelectFile(file);
}
} else { } else {
selectFile(file); selectFile(file);
} }

View File

@@ -122,4 +122,11 @@ export function addSelectFile(file: GPXFile) {
$selectedFiles.add(file); $selectedFiles.add(file);
return $selectedFiles; return $selectedFiles;
}); });
}
export function removeSelectFile(file: GPXFile) {
selectedFiles.update($selectedFiles => {
$selectedFiles.delete(file);
return $selectedFiles;
});
} }