-
-
Notifications
You must be signed in to change notification settings - Fork 47
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
[queryParamsStore] enhancements #430
Comments
Thanks for the kinds words @frederikhors 😊. If I'm understanding correctly, It sounds like what you are looking for is query string management with different strategies. Svelte UX has queryParamsStore (manage multiple params) as well as queryParamStore (single param) with different types/strategies. There is a pretty robust test suite and docs to see the differences, but maybe I'm misunderstanding what you are looking for. @paoloricciuti also has the wonderful https://github.com/paoloricciuti/sveltekit-search-params which I haven't looked closely at yet, but I think it's similar and likely has better SvelteKit integration (I created |
Thanks for your answer. I tried I created a small reproduction: see the file
These are very useful features especially with Svelte 5. I'm already talking with @paoloricciuti here about this. |
Thanks for the added context and discussion. If i understand the problem you want:
You MIGHT be able to use I haven't tried testing this and rather buried with other tasks ATM. I plan to migrate all Svelte UX stores to Svelte 5 with runes but it will take some time. import { queryParamsStore } from 'svelte-ux';
import { page } from '$app/stores';
import { goto } from '$app/navigation';
let { pagination, condition } = $props();
const paginationParam = queryParamStore({
name: 'pagination',
default: pagination ?? { page: 1, size: 10 },
paramType: 'object',
page,
goto,
});
const conditionParam = queryParamStore({
name: 'condition',
default: condition,
paramType: 'object',
page,
goto,
});
<input type="text" bind:value={$conditionParam.name} /> |
I did try to update your SvelteLab example with the following... <script>
import { queryParamStore } from 'svelte-ux';
import { afterNavigate, goto } from '$app/navigation';
import { page } from '$app/stores';
import { getData } from '../db.ts';
let { pagination, condition } = $props();
const paginationParam = queryParamStore({
name: 'pagination',
default: pagination ?? { page: 1, size: 10 },
paramType: 'object',
page,
goto,
});
const conditionParam = queryParamStore({
name: 'condition',
default: condition ?? {},
paramType: 'object',
page,
goto,
});
let listInput = $derived({
pagination: $paginationParam,
condition: $conditionParam
});
const players = $derived.by(() => {
return getData(listInput);
});
</script>
condition: {JSON.stringify($conditionParam)}
<br /><br />
Search player by name:
<input type="text" bind:value={$conditionParam.name} />
<br /><br />
{#each players as player}
name: {player.name} - gender: {player.gender} <br /><br />
{/each} but it didn't work |
I will try in a moment. I think But in the meantime, I opened sveltejs/kit#12460 right now. That code works (not so performant or good) but is very repetitive, but it's a start for me. Do you think the code you posted can do the same? |
TBH I'm not sure. |
I updated https://www.sveltelab.dev/4vnxej0ewwtlwe9?files=.%2Fsrc%2Froutes%2Fsvelte-ux%2F%2Bpage.svelte. Condition is not persisted in the URL at all. 😢 |
Look in your console 😉. This was the error I was referring to. |
You're right. I don't know what to do. I'm shocked that I haven't found anything similar to what I need anywhere on the web and yet it's something that should be very useful to a lot of people! |
I think rolling something custom like you have in sveltejs/kit#12460 is your best choice right now. Svelte UX's plan for Svelte 5 is to get it compatible with Svelte 3-5 which is helping to tease out some Svelte 5 regressions. I'm fairly close on getting the full docs running on Svelte 5 (it does locally, but currently fails some I already have Github Analysis and Strava Analysis running on Svelte 5, but know there is at least an issue with DateRangeField in some cases I need to investigate / report. LayerChart's simplified charts is my current priority when I have time for open source, which ebbs and flows. |
Since your project is AMAZING, I was wondering what do you think about creating a "kit for Kit" with Svelte 5 that allows us to save in the page URL any POJO object or scalar type we need with the serializer we need (for example I can use
JSON.stringify()
andJSON.parse()
for now).I described something similar here.
This would be amazing for lists filters for example:
I have a players list on page
/players
I order the list by created_at DESC
the kit saves this filter in the URL:
/players?order_by=created_at_DESC
(just an example)I filter players form team_id: 123
the kit saves this new filter in the URL:
/players?order_by=created_at_DESC&team_id=123
(just an example)I go back with the browser and the URL is now again:
/players?order_by=created_at_DESC
(just an example)I reload the page now and since the URL is this the list is ordered like before the reload
I hope you get the idea.
I now can manually add this using in each place I need it
url.searchParams.set
andafterNavigate
but I would like to have an helper to be used everywhere.Again, thanks for your work!
The text was updated successfully, but these errors were encountered: