Code reference
Build, present and share animated data stories in Jupyter Notebook
and similar environments.
ipyvizzu-story
package consists of two main parts:
ipyvizzu-story
package tries to figure out the environment and import the correct type of Story
,
however Story
could be imported with full path.
ipyvizzu-story
package imports the following objects in __init__.py
:
Story
from Env.py.story or Env.ipy.story or Env.st.story- Step
- Slide
ipyvizzustory.get_story()
A method for returning the appropriate Story for the environment.
Returns:
Type | Description |
---|---|
Union[ipyvizzustory.env.py.story.Story, ipyvizzustory.env.ipy.story.Story, ipyvizzustory.env.st.story.Story]
|
The appropriate |
Source code in ipyvizzustory/__init__.py
def get_story():
"""
A method for returning the appropriate Story for the environment.
Returns:
(Union[ipyvizzustory.env.py.story.Story, ipyvizzustory.env.ipy.story.Story, ipyvizzustory.env.st.story.Story]):
The appropriate `Story` for the environment.
""" # pylint: disable=line-too-long
return JupyterStory or StreamlitStory or PythonStory
ipyvizzustory.Story = get_story()
module-attribute
Available types:
ipyvizzustory.Slide
Bases: list
A class for representing a slide of a presentation story.
Source code in ipyvizzustory/storylib/story.py
class Slide(list):
"""A class for representing a slide of a presentation story."""
def __init__(self, step: Optional[Step] = None):
"""
Slide constructor.
Args:
step (optional): The first step can also be added to the slide in the constructor.
"""
super().__init__()
if step:
self.add_step(step)
def add_step(self, step: Step) -> None:
"""
A method for adding a step for the slide.
Args:
step: The next step of the slide.
Raises:
TypeError: If the type of the `step` is not `Step`.
"""
if not step or type(step) != Step: # pylint: disable=unidiomatic-typecheck
raise TypeError("Type must be Step.")
self.append(step)
__init__(step=None)
Slide constructor.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
step |
optional
|
The first step can also be added to the slide in the constructor. |
None
|
Source code in ipyvizzustory/storylib/story.py
def __init__(self, step: Optional[Step] = None):
"""
Slide constructor.
Args:
step (optional): The first step can also be added to the slide in the constructor.
"""
super().__init__()
if step:
self.add_step(step)
add_step(step)
A method for adding a step for the slide.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
step |
Step
|
The next step of the slide. |
required |
Raises:
Type | Description |
---|---|
TypeError
|
If the type of the |
Source code in ipyvizzustory/storylib/story.py
def add_step(self, step: Step) -> None:
"""
A method for adding a step for the slide.
Args:
step: The next step of the slide.
Raises:
TypeError: If the type of the `step` is not `Step`.
"""
if not step or type(step) != Step: # pylint: disable=unidiomatic-typecheck
raise TypeError("Type must be Step.")
self.append(step)
ipyvizzustory.Step
Bases: dict
A class for representing a step of a slide.
Source code in ipyvizzustory/storylib/story.py
class Step(dict):
"""A class for representing a step of a slide."""
def __init__(
self,
*animations: Union[Data, Style, Config],
**anim_options: Optional[Union[str, int, float, dict]],
):
"""
Step constructor.
Note:
Do not set `anim_options` argument, it will raise `NotImplementedError` error.
Args:
*animations: List of `ipyvizzu.Data`, `ipyvizzu.Config` and `ipyvizzu.Style` objects.
A `Step` can contain each of the above once.
**anim_options (optional): Animation options such as duration.
Raises:
ValueError: If `animations` are not set.
NotImplementedError: If `anim_options` are set.
"""
super().__init__()
if not animations:
raise ValueError("No animation was set.")
self._update(*animations)
if anim_options:
# self["animOptions"] = PlainAnimation(**anim_options).build()
raise NotImplementedError("Anim options are not supported.")
def _update(self, *animations: Union[Data, Style, Config]) -> None:
for animation in animations:
if not animation or type(animation) not in [
Data,
Style,
Config,
]: # pylint: disable=unidiomatic-typecheck
raise TypeError("Type must be Data, Style or Config.")
if type(animation) == Data: # pylint: disable=unidiomatic-typecheck
animation = DataFilter(animation)
builded_animation = animation.build()
common_keys = set(builded_animation).intersection(set(self))
if common_keys:
raise ValueError(f"Animation is already merged: {common_keys}")
self.update(builded_animation)
__init__(*animations, **anim_options)
Step constructor.
Note
Do not set anim_options
argument, it will raise NotImplementedError
error.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
*animations |
Union[Data, Style, Config]
|
List of |
()
|
**anim_options |
optional
|
Animation options such as duration. |
{}
|
Raises:
Type | Description |
---|---|
ValueError
|
If |
NotImplementedError
|
If |
Source code in ipyvizzustory/storylib/story.py
def __init__(
self,
*animations: Union[Data, Style, Config],
**anim_options: Optional[Union[str, int, float, dict]],
):
"""
Step constructor.
Note:
Do not set `anim_options` argument, it will raise `NotImplementedError` error.
Args:
*animations: List of `ipyvizzu.Data`, `ipyvizzu.Config` and `ipyvizzu.Style` objects.
A `Step` can contain each of the above once.
**anim_options (optional): Animation options such as duration.
Raises:
ValueError: If `animations` are not set.
NotImplementedError: If `anim_options` are set.
"""
super().__init__()
if not animations:
raise ValueError("No animation was set.")
self._update(*animations)
if anim_options:
# self["animOptions"] = PlainAnimation(**anim_options).build()
raise NotImplementedError("Anim options are not supported.")