Skip to main content

Custom Dash components for use in Webviz

Project description

PyPI version npm version Build Status Total alerts Language grade: JavaScript Language grade: Python Python 3.6 | 3.7 | 3.8 | 3.9 Code style: black code style: prettier codecov

Webviz subsurface components

webviz_subsurface_components is a Dash/React component library for use in webviz, which have in common that they are geared towards subsurface dashboards. There storybook is available at https://equinor.github.io/webviz-subsurface-components/storybook-static. And the demo of old components is available at https://equinor.github.io/webviz-subsurface-components.

How to install the components

You can quickly get started using the components in Dash by:

  1. Run pip install webviz-subsurface-components
  2. Run python examples/example_hm.py
  3. Visit http://localhost:8050 in your web browser

This project was originally generated by the dash-component-boilerplate. (with some modifications).

If you are only interested in using the JavaScript code in your own JavaScript project, you can install the npmjs deployed version:

npm i @webviz/subsurface-components

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. Run some potentially optional postinstall scripts
    npm run setup-deckgl-types --prefix ./react  # only needed if ignored scripts during install
    npm run copy-package-json --prefix ./react  # only needed if building Dash components
    
  3. Install python packages required to build components.
    pip install .[dependencies]
    pip install dash[dev]
    
  4. Install the python packages for testing.
    pip install .[tests]
    pip install dash[testing]
    
    The second of these commands appears to be necessary as long as this pip issue is open.

Write component code in src/lib/components/<component_name>/<component_name>.jsx

  • The demo app is in src/demo and is where you will import an example of your component. To start the existing demo app, run npm start.

  • 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.

    • 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.
  • Add custom styles to your component by putting your custom CSS files into your distribution folder (webviz_subsurface_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_subsurface_components/__init__.py so dash will serve them automatically when the component suite is requested.
  • Every file related to the component should be located in the component directory, unless the file is shared between multiple components. For example the file-structure should look something like this:

src
|--lib
    |----<component_name>
        |----components
              |----<sub_component>.ts
        |----utils
        |----<component_name>.tsx
        |----<component_name>.css
        |----index.ts

Automatically upload demo application

This repository has a GitHub workflow which can automatically build and deploy a demo app with your changes, to GitHub pages.

  • On push to your feature branch, in your fork, the workflow will build and deploy a demo app to your fork's GitHub page, given that your commit message includes the substring [deploy test].
  • On merge to master in the main repository, a build + deploy will be done to the official GitHub page in the main repository.

For this to work in your own fork, you will need to create a branch gh-pages (this you only need to do once). One way of creating this branch is e.g.:

git checkout --orphan gh-pages
git rm -rf .
git commit --allow-empty -m  "Create GitHub pages branch"
git push origin gh-pages

You are encouraged to rebase and squash/fixup unnecessary commits before pull request is merged to master.

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_subsurface_components-0.4.13rc0.tar.gz (63.0 MB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file webviz_subsurface_components-0.4.13rc0.tar.gz.

File metadata

  • Download URL: webviz_subsurface_components-0.4.13rc0.tar.gz
  • Upload date:
  • Size: 63.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.4 CPython/3.6.15

File hashes

Hashes for webviz_subsurface_components-0.4.13rc0.tar.gz
Algorithm Hash digest
SHA256 2a8d0dea524e8994df1f63a99392f6fd925846dee747fea5d56c37028fee658e
MD5 84d5ffd6b237a79496c0d7a1be8d62bb
BLAKE2b-256 08b1da271ecdfec5c50db1db2cd03a2628a9ca37faf99f58c1a1e8bfc68a19bd

See more details on using hashes here.

File details

Details for the file webviz_subsurface_components-0.4.13rc0-py3-none-any.whl.

File metadata

  • Download URL: webviz_subsurface_components-0.4.13rc0-py3-none-any.whl
  • Upload date:
  • Size: 14.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.4 CPython/3.6.15

File hashes

Hashes for webviz_subsurface_components-0.4.13rc0-py3-none-any.whl
Algorithm Hash digest
SHA256 12ae1be189ca85538966cf789ecf0e3928f9b3d07d93b74dde6351297b7370fe
MD5 702db8bc105f3f94d9ab7aa4d95c205b
BLAKE2b-256 6cd2e3f78ab0f65e190e33846c578272134f92557800f9e90ec410d58ceb2577

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