Create a way to accept recipe input when applying one with Project Browser

Created on 25 November 2024, 4 months ago

Problem/Motivation

Project Browser can apply recipes but it has no way to collect input on behalf of recipes that require it. Let's create a very rough way to collect input.

The designs call for a slick modal to collect input, but that's gonna be complicated and possibly require underlying API changes. Tricky.

For now, then, let's do something a little less ambitious: if you apply a recipe in Project Browser, and that recipe has inputs, the activator should redirect you to a form where you can enter those inputs, at which point the recipe is applied in a batch job and redirects you back to Project Browser.

✨ Feature request
Status

Active

Version

2.0

Component

User experience

Created by

πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @phenaproxima
  • Merge request !628Proof of concept β†’ (Merged) created by phenaproxima
  • Pipeline finished with Failed
    4 months ago
    Total: 369s
    #349558
  • πŸ‡¦πŸ‡ΊAustralia pameeela
  • πŸ‡ΊπŸ‡ΈUnited States tim.plunkett Philadelphia
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    Synced with 2.0.x and addressed your feedback!

  • Pipeline finished with Failed
    4 months ago
    Total: 5420s
    #370046
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    Self-assigning for tests, and to figure out the test failures.

  • Pipeline finished with Canceled
    4 months ago
    Total: 195s
    #371600
  • Pipeline finished with Failed
    4 months ago
    Total: 228s
    #371603
  • Pipeline finished with Failed
    4 months ago
    Total: 221s
    #371605
  • Pipeline finished with Failed
    4 months ago
    Total: 251s
    #371612
  • Pipeline finished with Failed
    4 months ago
    Total: 221s
    #371614
  • Pipeline finished with Failed
    4 months ago
    Total: 427s
    #371627
  • Pipeline finished with Failed
    4 months ago
    Total: 1749s
    #371671
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    Wrote a test for this, no problem.

  • Pipeline finished with Failed
    4 months ago
    Total: 365s
    #371704
  • Pipeline finished with Failed
    4 months ago
    Total: 473s
    #371954
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    Ready for review. The test failures are also present in HEAD; see #3494672-8: Allow sources to expose a local task β†’ .

  • Pipeline finished with Failed
    4 months ago
    Total: 662s
    #372588
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts
  • Pipeline finished with Failed
    4 months ago
    #372604
  • Pipeline finished with Failed
    4 months ago
    Total: 364s
    #372756
  • πŸ‡ΊπŸ‡ΈUnited States tim.plunkett Philadelphia

    Great work, thanks!

  • Pipeline finished with Failed
    4 months ago
    Total: 457s
    #372785
  • Pipeline finished with Failed
    4 months ago
    Total: 383s
    #372809
  • πŸ‡ΊπŸ‡ΈUnited States chrisfromredfin Portland, Maine

    Manually tested.

    There was an issue on 11.0.4(?) that Adam already fixed, regarding missing property $input.

    I think bumped my Drupal version to 11.1.0 and tested with the default website contact feedback form recipe, which worked great - prompting me for an email address, applying steps using a batch API progress meter, and dropped me right back where I expected.

    I think tried with drupal/drupal_cms_analytics recipe, but I never got to the screen where I needed to enter my analytics ID. Instead I got to this URL https://pb11.ddev.site/admin/modules/browse/recipe-input?recipe=/var/www... with an error:

    The website encountered an unexpected error. Try again later.
    
    Symfony\Component\Validator\Exception\ValidationFailedException: Object(Drupal\Core\TypedData\Plugin\DataType\StringData): This value should not be blank. (code c1051bb4-d103-4f74-8988-acbcafc7fdc3) in Drupal\Core\Recipe\InputConfigurator->collectAll() (line 162 of core/lib/Drupal/Core/Recipe/InputConfigurator.php).
    Drupal\project_browser\Form\RecipeForm->buildRecipeInputForm() (Line: 41)
    ...yadda yadda yadda...
    
  • πŸ‡ΊπŸ‡ΈUnited States chrisfromredfin Portland, Maine

    Additional info, I tried to adjust the recipe.yml to something valid, and though I now get the prompt for my tag ID, it fails after submitting that with:

    The website encountered an unexpected error. Try again later.
    
    LogicException: Input values cannot be changed once they have been set. in Drupal\Core\Recipe\InputConfigurator->collectAll() (line 141 of core/lib/Drupal/Core/Recipe/InputConfigurator.php).
    Drupal\Core\Recipe\InputConfigurator->collectAll() (Line: 139)
    Drupal\project_browser\Form\RecipeForm->setRecipeInput() (Line: 112)
    Drupal\project_browser\Form\RecipeForm->validateRecipeInput() (Line: 58)
    Drupal\project_browser\Form\RecipeForm->validateForm()
    ...
    

    Though these may be issues in the recipe(s), I wonder if we should handle them in a slightly better way.

  • Pipeline finished with Failed
    4 months ago
    Total: 415s
    #374980
  • Pipeline finished with Failed
    4 months ago
    Total: 399s
    #374985
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    The exception in #12, it turns out, is due to a core bug: πŸ› Recipes that depend on other recipes break RecipeInputFormTrait Active

    The good news is, we can work around it.

  • Pipeline finished with Failed
    4 months ago
    Total: 609s
    #375051
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    This now has strong test coverage, against the drupal_cms_analytics recipe itself (which is now a dev dependency).

    I think it's ready for review.

  • Pipeline finished with Canceled
    4 months ago
    Total: 269s
    #375144
  • Pipeline finished with Failed
    4 months ago
    Total: 357s
    #375150
  • πŸ‡ΊπŸ‡ΈUnited States chrisfromredfin Portland, Maine

    Checked on 11.0 and got an error relative to the Analytics recipe, which is expected! So, good there anyway,

    Went to 11.1 and got all the way through the input, and then the application, then looks like we missed new requirements from the other issue (project_browser.browse now requires a source param).

  • Pipeline finished with Failed
    4 months ago
    Total: 361s
    #375163
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts
  • Pipeline finished with Failed
    4 months ago
    Total: 449s
    #375186
  • Pipeline finished with Failed
    4 months ago
    Total: 223s
    #375199
  • Pipeline finished with Failed
    4 months ago
    Total: 356s
    #375203
  • Pipeline finished with Failed
    4 months ago
    Total: 346s
    #375239
  • Pipeline finished with Failed
    4 months ago
    Total: 349s
    #375265
  • Pipeline finished with Failed
    4 months ago
    Total: 386s
    #375266
  • Pipeline finished with Failed
    4 months ago
    Total: 350s
    #375272
  • Pipeline finished with Canceled
    4 months ago
    Total: 202s
    #375275
  • Pipeline finished with Failed
    4 months ago
    Total: 402s
    #375278
  • Pipeline finished with Failed
    4 months ago
    Total: 348s
    #375282
  • Pipeline finished with Skipped
    4 months ago
    #375295
  • πŸ‡ΊπŸ‡ΈUnited States chrisfromredfin Portland, Maine

    Tests broken already, fixing in related issue. Manually tested and reviewed.

    This is a great step in the direction of introducing user interaction during Activation of a project. Love it! And it makes recipes SO powerful.

  • Automatically closed - issue fixed for 2 weeks with no activity.

  • Pipeline finished with Failed
    about 2 months ago
    Total: 1069s
    #417492
  • Pipeline finished with Failed
    about 2 months ago
    Total: 498s
    #417501
  • Pipeline finished with Success
    about 2 months ago
    Total: 1110s
    #417502
  • Pipeline finished with Canceled
    about 2 months ago
    Total: 451s
    #422142
  • Pipeline finished with Failed
    about 2 months ago
    Total: 1193s
    #422154
  • Pipeline finished with Canceled
    about 2 months ago
    Total: 1110s
    #422204
  • Pipeline finished with Failed
    about 2 months ago
    Total: 1188s
    #422233
  • Pipeline finished with Failed
    about 2 months ago
    Total: 1331s
    #422265
  • Pipeline finished with Failed
    about 2 months ago
    Total: 1245s
    #422331
  • Pipeline finished with Failed
    about 2 months ago
    Total: 1344s
    #422369
  • Pipeline finished with Failed
    about 2 months ago
    Total: 443s
    #423041
  • Pipeline finished with Failed
    about 2 months ago
    Total: 572s
    #423042
  • Pipeline finished with Failed
    about 2 months ago
    Total: 1287s
    #423052
  • Pipeline finished with Failed
    about 2 months ago
    Total: 1344s
    #423072
Production build 0.71.5 2024