Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow skipping use:enhance with data-sveltekit-reload #13180

Closed
fehnomenal opened this issue Dec 16, 2024 · 1 comment
Closed

Allow skipping use:enhance with data-sveltekit-reload #13180

fehnomenal opened this issue Dec 16, 2024 · 1 comment
Labels
feature / enhancement New feature or request

Comments

@fehnomenal
Copy link
Contributor

fehnomenal commented Dec 16, 2024

Describe the problem

I'm having a search form with multiple fields for various criteria. The table below the form displays the database results correctly filtered. If I click the search button the criteria are correctly updated and so is the result table.
The form is method="post" and use:enhance and the search button has formmethod="get". The reason is that the same form is also used for form actions (think along the lines of "do this for all filtered items"). And all of this works great so far.

Now I need to add a button to export the filtered items. While the fetching from the database takes longer than acceptable I do not want to start a background task, but start downloading the data as soon as it is ready. This works great with a server endpoint that returns a response with a ReadableStream and the button having formtarget="_blank" but only without JS or without progressive enhancement.
Right now it does a fetch request to the target url (overwritten on the export button) but fails at parsing the CSV data as json (JSON.parse: unexpected character at line 1 column 1 of the JSON data).

Describe the proposed solution

I would like to be able to skip the progressive enhancement with the data-sveltekit-reload attribute on either the form element or the form submit element.

Alternatives considered

One alternative would be to duplicate each field and sync them with javascript. The duplicate would then be assigned to the export form which would be not enhanced. This does not work w/o js.

Importance

would make my life easier

Additional Information

Putting these lines in handle_submit results in the expected behavior:

		const skip = event.submitter?.getAttribute('data-sveltekit-reload')
			?? form_element.getAttribute('data-sveltekit-reload');
		if (skip === 'true') return;
@dummdidumm
Copy link
Member

This is possible to achieve by adding a little bit of code to your use:enhance. Basically you resubmit the form if you detect that the specific button is pressed:

<form
	use:enhance={({ submitter, formElement }) => {
		if (notTheButtonICareAbout(submitter)) return;
		formElement.action = submitter?.hasAttribute('formaction')
			? submitter.formAction
			: formElement.action;
		formElement.submit();
	}}
	method="POST"
>
	...
</form>

As such I'm against this: data-sveltekit-X all work on child elements, but in this specific case you would have to add it for the form or button element specifically.

This sounds like too much of an edge case to add this potentially confusing behavior, therefore closing.

@dummdidumm dummdidumm closed this as not planned Won't fix, can't repro, duplicate, stale Jan 15, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature / enhancement New feature or request
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants