Tôi đang cố gắng tạo bản ghi nhật ký các tìm kiếm được thực hiện thông qua khối biểu mẫu hiển thị Chế độ xem API tìm kiếm của tôi trong Drupal 9.
Vì một số lý do trên một tìm kiếm hoàn toàn mới, tôi nhận được 2 bản sao (tổng cộng 3 mục nhập) và có vẻ như tôi nhớ đã đọc ở đâu đó rằng các biểu mẫu có thể được gửi nhiều lần. Vì vậy, tôi muốn biết làm thế nào tôi có thể loại bỏ điều đó.
Cập nhật: đây là sự cố đối với Drupal 7
https://www.drupal.org/project/views/issues/2088549
Ngoài ra, khi tìm kiếm các từ khóa dẫn đến "không có kết quả", tôi không thấy mục nhập nào trong nhật ký Hành vi này có vẻ thành công và bỏ sót. Tôi đang sử dụng đoạn mã sau với thành công hạn chế:
/**
* Triển khai hook_form_views_exposed_form_alter().
*/
function MY_form_views_exposed_form_alter(&$form, FormStateInterface &$form_state, $form_id) {
// Tạo hàm gửi search_log cho watchdog
$view_names = mảng('search_api_view');
$view = $form_state->getStorage('view');
if ($form_id == 'views_exposed_form' && in_array($view['view']->id(), $view_names)) {
if ($form['#id'] == 'view-exposed-form-search-api-view-page-1') {
$form['#submit'][] = 'MY_search_api_log';
}
}
}
function MY_search_api_log(&$form, FormStateInterface $form_state) {
if ($form_state->getValue('search_api_fulltext') != "") {
// Tạo một liên kết
$link = Url::fromRoute('view.search_api_view.page_1', [], ['query' => ['search_api_fulltext' => $form_state->getValue('search_api_fulltext'), ], ]);
// ghi nhật ký gửi
\Drupal::logger('search_api_results')->info($form_state->getValue('search_api_fulltext'), ['link' => Link::fromTextAndUrl('results', $link)->toString()]) ;
}
}
Tôi đang cố gắng chuyển đổi chức năng này từ một hook mà tôi đang sử dụng trong D7, hoạt động tốt:
/**
* Triển khai hook_form_views_exposed_form_alter().
*/
function MY_form_views_exposed_form_alter(&$form, &$form_state, $form_id) {
//Tạo hàm gửi search_log cho watchdog
if($form_state["view"]->base_field == 'search_api_id') {
$form['#submit'][] = 'MY_search_api_log';
}
}
function MY_search_api_log(&$form, $form_state) {
if ($form_state['values']['search_api_views_fulltext'] != "") {
$link = l('results', '/search-results', ['query' => ['search_api_views_fulltext' => $form_state['values']['search_api_views_fulltext'], ], ]);
cơ quan giám sát('search_api_results', $form_state['values']['search_api_views_fulltext'], [], WATCHDOG_INFO, $link);
}
}