Metadata-Version: 2.1
Name: dash_express_components
Version: 0.0.110
Summary: Simple widgets to add plotly express style plotting to dash
Home-page: https://github.com/VK/dash-express-components
Author: Viktor Krückl <viktor@krueckl.de>
License: MIT
Description: # Dash Express Components
        ![Publish release](https://github.com/VK/dash-express-components/workflows/Publish%20release/badge.svg)
        [![PyPI](https://img.shields.io/pypi/v/dash-express-components?logo=pypi)](https://pypi.org/project/dash-express-components)
        [![npm](https://img.shields.io/npm/v/dash_express_components.svg?logo=npm)](https://www.npmjs.com/package/dash_express_components)
        [![Documentation](https://github.com/VK/dash-express-components/workflows/Documentation/badge.svg)](https://vk.github.io/dash-express-components)
        [![Test](https://github.com/VK/dash-express-components/actions/workflows/test.yml/badge.svg)](https://github.com/VK/dash-express-components/actions/workflows/test.yml)
        [![codecov](https://codecov.io/gh/VK/dash-express-components/branch/main/graph/badge.svg?token=13XCRAQY0D)](https://codecov.io/gh/VK/dash-express-components)
        
        ### Components to bring [Plotly Express](https://plotly.com/python/plotly-express/) style plots to [Dash](https://dash.plotly.com/):
        
        * [**dxc.Filter**](https://vk.github.io/dash-express-components/Filter.html) to define  filter configurations for numerical, categorical or temporal columns.
        * [**dxc.Transform**](https://vk.github.io/dash-express-components/Transform.html) to specify a series of data transformations like melt, group by or aggregate.
        * [**dxc.Plotter**](https://vk.github.io/dash-express-components/Plotter.html) to set a plot layout like scatter, box, image or table.
        * [**dxc.Configurator**](https://vk.github.io/dash-express-components/Configurator.html) is a component that combines
        [**dxc.Filter**](https://vk.github.io/dash-express-components/Filter.html),
        [**dxc.Transform**](https://vk.github.io/dash-express-components/Transform.html) and
        [**dxc.Plotter**](https://vk.github.io/dash-express-components/Plotter.html)
        to make the components even easier to use, since the interaction between them is handled automatically.
        * [**dxc.Graph**](https://vk.github.io/dash-express-components/Graph.html) uses [dcc.Graph](https://dash.plotly.com/dash-core-components/graph) and [dash_table.DataTable](https://dash.plotly.com/datatable) to show a plot or a table based on the plot configuration.
        
        
        
        ### A typical data flow looks like this:
        
        <img align="right" src="https://raw.githubusercontent.com/VK/dash-express-components/main/.media/dataflow.png" width="370px">
        
        First, the metadata is extracted from the dataframe ***df*** with **dxc.get_meta(*df*)**. This ***meta*** json is needed for
        [**dxc.Filter**](https://vk.github.io/dash-express-components/Filter.html),
        [**dxc.Transform**](https://vk.github.io/dash-express-components/Transform.html) or  [**dxc.Plotter**](https://vk.github.io/dash-express-components/Plotter.html) to show all options without additional queries to the dataframe. As a result, the components react quite quickly.
        
        Since the metadata can be changed by filter or transform operations, and we don't want additional server calls, the changes are directly computed in the web components. You can access the metadata after transformations via the ***meta_out*** property of [**dxc.Filter**](https://vk.github.io/dash-express-components/Filter.html) and [**dxc.Transform**](https://vk.github.io/dash-express-components/Transform.html). 
        
        A combined ***config*** is needed to compute the final plot with **dxc.get_plot(*df*, *config*)**. You can combine the configurations of each component yourself or use the [**dxc.Configurator**](https://vk.github.io/dash-express-components/Configurator.html) to get a combined configuration like: 
        
        <img align="right" src="https://raw.githubusercontent.com/VK/dash-express-components/main/.media/box.png" width="370px">
        
        ```python
        {
            "filter": [
                {
                    "col": "continent",
                    "type": "isnotin",
                    "value": ["Oceania"]
                }
            ],    
            "transform": [
                {
                    "type": "aggr",
                    "groupby": [
                        "country",
                        "continent"
                    ],
                    "cols": ["gdpPercap"],
                    "types": ["median"]
                }
            ],
            "plot": {
                "type": "box",
                "params": {
                    "x": "continent",
                    "y": "gdpPercap_median",
                    "color": "continent",
                    "aggr": ["mean"],
                    "reversed_x": True
                }
            }
        }
        ```
        
        An example with the gapminder dataset and [**dash-lumino-components**](https://github.com/VK/dash-lumino-components) for the MDI layout.
        ![example](https://raw.githubusercontent.com/VK/dash-express-components/main/examples/lumino/recording.gif)  
         
        
        
        ## Try it
        Install dependencies
        ```console
        $ pip install dash-express-components
        ```
        and start with quickly editable graphs:
        ```python
        import dash_express_components as dxc
        app.layout = html.Div([
        
            # add a plot dxc.Configurator
            html.Div([
                dxc.Configurator(
                    id="plotConfig",
                    meta=meta,
                ),
            ], style={"width": "500px", "float": "left"}),
        
            # add an editable dxc.Graph 
            html.Div([
                dxc.Graph(id="fig",
                          meta=meta,
                          style={"height": "100%", "width": "100%"}
                         )],
                style={"width": "calc(100% - 500px)", "height": "calc(100vh - 30px)",
                       "display": "inline-block", "float": "left"}
            )
        ])
        ```
        
        ## Develop
        1. Install npm packages
            ```console
            $ npm install
            ```
            
        2. Create a virtual env and activate.
            ```console
            $ virtualenv venv
            $ . venv/bin/activate
            ```
            _Note: venv\Scripts\activate for windows_
        
        3. Install python packages required to build components.
            ```console
            $ pip install -r requirements.txt
            ```
        
        4. Build your code
            ```console
            $ npm run build
            ```
        
        5. Run the example
            ```console
            $ python usage.py
            ```
Platform: UNKNOWN
Classifier: Framework :: Dash
Description-Content-Type: text/markdown
