Added search with wildcard (with ? and *)

This commit is contained in:
Kyle Huynh 2021-12-06 10:22:00 -05:00
parent 969dc21bb6
commit 9836edfb58

View file

@ -163,22 +163,41 @@ class AdvancedSearchQuery {
$q = implode(' ', $q);
/** @var Solarium\QueryType\Select\Query\Query $solarium_query */
// enable dismax search query option
/** @var Solarium\QueryType\Select\Query\Component\DisMax $dismax */
$dismax = $solarium_query->getDisMax();
$dismax->setQueryParser('edismax');
$query_fields = [];
foreach ($field_mapping as $key => $field) {
foreach ($field as $f => $item) {
if (strpos($item, 'sticky') === false) {
array_push($query_fields, $item);
if ((strpos($q, "*") !== false || strpos($q, "?") !== false)) {
// enable wildcard
$tmp = str_replace('"', "", trim($q));
$query_fields = [];
foreach ($field_mapping as $key => $field) {
foreach ($field as $f => $item) {
if (strpos($item, 'sticky') === false && !in_array($item, ['score', 'random', 'boost_document'])
&& ((strpos( $item, "sm_" ) === 0) || (strpos( $item, "tm_" ) === 0) || (strpos($item, "sort_ss_") === 0) || (strpos($item, "ts_") === 0)
|| (strpos($item, "ss_") === 0)
)){
array_push($query_fields, '('.$item. ':'. $tmp .')');
}
}
}
$q = implode(" ", array_unique($query_fields));
}
else {
// enable dismax search query option
/** @var Solarium\QueryType\Select\Query\Component\DisMax $dismax */
$dismax = $solarium_query->getDisMax();
$dismax->setQueryParser('edismax');
$query_fields = [];
foreach ($field_mapping as $key => $field) {
foreach ($field as $f => $item) {
if (strpos($item, 'sticky') === false) {
array_push($query_fields, $item);
}
}
}
$query_fields = implode(" ", array_unique($query_fields));
$dismax->setQueryFields($query_fields);
}
$query_fields = implode(" ", array_unique($query_fields));
$dismax->setQueryFields($query_fields);
$solarium_query->setQuery($q);
}
}
}
/**