mirror of
https://github.com/Sarjuuk/aowow.git
synced 2025-11-29 15:58:16 +08:00
- what which index does needs to be implemented in the implementation - differences to wowhead * strings in criteria are more lenient and will also work with partial matches * the ? and * wildcards are supported
92 lines
2.7 KiB
PHP
92 lines
2.7 KiB
PHP
<?php
|
|
|
|
if (!defined('AOWOW_REVISION'))
|
|
die('invalid access');
|
|
|
|
$pageData = array(
|
|
'items' => null,
|
|
'summary' => '[]'
|
|
);
|
|
$compareString = '';
|
|
|
|
// prefer $_GET over $_COOKIE
|
|
if (!empty($_GET['compare']))
|
|
$compareString = $_GET['compare'];
|
|
else if (!empty($_COOKIE['compare_groups']))
|
|
$compareString = urldecode($_COOKIE['compare_groups']);
|
|
|
|
if ($compareString)
|
|
{
|
|
$sets = explode(";", $compareString);
|
|
$items = [];
|
|
foreach ($sets as $set)
|
|
{
|
|
$itemsting = explode(":", $set);
|
|
$outString = [];
|
|
foreach ($itemsting as $substring)
|
|
{
|
|
$params = explode(".", $substring);
|
|
$items[] = (int)$params[0];
|
|
while (sizeof($params) < 7)
|
|
$params[] = 0;
|
|
|
|
$outString[] = $params;
|
|
|
|
// MATCH() AGAINST() for integers would be nice...
|
|
$res = DB::Aowow()->SelectRow(
|
|
"SELECT id FROM ?_itemset WHERE
|
|
item1 = ? OR item2 = ? OR item3 = ? OR item4 = ? OR item5 = ? OR
|
|
item6 = ? OR item7 = ? OR item8 = ? OR item9 = ? OR item10 = ?",
|
|
(int)$params[0], (int)$params[0], (int)$params[0], (int)$params[0], (int)$params[0], (int)$params[0], (int)$params[0], (int)$params[0], (int)$params[0], (int)$params[0]
|
|
);
|
|
|
|
if ($res)
|
|
$piecesAssoc[(int)$params[0]] = $res['id'];
|
|
}
|
|
$outSet[] = $outString;
|
|
}
|
|
$pageData['summary'] = json_encode($outSet, JSON_NUMERIC_CHECK);
|
|
|
|
$iList = new ItemList(array(['i.entry', $items]));
|
|
$data = $iList->getListviewData(ITEMINFO_SUBITEMS | ITEMINFO_JSON);
|
|
foreach ($data as $id => $item)
|
|
{
|
|
while ($iList->id != $id)
|
|
$iList->iterate();
|
|
|
|
$pageData['items'][] = [
|
|
$id,
|
|
Util::jsEscape($iList->names[$id]),
|
|
$iList->getField('Quality'),
|
|
$iList->getField('icon'),
|
|
json_encode($item, JSON_NUMERIC_CHECK)
|
|
];
|
|
}
|
|
}
|
|
|
|
|
|
$page = array(
|
|
'title' => Lang::$compare['compare'],
|
|
'tab' => 1,
|
|
'reqCSS' => array(
|
|
array('path' => 'template/css/Summary.css', 'condition' => false),
|
|
array('path' => 'template/css/Summary_ie6.css', 'condition' => 'lte IE 6'),
|
|
),
|
|
'reqJS' => array(
|
|
array('path' => 'template/js/Draggable.js'),
|
|
array('path' => 'template/js/filters.js'),
|
|
array('path' => 'template/js/Summary.js'),
|
|
array('path' => 'template/js/swfobject.js'),
|
|
array('path' => '?data=weight-presets.gems.enchants.itemsets'),
|
|
),
|
|
);
|
|
|
|
|
|
$smarty->updatePageVars($page);
|
|
$smarty->assign('lvData', $pageData);
|
|
$smarty->assign('lang', array_merge(Lang::$main, Lang::$compare));
|
|
$smarty->assign('mysql', DB::Aowow()->getStatistics());
|
|
$smarty->display('compare.tpl');
|
|
|
|
?>
|