invoke new_pic_inline from current_rendering_part

invoke new_pic_inline from current_rendering_part (header, document body or footer), so the image relationship gets created correctly

Remove white spaces
This commit is contained in:
idris nacer 2021-03-29 09:21:02 +01:00 committed by Idris
parent bc6d88251a
commit 6496abf307

View File

@ -208,14 +208,18 @@ class DocxTemplate(object):
return src_xml return src_xml
def render_xml(self, src_xml, context, jinja_env=None): current_rendering_part = None
def render_xml(self, src_xml, part, context, jinja_env=None):
src_xml = src_xml.replace(r'<w:p>', '\n<w:p>') src_xml = src_xml.replace(r'<w:p>', '\n<w:p>')
try: try:
self.current_rendering_part = part
if jinja_env: if jinja_env:
template = jinja_env.from_string(src_xml) template = jinja_env.from_string(src_xml)
else: else:
template = Template(src_xml) template = Template(src_xml)
dst_xml = template.render(context) dst_xml = template.render(context)
self.current_rendering_part = None
except TemplateError as exc: except TemplateError as exc:
if hasattr(exc, 'lineno') and exc.lineno is not None: if hasattr(exc, 'lineno') and exc.lineno is not None:
line_number = max(exc.lineno - 4, 0) line_number = max(exc.lineno - 4, 0)
@ -266,7 +270,7 @@ class DocxTemplate(object):
def build_xml(self, context, jinja_env=None): def build_xml(self, context, jinja_env=None):
xml = self.get_xml() xml = self.get_xml()
xml = self.patch_xml(xml) xml = self.patch_xml(xml)
xml = self.render_xml(xml, context, jinja_env) xml = self.render_xml(xml, self.docx._part, context, jinja_env)
return xml return xml
def map_tree(self, tree): def map_tree(self, tree):
@ -274,10 +278,13 @@ class DocxTemplate(object):
body = root.body body = root.body
root.replace(body, tree) root.replace(body, tree)
def get_headers_footers_xml(self, uri): def get_headers_footers(self, uri):
for relKey, val in self.docx._part._rels.items(): for relKey, val in self.docx._part._rels.items():
if (val.reltype == uri) and (val.target_part.blob): if (val.reltype == uri) and (val.target_part.blob):
yield relKey, self.xml_to_string(parse_xml(val.target_part.blob)) yield relKey, val.target_part
def get_part_xml(self, part):
return self.xml_to_string(parse_xml(part.blob))
def get_headers_footers_encoding(self, xml): def get_headers_footers_encoding(self, xml):
m = re.match(r'<\?xml[^\?]+\bencoding="([^"]+)"', xml, re.I) m = re.match(r'<\?xml[^\?]+\bencoding="([^"]+)"', xml, re.I)
@ -286,10 +293,11 @@ class DocxTemplate(object):
return 'utf-8' return 'utf-8'
def build_headers_footers_xml(self, context, uri, jinja_env=None): def build_headers_footers_xml(self, context, uri, jinja_env=None):
for relKey, xml in self.get_headers_footers_xml(uri): for relKey, part in self.get_headers_footers(uri):
xml = self.get_part_xml(part)
encoding = self.get_headers_footers_encoding(xml) encoding = self.get_headers_footers_encoding(xml)
xml = self.patch_xml(xml) xml = self.patch_xml(xml)
xml = self.render_xml(xml, context, jinja_env) xml = self.render_xml(xml, part, context, jinja_env)
yield relKey, xml.encode(encoding) yield relKey, xml.encode(encoding)
def map_headers_footers_xml(self, relKey, xml): def map_headers_footers_xml(self, relKey, xml):
@ -636,7 +644,8 @@ class DocxTemplate(object):
xml = self.get_xml() xml = self.get_xml()
xml = self.patch_xml(xml) xml = self.patch_xml(xml)
for uri in [self.HEADER_URI, self.FOOTER_URI]: for uri in [self.HEADER_URI, self.FOOTER_URI]:
for relKey, _xml in self.get_headers_footers_xml(uri): for relKey, part in self.get_headers_footers(uri):
_xml = self.get_part_xml(part)
xml += self.patch_xml(_xml) xml += self.patch_xml(_xml)
if jinja_env: if jinja_env:
env = jinja_env env = jinja_env
@ -806,7 +815,7 @@ class InlineImage(object):
self.width, self.height = width, height self.width, self.height = width, height
def _insert_image(self): def _insert_image(self):
pic = self.tpl.docx._part.new_pic_inline( pic = self.tpl.current_rendering_part.new_pic_inline(
self.image_descriptor, self.image_descriptor,
self.width, self.width,
self.height self.height