From f5a6ef29115e499087ada47e1736a1592ae7cc01 Mon Sep 17 00:00:00 2001 From: Matei Octavian Date: Mon, 31 Jul 2023 09:57:15 +0200 Subject: [PATCH] Added index in DFTable (#118) * Added index in DFTable --- .../document_exporting/element/df_table.py | 56 ++++++++++++++++++- .../templates/df_table.html | 16 +++++- 2 files changed, 68 insertions(+), 4 deletions(-) diff --git a/qf_lib/documents_utils/document_exporting/element/df_table.py b/qf_lib/documents_utils/document_exporting/element/df_table.py index fa4a3e2d..660d9be8 100644 --- a/qf_lib/documents_utils/document_exporting/element/df_table.py +++ b/qf_lib/documents_utils/document_exporting/element/df_table.py @@ -26,7 +26,7 @@ class DFTable(Element): def __init__(self, data: QFDataFrame = None, columns: Sequence[str] = None, css_classes: Union[str, Sequence[str]] = - "table", title: str = "", grid_proportion: GridProportion = GridProportion.Eight): + "table", title: str = "", grid_proportion: GridProportion = GridProportion.Eight, include_index=False): super().__init__(grid_proportion) self.model = ModelController(data=data, index=data.index, @@ -39,6 +39,9 @@ def __init__(self, data: QFDataFrame = None, columns: Sequence[str] = None, css_ self.title = title + if include_index: + self.model.index_styling = self.model.IndexStyle() + def generate_html(self, document: Optional[Document] = None) -> str: """ Generates the underlying table element as HTML. @@ -59,7 +62,15 @@ def generate_html(self, document: Optional[Document] = None) -> str: for level in range(self.columns.nlevels) ] - return template.render(css_class=self.model.table_styles.classes(), table=self, columns=columns_to_occurrences) + if self.model.index_styling: + index_levels = self.model.data.index.nlevels + columns_to_occurrences[0] = [("Index", index_levels)] + columns_to_occurrences[0] + for index, occurence in enumerate(columns_to_occurrences[1:]): + columns_to_occurrences[index+1] = [("", index_levels)] + occurence + + return template.render(css_class=self.model.table_styles.classes(), table=self, + columns=columns_to_occurrences, + index_styling=self.model.index_styling) @property def columns(self): @@ -132,6 +143,19 @@ def remove_cells_classes(self, columns: Union[str, Sequence[str]], rows: Union[A css_classes, _ = convert_to_list(css_classes, str) self.model.remove_cells_classes(columns, rows, css_classes) + def add_index_style(self, styles: Union[Dict[str, str], Sequence[str]]): + self.model.add_index_style(styles) + + def add_index_class(self, css_classes: str): + css_classes, _ = convert_to_list(css_classes, str) + self.model.add_index_class(css_classes) + + def remove_index_style(self): + self.model.remove_index_style() + + def remove_index_class(self): + self.model.remove_index_class() + class ModelController: def __init__(self, data=None, index=None, columns=None, dtype=None, copy=False): @@ -160,11 +184,33 @@ def __init__(self, data=None, index=None, columns=None, dtype=None, copy=False): }, index=self.data.index, columns=self.data.columns) self.table_styles = self.Style() + self.index_styling = None + + def add_index_style(self, styles: Union[Dict[str, str], Sequence[str]]): + if self.index_styling is None: + self.index_styling = self.IndexStyle() + else: + self.remove_index_style() + self.index_styling.add_styles(styles) + + def add_index_class(self, css_classes: str): + if self.index_styling is None: + self.index_styling = self.IndexStyle() + else: + self.remove_index_class() + self.index_styling.add_css_class(css_classes) + + def remove_index_style(self): + if self.index_styling: + self.index_styling.style = dict() + + def remove_index_class(self): + if self.index_styling: + self.index_styling.css_class = [] def add_columns_styles(self, columns: Union[str, Sequence[str]], styles_dict: Dict[str, str]): if not isinstance(columns, list): columns = [columns] - for column_name in columns: self.columns_styles[column_name].add_styles(styles_dict) @@ -354,6 +400,10 @@ def merge_classes(css_classes_list: Sequence[str]) -> str: css_classes = merge_classes(self.css_class) return css_classes + class IndexStyle(Style): + def __init__(self, style: Dict[str, str] = None, css_class: str = None): + super().__init__(style, css_class) + class ColumnStyle(Style): def __init__(self, column_name: str, style: Dict[str, str] = None, css_class: str = None): super().__init__(style, css_class) diff --git a/qf_lib/documents_utils/document_exporting/templates/df_table.html b/qf_lib/documents_utils/document_exporting/templates/df_table.html index 5c29074c..9016ce8f 100644 --- a/qf_lib/documents_utils/document_exporting/templates/df_table.html +++ b/qf_lib/documents_utils/document_exporting/templates/df_table.html @@ -28,8 +28,22 @@ {% endfor %} - {% for (index, row), (_, styles) in table.model.iterrows(): %} + {% for (indices, row), (_, styles) in table.model.iterrows(): %} + {% if index_styling%} + {% if indices is iterable %} + {% for index in indices %} + + {{index}} + + {% endfor %} + {% else %} + + {{indices}} + + {% endif%} + {% endif %} + {% for i in range(0, row|length): %} {{ row[i] }}