You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
45 lines
1.2 KiB
45 lines
1.2 KiB
<?php
|
|
|
|
namespace TomLingham\Searchy\Matchers;
|
|
|
|
/**
|
|
* Matches strings that include all the characters in the search relatively position within the string.
|
|
* It also calculates the percentage of characters in the string that are matched and applies the multiplier accordingly.
|
|
*
|
|
* For Example, a search for 'fba' would match; 'Foo Bar' or 'Afraid of bats'
|
|
*
|
|
* Class ConsecutiveCharactersMatcher
|
|
*/
|
|
class ConsecutiveCharactersUnicodeMatcher extends BaseMatcher
|
|
{
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $operator = 'LIKE';
|
|
|
|
/**
|
|
* @param $searchString
|
|
*
|
|
* @return string
|
|
*/
|
|
public function formatSearchString($searchString)
|
|
{
|
|
$results = [];
|
|
preg_match_all('/./u', $searchString, $results);
|
|
|
|
return '%'.implode('%', $results[0]).'%';
|
|
}
|
|
|
|
/**
|
|
* @param $column
|
|
* @param $rawString
|
|
*
|
|
* @return mixed|string
|
|
*/
|
|
public function buildQueryString($column, $rawString)
|
|
{
|
|
$searchString = $this->formatSearchString($rawString);
|
|
|
|
return "IF( REPLACE($column, '\.', '') {$this->operator} '$searchString', ROUND({$this->multiplier} * ( CHAR_LENGTH( '$rawString' ) / CHAR_LENGTH( REPLACE($column, ' ', '') ))), 0)";
|
|
}
|
|
}
|