Skip to content

Commit

Permalink
Added index in DFTable (#118)
Browse files Browse the repository at this point in the history
* Added index in DFTable
  • Loading branch information
tavisit authored Jul 31, 2023
1 parent 4303110 commit f5a6ef2
Show file tree
Hide file tree
Showing 2 changed files with 68 additions and 4 deletions.
56 changes: 53 additions & 3 deletions qf_lib/documents_utils/document_exporting/element/df_table.py
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand All @@ -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.
Expand All @@ -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):
Expand Down Expand Up @@ -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):
Expand Down Expand Up @@ -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)

Expand Down Expand Up @@ -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)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,22 @@
{% endfor %}
</thead>
<tbody>
{% for (index, row), (_, styles) in table.model.iterrows(): %}
{% for (indices, row), (_, styles) in table.model.iterrows(): %}
<tr>
{% if index_styling%}
{% if indices is iterable %}
{% for index in indices %}
<td style={{index_styling.styles()}} class={{index_styling.classes()}}>
{{index}}
</td>
{% endfor %}
{% else %}
<td style={{index_styling.styles()}} class={{index_styling.classes()}}>
{{indices}}
</td>
{% endif%}
{% endif %}

{% for i in range(0, row|length): %}
<td style={{styles[i].styles()}} class={{styles[i].classes()}}>
{{ row[i] }}
Expand Down

0 comments on commit f5a6ef2

Please sign in to comment.