Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sukkaw/forgetti-loader
A webpack/rspack loader and a Next.js plugin that brings an auto-memoization compiler to solves your hook spaghetti. Powered by forgetti which is inspired by React Forget.
https://github.com/sukkaw/forgetti-loader
forgetti nextjs nextjs-plugin react react-forget rspack rspack-loader webpack webpack-loader
Last synced: 4 days ago
JSON representation
A webpack/rspack loader and a Next.js plugin that brings an auto-memoization compiler to solves your hook spaghetti. Powered by forgetti which is inspired by React Forget.
- Host: GitHub
- URL: https://github.com/sukkaw/forgetti-loader
- Owner: SukkaW
- License: mit
- Created: 2023-04-22T07:30:51.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-03-19T07:56:26.000Z (10 months ago)
- Last Synced: 2025-01-19T13:55:44.576Z (5 days ago)
- Topics: forgetti, nextjs, nextjs-plugin, react, react-forget, rspack, rspack-loader, webpack, webpack-loader
- Language: TypeScript
- Homepage:
- Size: 275 KB
- Stars: 54
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# forgetti-loader
A webpack loader, a [rspack](https://www.rspack.dev) loader and a Next.js plugin that brings an auto-memoization compiler to solve your hook spaghetti. Powered by [Forgetti](https://github.com/lxsmnsyc/forgetti) which is inspired by React Forget.
## What is Forgetti?
[Forgetti](https://github.com/lxsmnsyc/forgetti) is an auto-memoization Babel plugin made by [Alexis H. Munsayac](https://github.com/lxsmnsyc). It was inspired by React Forget and can be used for optimizing a hook-based flow like React hooks.
[![React without memo](https://img.youtube.com/vi/lGEMwh32soc/0.jpg)](https://youtu.be/lGEMwh32soc "React without memo")
## Installation
```bash
# npm
npm i forgetti
npm i -D forgetti-loader
# yarn
yarn add forgetti
yarn add -D forgetti-loader
# pnpm
pnpm add forgetti
pnpm add -D forgetti-loader
```## Usage
### Webpack / Rspack
```js
// webpack.config.js / rspack.config.js// You can leverage your IDE's Intellisense (autocompletion, type check, etc.) with the helper function:
const { defineForgettiLoaderOptions } = require('forgetti-loader');module.exports = {
module: {
rules: [
rules: [
{
test: /\.[mc]?jsx$/i,
exclude: /node_modules/,
use: [
// babel-loader, swc-loader, esbuild-loader, or anything you like to transpile JSX should go here.
// If you are using rspack, the rspack's buiilt-in react transformation is sufficient.
// { loader: 'swc-loader' },
// Now add forgetti-loader
{
loader: 'forgetti-loader',
options: defineForgettiLoaderOptions({
// Forgetti options. See https://github.com/lxsmnsyc/forgetti/blob/main/docs/configuration.md for more details.
preset: 'react',
// preset: 'preact',
// preset: {}
})
}
]
}
]
]
}
};
```### Next.js
```js
// next.config.js
const withForgetti = require('forgetti-loader/next');module.exports = withForgetti({
// Forgetti options. See https://github.com/lxsmnsyc/forgetti/blob/main/docs/configuration.md for more details.
preset: 'react',
// preset: 'preact',
// preset: {}
})({
// Your Next.js config goes here.
});
```## Author
**forgetti-loader** © [Sukka](https://github.com/SukkaW), Released under the [MIT](./LICENSE) License.
Authored and maintained by Sukka with help from contributors ([list](https://github.com/SukkaW/forgetti-loader/graphs/contributors)).> [Personal Website](https://skk.moe) · [Blog](https://blog.skk.moe) · GitHub [@SukkaW](https://github.com/SukkaW) · Telegram Channel [@SukkaChannel](https://t.me/SukkaChannel) · Twitter [@isukkaw](https://twitter.com/isukkaw) · Mastodon [@[email protected]](https://acg.mn/@sukka) · Keybase [@sukka](https://keybase.io/sukka)