Materials Project Dash Components is a Dash component library that ports components from mp-react-components.
See examples and documentation
Get started with:
- Install Dash and its dependencies: https://dash.plot.ly/installation
- Run python usage.py
- Visit http://localhost:8050 in your web browser
If you have selected install_dependencies during the prompt, you can skip this part.
- 
Install npm packages $ npm install
- 
Create a virtual env and activate. $ virtualenv venv $ . venv/bin/activateNote: venv\Scripts\activate for windows 
- 
Install python packages required to build components. $ pip install -r requirements.txt
- 
Install the python packages for testing (optional) $ pip install -r tests/requirements.txt
Add a new component file inside of one of the directories in src/lib/components and name the file MyComponent.react.js (where "MyComponent" is replaced with the name of the new component). Also, remember to add "MyComponent" into src/lib/index.js for importing/exporting.
The components in this library are all ported from mp-react-components so the component files should simply wrap the component from mp-react-components and redefine the prop types for the component.
import * as mpc from '@materialsproject/mp-react-components';
import {Component} from 'react';
import React from 'react';
import PropTypes from 'prop-types';
export default class MyComponent extends Component {
    render() {
        return <mpc.MyComponent {...this.props} />;
    }
}
MyComponent.propTypes = {
    id: PropTypes.string,
    className: PropTypes.string,
    setProps: PropTypes.func,
    children: PropTypes.node
};
Note that if the react component utilizes the children prop, make sure that prop is included in the propTypes object with the type PropTypes.node. If the react component is not configured to accept any children, then this prop should not be included.
First, make sure that you have pulled in the latest changes from mp-react-components:
npm install @materialsproject/mp-react-components@next
Make sure to use node v18 to correctly run build
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
nvm install 18
nvm use 18
After updating the JavaScript component files and the mp-react-components dependency, you need to run the build process to generate the Dash versions of the components:
npm run build
If you are using a virtual environment, make sure it is activated when you run the build command.
Commit the changes and freshly built components:
git commit -am "Update components"
Tag and push a new version
npm version patch|minor|major
This will automatically bumps the version number in package.json, create a tag in the local
repository, and push it to github. A github action will build and publish the python package.
In some cases, the changes made in mp-react-components won't require any new component files or props. In this case, you still need to update the package from npm and run the build steps:
npm install @materialsproject/mp-react-components@next
npm run build
git commit -am "Update mp-react-components"
npm version patch
- 
Build your code: $ npm run build
- 
Create a Python tarball $ python setup.py sdistThis distribution tarball will get generated in the dist/folder
- 
Test your tarball by copying it into a new environment and installing it locally: $ pip install dash_mp_components-x.x.x.tar.gz
- 
If it works, then you can publish the component to NPM and PyPI: - Publish on PyPI
$ twine upload dist/*
- Cleanup the dist folder (optional)
$ rm -rf dist
- Publish on NPM (Optional if chosen False in publish_on_npm)Publishing your component to NPM will make the JavaScript bundles available on the unpkg CDN. By default, Dash serves the component library's CSS and JS locally, but if you choose to publish the package to NPM you can set$ npm publishserve_locallytoFalseand you may see faster load times.
 
- Publish on PyPI
- 
To publish a new version from github, use npm version
The components are currently published in the test index, so you'll need to specify the url of
the index when you install the package
pip install --index-url https://test.pypi.org/simple/ dash-mp-components
This project was generated by the dash-component-boilerplate it contains the minimal set of code required to create your own custom Dash component.