forked from MapComplete/MapComplete
Fix: fix file drag and drop, allow entire featurePopup for file drop
This commit is contained in:
parent
03d55955e6
commit
859faead7f
2 changed files with 50 additions and 30 deletions
|
@ -1,5 +1,5 @@
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { createEventDispatcher } from "svelte"
|
import { createEventDispatcher, onDestroy } from "svelte"
|
||||||
import { twMerge } from "tailwind-merge"
|
import { twMerge } from "tailwind-merge"
|
||||||
|
|
||||||
export let accept: string
|
export let accept: string
|
||||||
|
@ -9,42 +9,62 @@
|
||||||
export let cls: string = ""
|
export let cls: string = ""
|
||||||
let drawAttention = false
|
let drawAttention = false
|
||||||
let inputElement: HTMLInputElement
|
let inputElement: HTMLInputElement
|
||||||
let id = Math.random() * 1000000000 + ""
|
let formElement: HTMLFormElement
|
||||||
|
let id = "fileinput_" + Math.round(Math.random() * 1000000000000)
|
||||||
|
|
||||||
|
function handleDragEvent(e: DragEvent) {
|
||||||
|
if (e.target["id"] == id) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if(formElement.contains(e.target) || document.getElementsByClassName("selected-element-view")[0]?.contains(e.target)){
|
||||||
|
e.preventDefault()
|
||||||
|
|
||||||
|
if(e.type === "drop"){
|
||||||
|
console.log("Got a 'drop'", e)
|
||||||
|
drawAttention = false
|
||||||
|
dispatcher("submit", e.dataTransfer.files)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
drawAttention = true
|
||||||
|
e.dataTransfer.dropEffect = "copy"
|
||||||
|
|
||||||
|
return
|
||||||
|
/*
|
||||||
|
drawAttention = false
|
||||||
|
dispatcher("submit", e.dataTransfer.files)
|
||||||
|
console.log("Committing")*/
|
||||||
|
}
|
||||||
|
drawAttention = false
|
||||||
|
e.preventDefault()
|
||||||
|
e.dataTransfer.effectAllowed = "none"
|
||||||
|
e.dataTransfer.dropEffect = "none"
|
||||||
|
}
|
||||||
|
|
||||||
|
window.addEventListener("dragenter", handleDragEvent)
|
||||||
|
window.addEventListener("dragover", handleDragEvent)
|
||||||
|
window.addEventListener("drop", handleDragEvent)
|
||||||
|
|
||||||
|
onDestroy(() => {
|
||||||
|
window.removeEventListener("dragenter", handleDragEvent)
|
||||||
|
window.removeEventListener("dragover", handleDragEvent)
|
||||||
|
window.removeEventListener("drop", handleDragEvent)
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<form
|
<form
|
||||||
on:change|preventDefault={() => {
|
bind:this={formElement}
|
||||||
drawAttention = false
|
|
||||||
dispatcher("submit", inputElement.files)
|
|
||||||
}}
|
|
||||||
on:dragend={() => {
|
|
||||||
console.log("Drag end")
|
|
||||||
drawAttention = false
|
|
||||||
}}
|
|
||||||
on:dragenter|preventDefault|stopPropagation={(e) => {
|
|
||||||
console.log("Dragging enter")
|
|
||||||
drawAttention = true
|
|
||||||
e.dataTransfer.drop = "copy"
|
|
||||||
}}
|
|
||||||
on:dragstart={() => {
|
|
||||||
console.log("DragStart")
|
|
||||||
drawAttention = false
|
|
||||||
}}
|
|
||||||
on:drop|preventDefault|stopPropagation={(e) => {
|
|
||||||
console.log("Got a 'drop'")
|
|
||||||
drawAttention = false
|
|
||||||
dispatcher("submit", e.dataTransfer.files)
|
|
||||||
}}
|
|
||||||
>
|
>
|
||||||
<label
|
<label
|
||||||
class={twMerge(cls, drawAttention ? "glowing-shadow" : "")}
|
class={twMerge(cls, drawAttention ? "glowing-shadow" : "")}
|
||||||
style="margin-left:0"
|
for={id}
|
||||||
tabindex="0"
|
|
||||||
for={"fileinput" + id}
|
|
||||||
on:click={() => {
|
on:click={() => {
|
||||||
console.log("Clicked", inputElement)
|
|
||||||
inputElement.click()
|
inputElement.click()
|
||||||
}}
|
}}
|
||||||
|
style="margin-left:0"
|
||||||
|
tabindex="0"
|
||||||
>
|
>
|
||||||
<slot />
|
<slot />
|
||||||
</label>
|
</label>
|
||||||
|
@ -52,7 +72,7 @@
|
||||||
{accept}
|
{accept}
|
||||||
bind:this={inputElement}
|
bind:this={inputElement}
|
||||||
class="hidden"
|
class="hidden"
|
||||||
id={"fileinput" + id}
|
{id}
|
||||||
{multiple}
|
{multiple}
|
||||||
name="file-input"
|
name="file-input"
|
||||||
type="file"
|
type="file"
|
||||||
|
|
|
@ -43,7 +43,7 @@
|
||||||
<Tr t={Translations.t.general.returnToTheMap} />
|
<Tr t={Translations.t.general.returnToTheMap} />
|
||||||
</button>
|
</button>
|
||||||
{:else}
|
{:else}
|
||||||
<div class="flex h-full w-full flex-col gap-y-2 overflow-y-auto p-1 px-4" tabindex="-1">
|
<div class="flex h-full flex-col gap-y-2 overflow-y-auto p-1 px-4 w-full selected-element-view" tabindex="-1">
|
||||||
{#each $knownTagRenderings as config (config.id)}
|
{#each $knownTagRenderings as config (config.id)}
|
||||||
<TagRenderingEditable
|
<TagRenderingEditable
|
||||||
{tags}
|
{tags}
|
||||||
|
|
Loading…
Reference in a new issue