Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enable highlighting of active page button and refactor accordion.build() #74

Merged
merged 24 commits into from
Oct 4, 2023
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
3033abd
fixing accordion item highlight bug
nadijagraca Sep 27, 2023
b4cbf9f
removing background color highlight from selected accordion, aligning…
nadijagraca Sep 28, 2023
f630b50
added changelog
nadijagraca Sep 28, 2023
d843b1d
minor linting fixes'
nadijagraca Sep 28, 2023
417ca3c
fixed tests
nadijagraca Sep 28, 2023
19983a8
Merge branch 'main' into vizro/bug/highlight_active_accordion_item
huong-li-nguyen Oct 2, 2023
e6307aa
Lint
huong-li-nguyen Oct 2, 2023
9fecf3c
Replace active class with active param
huong-li-nguyen Oct 2, 2023
8cd1bfc
Merge branch 'main' into vizro/bug/highlight_active_accordion_item
huong-li-nguyen Oct 2, 2023
5768665
Merge branch 'main' into vizro/bug/highlight_active_accordion_item
huong-li-nguyen Oct 3, 2023
901c7f2
Merge branch 'main' into vizro/bug/highlight_active_accordion_item
huong-li-nguyen Oct 3, 2023
4bdca79
Refactor code
huong-li-nguyen Oct 3, 2023
e320bb8
Fix tests
huong-li-nguyen Oct 3, 2023
ca5e675
Lint
huong-li-nguyen Oct 3, 2023
56ebe70
Merge branch 'main' into vizro/bug/highlight_active_accordion_item
huong-li-nguyen Oct 3, 2023
5081c89
Move page registering to Dashboard.pre_build
huong-li-nguyen Oct 3, 2023
6401a26
Update changelog
huong-li-nguyen Oct 3, 2023
a9dc868
Remove Accordion.build from page.build
huong-li-nguyen Oct 3, 2023
e3851c3
Remove navigation.pre_build from page and fix tests
huong-li-nguyen Oct 3, 2023
203975f
Update changelog
huong-li-nguyen Oct 4, 2023
2fa3429
PR comments
huong-li-nguyen Oct 4, 2023
947cdaf
Merge branch 'main' into vizro/bug/highlight_active_accordion_item
huong-li-nguyen Oct 4, 2023
a316e42
Fix access to dash.page_registry
huong-li-nguyen Oct 4, 2023
bb8d9f0
Update KeyError
huong-li-nguyen Oct 4, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
<!--
A new scriv changelog fragment.

Uncomment the section that is right (remove the HTML comment wrapper).
-->

<!--
### Removed

- A bullet item for the Removed category.

-->
<!--
### Added

- A bullet item for the Added category.

-->
<!--
### Changed

- A bullet item for the Changed category.

-->
<!--
### Deprecated

- A bullet item for the Deprecated category.

-->

### Fixed

- Fixed highlighting for active accordion item and arranged a setup to maintain the expanded state of the parent accordion item when page is active. ([#74](https://github.com/mckinsey/vizro/pull/74))
huong-li-nguyen marked this conversation as resolved.
Show resolved Hide resolved

<!--
### Security

- A bullet item for the Security category.

-->
22 changes: 12 additions & 10 deletions vizro-core/src/vizro/models/_navigation/_accordion.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,17 +26,17 @@ class Accordion(VizroBaseModel):
_validate_pages = validator("pages", allow_reuse=True, always=True)(_validate_pages)

@_log_call
def build(self):
def build(self, page_id):
huong-li-nguyen marked this conversation as resolved.
Show resolved Hide resolved
if self.pages:
return self._create_accordion()
return self._create_default_accordion()
return self._create_accordion(page_id=page_id)
return self._create_default_accordion(page_id=page_id)

def _create_accordion_buttons(self, accordion_pages):
def _create_accordion_buttons(self, accordion_pages, page_id):
return [
dbc.Button(
children=[page["name"]],
key=page["relative_path"],
className="accordion-item-button",
className="accordion-item-button-active" if page_id == page["name"] else "accordion-item-button",
huong-li-nguyen marked this conversation as resolved.
Show resolved Hide resolved
href=page["relative_path"],
)
for page in dash.page_registry.values()
Expand All @@ -51,12 +51,12 @@ def _create_accordion_item(self, accordion_buttons, title=ACCORDION_TITLE):
class_name="accordion_item",
)

def _create_default_accordion(self):
def _create_default_accordion(self, page_id):
accordion_buttons = [
dbc.Button(
children=[page["name"]],
key=page["relative_path"],
className="accordion-item-button",
className="accordion-item-button-active" if page_id == page["name"] else "accordion-item-button",
href=page["relative_path"],
)
for page in dash.page_registry.values()
Expand All @@ -77,23 +77,24 @@ def _create_default_accordion(self):
class_name="accordion",
persistence=True,
persistence_type="session",
always_open=True,
huong-li-nguyen marked this conversation as resolved.
Show resolved Hide resolved
),
html.Div(className="keyline"),
],
className="nav_panel",
id=f"{self.id}_outer",
)

def _create_accordion(self):
def _create_accordion(self, page_id):
accordion_items = []

if isinstance(self.pages, dict):
for title, accordion_pages in self.pages.items():
accordion_buttons = self._create_accordion_buttons(accordion_pages=accordion_pages)
accordion_buttons = self._create_accordion_buttons(accordion_pages=accordion_pages, page_id=page_id)
accordion_items.append(self._create_accordion_item(accordion_buttons=accordion_buttons, title=title))

if isinstance(self.pages, list):
accordion_buttons = self._create_accordion_buttons(accordion_pages=self.pages)
accordion_buttons = self._create_accordion_buttons(accordion_pages=self.pages, page_id=page_id)
accordion_items.append(self._create_accordion_item(accordion_buttons=accordion_buttons))

if len(accordion_buttons) == len(accordion_items) == 1:
Expand All @@ -107,6 +108,7 @@ def _create_accordion(self):
class_name="accordion",
persistence=True,
persistence_type="session",
always_open=True,
),
html.Div(className="keyline"),
],
Expand Down
4 changes: 2 additions & 2 deletions vizro-core/src/vizro/models/_navigation/navigation.py
Original file line number Diff line number Diff line change
Expand Up @@ -72,5 +72,5 @@ def _set_selector(self):
self._selector = Accordion(pages=self.pages)

@_log_call
def build(self):
return self._selector.build()
def build(self, page_id):
return self._selector.build(page_id=page_id)
4 changes: 2 additions & 2 deletions vizro-core/src/vizro/models/_page.py
Original file line number Diff line number Diff line change
Expand Up @@ -172,9 +172,9 @@ def _create_nav_panel(self):

_, dashboard = next(model_manager._items_with_type(Dashboard))
if dashboard.navigation:
return dashboard.navigation.build()
return dashboard.navigation.build(page_id=self.id)

return Accordion().build()
return Accordion().build(page_id=self.id)

def _create_component_container(self, components_content):
component_container = html.Div(
Expand Down
9 changes: 7 additions & 2 deletions vizro-core/src/vizro/static/css/accordion.css
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,6 @@

.accordion-button:not(.collapsed) {
color: var(--text-primary);
background-color: var(--state-overlays-selected);
}

.accordion-button:not(.collapsed)::after {
Expand Down Expand Up @@ -102,7 +101,8 @@
gap: var(--spacing-01);
}

div.page_container .accordion-item-button {
div.page_container .accordion-item-button,
.accordion-item-button-active {
huong-li-nguyen marked this conversation as resolved.
Show resolved Hide resolved
background-color: inherit;
width: 100%;
display: flex;
Expand All @@ -113,6 +113,11 @@ div.page_container .accordion-item-button {
line-height: var(--text-size-03);
}

.accordion-item-button-active {
background-color: var(--state-overlays-selected);
color: var(--text-primary);
}

huong-li-nguyen marked this conversation as resolved.
Show resolved Hide resolved
/*
* Since the text inside a accordion btn is very specific
* Adding important to increase the specificity
Expand Down
2 changes: 1 addition & 1 deletion vizro-core/src/vizro/static/css/layout.css
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
display: flex;
flex: 0 0 auto;
flex-direction: column;
padding: 40px 32px 0 32px;
padding: 30px 32px 0 32px;
scrollbar-gutter: stable;
width: 352px;
overflow: auto;
Expand Down
6 changes: 4 additions & 2 deletions vizro-core/tests/unit/vizro/models/_navigation/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ def accordion_from_page_as_list():
accordion_buttons = [
dbc.Button(
children=["Page 1"],
className="accordion-item-button",
className="accordion-item-button-active",
key="/",
href="/",
),
Expand All @@ -52,6 +52,7 @@ def accordion_from_page_as_list():
class_name="accordion",
persistence=True,
persistence_type="session",
always_open=True,
),
html.Div(className="keyline"),
],
Expand All @@ -65,7 +66,7 @@ def accordion_from_page_as_list():
def accordion_from_pages_as_dict():
accordion_items = [
dbc.AccordionItem(
children=[dbc.Button(children=["Page 1"], className="accordion-item-button", key="/", href="/")],
children=[dbc.Button(children=["Page 1"], className="accordion-item-button-active", key="/", href="/")],
title="PAGE 1",
class_name="accordion_item",
),
Expand All @@ -85,6 +86,7 @@ def accordion_from_pages_as_dict():
class_name="accordion",
persistence=True,
persistence_type="session",
always_open=True,
),
html.Div(className="keyline"),
],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,25 +43,25 @@ class TestAccordionBuild:

@pytest.mark.parametrize("pages", [["Page 1", "Page 2"], None])
def test_accordion_build_default(self, pages, accordion_from_page_as_list):
accordion = Accordion(pages=pages, id="accordion_list").build()
accordion = Accordion(pages=pages, id="accordion_list").build(page_id="Page 1")
result = json.loads(json.dumps(accordion, cls=plotly.utils.PlotlyJSONEncoder))
expected = json.loads(json.dumps(accordion_from_page_as_list, cls=plotly.utils.PlotlyJSONEncoder))
assert result == expected

def test_accordion_build_pages_as_list(self, pages_as_list, accordion_from_page_as_list):
accordion = Accordion(pages=pages_as_list, id="accordion_list").build()
accordion = Accordion(pages=pages_as_list, id="accordion_list").build(page_id="Page 1")
result = json.loads(json.dumps(accordion, cls=plotly.utils.PlotlyJSONEncoder))
expected = json.loads(json.dumps(accordion_from_page_as_list, cls=plotly.utils.PlotlyJSONEncoder))
assert result == expected

def test_accordion_build_pages_as_dict(self, pages_as_dict, accordion_from_pages_as_dict):
accordion = Accordion(pages=pages_as_dict, id="accordion_dict").build()
accordion = Accordion(pages=pages_as_dict, id="accordion_dict").build(page_id="Page 1")
result = json.loads(json.dumps(accordion, cls=plotly.utils.PlotlyJSONEncoder))
expected = json.loads(json.dumps(accordion_from_pages_as_dict, cls=plotly.utils.PlotlyJSONEncoder))
assert result == expected

def test_accordion_build_single_page_accordion(self):
accordion = Accordion(pages=["Page 1"], id="single_accordion").build()
accordion = Accordion(pages=["Page 1"], id="single_accordion").build(page_id="Page 1")
assert accordion is None

def test_navigation_not_all_pages_included(self, dashboard_build):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,6 @@ def test_navigation_build(self, pages):
accordion = Accordion(pages=pages)
navigation._selector.id = accordion.id

result = json.loads(json.dumps(navigation.build(), cls=plotly.utils.PlotlyJSONEncoder))
expected = json.loads(json.dumps(accordion.build(), cls=plotly.utils.PlotlyJSONEncoder))
result = json.loads(json.dumps(navigation.build(page_id="Page 1"), cls=plotly.utils.PlotlyJSONEncoder))
expected = json.loads(json.dumps(accordion.build(page_id="Page 1"), cls=plotly.utils.PlotlyJSONEncoder))
assert result == expected