Releases: urql-graphql/urql
v1.5.0
This release finally adds shortcuts to imperatively make queries and mutations.
They make it easier to quickly use the client programmatically, either with
a Wonka source-based or Promise-based call.
// Call .query or .mutation which return Source<OperationResult>
const source = client.query(doc, vars);
const source = client.mutation(doc, vars);
// Call .toPromise() on the source to get Promise<OperationResult>
const promise = client.query(doc, vars).toPromise();
const promise = client.mutation(doc, vars).toPromise();
This version also adds a useClient
hook as a shortcut for useContext(Context)
.
We provide a default client that makes requests to /graphql
. Since that has
confused users before, we now log a warning, when it's used.
v1.4.1
This release adds "active teardowns" for operations, which means that an exchange can now send a teardown to cancel ongoing operations. The subscriptionsExchange
for instance now ends ongoing subscriptions proactively if the server says that they've completed! This is also reflected as fetching: false
in the useQuery
and useSubscription
hook.
We've also fixed a small issue with suspense and added all features from useQuery
to useSubscription
! This includes the pause
argument and an executeSubscription
function.
v1.4.0
This release removes all metadata for the @urql/devtools
extension from the core
urql
package. This data will now be generated internally in the devtools exchange
itself. Please also upgrade to the latest @urql/devtools
version if you're using
the extension.
This release has mainly been focused on minor refactors to keep the bundlesize low.
But it also introduces new features, like specifying a default requestPolicy
and
a new polling option on useQuery
!
This release also exports makeResult
and makeErrorResult
, which will reduce the
boilerplate code that you need for custom fetch exchanges.
- Minor bundlesize optimizations and remove
debugExchange
in production (see #375) - ✨ Add
requestPolicy
option toClient
to change the default request policy (see #376) - ⚠ Remove dependency on
graphql-tag
and improveOperation.key
hashing (see #383) - Remove
networkLatency
andsource
metadata from context, and deleteuseDevtoolsContext
(see #387 and #388) - ✨ Add support for polling with
pollInterval
argument touseQuery
, by @mxstbr (see #397) - ⚠ Prevent
__typename
from being added to the toplevel GraphQL documents (see #399) - Add
operationName
field tofetch
request body (see #401)
v1.3.0
This release comes with some important fixes and enhancements, which all address
certain edge-cases when using urql
.
It fixes the cache-and-network
request policy, which wouldn't always work correctly and issue another network request after resolving a response from the default cache. We also had a major bug in React Native environments where responses wouldn't ever be reflected in the useQuery
hook's state. Lastly, you can now use extensions
from your GraphQL servers and modify the OperationContext
from the hooks options.
- ✨ Add support for
extensions
key in GraphQL responses, by @adamscybot (see #355) - ⚠ Fix
cache-and-network
request policy by adding operation flushing to the client (see #356) - Add
fetch
option to the Client so it doesn't have to be polyfilled globally (see #357 and #359) - ⚠ Fix
useImmediateState
for React Native environments (see #358) - ✨ Add
context
option to all hooks to allowOperationContext
to be changed dynamically (see #351) - Add
isClient
option tossrExchange
in casesuspense
is activated on the client-side (see #369)
v1.2.0
A release focused on improving developer experience (in preparation for the
upcoming devtools) as well as minor documentation improvements and bug fixes.
- Add metadata to operation context in development (see #305, #324, #325 and #329)
- Fix minor typename memory leak (see #321)
- Fix types for react subscription components (see #328)
- Fix displayName attributes not populated in examples (see #330)
- Fix error in
collectTypes
method (see #343) - Fix HTTP status bounds check error (see #348)
v1.1.3
v1.1.2
This patch fixes a small bug that usually manifests in development,
where the initial state would be incorrect after a fast response from
the GraphQL API. This used to lock the state into fetching: true
indefinitely in some cases.
v1.1.1
This release comes with two small patches. One being a crticial fix, where cancelled requests would be erroneously deduped, which meant a previously cancelled query would never be fetched.
It also refactors our bundling process to transpile Object.assign
to restore IE11 support and reduce the amount of duplicate helper in our bundles.
v1.1.0 – Server-side Rendering Support!
After our recent announcement of urql
v1 we've received lots of positive feedback and support, but it became clear that the most requested feature for urql
was server-side rendering.
So we went back into the machine room and implemented it, so today we're publishing urql
v1.1, just a week after our blog post! Our new implementation of server-side rendering works by adding a single new exchange, the ssrExchange
, and using a new suspense-mode on the server-side, which can be used together with react-ssr-prepass
to prefetch urql
queries. 🎉
Getting started with server-side rendering in urql
is easy! We've got an extensive guide on how to set it up, which you can read on our new & fancy docs site, or alternatively as markdown on GitHub.
We've also added a new example to our repository based on Next.js!
Changes
This version now also requires a version of React supporting hooks! (>= 16.8.0)
We unfortunately forgot to correct the peerDependencies
entries in our v1.0.0 release.
- ✨ Add server-side rendering support (see #268)
- ✨ Ensure that state changes are applied immediately on mount (see #256)
- Ensure that effects are run immediately on mount (see #250)
⚠️ Removecreate-react-context
and bump React peer dependency (see #252)- Add generics to the
Query
,Mutation
, andSubscription
components ⚠️ Fix issues whereuseQuery
wouldn't update or teardown correctly (see #243)- ✨ Add support for
pause
prop/option touseQuery
andQuery
(see #237)
v1.0.5
- Export
MutationProps
types for TS typings, by @mxstbr (see #236) - Export
Use*Args
types for TS typings, by @mxstbr (see #235) - Export all hook response types for TS typings, by @good-idea (see #233)
- ⚠ Fix runtime error in
cachExchange
where already deleted keys where being accessed (see #223) ⚠️ FixcacheExchange
not forwarding teardowns correctly, which lead to unnecessary/outdated queries being executed, by @federicobadini (see #222)- Change
GraphQLRequest
to always pass on a parsed GraphQLDocumentNode
instead of just a string, which reduces work (see #221) - Fix incorrect TS types by using
Omit<T, K>
(see #220)