##// END OF EJS Templates
release 8.12.1
release 8.12.1

File last commit:

r27249:96f8b20f
r28265:f4df70be
Show More
display.py
93 lines | 3.1 KiB | text/x-python | PythonLexer
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 """Simple magics for display formats"""
#-----------------------------------------------------------------------------
# Copyright (c) 2012 The IPython Development Team.
#
# Distributed under the terms of the Modified BSD License.
#
# The full license is in the file COPYING.txt, distributed with this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
# Our own packages
Matthias Bussonnier
Do not import from IPython.core.display and warn users.
r25632 from IPython.display import display, Javascript, Latex, SVG, HTML, Markdown
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 from IPython.core.magic import (
Thomas Kluyver
Remove unused imports
r9399 Magics, magics_class, cell_magic
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 )
Sjoerd de Vries
added --isolated option for %%html magic
r24112 from IPython.core import magic_arguments
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946
#-----------------------------------------------------------------------------
# Magic implementation classes
#-----------------------------------------------------------------------------
@magics_class
class DisplayMagics(Magics):
"""Magics for displaying various output types with literals
Jonathan Frederic
Add %%js alias for %%javascript
r22307
Defines javascript/latex/svg/html cell magics for writing
Mikhail Korobov
fix DisplayMagics.html docstring
r10054 blocks in those languages, to be rendered in the frontend.
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 """
Jonathan Frederic
Add %%js alias for %%javascript
r22307
@cell_magic
def js(self, line, cell):
Matthias Bussonnier
Precise that %%js is an alias of %%javascript
r22310 """Run the cell block of Javascript code
Sjoerd de Vries
added --isolated option for %%html magic
r24112
Matthias Bussonnier
Precise that %%js is an alias of %%javascript
r22310 Alias of `%%javascript`
Matthias Bussonnier
Start deprecating %%javascript/%%js...
r27249
Starting with IPython 8.0 %%javascript is pending deprecation to be replaced
by a more flexible system
Please See https://github.com/ipython/ipython/issues/13376
Matthias Bussonnier
Precise that %%js is an alias of %%javascript
r22310 """
Jonathan Frederic
Add %%js alias for %%javascript
r22307 self.javascript(line, cell)
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 @cell_magic
def javascript(self, line, cell):
Matthias Bussonnier
Start deprecating %%javascript/%%js...
r27249 """Run the cell block of Javascript code
Starting with IPython 8.0 %%javascript is pending deprecation to be replaced
by a more flexible system
Please See https://github.com/ipython/ipython/issues/13376
"""
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 display(Javascript(cell))
Jonathan Frederic
Add %%js alias for %%javascript
r22307
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 @cell_magic
def latex(self, line, cell):
Daniel Mietchen
grammar, plus styling of LaTeX
r26219 """Render the cell as a block of LaTeX
Jonathan Frederic
Add %%js alias for %%javascript
r22307
Daniel Mietchen
grammar, plus styling of LaTeX
r26219 The subset of LaTeX which is supported depends on the implementation in
Jonathan Frederic
Add %%js alias for %%javascript
r22307 the client. In the Jupyter Notebook, this magic only renders the subset
Daniel Mietchen
another LaTeX
r26220 of LaTeX defined by MathJax
Jonathan Frederic
Better document the %%latex magic latex support.
r21735 [here](https://docs.mathjax.org/en/v2.5-latest/tex.html)."""
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 display(Latex(cell))
@cell_magic
def svg(self, line, cell):
"""Render the cell as an SVG literal"""
display(SVG(cell))
MinRK
add %%html cell magic
r9999
Sjoerd de Vries
added --isolated option for %%html magic
r24112 @magic_arguments.magic_arguments()
@magic_arguments.argument(
'--isolated', action='store_true', default=False,
help="""Annotate the cell as 'isolated'.
Isolated cells are rendered inside their own <iframe> tag"""
)
MinRK
add %%html cell magic
r9999 @cell_magic
def html(self, line, cell):
Mikhail Korobov
fix DisplayMagics.html docstring
r10054 """Render the cell as a block of HTML"""
Sjoerd de Vries
added --isolated option for %%html magic
r24112 args = magic_arguments.parse_argstring(self.html, line)
html = HTML(cell)
if args.isolated:
display(html, metadata={'text/html':{'isolated':True}})
else:
display(html)
@cell_magic
Matti Remes
add markdown cell magic function...
r23656 def markdown(self, line, cell):
"""Render the cell as Markdown text block"""
display(Markdown(cell))