Account created on 8 February 2016, almost 9 years ago
#

Merge Requests

More

Recent comments

🇺🇸United States kurttrowbridge

Nice—I hadn't even finished writing my comment yet to mark it ready for review, haha. Thanks!

🇺🇸United States kurttrowbridge

I didn't test the merge request on a fresh install, so not going to mark this RTBC myself, but just thought I'd note that I got tripped up by this issue after having enabled the module on a Drupal 10 site, and the config change suggested in the MR and comment #4 got us back to the workflow we were expecting, so what's in the MR makes sense to me. Thanks!

🇺🇸United States kurttrowbridge

I noticed the same issue, and the MR properly addressed it for me. Thanks! Marking RTBC.

🇺🇸United States kurttrowbridge

I've been using MR 15, but it's no longer applying to the newest dev version of the module. It looks like there are conflicts in src/Entity/Flagging.php and src/FlagService.php. Will report back if I'm able to get it taken care of myself.

🇺🇸United States kurttrowbridge

I was facing this issue too after having migrated in a set of Texts entities from a CSV I had prepared.

First, I should note that I was confused that TextsListBuilder seemingly isn't used for the /admin/content/texts route—I think it might not be in use at all. (You can make it work for that page by adding a route that points to it, but its contents are different from what's in that table now, so I didn't want to change it.)

I found that TranslationFormBase.php is what controls the contents of that page instead, and that had a single sort criterion based on the time of the entity's last update, sorted in descending order. In my case, that timestamp was the same for all of the entities I'd imported, so they continually got resorted.

I added another sort criterion so that after it sorts by changed time, it sorts by the entity's ID. That's available in the merge request I've provided.

Thanks!

🇺🇸United States kurttrowbridge

I did go back and work from the original patch to create a new one, and I think I now have a working solution that's ready for review; see the provided merge request. This should address the use case of a Media entity that contains multiple File fields (mine are a PDF and a DOCX, just like the case described in the original issue; both of mine are also single-value fields).

I'll attach a screenshot of my entity edit form as well, in which there's a "Replace file: ___" field for each file field, correctly identifying the field name and its allowed extensions.

I did a fair bit of testing with updating one or both files, with and without overwriting the file name, along with the creation of new Media entities, and didn't run into any issues. I would definitely appreciate additional reviews, though, especially given that I leaned on AI more than I typically do. Hopefully this will help for others as well.

Thanks!

🇺🇸United States kurttrowbridge

I got confused by this too, and Megan's comment in #5 is what finally cleared it up for me after first reviewing both the module's description and the README in the code. After following her instructions, I went into both the README and the help text on the settings form to make the steps clearer.

It also wasn't immediately clear to me that I had to enter the Google Analytics property ID before uploading the service account's credential JSON file; I worked through the form top-to-bottom and kept getting errors because I was uploading the JSON file without having put in the property ID. To alleviate the potential for that tripping people up in the future, I swapped the order of the two fields, so you're more likely to have entered the property ID before attempting to upload your credentials.

Both changes are available in the merge request that's now on this issue. Reviews and other thoughts welcome. Thanks!

🇺🇸United States kurttrowbridge

(After thinking on it over the weekend, I decided the checkbox I introduced to customize the email when a default was set was overly complex—I removed it, so the Email field just has a default value if the submission has a value for the selected field, and is empty otherwise.)

re: #7, no, I don't think so—third-party settings are a Drupal core feature and (despite this being my first time having used them myself) have been around since D8. Nothing else in my MR requires any specific Webform functionality.

🇺🇸United States kurttrowbridge

Hello again—I created a merge request with a couple additions based on this issue (so I'm also switching it to a feature request and modifying the title):

  1. The Email field on the reply form now has support for tokens, so you can enter the token for an email field as the value.
  2. If a Webform has at least one Email field, it now has a third-party setting (see /admin/structure/webform/manage/{webform}/settings) where you can specify the default recipient field for replies sent for that form's submissions.
  3. If a default field is set, the Email field is disabled and automatically filled in with the default field's value, but the reply form has a new checkbox so that it be customized beyond the default. (As I write this up now, I'm starting to wonder if that's overkill; maybe the default value just gets filled in, but the field remains enabled for further editing, and there's no checkbox at all. Open to feedback on that.)

I did what I think was a decent amount of testing—sending replies to both a hardcoded email address and a token, confirming nothing breaks when the Webform has no email fields, confirming nothing breaks when the submission didn't use the default field—but would appreciate additional reviews or feedback. Thanks!

🇺🇸United States kurttrowbridge

I noticed this too, and I confirmed that with the patch applied, that's no longer happening. Marking as RTBC—thanks!

🇺🇸United States kurttrowbridge

I've been looking into this one because I'm having issues with a use case very similar to what's described in the original issue: a Media entity with two single-value File fields, one allowing PDFs and one allowing DOC/DOCX files.

Not sure if I'm just confused, but #9 doesn't seem to be addressing the use case of a Media entity with multiple File fields (not necessarily one or more multivalue fields), and seems more like it's addressing multivalue fields. #1 did seem to do so, so unless I'm missing anything on #9, my next attempt will be to fix the patch in #1 to work with the latest version of the module.

🇺🇸United States kurttrowbridge

I work with JI_Gravityworks and have seen it working on the site where she needed it, but I also needed this for a second site and have confirmed that it's working there as well. Marking as RTBC. Thank you!

🇺🇸United States kurttrowbridge

MR #20 appears to be working here. Thanks! Marking RTBC.

🇺🇸United States kurttrowbridge

That's true for the From: value (who's sending the email), but I think the original request was about the To: value (who's receiving it)—and I actually just came looking for that this week as well. Ideally, I would think you'd be able to either enter a token that would fill in the value from the Webform submission, or you'd get to choose on a per-form basis which Email field from the form gets used.

🇺🇸United States kurttrowbridge

I think this is related to this issue and its patch, but apologies if it's unrelated. I added this patch because I was having issues with a field that has multiple visibility conditions (e.g. Field 2 is visible if the answer to Field 1 was Option A or Option B). With the patch installed, that results in an error on line 64 ($trigger = key($triggerValue);) because of the or condition: the $triggers array that is looped through includes a non-array value, or, between the actual visibility conditions, so there's no array key to assign to the $trigger variable. I've attached a screenshot of what the $triggers variable contains. Not sure if it's as straightforward as confirming that $triggerValue is an array before continuing—I may try it and report back—or if that would cause an issue with the or condition not taking effect.

(Possibly of note: I have the patch installed atop version 2.0.10, not 2.0.x-dev, since the dev version is behind it and doesn't support version 6 of Webform.)

🇺🇸United States kurttrowbridge

Making the suggestion to start with a single category, Content Editing Experience. Whenever I've used Entityqueue, it's been aimed at improving content editors' capabilities to feature or list content. Site Structure might also be worth considering, but I'll start with just the one.

🇺🇸United States kurttrowbridge

Updating to a single category: Security.

🇺🇸United States kurttrowbridge

Proposing just one category for this one: Security. Thought about Access Control since reCAPTCHA's often used on login forms, but it's a stretch, so keeping the fewer-is-better recommendation in mind.

🇺🇸United States kurttrowbridge

We also ran into this problem, just as described in #16 (whenever a click event is triggered; you don't even have to click on interactive elements, though things like forms and accordions that require user interaction are naturally where it's most obvious), while running alpha3. Downgrading to alpha2 fixed the issue.

Based on the suggestion in #15, I provided an MR that tracks whether or not the menu is open, and adjusted the JavaScript in two problematic places so closeMenu() is only called if the menu isn't currently open. (I also snuck in a minor typo fix.) This appears to be working for us, but additional reviews/suggestions are much appreciated. Thanks!

If credited, please also credit my coworker joshcavindergmailcom , who helped me troubleshoot.

🇺🇸United States kurttrowbridge

As mentioned in #4, header and footer text still don't appear if there are no results, despite a header and/or footer set to display even when there aren't any. I updated the MR to include that as well.

🇺🇸United States kurttrowbridge

Addressed most of the feedback in the MR, hopefully correctly—the only one I think I left outstanding was the question about catching exceptions. Leaving marked as Needs work, and I'll see if JI_Gravityworks and I can touch base on that last one tomorrow (we work together).

🇺🇸United States kurttrowbridge

This got in my way more this week, so I tried to figure out how to fix it. :)

I figured out that when the instagram_lite_media config value gets serialized before it's stored, null characters were being included in the output, and YAML won't parse that cleanly. By doing a preg_replace() that removes those, the config value is cleaned up, and the visual output of the Instagram feed on the page appears to be unaffected.

In addition to the provided merge request, I've attached a screenshot of the diff in my site's config after this patch has been applied, showing the removal of the null characters and the otherwise unaltered data (I guess it also turns from a multiline string to a single line...which is possibly fine? I don't display captions, but I do see line breaks in multiline captions get removed, which I could see being a problem for someone else).

This gets outside my typical wheelhouse a bit, so any additional reviews would be much appreciated. Thanks!

🇺🇸United States kurttrowbridge

MR created with that plus a couple other small fixes (added missing punctuation at the ends of two sentences, and changed "grass roots" to "grassroots"). Thanks!

🇺🇸United States kurttrowbridge

Hi! I followed the instructions in #7 while also excluding this module from the standard Drupal repository (see snippet below), and that installed the dependencies successfully and fixed the errors. Marking RTBC. Thanks!

    "repositories": [
        {
            "type": "composer",
            "url": "https://packages.drupal.org/8",
            "exclude": [
                "drupal/opigno_scorm"
            ]
        },
        ...
        {
            "type": "vcs",
            "url": "git@git.drupal.org:issue/opigno_scorm-3281986.git"
        }
    ],
🇺🇸United States kurttrowbridge

Also confirmed that the supplied MR resolved the issue for my site using PHP 8.2 and the dev version of the module. Thank you!

🇺🇸United States kurttrowbridge

One more confirmation that the patch in #9 is working on a site with Drupal 10.2, PHP 8.2, and the dev version of this module. Going to mark this as RTBC. Thanks!

🇺🇸United States kurttrowbridge

Hello! I tested this, first confirming that I saw the PHPCS errors mentioned when the patch was not yet applied. After applying the MR as a patch, the PHPCS errors are no longer present. Marking RTBC as a result.

(That said, I should note that line 60 in the .theme file—the comment starting with "Calculate the minimum and maximum"—warns me, both before and after, that it's lengthier than the 80-character limit in Drupal's standards. Not sure why it doesn't appear in your testing, so I didn't flip back to Needs Work in case it's just something I'm doing differently on my end.)

🇺🇸United States kurttrowbridge

I've been poking at this a little bit tonight, and I think it's an issue specific to the way the Claro theme (and probably others based on it, like Gin) handles focus indicators—the typical green outline visible when focusing on an element in Claro is actually a box-shadow, and the outline is transparent (I think because of something having to do with Windows High Contrast Mode). I'm not positive why the box-shadow doesn't show up, but assume it has something to do with the <a> element being within an <svg> element.

If I switch to another admin theme (I switched to Umami; it's meant to be a front-end theme, but still illustrated what I needed), I do see focus indicators when tabbing through the diagram elements.

Anyway, a possible solution could be to target .mermaid svg a:focus and apply an outline-color there. I wonder if that might be more suitable in the Mermaid Diagram Field module, so feel free to move this there if you'd like and I can provide a new MR, but I'll include one that adds the outline-color with a value of var(--color-focus) for themes like Claro that provide that CSS variable, and a fallback to currentColor for those that don't.

🇺🇸United States kurttrowbridge

(Working on this at FLDC 2024.) There was one subfolder, tests/src/Functional/Update, that had a file that was missing the declare statement. I added it to the existing MR for this issue. Now marking Needs Review.

🇺🇸United States kurttrowbridge

KurtTrowbridge made their first commit to this issue’s fork.

🇺🇸United States kurttrowbridge

Just missing a preposition ("to retrieve information"), so slight tweak below:

Provides a file metadata manager service and API to allow developers to retrieve information stored in files, like EXIF photo information, TrueType font information, and others.

(Character count: 177)

🇺🇸United States kurttrowbridge

Very slight tweak, assuming "ex.g." was a typo—I like the latest suggestion otherwise:

Allows users to add additional filters (facets) to search results, to further refine search results by some criteria (e.g. Amazon's search interface).

Character count: 150

(Leaving as Needs Review since I changed it.)

🇺🇸United States kurttrowbridge

Hello! I'm looking at this during Florida DrupalCamp 2024, and freshly installed Project Browser with the MR applied. The placeholder text appears as expected, both in the visual output of the search field and in the DOM as a placeholder attribute. Screenshot attached of the visual output.

Going to mark this as RTBC. Thanks!

🇺🇸United States kurttrowbridge

I moved the suggested README contents in #2 into an actual file on a new branch, then cleaned it up based on the recommended format . MR is ready for review.

🇺🇸United States kurttrowbridge

(Working on this at FLDC 2024.) I'm not seeing the error when running PHPCS in the first place, so a review would definitely be appreciated, but the fix seems straightforward enough. PHPCS did not find any errors following my change either.

🇺🇸United States kurttrowbridge

KurtTrowbridge made their first commit to this issue’s fork.

🇺🇸United States kurttrowbridge

I know this module is obsolete now, and we'll be getting rid of it on the site on which I tested this once it's upgraded to Drupal 10, but for any other fellow stragglers on Drupal 9, the patch in #2 solves the issue.

🇺🇸United States kurttrowbridge

This also resolved issues with grouped proximity filters on a site of ours. Since others have said the same above, I'm going to mark this as RTBC. Thank you!

🇺🇸United States kurttrowbridge

KurtTrowbridge made their first commit to this issue’s fork.

🇺🇸United States kurttrowbridge

Thanks for catching that! That does appear to have done the trick, so marking as RTBC.

🇺🇸United States kurttrowbridge

That did the trick, thanks! Marking RTBC. Good to know about the upcoming core improvement too.

🇺🇸United States kurttrowbridge

Here's patch #20 again, this time with the PHP CodeSniffer issues resolved.

🇺🇸United States kurttrowbridge

Suggesting the following description:

Adds filters to the top of the Permissions list, reducing it to only include permissions related to the selected user roles and/or modules.

Character count: 139.

🇺🇸United States kurttrowbridge

Thanks for the quick reply! I had another chance to look further into this tonight, and unfortunately still don't have an answer. What I tried:

  • Switching the datalayer_page_bottom() hook to datalayer_page_top()
  • Uninstalling any other modules that implemented hook_page_bottom() (AMP, Mailchimp, Tour)
  • Removing my custom theme's html.html.twig template (even though it did have {{ page_bottom }} included)

I've included my datalayer.settings.yml contents below.

_core:
  default_config_hash: N67AkcKPlikWJbwxABv6MSMpGuXe36qWZfH88pEzeqc
add_page_meta: true
output_terms: true
output_fields: true
remove_from_admin_routes: false
lib_helper: false
entity_meta:
  created: '0'
  langcode: '0'
  name: '0'
  status: '0'
  uid: '0'
  uuid: '0'
  vid: '0'
enable_ia: false
ia_depth: 3
ia_category_primary: primaryCategory
ia_category_sub: subCategory
vocabs:
  tags: tags
  column: '0'
expose_user_details: ''
expose_user_details_roles:
  authenticated: '0'
  content_editor: '0'
  social_media_editor: '0'
  administrator: '0'
current_user_meta:
  name: '0'
  mail: '0'
  roles: '0'
  created: '0'
  access: '0'
group: false
expose_user_details_fields: false
entity_title: entityTitle
entity_type: entityType
entity_bundle: entityBundle
entity_identifier: entityId
group_label: groupLabel
drupal_language: drupalLanguage
drupal_country: drupalCountry
site_name: siteName
key_replacements:
  - ''

And it case it's relevant, the hook_datalayer_alter() implementation through which I handle multivalue fields and a couple custom additions:

/**
 * Implements hook_datalayer_alter().
 */
function bridge_utilities_datalayer_alter(&$data_layer) {
  // Modify data layer for Tags.
  if (isset($data_layer['entityTaxonomy']['tags'])) {
    $data_layer['articleTags'] = implode('|', $data_layer['entityTaxonomy']['tags']);
  }

  // Modify data layer for Authors.
  if (isset($data_layer['field_author'])) {
    $authors = $data_layer['field_author']['value'];
    $author_names = [];
    foreach ($authors as $author) {
      if (!empty($author['label'])) {
        $author_names[] = $author['label'];
      }
    }
    $data_layer['articleAuthors'] = implode('|', $author_names);
  }

  // Modify data layer for publish date.
  if (isset($data_layer['entityCreated'])) {
    $data_layer['articleDate'] = date('Y-m-d', $data_layer['entityCreated']);
  }

  // Modify data layer for donation confirmation order ID and revenue.
  if (\Drupal::request()->get('uid') !== NULL) {
    $data_layer['order_id'] = \Drupal::request()->get('uid');
  }
  if (\Drupal::request()->get('amount') !== NULL) {
    $data_layer['revenue'] = \Drupal::request()->get('amount');
  }
}

Thanks again!

🇺🇸United States kurttrowbridge

I added a new fork, 3392147-allowed-ips, with the patch provided in #5 plus some inclusive language changes. (Sorry if I didn't do that right—the amount that the existing MR had changed in unrelated files threw me off, so I was hesitant to try to build on top of it.) I also did a little bit of formatting cleanup, but that probably wasn't exhaustive.

One thing I'm confused by is that when I look at the allowlist, the IP addresses won't show up in the column (see attached screenshot)—something seems off with how the ID and Allowlisted IP properties are defined and saved, but I haven't yet figured out what. Additionally, it looks like the IP address is intended to be saved as the entity ID; this works for IPv4 addresses, but causes a fatal error ("Invalid character in Config object name") when allowing IPv6 addresses due to the colons (:) in the address.

🇺🇸United States kurttrowbridge

KurtTrowbridge made their first commit to this issue’s fork.

🇺🇸United States kurttrowbridge

I set up Mercury Editor and the Inline Editor submodule on a test site and confirmed I initially could not edit a text Paragraph inline. Then I patched it with MR #17, and confirmed that inline editing was possible again. Thanks!

🇺🇸United States kurttrowbridge

I've updated the merge request based on the provided feedback—should be ready for review again. Thanks!

🇺🇸United States kurttrowbridge

KurtTrowbridge made their first commit to this issue’s fork.

🇺🇸United States kurttrowbridge

Confirmed that MR #2 also works (alongside my earlier MR on 🐛 Entity queries must explicitly set whether the query should be access checked or not Needs review , which I previously forgot to mention I also have in place to explicitly set access checks on a few queries). Leaving as RTBC!

🇺🇸United States kurttrowbridge

The patch in #21 did not apply for me using Composer, I think because of the problem described in 🐛 Packaging info from .info.yml often creates conflicts when patching Active . Merge request #7, however, does successfully apply, so leaving this as RTBC. The only difference I see between the two is that drupal/image is not removed as a dependency in MR #7, but I think its removal was unintentional anyway based on the patches and comments in #16 and #19 here, so that seems fine to me.

🇺🇸United States kurttrowbridge

Hi! I ran into this today too on a site running Drupal 9.5.11. I was able to get the newly added handler to open its configuration form after making some adjustments, matching a couple other Webform handlers I referenced. After that, I hit some issues related to the Comparison Operator field due to how the title was formatted, so I provided an adjustment that moves the additional information for that field into a description. Lastly, I had an issue saving the configuration form because it tried to validate the comparison operator based on the value of $values['compare']['operator'], when the variable appears like it should be $values['operator']–only the left and right values are nested under $values['compare'].

Hopefully that all makes sense. I confirmed that the comparison was working for me following those adjustments, and confirmed that the file meets Drupal's code standards (one other adjustment needed for that was to put the use statements in alphabetical order). Everything I've mentioned is in the provided merge request, but I'd definitely appreciate a review—dependency injection is not my strong suit, and a couple of the fixes were a little unexpected to me.

Thanks!

🇺🇸United States kurttrowbridge

KurtTrowbridge made their first commit to this issue’s fork.

🇺🇸United States kurttrowbridge

First, I think this may be a duplicate of #3303510 📌 File metadata manager - Add a short description Needs review .

I like Chris's suggestion in #9 there, and just tweaked it slightly to add a missing preposition:

Provides a file metadata manager service and API to allow developers to retrieve information stored in files, like EXIF photo information, TrueType font information, and others.

🇺🇸United States kurttrowbridge

Went back and forth on a few ideas, but put this suggestion into the issue summary:

Provides a text input that allows users to type a keyboard shortcut and enter the name of a requested Drupal admin page. Offers page suggestions based on the entered keywords.

My primary thought is that we should avoid specifying the Alt+D keyboard shortcut in the description, because (as is detailed in the module's full description) that's not accurate in all cases (and, thinking about future-proofing it, perhaps unnecessarily, I know there are some feature requests in the module's issue queue that would allow sites to customize that shortcut). Character count on my suggestion is 175.

🇺🇸United States kurttrowbridge

I like and agree with Emma's feedback in #7. I tweaked that slightly based on the language I've seen used in other descriptions, and added that to the issue summary. Character count still looks good, now at 147.

🇺🇸United States kurttrowbridge

Agreed with the most recent edits. Character count is 134, so all good there. Marking as RTBC!

🇺🇸United States kurttrowbridge

This one looks good to me. Character count is 152. Marking as RTBC!

🇺🇸United States kurttrowbridge

Merge request provided and ready for review. Attaching a screenshot of the revised fieldset with the MR applied.

🇺🇸United States kurttrowbridge

KurtTrowbridge made their first commit to this issue’s fork.

🇺🇸United States kurttrowbridge

Screenshot attached, but the buttons look right again with the MR applied! Marking as RTBC, though I'm not sure if the automated test failure on the MR is a problem. (When I ran the code check script locally, ESLint didn't find any issues.)

🇺🇸United States kurttrowbridge

Tweaked slightly, mostly to capitalize Views, but also while thinking that "This module" and "Drupal" might be unnecessary to include; just a thought. I agree with the previous comments about including the relevant file extensions, and confirmed that the three included are the ones it supports by default (the module description includes more, but they're merely on the roadmap, per the code's README).

🇺🇸United States kurttrowbridge

I like what's proposed; I just tweaked it slightly because the use of "content types" gave me pause since that has its own unrelated meaning in Drupal. Character count is now 189.

Production build 0.71.5 2024