Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/yudai-nkt/satori-factory
- Owner: yudai-nkt
- License: mit
- Created: 2024-04-03T13:54:31.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-04-04T14:34:25.000Z (9 months ago)
- Last Synced: 2024-08-09T17:52:56.711Z (5 months ago)
- Topics: jsx, satori
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/satori-factory
- Size: 44.9 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
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.