Vulcan
Vulcan copied to clipboard
Duplicate Item with withMulti
Describe the bug Hola, I have a problem with withMulti2 when I make a request by limiting. I have data which is duplicated in result node v14.16.1 vulcan
To Reproduce Steps to reproduce the behavior:
1 - withMulti2( ... limit: 3)([component])
2 - in my component call loadMoreInc() after result
content duplicated item
According to the code from your PR, this is a backend issue => the multi resolver is sending the same item twice, as if the limit was taken into account incorectly
useMulti2
in meteor seems to work for me, but useMulti from vulcanjs/hooks is not getting the filter after loadmore.
I am filtering documents by userId
(and a template type field), and I can see that in the first query (before loadmore), all filter and userId is present:
data:image/s3,"s3://crabby-images/d1b5b/d1b5b4797a5100309eb3444ea4965fad0c3494bd" alt="Screenshot 2021-06-17 at 13 08 35"
After loadMore button clicked, the query no longer has the filter at all:
data:image/s3,"s3://crabby-images/28c62/28c628920d56a47acd8010c21b88464c0bd948e1" alt="Screenshot 2021-06-17 at 13 05 53"
So I'm just looking into that now 🤓
I have tracked it down to here: https://github.com/VulcanJS/vulcan-npm/blob/98b23f1ea04b18c39b036faafb075951b4bd4549/packages/react-hooks/multi.ts#L182
in fetchMore
, I don't see the filter
, only the input
with offset:
return fetchMore({
variables: { input: offsetInput },
updateQuery: fetchMoreUpdateQuery(resolverName),
});
Setting it up locally looks like there is a few steps and maybe a learning curve: https://github.com/VulcanJS/vulcan-next/blob/devel/src/content/docs/contributing.md. I haven't got time right now to dig further, so will come back to it next week and continue on other parts first
@GraemeFulton will be fixed by https://github.com/VulcanJS/vulcan-npm/pull/56/files (edit: released just now in "0.2.1" of react-hooks)
@IBRAHIMDANS the issue is that variables are not correclty merged in the hook, so in the loadMore/loadMoreInc calls, it indeed loses the filter. Instead of using "uniq", the solution is to fix the variable merging pattern, you can take a look at the PR: https://github.com/VulcanJS/vulcan-npm/pull/56/files
To fix this:
- I get current variables from the queryResult (when doing
useQuery
, Apollo returns the result but also the variables you used to get this result) - I merge the variables (previously, I was just merging the pagination inputs)