mirror of
https://github.com/gpxstudio/gpx.studio.git
synced 2025-09-01 08:12:32 +00:00
sortable with multidrag
This commit is contained in:
@@ -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);
|
||||||
}
|
}
|
||||||
|
@@ -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;
|
||||||
|
});
|
||||||
}
|
}
|
Reference in New Issue
Block a user