Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/yudai-nkt/satori-factory

Tiny yet full-fledged JSX factory for Satori
https://github.com/yudai-nkt/satori-factory

jsx satori

Last synced: about 2 months ago
JSON representation

Tiny yet full-fledged JSX factory for Satori

Awesome Lists containing this project

README

        

# Satori Factory
[![NPM Version](https://img.shields.io/npm/v/satori-factory?logo=npm)](https://www.npmjs.com/package/satori-factory)
[![test](https://github.com/yudai-nkt/satori-factory/actions/workflows/test.yml/badge.svg)](https://github.com/yudai-nkt/satori-factory/actions/workflows/test.yml)
[![bundle size](https://deno.bundlejs.com/badge?q=satori-factory/jsx-runtime&config=%7B%22compression%22:%22brotli%22%7D)](https://bundlejs.com/?q=satori-factory%2Fjsx-runtime&config=%7B%22compression%22%3A%22brotli%22%7D)

Tiny yet full-fledged JSX factory for [Satori](https://github.com/vercel/satori).

```tsx
/** @jsxImportSource satori-factory */
import satori from "satori";

const svg = await satori(

Hello, Satori Factory!
, {
height: 630,
width: 1200,
fonts: [
/* your fonts data here */
],
});
```

## Features

- ***Featherlight*** — Satori Factory has zero dependencies and can be minified & brotli'd to less than 0.2kB.
- ***Function component*** — You can define reusable components much like React.
- ***Fine-tuned TypeScript support*** — Give unsupported CSS properties and you will get warned.

## Installation

This package is available on NPM registry.
You can install `satori-factory` using a package manager of your preference.

## Usage

Satori Factory supports the newer JSX transformation, so you need to configure `tsconfig.json` accordingly.

```json
{
"compilerOptions": {
"jsx": "react-jsx",
"jsxImportSource": "satori-factory"
},
}
```

ESBuild picks up these compiler options automatically, so the above setup should suffice in major Vite-powered frameworks.

You can also specify JSX import source on a per-file basis.
See [TSConfig reference](https://www.typescriptlang.org/tsconfig#jsxImportSource) for details.

## FAQ
### Why not React?

If you already use React in your project, this package is probably not for you.

### What's the motivation behind this package then?

The primary usecase is non-React framework such as Astro, SvelteKit, or HonoX.
When you want to use Satori with these frameworks, you have to [use object literals](https://github.com/vercel/satori#use-without-jsx) instead of JSX expressions, which is quite cumbersome.
Of course you can install React as an additional dependency but using React only for Satori might be a sledgehammer for a nut if you don't use it in the main part of your application.
In addition to that, reducing server-side bundle size is becoming more important than ever due to the tight restriction in the emerging CDN edge computing platforms.

This is where Satory Factory comes in.
It offers the ergonomics of JSX to Satori users while incurring as small build footprint as possible.

### Satori is big enough that the size of React can be negligible, isn't it?

Yes.
Unfortunately and stupidly, I only noticed that fact after finishing the initial implementation of the package.

## License

This package is release under the MIT License.
See [LICENSE.md](./LICENSE.md) for details.