mirror of
https://github.com/seanmorley15/AdventureLog.git
synced 2025-07-22 06:19:38 +02:00
185 lines
5.6 KiB
Svelte
185 lines
5.6 KiB
Svelte
|
<script lang="ts">
|
||
|
export let transportationToEdit: Transportation;
|
||
|
import { createEventDispatcher } from 'svelte';
|
||
|
import type { Transportation } from '$lib/types';
|
||
|
const dispatch = createEventDispatcher();
|
||
|
import { onMount } from 'svelte';
|
||
|
import { addToast } from '$lib/toasts';
|
||
|
let modal: HTMLDialogElement;
|
||
|
|
||
|
console.log(transportationToEdit.id);
|
||
|
|
||
|
let originalName = transportationToEdit.name;
|
||
|
|
||
|
let isPointModalOpen: boolean = false;
|
||
|
|
||
|
import MapMarker from '~icons/mdi/map-marker';
|
||
|
import Calendar from '~icons/mdi/calendar';
|
||
|
import Notebook from '~icons/mdi/notebook';
|
||
|
import ClipboardList from '~icons/mdi/clipboard-list';
|
||
|
import Image from '~icons/mdi/image';
|
||
|
import Star from '~icons/mdi/star';
|
||
|
import Attachment from '~icons/mdi/attachment';
|
||
|
import PointSelectionModal from './PointSelectionModal.svelte';
|
||
|
import Earth from '~icons/mdi/earth';
|
||
|
import TransportationCard from './TransportationCard.svelte';
|
||
|
|
||
|
onMount(async () => {
|
||
|
modal = document.getElementById('my_modal_1') as HTMLDialogElement;
|
||
|
if (modal) {
|
||
|
modal.showModal();
|
||
|
}
|
||
|
});
|
||
|
|
||
|
if (transportationToEdit.date) {
|
||
|
transportationToEdit.date = transportationToEdit.date.slice(0, 19);
|
||
|
}
|
||
|
|
||
|
function submit() {}
|
||
|
|
||
|
function close() {
|
||
|
dispatch('close');
|
||
|
}
|
||
|
|
||
|
function handleKeydown(event: KeyboardEvent) {
|
||
|
if (event.key === 'Escape') {
|
||
|
close();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
async function handleSubmit(event: Event) {
|
||
|
event.preventDefault();
|
||
|
const form = event.target as HTMLFormElement;
|
||
|
const formData = new FormData(form);
|
||
|
|
||
|
const response = await fetch(form.action, {
|
||
|
method: form.method,
|
||
|
body: formData
|
||
|
});
|
||
|
|
||
|
if (response.ok) {
|
||
|
const result = await response.json();
|
||
|
const data = JSON.parse(result.data);
|
||
|
console.log(data);
|
||
|
|
||
|
if (data) {
|
||
|
addToast('success', 'Adventure edited successfully!');
|
||
|
dispatch('saveEdit', transportationToEdit);
|
||
|
close();
|
||
|
} else {
|
||
|
addToast('warning', 'Error editing adventure');
|
||
|
console.log('Error editing adventure');
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<dialog id="my_modal_1" class="modal">
|
||
|
<!-- svelte-ignore a11y-no-noninteractive-element-interactions -->
|
||
|
<!-- svelte-ignore a11y-no-noninteractive-tabindex -->
|
||
|
<div class="modal-box" role="dialog" on:keydown={handleKeydown} tabindex="0">
|
||
|
<h3 class="font-bold text-lg">Edit Transportation: {originalName}</h3>
|
||
|
<div
|
||
|
class="modal-action items-center"
|
||
|
style="display: flex; flex-direction: column; align-items: center; width: 100%;"
|
||
|
>
|
||
|
<form method="post" style="width: 100%;" on:submit={handleSubmit} action="/collections?/edit">
|
||
|
<div class="mb-2">
|
||
|
<input
|
||
|
type="text"
|
||
|
id="adventureId"
|
||
|
name="adventureId"
|
||
|
hidden
|
||
|
readonly
|
||
|
bind:value={transportationToEdit.id}
|
||
|
class="input input-bordered w-full max-w-xs mt-1"
|
||
|
/>
|
||
|
<label for="name">Name</label><br />
|
||
|
<input
|
||
|
type="text"
|
||
|
name="name"
|
||
|
id="name"
|
||
|
bind:value={transportationToEdit.name}
|
||
|
class="input input-bordered w-full max-w-xs mt-1"
|
||
|
/>
|
||
|
</div>
|
||
|
<div class="mb-2">
|
||
|
<label for="date">Description <Notebook class="inline-block -mt-1 mb-1 w-6 h-6" /></label
|
||
|
><br />
|
||
|
<div class="flex">
|
||
|
<input
|
||
|
type="text"
|
||
|
id="description"
|
||
|
name="description"
|
||
|
bind:value={transportationToEdit.description}
|
||
|
class="input input-bordered w-full max-w-xs mt-1 mb-2"
|
||
|
/>
|
||
|
|
||
|
<!-- <button
|
||
|
class="btn btn-neutral ml-2"
|
||
|
type="button"
|
||
|
on:click={generate}
|
||
|
><iconify-icon icon="mdi:wikipedia" class="text-xl -mb-1"
|
||
|
></iconify-icon>Generate Description</button
|
||
|
> -->
|
||
|
</div>
|
||
|
<div class="mb-2">
|
||
|
<label for="start_date"
|
||
|
>Date & Time <Calendar class="inline-block mb-1 w-6 h-6" /></label
|
||
|
><br />
|
||
|
<input
|
||
|
type="datetime-local"
|
||
|
id="date"
|
||
|
name="date"
|
||
|
bind:value={transportationToEdit.date}
|
||
|
class="input input-bordered w-full max-w-xs mt-1"
|
||
|
/>
|
||
|
</div>
|
||
|
<div class="mb-2">
|
||
|
<label for="end_date">End Date <Calendar class="inline-block mb-1 w-6 h-6" /></label><br
|
||
|
/>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="mb-2">
|
||
|
<label for="is_public">Public <Earth class="inline-block -mt-1 mb-1 w-6 h-6" /></label><br
|
||
|
/>
|
||
|
<input
|
||
|
type="checkbox"
|
||
|
class="toggle toggle-primary"
|
||
|
id="is_public"
|
||
|
name="is_public"
|
||
|
bind:checked={transportationToEdit.is_public}
|
||
|
/>
|
||
|
</div>
|
||
|
|
||
|
{#if transportationToEdit.is_public}
|
||
|
<div class="bg-neutral p-4 rounded-md shadow-sm">
|
||
|
<p class=" font-semibold">Share this Adventure!</p>
|
||
|
<div class="flex items-center justify-between">
|
||
|
<p class="text-card-foreground font-mono">
|
||
|
{window.location.origin}/collections/{transportationToEdit.id}
|
||
|
</p>
|
||
|
<button
|
||
|
type="button"
|
||
|
on:click={() => {
|
||
|
navigator.clipboard.writeText(
|
||
|
`${window.location.origin}/collections/${transportationToEdit.id}`
|
||
|
);
|
||
|
}}
|
||
|
class="inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 h-10 px-4 py-2"
|
||
|
>
|
||
|
Copy Link
|
||
|
</button>
|
||
|
</div>
|
||
|
</div>
|
||
|
{/if}
|
||
|
|
||
|
<button type="submit" class="btn btn-primary mr-4 mt-4" on:click={submit}>Edit</button>
|
||
|
<!-- if there is a button in form, it will close the modal -->
|
||
|
<button class="btn mt-4" on:click={close}>Close</button>
|
||
|
</form>
|
||
|
<div class="flex items-center justify-center flex-wrap gap-4 mt-4"></div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</dialog>
|