Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/equinor/webviz-core-components

Discipline agnostic Webviz and Dash components.
https://github.com/equinor/webviz-core-components

dash javascript python react webviz

Last synced: about 1 month ago
JSON representation

Discipline agnostic Webviz and Dash components.

Awesome Lists containing this project

README

        

[![PyPI version](https://badge.fury.io/py/webviz-core-components.svg)](https://badge.fury.io/py/webviz-core-components)
[![npm version](https://badge.fury.io/js/%40webviz%2Fcore-components.svg)](https://badge.fury.io/js/%40webviz%2Fcore-components)
[![Build Status](https://github.com/equinor/webviz-core-components/workflows/webviz-core-components/badge.svg)](https://github.com/equinor/webviz-core-components/actions?query=branch%3Amaster)
[![Total alerts](https://img.shields.io/lgtm/alerts/g/equinor/webviz-core-components.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/equinor/webviz-core-components/alerts/)
[![Language grade: JavaScript](https://img.shields.io/lgtm/grade/javascript/g/equinor/webviz-core-components.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/equinor/webviz-core-components/context:javascript)
[![Language grade: Python](https://img.shields.io/lgtm/grade/python/g/equinor/webviz-core-components.svg?logo=lgtm&logoWidth=18)](https://lgtm.com/projects/g/equinor/webviz-core-components/context:python)
[![Python 3.8 | 3.9 | 3.10 | 3.11 | 3.12](https://img.shields.io/badge/python-3.8%20|%203.9%20|%203.10%20|%203.11%20|%203.12-blue.svg)](https://www.python.org/)
[![Code style: black](https://img.shields.io/badge/code%20style-black%20%28Python%29-000000.svg)](https://github.com/psf/black)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier%20%28JavaScript%29-ff69b4.svg)](https://github.com/prettier/prettier)

# Webviz core components

`webviz_core_components` is a Dash component library for use in `webviz`. A storybook showing all available components is available at https://equinor.github.io/webviz-core-components/storybook-static.

You can quickly get started with:

1. Run `pip install webviz-core-components`
2. Run `python usage.py`
3. Visit http://localhost:8050 in your web browser

## How to contribute

### Install dependencies

If you want to build and develop yourself, you should fork + clone the repository, and
then:

1. Install npm packages.
```
npm ci --ignore-scripts --prefix ./react
```
2. Install python packages required to build components.
```
pip install .[dependencies]
pip install dash[dev]
```
3. Install the python packages for testing.
```
pip install .[tests]
```

### Write component code in `react/src/lib/components//.tsx`

- Have a look at other components to see how the directory and file structure looks like.
- The demo app is in `react/src/demo` and is where you will import an example of your
component. To start the existing demo app, run `npm start --prefix ./react`.
- To test your code in a Python environment:

1. Build your code
```
npm run build --prefix ./react
```
2. Install the Python pacakge in development mode (if not already done and
assuming you are using a virtual environment):
```
pip install -e .
```
3. Create a new example in `examples/` which uses your new component.

- Write tests for your component.

- Python
- Python tests exist in `tests/`. Take a look at them to see how to write tests using
the Dash test framework.
- Run the tests with `pytest tests`.
- JavaScript
- JavaScript tests exist in `react/tests`. Take a look at them to see how to write tests using
the Jest test framework.

- Add custom styles to your component by putting your custom CSS files into
your distribution folder (`webviz_core_components`).
- Make sure that they are referenced in `MANIFEST.in` so that they get
properly included when you're ready to publish your component.
- Make sure the stylesheets are added to the `_css_dist` dict in
`webviz_core_components/__init__.py` so dash will serve them
automatically when the component suite is requested.
- You can also include stylesheets directly in your component by adding the stylesheet to your component's directory and importing it via `import "./.css`. Make sure that the class names in your stylesheet
are starting with your component's name and two underscores: `.MyComponent__MyClassName`.