Add support for OR in block visibility conditions

Created on 27 September 2010, over 14 years ago
Updated 21 January 2023, about 2 years ago

Problem/Motivation

Block visibility settings allow to show a block "per page path" OR "per content type" only.

Example: "Recent blog posts" - a pure blog related block.
If "Pages" is set to "All pages" AND "Content types" to "Blog entry" it will show up ONLY on blog posts but not on Blogs page.
If "Only the listed pages" is set to "blog" it will show up ONLY on Blogs page but not on any of blog posts.
If "Only the listed pages" is set to "blog" AND "Content types" is set to "Blog entry" it will not be shown at all. Nowhere.
Isn't it logical to allow it to be visible at Blogs page AND Blog posts?

The same goes for any other block, not only "recent blog posts".

(There are snippets like this one http://drupal.org/node/134425 but they require the PHP module.)

Steps to reproduce

Proposed resolution

Add support for OR conditions groups

Remaining tasks

Add automated test coverage
Update issue summary proposed resolution and steps to reproduce

User interface changes

API changes

Data model changes

Release notes snippet

โœจ Feature request
Status

Needs work

Version

10.1 โœจ

Component
Blockย  โ†’

Last updated 9 days ago

Created by

๐Ÿ‡ญ๐Ÿ‡ฐHong Kong mertskeli

Live updates comments and jobs are added and updated live.
  • Needs issue summary update

    Issue summaries save everyone time if they are kept up-to-date. See Update issue summary task instructions.

  • Needs tests

    The change is currently missing an automated test that fails when run with the original code, and succeeds when the bug has been fixed.

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.

  • ๐Ÿ‡ฉ๐Ÿ‡ชGermany Daniel Kulbe Berlin

    Please also note, I fixed in this Version :

    • Missing context vs. context value, a cache issue, as stated in the comment in code.
    • The conditions count was created prior the and-or plugin was removed.
    • The form
    • I applied the same logic in the radio negate switch form to all considerable elements in the form.
    • I choose to stick to jQuery in block.js

    One further opinion on this ... the check regarding the empty request_path plugin - shouldn't it be happen in the plugin form validation method instead. It is called a few lines below where the check was added.

  • ๐Ÿ‡ฉ๐Ÿ‡ชGermany Daniel Kulbe Berlin

    Sorry, still found a tiny JavaScript selector issue. I will not start the failed tests in 78 again, as nothing has changed.
    Can please sb. take care of the functional test, who has some strong suites there.

  • ๐Ÿ‡ฉ๐Ÿ‡ชGermany Daniel Kulbe Berlin

    One final thought on this - the original code is right in one further thing: The Condition should be added to the conditions array in every case, even if there is an exception, so when collecting cachability, every condition is applied to forbidden for missing value, not just only the valid ones. Adding another version here, which fixes this.

  • ๐Ÿ‡ฎ๐Ÿ‡ณIndia _utsavsharma

    Fixed CCF for #81 in 9.5.x.

  • ๐Ÿ‡ฎ๐Ÿ‡นItaly trickfun

    I think that having one condition logic for all visibility types is wrong.
    "user roles" condition should be always in AND mode.

    user roles is different from "content type" or "path".

    i suggest to separate "user role" from other conditions.
    I think the better solution is to have

    Visibility (AND or OR for all conditions)

    AND

    User Visibility (AND or OR for all conditions relative to user)

    Thank you

  • ๐Ÿ‡ฎ๐Ÿ‡นItaly kopeboy Milan

    @ #82: This is a restriction imho: why?
    I could say we should leave it more general, as you can't exclude in advance an OR condition on user role.

    Here is an example usecase for a block showing diff/debug/editorial information:

    1. Show this block on taxonomy term pages only

      AND
    2. Show this block on admin or edit pages only

      OR
    3. Show this block if user has taxonomy editor role
  • ๐Ÿ‡ฎ๐Ÿ‡นItaly trickfun

    Is it possible to have this use case?

    1. show A block on taxonomy term
    OR
    2. show A block on /my-custom-url

    3. show in the previous page only if user is admin

    thank you

  • ๐Ÿ‡ฉ๐Ÿ‡ชGermany flefle

    Attached bellow is the adopted patch for 10.2.x.

  • last update over 1 year ago
    Patch Failed to Apply
  • last update over 1 year ago
    Patch Failed to Apply
  • Status changed to Needs review over 1 year ago
  • ๐Ÿ‡ฎ๐Ÿ‡ณIndia gauravvvv Delhi, India

    Added patch for 11.x

  • last update over 1 year ago
    Custom Commands Failed
  • Status changed to Needs work over 1 year ago
  • Status changed to Needs review over 1 year ago
  • ๐Ÿ‡ฎ๐Ÿ‡ณIndia gauravvvv Delhi, India

    Tried fixing CCF, attached interdiff for same.

  • last update over 1 year ago
    25,956 pass, 1,830 fail
  • Status changed to Needs work about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Caused a large number of failures.

  • ๐Ÿ‡ฉ๐Ÿ‡ชGermany onfire84

    Tryed Patch #86 on a 10.2.x Drupal Page. Patch does apply, but when i try to configure a block on the blocklayout page, it fails with "Error: Undefined constant "Drupal\block\form_state" in Drupal\block\BlockForm->buildVisibilityInterface() (line 242 of core/modules/block/src/BlockForm.php)."

  • ๐Ÿ‡บ๐Ÿ‡ธUnited States johnlutz

    Fixed the patch that applies against 10.2.x.

  • ๐Ÿ‡ต๐Ÿ‡ญPhilippines adriancruz

    Patch for 10.2.x

  • Merge request !7270Resolve #923934 "Block visibility or" โ†’ (Closed) created by smustgrave
  • Pipeline finished with Failed
    about 1 year ago
    Total: 659s
    #134736
  • Pipeline finished with Success
    about 1 year ago
    Total: 642s
    #134751
  • Pipeline finished with Failed
    about 1 year ago
    Total: 166s
    #134785
  • Status changed to Needs review about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Hiding patches for clarity

    Cleaned up issue summary so removing that tag.

    Ran test-only feature and got https://git.drupalcode.org/issue/drupal-923934/-/jobs/1210671 but that shows the schema update

    This shows the block placement test. https://git.drupalcode.org/issue/drupal-923934/-/jobs/1211130

    So removing that tag as well

    Turned patch #93 into an MR with a few changes
    Removed some changes to the tests that seemed out of scope.
    Turned the new condition into an attribute vs annotation usage.
    Added new test coverage.

    Suggestions appreciated

  • Pipeline finished with Success
    about 1 year ago
    Total: 1042s
    #134786
  • Status changed to Needs work about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Posted in slack and @berdir made a recommendation to take a deeper look at #59

  • Pipeline finished with Canceled
    about 1 year ago
    #134898
  • Pipeline finished with Failed
    about 1 year ago
    Total: 198s
    #134903
  • Pipeline finished with Failed
    about 1 year ago
    Total: 754s
    #134908
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Updated issue summary with new solution.

    I've pushed changes to the new MR but there is a test failure I can't figure out why, with the default config.

  • Pipeline finished with Failed
    about 1 year ago
    Total: 725s
    #134922
  • Pipeline finished with Canceled
    about 1 year ago
    Total: 125s
    #134934
  • Pipeline finished with Failed
    about 1 year ago
    Total: 752s
    #134936
  • Pipeline finished with Failed
    about 1 year ago
    Total: 314s
    #134946
  • Pipeline finished with Failed
    about 1 year ago
    #134948
  • Pipeline finished with Canceled
    about 1 year ago
    Total: 157s
    #134953
  • Pipeline finished with Failed
    about 1 year ago
    Total: 691s
    #134954
  • Pipeline finished with Success
    about 1 year ago
    Total: 568s
    #134961
  • Status changed to Needs review about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    All tests green, think ready for review of new approach.

  • Status changed to Needs work about 1 year ago
  • ๐Ÿ‡ฆ๐Ÿ‡บAustralia acbramley

    Left some comments on the MR, IMO the summary could use a rewording - it took me a few goes to understand what "hit" meant in this context.

  • Status changed to Needs review about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Updated and cleaned out more to just include a single example.

    Addressed feedback

  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave
  • Pipeline finished with Failed
    about 1 year ago
    Total: 722s
    #135796
  • Status changed to Needs work about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Forgot the upgrade path test

  • #93 worked for me. Drupal version : 10.3.8

    Merge request !7274 could not be applied.

  • ๐Ÿ‡ฉ๐Ÿ‡ชGermany flefle

    Drupal 10.4.1 adapted patch.

  • ๐Ÿ‡จ๐Ÿ‡ทCosta Rica robert-arias

    #106 missed the plugin itself.

    Drupal 10.4.2 patchโ€”working.

  • Pipeline finished with Failed
    about 2 months ago
    Total: 482s
    #427428
  • Pipeline finished with Failed
    about 2 months ago
    Total: 358s
    #427733
  • Pipeline finished with Failed
    about 2 months ago
    Total: 543s
    #428518
  • Pipeline finished with Failed
    about 1 month ago
    Total: 344s
    #428603
  • Pipeline finished with Failed
    about 1 month ago
    Total: 417s
    #428931
  • ๐Ÿ‡ฆ๐Ÿ‡บAustralia acbramley

    This will need the same preSave logic that was requested over in https://git.drupalcode.org/project/drupal/-/merge_requests/6953#note_463274

    I haven't figured out how to persist the deprecationEnabled setting between the update hook and preSave but https://git.drupalcode.org/project/drupal/-/merge_requests/5544/diffs is using similar logic and its working there.

  • Pipeline finished with Failed
    about 1 month ago
    Total: 182s
    #440917
  • Pipeline finished with Failed
    about 1 month ago
    Total: 416s
    #440962
  • Pipeline finished with Canceled
    25 days ago
    Total: 343s
    #445176
  • Pipeline finished with Failed
    25 days ago
    Total: 442s
    #445184
  • Pipeline finished with Failed
    25 days ago
    Total: 398s
    #445194
Production build 0.71.5 2024