-
Notifications
You must be signed in to change notification settings - Fork 14.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Migrate trigger form params to new UI #45270
base: main
Are you sure you want to change the base?
Migrate trigger form params to new UI #45270
Conversation
51d3c4d
to
83c450e
Compare
Thanks @jscheffl for working on this. As mentioned in TODO, we will support the accordion and not flat. Some points which i noticed, just writing it down incase we don't miss.
Overall this is going in right direction. Should we have inbuilt scroll for the dynamic form? since the modal seems very long. EDIT: Just saw a todo for point 6 (json code view) and most of the above issues as todo. |
e7381e7
to
8067918
Compare
(1) I recommend to make into a separate PR - as also discussed 1:1 So... for the Layout part I'd say... ready for review! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @jscheffl ! Overall it looks good. Just few comments.
When clicking on trigger run, the modal pops up with all the options at front.
Should we consider them in a accordion and if needed user can view?
Apart from it, had some general comments, which is similar for all files.
airflow/ui/src/components/FlexibleForm/FlexibleFormFieldAdvancedArray.tsx
Outdated
Show resolved
Hide resolved
airflow/ui/src/components/FlexibleForm/FlexibleFormFieldBool.tsx
Outdated
Show resolved
Hide resolved
airflow/ui/src/components/FlexibleForm/FlexibleFormFieldDate.tsx
Outdated
Show resolved
Hide resolved
8067918
to
313d868
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Found one glitch, which can be taken in further work.
Also, few things to add in list of TODO:
- Reset button should reset everything on the Form, including the flexible form, and it should ask a validation pop up, since if by mistake user press it, it's lot to loose.
- Accordion should be there for flexible form fields.
- And of course connection between conf and flexible form.
airflow/ui/src/components/FlexibleForm/FlexibleFormFieldString.tsx
Outdated
Show resolved
Hide resolved
height="200px" | ||
id={`element_${name}`} | ||
style={{ | ||
border: "1px solid #CBD5E0", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's best if we avoid hard coded hex colors.
Instead we can access the chaklra color themes like so:
useToken("colors", [
"red.100",
"red.800",
"red.500",
"red.400",
]);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Adjusted via chakra variable - is this also OK?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
6b61cf4
to
fcbe5d0
Compare
…o separate TSX file
fcbe5d0
to
de1a47c
Compare
Had a few "sleeps" over the discussion I had in Slack with @shubhamraj-git about Accordion.. and after Pierre also assigned it to the Note for Clear tasks... I am somewhat open and ajusted... as forms can get long. All is not (last commit) in one accordion group. Looks like this and parts are nicely folding: Changing to Advanced options: WDYT? |
After @shubhamraj-git has added the trigger form to the new React UI, this PR now adds the flexible trigger form - Based on the logic of the former AIP-50 implementation - using DAG ParamsDict to render form fields based on field definitions.
Note that the form rendering was made as a component by intent as it will be re-used in Connection Forms in future to render connection extra fields.
To test the form rendering the following DAGs might be good candidates:
example_bash_decorator
- has no params so should not display a specific formexample_bash_operator
- has one basic parameter w/o any special thing. Simple as it can beexample_params_trigger_ui
- has 4 parameters, still basic... and with advanced section un-folded:
example_params_ui_tutorial
- this is the most complex beast as it has all features as a demo that shall be supported....and the lower section un-folded:
Scope of the PR is the UI layout and logic to render. What is missing and will be a follow-up PR is the binding and sync of the form field content with the JSON dict that is used to trigger the DAG in the "Advanced Options" section.