Skip to content

Github Template that offers 12 User Interface Patterns built with React using Carbon Design System and served using Node.js

Notifications You must be signed in to change notification settings

client-engineering-devops/template-node-react

 
 

Repository files navigation

IBM Cloud

IBM Cloud platform Apache 2

React UI Patterns with Node.js

React is a popular framework for creating user interfaces in modular components. In this sample application, you will create a web application using Express and React to serve web pages in Node.js, complete with standard best practices, including a health check and application metric monitoring.

This code pattern contains 12 popular UI patterns that make it very easy to construct a dashboard application.

This app contains an opinionated set of components for modern web development, including:

Deploying

After you have created a new git repo from this git template, remember to rename the project. Edit package.json and change the default name to the name you used to create the template.

Make sure you are logged into the IBM Cloud using the IBM Cloud CLI and have access to you development cluster. If you are using OpenShift make sure you have logged into OpenShift CLI on the command line.

npm install -g @ibmgaragecloud/cloud-native-toolkit-cli

Use the IBM Garage for Cloud CLI to register the GIT Repo with Tekton or Jenkins

oc sync <project> --dev
oc pipeline

Ensure you have the Cloud-Native Toolkit installed in your cluster to make this method of pipeline registry quick and easy Cloud-Native Toolkit

Native Application Development

Install the latest Node.js 6+ LTS version.

Once the Node toolchain has been installed, you can download the project dependencies with:

npm install
cd client; npm install; cd ..
npm run build
npm run start

Modern web applications require a compilation step to prepare your ES2015 JavaScript or Sass stylesheets into compressed Javascript ready for a browser. Webpack is used for bundling your JavaScript sources and styles into a bundle.js file that your index.html file can import.

Webpack

For development mode, use webpack -d to leave the sources uncompress and with the symbols intact.

For production mode, use webpack -p to compress and obfuscate your sources for development usage.

Gulp

Gulp is a task runner for JavaScript. You can run the above Webpack commands in by running:

gulp

To run your application locally:

npm run start

Your application will be running at http://localhost:3000. You can access the /health and /appmetrics-dash endpoints at the host.

Session Store

You may see this warning when running ibmcloud dev run:

Warning: connect.session() MemoryStore is not
designed for a production environment, as it will leak
memory, and will not scale past a single process.

When deploying to production, it is best practice to configure sessions to be stored in an external persistence service.

Next Steps

License

This sample application is licensed under the Apache License, Version 2. Separate third-party code objects invoked within this code pattern are licensed by their respective providers pursuant to their own separate licenses. Contributions are subject to the Developer Certificate of Origin, Version 1.1 and the Apache License, Version 2.

Apache License FAQ

About

Github Template that offers 12 User Interface Patterns built with React using Carbon Design System and served using Node.js

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 55.2%
  • HTML 42.3%
  • Mustache 0.7%
  • Shell 0.7%
  • SCSS 0.6%
  • Dockerfile 0.4%
  • CSS 0.1%