J'essaie de remplacer un élément de formulaire de saisie semi-automatique entityreference, j'ai réussi à remplacer le formulaire et à faire passer l'argument à un rappel hook_menu. Cependant, j'ai du mal à faire fonctionner le rappel en fonction de ce que je tape dans la zone de formulaire. En regardant dans le module de référence d'entité, il y a du code dans le hook_autocomplete_callback qui gère l'argument $ string et recherche les correspondances $entity_labels = $handler->getReferencableEntities($tag_last, $instance['widget']['settings']['match_operator']
- quelque chose comme ça.
Quelqu'un peut-il aider?
Mon code:
/**
* Implements hook_form_FORM_ID_alter().
*/
function wl_event_form_event_node_form_alter(&$form, &$form_state, $form_id) {
dpm($form);
// We will get our term id argument from the from build itself.
$node_id = $form['#node']->nid;
// This is the path we will create in hook_menu().
$new_path = "wl_event/autocomplete/{$node_id}";
// Maximum number of descrete values (deltas) that are present.
$max_delta = $form['field_wl_event_acquired_resource']['und']['#max_delta'];
// Hijack the autocomplete callback for each of our values.
for($x=0; $x <= $max_delta; $x++) {
$form['field_wl_event_acquired_resource']['und'][$x]['target_id']['#autocomplete_path']= $new_path;
}
}
/**
* Implements hook_menu().
*/
// can be used to do a lookup on a menu path to return json
// probably entity reference autocomplete does a similar thing
//we want to get all of the resources of the user profiles of
//users who are registered on the event
//
function wl_event_menu() {
$items = array();
$items['wl_event/autocomplete/%'] = array(
'title' => t('project call back'),
'page callback' => 'wl_event_autocomplete_callback',
'page arguments' => array(2),
'access callback' => TRUE,
'type' => MENU_CALLBACK
);
return $items;
}
function wl_event_autocomplete_callback($arg1, $string = '') {
$query = new EntityFieldQuery();
$query->entityCondition('entity_type', 'node')
->entityCondition('bundle', 'resource');
// ->propertyCondition('nid', '1')
$results = $query->execute();
print_r(drupal_json_output($results));
return drupal_json_output($results);
}
Réponses:
EntityReference utilise le système de plugins ctools pour définir des gestionnaires de sélection qui alimentent les options de saisie semi-automatique. La définition de l'interface est définie dans entityreference / plugins / selection / abstract.inc . Dans ce même répertoire, vous verrez les deux gestionnaires inclus, Simple et Views. Chacun d'eux est défini par deux fichiers, un pour la classe elle-même et un avec un tableau pour enregistrer le plugin avec ctools.
Pour fournir votre propre gestionnaire de sélection, dites d'abord à ctools où chercher votre plugin en l'implémentant
hook_ctools_plugin_directory
.Créez ensuite 2 fichiers
wl_event/plugins/selection
similaires à ceux de la référence d'entité. Le.inc
fichier doit définir les informations du plugin ctools et le.class.php
fichier doit contenir votre classe de plugin. Vous voudrez probablement sousEntityReference_SelectionHandler_Generic
- classer et simplement remplacer les méthodes appropriées.Enfin, assurez-vous d'ajouter le fichier avec votre classe de plug-in au
files[]
tableau dans le fichier d'informations de vos modules afin que l'autochargeur puisse le trouver.la source