-
Notifications
You must be signed in to change notification settings - Fork 147
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
[Bug] Enable that components can be nested inside nested basic type structures too #929
base: main
Are you sure you want to change the base?
Conversation
…pe structures too
View the example dashboards of the current commit live on PyCafe ☕ 🚀Updated on: 2024-12-13 16:04:53 UTC Link: vizro-core/examples/dev/ Link: vizro-core/examples/scratch_dev |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we write some tests for this case ;)
I also had this on my mind, but I've decided not to do so because all these util methods are still private. We don't test private methods much because it can easily happen that their structure or API completely changes. And, model_manager will be changed again (maybe even drastically changed) when we introduce |
I agree with @maxschulz-COL that we should include unit tests though. We do test private methods in other models, but for some we have deprioritized it. Ideally, anything that could be unintentionally broken should be tested. We don't need to test every possible level of nesting, but we should cover basic cases, such as the code snippet mentioned in this issue: #82 Is this scenario included in our tests? If not, would you mind adding it? I remember Antony sent out this issue again, but it broke after the action refactoring, and we only noticed when another user requested a similar feature right? I think optimally unit tests should have caught this earlier, but we didn't have them in place 😬 So maybe let's use the chance now? |
@@ -84,28 +84,25 @@ def _get_models( | |||
def __get_model_children(self, model: Model) -> Generator[Model, None, None]: | |||
"""Iterates through children of `model`. | |||
|
|||
Currently looks only through certain fields so might miss some children models. | |||
Currently, this method looks only through certain fields so might miss some children models. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Currently, this method looks only through certain fields so might miss some children models. | |
Currently, this method looks only through certain fields so might miss some children models. |
What does that mean that it looks "through certain fields"? I thought it's independent of "components", "tabs", "controls", "actions", "selector" now. Or does it refer to something else? If I understood correctly, it just misses children
nested inside dict
, right? If that's correct, then could we update the docstring here?
|
||
### Fixed | ||
|
||
- Enable that custom components can be nested arbitrarily deep inside basic type structures (e.g. lists within lists), and not just specific attributes. ([#929](https://github.com/mckinsey/vizro/pull/929)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe rephrase to below? I tried to simplify a bit
- Enable that custom components can be nested arbitrarily deep inside basic type structures (e.g. lists within lists), and not just specific attributes. ([#929](https://github.com/mckinsey/vizro/pull/929)) | |
- Enable arbitrary deep nesting of custom components. All models can now be nested arbitrarily deep within lists and tuples. ([#929](https://github.com/mckinsey/vizro/pull/929)) |
controls: List[Tuple[str, List[ControlType]]] = [[]] | ||
|
||
def build(self): | ||
return html.Div( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Amazing, how this works now! 🥳 🍾
Due to prioritisation and capacity for the current sprint, I will write unit tests and finalise this PR next year. |
Description
This is bugfix made on top of #903.
This PR enables that model_manager can find components that are nested arbitrarily deep inside basic type structures (e.g. lists within lists) too, and not just specific attributes like (e.g. "components", "tabs", "controls", "actions", "selector"). So, this PR enables you to define any component structure, For example:
my_custom_components_property: list[list[tuple[vm.VizroBaseComponent]]]
.This PR does not solve nesting components inside
dict
type. This is known limitation emphasised with the "TODO" already, and will be solved separately.See how
scratch/app.py
works from this, but doesn't work from the main branch. The best way to see the problem is to refresh the page and see if the controls are taken into account when the page loads.Screenshot
Notice
I acknowledge and agree that, by checking this box and clicking "Submit Pull Request":