##// END OF EJS Templates
s/target_name/widget_class
s/target_name/widget_class

File last commit:

r16869:af858551
r18515:cd81e53e
Show More
revealhelp.py
75 lines | 3.3 KiB | text/x-python | PythonLexer
Jonathan Frederic
Cleanup and refactor, transformers
r10674 """Module that pre-processes the notebook for export via Reveal.
"""
#-----------------------------------------------------------------------------
# Copyright (c) 2013, 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
#-----------------------------------------------------------------------------
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 from .base import Preprocessor
Thomas Kluyver
Fixes for nbconvert under Python 3
r13397 from IPython.utils.traitlets import Unicode
damianavila
Added white line after imports.
r11181
Jonathan Frederic
Cleanup and refactor, transformers
r10674 #-----------------------------------------------------------------------------
# Classes and functions
#-----------------------------------------------------------------------------
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 class RevealHelpPreprocessor(Preprocessor):
Jonathan Frederic
Split transformer code
r10437
MinRK
use local reveal.js url prefix by default...
r12443 url_prefix = Unicode('reveal.js', config=True,
MinRK
remove special handling of speaker notes
r12439 help="""The URL prefix for reveal.js.
This can be a a relative URL for a local copy of reveal.js,
or point to a CDN.
MinRK
use local reveal.js url prefix by default...
r12443 For speaker notes to work, a local reveal.js prefix must be used.
MinRK
remove special handling of speaker notes
r12439 """
)
damianavila
Make configurable the url where look for reveal.js library.
r11179
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 def preprocess(self, nb, resources):
Jonathan Frederic
Cleanup and refactor, transformers
r10674 """
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 Called once to 'preprocess' contents of the notebook.
damianavila
Added some changes covering Mathias's commentaries.
r11183
Jonathan Frederic
Cleanup and refactor, transformers
r10674 Parameters
----------
nb : NotebookNode
Notebook being converted
resources : dictionary
Additional resources used in the conversion process. Allows
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 preprocessors to pass variables into the Jinja engine.
Jonathan Frederic
Cleanup and refactor, transformers
r10674 """
damianavila
Added some changes covering Mathias's commentaries.
r11183
damianavila
Delete an old dictionary available for selecting the aligment of text.
r13846 for worksheet in nb.worksheets:
Jonathan Frederic
Added writers and supporting code.
r11367 for index, cell in enumerate(worksheet.cells):
damianavila
Fixed reveal in the new nbconvert to make it work.
r10823
#Make sure the cell has slideshow metadata.
cell.metadata.slide_type = cell.get('metadata', {}).get('slideshow', {}).get('slide_type', '-')
damianavila
Fixed restarting cell to (-) type. Added a final point to the while cycle.
r16867 #Get the slide type. If type is start of subslide or slide,
Jonathan Frederic
Cleanup and refactor, transformers
r10674 #end the last subslide/slide.
Jonathan Frederic
Split transformer code
r10437 if cell.metadata.slide_type in ['slide']:
Jonathan Frederic
Added writers and supporting code.
r11367 worksheet.cells[index - 1].metadata.slide_helper = 'slide_end'
Jonathan Frederic
Split transformer code
r10437 if cell.metadata.slide_type in ['subslide']:
Jonathan Frederic
Added writers and supporting code.
r11367 worksheet.cells[index - 1].metadata.slide_helper = 'subslide_end'
damianavila
Fixed restarting cell to (-) type. Added a final point to the while cycle.
r16867 #Prevent the rendering of "do nothing" cells before fragments
damianavila
Updated reveal CDN and use the new data-fragment-index attribute to get composite fragments (several cells inside the same fragment).
r16868 #Group fragments passing frag_number to the data-fragment-index
damianavila
Getting linearity to reveal fragments. This avoid rendering of - (none) cells before fragments.
r16866 if cell.metadata.slide_type in ['fragment']:
damianavila
Updated reveal CDN and use the new data-fragment-index attribute to get composite fragments (several cells inside the same fragment).
r16868 worksheet.cells[index].metadata.frag_number = index
damianavila
Fixed restarting cell to (-) type. Added a final point to the while cycle.
r16867 i = 1
while i < len(worksheet.cells) - index:
worksheet.cells[index + i].metadata.frag_helper = 'fragment_end'
damianavila
Updated reveal CDN and use the new data-fragment-index attribute to get composite fragments (several cells inside the same fragment).
r16868 worksheet.cells[index + i].metadata.frag_number = index
damianavila
Fixed restarting cell to (-) type. Added a final point to the while cycle.
r16867 i += 1
#Restart the slide_helper when the cell status is changed
damianavila
Fixed test and add fragments to the list of resets.
r16869 #to other types.
if cell.metadata.slide_type in ['-', 'skip', 'notes', 'fragment']:
damianavila
Fixed restarting cell to (-) type. Added a final point to the while cycle.
r16867 worksheet.cells[index - 1].metadata.slide_helper = '-'
damianavila
Added some changes covering Mathias's commentaries.
r11183
Jonathan Frederic
Fixed, don't check using in since resources is a default dict.
r12143 if not isinstance(resources['reveal'], dict):
damianavila
Added look for key 'reveal' to not overwrite it.
r11184 resources['reveal'] = {}
damianavila
Added some changes covering Mathias's commentaries.
r11183 resources['reveal']['url_prefix'] = self.url_prefix
Jonathan Frederic
Cleanup and refactor, transformers
r10674 return nb, resources