Skip to content

📚 An end to end solution for bringing React components to your legacy system.

License

Notifications You must be signed in to change notification settings

SurLaTable/slt-ui

Repository files navigation

SLT's component library

master develop
Travis 'master' build status codecov Travis 'develop' build status codecov

⚠️ Our build requires Node 10.x or greater.

Getting started:

If you want to view component documentation and hack on components, you can run:

yarn install
yarn docs

We use React Styleguidist for documentation, usage details can be found here.

Starting a new component:

If you want to start a brand new component, run the following to create all boilerplate files (including documentation and unit tests):

yarn install
yarn start-component FooBarScroller

Psst! Replace FooBarScroller with your component's name.


Our original sandbox is available with the below command, but is deprecated as the documentation engine encourages documenting components while engineering them.

yarn install
yarn sandbox

Conversely, you can also use CodeSandbox, although the version there is out-of-date at the moment:

Edit @sur-la-table/slt-ui

Building:

yarn install
yarn build

Additional flags for yarn build:

Description Flag
Build the development version. --dev
Open the webpack bundle report after building. --report

Dynamically registering components:

First build the component:

yarn build dynamic-registration ./src/--REPLACE_WITH_COMPONENT_DIRECTORY--/index.js

Then in your frontend environment:

var slt_dynamic_registration=function(e){var t={};function n(r) ...
$('<div data-component="TestButton">This is a test button</div>').prependTo('body');
ComponentManifest.register(slt_dynamic_registration);

What is this?

slt-ui allows you to use modern components on legacy systems. Single page apps are great, but some of us still need to deal with a legacy CMS or other systems. That doesn't mean we want to write legacy code though! Imagine using Material UI to build high level components and dropping them in any ancient CMS (WordPress, ATG, Sitecore, Drupal, Adobe Experience Manager, et cetera). Now you can!

How did you do this?

We got a lot of help from these libraries:

React Habitat was the leg up on incorporating ES-NEXT React components into a legacy system, the problem was that it did not handle nested child components, which kept us from starting with a large pattern library like Material UI. We've solved that here and here.

We also needed a way to asynchronously load individual components, to keep our clients from getting a huge payload for one component. We additively wrap each Material UI component (and our own components) using react-async-component. The code for that lives here.

OK, I want to use this.

Just do:

yarn add @sur-la-table/slt-ui

Then you can grab any component using:

import { Button } from '@sur-la-table/slt-ui';

For injecting into a legacy system, use React Habitat's syntax:

<div data-component="Card">
    <div data-component="Button">Yo</div>
</div>

To register these components with Habitat, run:

ComponentManifest.bootstrapper.update();

Note that this differs from React Habitat's method (window.updateHabitat();). Both are functionally the same, but we expose the low level bootstrapper to have access to more of Habitat's internal methods.

Also, unlike vanilla React Habitat you can have nested components.

For more details, head here.

Contributing components:

Note that production-ready components that utilize Material UI components, must use the following import syntax:

import Button from '@material-ui/core/Button';

Note the lack of curly brackets around the import name, and the direct path to the component in the package string. Luckily, this is the exact syntax used in Material UI's documentation.

Without this direct reference to a component, all of Material UI will be included in each component, rather than the specific component itself. As you can guess, this causes needless bloat for the end user.

Publishing:

After building the repo, set the version number in (package.json)[package.json] and (build/package.json)[build/package.json], then:

cd build
npm login
npm publish

To publish the beta tag to npm (for development environments), just add a --tag beta argument to npm publish, in other words:

cd build
npm login
npm publish --tag beta

The beta tags follow this format:

DATE.INCREMENTED.NUMBER-beta

For instance:

20180822.0.0-beta

If you published another one you would increment the numbers in the MINOR and PATCH spots, like so:

20180822.0.1-beta

So if you published 12 versions in one day, you would be on:

20180822.1.1-beta