Giter Club home page Giter Club logo

dash-core-components's Introduction

Dash Core Components

This package provides the core React component suite for Dash.

CircleCI Greenkeeper badge

Development

Testing Locally

  1. Install the dependencies with:
$ npm i
  1. Build the code:
$ npm run build-dev
  1. Install the library
$ cd dash-core-components
$ npm run copy-lib
$ python setup.py install

I recommend installing the library and running the examples in a fresh virtualenv in a separate folder:

$ mkdir dash_examples # create a new folder to test examples
$ cd dash_examples
$ virtualenv venv # create a virtual env
$ source venv/bin/activate # use the virtual env

(and then repeat step 3).

  1. Add the following line to your Dash app
app.scripts.config.serve_locally = True

Demo server

You can start up a demo development server to see a demo of the rendered components:

$ builder run demo
$ open http://localhost:9000

You have to maintain the list of components in demo/Demo.react.js.

Code quality and tests

To run integration tests (test_integration.py)

We run our integration tests on CircleCI with help from Tox. There’s a tox.ini file which holds the configuration, refer to tox's documentation for help. You may need to set environment variables in your terminal, like TOX_PYTHON_27 to my version of python that I wanted tox to use. So running:

export TOX_PYTHON_27=python2

set the TOX_PYTHON_27 env variable to point to python2, which is Python 2.7 running on my machine. You could also look in tox.ini and see which tests it runs, and run those commands yourself:

python -m unittest test.test_integration

Testing your components in Dash

  1. Build development bundle to lib/ and watch for changes

     # Once this is started, you can just leave it running.
     $ npm start
    
  2. Install module locally (after every change)

     # Generate metadata, and build the JavaScript bundle
     $ npm run install-local
    
     # Now you're done. For subsequent changes, if you've got `npm start`
     # running in a separate process, it's enough to just do:
     $ python setup.py install
    
  3. Run the dash layout you want to test

     # Import dash_core_components to your layout, then run it:
     $ python my_dash_layout.py
    

Installing python package locally

Before publishing to PyPi, you can test installing the module locally:

# Install in `site-packages` on your machine
$ npm run install-local

Uninstalling python package locally

$ npm run uninstall-local

Publishing

See the Publishing New Components/Features section of the Contributing guide for step-by-step instructions on publishing new components.

Builder / Archetype

We use Builder to centrally manage build configuration, dependencies, and scripts.

To see all builder scripts available:

$ builder help

See the dash-components-archetype repo for more information.

dash-core-components's People

Contributors

chriddyp avatar valentijnnieman avatar alishobeiri avatar t4rk1n avatar mjclawar avatar rmarren1 avatar coopy avatar jbampton avatar bpostlethwaite avatar jackluo avatar akronix avatar cpsievert avatar ned2 avatar pravj avatar betatim avatar greenkeeper[bot] avatar synapticarbors avatar madhu94 avatar wbrgss avatar cldougl avatar

Watchers

James Cloos avatar Sebastian Gjertsen 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.