-
Notifications
You must be signed in to change notification settings - Fork 28
/
ajax_prods.php
33 lines (29 loc) · 967 Bytes
/
ajax_prods.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<?php
require_once("bootstrap.inc.php");
header("Content-type: application/json; charset=utf-8");
$sql = new SQLSelect();
$sql->AddField("prods.id");
$sql->AddField("prods.name");
$sql->AddField("groups.name as groupName");
$sql->AddJoin("left","groups","groups.id = prods.group1");
$sql->AddTable("prods");
$r = array();
if (@$_POST["id"] || preg_match("/id=(\d+)/",@$_POST["search"],$m))
{
$sql->AddWhere(sprintf_esc("prods.id = %d",$_POST["id"]?:$m[1]));
$sql->SetLimit(1);
$r = SQLLib::selectRows( $sql->GetQuery() );
}
else if (@$_POST["search"])
{
$terms = split_search_terms( $_POST["search"] );
foreach($terms as $term)
{
$sql->AddWhere(sprintf_esc("prods.name like '%%%s%%' or groups.name like '%%%s%%'",_like($term),_like($term)));
}
$sql->AddOrder(sprintf_esc("if(prods.name='%s',1,2), prods.views desc, prods.name",$_POST["search"]));
$sql->SetLimit(10);
$r = SQLLib::selectRows( $sql->GetQuery() );
}
echo json_encode($r);
?>