Add view tab + standard template for block content

Created on 19 February 2023, almost 2 years ago
Updated 19 June 2024, 7 months ago

Problem/Motivation

https://www.drupal.org/project/block_content_template something like this

Steps to reproduce

NA

Proposed resolution

Add a new setting (similar to media) for allowing standalone URLs.
When enableda view tab to the block content entity will appear.

Add default template when using the view route of the block only As a preview of what the block will look like if that helps

Remaining tasks




code review

User interface changes

New tab to "View" block without being placed on a page

New view tab

View page

API changes

Block content now has a settings form with one setting for enabling standalone URLs.

Data model changes

NA

Release notes snippet

TBD

Feature request
Status

Needs work

Version

11.0 🔥

Component
Block content 

Last updated 7 days ago

Created by

🇺🇸United States smustgrave

Live updates comments and jobs are added and updated live.
  • Usability

    Makes Drupal easier to use. Preferred over UX, D7UX, etc.

Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • Issue created by @smustgrave
  • Open on Drupal.org →
    Environment: PHP 8.2 & MySQL 8
    last update over 1 year ago
    Not currently mergeable.
  • last update over 1 year ago
    29,405 pass, 16 fail
  • last update over 1 year ago
    29,406 pass, 15 fail
  • last update over 1 year ago
    Custom Commands Failed
  • 🇺🇸United States smustgrave

    So my current questions are

    1. Is this the correct way?
    2. Should we use that .bc route?
    3. Do we need a "view block content" permission? Was having a hard time thinking the use case.
    4. Is it okay I updated the previous .bc routes.

  • 21:42
    16:33
    Running
  • last update over 1 year ago
    29,442 pass, 5 fail
  • last update over 1 year ago
    29,450 pass
  • last update over 1 year ago
    29,498 pass, 2 fail
  • last update over 1 year ago
    29,499 pass
  • Status changed to Needs review over 1 year ago
  • Status changed to Needs work over 1 year ago
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Left some more feedback on the MR

  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10
  • last update over 1 year ago
    30,052 pass, 1 fail
  • 🇬🇧United Kingdom AndyF

    Thanks for the work on this... I could be misrepresenting, but I believe there were concerns raised with taking this approach in Ability to display block_content entities independently, also outside of Blocks Postponed: needs info however (eg. #2704331-19: Ability to display block_content entities independently, also outside of Blocks ). Do we have a response to that at all?

  • 🇺🇸United States smustgrave

    This template is only going to be picked up when using the view route of the block. As a preview of what the block will look like if that helps

  • last update over 1 year ago
    30,056 pass
  • Status changed to Needs review over 1 year ago
  • 🇺🇸United States smustgrave

    Addressed the feedback. Ready for another review

  • 🇬🇧United Kingdom AndyF

    This template is only going to be picked up when using the view route of the block. As a preview of what the block will look like if that helps

    Thanks for humoring me @smustgrave, that wasn't clear to me when looking at the IS and description of the linked module.

  • last update over 1 year ago
    30,164 pass
  • Status changed to Needs work over 1 year ago
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Just one minor thing and one question, left in the MR

  • Status changed to Needs review over 1 year ago
  • 🇺🇸United States smustgrave

    Addressed feedback

  • last update over 1 year ago
    30,143 pass, 12 fail
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
  • Status changed to Needs work over 1 year ago
  • 🇺🇸United States smustgrave

    Seems removing that render key caused some failures. Need to investigate why.

  • Status changed to Needs review over 1 year ago
  • 🇺🇸United States smustgrave

    Lets see if that works.

  • last update over 1 year ago
    30,168 pass
  • 🇺🇸United States smustgrave

    Fixed!

    @Wim Leers I added some screenshots those work?

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Ah … so it's not just a Twig template, it's also new routes and tabs! That wasn't clear at all to me based on the title + summary 😅

    Seems like #13 also contains pretty critical information that belongs in the issue summary. And perhaps also on the docblock in the Twig template itself? 🤔

  • 🇺🇸United States smustgrave

    Updated will update the template too!

  • last update over 1 year ago
    30,168 pass
  • 🇺🇸United States smustgrave

    Left a small in the template.

  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Left a comment on the MR

  • Status changed to Needs work over 1 year ago
  • The Needs Review Queue Bot tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".

    This does not mean that the patch needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide to find step-by-step guides for working with issues.

  • Status changed to Needs review over 1 year ago
  • 🇺🇸United States smustgrave

    Rebased

  • Open on Drupal.org →
    Environment: PHP 8.2 & MySQL 8
    last update over 1 year ago
    Waiting for branch to pass
  • last update over 1 year ago
    Custom Commands Failed
  • Pipeline finished with Canceled
    over 1 year ago
    Total: 78s
    #26386
  • Pipeline finished with Failed
    over 1 year ago
    Total: 173s
    #26387
  • Status changed to Needs work over 1 year ago
  • The Needs Review Queue Bot tested this issue. It fails the Drupal core commit checks. Therefore, this issue status is now "Needs work".

    This does not mean that the patch needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide to find step-by-step guides for working with issues.

  • Status changed to Needs review over 1 year ago
  • Status changed to Needs work over 1 year ago
  • The Needs Review Queue Bot tested this issue. It fails the Drupal core commit checks. Therefore, this issue status is now "Needs work".

    This does not mean that the patch needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide to find step-by-step guides for working with issues.

  • Open on Drupal.org →
    Environment: PHP 8.2 & MySQL 8
    last update over 1 year ago
    Waiting for branch to pass
  • Status changed to Needs review over 1 year ago
  • Pipeline finished with Failed
    over 1 year ago
    #26391
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Still keen to understand why we need to manually add the list cache tag

  • last update over 1 year ago
    Custom Commands Failed
  • Pipeline finished with Failed
    over 1 year ago
    Total: 248s
    #26809
  • last update over 1 year ago
    30,379 pass
  • Pipeline finished with Success
    over 1 year ago
    Total: 982s
    #26813
  • 🇺🇸United States smustgrave

    Odd so removing that line worked now. No clue but I'll take it.

  • Status changed to RTBC over 1 year ago
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    This looks good to me, thanks @smustgrave

  • 26:43
    22:53
    Running
  • Status changed to Postponed: needs info over 1 year ago
  • 🇫🇮Finland lauriii Finland

    What's the use case for the block content view tab? I understand editors may want to use it to preview the block but I'm not sure if the view tab is ideal for that.

    Reading the description of the module, I wonder if 📌 Fall back to 'edit-form' as default $rel in EntityBase::toUrl() Fixed has helped solve part of the problem?

    If we decide to do this, I think we may need to implement something similar to what we did in Media where this would not be enabled by default. It seems strange that anonymous users who may have access to view blocks, would be able to visit these URLs. See #3017935: Media items should not be available at /media/{id} to users with 'view media' permission by default for the media issue.

  • Status changed to Needs work over 1 year ago
  • 🇺🇸United States smustgrave

    Think you answered it. This is to provide editors the ability to preview blocks without having to place on a page first.

    Since block content doesn’t have a settings from guess one will have to be added.

  • Pipeline finished with Failed
    about 1 year ago
    Total: 609s
    #62296
  • Pipeline finished with Canceled
    about 1 year ago
    #62303
  • Pipeline finished with Canceled
    about 1 year ago
    #62306
  • Pipeline finished with Failed
    about 1 year ago
    Total: 541s
    #62307
  • Pipeline finished with Failed
    about 1 year ago
    Total: 672s
    #62310
  • Pipeline finished with Failed
    about 1 year ago
    Total: 615s
    #62316
  • Pipeline finished with Failed
    about 1 year ago
    Total: 2886s
    #62314
  • Pipeline finished with Failed
    about 1 year ago
    Total: 650s
    #62328
  • Status changed to Needs review about 1 year ago
  • 🇺🇸United States smustgrave

    Updated issue summary to include the settingsForm being added.

    Started a CR as well

    Wasn't sure how we wanted to handle admin/content/block/{block-content} when the standalone_url setting is off. Can't deprecate the route as it is used.

    Think it's ready for some review.

  • Pipeline finished with Failed
    about 1 year ago
    #62338
  • Pipeline finished with Failed
    about 1 year ago
    Total: 792s
    #62342
  • Pipeline finished with Canceled
    about 1 year ago
    Total: 41s
    #62350
  • Pipeline finished with Success
    about 1 year ago
    Total: 637s
    #62351
  • Status changed to Needs work about 1 year ago
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Left a review

  • 🇩🇪Germany rkoller Nürnberg, Germany

    I've taken a look yesterday night, one minor detail I am unsure about is into which group the "block content settings" link is placed on /admin/config. It not really feels like the perfect fit to put it under "user interface". My first goto in the list of available groups would have been content authoring probably. but that is only due to the fact that the term is closest to the general term "content", defining stand alone urls for content blocks isnt exactly "content authoring" either. while the term "user interface" is simply too generic (i wouldn't even considered or expected a setting like that there). for media settings it is easier since there is a dedicated group media available. tricky. "user interface" just seems not the exact right fit imho.

  • 🇺🇸United States smustgrave

    Addressed most of the feedback but leaving NW for the open threads.

    @rkoller I didn't know either where it should go but speaking to @larowlan we picked that one as there didn't seem to be a better spot.

  • Pipeline finished with Failed
    about 1 year ago
    Total: 623s
    #74423
  • 🇩🇪Germany rkoller Nürnberg, Germany

    i completely agree. and i've only looked at it from the perspective where to sort the link in the list of available groups. Another option might be to introduce a new one. Yet another option might be to go with the user interface group where the patch currently puts it and wait what comes out of the restructuring the admin ui menu structure and tackle the question/problem in the context of that effort (might be the pragmatic approach).

    or in addition i could bring up the topic either informally in the ux channel or raise it during the next ux meeting. just to get a few more perspectives (but i doubt anyone might have a better idea for the destination with the list of current groups).

  • 🇺🇸United States smustgrave

    Well if we add a new Block Content or Block section, similar to Media. Would it be odd if it's the only setting?

    May make sense for contrib just can't think of anything on the horizon for core to add another link to that section.

  • 🇩🇪Germany rkoller Nürnberg, Germany

    well without the patch applied user interface also has just a single link (Shortcuts) in it.

    but just adding a new group should also handled with care imho. would it make sense to add it, i mean are there many different contrib modules related to blocks that would justify that?

  • 🇺🇸United States smustgrave

    Create a new section for "Block" @larowlan some of the stuff requested we remove would break existing behavior.

  • Pipeline finished with Success
    about 1 year ago
    #74592
  • Pipeline finished with Failed
    12 months ago
    Total: 181s
    #84418
  • Pipeline finished with Success
    12 months ago
    Total: 606s
    #84905
  • Status changed to Needs review 12 months ago
  • 🇺🇸United States smustgrave

    Feedback addressed

  • Pipeline finished with Failed
    11 months ago
    Total: 651s
    #99837
  • Pipeline finished with Success
    11 months ago
    Total: 485s
    #99841
  • Status changed to Needs work 11 months ago
  • 🇦🇺Australia acbramley

    Needs a reroll

  • Assigned to smustgrave
  • 🇺🇸United States smustgrave

    Will address it tomorrow!

  • Pipeline finished with Failed
    11 months ago
    Total: 179s
    #110568
  • Pipeline finished with Success
    11 months ago
    Total: 489s
    #110576
  • Status changed to Needs review 11 months ago
  • 🇺🇸United States smustgrave

    Resolved all feedback. Still passing.

  • Status changed to Needs work 11 months ago
  • The Needs Review Queue Bot tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".

    This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide to find step-by-step guides for working with issues.

  • Status changed to Needs review 11 months ago
  • 🇺🇸United States smustgrave

    Rebased

  • Pipeline finished with Success
    11 months ago
    Total: 475s
    #112980
  • Pipeline finished with Canceled
    11 months ago
    Total: 62s
    #113356
  • Pipeline finished with Canceled
    11 months ago
    Total: 282s
    #113357
  • Pipeline finished with Failed
    11 months ago
    Total: 583s
    #113360
  • 🇺🇸United States smustgrave

    Addressed feedback.

  • Pipeline finished with Success
    11 months ago
    Total: 500s
    #113371
  • Status changed to Needs work 11 months ago
  • The Needs Review Queue Bot tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".

    This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.

    Consult the Drupal Contributor Guide to find step-by-step guides for working with issues.

  • Status changed to Needs review 11 months ago
  • 🇺🇸United States smustgrave

    Rebased

  • Pipeline finished with Success
    11 months ago
    Total: 490s
    #116856
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    From #39 and #41 it feels like @rkoller isn't sure that a new group is the right approach. I think we should get the UX team to make a suggestion either way. We could bundle in the wording on the form as part of that - I realise this is similar to the Media settings form but in this instance its only for preview so the wording/use case is slightly different. Tagging for UX team (I think that's the correct tag)

    Leaving at needs review

  • 🇩🇪Germany rkoller Nürnberg, Germany

    i have had added this issue to the shortlist for todays usability meeting, but yesterday a request for the review of the navigation module came in. since they try to get it into core as experimental we've discussed the navigation module today. we hopefully find time next week or i might pick the brains of the other regulars during the week.

    my main concern about the new group here was twofold. for one the new group Block is created with only a single page Block Content Settings in it and that single page has only a single interface component, a checkbox Standalone Block Content URL on it. on the other hand i think we should be mindful about the number of categories/groups available as well as what types there are. the majority is currently organized by topic/general function, not many are based on an actual entity type/module? media for one but that contains not only pages for the media module but also anything related to images and files.

  • Status changed to Needs work 9 months ago
  • 🇩🇪Germany rkoller Nürnberg, Germany

    Usability review

    We discussed this issue at 📌 Drupal Usability Meeting 2024-04-12 Needs work . The recording of the meeting can be found at: https://www.youtube.com/watch?v=1uFZZtA_xDw

    For the record, the attendees at the usability meeting were @AaronMcHale, @BlackBamboo, @benjifisher, @rkoller, @simohell, @skaught, and @worldlinemine.

    If you want more feedback from the usability team, a good way to reach out is in the #ux channel in Slack.

    At first sorry for the delay, but getting our train of thought and the reasoning behind our recommendations into a (hopefully) coherent comprehensible shape, instead of providing just a incoherent list of bullet points with our recommendations, I was sort of struggling over the course of the last few days. :/

    As one of the first steps in the meeting, we've compared the behavior of a block page with and without the MR applied:

    MR not applied
    Block description link: /admin/content/block/1
    Operations Edit button: /admin/content/block/1

    MR applied - "Standalone Block Content URL" and "Standalone media URL" ticked
    Block description link: /admin/content/block/1 (uses Olivero)
    Operations Edit button: /admin/content/block/1/edit (uses Claro)

    Accessing /admin/content/block/1 as an anonymous user in a private browser window leads to an Access denied page in Olivero.

    Media name link: /media/1 (uses Olivero)
    Operations Edit button: /media/1/edit (uses Claro)

    Accessing /media/1 as an anonymous user in a private browser window displays the page for the first media item in Olivero.

    MR applied - "Standalone Block Content URL" and "Standalone media URL" unticked
    /admin/content/block/1 redirects to /admin/content/block/1/edit
    /media/1 redirects to a Page not found page

    One detail that sparked our attention, on one hand you have a consistent patterns used for paths and the themes used for displaying the content in the different contexts with the standalone URLs for blocks and media ticked, on the other hand you have the discrepancy when standalone URLs are both unticked for blocks and media, how none available paths are then handled for each entity type.

    From there the discussion shifted into a brief outline of the historical evolution of content entity types. Initially only nodes were field-able, then terms became field-able, in Drupal 8.0 blocks got field-able, and then finally media items. Over time by general demand the different content entity types evolved more and more, added new features and moved towards a feature parity and a sort of uniform set of UI components for the user.

    But we have to be clear what the use case for an entity type is and it is important that we don't deviate from it or be ambiguous about it, otherwise things become confusing in particular for people who are learning Drupal for instance. If you create for example a block called image and you put an image field on it, what is the difference to a media item other than its location in the media library from the end users perspective? Same if you have block with four fields and a node with the same set of fields, the difference due to the strive for consistency in UI components and their micro copy is marginal, making it challenging to distinguish and pick one of the two.

    In consequence the group came to the insight and conclusion, certain things should be consistent across content entity types, but there should also be fundamental differences between the various entity types. We should be deliberate when we make those choices to have deliberate inconsistencies. Otherwise when a user is looking at the different content entity types and they all look almost identical without any cue that person is lost.

    So blocks are not standalone, blocks were never been designed to be viewed independently, they are placed into other entities. The main use case is with Layout Builder, currently there is no way to preview a block before adding it to a layout. Blocks are only viewable by authenticated users with with necessary permissions, that means the URL (for example /admin/content/block/1) is appropriate, that also means blocks should remain under /admin, that means the permissions are appropriate, so in consequence the "Standalone Block Content URL" would be obsolete. Blocks could only be previewed by users that are able to edit blocks while anonymous users or users without the necessary permission get an access denied page. That lead into the following conclusions:

    1. There was a clear consensus to recommend removing the Block Content settings page again. Instead make that option (the tab) enabled per default for every block type for users with the necessary permission. The tab should be renamed to Preview, view you associate with viewing something in its final form, by making that deliberate switch in the wording we communicate you are able to preview something, but its final form will look different in a different surrounding context. And in regards of the preview it would be a reasonable step to use the admin theme Claro instead of the default theme Olivero respecting the context of the /admin/content/block/ path - using Olivero per default is waking wrong expectations as well as assumptions.
    2. One suggestion that is completely out the scope for this issue, which could be moved to a followup issue is to add an option on a per block type basis on the edit page to set in which theme the blocks of a block type are previewed in. Meaning the user would be able to change the preview from the default Claro to the default theme for example. That way the user would be flexible to assign a block type to the context aka theme it is created for.
    3. The last point that was raised was in regards of consistency, it was suggested to add a publishing option for blocks. But while writing up the issue I've remembered and after some searching I've found that there is already a far grown issue for suggestion: UI for publishing/unpublishing block_content blocks Needs work . So a double thumbs up for the issue and feature from the group.

    I've removed the Needs usability review tag and changed the status back to Needs work

  • 🇺🇸United States xjm

    I just filed 🐛 Block library view links to the edit page for each content block even when the user does not have edit access Active which may be a duplicate. This issue has wider scope, but would resolve that.

    May check back later to incorporate my STR into this issue etc. and properly close it as a duplicate.

Production build 0.71.5 2024