Skip to main content

Core components for webviz-config

Project description

PyPI version npm version Build Status Total alerts Language grade: JavaScript Language grade: Python Python 3.8 | 3.9 | 3.10 | 3.11 | 3.12 Code style: black code style: 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/<ComponentName>/<ComponentName>.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 "./<ComponentName>.css. Make sure that the class names in your stylesheet are starting with your component's name and two underscores: .MyComponent__MyClassName.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

webviz_core_components-0.8.2.tar.gz (1.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

webviz_core_components-0.8.2-py3-none-any.whl (734.1 kB view details)

Uploaded Python 3

File details

Details for the file webviz_core_components-0.8.2.tar.gz.

File metadata

  • Download URL: webviz_core_components-0.8.2.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.18

File hashes

Hashes for webviz_core_components-0.8.2.tar.gz
Algorithm Hash digest
SHA256 2ed350927fa84470ca196b677c5acdda9c20cbbf22467d3d3d5444ae17276de9
MD5 64384ed25d67e6af70f15e401845f156
BLAKE2b-256 47663a462343eb58c0c9b54111776f355b5904bc2694dd246b8467ab13d9838b

See more details on using hashes here.

File details

Details for the file webviz_core_components-0.8.2-py3-none-any.whl.

File metadata

File hashes

Hashes for webviz_core_components-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 38d9efe3b83dc365bd689f465044d31bd2a87006b1341704a141cb5fd449b756
MD5 4e70e329d6073d20a564a838f1a4a016
BLAKE2b-256 36259e39b5bb7117e3cc928c1469c5dad1326f0ea3cb2962881c115ed4ae777f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page