Custom WTForm fields. This is where all the UI Components Fields and their base classes are located.
class bluecat.wtform_fields.AliasRecord
(*args, **kwargs)
Bases: bluecat.wtform_fields.validating_string_field.ValidatingStringField
StringField for inputting Alias Records with client side validation and auto-checks that it is available.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
result_decorator | Function to manipulate result set instead of a server-side call. |
kwargs | Other keyword arguments for WTForms Fields. |
class bluecat.wtform_fields.Configuration
(*args, **kwargs)
Bases: bluecat.wtform_fields.custom_select_field.CustomSelectField
SelectField that is auto-populated with configuration data.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
kwargs | Other keyword arguments for WTForms Fields. |
widget = <bluecat.ui_components.wtform_widgets.SuperSelect object>
class bluecat.wtform_fields.CustomBooleanField
(*args, **kwargs)
Bases: wtforms.fields.core.BooleanField
, bluecat.wtform_fields.extended_field.ExtendedField
Custom boolean/checkbox class that extends WTForms to generate html and JavaScript checkbox code.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
on_checked | JavaScript functions to call when checkbox is checked. |
on_unchecked | JavaScript functions to call when checkbox is unchecked. |
kwargs | Other keyword arguments for ExtendedField and WTForms Field. |
generate_call_function_js()
Generate JavaScript for call function.
Returns: JavaScript for call function.
generate_checkbox_javascript()
Generates JavaScript to handle the checking/un-checking and populating of the checkbox.
Returns: JavaScript code to handle changes to checkbox.
generate_event_listener_js()
Generate JavaScript to call side_effect function on change.
Returns: JavaScript to call side effect function on change.
generate_populate_function_js()
Generate JavaScript for populate function.
Returns: JavaScript for populate function.
widget = <bluecat.ui_components.wtform_widgets.SuperCheckboxInput object>
class bluecat.wtform_fields.CustomButtonField
(*args, **kwargs)
Bases: wtforms.fields.core.BooleanField
, bluecat.wtform_fields.extended_field.ExtendedField
A simple button object with no extra JavaScript.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
kwargs | Other keyword arguments for WTForms Fields. |
widget = <bluecat.ui_components.wtform_widgets.SuperInput object>
class bluecat.wtform_fields.CustomPasswordField
(*args, **kwargs)
Bases: bluecat.wtform_fields.custom_string_field.CustomStringField
, bluecat.wtform_fields.extended_field.ExtendedField
Password field which will fetch the value of another field as put it as it’s own when the call_{id} function is called.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
inputs | Determines where to fetch the data from or what to pass to a server call. If no server_side_method is defined, then inputs must contain the id of itself mapping it to the field where to get the data from. |
server_side_method | Server-side call to retrieve data. |
widget = <bluecat.ui_components.wtform_widgets.SuperPasswordInput object>
class bluecat.wtform_fields.CustomSearchButtonField
(*args, **kwargs)
Bases: bluecat.wtform_fields.custom_button_field.CustomButtonField
Button implementing a remote query from input data of a single field.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
clear_below_on_change | Whether to clear all fields below it when the user selects a different option. |
message_field | Deprecated. Use display_message from ExtendedField instead. |
generate_call_function_js()
Generate JavaScript for call function.
Returns: JavaScript for call function.
generate_clear_below_js()
Add disable all below code.
Returns: JavaScript for CustomSearchButtonField.
generate_event_listener_js()
Generate JavaScript to call side_effect function on change.
Returns: JavaScript to call side effect function on change.
generate_populate_function_js()
Generate JavaScript for populate function. Generate empty populate function in case another js function tries to call the searchButtons populate function.
Returns: JavaScript for populate function.
generate_side_effect_function_js()
Generate JavaScript for side effect function.
Returns: JavaScript for side_effect function.
class bluecat.wtform_fields.CustomSelectField
(*args, **kwargs)
Bases: wtforms.fields.core.SelectField
, bluecat.wtform_fields.extended_field.ExtendedField
SelectField that is auto-populated with configuration data.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
choices_function | Python function for retrieving the choices used to populate the select field. |
default_not_selected | The default value for the SelectField when nothing is selected. |
clear_below_on_change | Whether to clear all fields below it when the user selects a different option. |
kwargs | Other keyword arguments for WTForms Fields. |
generate_call_function_js()
Generate JavaScript for call function.
Returns: JavaScript for call function.
generate_clear_below_js()
Add disable all below code.
Returns: JavaScript
generate_event_listener_js()
Generate JavaScript to call side_effect function on change.
Returns: JavaScript to call side effect function on change.
generate_populate_function_js()
Generate JavaScript for populate function.
Returns: JavaScript for populate function.
generate_side_effect_function_js()
Generate JavaScript for side effect function.
Returns: JavaScript for side_effect function.
widget = <bluecat.ui_components.wtform_widgets.SuperSelect object>
class bluecat.wtform_fields.CustomStringField
(*args, **kwargs)
Bases: wtforms.fields.core.StringField
, bluecat.wtform_fields.extended_field.ExtendedField
String field which will fetch the value of another field as put it as it’s own when the call_{id} function is called.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
inputs | Determines where to fetch the data from or what to pass to a server call. If no server_side_method is defined, then inputs must contain the id of itself mapping it to the field where to get the data from. |
server_side_method | Server-side call to retrieve data. |
generate_call_function_js()
Generate the call function
Returns: JavaScript for call function.
generate_populate_function_js()
Generate JavaScript for populate function.
Returns: JavaScript for populate function.
widget = <bluecat.ui_components.wtform_widgets.SuperTextInput object>
class bluecat.wtform_fields.CustomSubmitField
(*args, **kwargs)
Bases: wtforms.fields.simple.SubmitField
, bluecat.wtform_fields.extended_field.ExtendedField
Field to render submit button
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
kwargs | Other keyword arguments for WTForms Fields. |
generate_call_function_js()
Generate JavaScript for call function.
Returns: JavaScript for call function.
generate_populate_function_js()
Generate JavaScript for populate function.
Returns: JavaScript for populate function.
widget = <bluecat.ui_components.wtform_widgets.SuperSubmit object>
class bluecat.wtform_fields.ExtendedField
(*args, **kwargs)
Bases: wtforms.fields.core.Field
Base class for UI Component Fields that adds extra functionality.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
inputs | Specific inputs to the server_side_method. Should be a dictionary of key and element id pairs. |
enable_on_complete | Fields to enable once user is done with a field and should then move on to other fields. |
on_complete | JavaScript functions to call once the user is done with a field and should move on to other fields. |
on_change | JavaScript functions to call when the user changes the value of a field. |
on_validate | JavaScript functions to call when the user on validation of field. |
on_click | JavaScript functions to call when the user on click of field. |
classes | Extra HTML classes to append to the element. |
required | Whether the field must be filled in or not. If True, users must put something in the field in order to submit the form. |
is_disabled_on_error | Whether the field should be disabled if the form is reloaded when an error occurs. Default: False. |
is_disabled_on_start | Whether the field should be disabled if the form is first loaded. Default: True. Note: when using GatewayForm, all fields are disabled on start by default. This parameter should be True for at least one field to get the started. |
server_outputs | Mapping of returned data properties to which field they should go to. |
server_side_method | The server-side endpoint method the field uses to get the data it displays. |
result_decorator | Function to manipulate result set instead of a server-side call. |
server_side_output_method | The server-side endpoint method the field uses to populate other fields. Must be used in conjunction with server_outputs. |
output_result_decorator | Function to manipulate result set instead of an output server-side call. |
workflow_name | Name of the workflow the element is used in. |
permissions | Which workflow permissions the server_side_method should have. |
readonly | If True, the field will only be readable but not interactive. False by default. |
enable_dependencies | List of dependents from which the enable_disable_dependents_generator function generates a JavaScript function to enable those dependents. |
disable_dependencies | List of dependents from which the disable_dependents_generator function generates a JavaScript function to disable those dependents. The JavaScript function can then be triggered by being called in on_change, on_validate, or on_complete. |
should_cascade_disable_on_change | |
clear_dependencies | Which workflow permissions the server_side_method should have. |
should_cascade_clear_on_change | |
display_message | Flag on whether to display server endpoint messages. |
kwargs | Other keyword arguments for WTForms Fields. |
clear_component_message()
Create JS to clear a message for a ui component.
Returns: JS code
clear_dependents_generator(dependents, trigger)
Generates JavaScript function for clearing a field’s dependent fields.
Parameters | Description |
---|---|
dependents | List of ids of the field’s dependents. |
trigger | Type of event needed to occur on the field to trigger the function. For example, on_change, on_complete. |
Returns: JavaScript function code as Python string.
clear_self_and_dependants_generator(has_dependents=False, trigger='on_change', cascade=False)
Generates JavaScript function for clearing a field and calling the generated function for clearing its dependent fields.
Parameters | Description |
---|---|
has_dependents | Whether the field has dependents to be cleared along with it. |
trigger | Type of event needed to occur on the field to trigger the function. For example, on_change, on_complete. |
cascade | Whether the field’s dependents should be cleared along with it. Will clear dependents if True. |
Returns: JavaScript function code as Python string.
enable_disable_dependents_generator(dependents, trigger, should_disable=True)
Generates JavaScript function for enabling or disabling a field’s dependent fields.
Parameters | Description |
---|---|
dependents | List of ids of the field’s dependents. |
trigger | Type of event needed to occur on the field to trigger the function. For example, on_change, on_complete. |
should_disable | Whether the dependents should be enabled or disabled. |
Returns: JavaScript function code as Python string.
enable_disable_self_and_dependants_generator(has_dependents=False, trigger='on_change', should_disable=True, cascade=False)
Generates JavaScript function for enabling or disabling a field and calling the generated function for disabling its dependent fields.
Parameters | Description |
---|---|
has_dependents | Whether the field has dependents to be disabled along with it. |
trigger | Type of event needed to occur on the field to trigger the function. For example, on_change, on_complete. |
should_disable | Whether the dependents should be enabled or disabled. |
cascade | Whether the field’s dependents should be disabled along with it. Disables dependents if True. |
Returns: JavaScript function code as Python string.
fill_in_missing_triggers(trigger_dict)
Check the trigger_dict to see if it is missing any of the triggers defined for the class.
Parameters | Description |
---|---|
trigger_dict | A dictionary containing the triggers to be checked. |
Returns: The given trigger_dict with missing triggers added as keys in the dictionary with an empty list as the value.
generate_call_function_js()
Generate JavaScript for call function.
Returns: JavaScript for call function.
generate_common_clear_code()
Generator used to generate field clearing code, should be used by child classes that inherit it to generate complete JavaScript for fields.
Returns: Generated JavaScript for the field.
generate_common_disable_code()
Generator used to generate field disabling code, should be used by child classes that inherit it to generate complete JavaScript for fields.
Returns: Generated JavaScript for the field.
generate_common_display_message_code()
Generator used to generate display message code, should be used by child classes that inherit it to generate complete JavaScript for fields.
Returns: Generated JavaScript for the field.
generate_common_enable_code()
Generator used to generate field enabling code, should be used by child classes that inherit it to generate complete JavaScript for fields.
Returns: Generated JavaScript for the field.
generate_common_server_output_code()
Generator used to generate server output code, should be used by child classes that inherit it to generate complete JavaScript for fields.
Returns: Generated JavaScript for the field.
generate_event_listener_js()
Generate JavaScript to listen and execute code on events.
Returns: JavaScript for event listening.
generate_populate_function_js()
Generate JavaScript for populate function.
Returns: JavaScript for populate function.
javascript_generator()
Generates default JavaScript standard for every field.
Returns: Generated JavaScript for the field.
populate_component_message()
Create JS to populate a message for a ui component.
Returns: JS code
populate_fields_generator(outputs, trigger='on_complete')
Function for populating multiple fields from a mapping of given data to fields.
Parameters | Description |
---|---|
outputs | Mapping of data properties to which field they should go to. |
trigger | Type of event needed to occur on the field to trigger the function. For example, on_change, on_complete. |
Returns: JavaScript function output_<element_id> that handles the populating of multiple fields.
post_call_generator(output_functions=None)
Generates JavaScript function that makes a one-off POST call to an endpoint generated from the workflow_name and element_io with the given inputs. On successfully callback, will call a function with name “populate_<element_id>” with the returned results.
Parameters | Description |
---|---|
output_functions | List of functions to call with data returned from POST call. |
Returns: JavaScript function code as Python string.
server_output_javascript(outputs=None, trigger='on_complete')
JavaScript function for a specific field that can be called to populate an arbitrary number of other fields based on server output from the specified endpoint.
Parameters | Description |
---|---|
outputs | Mapping of returned data properties to which field they should go to. |
trigger | The trigger for when the function should be called. |
Returns: JavaScript function code as Python string.
triggers = ['on_change', 'on_validate', 'on_complete', 'on_checked', 'on_unchecked']
class bluecat.wtform_fields.FilteredSelectField
(*args, **kwargs)
Bases: bluecat.wtform_fields.filtered_select_field.NoPreValidationSelectField
, bluecat.wtform_fields.extended_field.ExtendedField
FilteredSelectField a select field with an attached filter field that can provide hints by which to filter the results in the search field by. Provides functionality for pass-through fields as well
Parameters | Description |
---|---|
filter_field | The field from which to get the hint string to use as a filter in the select list |
message_field | Deprecated. Use display_message from ExtendedField instead. |
clear_fields | The fields to clear when a new filter hint is typed |
label | HTML label for the generated field. |
kwargs | Other keyword arguments for WTForms Fields. |
generate_call_function_js()
Generate JavaScript for call function.
Returns: JavaScript for call function
generate_event_listener_js()
Generate JavaScript to call other js functions on change event.
Returns: JavaScript to call functions on change event.
generate_filter_field_js()
Generate JavaScript to filter the field.
Returns: JavaScript for filtering the field.
generate_populate_function_js()
Generate JavaScript for populate function.
Returns: JavaScript for populate function
widget = <bluecat.ui_components.wtform_widgets.SuperSelect object>
class bluecat.wtform_fields.HostRecord
(*args, **kwargs)
Bases: bluecat.wtform_fields.validating_string_field.ValidatingStringField
StringField for inputting the host records
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
result_decorator | Function to manipulate result set instead of a server-side call. |
kwargs | Other keyword arguments for WTForms Fields. |
class bluecat.wtform_fields.IP4Address
(*args, **kwargs)
Bases: bluecat.wtform_fields.validating_string_field.ValidatingStringField
StringField for inputting IPv4 addresses with client-side validation and auto-checks that it is available.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
result_decorator | Function to manipulate result set instead of a server-side call. |
kwargs | Other keyword arguments for WTForms Fields. |
class bluecat.wtform_fields.NoPreValidationSelectField
(*args, **kwargs)
Bases: wtforms.fields.core.SelectField
SelectField with no pre-validation of field value against possible choices. Useful if choices are dynamically populated.
pre_validate(form)
Pre-validate method being overwritten to no longer perform validation.
Parameters | Description |
---|---|
form | The form the field belongs to. |
class bluecat.wtform_fields.PlainHTML
(*args, **kwargs)
Bases: wtforms.fields.core.Field
Field to render plain HTML
Parameters | Description |
---|---|
text | HTML text. |
kwargs | Other keyword arguments for WTForms Fields. |
widget = <bluecat.ui_components.wtform_widgets.HTMLWidget object>
class bluecat.wtform_fields.SimpleAutocompleteField
(*args, **kwargs)
Bases: wtforms.fields.core.StringField
, bluecat.wtform_fields.extended_field.ExtendedField
Generic auto-complete enabled Field.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
one_off | Whether the data from the server_side_method is only retrieved once or every time the input changes. |
source | A static list from which auto-complete should filter and display based on user input. Used instead of server_side_method. |
clear_below_on_change | Whether to clear all fields below it when the user selects a different option. |
kwargs | Other keyword arguments for WTForms Fields. |
generate_call_function_js()
Override default JS for call function
Returns: JavaScript function snippet.
generate_clear_below_js()
Add disable all below code.
Returns: JavaScript for CustomSearchButtonField.
generate_populate_function_js()
Override default JS for populate function
Returns: JavaScript function snippet.
widget = <bluecat.ui_components.wtform_widgets.SuperTextInput object>
class bluecat.wtform_fields.TableField
(*args, **kwargs)
Bases: bluecat.wtform_fields.extended_field.ExtendedField
Field to render Table data
Parameters | Description |
---|---|
label | HTML label for the generated field. |
data_function | Function to pre-populate the table with data |
table_features | Dictionary containing feature terms to enable in the table, more info: https://datatables.net/reference/option/ |
buttons | A list containing the names of buttons to enable. Default: [‘export’] Valid elements: ‘import’, ‘export’ |
server_side_method | The server-side endpoint method the field uses to get the data it displays. |
inputs | Specific inputs to the server_side_method. Should be a dictionary of key and element id pairs. |
workflow_name | Name of the workflow the element is used in. |
permissions | Which workflow permissions the server_side_method should have. |
generate_call_function_js()
Generate JavaScript for call function.
Returns: JavaScript for call function.
generate_common_clear_code()
Override the default clear code generation with Table specific logic
Returns: JavaScript for common clear JS code.
generate_default_features()
Generate default DataTable features.
Returns: Javascript code for the default DataTable features.
generate_global_scope_js()
Generate the JavaScript code for the component, to be placed in the global scope.
Returns: JavaScript code for the global scope.
Return type: str
generate_parse_data_function_js()
Parse data JS function
Returns: JavaScript for parse data function.
generate_populate_function_js()
Generate JavaScript for populate function.
Returns: JavaScript for populate function.
widget = <bluecat.ui_components.wtform_widgets.SuperTableWidget object>
class bluecat.wtform_fields.ValidatingStringField
(*args, **kwargs)
Bases: wtforms.fields.core.StringField
, bluecat.wtform_fields.extended_field.ExtendedField
StringField with server side validation that can be attached to it, will show green when validated and red when not.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
client_side_validator | JavaScript function name to call when validating field. |
classes | Extra HTML classes to append to the element. |
kwargs | Other keyword arguments for WTForms Fields. |
generate_call_function_js()
Override default JS for call function
Returns: JavaScript function snippet.
generate_clear_below_js()
Add disable all below code.
Returns: JavaScript for clear below JS.
generate_client_and_server_validator()
Adds client and server side validation to a field. Listener for the field must be added separately and should call “populate_<element_id>” when it wants to validate the input.
Returns: JavaScript function code as Python string.
generate_populate_function_js()
Override default JS for populate function
Returns: JavaScript function snippet.
generate_user_input_delay()
Generates generic JavaScript function for adding delay on input.
Returns: The generated JavaScript for adding delay on input.
widget = <bluecat.ui_components.wtform_widgets.SuperTextInput object>
class bluecat.wtform_fields.View
(*args, **kwargs)
Bases: bluecat.wtform_fields.simple_autocomplete_field.SimpleAutocompleteField
Autocomplete enabled field for View entities.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
kwargs | Other keyword arguments for WTForms Fields. |
class bluecat.wtform_fields.Zone
(*args, **kwargs)
Bases: bluecat.wtform_fields.simple_autocomplete_field.SimpleAutocompleteField
Autocomplete enabled field for Zone entities.
Parameters | Description |
---|---|
label | HTML label for the generated field. |
validators | WTForm validators for the field run on the server side. |
kwargs | Other keyword arguments for WTForms Fields. |