Search test

This commit is contained in:
2023-01-15 13:11:00 +01:00
parent b68fdb31a7
commit c2cc255c61
2 changed files with 53 additions and 75 deletions

View File

@@ -5,7 +5,7 @@ namespace App\Http\Controllers;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use App\Models\Person; use App\Models\Person;
use App\Http\Controllers\JsonResponse; use App\Http\Controllers\JsonResponse;
use Illuminate\Database\Eloquent\Builder;
class PersonController extends Controller class PersonController extends Controller
{ {
@@ -18,88 +18,66 @@ class PersonController extends Controller
return response()->json($persons); return response()->json($persons);
} }
public function process_rule($query,$rules,$condition)
{
$where = null;
$count = 0;
foreach ($rules as $rule) {
if(array_key_exists("condition",$rule)) {
$where = function ($q) use ($rule) {
$this->process_rule($q,$rule["rules"],$rule["condition"]);
};
} else {
switch ($rule["operator"]) {
case "=":
$where = [ $rule["id"], '=', $rule["value"]];
break;
case "(":
$where = [ $rule["id"], 'LIKE', $rule["value"]."%" ];
break;
case "!=":
$where = [ $rule["id"], '!=', $rule["value"]];
break;
case ")":
$where = [ $rule["id"], 'LIKE', "%".$rule["value"]];
break;
}
}
if ($query != null)
{
switch ($condition) {
case "and":
$query->where($where);
break;
case "or":
$count == 0 ? $query->where($where) : $query->orWhere($where);
}
} else {
$query = Person::where($where);
}
$count++;
}
return $query;
}
public function search(Request $request) public function search(Request $request)
{ {
$query = $request->post(); $query = $request->post();
$result = []; $currentQuery = $query;
$where = []; $condition = $currentQuery["condition"];
$qr = null;
$qa = [$qr];
$q = $qr;
$count = 0;
foreach ($query as $c) { $qr = $this->process_rule(null,$currentQuery["rules"],$condition);
if ($c["criteria"]["operator"] == "=") $where = [$c["field"]["name"], $c["pre"] == "NOT" ? '!=' : '=', $c["value"]];
if ($c["criteria"]["operator"] == "LIKE START") $where = [$c["field"]["name"], $c["pre"] == "NOT" ? 'not like': 'like', $c["value"].'%'];
if ($c["criteria"]["operator"] == "LIKE") $where = [$c["field"]["name"], $c["pre"] == "NOT" ? 'not like': 'like', '%'.$c["value"].'%'];
// $result[] = $where;
if ($c["count"] == 0) {
$q = \array_pop($qa);
if ($q == null)
$q = Person::where([$where]);
else
$q->where([$where]);
}
if ($c["level"] > 0 && $c["count"] == 0)
array_push($qa,$q);
if ($c["pre"] == 'AND') $q->andWhere($where);
if ($c["pre"] == 'OR') $q->orWhere($where);
if ($c["pre"] == 'AND NOT') $q->whereNot($where);
if ($c["pre"] == 'OR NOT') $q->orWhereNot($where);
if ($c["groupop"] != "") {
if ($c["count"] == 0) {
$qr2 = function($q) use ($c) {
};
array_push($qa,$qr2);
}
}
}
// DB::connection( 'mongodb' )->enableQueryLog();
if ($qr) $result = $qr->get(); if ($qr) $result = $qr->get();
else $result = []; else $result = [];
// dd(DB::connection('mongodb')->getQueryLog());
return response()->json($result); return response()->json($result);
// {
// "groupop": "",
// "pre": "NOT",
// "field": {
// "name": "fullNames.value",
// "desc": "Plné meno"
// },
// "value": "sds",
// "criteria": {
// "name": "Rovná sa",
// "operator": "%s"
// },
// "level": 0,
// "count": 0
// },
// {
// "groupop": "",
// "pre": "NOT",
// "field": {
// "name": "fullNames.value",
// "desc": "Plné meno"
// },
// "value": "sds",
// "criteria": {
// "name": "Rovná sa",
// "operator": "%s"
// },
// "level": 0,
// "count": 1
// }
// ]
} }
} }

View File

@@ -4,12 +4,12 @@ namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Jenssegers\Mongodb\Eloquent\Model; use Jenssegers\Mongodb\Eloquent\Model;
use Mehradsadeghi\FilterQueryString\FilterQueryString; // use Mehradsadeghi\FilterQueryString\FilterQueryString;
class Person extends Model class Person extends Model
{ {
use HasFactory; use HasFactory;
use FilterQueryString; // use FilterQueryString;
protected $filters = []; protected $filters = [];
protected $connection = 'mongodb'; protected $connection = 'mongodb';