Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/donavon/superjson-remix
https://github.com/donavon/superjson-remix
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/donavon/superjson-remix
- Owner: donavon
- License: mit
- Created: 2022-03-13T17:28:57.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2023-02-04T18:34:23.000Z (almost 2 years ago)
- Last Synced: 2024-10-12T08:11:25.450Z (3 months ago)
- Language: TypeScript
- Size: 458 KB
- Stars: 83
- Watchers: 2
- Forks: 4
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-remix - superjson-remix - A solution for Remix that allows you to send binary data from your loader to your React client app. (Utility)
- awesome-remix - superjson-remix - A solution for Remix that allows you to send binary data from your loader to your React client app. (Utility)
README
# superjson-remix
A solution for Remix that allows you to send binary data from your `loader` function to your React client app. It uses the awesome [`superjson`](https://github.com/blitz-js/superjson) package to serialize/deserialize your data automatically.
## Problem
With the existing Remix approach, only JSON parsable data can be sent to the client. This is a problem for binary data such as `Date`, `Map`, `Set` or `BigInt`.
Say you have a `loader` function and would like to send this to the client:
```ts
import { json } from 'remix';const loader: LoaderFunction = () => {
const obj = {
set: new Set([1, 2, 3]),
now: new Date(),
largeNumber: BigInt(9007199254740991),
};return json(obj);
};
```Well you're out of luck! On the client, `Set` will parse to an empty object.
```
set: {},
````Date` will parse as an ISO-8601 string — not the end of the world, but certainly inconvenient.
```
now: '2022-03-13T16:47:37.521Z'
```And you just can't send `BigInt` to the client, period.
```
TypeError: Do not know how to serialize a BigInt
```## Solution
With `superjson-remix`, you can easily send our example data to the client. Just replace the `json` helper function that you normally would import from `remix` with an import from `superjson`.
```diff
- import { json } from 'remix';
+ import { json } from 'superjson-remix';
```## What about the client?
We do the same thing on the client. We import `useLoaderData` from `superjson-remix` instead of from `remix`, just like we did with `json` on the server.
```diff
- import { useLoaderData } from 'remix';
+ import { useLoaderData } from 'superjson-remix';
```## Complete example
Here is an example route that uses `superjson-remix` to send our data to the client.
```js
import { json, useLoaderData } from 'superjson-remix';export const loader = () => {
const obj = {
set: new Set([1, 2, 3]),
now: new Date(),
largeNumber: BigInt(9007199254740991),
};return json(obj);
};const MyComponent = () => {
const { set, now, largeNumber } = useLoaderData();return (
Our set: {Array.from(set).join(', ');}
Server time: {now.toLocaleString()}
A large number: {largeNumber.toString()}
);
};export default MyComponent;
```It renders the following.
```
Our set: 1, 2, 3Server time: 3/13/2022, 1:05:20 PM
A large number: 9007199254740991
```## Oh, yeah. The `meta` function.
We provide a `withSuperJSON` higher-order function that wraps your `meta` function and will automatically deserialize the `data` argument.
```js
import { withSuperJSON } from 'superjson-remix';export const meta = withSuperJSON(({ data }) => {
return {
title: 'Sample App',
description: `Created on ${data.now.toLocaleString()}`,
};
});
```## Getting Started
Install the library with your package manager of choice, e.g.:
```
npm i superjson-remix
```
or
```
yarn add superjson-remix
```
## License
© 2022 Donavon West. Released under [MIT license](./LICENSE).