The nostalgie/functions
package exposes some tools to easily interact with Server Functions.
IMPORTANT: The
useQueryFunction
anduseMutationFunction
hooks must be invoked with an actual reference to the Server Function that you want to invoke. Don't worry though, the Server Function and its dependencies won't actually be included in your front-end bundles. The Nostalgie compiler takes care of swapping out the actual function with an internal representation at build time.Using a reference to the actual function allows us to give rich type hinting on the shape of required arguments and on the data ultimately returned by the function. It also means that information is equally available to JavaScript and TypeScript users working in an environment with the TypeScript language services.
useQueryFunction(queryFunction, args, [options])
A React Hook that returns a live observer of the result of invoking a Server Function. Dependending on the options used, this may return cached ('stale') data from a previous invocation or even an invocation that happened during server rendering.
queryFunction
- a reference to the actual Server Function that you want to invoke.args
- an array of arguments that will be passed to the Server Function. These must be serializable to JSON as they may sometimes be passed via HTTP request.options
- optional configuration for the query, which are identical to useQuery
options in react-query
except that queryKey
and queryFn
cannot be provided as Nostalgie will determine these automatically.Returns the query observer object returned by useQuery
. Please refer to the (excellent) react-query
documentation for more information.
In this example, we want to show the result of calling process.resourceUsage()
in the browser and refresh this value periodically.
./src/functions.js:
export function getResourceUsage() {
return process.resourceUsage();
}
./src/ResourceUsage.jsx:
import { useQueryFunction } from 'nostalgie/functions';
import * as React from 'react';
import { getResourceUsage } from '../../../functions';
export function ResourceUsage() {
// The `usage` object is an object that will update over time as the lifecycle
// of the query progresses.
const usage = useQueryFunction(getResourceUsage, [], {
refetchInterval: 10000, // Every ten seconds
});
// In the real world, we might want to handle different states differently
if (!usage.isSuccess) {
return <pre>Loading...</pre>;
}
// Show our resource usage as formatted JSON
return <pre>{JSON.stringify(usage.data, null, 2)}</pre>;
}
Live result:
{ "userCPUTime": 760000, "systemCPUTime": 30000, "maxRSS": 69312, "sharedMemorySize": 0, "unsharedDataSize": 0, "unsharedStackSize": 0, "minorPageFault": 0, "majorPageFault": 0, "swappedOut": 0, "fsRead": 0, "fsWrite": 0, "ipcSent": 0, "ipcReceived": 0, "signalsCount": 0, "voluntaryContextSwitches": 0, "involuntaryContextSwitches": 0 }
useMutationFunction(queryFunction, [options])
A React Hook that returns a live observer of the a mutating Server Function. The server function will not be invoked until the .mutate()
method is invoked.
queryFunction
- a reference to the actual Server Function that you want to invoke.options
- optional configuration for the query, which are identical to useMutation
options in react-query
except that mutationFn
cannot be provided as Nostalgie will determine it automatically.
mutate(args)
- invoke the mutation function in the background, where:
args
- an array of arguments that will be passed to the Server Function. These must be serializable to JSON as they may sometimes be passed via HTTP request.mutateAsync(args)
- invoke the mutation function, returning a Promise
for its outcome, where:
args
- an array of arguments that will be passed to the Server Function. These must be serializable to JSON as they may sometimes be passed via HTTP request.Returns the mutation observer object returned by useMutation
. Please refer to the (excellent) react-query
documentation for more information.