hide file

This commit is contained in:
vcoppe
2024-06-19 18:11:05 +02:00
parent 40a6eb5192
commit 06bc49901d
5 changed files with 71 additions and 10 deletions

View File

@@ -34,7 +34,8 @@
exportSelectedFiles,
triggerFileInput,
createFile,
loadFiles
loadFiles,
toggleSelectionVisibility
} from '$lib/stores';
import { selectAll, selection } from '$lib/components/file-list/Selection';
import { derived } from 'svelte/store';
@@ -337,6 +338,9 @@
} else if (e.key === 'l' && (e.metaKey || e.ctrlKey)) {
$verticalFileView = !$verticalFileView;
e.preventDefault();
} else if (e.key === 'h' && (e.metaKey || e.ctrlKey)) {
toggleSelectionVisibility();
e.preventDefault();
} else if (e.key === 'F1') {
switchBasemaps();
e.preventDefault();

View File

@@ -8,7 +8,18 @@
import * as Popover from '$lib/components/ui/popover';
import Shortcut from '$lib/components/Shortcut.svelte';
import { dbUtils, getFile, settings } from '$lib/db';
import { Copy, Info, MapPin, PaintBucket, Plus, Save, Trash2, Waypoints } from 'lucide-svelte';
import {
Copy,
Info,
MapPin,
PaintBucket,
Plus,
Save,
Trash2,
Waypoints,
Eye,
EyeOff
} from 'lucide-svelte';
import {
ListFileItem,
ListLevel,
@@ -19,7 +30,7 @@
import { selectItem, selection } from './Selection';
import { getContext } from 'svelte';
import { get } from 'svelte/store';
import { gpxLayers, map } from '$lib/stores';
import { gpxLayers, map, toggleSelectionVisibility } from '$lib/stores';
import {
GPXTreeElement,
Track,
@@ -37,6 +48,7 @@
export let item: ListItem;
export let label: string | undefined;
let nodeColors: string[] = [];
let hidden = false;
let orientation = getContext<'vertical' | 'horizontal'>('orientation');
@@ -169,8 +181,14 @@
<!-- svelte-ignore a11y-no-static-element-interactions -->
<ContextMenu.Root
onOpenChange={(open) => {
if (open && !get(selection).has(item)) {
selectItem(item);
if (open) {
if (!get(selection).has(item)) {
selectItem(item);
}
let layer = gpxLayers.get(item.getFileId());
if (layer) {
hidden = layer.hidden;
}
}
}}
>
@@ -347,6 +365,18 @@
<PaintBucket size="16" class="mr-1" />
{$_('menu.style.button')}
</ContextMenu.Item>
{#if item instanceof ListFileItem}
<ContextMenu.Item on:click={toggleSelectionVisibility}>
{#if hidden}
<Eye size="16" class="mr-1" />
{$_('menu.unhide')}
{:else}
<EyeOff size="16" class="mr-1" />
{$_('menu.hide')}
{/if}
<Shortcut key="H" ctrl={true} />
</ContextMenu.Item>
{/if}
<ContextMenu.Separator />
{/if}
{#if $verticalFileView}
@@ -394,10 +424,10 @@
>
<ContextMenu.Separator />
{/if}
<ContextMenu.Item on:click={dbUtils.deleteSelection}
><Trash2 size="16" class="mr-1" />
<ContextMenu.Item on:click={dbUtils.deleteSelection}>
<Trash2 size="16" class="mr-1" />
{$_('menu.delete')}
<Shortcut key="⌫" ctrl={true} /></ContextMenu.Item
>
<Shortcut key="⌫" ctrl={true} />
</ContextMenu.Item>
</ContextMenu.Content>
</ContextMenu.Root>

View File

@@ -50,6 +50,7 @@ export class GPXLayer {
fileId: string;
file: Readable<GPXFileWithStatistics | undefined>;
layerColor: string;
hidden: boolean = false;
markers: mapboxgl.Marker[] = [];
selected: boolean = false;
draggable: boolean;
@@ -362,6 +363,17 @@ export class GPXLayer {
}
}
toggleVisibility() {
this.hidden = !this.hidden;
if (this.hidden) {
this.map.setLayoutProperty(this.fileId, 'visibility', 'none');
this.markers.forEach(marker => marker.remove());
} else {
this.map.setLayoutProperty(this.fileId, 'visibility', 'visible');
this.markers.forEach(marker => marker.addTo(this.map));
}
}
getGeoJSON(): GeoJSON.FeatureCollection {
let file = get(this.file)?.file;
if (!file) {

View File

@@ -255,6 +255,19 @@ export function exportFile(file: GPXFile) {
URL.revokeObjectURL(url);
}
export function toggleSelectionVisibility() {
let files = new Set<string>();
get(selection).forEach((item) => {
files.add(item.getFileId());
});
files.forEach((fileId) => {
let layer = gpxLayers.get(fileId);
if (layer) {
layer.toggleVisibility();
}
});
}
let stravaCookies: any = null;
function refreshStravaCookies() {
/*

View File

@@ -52,7 +52,9 @@
"color": "Color",
"opacity": "Opacity",
"weight": "Weight"
}
},
"hide": "Hide",
"unhide": "Unhide"
},
"toolbar": {
"routing": {