A node-based flow builder application made with React, Vite, and Pixi.js that allows you to create visual processes by connecting nodes together.
- Dynamically loaded nodes from directory structure
- Drag-and-drop node interface
- Real-time flow previews with Pixi.js rendering
- Local media storage for offline use
- Customizable effects and transformations
- Image export capability
- Install dependencies:
npm install
- Start the development server:
npm run dev
- Build for production:
npm run build
To create a new node type, add a new folder under src/nodes with an index.tsx file that exports a NodeDefinition object.
src/types- TypeScript interfaces and typessrc/nodes- Node implementationssrc/components- React components for the UIsrc/utils- Utility functionssrc/state/flowSate- Engine for managing the global node state which is then rendered through react-flow
MIT
This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
Currently, two official plugins are available:
- @vitejs/plugin-react uses Babel for Fast Refresh
- @vitejs/plugin-react-swc uses SWC for Fast Refresh
If you are developing a production application, we recommend updating the configuration to enable type-aware lint rules:
export default tseslint.config({
extends: [
// Remove ...tseslint.configs.recommended and replace with this
...tseslint.configs.recommendedTypeChecked,
// Alternatively, use this for stricter rules
...tseslint.configs.strictTypeChecked,
// Optionally, add this for stylistic rules
...tseslint.configs.stylisticTypeChecked,
],
languageOptions: {
// other options...
parserOptions: {
project: ["./tsconfig.node.json", "./tsconfig.app.json"],
tsconfigRootDir: import.meta.dirname,
},
},
});You can also install eslint-plugin-react-x and eslint-plugin-react-dom for React-specific lint rules:
// eslint.config.js
import reactX from "eslint-plugin-react-x";
import reactDom from "eslint-plugin-react-dom";
export default tseslint.config({
plugins: {
// Add the react-x and react-dom plugins
"react-x": reactX,
"react-dom": reactDom,
},
rules: {
// other rules...
// Enable its recommended typescript rules
...reactX.configs["recommended-typescript"].rules,
...reactDom.configs.recommended.rules,
},
});