Improved export for hierarchical views

svn: r13830
This commit is contained in:
Nick Hall 2009-12-16 22:56:55 +00:00
parent bd961672c8
commit bfd2a9629f
3 changed files with 35 additions and 12 deletions

View File

@ -803,8 +803,16 @@ class ListView(NavigationView):
ofile.open(name) ofile.open(name)
ofile.start_page() ofile.start_page()
ofile.start_row() ofile.start_row()
# Headings # Headings
map(ofile.write_cell, column_names) if self.model.get_flags() & gtk.TREE_MODEL_LIST_ONLY:
headings = column_names
else:
levels = self.model.get_tree_levels()
headings = levels + column_names[1:]
data_cols = data_cols[1:]
map(ofile.write_cell, headings)
ofile.end_row() ofile.end_row()
if self.model.get_flags() & gtk.TREE_MODEL_LIST_ONLY: if self.model.get_flags() & gtk.TREE_MODEL_LIST_ONLY:
@ -816,25 +824,28 @@ class ListView(NavigationView):
ofile.end_row() ofile.end_row()
else: else:
# Tree model # Tree model
node = self.model.get_iter_first() node = self.model.on_get_iter((0,))
self.write_node(node, 0, ofile, data_cols) self.write_node(node, len(levels), [], ofile, data_cols)
ofile.end_page() ofile.end_page()
ofile.close() ofile.close()
def write_node(self, node, level, ofile, data_cols): def write_node(self, node, depth, level, ofile, data_cols):
if node is None: if node is None:
return return
while node is not None: while node is not None:
new_level = level + [self.model.on_get_value(node, 0)]
if self.model.get_handle(node):
ofile.start_row() ofile.start_row()
map(ofile.write_cell, ('',)*level) padded_level = new_level + [''] * (depth - len(new_level))
map(ofile.write_cell, padded_level)
for index in data_cols: for index in data_cols:
ofile.write_cell(self.model.get_value(node, index)) ofile.write_cell(self.model.on_get_value(node, index))
ofile.end_row() ofile.end_row()
first_child = self.model.iter_children(node) first_child = self.model.on_iter_children(node)
self.write_node(first_child, level + 1, ofile, data_cols) self.write_node(first_child, depth, new_level, ofile, data_cols)
node = self.model.iter_next(node) node = self.model.on_iter_next(node)
#################################################################### ####################################################################
# Template functions # Template functions

View File

@ -159,6 +159,12 @@ class PeopleModel(TreeBaseModel):
""" Return the number of columns in the model """ """ Return the number of columns in the model """
return len(self.fmap)+1 return len(self.fmap)+1
def get_tree_levels(self):
"""
Return the headings of the levels in the hierarchy.
"""
return ['Group As', 'Name']
def add_row(self, handle, data): def add_row(self, handle, data):
""" """
Add nodes to the node map for a single person. Add nodes to the node map for a single person.

View File

@ -73,6 +73,12 @@ class PlaceTreeModel(PlaceBaseModel, TreeBaseModel):
nrgroups = 3, nrgroups = 3,
group_can_have_handle = True) group_can_have_handle = True)
def get_tree_levels(self):
"""
Return the headings of the levels in the hierarchy.
"""
return ['Country', 'State', 'County', 'Place Name']
def add_row(self, handle, data): def add_row(self, handle, data):
""" """
Add nodes to the node map for a single place. Add nodes to the node map for a single place.