custom_event

class virtualitics_sdk.elements.custom_event.AssetDownloadCustomEvent(title, asset, extension, mime_type=None, show_title=True, show_description=True)

Bases: CustomEvent

Creates a custom event that generates a download link to an Asset’s data/object. The download link will return the bytes of the object if it is an instance of bytes, a text file if it is an instance of str or the dill pickled bytes of the python object.

Adds some additional required parameters to the constructor.

Parameters:
  • title (str) – The title of the custom event element.

  • asset (Asset) – an Asset object with reference of the data/object to download.

  • extension (str) – A file extension of the resulting downloaded file.

  • mime_type (Optional[str]) – Force the mimetype of the downloaded file (this determines how the client’s browser encodes or writes the file being download.

  • show_title (bool) – whether to show the title on the page when rendered, defaults to True.

  • show_description (bool) – whether to show the description to the page when rendered, defaults to True.

EXAMPLE:

# Imports 
from virtualitics_sdk.elements.custom_event import AssetDownloadCustomEvent
. . .
# Example usage 
class DataShow(Step):
 def run(self, flow_metadata):
     . . . 
     acc = Model(label="linear-svc", model=LinearSVC().fit(X, y), name="Example")
     event = AssetDownloadCustomEvent("Download Linear SVC", acc, "pkl")

The above AssetDownloadCustomEvent usage will be displayed as:

callback(flow_metadata, **step_clients)
Return type:

Union[str, dict]

class virtualitics_sdk.elements.custom_event.CustomEvent(title, description, show_title=True, show_description=True, position=CustomEventPosition.RIGHT, label='', placeholder='', **kwargs)

Bases: InputElement

Creates a custom event element that calls the passed in function using flow_metadata when clicked.

Parameters:
  • title (str) – The title of the custom event element.

  • description (str) – A description to go with this element on the page.

  • show_title (bool) – whether to show the title on the page when rendered, defaults to True.

  • show_description (bool) – whether to show the description to the page when rendered, defaults to True.

  • position (CustomEventPosition) – The position the event button should be placed, defaults to CustomEventPosition.RIGHT

  • label (str) – The label of the element, defaults to ‘’.

  • placeholder (str) – The placeholder of the element, defaults to ‘’.

EXAMPLE:

# Imports 
from virtualitics_sdk.elements.custom_event import CustomEvent
. . .
# Example usage
# This creates a custom event for us to place in the step defined below
class SimpleCustomEvent(CustomEvent):
   def __init__(self):
      super().__init__(title="Kick-off", description="", show_description=False)
    def callback(self, flow_metadata) -> Union[str, dict]:
      return "Done!"
class ExampleStep(Step):
    def run(self, flow_metadata):
     . . . 
     event = SimpleCustomEvent()
     info = Infographic("", "", [], [recommendation], event=event)
     return info

The above CustomEvent will be displayed as:

abstract callback(flow_metadata, **step_clients)
Return type:

Union[str, dict]

get_value()

This function does nothing for Custom Events. Although they are input elements, getting their value will return None

Returns:

None

class virtualitics_sdk.elements.custom_event.CustomEventPosition(value, names=None, *, module=None, qualname=None, type=None, start=1, boundary=None)

Bases: Enum

CENTER = 'center'
LEFT = 'left'
RIGHT = 'right'
class virtualitics_sdk.elements.custom_event.TriggerFlowCustomEvent(title, description, flow_name, input_parameters=None, timeout=30, show_title=True, show_description=True, position=CustomEventPosition.RIGHT, **kwargs)

Bases: CustomEvent

Creates a custom event that triggers another app with optional pre-supplied input parameters. Then wait for the app to stop and return a redirect url to the last started step.

Parameters:
  • title (str) – The title of the custom event element.

  • description (str) – A description to go with this element on the page.

  • flow_name (str) – the Name of the App to be triggered

  • input_parameters (Optional[dict]) – an optional dictionary describing input parameters to be passed to the triggered app

  • timeout (int) – timeout in seconds, the amount of time to wait for the triggered app to stop [default = 30]

  • show_title (bool) – whether to show the title on the page when rendered, defaults to True.

  • show_description (bool) – whether to show the description to the page when rendered, defaults to True.

  • position (CustomEventPosition) – The position the event button should be placed, defaults to CustomEventPosition.RIGHT

  • kwargs

EXAMPLE:

# Imports 
from virtualitics_sdk.elements.custom_event import TriggerFlowCustomEvent
. . . 
# Example usage 
class DataUpload(Step):
  def run(self, flow_metadata):
     . . .
     flow_input_parameters = {"steps": {
         "DataUpload": {
             "Dropdown One": {"value": "A", 
                              "description": "", 
                              "card_title": 
                              "User Input Card"},
             "Dropdown Two": {"value": "B", 
                              "card_title": 
                              "User Input Card"}}}}
     trigger = TriggerFlowCustomEvent(title="Trigger a Flow",
                                     description="",
                                     flow_name="TriggerFlowTest",
                                     input_parameters=flow_input_parameters)

The above TriggerFlowCustomEvent will be displayed as:

callback(flow_metadata, **step_clients)
Return type:

Union[str, dict]