mirror of
https://github.com/Sarjuuk/aowow.git
synced 2025-12-01 21:15:20 +08:00
features: - tool - Maps: * finally supports multi-layered zones * should also support icons if needed (questgiver, ect) - tool - Item Comparison: * fully functional (yes, that includes heirlooms and items with random props) * may throw a minor js-error if using arrow-keys/esc/ret in input-fields in the LightboxPopus (but wowhead does also) * icons for prismatic sockets are not displayed if no other sockets are present (calculation is correct though) * modelviewer will still 'call home' - tool - Talent Calculator: * got rid of a VERY dirty hack for the icons (they are now supplied as texture, not laoded one at a time) * glyphs should also be a bit more informative * talent data is pulled from static file, that should a) speed up load and b) prevent lockups if it cant be generated on the fly * you can now set the level for your build, which affects available talent points, glyphs and glyph-slots - tool - Pet Calculator: * initial implementation; basically the same as the Talent Calculator - general concept changed: * dropped ajax.php; json is now supplied by the appropriate page if &json is appended to the url * search.php and opensearch.php are being merged; again, output will depend on the appended parameter (&openserach, &json) * data included via data.php will be static and assembled only on installation and when the database changes (should speed up load) * locale strings are now in a single file instead of being split up to the template * still getting rid of criss-cross-includes, global variables and string-defines
81 lines
1.7 KiB
PHP
81 lines
1.7 KiB
PHP
<?php
|
|
/**
|
|
* Smarty plugin
|
|
* @package Smarty
|
|
* @subpackage plugins
|
|
*/
|
|
|
|
|
|
/**
|
|
* Smarty {counter} function plugin
|
|
*
|
|
* Type: function<br>
|
|
* Name: counter<br>
|
|
* Purpose: print out a counter value
|
|
* @author Monte Ohrt <monte at ohrt dot com>
|
|
* @link http://smarty.php.net/manual/en/language.function.counter.php {counter}
|
|
* (Smarty online manual)
|
|
* @param array parameters
|
|
* @param Smarty
|
|
* @return string|null
|
|
*/
|
|
function smarty_function_counter($params, &$smarty)
|
|
{
|
|
static $counters = array();
|
|
|
|
$name = (isset($params['name'])) ? $params['name'] : 'default';
|
|
if (!isset($counters[$name])) {
|
|
$counters[$name] = array(
|
|
'start'=>1,
|
|
'skip'=>1,
|
|
'direction'=>'up',
|
|
'count'=>1
|
|
);
|
|
}
|
|
$counter =& $counters[$name];
|
|
|
|
if (isset($params['start'])) {
|
|
$counter['start'] = $counter['count'] = (int)$params['start'];
|
|
}
|
|
|
|
if (!empty($params['assign'])) {
|
|
$counter['assign'] = $params['assign'];
|
|
}
|
|
|
|
if (isset($counter['assign'])) {
|
|
$smarty->assign($counter['assign'], $counter['count']);
|
|
}
|
|
|
|
if (isset($params['print'])) {
|
|
$print = (bool)$params['print'];
|
|
} else {
|
|
$print = empty($counter['assign']);
|
|
}
|
|
|
|
if ($print) {
|
|
$retval = $counter['count'];
|
|
} else {
|
|
$retval = null;
|
|
}
|
|
|
|
if (isset($params['skip'])) {
|
|
$counter['skip'] = $params['skip'];
|
|
}
|
|
|
|
if (isset($params['direction'])) {
|
|
$counter['direction'] = $params['direction'];
|
|
}
|
|
|
|
if ($counter['direction'] == "down")
|
|
$counter['count'] -= $counter['skip'];
|
|
else
|
|
$counter['count'] += $counter['skip'];
|
|
|
|
return $retval;
|
|
|
|
}
|
|
|
|
/* vim: set expandtab: */
|
|
|
|
?>
|