From 4c19d0431f4a280a266072233cdf2f2501ea677b Mon Sep 17 00:00:00 2001 From: Christopher Bonilla Date: Tue, 15 Oct 2024 00:02:23 +0200 Subject: [PATCH] feat: add attributeFilterConfig to Visualization Added `attributeFilterConfigs` to visualization. This holds the display label information when using a secondary label in a filter. JIRA: LX-379 risk: low --- gooddata-sdk/gooddata_sdk/visualization.py | 42 ++++++++++++++++++++++ 1 file changed, 42 insertions(+) diff --git a/gooddata-sdk/gooddata_sdk/visualization.py b/gooddata-sdk/gooddata_sdk/visualization.py index 99ddd8fa1..c7535a3dd 100644 --- a/gooddata-sdk/gooddata_sdk/visualization.py +++ b/gooddata-sdk/gooddata_sdk/visualization.py @@ -440,6 +440,38 @@ def __repr__(self) -> str: return repr(self._filter) +class VisualizationAttributeFilterConfig: + """ + Represents attribute filter configuration used by a visualization. + """ + + def __init__(self, afc: tuple[str, Any]) -> None: + local_id, data = afc + self._local_id = local_id + self._data = data + + @property + def local_id(self) -> str: + return self._local_id + + @property + def label_id(self) -> str: + return self._data["displayAsLabel"]["identifier"]["id"] + + @property + def type(self) -> str: + return self._data["displayAsLabel"]["identifier"]["type"] + + def __str__(self) -> str: + return self.__repr__() + + def __repr__(self) -> str: + return ( + f"VisualizationAttributeFilterConfig(local_id='{self.local_id}', label_id='{self.label_id}', " + f"type='{self.type}')" + ) + + class VisualizationSortLocator: def __init__(self, locator: dict[str, str], locator_type: LocatorItemType) -> None: self._locator = locator @@ -546,6 +578,7 @@ def __init__( side_loads: Optional[SideLoads] = None, ) -> None: self._vo = from_vis_obj + self._attribute_filter_configs: Optional[list[VisualizationAttributeFilterConfig]] = None self._buckets: Optional[list[VisualizationBucket]] = None self._filters: Optional[list[VisualizationFilter]] = None self._sorts: Optional[list[VisualizationSort]] = None @@ -568,6 +601,15 @@ def are_relations_valid(self) -> str: # Fallback to true for tests, where fixtures were generated without HTTP header activating this feature return self._vo["attributes"].get("areRelationsValid", "true") + @property + def attribute_filter_configs(self) -> list[VisualizationAttributeFilterConfig]: + if self._attribute_filter_configs is None: + visualization_attribute_filter_configs = self._vo["attributes"]["content"]["attributeFilterConfigs"] + self._attribute_filter_configs = [ + VisualizationAttributeFilterConfig(afc) for afc in visualization_attribute_filter_configs.items() + ] + return self._attribute_filter_configs + @property def buckets(self) -> list[VisualizationBucket]: if self._buckets is None: