2009-02-01 16:42:57 +00:00
|
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
|
|
#
|
|
|
|
# Copyright (C) 2007-2009 Douglas S. Blank <doug.blank@gmail.com>
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
|
|
# $Id$
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# GRAMPS modules
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
2009-10-24 13:53:20 +00:00
|
|
|
from DataViews import Gramplet
|
2009-02-01 16:42:57 +00:00
|
|
|
from TransUtils import sgettext as _
|
2009-10-08 01:12:51 +00:00
|
|
|
import config
|
2009-02-01 16:42:57 +00:00
|
|
|
|
2009-07-03 20:23:41 +00:00
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Constants
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
|
|
|
|
_YIELD_INTERVAL = 350
|
|
|
|
|
2009-02-01 16:42:57 +00:00
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Local functions
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
def make_tag_size(n, counts, mins=8, maxs=20):
|
|
|
|
# return font sizes mins to maxs
|
|
|
|
diff = maxs - mins
|
|
|
|
# based on counts (biggest to smallest)
|
|
|
|
if len(counts) > 1:
|
|
|
|
position = diff - (diff * (float(counts.index(n)) / (len(counts) - 1)))
|
|
|
|
else:
|
|
|
|
position = 0
|
|
|
|
return int(position) + mins
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Gramplet class
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
class SurnameCloudGramplet(Gramplet):
|
|
|
|
def init(self):
|
|
|
|
self.set_tooltip(_("Double-click surname for details"))
|
|
|
|
self.top_size = 100 # will be overwritten in load
|
|
|
|
self.set_text(_("No Family Tree loaded."))
|
|
|
|
|
|
|
|
def db_changed(self):
|
|
|
|
self.dbstate.db.connect('person-add', self.update)
|
|
|
|
self.dbstate.db.connect('person-delete', self.update)
|
|
|
|
self.dbstate.db.connect('person-update', self.update)
|
|
|
|
self.dbstate.db.connect('person-rebuild', self.update)
|
|
|
|
self.dbstate.db.connect('family-rebuild', self.update)
|
|
|
|
|
|
|
|
def on_load(self):
|
|
|
|
if len(self.gui.data) > 0:
|
|
|
|
self.top_size = int(self.gui.data[0])
|
|
|
|
|
|
|
|
def on_save(self):
|
|
|
|
self.gui.data = [self.top_size]
|
|
|
|
|
|
|
|
def main(self):
|
|
|
|
self.set_text(_("Processing...") + "\n")
|
|
|
|
yield True
|
|
|
|
surnames = {}
|
|
|
|
representative_handle = {}
|
2009-07-14 14:16:03 +00:00
|
|
|
|
|
|
|
cnt = 0
|
2009-09-14 20:50:25 +00:00
|
|
|
for person in self.dbstate.db.iter_people():
|
|
|
|
allnames = [person.get_primary_name()] + person.get_alternate_names()
|
|
|
|
allnames = set([name.get_group_name().strip() for name in allnames])
|
|
|
|
for surname in allnames:
|
|
|
|
surnames[surname] = surnames.get(surname, 0) + 1
|
|
|
|
representative_handle[surname] = person.handle
|
|
|
|
cnt += 1
|
2009-07-03 20:23:41 +00:00
|
|
|
if not cnt % _YIELD_INTERVAL:
|
2009-02-01 16:42:57 +00:00
|
|
|
yield True
|
2009-07-03 20:23:41 +00:00
|
|
|
|
2009-02-01 16:42:57 +00:00
|
|
|
total_people = cnt
|
|
|
|
surname_sort = []
|
2009-07-14 14:16:03 +00:00
|
|
|
total = cnt = 0
|
|
|
|
for surname in surnames:
|
2009-02-01 16:42:57 +00:00
|
|
|
surname_sort.append( (surnames[surname], surname) )
|
|
|
|
total += surnames[surname]
|
2009-09-14 20:50:25 +00:00
|
|
|
cnt += 1
|
2009-07-03 20:23:41 +00:00
|
|
|
if not cnt % _YIELD_INTERVAL:
|
2009-02-01 16:42:57 +00:00
|
|
|
yield True
|
2009-07-03 20:23:41 +00:00
|
|
|
|
2009-02-01 16:42:57 +00:00
|
|
|
total_surnames = cnt
|
2009-07-03 20:23:41 +00:00
|
|
|
surname_sort.sort(reverse=True)
|
2009-02-01 16:42:57 +00:00
|
|
|
cloud_names = []
|
|
|
|
cloud_values = []
|
2009-07-14 14:16:03 +00:00
|
|
|
for (count, surname) in surname_sort:
|
2009-02-01 16:42:57 +00:00
|
|
|
cloud_names.append( (count, surname) )
|
|
|
|
cloud_values.append( count )
|
2009-07-03 20:23:41 +00:00
|
|
|
|
|
|
|
cloud_names.sort(key=lambda k:k[1])
|
2009-09-18 01:41:31 +00:00
|
|
|
counts = list(set(cloud_values))
|
|
|
|
counts.sort(reverse=True)
|
2009-02-01 16:42:57 +00:00
|
|
|
line = 0
|
|
|
|
### All done!
|
|
|
|
# Now, find out how many we can display without going over top_size:
|
|
|
|
totals = {}
|
|
|
|
for (count, givensubname) in cloud_names: # givensubname_sort:
|
|
|
|
totals[count] = totals.get(count, 0) + 1
|
2009-05-27 17:33:45 +00:00
|
|
|
sums = sorted(totals, reverse=True)
|
2009-02-01 16:42:57 +00:00
|
|
|
total = 0
|
|
|
|
include_greater_than = 0
|
|
|
|
for s in sums:
|
|
|
|
if total + totals[s] <= self.top_size:
|
|
|
|
total += totals[s]
|
|
|
|
else:
|
|
|
|
include_greater_than = s
|
|
|
|
break
|
|
|
|
# Ok, now we can show those counts > include_greater_than:
|
|
|
|
showing = 0
|
|
|
|
self.set_text("")
|
|
|
|
for (count, surname) in cloud_names: # surname_sort:
|
|
|
|
if count > include_greater_than:
|
|
|
|
if len(surname) == 0:
|
2009-10-08 01:12:51 +00:00
|
|
|
text = config.get('preferences.no-surname-text')
|
2009-02-01 16:42:57 +00:00
|
|
|
else:
|
|
|
|
text = surname
|
|
|
|
size = make_tag_size(count, counts)
|
|
|
|
self.link(text, 'Surname', representative_handle[surname], size,
|
|
|
|
"%s, %d%% (%d)" % (text,
|
|
|
|
int((float(count)/total_people) * 100),
|
|
|
|
count))
|
|
|
|
self.append_text(" ")
|
|
|
|
showing += 1
|
|
|
|
self.append_text(("\n\n" + _("Total unique surnames") + ": %d\n") %
|
|
|
|
total_surnames)
|
|
|
|
self.append_text((_("Total surnames showing") + ": %d\n") % showing)
|
|
|
|
self.append_text((_("Total people") + ": %d") % total_people, "begin")
|