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

Document new React APIs in code - Part 2 of 2 #11523

Merged
merged 28 commits into from
Jan 26, 2024
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
4b65afd
Mark symbols in QueryReference as internal
jerelmiller Jan 25, 2024
8f22e23
Add documentation on toPromise for QueryReference
jerelmiller Jan 25, 2024
b479711
Add inline code tag in createQueryPreloader description
jerelmiller Jan 25, 2024
2be5751
Add since tag to createQueryPreloader
jerelmiller Jan 25, 2024
00e075c
Add docblock for useLoadableQuery
jerelmiller Jan 25, 2024
7efaa70
Add useLoadableQuery to hooks page
jerelmiller Jan 25, 2024
44c7514
Add `@since` tag to useQueryRefHandlers
jerelmiller Jan 25, 2024
8623b09
Add useQueryRefHandlers to hooks documentation
jerelmiller Jan 25, 2024
40e10dc
Add link to documentation on createQueryPreloader
jerelmiller Jan 25, 2024
811c1dd
Rerun extract api report
jerelmiller Jan 25, 2024
fd229f6
Add additional info for toPromise
jerelmiller Jan 25, 2024
1d15fd3
Move doc for useLoadableQuery to first overload
jerelmiller Jan 26, 2024
7414629
Create a type for the handlers returned from useLoadableQuery
jerelmiller Jan 26, 2024
e9f56d6
Add doc comments to useLoadableQuery handlers
jerelmiller Jan 26, 2024
3e59cbe
Add more detailed code for useLoadableQuery
jerelmiller Jan 26, 2024
d6fcb1b
List createQueryPreloader as alpha
jerelmiller Jan 26, 2024
3199bb7
Clean up Prettier, Size-limit, and Api-Extractor
jerelmiller Jan 26, 2024
a80245e
Use `@alpha` designation for toPromise on QueryReference
jerelmiller Jan 26, 2024
44cc612
Clean up Prettier, Size-limit, and Api-Extractor
jerelmiller Jan 26, 2024
b88f14e
Fix id prefix
jerelmiller Jan 26, 2024
841f88d
Fix syntax error in list
jerelmiller Jan 26, 2024
3c572b1
Add new preloading doc for createQueryPreloader
jerelmiller Jan 26, 2024
b0516e2
Revert change to add handlers type
jerelmiller Jan 26, 2024
4760636
Allow overrides to be formatted
jerelmiller Jan 26, 2024
9b14c23
Move result override for useLoadableQuery to own component
jerelmiller Jan 26, 2024
0cef515
Move description for useLoadableQuery to last overload
jerelmiller Jan 26, 2024
b6a7040
Extract API
jerelmiller Jan 26, 2024
66b958e
Ensure | null is added to queryRef in return type
jerelmiller Jan 26, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 2 additions & 3 deletions .api-reports/api-report-react.md
Original file line number Diff line number Diff line change
Expand Up @@ -1759,13 +1759,12 @@ interface QueryOptions<TVariables = OperationVariables, TData = any> {
//
// @public
export interface QueryReference<TData = unknown, TVariables = unknown> {
// (undocumented)
// @internal (undocumented)
[PROMISE_SYMBOL]: QueryRefPromise<TData>;
// Warning: (ae-forgotten-export) The symbol "InternalQueryReference" needs to be exported by the entry point index.d.ts
//
// (undocumented)
// @internal (undocumented)
readonly [QUERY_REFERENCE_SYMBOL]: InternalQueryReference<TData>;
// (undocumented)
toPromise(): Promise<QueryReference<TData, TVariables>>;
}

Expand Down
5 changes: 2 additions & 3 deletions .api-reports/api-report-react_hooks.md
Original file line number Diff line number Diff line change
Expand Up @@ -1634,13 +1634,12 @@ interface QueryOptions<TVariables = OperationVariables, TData = any> {
//
// @public
interface QueryReference<TData = unknown, TVariables = unknown> {
// (undocumented)
// @internal (undocumented)
[PROMISE_SYMBOL]: QueryRefPromise<TData>;
// Warning: (ae-forgotten-export) The symbol "InternalQueryReference" needs to be exported by the entry point index.d.ts
//
// (undocumented)
// @internal (undocumented)
readonly [QUERY_REFERENCE_SYMBOL]: InternalQueryReference<TData>;
// (undocumented)
toPromise(): Promise<QueryReference<TData, TVariables>>;
}

Expand Down
5 changes: 2 additions & 3 deletions .api-reports/api-report-react_internal.md
Original file line number Diff line number Diff line change
Expand Up @@ -1398,11 +1398,10 @@ interface QueryOptions<TVariables = OperationVariables, TData = any> {
//
// @public
export interface QueryReference<TData = unknown, TVariables = unknown> {
// (undocumented)
// @internal (undocumented)
[PROMISE_SYMBOL]: QueryRefPromise<TData>;
// (undocumented)
// @internal (undocumented)
readonly [QUERY_REFERENCE_SYMBOL]: InternalQueryReference<TData>;
// (undocumented)
toPromise(): Promise<QueryReference<TData, TVariables>>;
}

Expand Down
5 changes: 2 additions & 3 deletions .api-reports/api-report.md
Original file line number Diff line number Diff line change
Expand Up @@ -2323,13 +2323,12 @@ export { QueryOptions }
//
// @public
export interface QueryReference<TData = unknown, TVariables = unknown> {
// (undocumented)
// @internal (undocumented)
[PROMISE_SYMBOL]: QueryRefPromise<TData>;
// Warning: (ae-forgotten-export) The symbol "InternalQueryReference" needs to be exported by the entry point index.d.ts
//
// (undocumented)
// @internal (undocumented)
readonly [QUERY_REFERENCE_SYMBOL]: InternalQueryReference<TData>;
// (undocumented)
toPromise(): Promise<QueryReference<TData, TVariables>>;
}

Expand Down
5 changes: 5 additions & 0 deletions docs/source/api/react/hooks.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ api_doc:
- "@apollo/client!useSubscription:function(1)"
- "@apollo/client!useApolloClient:function(1)"
- "@apollo/client!useReactiveVar:function(1)"
- "@apollo/client!useLoadableQuery:function(1)"
- "@apollo/client!useQueryRefHandlers:function(1)"
---

import UseFragmentOptions from '../../../shared/useFragment-options.mdx';
Expand Down Expand Up @@ -477,3 +479,6 @@ const { data } = useSuspenseQuery(
In this case, it becomes apparent for TypeScript that there is a direct connection between skipping and the `variables` option - and it will work without unsafe workarounds.

</blockquote>

<FunctionDetails canonicalReference="@apollo/client!useLoadableQuery:function(1)" headingLevel={2} />
<FunctionDetails canonicalReference="@apollo/client!useQueryRefHandlers:function(1)" headingLevel={2} />
45 changes: 45 additions & 0 deletions src/react/hooks/useLoadableQuery.ts
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,51 @@ export type UseLoadableQueryResult<
},
];

/**
* A hook for imperatively loading a query, such as responding to a user
* interaction.
*
* > Refer to the [Suspense - Fetching in response to user interaction](https://www.apollographql.com/docs/react/data/suspense#fetching-in-response-to-user-interaction) section for a more in-depth overview of `useLoadableQuery`.
*
* @example
* ```jsx
* import { gql, useLoadableQuery } from "@apollo/client";
*
* const GET_GREETING = gql`
* query GetGreeting($language: String!) {
* greeting(language: $language) {
* message
* }
* }
* `;
*
* function App() {
* const [loadGreeting, queryRef] = useLoadableQuery(GET_GREETING);
*
* return (
* <>
* <button onClick={() => loadGreeting({ language: "english" })}>
* Load greeting
* </button>
* <Suspense fallback={<div>Loading...</div>}>
* {queryRef && <Hello queryRef={queryRef} />}
* </Suspense>
* </>
* );
* }
*
* function Hello({ queryRef }) {
* const { data } = useReadQuery(queryRef);
*
* return <div>{data.greeting.message}</div>;
* }
* ```
*
* @since 3.9.0
* @param query - A GraphQL query document parsed into an AST by `gql`.
* @param options - Options to control how the query is executed.
* @returns A tuple in the form of `[loadQuery, queryRef, handlers]`
*/
export function useLoadableQuery<
TData,
TVariables extends OperationVariables,
Expand Down
2 changes: 1 addition & 1 deletion src/react/hooks/useQueryRefHandlers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ export interface UseQueryRefHandlersResult<
* // ...
* }
* ```
*
* @since 3.9.0
* @param queryRef - A `QueryReference` returned from `useBackgroundQuery`, `useLoadableQuery`, or `createQueryPreloader`.
*/
export function useQueryRefHandlers<
Expand Down
39 changes: 39 additions & 0 deletions src/react/internal/cache/QueryReference.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,47 @@ const PROMISE_SYMBOL: unique symbol = Symbol();
* suspend until the promise resolves.
*/
export interface QueryReference<TData = unknown, TVariables = unknown> {
/** @internal */
readonly [QUERY_REFERENCE_SYMBOL]: InternalQueryReference<TData>;
/** @internal */
[PROMISE_SYMBOL]: QueryRefPromise<TData>;
/**
* A function that returns a promise that resolves when the query has finished
* loading. The promise resolves with the `QueryReference` itself.
*
* @remarks
* This method is useful for preloading queries in data loading routers, such
* as [React Router](https://reactrouter.com/en/main) or [TanStack Router](https://tanstack.com/router),
* to prevent routes from transitioning until the query has finished loading.
* `data` is not exposed on the promise to discourage using the data in
* `loader` functions and exposing it to your route components. Instead, we
* prefer you rely on `useReadQuery` to access the data to ensure your
* component can rerender with cache updates. If you need to access raw query
* data, use `client.query()` directly.
*
* @example
* Here's an example using React Router's `loader` function:
* ```ts
* import { createQueryPreloader } from "@apollo/client";
*
* const preloadQuery = createQueryPreloader(client);
*
* export async function loader() {
* const queryRef = preloadQuery(GET_DOGS_QUERY);
*
* return queryRef.toPromise();
* }
*
* export function RouteComponent() {
* const queryRef = useLoaderData();
* const { data } = useReadQuery(queryRef);
*
* // ...
* }
* ```
*
* @experimental
jerelmiller marked this conversation as resolved.
Show resolved Hide resolved
*/
toPromise(): Promise<QueryReference<TData, TVariables>>;
}

Expand Down
5 changes: 4 additions & 1 deletion src/react/query-preloader/createQueryPreloader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -153,14 +153,17 @@ export interface PreloadQueryFunction {
* when you want to start loading a query as early as possible outside of a
* React component.
*
* @param client - The ApolloClient instance that will be used to load queries
* > Refer to the [Suspense - Initiating queries outside React](https://www.apollographql.com/docs/react/data/suspense#initiating-queries-outside-react) section for a more in-depth overview.
*
* @param client - The `ApolloClient` instance that will be used to load queries
* from the returned `preloadQuery` function.
* @returns The `preloadQuery` function.
*
* @example
* ```js
* const preloadQuery = createQueryPreloader(client);
* ```
* @since 3.9.0
* @experimental
*/
export function createQueryPreloader(
jerelmiller marked this conversation as resolved.
Show resolved Hide resolved
Expand Down
Loading