Craft CMS React Renderer lets you implement React.js client and server-side rendering in your Craft CMS projects, leveraging external node.js server to render.
This is a fork of Alexandre Kilian's project craft-react, that is implemented using PhpExecJsReactRenderer
, which requires php-v8js
extension in order to run, which can be pain to setup in certain cases.
This is a rewrite of the plugin, leveraging ExternalServerReactRenderer
, which requires you to run external node.js server to render for you, which you have to run separately, but you can just use nodemon to handle restarts, so it's barely an issue to maintain it.
Check Symfony React Sandbox for an example of this external server.
For a complete documentation of the core functionality and client examples, as well as problems related to the Renderer itself, please check out ReactBundle or Symfony React Sandbox.
By rendering your react components on the server, you not only increase performance and search engine readability for SEO but also enable users with slower connections to be able to access your information before your client bundle has completely loaded.
Please checkout the Walkthrough for a step by step explanation of the client and twig-side of this plugin. For a JSON-API, we recommend Elements API for Craft CMS.
To install the plugin, follow these instructions:
-
Open your terminal and go to your Craft project:
cd /path/to/project
-
Then tell Composer to load the plugin:
composer require zoilorys/craft-react-external-server
In the Control Panel, go to Settings → Plugins and click the “Install” button for Craft React.
In the plugin settings, add the following entry:
Environment: "client_side", "server_side" or "both"
or override the settings globally in config/react.php
And add NODE_SOCK_PATH
to .env with your node.sock
file location (refer to Symfony React Sandbox/external-server.js for usage)
<?php
return [
'env' => 'client_side',
];
In your template, add the following TWIG-function where you want your react application to be rendered into:
{{ react_component('MyApp', {'props': {entry: entry}}) }}
In the props, pass whatever props you want to pass to your root component.
In order to serialize your entries to create a store or props, the new twig function serialize(entry, schema = 'entry', group = 'default')
has been introduced. This allows you to create a php file to serialize your entries. Files should be located in config/react
and should be named [schema].php
.
If unspecified, the schema will default to entry.php
and the group to default
.
<?php
# config/react/entry.php
use craft\elements\Entry;
return [
'default' => function(Entry $entry){// named after the group
return [
'id' => $entry->id,
'title' => $entry->title,
'customField' => $entry->customField,
];
}
];
To use it in twig, just pass your current entry and use the result in your store:
{# _entry.twig #}
{% set serializedBlogPost = serialize(entry,'blog', 'detail') %}
{{ react_component('MyApp', {'props': {blogpost: serializedBlogPost}}) }}
This will use the file config/react/blog.php
<?php
# config/react/blog.php
use craft\elements\Entry;
return [
'detail' => function(Entry $entry){
return [
'id' => $entry->id,
'title' => $entry->title,
'content' => $entry->content,// custom field
];
}
];