Я не знаю, как реализовать AJAX в hook_form_alter ().
Поле по умолчанию представляет собой обычный текст и заполняется NID (номером) компании-клиента.Название модуля "my_car".Я не использовал ссылку на узел в этом поле.
Вот код:
function my_car_form_alter(&$form, &$form_state, $form_id) {
if ($form_id == 'car_node_form') {
$clientCompanies = companyTitle(12); // TID 12
// Replace Client company NID with title
$form['field_car_company']['und'][0]['value'] = array(
'#title' => 'Client company',
'#type' => 'select',
'#default_value' => $form_state['node']->field_car_company['und'][0]['value'],
'#options' => $clientCompanies,
'#required' => TRUE,
'#empty_option' => t('- Select -')
);
}
}
Здесь я использую функцию companyTitle (), чтобы вернуть все компании (узлы), которые имеют TID 12 изамените тип поля («текстовое поле» на «выберите»), а его содержимое - номер с текстом (NID с заголовком).
function companyTitle($tid) {
$results = db_query("
SELECT n.nid, n.title
FROM {node} AS n
LEFT JOIN {field_data_field_company_type} AS ct ON ct.entity_id = n.nid
WHERE n.type = 'company' AND ct.field_company_type_tid = :tid
ORDER BY n.title ASC",
array(':tid' => $tid))->fetchAllKeyed();
return $results;
}
Я написал функцию, которая возвращает NID и название компании-клиента на основе TIDи заголовок:
function ajaxCompanyTitle($tid, $companyName) {
$query = db_select('node', 'company')
->fields('company', array('nid', 'title'))
->condition('company.type', 'company', '=')
->condition('type.field_company_type_tid', $tid, '=')
->condition('company.title', '%'.db_like($companyName).'%', 'LIKE')
->orderBy('company.title', 'ASC')
->range(0, 10);
$query->leftJoin('field_data_field_company_type', 'type', 'type.entity_id = company.nid');
$results = $query->execute()->fetchAll();
return $results;
}
Теперь вопрос о том, как реализовать AJAX с последней функцией.Мне нужно текстовое поле (это не список выбора) с поиском AJAX, где NID будет отображаться как заголовок (NID остается только в базе данных в столбце field_car_company_value).
Очевидно, я не знаю, как реализовать обратный вызовфункция.
function my_car_form_alter(&$form, &$form_state, $form_id) {
if ($form_id == 'car_node_form') {
// Replace Client company NID with title
$form['field_car_company']['und'][0]['value'] = array(
'#title' => 'Client company',
'#type' => 'textfield',
'#required' => TRUE,
'#ajax' => array(
'callback' => 'ajax_callback',
'wrapper' => 'edit-field-car-company-und-0-value',
)
);
}
}
function ajax_callback($string = '') {
$matches = array();
if ($string) {
$clientCompanies = ajaxCompanyTitle(12, $string);
foreach ($clientCompanies as $clientCompany) {
$matches[$clientCompany->title] = $clientCompany->title;
}
}
drupal_json_output($matches);
}