diff --git a/client/src/api/schema/schema.ts b/client/src/api/schema/schema.ts index f4f0ba6b4c94..7eb951308e92 100644 --- a/client/src/api/schema/schema.ts +++ b/client/src/api/schema/schema.ts @@ -11941,6 +11941,21 @@ export interface components { */ workflow_step_id: number; }; + /** InvocationFailureWorkflowParameterInvalidResponse */ + InvocationFailureWorkflowParameterInvalidResponse: { + /** + * Details + * @description Message raised by validator + */ + details: string; + /** + * @description discriminator enum property added by openapi-typescript + * @enum {string} + */ + reason: "workflow_parameter_invalid"; + /** Workflow parameter step that failed validation */ + workflow_step_id: number; + }; /** InvocationInput */ InvocationInput: { /** @@ -12022,7 +12037,8 @@ export interface components { | components["schemas"]["InvocationFailureExpressionEvaluationFailedResponse"] | components["schemas"]["InvocationFailureWhenNotBooleanResponse"] | components["schemas"]["InvocationUnexpectedFailureResponse"] - | components["schemas"]["InvocationEvaluationWarningWorkflowOutputNotFoundResponse"]; + | components["schemas"]["InvocationEvaluationWarningWorkflowOutputNotFoundResponse"] + | components["schemas"]["InvocationFailureWorkflowParameterInvalidResponse"]; /** InvocationOutput */ InvocationOutput: { /** diff --git a/client/src/components/Form/FormElement.vue b/client/src/components/Form/FormElement.vue index ed81622799e1..aa3507808661 100644 --- a/client/src/components/Form/FormElement.vue +++ b/client/src/components/Form/FormElement.vue @@ -27,6 +27,7 @@ import FormSelection from "./Elements/FormSelection.vue"; import FormTags from "./Elements/FormTags.vue"; import FormText from "./Elements/FormText.vue"; import FormUpload from "./Elements/FormUpload.vue"; +import FormElementHelpMarkdown from "./FormElementHelpMarkdown.vue"; interface FormElementProps { id?: string; @@ -35,6 +36,7 @@ interface FormElementProps { title?: string; refreshOnChange?: boolean; help?: string; + helpFormat?: string; error?: string; warning?: string; disabled?: boolean; @@ -63,6 +65,7 @@ const props = withDefaults(defineProps(), { connectedDisableText: "Add connection to module.", connectedEnableIcon: "fa fa-times", connectedDisableIcon: "fa fa-arrows-alt-h", + helpFormat: "html", workflowBuildingMode: false, }); @@ -337,7 +340,13 @@ function onAlert(value: string | undefined) {
{{ previewText }}
- + + diff --git a/client/src/components/Form/FormElementHelpMarkdown.vue b/client/src/components/Form/FormElementHelpMarkdown.vue new file mode 100644 index 000000000000..e6271c9a2124 --- /dev/null +++ b/client/src/components/Form/FormElementHelpMarkdown.vue @@ -0,0 +1,56 @@ + + + diff --git a/client/src/components/Form/FormInputs.vue b/client/src/components/Form/FormInputs.vue index 1421a4b79ea3..fafe1734b478 100644 --- a/client/src/components/Form/FormInputs.vue +++ b/client/src/components/Form/FormInputs.vue @@ -11,6 +11,7 @@ v-model="input.test_param.value" :type="input.test_param.type" :help="input.test_param.help" + :help-format="input.test_param.help_format" :refresh-on-change="false" :disabled="sustainConditionals" :attributes="input.test_param" @@ -51,6 +52,7 @@ :error="input.error" :warning="input.warning" :help="input.help" + :help-format="input.help_format" :refresh-on-change="input.refresh_on_change" :attributes="input.attributes || input" :collapsed-enable-text="collapsedEnableText" diff --git a/client/src/components/Help/HelpPopover.vue b/client/src/components/Help/HelpPopover.vue index 11ded1f423de..200f76706a2b 100644 --- a/client/src/components/Help/HelpPopover.vue +++ b/client/src/components/Help/HelpPopover.vue @@ -12,7 +12,7 @@ defineProps(); diff --git a/client/src/components/Help/terms.yml b/client/src/components/Help/terms.yml index 0ca9bd36bc72..536d08f3dee1 100644 --- a/client/src/components/Help/terms.yml +++ b/client/src/components/Help/terms.yml @@ -27,7 +27,12 @@ unix: debug what is wrong with the execution of an application. More information on stack traces can be found on [Wikipedia](https://en.wikipedia.org/wiki/Stack_trace). +programming: + python: + regex: | + Regular expressions are patterns used to match character combinations in strings. This input accepts Python-style regular expressions, find more information about these in [this Python for Biologists tutorial](https://pythonforbiologists.com/tutorial/regex.html). + The website [regex101](https://regex101.com/) is a useful playground to explore regular expressions (be sure to enable "Python" as your flavor) and language models such as ChatGPT can help interactively build up and explain regular expressions from natural language prompts or examples. galaxy: collections: flatList: | diff --git a/client/src/components/RuleBuilder/RegularExpressionInput.vue b/client/src/components/RuleBuilder/RegularExpressionInput.vue index 3f7c089adf80..b3788e423abe 100644 --- a/client/src/components/RuleBuilder/RegularExpressionInput.vue +++ b/client/src/components/RuleBuilder/RegularExpressionInput.vue @@ -1,7 +1,7 @@