Download & Extend

Selecting <None> displays the first view of the site

Project:Viewfield
Version:6.x-1.x-dev
Component:Code
Category:bug report
Priority:critical
Assigned:Unassigned
Status:closed (fixed)

Issue Summary

I have these field settings:

  • Required: No
  • Allowed views: selected one
  • nothing else ticked

When creating content I see am option in the viewfield. Selecting it and then clicking on preview lists the first view (of the site) instead of none.

I found this: viewfield.module

<?php
function _viewfield_potential_references($field_settings = TRUE, $field = array(), $delta = 0) {
...
  if (!
$field_settings && (!$field['required'] || ($field['multiple'] && $delta > 0))) {
//     drupal_set_message("<pre>" . print_r($options, TRUE) . "</pre>");
//     array_unshift($options, '<'. t('none') .'>');
   
$options[NULL] =  '<'. t('none') .'>';
?>

Otherwise it gives a value of '0' later on.
<?php
function viewfield_field($op, &$node, $field, &$items, $teaser, $page) {
...
    case
'sanitize':
     
      foreach (
$items as $delta => $item) {
        if (empty(
$item['vname'])) {
         
$items[$delta] = array("vname"=>NULL,"vargs"=>NULL);
          continue;
        }
       
$item = empty($item['vname']) || $field['widget']['force_default'] ? $field['super_default_widget'] :
?>

This fixes the problem for me. But I think it needs a better fix in case people use the force default stuff.

Great module BTW!!!

Comments

#1

Actually I think I found a simple solution for this - although it's more like a workaround but might help someone else.

<?php
function _viewfield_potential_references($field_settings = TRUE, $field = array(), $delta = 0) {
..
  if (
/*!$field_settings && */(!$field['required'] || ($field['multiple'] && $delta > 0))) {
   
array_unshift($options, '<'. t('none') .'>');
  }
?>

This allows setting the default view to in the field settings and leaves the default on when editing content.

#2

Priority:normal» critical
Status:active» needs review

If you don't choose the option to 'force default' the field still saves whatever view is selected as a 'global default value'. If you haven't selected a view, it ends up saving the first view in the list as the 'global default value'. Then on pages where you don't select any view there is some borked logic that displays the global default view even if you have not chosen 'force default'.

This fix doesn't take care of the borked logic, but at least allows the default to be no view instead of whatever view happens to be the first one in the list.

This is a fairly critical problem that actually makes the field unusable if you don't want a default view.

#3

To replicate the problem:

1) Add a viewfield to a content type.
2) Leave 'force default' unchecked and select no view as a default and make it not required.
3) Create a new page for this content type and leave the viewfield empty to display no view on that page.
4) You will see the first view in the viewfield list instead of no view.

#4

Thanks for this snippet miiimooo. This problem was kicking my ass, and would have taken me ages longer to figure out without that.

#5

Marked #484850: Not choosing any view not possible as duplicate of this issue.

#6

Hi there,

can someone please post the full corrected viewfield.module code/file?

I am not quite sure where to put the additional 3 lines within that block, and I'm also having the issue that always *something* is displayed....

Thanks a lot!
Robert

#7

Issue is reproducible with today's -dev.

#8

Subscribing

#9

solution mentioned in #1 works.

Here is a patch for it.

Any reason not to commit this to dev?

AttachmentSize
viewfield_defaultnone_1.patch 775 bytes

#10

critical for futher use indeed, needs update

#11

Installed viewfield and immediately hit this problem. Pretty much killed what i wanted to do until I came across this thread.

I manually applied the patch from #9 and can confirm this fixed the issue for me.

#12

subscribing

#13

@the maintainers:

Is there a reason why you didn't add this path to the current (march 27th) dev release?

I helped myself by creating an always empty view (node-id = 0) and set this view as default in the field settings of the viewfield. But I would better like the patch to be included in the next dev release, please!

#14

Status:needs review» needs work

+++ viewfield.module 2010-01-29 10:29:42.000000000 +0100
@@ -279,7 +279,10 @@ function _viewfield_potential_references
-  if (!$field_settings && (!$field['required'] || ($field['multiple'] && $delta > 0))) {
+  //if (!$field_settings && (!$field['required'] || ($field['multiple'] && $delta > 0))) {
+  //  array_unshift($options, '<'. t('none') .'>');
+  //}
+  if (/*!$field_settings && */(!$field['required'] || ($field['multiple'] && $delta > 0))) {

Why didn't you just remove !$field_settings and the parenthesis that wrap the directly following condition?

Powered by Dreditor.

#15

Status:needs work» needs review

Fresh to this module, but the proposed fix looks wrong - presuming that the calling code is right, of course.

Attached patch should be the proper fix, also clarifying the logic.

AttachmentSize
viewfield.form-default.15.patch 2.87 KB

#16

Title:Selecting <None> displays the first view of the site (and it's not even in the allowed list ;)» Selecting <None> displays the first view of the site
Status:needs review» reviewed & tested by the community

Alrighty, this time for real - the calling code was bogus, too.

AttachmentSize
viewfield-HEAD.form-default.16.patch 4.67 KB

#17

sun >
thanks, that works (and looks better ;)

#18

Is this going to get commited soon do you think? I really need this functionality and would prefer to use an up to date version rather than use patches / workarounds.

#19

Patch works great by the way, many thanks. Needed to uninstall the module and reinstall first (is that because the inc file makes changes to the database? I'm new to this)

#20

Status:reviewed & tested by the community» fixed

Thanks for reporting, reviewing, and testing! Committed to all branches.

A new development snapshot will be available within the next 12 hours. This improvement will be available in the next official release.

#21

"Next official release" would be fine - there has not even been a release for 6.x yet. Any plans?

#22

Status:fixed» closed (fixed)

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

nobody click here