Targeting CCK in 6 not working
mikelove - May 14, 2008 - 15:38
| Project: | Prepopulate |
| Version: | 6.x-2.x-dev |
| Component: | Code |
| Category: | bug report |
| Priority: | normal |
| Assigned: | Unassigned |
| Status: | patch (code needs work) |
Description
I am trying to target an autocomplete node reference field and having difficulty formulating the URL.
I can successfully edit the title and other fields, but not this field. I'm using the URL ending:
&edit[field_interview_link][0][nid][nid]=test
And here is the HTML for the first input:
<table id="field_interview_link_values" class="content-multiple-table sticky-enabled">
<thead><tr><th colspan="2">Interview link: </th><th>Order</th> </tr></thead>
<tbody>
<tr class="draggable odd"><td class="content-multiple-drag"></td><td><div class="form-item" id="edit-field-interview-link-0-nid-nid-wrapper">
<input type="text" maxlength="128" name="field_interview_link[0][nid][nid]" id="edit-field-interview-link-0-nid-nid" size="60" value="" class="form-text form-autocomplete" />
</div>
<input class="autocomplete" type="hidden" id="edit-field-interview-link-0-nid-nid-autocomplete" value="http://alegent.iftf.net/nodereference/autocomplete/field_interview_link" disabled="disabled" /></td><td class="delta-order"><div class="form-item" id="edit-field-interview-link-0--weight-wrapper">
<select name="field_interview_link[0][_weight]" class="form-select field_interview_link-delta-order" id="edit-field-interview-link-0--weight" ><option value="-10">-10</option><option value="-9">-9</option><option value="-8">-8</option><option value="-7">-7</option><option value="-6">-6</option><option value="-5">-5</option><option value="-4">-4</option><option value="-3">-3</option><option value="-2">-2</option><option value="-1">-1</option><option value="0" selected="selected">0</option><option value="1">1</option><option value="2">2</option><option value="3">3</option><option value="4">4</option><option value="5">5</option><option value="6">6</option><option value="7">7</option><option value="8">8</option><option value="9">9</option><option value="10">10</option></select>
</div>
</td> </tr>...
#1
Check out this issue: http://drupal.org/node/247399
#2
I started with this, and having difficulty with this method also. This what I'm trying:
&edit[field_interview_link][0][node_name]=test#3
I'm going to switch back to active because the [node_name] solution doesn't seem to work with 6.x. Maybe something to do with the fields being rearrangeable.
#4
Marking #270116: cannot populate cck fields as a duplicate of this. Looks like CCK changes for 6 are making this wonky.
#5
I fixed CCK in D6 using the following patch. Not sure if this does something bad, as I really don't know how forms in D6 are handled. But var_dump() helped me finding the problem and it works for me now.
#6
Thanks for the patch. I won't get a chance to look at this for a week or so but I'm marking it needs review and hopefully others can take it for a spin.
#7
Perhaps I should describe what the problem was, so you don't have to find out yourself...:
I use the Prepopulate-module to fill nodereferences with initial data (other cck-fields may behave different). Within _prepopulate_get_walk() the module tries to find the last entry in $form according to the array given in $_GET. It seems like things have changed here, at least nodereference stores an array inside $field['#default_value']. So the array needs to be set right. Walking the $form-array fails, because it only tries to use the last element as a default value. Instead with the patch I checked if $form has an #default_value-item and set it using array_merge(), so the whole array gets copied into the form. I don't know if replacing the array instead of doing array_merge() would be better or if there is some better way to figure out that #default_value needs to be set (or further walking is needed). Like said before, I don't know much about drupal forms, but the patch just worked...so I thought it might be worth sharing. ;-)
#8
Sorry, somehow the status of the ticket got changed...
#9
On Drupal 6.3 this module works only with [title]. Body and CCK fields cannot be changed. #5 patch is ineffective on my installation.
Drupal: 6.3, CCK: 6.x-2.0-rc4
#10
Well, It works only under some conditions.
Following tests run on a 6.x-2.x-dev (2008-Jun-24) patched with #5.
<?php<option value="2">A</option>
<option value="3">AB</option>
<option value="4">B</option>
<option value="1">O</option>
</select>
?>
Select AB option on from vocabulary 1
<?php<textarea id="edit-field-references-0-value" class="form-textarea resizable textarea-processed" name="field_references[0][value]" rows="5" cols="60">My References</textarea>
?>
Add My References to field_references field (text field on multiple rows).
Note: it only works outside Groups (fieldset). Moving a field outside fieldset make it works.
<?php<select id="edit-language" class="form-select" name="language">
<option value="">Indipendente dalla lingua</option>
<option selected="selected" value="en">Inglese</option>
<option value="it">Italiano</option>
</select>
?>
Select "Inglese" multilingual option (using the value as ID, like taxonomy) from Internationalization module.
<?php<input id="edit-field-work-0-nid-nid" class="form-text form-autocomplete" type="text" value="Mai [nid:12]" size="60" name="field_work[0][nid][nid]" maxlength="128" autocomplete="OFF"/>
?>
To select Mai (node/12) on the first nodereference CCK field. Note: name is field_work[0][nid][nid] but only [field_work][0][nid] works.
Main issues:
I hope these tests will be useful to fix these bugs.
#11
I don't believe the patch is working for me, but I could have my URL formatted wrong too.
I want to prepopulate a CCK nodereference dropdown field. Here is the HTML for the field:
<select id="edit-field-customer-nid-nid" class="form-select required" name="field_customer[nid][nid]">And here is what I attempted for a URL:
http://localhost/drupal-6/node/add/activity?edit[field_customer][nid][nid]=KingdomI'd appreciate any suggestions. :)
#12
Try http://localhost/drupal-6/node/add/activity?edit[field_customer][0][nid]=$nid
($nid means it should be the ID, not the title)
#13
Sometimes ddanier #5 patch on my installation causes a "warning: array_keys() [function.array-keys]: The first argument should be an array" when targeting page title. On _prepopulate_get_walk !is_null($form['#default_value']) else missed the is_array($getslice) control statement. I attach the new patch (I have to test it more deeply).