Skip to content

rovelcio/nullstack-react-plugin

 
 

Repository files navigation

Nullstack React Plugin

Plugin to allow for React components to be used within Nullstack.

Getting Started

  1. Install the package using the GitHub url like:
yarn add 'git+ssh://[email protected]:agencyenterprise/nullstack-react-plugin.git#v{VERSION_NUMBER}'
  1. Add the plugin to your server and client files:

Client:

// client.js
import Nullstack from "nullstack";

import Application from "./src/Application";
import reactClientPlugin from "nullstack-react-plugin/client";

Nullstack.use(reactClientPlugin);
const context = Nullstack.start(Application);

context.start = async function start() {
  // https://nullstack.app/application-startup
};

export default context;

Server:

// server.js
import Nullstack from "nullstack";

import Application from "./src/Application";
import reactServerPlugin from "nullstack-react-plugin/server";

Nullstack.use(reactServerPlugin);
const context = Nullstack.start(Application);

context.start = async function start() {
  // https://nullstack.app/application-startup
};

export default context;
  1. Extend your Webpack configuration from the plugin:
// webpack.config.js
const [server, client] = require("nullstack-react-plugin/webpack.config");

module.exports = [server, client];
  1. Create your React components under a src/react folder and use them normally

Examples

You can find an example app here.

Developing locally

I'm seeing TypeError: Cannot read properties of null (reading 'useEffect'), what should I do?

This error is caused when you have packages linked with yarn link and packages installed inside the "link", meaning it copies the node_modules folder from your lib into the example app. Erasing the node_modules folder from the lib (at the root folder) should solve the issue.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 84.1%
  • JavaScript 15.9%