|
|
@ -85,42 +85,44 @@ class Svg(object): |
|
|
|
colors = self.graph.style.get_colors(self.id, self.graph._order) |
|
|
|
colors = self.graph.style.get_colors(self.id, self.graph._order) |
|
|
|
strokes = self.get_strokes() |
|
|
|
strokes = self.get_strokes() |
|
|
|
all_css = [] |
|
|
|
all_css = [] |
|
|
|
for css in ['base.css'] + list(self.graph.css): |
|
|
|
for css in ['file://base.css'] + list(self.graph.css): |
|
|
|
if '://' in css: |
|
|
|
css_text = None |
|
|
|
self.processing_instructions.append( |
|
|
|
if css.startswith('inline:'): |
|
|
|
etree.PI( |
|
|
|
css_text = css[len('inline:'):] |
|
|
|
u('xml-stylesheet'), u('href="%s"' % css))) |
|
|
|
elif css.startswith('file://'): |
|
|
|
else: |
|
|
|
if not os.path.exists(css): |
|
|
|
if css.startswith('inline:'): |
|
|
|
css = os.path.join( |
|
|
|
css_text = css[len('inline:'):] |
|
|
|
os.path.dirname(__file__), 'css', css[len('file://'):]) |
|
|
|
else: |
|
|
|
|
|
|
|
if not os.path.exists(css): |
|
|
|
class FontSizes(object): |
|
|
|
css = os.path.join( |
|
|
|
|
|
|
|
os.path.dirname(__file__), 'css', css) |
|
|
|
"""Container for font sizes""" |
|
|
|
|
|
|
|
|
|
|
|
class FontSizes(object): |
|
|
|
fs = FontSizes() |
|
|
|
|
|
|
|
for name in dir(self.graph.state): |
|
|
|
"""Container for font sizes""" |
|
|
|
if name.endswith('_font_size'): |
|
|
|
|
|
|
|
setattr( |
|
|
|
fs = FontSizes() |
|
|
|
fs, |
|
|
|
for name in dir(self.graph.state): |
|
|
|
name.replace('_font_size', ''), |
|
|
|
if name.endswith('_font_size'): |
|
|
|
('%dpx' % getattr(self.graph, name))) |
|
|
|
setattr( |
|
|
|
|
|
|
|
fs, |
|
|
|
with io.open(css, encoding='utf-8') as f: |
|
|
|
name.replace('_font_size', ''), |
|
|
|
css_text = template( |
|
|
|
('%dpx' % getattr(self.graph, name))) |
|
|
|
f.read(), |
|
|
|
|
|
|
|
style=self.graph.style, |
|
|
|
with io.open(css, encoding='utf-8') as f: |
|
|
|
colors=colors, |
|
|
|
css_text = template( |
|
|
|
strokes=strokes, |
|
|
|
f.read(), |
|
|
|
font_sizes=fs, |
|
|
|
style=self.graph.style, |
|
|
|
id=self.id) |
|
|
|
colors=colors, |
|
|
|
|
|
|
|
strokes=strokes, |
|
|
|
if css_text is not None: |
|
|
|
font_sizes=fs, |
|
|
|
|
|
|
|
id=self.id) |
|
|
|
|
|
|
|
if not self.graph.pretty_print: |
|
|
|
if not self.graph.pretty_print: |
|
|
|
css_text = minify_css(css_text) |
|
|
|
css_text = minify_css(css_text) |
|
|
|
all_css.append(css_text) |
|
|
|
all_css.append(css_text) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
self.processing_instructions.append( |
|
|
|
|
|
|
|
etree.PI( |
|
|
|
|
|
|
|
u('xml-stylesheet'), u('href="%s"' % css))) |
|
|
|
self.node( |
|
|
|
self.node( |
|
|
|
self.defs, 'style', type='text/css').text = '\n'.join(all_css) |
|
|
|
self.defs, 'style', type='text/css').text = '\n'.join(all_css) |
|
|
|
|
|
|
|
|
|
|
@ -147,13 +149,12 @@ class Svg(object): |
|
|
|
get_js_dict(), default=json_default))) |
|
|
|
get_js_dict(), default=json_default))) |
|
|
|
|
|
|
|
|
|
|
|
for js in self.graph.js: |
|
|
|
for js in self.graph.js: |
|
|
|
if '://' in js: |
|
|
|
if js.startswith('file://'): |
|
|
|
self.node( |
|
|
|
|
|
|
|
self.defs, 'script', type='text/javascript', href=js) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
script = self.node(self.defs, 'script', type='text/javascript') |
|
|
|
script = self.node(self.defs, 'script', type='text/javascript') |
|
|
|
with io.open(js, encoding='utf-8') as f: |
|
|
|
with io.open(js[len('file://'):], encoding='utf-8') as f: |
|
|
|
script.text = f.read() |
|
|
|
script.text = f.read() |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
self.node(self.defs, 'script', type='text/javascript', href=js) |
|
|
|
|
|
|
|
|
|
|
|
def node(self, parent=None, tag='g', attrib=None, **extras): |
|
|
|
def node(self, parent=None, tag='g', attrib=None, **extras): |
|
|
|
"""Make a new svg node""" |
|
|
|
"""Make a new svg node""" |
|
|
|