# # Gramps - a GTK+/GNOME based genealogy program # # Copyright (C) 2000-2003 Donald N. Allingham # # 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 # #------------------------------------------------------------------------- # # Standard Python Modules # #------------------------------------------------------------------------- import os import tempfile import string import zipfile import time #------------------------------------------------------------------------- # # Gramps modules # #------------------------------------------------------------------------- import Errors import TextDoc import const import Plugins import ImgManip #------------------------------------------------------------------------- # # internationalization # #------------------------------------------------------------------------- from intl import gettext as _ #------------------------------------------------------------------------- # # OpenOfficeDoc # #------------------------------------------------------------------------- class OpenOfficeDoc(TextDoc.TextDoc): def __init__(self,styles,type,template,orientation): TextDoc.TextDoc.__init__(self,styles,type,template,orientation) self.f = None self.filename = None self.level = 0 self.time = "0000-00-00T00:00:00" self.new_page = 0 self.new_cell = 0 def open(self,filename): t = time.localtime(time.time()) self.time = "%04d-%02d-%02dT%02d:%02d:%02d" % \ (t[0],t[1],t[2],t[3],t[4],t[5]) if filename[-4:] != ".sxw": self.filename = filename + ".sxw" else: self.filename = filename self.filename = os.path.normpath(os.path.abspath(filename)) try: self.content_xml = tempfile.mktemp() self.f = open(self.content_xml,"wb") except IOError,msg: errmsg = "%s\n%s" % (_("Could not create %s") % self.content_xml, msg) raise Errors.ReportError(errmsg) except: raise Errors.ReportError("Could not create %s" % self.content_xml) self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('') self.f.write('') self.f.write('\n') for style_name in self.style_list.keys(): style = self.style_list[style_name] self.f.write('\n\n') self.f.write('\n') for style_name in self.table_styles.keys(): style = self.table_styles[style_name] self.f.write('\n') table_width = float(self.get_usable_width()) table_width_str = "%.4f" % table_width self.f.write('\n') self.f.write('\n') for col in range(0,style.get_columns()): self.f.write('') width = table_width * float(style.get_column_width(col)/100.0) width_str = "%.4f" % width self.f.write('' % width_str) self.f.write('\n') for cell in self.cell_styles.keys(): cell_style = self.cell_styles[cell] self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') #Begin photo style self.f.write('') self.f.write('') self.f.write('\n') self.f.write('') self.f.write('') self.f.write('\n') self.f.write('') self.f.write('') self.f.write('\n') self.f.write('') self.f.write('') self.f.write('\n') #end of Photo style edits self.f.write('\n') self.f.write('\n') def close(self): self.f.write('\n') self.f.write('\n') self.f.close() self._write_styles_file() self._write_manifest() self._write_meta_file() self._write_zip() def add_photo(self,name,pos,x_cm,y_cm): image = ImgManip.ImgManip(name) (x,y) = image.size() ratio = float(x_cm)*float(y)/(float(y_cm)*float(x)) if ratio < 1: act_width = x_cm act_height = y_cm*ratio else: act_height = y_cm act_width = x_cm/ratio photo_list_item = (name,act_width,act_height) if not photo_list_item in self.photo_list: self.photo_list.append(photo_list_item) base = os.path.basename(name) tag = string.replace(base,'.','_') if self.new_cell: self.f.write('\n') if pos == "left": self.f.write('\n') if self.new_cell: self.f.write('\n') def start_table(self,name,style_name): self.f.write('\n' % style_name) table = self.table_styles[style_name] for col in range(0,table.get_columns()): self.f.write('\n') def end_table(self): self.f.write('\n') def start_row(self): self.f.write('\n') def end_row(self): self.f.write('\n') def start_cell(self,style_name,span=1): self.span = span self.f.write(' 1: self.f.write(' table:number-columns-spanned="%s">\n' % span) else: self.f.write('>\n') self.new_cell = 1 def end_cell(self): self.f.write('\n') for col in range(1,self.span): self.f.write('\n') self.new_cell = 0 def start_bold(self): self.f.write('') def end_bold(self): self.f.write('') def _write_zip(self): file = zipfile.ZipFile(self.filename,"w",zipfile.ZIP_DEFLATED) file.write(self.manifest_xml,str("META-INF/manifest.xml")) file.write(self.content_xml,str("content.xml")) file.write(self.meta_xml,str("meta.xml")) file.write(self.styles_xml,str("styles.xml")) for image in self.photo_list: base = os.path.basename(image[0]) file.write(image[0], str("Pictures/%s" % base)) file.close() os.unlink(self.manifest_xml) os.unlink(self.content_xml) os.unlink(self.meta_xml) os.unlink(self.styles_xml) def _write_styles_file(self): self.styles_xml = tempfile.mktemp() try: self.f = open(self.styles_xml,"wb") except IOError,msg: errmsg = "%s\n%s" % (_("Could not create %s") % self.styles_xml, msg) raise Errors.ReportError(errmsg) except: raise Errors.ReportError(_("Could not create %s") % self.styles_xml) self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') for key in self.style_list.keys(): style = self.style_list[key] self.f.write('\n') self.f.write('\n') self.f.write('\n') # Current no leading number format for headers self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.close() def page_break(self): self.new_page = 1 def start_paragraph(self,style_name,leader=None): style = self.style_list[style_name] self.level = style.get_header_level() if self.new_page == 1: self.new_page = 0 name = "NL%s" % style_name else: name = style_name if self.level == 0: self.f.write('' % name) else: self.f.write('') if leader != None: self.f.write(leader) self.f.write('') self.new_cell = 0 def end_paragraph(self): if self.level == 0: self.f.write('\n') else: self.f.write('\n') self.new_cell = 1 def write_text(self,text): text = string.replace(text,'&','&'); # Must be first text = string.replace(text,'<','<'); text = string.replace(text,'>','>'); text = string.replace(text,'\n','') text = text.replace('<super>','') text = text.replace('</super>','') self.f.write(text) def _write_manifest(self): self.manifest_xml = tempfile.mktemp() try: self.f = open(self.manifest_xml,"wb") except IOError,msg: errmsg = "%s\n%s" % (_("Could not create %s") % self.manifest_xml, msg) raise Errors.ReportError(errmsg) except: raise Errors.ReportError(_("Could not create %s") % self.manifest_xml) self.f.write('\n') self.f.write('') self.f.write('') for image in self.photo_list: i = image[0] base = os.path.basename(i) self.f.write('') self.f.write('') self.f.write('') self.f.write('') self.f.write('') self.f.write('\n') self.f.close() def _write_meta_file(self): name = self.name self.meta_xml = tempfile.mktemp() try: self.f = open(self.meta_xml,"wb") except IOError,msg: errmsg = "%s\n%s" % (_("Could not create %s") % self.meta_xml, msg) raise Errors.ReportError(errmsg) except: raise Errors.ReportError(_("Could not create %s") % self.meta_xml) self.f.write('\n') self.f.write('\n'); self.f.write('\n') self.f.write('') self.f.write(const.progName + ' ' + const.version) self.f.write('\n') self.f.write('') self.f.write(name) self.f.write('\n') self.f.write('') self.f.write(self.time) self.f.write('\n') self.f.write('') self.f.write(name) self.f.write('\n') self.f.write('') self.f.write(self.time) self.f.write('\n') self.f.write('0-00-00T00:00:00\n') self.f.write('en-US\n') self.f.write('1\n') self.f.write('PT0S\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.write('\n') self.f.close() Plugins.register_text_doc(_("OpenOffice.org Writer"),OpenOfficeDoc,1,1,1,".sxw")