Giter Club home page Giter Club logo

terra-toolkit's Introduction

Terra Toolkit

NPM version License Build Status Dependencies status devDependencies status

Terra Toolkit is a utility module used to facilitate independent development of Terra projects. This toolkit provides build scripts, configurations, and Webdriver Services needed to serve assets, compile webpack, and run webdriver.io tests to streamline development of npm packages.

terra-core, terra-clinical, and terra-framework are a few examples repositories which are utilizing the utilities offered in this package.

terra-dev-site is a node module that extends the configurations offered by toolkit.

Getting Started

  • Install toolkit and its peer dependencies as dev-dependencies with npm:
> npm install --save-dev terra-toolkit webpack webpack-cli webpack-dev-server @babel/cli @babel/core 

To use Terra Toolkit for local webdriver testing, you must install docker on your machine.

Theme Aggregation

Terra Toolkit provides a built-in mechanism for aggregating themes.

See the Theme Aggregation to get started.

Serve Options

Terra Toolkit offers two ways to serve your client side application, serve and serve-static. Serve provides a hot-reloading, development only option via webpack-dev-server, while serve-static is a non-hot-reloading express server. Serve-static supports IE10 and is used in webdriver testing.

See the Serve Guide to get started.

Webdriver.io Utility

Webdriver.io is a framework for writing webdriver powered tests to validate functionality in browsers. The Webdriver.io framework provides services for setting up a selenium server, starting webpack and static servers, running accessibility and visual regression testing, and more.

See the Webdriver.io Utility Developer's Guide to get started.

Webpack Configuration

Webpack is a module bundler used to compile modules with dependencies and generate static assets. Webpack is a very powerful tool that is highly configurable and Terra components rely on specific polyfills, webpack loaders and plugins to render correctly. Terra provides a default webpack configuration which we recommend you extend to meet your needs. By using this default configuration, we will manage webpack dependencies and set up translation aggregation.

See the Webpack Configuration Guide to get started.

Versioning

Terra-toolkit is considered to be stable and will follow SemVer for versioning.

  1. MAJOR versions represent breaking changes
  2. MINOR versions represent added functionality in a backwards-compatible manner
  3. PATCH versions represent backwards-compatible bug fixes

Consult the component CHANGELOGs, related issues, and PRs for more information.

Contributing

Please read through our contributing guidelines. Included are directions for issue reporting and pull requests.

LICENSE

Copyright 2017 - 2019 Cerner Innovation, Inc.

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

terra-toolkit's People

Contributors

alex-bezek avatar amichaelparker avatar avinashg1994 avatar benbcai avatar benboersma avatar bjankord avatar cody-dot-js avatar dv297 avatar emilyrohrbough avatar hs025828 avatar jakelacombe avatar justinwisniewski avatar jv075002 avatar kschuste avatar lalitha94 avatar mhemesath avatar mjhenkes avatar mschile avatar nfaltermeier avatar noahbenham avatar nramamurth avatar pranav300 avatar rm012685 avatar ryanthemanuel avatar stephenesser avatar tbiethman avatar yuderekyu avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.