mirror of
https://github.com/Sarjuuk/aowow.git
synced 2025-11-29 15:58:16 +08:00
I'm not overly happy with passing the templateObject to each typeObject, but it works .. for now. Effectively this should reduce db-lookups as each type should be looked up only twice at max (once for relevant data on the page and maybe again to get related jsGlobals for the template) also removed BaseType::addRewardsToJscript() get it with BaseType::addGlobalsToJscript() and the appropriate addMask * added ListviewHelper::getSetFields() wich is more appropriate in some cases (like reagents for spells should be shown even if they are all the same) * load bricks as needed, removed the if-blocks (maybe add the filename to every TypeClass..?)
203 lines
6.2 KiB
PHP
203 lines
6.2 KiB
PHP
<?php
|
|
|
|
if (!defined('AOWOW_REVISION'))
|
|
die('illegal access');
|
|
|
|
class WorldEventList extends BaseType
|
|
{
|
|
public static $type = TYPE_WORLDEVENT;
|
|
|
|
protected $setupQuery = 'SELECT *, -e.id AS ARRAY_KEY, -e.id as id FROM ?_events e LEFT JOIN ?_holidays h ON e.holidayId = h.id WHERE [cond] ORDER BY -e.id ASC';
|
|
protected $matchQuery = 'SELECT COUNT(1) FROM ?_events e LEFT JOIN ?_holidays h ON e.holidayId = h.id WHERE [cond]';
|
|
|
|
public function __construct($data)
|
|
{
|
|
parent::__construct($data);
|
|
|
|
// unseting elements while we iterate over the array will cause the pointer to reset
|
|
$replace = [];
|
|
|
|
// post processing
|
|
while ($this->iterate())
|
|
{
|
|
// emulate category
|
|
$sT = $this->curTpl['scheduleType'];
|
|
if (!$this->curTpl['holidayId'])
|
|
$this->curTpl['category'] = 0;
|
|
else if ($sT == 2)
|
|
$this->curTpl['category'] = 3;
|
|
else if (in_array($sT, [0, 1]))
|
|
$this->curTpl['category'] = 2;
|
|
else if ($sT == -1)
|
|
$this->curTpl['category'] = 1;
|
|
|
|
// preparse requisites
|
|
if ($this->curTpl['requires'])
|
|
$this->curTpl['requires'] = explode(' ', $this->curTpl['requires']);
|
|
|
|
// change Ids if holiday is set
|
|
if ($this->curTpl['holidayId'] > 0)
|
|
{
|
|
$this->curTpl['id'] = $this->curTpl['holidayId'];
|
|
$this->curTpl['name'] = $this->getField('name', true);
|
|
$replace[$this->id] = $this->curTpl;
|
|
unset($this->curTpl['description']);
|
|
}
|
|
else // set a name if holiday is missing
|
|
{
|
|
// template
|
|
$this->curTpl['name_loc0'] = $this->curTpl['description'];
|
|
$this->curTpl['iconString'] = 'trade_engineering';
|
|
$this->curTpl['name'] = '(SERVERSIDE) '.$this->getField('description', true);
|
|
$replace[$this->id] = $this->curTpl;
|
|
}
|
|
}
|
|
|
|
foreach ($replace as $old => $data)
|
|
{
|
|
unset($this->templates[$old]);
|
|
$this->templates[$data['id']] = $data;
|
|
}
|
|
$this->reset();
|
|
}
|
|
|
|
public static function getName($id)
|
|
{
|
|
if ($id > 0)
|
|
$row = DB::Aowow()->SelectRow('SELECT * FROM ?_holidays WHERE Id = ?d', intVal($id));
|
|
else
|
|
$row = DB::Aowow()->SelectRow('SELECT description as name FROM ?_events WHERE Id = ?d', intVal(-$id));
|
|
|
|
return Util::localizedString($row, 'name');
|
|
}
|
|
|
|
public static function updateDates($start, $end, $occurence, $final = 5000000000) // in the far far FAR future..
|
|
{
|
|
if (!$start)
|
|
{
|
|
return array(
|
|
'start' => 0,
|
|
'end' => 0,
|
|
'nextStart' => 0,
|
|
'nextEnd' => 0
|
|
);
|
|
}
|
|
|
|
// Convert everything to seconds
|
|
$start = intVal($start);
|
|
$end = intVal($end);
|
|
$occurence = intVal($occurence);
|
|
$final = intVal($final);
|
|
|
|
$now = time();
|
|
$year = date("Y", $now);
|
|
|
|
$curStart = $start;
|
|
$curEnd = $end;
|
|
$nextStart = $curStart + $occurence;
|
|
$nextEnd = $curEnd + $occurence;
|
|
|
|
while ($nextEnd <= $final && date("Y", $nextEnd) <= $year && $curEnd <= $now)
|
|
{
|
|
$curStart = $nextStart;
|
|
$curEnd = $nextEnd;
|
|
$nextStart = $curStart + $occurence;
|
|
$nextEnd = $curEnd + $occurence;
|
|
}
|
|
|
|
return array(
|
|
'start' => $curStart,
|
|
'end' => $curEnd,
|
|
'nextStart' => $nextStart,
|
|
'nextEnd' => $nextEnd
|
|
);
|
|
}
|
|
|
|
public function getListviewData()
|
|
{
|
|
$data = [];
|
|
|
|
while ($this->iterate())
|
|
{
|
|
$data[$this->id] = array(
|
|
'category' => $this->curTpl['category'],
|
|
'id' => $this->id,
|
|
'name' => $this->getField('name', true),
|
|
'rec' => $this->curTpl['occurence'],
|
|
'startDate' => $this->curTpl['startTime'],
|
|
'endDate' => $this->curTpl['startTime'] + $this->curTpl['length']
|
|
);
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function addGlobalsToJScript(&$template, $addMask = 0)
|
|
{
|
|
while ($this->iterate())
|
|
{
|
|
$template->extendGlobalData(self::$type, [$this->id => array(
|
|
'name' => $this->getField('name', true),
|
|
'icon' => $this->curTpl['iconString']
|
|
)]);
|
|
}
|
|
}
|
|
|
|
public function renderTooltip() { }
|
|
}
|
|
|
|
/*
|
|
|
|
function event_name($events)
|
|
{
|
|
global $DB;
|
|
if (!$events || !is_array($events) || count($events) == 0)
|
|
return array();
|
|
|
|
$entries = arraySelectKey($events, 'entry');
|
|
|
|
$rows = $DB->select('
|
|
SELECT eventEntry AS entry, description AS name
|
|
FROM game_event
|
|
WHERE eventEntry IN (?a)',
|
|
$entries
|
|
);
|
|
|
|
// Merge original array with new information
|
|
$result = array();
|
|
foreach ($events as $event)
|
|
if (isset($event['entry']))
|
|
$result[$event['entry']] = $event;
|
|
|
|
if ($rows)
|
|
{
|
|
foreach ($rows as $event)
|
|
$result[$event['entry']] = array_merge($result[$event['entry']], $event);
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
function event_description($entry)
|
|
{
|
|
global $DB;
|
|
|
|
$result = event_infoline(array(array('entry' => $entry)));
|
|
if (is_array($result) && count($result) > 0)
|
|
$result = reset($result);
|
|
else
|
|
return NULL;
|
|
|
|
$result['period'] = sec_to_time(intval($result['occurence'])*60);
|
|
|
|
$result['npcs_guid'] = $DB->selectCol('SELECT guid FROM game_event_creature WHERE eventEntry=?d OR eventEntry=?d', $entry, -$entry);
|
|
$result['objects_guid'] = $DB->selectCol('SELECT guid FROM game_event_gameobject WHERE eventEntry=?d OR eventEntry=?d', $entry, -$entry);
|
|
$result['creatures_quests_id'] = $DB->select('SELECT id AS creature, quest FROM game_event_creature_quest WHERE eventEntry=?d OR eventEntry=?d GROUP BY quest', $entry, -$entry);
|
|
|
|
return $result;
|
|
}
|
|
|
|
*/
|
|
|
|
?>
|