Comments (2)
Possible but not recommended as you might cause value skipping setting the reactive values on the useMutation
returns, which could be acceptable if the only way you use useMutation
is via the execute
function.
So the dirty way is to introduce a custom fetch plugin that throws, something similar to fetch
default plugin which you can use as a baseline but make sure to throw the error
. I'm not going to offer code guidance there since I don't like recommending this hack.
Another way that I recommend, is to compose useMutation
with a custom one:
export function useThrowingMutation(query) {
const mutation = useMutation(query);
mutation.execute = function executeWithThrow(...args) {
const { data, errors } = await execute(...args);
if (error) {
throw error;
}
return { data };
}
}
This is simpler and should work well and you can use it for all of your mutations.
Internally this is hard to offer out of the box because villus uses a pipeline of plugins system, so if one crashes it is a big deal and causes integrity concerns to the GraphQL result.
from villus.
I understand, thanks for your answer!
from villus.
Related Issues (20)
- createClient - No fetch function in the code HOT 1
- updating the cache after a mutation HOT 2
- Mutation response undefined HOT 1
- How to set authorization header when using createClient({}) instance, I use quasar framework and I want to add headers on each request send to API. HOT 1
- missing null in type of useMutation HOT 1
- How to get a global isFetching status for queries & mutations with Villus HOT 1
- SubscriptionForwarder Typescript issue with graphql-ws HOT 1
- useSubscription return old value when router.push is used HOT 1
- Query normalization with `useSubscription` HOT 1
- Feature request: hooks for data fetch HOT 5
- Deploying to Vercel Edge function
- Typing executeQuery/executeMutation when used in a different context
- Manually setting cache HOT 7
- Cache persist on IndexedDB? HOT 2
- refetchTags without making a mutation HOT 2
- When setting/changing variables in plugins, the (cache) key is not updated HOT 1
- Question: Villus with Mock Service Worker (msw) HOT 1
- Duplicate requests with Villus and Nuxt HOT 1
- The Pinia Example preview: "Loading..." HOT 1
- Fetch options HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from villus.