Important
If you or your company are using any of my projects or like what I'm doing, please consider backing me up. I appreciate it! ๐ Your support will help me allocate more time to the open source work.
- Become a sponsor
- Buy me a coffee โ๏ธ
- or send a Solana airdrop ๐ ๐, SOL:
LJJwteDZjL8u2Uhh5giwVpRa5KcHLkDogYAZntYbMsD
I maintain and contribute to OSS software, below is a list of my latest projects and writings. My current focus is on developing CRDT and OT collaborative editing solutions, local-first software, and Web3 apps.
- UI and React
react-use
andlibreact
โ lots of React hooks and utility components.nano-css
andnano-theme
โ the fastest and smallest CSS-in-JS library with lots of plugins (successor offreestyler
).react-embed
โ embed social widgets in your React app.use-media
โ CSS media queries through React hook.react-simple-player
โ a minimalistic audio player React component.clickable-json
โ JSON viewer and editor with hoverable and clickable objects.flexible-input
โ React<input>
and<textarea>
components which stretch to fit the content.collaborative-input
โ React<input>
and<textarea>
components with JSON CRDT real-time collaboration support.collaborative-ace
โ JSON CRDT real-time collaboration bindings for Ace editor.collaborative-monaco
โ JSON CRDT real-time collaboration bindings for the Monaco editor.collaborative-codemirror
โ JSON CRDT real-time collaboration bindings for the CodeMirror editor.awesome-styleguides
โ index of style guides and design systems.code-colors
andcode-colors-react
โ code syntax highlighting libraries.use-t
โ a small internationalization library for React.iconista
โ a React component for rendering open-source SVG icons.react-router-lite
โ a lightweight React router.
- Filesystem
- Data structures, algorithms, and utilities
json-joy
, a JSON CRDT implementation and collection of JSON awesomeness.json-joy/json-crdt
โ the fastest list CRDT implementation in JavaScript.json-joy/json-patch
โ very fast JSON Patch (and JSON Pointer) implementation in JavaScript.json-joy/json-expression
โ JSON Expression implementation.json-joy/json-type
โ the fastest JSON schema validation implementation in JavaScript.
git-cz
โfeat: ๐ธ emoji-fied Git commits
sonic-forest
โ very fast AVL, Splay, and Radix tree implementations in JavaScript.thingies
โ a collection of useful TypeScript utilities.rx-use
โ useful RxJS observables for web apps.tree-dump
โ utility to easily print tree-like structures.cross-ci
โ env var normalization across CI/CD services.web4
๐ soon โ CRDT-based content-addressable local-first data repository.
- Parsing
json-pack
โ the fastest CBOR, MessagePack, RESP3, UBJSON, JSON, and Bencode codecs in plain JavaScript.jit-router
โ the fastest HTTP router in JavaScript.md-mdast
โ extremely small and fast Markdown to MDAST parser.mdast-flat
โ MDAST format to flat-MDAST converter.mqtt-codec
๐งช๐ฅ experimental โ the fastest MQTT packet parser for Node.js.jit-parser
๐งช๐ฅ experimental โ PoC of LL recursive backtracking descent JIT parser generator.
- Server & Networking
ass-js
๐งช๐ฅ experimental โ X86_64 assembler compiler in JavaScript.reactive-rcp
๐งช๐ฅ experimental โ a very fast and type safe JSON Reactive RPC server and client.redis-joy
๐งช๐ฅ experimental โ a very fast Redis 7+ RESP3 standalone and cluster client.node-multicore
๐งช๐ฅ experimental โ PoC of a very fast thread pool for Node.js.
- Specifications
spec
JSON CRDT โ Full JSON implementation as a CRDT (Conflict-free Replicated Datatype).spec
JSON CRDT Patch โ The patch format for JSON CRDT.spec
JSON Expression โ s-expression specification for JSON.spec
JSON Reactive RPC โ JSON Reactive RPC protocol (RPC with server push) implementation.encoding
Compact JSON โ A compact Tuple-Type-Value (TTV) encoding for JSON.
- Blog posts
- My random notes
note
Programmingnote
JavaScriptnote
Collaborative editingnote
Funny GitHub profiles
Your support means a lot to me and will help me to continue working on my projects!
Support
- Become a sponsor
- Buy me a coffee โ๏ธ
- or send a Solana airdrop ๐ ๐, SOL:
LJJwteDZjL8u2Uhh5giwVpRa5KcHLkDogYAZntYbMsD