Controlando o layout dos objetos
Seu trabalho com Dash está causando um grande impacto na sua organização. No entanto, um colega entrou em contato sobre um problema em um dos painéis dele. O painel que ele imaginou tem o logo da empresa no topo, seguido de dois gráficos de barras lado a lado.
Mas o logo está muito colado no topo, e os gráficos estão empilhados um sobre o outro. Que bagunça!
Você acha que pode usar seu conhecimento de CSS para colocar esses objetos no lugar certo.
Este exercício faz parte do curso
Construindo Dashboards com Dash e Plotly
Instruções do exercício
- Adicione uma margem de
30pxapenas no topo do logo abaixo da linha15e deixe todos os outros lados sem margem. - Adicione estilos aos dois gráficos abaixo da linha
19para que eles apareçam lado a lado.
Exercício interativo prático
Experimente este exercício completando este código de exemplo.
from dash import Dash, dcc, html
import plotly.express as px
import pandas as pd
ecom_sales = pd.read_csv('/usr/local/share/datasets/ecom_sales.csv')
logo_link = 'https://assets.datacamp.com/production/repositories/5893/datasets/fdbe0accd2581a0c505dab4b29ebb66cf72a1803/e-comlogo.png'
ecom_bar_major_cat = ecom_sales.groupby('Major Category')['OrderValue'].agg('sum').reset_index(name='Total Sales ($)')
ecom_bar_minor_cat = ecom_sales.groupby('Minor Category')['OrderValue'].agg('sum').reset_index(name='Total Sales ($)')
bar_fig_major_cat = px.bar(ecom_bar_major_cat, x='Total Sales ($)', y='Major Category', color='Major Category', color_discrete_map={'Clothes':'blue','Kitchen':'red','Garden':'green','Household':'yellow'})
bar_fig_minor_cat = px.bar(ecom_bar_minor_cat, x='Total Sales ($)', y='Minor Category')
app = Dash()
app.layout = [
html.Img(src=logo_link,
# Add margin to the logo
style={'margin':'____ ____ ____ ____'}),
html.H1('Sales breakdowns'),
dcc.Graph(
# Style the graphs to appear side-by-side
figure=bar_fig_major_cat,
style={'display':'____', 'width': '49%'}),
dcc.Graph(
figure=bar_fig_minor_cat,
style={'display':'____', 'width': '49%'}),
]
if __name__ == '__main__':
app.run(debug=True)