Python API
Assistant
- class RPA.Assistant.Assistant
The Assistant library provides a way to display information to a user and request input while a robot is running. It allows building processes that require human interaction. Also it offers capabilities of running other robots inside the current one and determine what to display to the user based on his previous responses.
It is not included in the rpaframework package, so in order to use it you have to add rpaframework-assistant with the desired version in your conda.yaml file
Some examples of use-cases could be the following:
Displaying generated files after an execution is finished
Displaying dynamic and user-friendly error messages
Requesting passwords or other personal information
Running Keywords based on user’s actions
Displaying dynamic content based on user’s actions
Automating based on files created by the user
Workflow
The library is used to create dialogs, i.e. windows, that can be composed on-the-fly based on the current state of the execution.
The content of the dialog is defined by calling relevant keywords such as
Add text
orAdd file input
. When the dialog is opened the content is generated based on the previous keywords.Depending on the way the dialog is started, the execution will either block or continue while the dialog is open. During this time the user can freely edit any possible input fields or handle other tasks.
After the user has successfully submitted the dialog, any possible entered input will be returned as a result. The user also has the option to abort by closing the dialog window forcefully.
Results
Each input field has a required
name
argument that controls what the value will be called in the result object. Each input name should be unique, and must not be calledsubmit
as that is reserved for the submit button value.A result object is a Robot Framework DotDict, where each key is the name of the input field and the value is what the user entered. The data type of each field depends on the input. For instance, a text input will have a string, a checkbox will have a boolean, and a file input will have a list of paths.
If the user closed the window before submitting or there was an internal error, the results object returned by Run Dialog or Ask User won’t have a “submit” key.
Layouting
By default elements are added to the assistant dialog from top to bottom, with a bit of margin around each element to add spaciousness. This margin is added as a
Container
you can manually useOpen Container
to override the default container. You can use it to set smaller margins.You can combine layouting elements with each other. Layouting elements need to be closed with the corresponding
Close
keyword. (SoOpen Row
and thenClose Row
.)Open Row
can be used to layout elements in the same row.Open Column
can be used to layout elements in columns.Open Stack
and multipleOpen Container
’s inside it can be used to set positions like Center, Topleft, BottomRight, or coordinate tuples likes (0, 0), (100, 100) and such.Open Container
can bse used for absolute positioning inside a Stack, or anywhere for setting background color or margins and paddings.Open Navbar
can be used to make a navigation bar that will stay at the top of the dialog. Its contents won’t be cleared when.Examples
*** Keywords *** Success dialog Add icon Success Add heading Your orders have been processed Add files *.txt Run dialog title=Success Failure dialog Add icon Failure Add heading There was an error Add text The assistant failed to login to the Enterprise portal Add link https://robocorp.com/docs label=Troubleshooting guide Run dialog title=Failure Large dialog Add heading A real chonker size=large Add image fat-cat.jpeg Run dialog title=Large height=1024 width=1024 Confirmation dialog Add icon Warning Add heading Delete user ${username}? Add submit buttons buttons=No,Yes default=Yes ${result}= Run dialog IF $result.submit == "Yes" Delete user ${username} END Input form dialog Add heading Send feedback Add text input email label=E-mail address Add text input message ... label=Feedback ... placeholder=Enter feedback here ... maximum_rows=5 ${result}= Run dialog Send feedback message ${result.email} ${result.message}
def success_dialog(): assistant = Assistant() assistant.add_icon("success") assistant.add_heading("Your orders have been processed") assistant.add_files("*.txt") assistant.run_dialog(title="Success") def failure_dialog(): assistant = Assistant() assistant.add_icon("failure") assistant.add_heading("There was an error") assistant.add_text("The assistant failed to login to the Enterprise portal") assistant.add_link("https://robocorp.com/docs", label="Troubleshooting guide") assistant.add_files("*.txt") assistant.run_dialog(title="Failure") def large_dialog(): assistant = Assistant() assistant.add_heading("A real chonker", size="large") assistant.add_image("fat-cat.jpeg") assistant.run_dialog(title="Large", height=1024, width=1024) def confirmation_dialog(): assistant = Assistant() assistant.add_icon("warning") assistant.add_heading("Delete user ${username}?") assistant.add_submit_buttons(buttons="No, Yes", default="Yes") result = assistant.run_dialog() if result.submit == "Yes": delete_user(username) def input_from_dialog(): assistant = Assistant() assistant.add_heading("Send feedback") assistant.add_text_input("email", label="E-mail address") assistant.add_text_input("message", label="Feedback", placeholder="Enter feedback here", maximum_rows=5) assistant.add_submit_buttons("Submit", default="Submit") result = assistant.run_dialog() send_feedback_message(result.email, result.message)
- ROBOT_AUTO_KEYWORDS = False
- ROBOT_LIBRARY_DOC_FORMAT = 'REST'
- ROBOT_LIBRARY_SCOPE = 'GLOBAL'
- add_button(label: str, function: Callable | str, *args, location: VerticalLocation = VerticalLocation.Left, **kwargs) None
Create a button and execute the function as a callback when pressed.
- Parameters:
label – Text for the button
function – Python function or Robot Keyword name, that will get
*args
and**kwargs
passed into it
Example:
*** Keywords *** First View Add Heading Here is the first view of the app Add Button Change View Second View Second View Add Heading Let's build an infinite loop Add Button Change View First View
def first_view(): assistant = Assistant() assistant.add_heading("Here is the first view of the app") assistant.add_button("Change view", second_view) assistant.run_dialog() def second_view(): assistant = Assistant() assistant.add_heading("Let's build an infinite loop") assistant.add_button("Change view", first_view) assistant.run_dialog()
- add_checkbox(name: str, label: str, default: bool = False) None
Add a checkbox element
- Parameters:
name – Name of result field
label – Label text for checkbox
default – Default checked state
Adds a checkbox that indicates a true or false value. The selection will be available in the
name
field of the result, and thelabel
text will be shown next to the checkbox.The boolean
default
value will define the initial checked state of the element.Example:
*** Keywords *** Select checkboxes Add heading Enable features Add checkbox name=vault label=Enable vault default=True Add checkbox name=triggers label=Enable triggers default=False Add checkbox name=assistants label=Enable assistants default=True ${result}= Run dialog IF $result.vault Enable vault END
def select_checkboxes(): assistant = Assistant() assistant.add_heading("Enable features") assistant.add_checkbox(name="vault", label="Enable vault", default=True) assistant.add_checkbox(name="triggers", label="Enable triggers", default=False) assistant.add_checkbox(name="assistants", label="Enable assistants", default=True) result = assistant.run_dialog() if(result.vault): enable_vault()
- add_date_input(name: str, default: date | str | None = None, label: str | None = None) None
Add a date input element.
- Parameters:
name – Name of the result field
default – The default set date
label – Label for the date input field
Displays a date input. The selection the user makes will be available as a
date
object in thename
field of the result. Thedefault
argument can be a pre-set date as object or string in “YYYY-MM-DD” format, otherwise the current date is used.Example:
*** Keywords *** Select birthdate Add heading Enter your birthdate Add Date Input birthdate default=1993-04-26 ${result} = Run dialog Log To Console User birthdate year should be: ${result.birthdate.year}
def select_birthdate(): assistant = Assistant() assistant.add_heading("Enter your birthdate") assistant.add_date_input("birthdate", default="1993-04-26") result = assistant.run_dialog() print("User birthdate year should be: ", result.birthdate.year)
- add_drop_down(name: str, options: List[str] | str, default: str | None = None, label: str | None = None) None
Add a drop-down element
- Parameters:
name – Name of result field
options – List of drop-down options
default – The default selection
label – Label for input field
Creates a drop-down menu with the given
options
. The selection the user makes will be available in thename
field of the result.The
default
argument can be one of the defined options, and the dialog automatically selects that option for the input.A custom
label
text can also be added.Example:
*** Keywords *** Select user type from drop down Add heading Select user type Add drop-down ... name=user_type ... options=Admin,Maintainer,Operator ... default=Operator ... label=User type ${result}= Run dialog Log User type should be: ${result.user_type}
def select_user_type_from_drop_down(): assistant = Assistant() assistant.add_heading("Select user type") assistant.add_drop_down( name="user_type", options="Admin,Maintainer,Operator", default="Operator", label="User type" ) result = assistant.run_dialog() print("User type should be: ", result.user_type)
- add_file(path: str, label: str | None = None) None
Add a file element, which links to a local file
- Parameters:
path – The path to the file
label – A custom label text for the file
Adds a button which opens a local file with the corresponding default application. Can be used for instance to display generated files from the robot to the end-user.
Optionally a custom
label
can be given for the button text. By default uses the filename of the linked file.Example:
*** Keywords *** Open file button ${path}= Generate order files Add heading Current orders Add file ${path} label=Current Run dialog
def open_file_button(): path = generate_order_files() assistant = Assistant() assistant.add_heading("Current orders") assistant.add_file(path, label="Current") assistant.run_dialog()
- add_file_input(name: str, label: str | None = None, source: str | None = None, file_type: str | None = None, multiple: bool = False) None
Add a file input element
- Parameters:
name – Name of result field
label – Label for input field
source – Default source directory
file_type – Accepted file types
multiple – Allow selecting multiple files
Adds a native file selection dialog for inputting one or more files. The list of selected files will be available in the
name
field of the result.By default opens up in the user’s home directory, but it can be set to a custom path with the
source
argument.The argument
file_type
restricts the possible file extensions that the user can select. The format of the argument is as follows:pdf,png,svg
. For instance, an argument to limit options to Excel files could be:xls,xlsx
.To allow selecting more than one file, the
multiple
argument can be enabled.Example:
*** Keywords *** Multiple file selections # This can be any one file Add file input name=anything # This can be multiple files Add file input name=multiple multiple=True # This opens the select dialog to a custom folder Add file input name=src source=C:\Temp\Output\ # This restricts files to certain types Add file input name=types file_type=pdf # Every file input result is a list of paths ${result}= Run dialog FOR ${path} IN @{result.multiple} Log Selected file: ${path} END
def multiple_file_selections(): assistant = Assistant() # This can be any one file assistant.add_file_input(name="anything") # This can be multiple files assistant.add_file_input(name="multiple", multiple=True) # This opens the select dialog to a custom folder assistant.add_file_input(name="src", source="C:\Temp\Output") # This restricts files to certain types assistant.add_file_input(name="types", file_type="pdf") # Every file input result is a list of paths result = assistant.run_dialog() for path in result.multiple: print("Selected file: ", path)
- add_files(pattern: str) None
Add multiple file elements according to the given file pattern
- Parameters:
pattern – File matching pattern
See the keyword
Add file
for information about the inserted element itself.The keyword uses Unix-style glob patterns for finding matching files, and the supported pattern expressions are as follow:
Pattern
Meaning
*
Match everything
?
Match any single character
[seq]
Match any character in seq
[!seq]
Match any character not in seq
**
Match all files, directories, and subdirectories
If a filename has any of these special characters, they can be escaped by wrapping them with square brackets.
Example:
*** Keywords *** Open multiple files buttons # Add all excel files Add files *.xlsx # Add all log files in any subdirectory Add files **/*.log # Add all PDFs between order0 and order9 Add files order[0-9].pdf
def open_multiple_files_buttons(): assistant = Assistant() # Add all excel files assistant.add_file("*.xlsx") # Add all log files in any subdirectory assistant.add_file("**/*.log") # Add all PDFs between order0 and order9 assistant.add_file("order[0-9].pdf") assistant.run_dialog()
- add_flet_icon(icon: str, color: str | None = None, size: int | None = 24)
Add an icon from a large gallery of icons.
- Parameters:
icon – Corresponding flet icon name. Check https://gallery.flet.dev/icons-browser/ for a list of icons. Write the name in
lower_case
color – Color for the icon. Default depends on icon. Allowed values are colors from https://github.com/flet-dev/flet/blob/035b00104f782498d084c2fd7ee96132a542ab7f/sdk/python/packages/flet-core/src/flet_core/colors.py#L37 or ARGB/RGB (#FFXXYYZZ or #XXYYZZ).
size – Integer size for the icon.
Example:
*** Keywords *** Add custom icon Add Heading Check icon Add Flet Icon icon_name=check_circle_rounded color=FF00FF size=48 Run Dialog
def add_custom_icon() assistant = Assistant() assistant.add_heading("Check icon") assistant.add_flet_icon(icon="check_circle_rounded", color="FF00FF", size="48") assistant.run_dialog()
- add_heading(heading: str, size: Size = Size.Medium) None
Add a centered heading text element
- Parameters:
heading – The text content for the heading
size – The size of the heading
Supported
size
values are Small, Medium, and Large. By default uses the value Medium.Example:
*** Keywords *** Add dialog heading Add heading User information size=Large Add heading Location size=Small Add text input address label=User address Run dialog
def add_dialog_heading(): assistant = Assistant() assistant.add_heading("User information", size="large") assistant.add_heading("Location", size="small") assistant.add_text_input("address", label="User address") assistant.run_dialog()
Add a hidden input element
- Parameters:
name – Name of result feild
value – Value for input
Adds a special hidden result field that is not visible to the user and always contains the given static value.
Can be used to keep user input together with already known values such as user IDs, or to ensure that dialogs with differing elements all have the same fields in results.
Example:
*** Keywords *** Get user information Add hidden input user_id ${USER_ID} Add text input username ${result}= Run dialog Enter user information ${result.user_id} ${result.username}
def get_user_information(): assistant = Assistant() user_id = "Your user value" assistant.add_hidden_input("user_id", user_id) assistant.add_text_input("username") result = assistant.run_dialog() enter_user_information(result.user_id, result.username)
- add_icon(variant: Icon, size: int = 48) None
Add an icon element from RPA.Assistant’s short icon list.
- Parameters:
variant – The icon type
size – The size of the icon
Adds an icon which can be used to indicate status or the type of dialog being presented.
The currently supported icon types are:
Name
Description
Success
A green check mark
Warning
An orange warning triangle
Failure
A red cross or X mark
The
size
of the icon can also be changed, to a given height/width of pixels.Example:
*** Keywords *** Confirmation dialog Add icon Warning size=64 Add heading Do you want to delete this order? Add submit buttons buttons=No,Yes ${result}= Run dialog
def confirmation_dialog(): assistant = Assistant() assistant.add_icon("warning", size="64") assistant.add_heading("Do you want to delete this order?") assistant.add_submit_buttons(buttons="No, Yes") result = assistant.run_dialog()
- add_image(url_or_path: str, width: int | None = None, height: int | None = None) None
Add an image element, from a local file or remote URL
- Parameters:
url_or_path – The location of the image
width – The static width of the image, in pixels
height – The static height of the image, in pixels
Adds an inline image to the dialog, which can either point to a local file path on the executing machine or to a remote URL. If it’s a local file path it has to be absolute path.
By default the image is resized to fit the width of the dialog window, but the width and/or height can be explicitly defined to a custom value. If only one of the dimensions is given, the other is automatically changed to maintain the correct aspect ratio.
Example:
*** Keywords *** Display image Add image C:\Users\me\company-logo.png Add heading To start, please press the Continue button size=Small Add submit buttons Continue Run dialog
- add_link(url: str, label: str | None = None) None
Add an external URL link element
- Parameters:
url – The URL for the link
label – A custom label text for the link
Adds a clickable link element, which opens the user’s default browser to the given
url
. Optionally alabel
can be given which is shown as the link text, instead of the raw URL.Example:
*** Keywords *** Display troubleshoot link Add heading An error occurred Add text See link for documentation Add link https://robocorp.com/docs label=Troubleshooting Run dialog
def add_troubleshoot_link(): assistant = Assistant() assistant.add_heading("An error occurred") assistant.add_text("See link for documentation") assistant.add_link("https://robocorp.com/docs", label="Troubleshooting") assistant.run_dialog()
- add_loading_bar(name: str, width: int = 16, bar_height: int = 16, color: str | None = None, tooltip: str | None = None, value: float | None = None)
Add a loading bar.
- Parameters:
name – Name of the element
width – Width of the bar
bar_height – Height of the bar
color – Color of the bar’s stroke. Allowed values are colors from [https://github.com/flet-dev/flet/blob/035b00104f782498d084c2fd7ee96132a542ab7f/sdk/python/packages/flet-core/src/flet_core/colors.py#L37|Flet Documentation] (in the format
black12
,red500
) or ARGB/RGB (#FFXXYYZZ or #XXYYZZ).XXYYZZtooltip – Tooltip to be displayed on mouse hover.
value – Between 0.0 and 1.0 if you want to manually control it’s completion. Use None for indeterminate progress indicator.
- add_loading_spinner(name: str, width: int = 16, height: int = 16, stroke_width: int = 2, color: str | None = None, tooltip: str | None = None, value: float | None = None)
Add a loading spinner.
- Parameters:
name – Name of the element
width – Width of the spinner
height – Height of the spinner
stroke_width – Width of the spinner’s stroke
color – Color of the spinner’s stroke. Allowed values are colors from [https://github.com/flet-dev/flet/blob/035b00104f782498d084c2fd7ee96132a542ab7f/sdk/python/packages/flet-core/src/flet_core/colors.py#L37|Flet Documentation] (in the format
black12
,red500
) or ARGB/RGB (#FFXXYYZZ or #XXYYZZ).XXYYZZtooltip – Tooltip to be displayed on mouse hover.
value – Between 0.0 and 1.0 if you want to manually control it’s completion. If None it will spin endlessy.
- add_next_ui_button(label: str, function: Callable | str)
Create a button that leads to the next UI page, calling the passed keyword or function, and passing current form results as first positional argument to it.
- Parameters:
label – Text for the button
function – Python function or Robot Keyword name, that will take form results as its first argument
Example:
*** Keywords *** Retrieve User Data # Retrieves advanced data that needs to be displayed Main Form Add Heading Username input Add Text Input name=username_1 placeholder=username Add Next Ui Button Show customer details Customer Details Customer Details [Arguments] ${form} ${user_data}= Retrieve User Data ${form}[username_1] Add Heading Retrieved Data Add Text ${user_data}[phone_number] Add Text ${user_data}[address]
def main_form(): assistant = Assistant() assistant.add_heading("Username input") assistant.add_text_input("username_1", placeholder="username") assistant.add_next_ui_button("Show customer details", customer_details) assistant.run_dialog() def customer_details(form): assistant = Assistant() user_data = retrieve_user_data(form.username_1) assistant.add_heading("Retrieved Data") assistant.add_text(user_data[phone_number]) assistant.add_text(user_data[address]) assistant.run_dialog()
- add_password_input(name: str, label: str | None = None, placeholder: str | None = None) None
Add a password input element
- Parameters:
name – Name of result field
label – Label for field
placeholder – Placeholder text in input field
Adds a text field that hides the user’s input. The entered content will be available in the
name
field of the result.For customizing the look of the input, the
label
text can be given to add a descriptive label and theplacholder
text can be given to act as an example of the input value.Example:
*** Keywords *** Change password Add heading Change password Add text input username label=Current username Add password input password label=New password Add submit buttons buttons=Submit ${result}= Run dialog Change user password ${result.username} ${result.password}
def change_password(): assistant = Assistant() assistant.add_heading("Change password") assistant.add_text_input("username", label="Current username") assistant.add_password_input("password", label="New password") assistant.add_submit_buttons(buttons="Submit") result = assistant.run_dialog() change_user_password(result.username, result.password)
- add_radio_buttons(name: str, options: List[str] | str, default: str | None = None, label: str | None = None) None
Add radio button elements
- Parameters:
name – Name of result field
options – List of drop-down options
default – The default selection
label – Label for input field
Creates a set of radio buttons with the given
options
. The selection the user makes will be available in thename
field of the result.The
default
argument can be one of the defined options, and the dialog automatically selects that option for the input.A custom
label
text can also be added.Example:
*** Keywords *** Select user type from radio buttons Add heading Select user type Add radio buttons ... name=user_type ... options=Admin,Maintainer,Operator ... default=Operator ... label=User type ${result}= Run dialog Log User type should be: ${result.user_type}
def select_user_type_from_radio_buttons(): assistant = Assistant() assistant.add_heading("Select user type") assistant.add_radio_buttons( name="user_type", options="Admin,Maintainer,Operator", default="Operator", label="User type" ) result = assistant.run_dialog() print("User type should be: ", result.user_type)
- add_slider(name: str, slider_min: int | float = 0, slider_max: int | float = 100, thumb_text='{value}', steps: int | None = None, default: int | float | None = None, decimals: int | None = 1)
Add a slider input.
- Parameters:
name – Name of result field
slider_min – Minimum value of the slider
slider_max – Maximum value of the slider
thumb_label – Text to display when the slider is being slided. Use the placeholder {value} for the number. (thumb text {value%} will display values: 0%, 100%)
steps – Amount of steps for the slider. If None, the slider will be continuous. For integer output, specify a steps value where all the steps will be integers, or implement rounding when retrieving the result.
default – Default value for the slider. Must be between min and max.
decimals – How many decimals should the value have and show.
*** Keywords *** Create Percentage Slider Add Text Percentage slider Add Slider name=percentage slider_min=0 slider_max=100 thumb_text={value}% steps=100 round=1
def create_percentage_slider(): assistant = Assistant() assistant.add_text("Percentage slider") assistant.add_slider( name="percentage", slider_min=0, slider_max=100, thumb_text="{value}%", steps=100, decimals=1 ) assistant.run_dialog()
- add_submit_buttons(buttons: List[str] | str, default: str | None = None) None
Add custom submit buttons
- Parameters:
buttons – Submit button options
default – The primary button
The result field will always be called
submit
and will contain the pressed button text as a value.If one of the custom
options
should be the preferred option, thedefault
argument controls which one is highlighted with an accent color.Example:
*** Keywords *** Delete user warning Add icon Warning Add heading Delete user ${username}? Add submit buttons buttons=No,Yes default=Yes ${result}= Run dialog IF $result.submit == "Yes" Delete user ${username} END
def delete_user_warning(): assistant = Assistant() username = "user_01" assistant.add_icon("warning") assistant.add_heading(f"Delete user {username}?") assistant.add_submit_buttons(buttons="No, Yes", default="Yes") result = assistant.run_dialog() if result.submit == "Yes": delete_user(username)
- add_text(text: str, size: Size = Size.Medium) None
Add a text paragraph element, for larger bodies of text
- Parameters:
text – The text content for the paragraph
size – The size of the text
Supported
size
values are Small, Medium, and Large. By default uses the value Medium.Example:
*** Keywords *** Show error dialog Add heading An error occurred Add text There was an error while requesting user information Add text ${error} size=Small Run dialog
def show_error_dialog(): error = "Your error message" assistant = Assistant() assistant.add_heading("An error occurred") assistant.add_text("There was an error while requesting user information") assistant.add_text(f"{error}", size="small") assistant.run_dialog()
- add_text_input(name: str, label: str | None = None, placeholder: str | None = None, validation: Callable | str | None = None, default: str | None = None, required: bool = False, minimum_rows: int | None = None, maximum_rows: int | None = None) None
Add a text input element
- Parameters:
name – Name of result field
label – Label for field
placeholder – Placeholder text in input field
validation – Validation function for the input field
default – Default value if the field wasn’t completed
required – If true, will display an error if not completed
minimum_rows – Minimum number of rows to display for the input field
maximum_rows – Maximum number of rows to display for the input field, the input content can be longer but a scrollbar will appear
Adds a text field that can be filled by the user. The entered content will be available in the
name
field of the result.For customizing the look of the input, the
label
text can be given to add a descriptive label and theplacholder
text can be given to act as an example of the input value.The default value will be assigned to the input field if the user doesn’t complete it. If provided, the placeholder won’t be shown. This is None by default. Also, if a default value is provided and the user deletes it, None will be the corresponding value in the results dictionary.
Example:
*** Keywords *** Send feedback Add heading Send feedback Add text input email label=E-mail address Add text input message ... label=Feedback ... placeholder=Enter feedback here ${result}= Run dialog Send feedback message ${result.email} ${result.message}
Validation example:
*** Keywords *** Validate Email [Arguments] ${email} # E-mail specification is complicated, this matches that the e-mail has # at least one character before and after the @ sign, and at least one # character after the dot. ${regex}= Set Variable ^.+@.+\..+ ${valid}= Run Keyword And Return Status Should Match Regexp ${email} ${regex} IF not $valid RETURN Invalid email address END Open Dialog Add heading Send feedback Add text input email ... label=Email ... validation=Validate Email ${result}= Run dialog Log ${result.email}
import re def validate_email(email): # E-mail specification is complicated, this matches that the e-mail has # at least one character before and after the @ sign, and at least one # character after the dot. regex = r"^.+@.+\..+" valid = re.match(regex, email) if not valid: return "Invalid email address" def open_dialog(): assistant.add_heading("Send feedback") assistant.add_text_input("email", label="Email", validation=validate_email) result = run_dialog() print(result.email)
- ask_user(timeout: int = 180, **options: Any) Dict[str, Any]
Same as
Run Dialog
it will create a dialog from all the defined elements and block until the user has handled it. It will also add by default a submit and close buttons.- Parameters:
timeout – Time to wait for dialog to complete, in seconds
options – Options for the dialog
Returns a result object with all input values.
For more information about possible options for opening the dialog, see the documentation for the keyword
Run Dialog
.Example:
*** Keywords *** Ask user dialog Add heading Please enter your username Add text input name=username ${result}= Ask User Log The username is: ${result.username}
def ask_user_dialog(): assistant = Assistant() assistant.add_heading("Please enter your username") assistant.add_text_input("username") result = assistant.ask_user() print("The username is: ", result.username)
- clear_dialog() None
Clear dialog and results while it is running.
- close_column()
Closes previously opened Column.
Raises LayoutError if called with no Column open, or if another layout element was opened more recently than a Column.
- close_container()
Close previously opened container.
Raises LayoutError if called with no Row open, or if another layout element was opened more recently than a row.
Close previously opened navbar.
Raises LayoutError if called with no Row open, or if another layout element was opened more recently than a row.
- close_row()
Close previously opened row.
Raises LayoutError if called with no Row open, or if another layout element was opened more recently than a row.
- close_stack()
Close previously opened Stack.
Raises LayoutError if called with no Stack open, or if another layout element was opened more recently than a Stack.
- open_column()
Open a Column layout container. Following
Add <element>
calls will add items into that Column untilClose Column
is called.*** Keywords *** Double Column Layout Open Row Open Column Add Text First item in the first column Add Text Second item on the first column Close Column Open Column Add Text First item on the second column Close Column Close Row
def double_column_layout(): assistant = Assistant() assistant.open_row() assistant.open_column() assistant.add_text("First item in the first column") assistant.add_text("Second item on the first column") assistant.close_column() assistant.open_column() assistant.add_text("First item on the second column") assistant.close_column() assistant.close_row() assistant.run_dialog()
- open_container(margin: int | None = 5, padding: int | None = None, width: int | None = None, height: int | None = None, background_color: str | None = None, location: Location | Tuple[int, int] | None = None)
Open a single element container. The following
Add <element>
calls adds an element inside the container. Can be used for styling elements.- Parameters:
margin – How much margin to add around the container. RPA.Assistant adds by default a container of margin 5 around all elements, to have a smaller margin use containers with smaller margin value for elements.
padding – How much padding to add around the content of the container.
width – Width of the container.
height – Height of the container.
bgcolor – Background color for the container. Default depends on icon. Allowed values are colors from [https://github.com/flet-dev/flet/blob/035b00104f782498d084c2fd7ee96132a542ab7f/sdk/python/packages/flet-core/src/flet_core/colors.py#L37|Flet Documentation] (in the format
black12
,red500
) or ARGB/RGB (#FFXXYYZZ or #XXYYZZ).XXYYZZlocation –
Where to place the container (A Location value or tuple of ints). Only works inside a Stack layout element.
To use any Center___ or ___Center locations you must define width and height to the element.
*** Keywords *** Padded Element With Background Open Container padding=20 background_color=blue500 Add Text sample text Close Container
def padded_element_with_background(): assistant = Assistant() assistant.open_container(padding=20, background_color="blue500") assistant.add_text("Sample text") assistant.close_container() assistant.run_dialog()
Create a Navigation Bar. Following
Add <element>
calls will add items into the Navbar untilClose Navbar
is called.Navbar doesn’t clear when Clear Dialog is called.
Only one Navbar can be initialized at a time. Trying to make a second one will raise a LayoutError.
*** Keywords *** Go To Start Menu Add Heading Start menu Add Text Start menu content Assistant Navbar Open Navbar title=Assistant Add Button menu Go To Start Menu Close Navbar
def go_to_start_menu(): assistant = Assistant() assistant.add_heading("Start menu") assistant.add_text("Start menu content") assistant.run_dialog() def assistant_navbar(): assistant = Assistant() assistant.open_navbar(title="Assistant") assistant.add_button("menu", go_to_start_menu) assistant.close_navbar() assistant.run_dialog()
- open_row()
Open a row layout container. Following
Add <element>
calls will add items into that row untilClose Row
is called.*** Keywords *** Side By Side Elements Open Row Add Text First item on the row Add Text Second item on the row Close Row
def side_by_side_elements(): assistant = Assistant() assistant.open_row() assistant.add_text("First item on the row") assistant.add_text("Second item on the row") assistant.close_row() assistant.run_dialog()
- open_stack(width: int | None = None, height: int | None = None)
Create a “Stack” layout element. Stack can be used to position elements absolutely and to have overlapping elements in your layout. Use Container’s top and left arguments to position the elements in a stack.
*** Keywords *** Absolutely Positioned Elements # Positioning containers with relative location values requires # absolute size for the Stack Open Stack height=360 width=360 Open Container width=64 height=64 location=Center Add Text center Close Container Open Container width=64 height=64 location=TopRight Add Text top right Close Container Open Container width=64 height=64 location=BottomRight Add Text bottom right Close Container Close Stack
def absolutely_positioned_elements(): # Positioning containers with relative location values requires # absolute size for the Stack assistant = Assistant() assistant.open_stack(height=360, width=360) assistant.open_container(width=64, height=64, location=Center) assistant.add_text("center") assistant.close_container() assistant.open_container(width=64, height=64, location=TopRight) assistant.add_text("top right") assistant.close_container() assistant.open_container(width=64, height=64, location=BottomRight) assistant.add_text("bottom right") assistant.close_container() assistant.close_stack() assistant.run_dialog()
- refresh_dialog()
Can be used to update UI elements when adding elements while dialog is running
- run_dialog(timeout: int = 180, title: str = 'Assistant', height: int | typing_extensions.Literal[AUTO] = 'AUTO', width: int = 480, on_top: bool = False, location: WindowLocation | Tuple[int, int] | None = None) Dict[str, Any]
Create a dialog from all the defined elements and block until the user has handled it.
- Parameters:
timeout – Time to wait for dialog to complete, in seconds
title – Title of dialog
height – Height of dialog (in pixels or ‘AUTO’)
width – Width of dialog (in pixels)
on_top – Show dialog always on top of other windows
location – Where to place the dialog (options are Center, TopLeft, or a tuple of ints)
If the location argument is None it will let the operating system place the window.
Returns a result object with all input values.
When the dialog closes elements are cleared.
Example:
*** Keywords *** Open dialog Add heading Please enter your username Add text input name=username ${result}= Run dialog Log The username is: ${result.username}
def open_dialog(): assistant = Assistant() assistant.add_heading("Please enter your username") assistant.add_text_input("username") result = assistant.run_dialog() print("The username is: ", result.username)
- set_title(title: str)
Set dialog title when it is running.