Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/2nthony/usesignal
https://github.com/2nthony/usesignal
react react-hooks react-signals signals
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/2nthony/usesignal
- Owner: 2nthony
- License: mit
- Created: 2024-09-12T11:27:29.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-10-20T08:59:48.000Z (2 months ago)
- Last Synced: 2024-10-20T13:38:45.089Z (2 months ago)
- Topics: react, react-hooks, react-signals, signals
- Language: TypeScript
- Homepage: https://usesignal.vercel.app
- Size: 467 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# UseSignal
[![npm version][npm-version-src]][npm-version-href]
[![npm downloads][npm-downloads-src]][npm-downloads-href]
[![bundle][bundle-src]][bundle-href]
[![JSDocs][jsdocs-src]][jsdocs-href]
[![License][license-src]][license-href]Collection of Essential React Hooks with [Signals](https://github.com/preactjs/signals/tree/main/packages/react). Basically a **FORK** of [VueUse](https://vueuse.org/).
## Notice
- This project is currently in the initial development stage and is not yet stable.
- Bad DX with server side framework(e.g. Next.js) DEV mode, when a component changed, the `useSignalEffect(@preact/signals-react)/useWatch*(usesignal/core)` will never run the callback when signal changed; works fine in PROD mode.## Docs & Demos
[UseSignal](https://usesignal.vercel.app/), but you can ref to [VueUse](https://vueuse.org/functions.html) directly, all currently supported functions usage basically the same.
## Install
```sh
pnpm add @preact/signals-react @usesignal/core
```## Usage
```ts
import { useLocalStorage, useMouse, usePreferredDark } from '@usesignal/core'export function useCustomHook() {
// tracks mouse position
const { x, y } = useMouse()// if user prefers dark theme
const isDark = usePreferredDark()// persist state in localStorage
const store = useLocalStorage(
'my-storage',
{
name: 'Apple',
color: 'red',
},
)return { x, y, isDark, store }
}
```## Enhancements
### `signal`=`useSignal`
Proxy `Signal` to support `useRef`.
```tsx
import { useSignal } from '@usesignal/core'export default function App() {
const el = useSignal()
const input = useSignal('Hello World')console.log(el.value) // div
return (
)
}
```### `computed`=`useComputed`
Proxy `ReadonlySignal` to `ComputedSignal`, support `get` and `set`.
```ts
import { useComputed } from '@usesignal/core'export default function App() {
const count = useSignal(0)
// readonly
const computed = useComputed(() => count.value * 2)
// getter & setter
const computed2 = useComputed({
get() {
return count.value * 2
},
set(value) {
count.value = value / 2
},
})
}
```## Playground
- [Demo(vite-react)](https://usesignal.vercel.app/)
- [Next.js(shadcn/ui(stackblitz))](https://stackblitz.com/edit/stackblitz-starters-xvtr12?description=The%20React%20framework%20for%20production&file=app/page.tsx&title=Next.js%20Starter)
- [remix-run(stackblitz)](https://stackblitz.com/edit/remix-run-remix-6gxayd?file=app/routes/_index.tsx)## License
[MIT](./LICENSE) License © 2024-PRESENT [2nthony](https://github.com/2nthony)
[npm-version-src]: https://img.shields.io/npm/v/@usesignal/core?style=flat&colorA=080f12&colorB=1fa669
[npm-version-href]: https://npmjs.com/package/@usesignal/core
[npm-downloads-src]: https://img.shields.io/npm/dm/@usesignal/core?style=flat&colorA=080f12&colorB=1fa669
[npm-downloads-href]: https://npmjs.com/package/@usesignal/core
[bundle-src]: https://img.shields.io/bundlephobia/minzip/@usesignal/core?style=flat&colorA=080f12&colorB=1fa669&label=minzip
[bundle-href]: https://bundlephobia.com/result?p=@usesignal/core
[license-src]: https://img.shields.io/github/license/2nthony/usesignal.svg?style=flat&colorA=080f12&colorB=1fa669
[license-href]: https://github.com/2nthony/usesignal/blob/main/LICENSE
[jsdocs-src]: https://img.shields.io/badge/jsdocs-reference-080f12?style=flat&colorA=080f12&colorB=1fa669
[jsdocs-href]: https://www.jsdocs.io/package/@usesignal/core