2 include_once ("item_table.php");
3 include_once ("spell_table.php");
4 include_once ("talent_table.php");
5 include_once ("gameobject_table.php");
6 include_once ("enchant_table.php");
7 include_once("include/quest_data.php");
9 function getLPageOffset($page, $limit)
11 if ($page< 1)$page_seek = 0;
12 else $page_seek = ($page-1) * $limit;
16 function getPageOffset($page)
19 return getLPageOffset($page, $config['fade_limit']);
22 function generateLPage($totalRecords, $currentPage, $link, $limit, $colSpan)
24 $totalPage = floor($totalRecords /$limit+
0.9999);
25 if ($totalPage <=1) return;
28 echo "<tr><td colspan=$colSpan class=page>";
29 for ($i=1;$i<=$totalPage;$i++
)
31 if ($i!=$currentPage) printf($link, $i, $i);
32 else echo '<b><i>'.$i.' </i></b>';
37 function generatePage($totalRecords, $currentPage, $link, $colSpan)
40 generateLPage($totalRecords, $currentPage, $link, $config['fade_limit'], $colSpan);
43 function RenderError($text)
46 echo "$lang[error] - $text";
48 function money($many, $height=10)
52 $many = str_pad($many, 12, 0, STR_PAD_LEFT
);
59 $many = str_pad(-$many, 12, 0, STR_PAD_LEFT
);
62 $copper = intval(substr($many, -2));
63 $silver = intval(substr($many, -4, -2));
64 $gold = intval(substr($many, -11, -4));
66 if ($height!=14) $hstr = "height={$height}px";
67 if ($gold ) { $str.= "$gold<img $hstr src=images/gold.gif> "; }
68 if ($silver) { $str.= "$silver<img $hstr src=images/silver.gif> "; }
69 if ($copper) { $str.= "$copper<img $hstr src=images/copper.gif>"; }
73 function getTimeText($seconds)
77 if ($seconds < 0) {$text.= "$lang[minustime]";}
78 if ($seconds >=24*3600) {$text.= intval($seconds/(24*3600))." $lang[days]"; if ($seconds%
=24*3600) $text.=" ";}
79 if ($seconds >= 3600) {$text.= intval($seconds/3600)." $lang[hours]"; if ($seconds%
=3600) $text.=" ";}
80 if ($seconds >= 60) {$text.= intval($seconds/60)." $lang[min]"; if ($seconds%
=60) $text.=" ";}
81 if ($seconds > 0) {$text.= $seconds." $lang[sec]";}
85 // Ôóíêöèÿ ðàçäåëåíèÿ ñòðîêè ïî òî÷êå
86 function mergeStrByPoint($str, &$a, &$b)
89 if ($len == 0) {$a = -1; $b = -1; return;}
90 if ($x = strpos($str, '.'))
92 $a = intval(substr($str, 0, $x));
93 $b = intval(substr($str, $x +
1, $len - $x));
101 * Convert a PHP scalar, array or hash to JS scalar/array/hash. This function is
102 * an analog of json_encode(), but it can work with a non-UTF8 input and does not
103 * analyze the passed data. Output format must be fully JSON compatible.
105 * @param mixed $a Any structure to convert to JS.
106 * @return string JavaScript equivalent structure.
108 function php2js($a=false)
110 if (is_null($a)) return 'null';
111 if ($a === false) return 'false';
112 if ($a === true) return 'true';
115 // Always use "." for floats.
116 $a = str_replace(",", ".", strval($a));
118 // All scalars are converted to strings to avoid indeterminism.
119 // PHP's "1" and 1 are equal for all PHP operators, but
120 // JS's "1" and 1 are not. So if we pass "1" or 1 from the PHP backend,
121 // we should get the same result in the JS frontend (string).
122 // Character replacements for JSON.
123 static $jsonReplaces = array(
124 array("\\", "/", "\n", "\t", "\r", "\b", "\f", '"'),
125 array('\\\\', '\\/', '\\n', '\\t', '\\r', '\\b', '\\f', '\"')
127 return '"' . str_replace($jsonReplaces[0], $jsonReplaces[1], $a) . '"';
130 for ($i = 0, reset($a); $i < count($a); $i++
, next($a)) {
131 if (key($a) !== $i) {
139 $result[] = php2js($v);
141 return '[ ' . join(', ', $result) . ' ]'."\n";
143 foreach ($a as $k => $v) {
144 $result[] = php2js($k) . ': ' . php2js($v);
146 return '{ ' . join(', ', $result) . ' }';
151 function getListFromArray($array, $i, $mask, $href)
158 $data = @$array[$i]; if ($data == "") $data = "$i";
160 $text.="<a href=\"".sprintf($href, $i)."\">".$data."</a>";
171 // ñîñòàâëÿåò ñïèñîê c 0
172 function getListFromArray_0($array, $mask, $href="")
174 return getListFromArray($array, 0, $mask, $href);
176 // ñîñòàâëÿåò ñïèñîê c 1
177 function getListFromArray_1($array, $mask, $href="")
179 return getListFromArray($array, 1, $mask, $href);
182 function getExtendCost($excostid)
185 return $wDB->selectRow('-- CACHE: 1h
186 SELECT * FROM `wowd_item_ex_cost` WHERE `id` = ?d', $excostid);
189 function healthmanaex($hp)
191 echo number_format($hp);
194 function getLootList($lootId, $table, &$totalRecords, $offset=0, $count=0)
199 if ($count) $limit = "LIMIT $offset, $count";
200 $rows = $dDB->selectPage($totalRecords, "SELECT * FROM `$table`
202 GROUP BY IF (`mincountOrRef` < 0, `mincountOrRef`, `item`)
203 ORDER BY `groupid`, `ChanceOrQuestChance`>0, ABS(`ChanceOrQuestChance`) DESC $limit", $lootId);
206 foreach($rows as &$loot)
209 if ($loot['ChanceOrQuestChance'] == 0)
211 $group = $loot['groupid'];
213 foreach($rows as &$g)
214 if ($g['groupid'] == $group)
216 if ($g['ChanceOrQuestChance']>0) $chance+
=$g['ChanceOrQuestChance'];
219 $chance = round((100 - $chance) / $n, 3);
220 foreach($rows as &$g)
221 if ($g['groupid'] == $group && $g['ChanceOrQuestChance']==0)
222 $g['ChanceOrQuestChance'] =$chance;
224 if ($loot['mincountOrRef'] < 0)
228 $loot['item'] = getLootList(-$loot['mincountOrRef'], "reference_loot_template", $subcount);
229 $loot['maxcount'] = $dDB->selectCell("SELECT `maxcount` FROM `$table` WHERE `entry` = ?d AND `mincountOrRef` = ?d", $lootId, $loot['mincountOrRef']);
235 //******************************************************************************
236 // Ëîêàëèçàöèÿ äàííûõ
237 //******************************************************************************
238 function localiseCreature(&$creature)
240 global $dDB, $config;
241 $locale = $config['locales_lang'];
242 if ($locale == 0 OR @$creature['entry'] == 0)
244 $lang = $dDB->selectRow('-- CACHE: 1h
246 `name_loc'.$locale.'` AS `name`,
247 `subname_loc'.$locale.'` AS `subname`
248 FROM `locales_creature`
249 WHERE `entry` = ?d', $creature['entry']);
252 if ($lang['name']) $creature['name'] = $lang['name'];
253 if ($lang['subname']) $creature['subname'] = $lang['subname'];
257 function localiseGameobject(&$go)
259 global $dDB, $config;
260 $locale = $config['locales_lang'];
261 if ($locale == 0 OR $go['entry']==0)
263 $lang = $dDB->selectRow('-- CACHE: 1h
265 `name_loc'.$locale.'` AS `name`,
266 `castbarcaption_loc'.$locale.'` AS `cast_name`
267 FROM `locales_gameobject`
268 WHERE `entry` = ?d', $go['entry']);
271 if ($lang['name']) $go['name'] = $lang['name'];
272 if ($lang['cast_name']) $go['castBarCaption'] = $lang['cast_name'];
276 function localiseQuest(&$quest)
278 global $dDB, $config;
279 $locale = $config['locales_lang'];
280 if ($locale == 0 OR @$quest['entry']==0)
282 $lang = $dDB->selectRow('-- CACHE: 1h
284 `Title_loc'.$locale.'` as `Title`,
285 `Details_loc'.$locale.'` as `Details`,
286 `Objectives_loc'.$locale.'` as `Objectives`,
287 `OfferRewardText_loc'.$locale.'` as `OfferRewardText`,
288 `RequestItemsText_loc'.$locale.'` as `RequestItemsText`,
289 `EndText_loc'.$locale.'` as `EndText`,
290 `CompletedText_loc'.$locale.'` as `CompletedText`,
291 `ObjectiveText1_loc'.$locale.'` as `ObjectiveText1`,
292 `ObjectiveText2_loc'.$locale.'` as `ObjectiveText2`,
293 `ObjectiveText3_loc'.$locale.'` as `ObjectiveText3`,
294 `ObjectiveText4_loc'.$locale.'` as `ObjectiveText4`
295 FROM `locales_quest` WHERE `entry` = ?d', $quest['entry']);
298 if ($lang['Title']) $quest['Title'] = $lang['Title'];
299 if ($lang['Details']) $quest['Details'] = $lang['Details'];
300 if ($lang['Objectives']) $quest['Objectives'] = $lang['Objectives'];
301 if ($lang['OfferRewardText']) $quest['OfferRewardText'] = $lang['OfferRewardText'];
302 if ($lang['RequestItemsText'])$quest['RequestItemsText']= $lang['RequestItemsText'];
303 if ($lang['EndText']) $quest['EndText'] = $lang['EndText'];
304 if ($lang['CompletedText']) $quest['CompletedText'] = $lang['CompletedText'];
305 if ($lang['ObjectiveText1']) $quest['ObjectiveText1'] = $lang['ObjectiveText1'];
306 if ($lang['ObjectiveText2']) $quest['ObjectiveText2'] = $lang['ObjectiveText2'];
307 if ($lang['ObjectiveText3']) $quest['ObjectiveText3'] = $lang['ObjectiveText3'];
308 if ($lang['ObjectiveText4']) $quest['ObjectiveText4'] = $lang['ObjectiveText4'];
312 function localiseItem(&$item)
314 global $dDB, $config;
315 $locale = $config['locales_lang'];
316 if ($locale == 0 OR $item['entry']==0)
318 $lang = $dDB->selectRow('-- CACHE: 1h
320 `name_loc'.$locale.'` AS `name`,
321 `description_loc'.$locale.'` AS `desc`
323 WHERE `entry` = ?d', $item['entry']);
326 if ($lang['name']) $item['name'] = $lang['name'];
327 if ($lang['desc']) $item['description'] = $lang['desc'];
331 function getScalingStatDistribution($id)
334 return $wDB->selectRow('-- CACHE: 1h
335 SELECT * FROM `wowd_scaling_stat_distribution` WHERE `id` = ?d', $id);
337 function getScalingStatValues($level)
340 return $wDB->selectRow('-- CACHE: 1h
341 SELECT * FROM `wowd_scaling_stat_values` WHERE `level` = ?d', $level);
344 function getRandomSuffix($id)
347 return $wDB->selectRow('-- CACHE: 1h
348 SELECT * FROM `wowd_item_random_suffix` WHERE `id` = ?d', $id);
351 function getRandomProperty($id)
354 return $wDB->selectRow('-- CACHE: 1h
355 SELECT * FROM `wowd_item_random_propety` WHERE `id` = ?d', $id);
358 function getRandomPropertyPoint($level, $type, $quality)
360 if ($level < 0 OR $level > 300)
364 case 2: $field = "uncommon"; break; // ITEM_QUALITY_UNCOMMON
365 case 3: $field = "rare"; break; // ITEM_QUALITY_RARE
366 case 4: $field = "epic"; break; // ITEM_QUALITY_EPIC
372 case 0: // INVTYPE_NON_EQUIP:
373 case 18: // INVTYPE_BAG:
374 case 19: // INVTYPE_TABARD:
375 case 24: // INVTYPE_AMMO:
376 case 27: // INVTYPE_QUIVER:
377 case 28: // INVTYPE_RELIC:
379 case 1: // INVTYPE_HEAD:
380 case 4: // INVTYPE_BODY:
381 case 5: // INVTYPE_CHEST:
382 case 7: // INVTYPE_LEGS:
383 case 17: // INVTYPE_2HWEAPON:
384 case 20: // INVTYPE_ROBE:
387 case 3: // INVTYPE_SHOULDERS:
388 case 6: // INVTYPE_WAIST:
389 case 8: // INVTYPE_FEET:
390 case 10: // INVTYPE_HANDS:
391 case 12: // INVTYPE_TRINKET:
394 case 2: // INVTYPE_NECK:
395 case 9: // INVTYPE_WRISTS:
396 case 11: // INVTYPE_FINGER:
397 case 14: // INVTYPE_SHIELD:
398 case 16: // INVTYPE_CLOAK:
399 case 23: // INVTYPE_HOLDABLE:
402 case 13: // INVTYPE_WEAPON:
403 case 21: // INVTYPE_WEAPONMAINHAND:
404 case 22: // INVTYPE_WEAPONOFFHAND:
407 case 15: // INVTYPE_RANGED:
408 case 25: // INVTYPE_THROWN:
409 case 26: // INVTYPE_RANGEDRIGHT:
416 return $wDB->selectCell("-- CACHE: 1h
417 SELECT `$field` FROM `wowd_random_property_points` WHERE `itemlevel` = ?d", $level);
420 function getGlyph($entry)
423 return $wDB->selectRow('-- CACHE: 1h
424 SELECT * FROM `wowd_glyphproperties` WHERE `id` = ?d', $entry);
427 function getGlyphName($entry)
429 if ($g=getGlyph($entry))
430 return getSpellName(getSpell($g['SpellId']));
431 return 'Glyph_'.$entry;
434 function getLockTypeNames()
437 return $wDB->selectCol('-- CACHE: 1h
438 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_lock_type`');
441 function getLockType($id, $asref=1)
443 $l = getLockTypeNames();
444 $name = isset($l[$id]) ?
$l[$id] : 'Lock_type_'.$id;
446 return '<a href="?s=s&lock='.$id.'">'.$name.'</a>';
448 return '<a href="?s=o&lockSkill='.$id.'">'.$name.'</a>';
450 return '<a href="?s=o&lockItem='.$id.'">'.$name.'</a>';
455 function getLock($id)
458 return $wDB->selectRow('-- CACHE: 1h
459 SELECT * FROM `wowd_lock` WHERE `id` = ?d', $id);
463 function getSpellFocus($id)
466 return $wDB->selectRow('-- CACHE: 1h
467 SELECT * FROM `wowd_spellfocus` WHERE `id` = ?d', $id);
471 function getSpellFocusName($id, $reftype=0)
473 $focus = getSpellFocus($id);
476 if ($reftype == 1) return "<a href=?s=s&focus=$id>".$focus['name']."</a>";
477 if ($reftype == 2) return "<a href=?s=o&focus=$id>".$focus['name']."</a>";
478 return $focus['name'];
480 return "Spellfocus_$id";
484 function getSkillLineAbility($spellId)
487 return $wDB->selectRow('-- CACHE: 1h
488 SELECT * FROM `wowd_skill_line_ability` WHERE `spellId` = ?d', $spellId);
491 function getSkillLine($id)
494 return $wDB->selectRow('-- CACHE: 1h
495 SELECT * FROM `wowd_skill_line` WHERE `id` = ?d', $id);
498 function getSkillName($skillId, $as_ref=1)
500 $skillLine = getSkillLine($skillId);
504 return "<a href=\"?skill=$skillId\">".$skillLine['Name']."</a>";
506 return $skillLine['Name'];
511 function getSkillNameForSpell($spellId, $as_ref=1)
513 if ($SkillLineAbility = getSkillLineAbility($spellId))
514 return getSkillName($SkillLineAbility['skillId'], $as_ref);
518 function show_spell($entry, $iconId=0, $style=0)
522 $iconId = $wDB->selectCell('-- CACHE: 1h
523 SELECT `SpellIconID` FROM `wowd_spell` WHERE `id` = ?d', $entry);
524 $icon = getSpellIcon($iconId);
525 echo '<a href="?spell='.$entry.'"><img'.($style?
' class='.$style:'').' src="'.$icon.'"></a>';
529 function validateText($text)
531 $letter = array("'",'"' ,"<" ,">" ,">" ,"\r","\n" );
532 $values = array("`",'"',"<",">",">","" ,"<br>");
533 return str_replace($letter, $values, $text);
535 function addTooltip($text, $extra='')
537 if ($text=='') return '';
538 return 'onmouseover="Tip(\''.validateText($text).'\''.($extra?
','.$extra:'').');"';
541 function getSpellTargetPosition($id)
544 return $dDB->selectRow("SELECT * FROM `spell_target_position` WHERE `id` = ?d", $id);
547 function getSpellScriptTarget($id)
550 return $dDB->select("SELECT * FROM `spell_script_target` WHERE `entry` = ?d", $id);
553 function getEnchantment($enchantmentId)
556 return $wDB->selectRow('-- CACHE: 1h
557 SELECT * FROM `wowd_item_enchantment` WHERE `id` = ?d', $enchantmentId);
560 function getEnchantmentDesc($enchantment)
562 if ($enc = getEnchantment($enchantment))
563 return "<a href=?enchant=$enchantment>".validateText($enc['description'])."</a>";
564 return "Enchant $enchantment";
567 function getGemInfo($GemId)
570 return $wDB->selectRow('-- CACHE: 1h
571 SELECT * FROM `wowd_gemproperties` WHERE `id` = ?d', $GemId);
574 function getGemProperties($GemProperties)
576 if ($gem = getGemInfo($GemProperties))
577 return getEnchantmentDesc($gem['spellitemenchantement']);
578 return "Gem Properties id - $GemProperties";
581 //********************************************************************************
582 function getCreature($creature_id, $fields = "*")
585 if ($creature = $dDB->selectRow("-- CACHE: 1h
586 SELECT $fields FROM `creature_template` WHERE `entry` = ?d", $creature_id))
587 localiseCreature($creature);
591 function getCreatureName($creature_id, $as_ref=1)
593 if ($Creature=getCreature($creature_id, "`entry`, `name`"))
595 if ($Creature['name']=="") $Creature['name'] = "npc_$creature_id";
597 return "<a href=?npc=".$Creature['entry'].">".$Creature['name']."</a>";
598 return $Creature['name'];
600 return "Unknown creature - $creature_id";
603 function getCreatureRank($rank, $as_ref=1)
605 global $gCreatureRank;
606 $name = @$gCreatureRank[$rank];
607 if (empty($name)) $name = "Rank_".$rank;
609 return "<a href=\"?s=n&rank=$rank\">".$name."</a>";
613 function getCreatureFamilyNames()
616 return $wDB->selectCol('-- CACHE: 1h
617 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_creature_family`');
620 function getCreatureFamily($family, $as_ref=1)
622 $l = getCreatureFamilyNames();
623 $name = isset($l[$family]) ?
$l[$family] : 'family_'.$family;
625 return '<a href="?s=n&family='.$family.'">'.$name.'</a>';
630 function getCreatureTypeNames()
633 return $wDB->selectCol('-- CACHE: 1h
634 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_creature_type`');
637 function getCreatureType($i, $as_ref=1)
639 $t = getCreatureTypeNames();
640 $name = isset($t[$i]) ?
$t[$i] : 'Type_'.$i;
642 return '<a href="?s=n&type='.$i.'">'.$name.'</a>';
646 function getCreatureTypeList($mask, $as_ref=1)
648 $t = getCreatureTypeNames();
650 return getListFromArray_1($t, $mask, "?s=n&type=%d");
651 return getListFromArray_1($t, $mask);
654 function getCreatureCount($creature_id)
657 return $dDB->selectCell("SELECT count(*) FROM `creature` WHERE `id` = ?d", $creature_id);
660 function getCreatureFlagName($flag, $as_ref=1)
662 global $gCreatureFlags;
664 return '<a href="?s=n&flag='.$flag.'">'.@$gCreatureFlags[$flag].'</a>';
665 return @$gCreatureFlags[$flag];
668 function getCreatureFlagsList($mask, $as_ref=1)
670 global $gCreatureFlags;
672 return getListFromArray_0($gCreatureFlags, $mask, "?s=n&flag=%d");
673 return getListFromArray_0($gCreatureFlags, $mask);
676 function getCreatureRewRate($faction_id)
679 $creature = $dDB->selectCell("-- CACHE: 1h
680 SELECT `creature_rate` FROM `reputation_reward_rate` WHERE `faction` = ?d", $faction_id);
686 function getCreatureEvent($creature_guid)
689 return $dDB->selectCell("-- CACHE: 1h
690 SELECT `event` FROM `game_event_creature` WHERE `guid` = ?d", $creature_guid);
693 function getCreaturePool($creature_guid)
696 return $dDB->selectCell("-- CACHE: 1h
697 SELECT `pool_entry` FROM `pool_creature` WHERE `guid` = ?d", $creature_guid);
700 function getCreaturePoolTemplate($creature_id)
703 return $dDB->selectCell("-- CACHE: 1h
704 SELECT `pool_entry` FROM `pool_creature_template` WHERE `id` = ?d", $creature_id);
706 //********************************************************************************
707 function getGameobject($gameobject_id, $fields="*")
710 if ($go = $dDB->selectRow("-- CACHE: 1h
711 SELECT $fields FROM `gameobject_template` WHERE `entry` = ?d", $gameobject_id))
712 localiseGameobject($go);
715 function getGameobjectName($gameobject_id, $as_ref=1)
717 if ($gameobject=getGameobject($gameobject_id, "`entry`, `name`"))
719 if (empty($gameobject['name'])) $gameobject['name'] = "go_$gameobject_id";
721 return "<a href=?object=".$gameobject['entry'].">".$gameobject['name']."</a>";
722 return $gameobject['name'];
724 return "Unknown go - $gameobject_id";
727 function getGameobjectType($i, $as_ref=1)
729 global $gameobjectType;
730 $type = @$gameobjectType[$i];
734 return "<a href=?s=o&type=".$i.">".$type."</a>";
740 function getGameobjectCount($gameobject_id)
743 return $dDB->selectCell("SELECT count(*) FROM `gameobject` WHERE `id` = ?d", $gameobject_id);
746 function getGameobjectEvent($gameobject_guid)
749 return $dDB->selectCell("-- CACHE: 1h
750 SELECT `event` FROM `game_event_gameobject` WHERE `guid` = ?d", $gameobject_guid);
753 function getGameobjectPool($gameobject_guid)
756 return $dDB->selectCell("-- CACHE: 1h
757 SELECT `pool_entry` FROM `pool_gameobject` WHERE `guid` = ?d", $gameobject_guid);
760 function getGameobjectPoolTemplate($gameobject_id)
763 return $dDB->selectCell("-- CACHE: 1h
764 SELECT `pool_entry` FROM `pool_gameobject_template` WHERE `id` = ?d", $gameobject_id);
766 //********************************************************************************
767 function getFaction($faction_id, $fields="*")
770 return $wDB->selectRow("-- CACHE: 1h
771 SELECT $fields FROM `wowd_faction` WHERE `id` = ?d", $faction_id);
773 function getFactionName($faction_id, $as_ref=1)
775 if ($faction = getFaction($faction_id, "`name`"))
776 $name = $faction['name'];
778 $name = "Faction ($faction_id)";
780 $name = '<a href="?faction='.$faction_id.'">'.$name.'</a>';
784 function getFactionTemplate($faction_id)
787 return $wDB->selectRow('-- CACHE: 1h
788 SELECT * FROM `wowd_faction_template` WHERE `id` = ?d', $faction_id);
791 function getFactionTemplateName($faction_id)
795 if ($faction_template = getFactionTemplate($faction_id))
796 return getFactionName($faction_template['faction']);
797 return "Faction template - $faction_id";
800 function getBaseReputationForFaction($faction, $race, $class)
802 if (empty($faction)) return 0;
803 $racemask = 1<<($race -1);
804 $classmask = 1<<($class-1);
806 if ($faction['BaseRepRaceMask_'.$i] & $racemask AND
807 ($faction['BaseRepClassMask_'.$i] == 0 OR $faction['BaseRepClassMask_'.$i] & $classmask))
808 return $faction['BaseRepValue_'.$i];
811 function getBaseReputationFlagForFaction($faction, $race, $class)
813 if (empty($faction)) return 0;
814 $racemask = 1<<($race -1);
815 $classmask = 1<<($class-1);
817 if ($faction['BaseRepRaceMask_'.$i] & $racemask AND
818 ($faction['BaseRepClassMask_'.$i] == 0 OR $faction['BaseRepClassMask_'.$i] & $classmask))
819 return $faction['ReputationFlags_'.$i];
822 function getReputationRankName($rep)
824 global $gReputationRank;
825 $text = @$gReputationRank[$rep];
827 $text = "Err Rep Rank $rep";
830 function getReputationDataFromReputation($rep)
832 global $gReputationRank;
834 $gRepStep = array(36000, 3000, 3000, 3000, 6000, 12000, 21000, 1000);
835 $current = $gBaseRep;
836 for ($i=0;$i<8;$current+
=$gRepStep[$i],$i++
)
837 if ($current +
$gRepStep[$i] > $rep)
838 return array('rank'=>$i, 'rank_name'=>$gReputationRank[$i], 'rep'=>$rep - $current, 'max'=>$gRepStep[$i]);
839 return array('rank'=>7, 'rank_name'=>$gReputationRank[7], 'rep'=>$gRepStep[7], 'max'=>$gRepStep[7]);
841 function getFactionType($id)
843 global $gFactionType;
844 return $gFactionType[$id];
847 function getArea($Zone_id, $fields="*")
850 return $wDB->selectRow("-- CACHE: 1h
851 SELECT $fields FROM `wowd_zones` WHERE `id` = ?d", $Zone_id);
854 function getAreaName($Zone_id, $as_ref=1)
856 $zone = getArea($Zone_id, '`name`');
859 $name = $zone['name'];
861 $name = '<a href="?zone='.$Zone_id.'">'.$name.'</a>';
864 $name = "Unknown area - $Zone_id";
868 function getFullAreaName($Zone_id, $as_ref=1)
870 $zone = getArea($Zone_id, '`name`, `zone_id`');
873 $name = $zone['name'];
875 $name = '<a href="?zone='.$Zone_id.'">'.$name.'</a>';
876 if ($zone['zone_id'])
877 $name = getAreaName($zone['zone_id'], $as_ref).' - '.$name;
880 $name = "Unknown area - $Zone_id";
884 function getMapName($id)
887 $l = $wDB->selectCol('-- CACHE: 1h
888 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_map`');
889 return isset($l[$id]) ?
$l[$id] : 'map_'.$id;
892 FACTION_MASK_PLAYER = 1, // any player
893 FACTION_MASK_ALLIANCE = 2, // player or creature from alliance team
894 FACTION_MASK_HORDE = 4, // player or creature from horde team
895 FACTION_MASK_MONSTER = 8 // aggressive creature from monster team
897 function getLoyality($faction_id)
899 $faction_template=getFactionTemplate($faction_id);
900 if (!$faction_template)
903 if ($faction_template['friendlyMask'])
905 $loyality.= '<span class=friendly>';
906 if ($faction_template['friendlyMask']&1) $loyality.='AH';
909 if ($faction_template['friendlyMask']&2) $loyality.='A';
910 if ($faction_template['friendlyMask']&4) $loyality.='H';
911 // if ($faction_template[friendlyMask]&8) $loyality.='M';
913 $loyality.= '</span>';
915 if ($faction_template['hostileMask'])
917 $loyality.= '<span class=hostile>';
918 if ($faction_template['hostileMask']&1) $loyality.='AH';
921 if ($faction_template['hostileMask']&2) $loyality.='A';
922 if ($faction_template['hostileMask']&4) $loyality.='H';
923 // if ($faction_template['hostileMask']&8) $loyality.='M';
925 $loyality.= '</span>';
927 if (($faction_template['friendlyMask']&7)==0 && ($faction_template['hostileMask']&7) == 0)
929 $loyality.='<span class=neitral>AH</span>';
934 //********************************************************************************
935 function getQuest($quest_id, $fields = "*")
937 global $dDB, $config;
938 $quest = $dDB->selectRow("-- CACHE: 1h
939 SELECT $fields FROM `quest_template` WHERE `entry` = ?d", $quest_id);
941 localiseQuest($quest);
945 function getQuestName($quest_id, $ashref=1)
947 if ($quest = getQuest($quest_id, "`entry`, `Title`"))
949 if (empty($quest['Title'])) $quest['Title'] = "quest_$quest_id";
951 return "<a href=?quest=".$quest['entry'].">".$quest['Title']."</a>";
952 return $quest['Title'];
954 return "Unknown quest - $quest_id";
957 function getQuestOld($quest_id)
960 return $dDB->selectCell("-- CACHE: 1h
961 SELECT `entry` FROM `quest_template` WHERE (`Title` LIKE '%<CHANGE TO GOSSIP>%' OR `Title` LIKE '%EPRECATE%' OR `Title` LIKE '%DEPRICATED%' OR `Title` LIKE '%REUSE%' OR `Title` LIKE '%<NYI>%' OR `Title` LIKE '%COPY' OR `Title` LIKE '%UNUSED%' OR `Title` LIKE '%<TXT>%' OR `Title` LIKE '%ZZOLD%' OR `Title` LIKE '%[PH]%' OR `Title` LIKE '%[%') AND `entry` = ?d", $quest_id);
964 function getQuestSort($sort)
967 $q = $wDB->selectCol('-- CACHE: 1h
968 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_quest_sort`');
969 return isset($q[$sort]) ?
$q[$sort] : 'Sort_'.$sort;
972 function getQuestType($type)
975 $q = $wDB->selectCol('-- CACHE: 1h
976 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_quest_info`');
977 return isset($q[$type]) ?
$q[$type] : 'Info_'.$type;
980 function getNumPalayersCompletedQuest($entry)
983 return $cDB->selectCell("SELECT count(*) FROM `character_queststatus` WHERE `quest` = '$entry' AND `status` = '1' AND `rewarded`='1'");
986 function getNumPalayersWithThisQuest($entry)
989 return $cDB->selectCell("SELECT count(*) FROM `character_queststatus` WHERE quest = '$entry' AND (`status` = '0' OR `status` = '3')");
992 function getQuestXPValue($quest)
994 if ($quest['QuestLevel'] > 0)
995 $rawXPcount=getRewQuestXP($quest['QuestLevel']);
997 $rawXPcount=getRewQuestXP(79);
999 foreach ($rawXPcount as $field)
1001 $realXP = $field['Field'.($quest['RewXPId']+
1)];
1006 function getRewQuestXP($questlevel_id)
1009 return $wDB->select("-- CACHE: 1h
1010 SELECT * FROM `wowd_questxp` WHERE `id` = ?d", $questlevel_id);
1013 function getRepRewRate($faction_id)
1016 $faction = $dDB->selectCell("-- CACHE: 1h
1017 SELECT `quest_rate` FROM `reputation_reward_rate` WHERE `faction` = ?d", $faction_id);
1023 function getRepSpillover($faction_id)
1026 return $dDB->select("-- CACHE: 1h
1027 SELECT * FROM `reputation_spillover_template` WHERE `faction` = ?d", $faction_id);
1030 function getGameEventQuest($quest_id)
1033 return $dDB->selectCell("-- CACHE: 1h
1034 SELECT `event` FROM `game_event_quest` WHERE `quest` = ?d", $quest_id);
1037 function getGameEventName($event_id)
1040 return $dDB->selectCell("-- CACHE: 1h
1041 SELECT `description` FROM `game_event` WHERE `entry` = ?d", $event_id);
1044 function getGameEventActive()
1047 return $cDB->select("SELECT `event` FROM `game_event_status`");
1050 function getGameEventActiveName($event_id)
1053 return $dDB->selectCell("-- CACHE: 1h
1054 SELECT `holiday` FROM `game_event` WHERE `entry` = ?d", $event_id);
1057 function getGameHolidayName($holiday_id)
1060 return $dDB->selectCell("-- CACHE: 1h
1061 SELECT `description` FROM `game_event` WHERE `holiday` = ?d", $holiday_id);
1064 function getTeamContributionPoints($level_id)
1067 return $wDB->selectCell("-- CACHE: 1h
1068 SELECT `Field1` FROM `wowd_teamcontributionpoints` WHERE `id` = ?d", $level_id);
1071 function getNpcQuestrelation($npc_id)
1074 return $dDB->selectCell("SELECT count(*) FROM `creature_questrelation` WHERE `id` = ?d", $npc_id);
1077 function getNpcInvolvedrelation($npc_id)
1080 return $dDB->selectCell("SELECT count(*) FROM `creature_involvedrelation` WHERE `id` = ?d", $npc_id);
1082 //********************************************************************************
1094 function getItem($item_id, $fields = "*")
1096 global $dDB, $config;
1097 $item = $dDB->selectRow("-- CACHE: 1h
1098 SELECT $fields FROM `item_template` WHERE `entry` = ?d", $item_id);
1100 localiseItem($item);
1104 function getItemName($item_id)
1106 $item = getItem($item_id, "`entry`, `name`");
1108 return $item['name'];
1109 return "Unknown item - $item_id";
1112 function getItemFlags2($item_id)
1114 global $dDB, $config;
1115 $item = $dDB->selectCell("-- CACHE: 1h
1116 SELECT `Flags2` FROM `item_template` WHERE `entry` = ?d", $item_id);
1120 function getItemMail($item_id)
1122 global $dDB, $config;
1123 $item = $dDB->selectCell("-- CACHE: 1h
1124 SELECT `item` FROM `mail_loot_template` WHERE `entry` = ?d", $item_id);
1128 function getItemBonusText($i, $amount)
1131 $text = @$iBonus[$i];
1132 if ($text == "") $text = "Err stat $i - %d";
1133 if ($i >=0 && $i < 8 && $amount > 0)
1134 return sprintf("+".$text, $amount);
1135 return sprintf($text, $amount);
1138 function getInventoryType($i, $as_ref=1)
1140 global $gInventoryType;
1141 $name = @$gInventoryType[$i];
1142 if ($name=="") $name = "InvType_$i";
1144 return "<a href=\"?s=i&type=$i\">".$name."</a>";
1148 function getInventoryTypeList($mask, $as_ref=1)
1150 global $gInventoryType;
1152 return getListFromArray_0($gInventoryType, $mask, "?s=i&type=%d");
1153 return getListFromArray_0($gInventoryType, $mask);
1156 function getClassName($class, $as_ref=1)
1158 global $itemClassSubclass;
1160 return "<a href=\"?s=i&class=$class\">".$itemClassSubclass["$class"]."</a>";
1162 return $itemClassSubclass["$class"];
1165 function getSubclassName($class,$subclass, $as_ref=1)
1167 global $itemClassSubclass;
1170 $names = explode(":",$itemClassSubclass["$class"."."."$subclass"]);
1171 if (@$names[1]) $name = $names[1];
1172 else $name = $names[0];
1174 return "<a href=\"?s=i&class=$class.$subclass\">".$name."</a>";
1178 return getClassName($class, $as_ref);
1181 function getShortSubclassName($class,$subclass, $as_ref=1)
1183 global $itemClassSubclass;
1186 $names = explode(":",$itemClassSubclass["$class"."."."$subclass"]);
1189 return "<a href=\"?s=i&class=$class.$subclass\">".$name."</a>";
1193 return getClassName($class, $as_ref);
1196 function getSubclassList($class, $mask, $as_ref=1)
1204 if ($mask & 1) {$text.=getSubclassName($class,$i,$as_ref);if ($mask!=1) $text.=", ";}
1211 function getSpellIconName($icon_id)
1214 $name = $wDB->selectCell('-- CACHE: 1h
1215 SELECT `name` FROM `wowd_spellicon` WHERE `id` = ?d', $icon_id);
1216 if ($name) return strtolower($name.'.jpg');
1217 else return 'wowunknownitem01.jpg';
1220 $bwicon_mode = false;
1221 function setBwIconMode() {global $bwicon_mode; $bwicon_mode = true;}
1222 function unsetBwIconMode() {global $bwicon_mode; $bwicon_mode = false;}
1224 function getSpellIcon($icon_id)
1226 global $wDB, $bwicon_mode;
1227 if ($bwicon_mode){$dir = 'bwicons';$g_bwicon_mode = 0;}
1228 else $dir = 'icons';
1229 return 'images/'.$dir.'/'.getSpellIconName($icon_id);
1233 function getItemIconName($icon_id)
1236 $name = $wDB->selectCell('-- CACHE: 1h
1237 SELECT `name` FROM `wowd_itemicon` WHERE `id` = ?d', $icon_id);
1238 if ($name) return strtolower($name.'.jpg');
1239 else return 'wowunknownitem01.jpg';
1242 function getItemIcon($icon_id)
1244 global $wDB, $bwicon_mode;
1245 if ($bwicon_mode){$dir = 'bwicons';$g_bwicon_mode = 0;}
1246 else $dir = 'icons';
1247 return 'images/'.$dir.'/'.getItemIconName($icon_id);
1250 function getItemIconFromItemId($item_id)
1252 global $dDB, $bwicon_mode;
1253 if ($icon = $dDB->selectCell("SELECT `displayid` FROM `item_template` WHERE `entry` = ?d", $item_id))
1254 return getItemIcon($icon, $bwicon_mode);
1255 return 'images/icons/wowunknownitem01.jpg';
1258 function getItemIconFromItemData($item_data)
1260 if ($item = getItem($item_data[ITEM_FIELD_ENTRY
]))
1261 return getItemIcon($item['displayid']);
1262 return 'images/icons/wowunknownitem01.jpg';
1265 function getItemSet($item_set_id)
1268 return $wDB->selectRow('-- CACHE: 1h
1269 SELECT * FROM `wowd_itemset` WHERE `id` = ?d', $item_set_id);
1272 function getItemData($guid)
1275 return explode(' ', $cDB->selectCell("SELECT `data` FROM `item_instance` WHERE `guid` = ?d", $guid));
1278 function getRecipeItem($recipe)
1281 if ($recipe['spellid_1'] == 483)
1283 // Ïîëó÷àåì ñïåëë êîòîðîìó îáó÷àåò
1284 $spell = getSpell($recipe['spellid_2']);
1285 if ($spell = getSpell($recipe['spellid_2']))
1286 return getItem($spell['EffectItemType_1']);
1291 function getCount($count)
1293 if ($count>1) return "($count)";
1297 function getRecipeReqString($spell)
1300 if ($spell['Reagent_1']) $text.=getItemName($spell['Reagent_1']).getCount($spell['ReagentCount_1']);
1301 if ($spell['Reagent_2']) $text.=", ".getItemName($spell['Reagent_2']).getCount($spell['ReagentCount_2']);
1302 if ($spell['Reagent_3']) $text.=", ".getItemName($spell['Reagent_3']).getCount($spell['ReagentCount_3']);
1303 if ($spell['Reagent_4']) $text.=", ".getItemName($spell['Reagent_4']).getCount($spell['ReagentCount_4']);
1304 if ($spell['Reagent_5']) $text.=", ".getItemName($spell['Reagent_5']).getCount($spell['ReagentCount_5']);
1305 if ($spell['Reagent_6']) $text.=", ".getItemName($spell['Reagent_6']).getCount($spell['ReagentCount_6']);
1306 if ($spell['Reagent_7']) $text.=", ".getItemName($spell['Reagent_7']).getCount($spell['ReagentCount_7']);
1307 if ($spell['Reagent_8']) $text.=", ".getItemName($spell['Reagent_8']).getCount($spell['ReagentCount_8']);
1311 function text_show_item($entry, $iconId = 0, $style = 0)
1313 global $dDB, $config;
1315 $iconId = $dDB->selectCell('-- CACHE: 1h
1316 SELECT `displayid` FROM `item_template` WHERE `entry` = ?d', $entry);
1317 $icon = getItemIcon($iconId);
1318 $text = '<a href="?item='.$entry.'"><img'.($style?
' class='.$style:'').' src="'.$icon.'"></a>';
1322 function show_item($entry, $iconId = 0, $style = 'item')
1324 echo text_show_item($entry, $iconId, $style);
1327 function getborderText($text, $posx = 'left', $dx=0, $posy = 'top', $dy=0)
1330 "<div style=\"position: absolute; $posx: ".($dx-1)."px; $posy: ".($dy-1)."px; color: black;\">$text</div>
1331 <div style=\"position: absolute; $posx: ".($dx-1)."px; $posy: ".($dy+
1)."px; color: black;\">$text</div>
1332 <div style=\"position: absolute; $posx: ".($dx+
1)."px; $posy: ".($dy-1)."px; color: black;\">$text</div>
1333 <div style=\"position: absolute; $posx: ".($dx+
1)."px; $posy: ".($dy+
1)."px; color: black;\">$text</div>
1334 <div style=\"position: absolute; $posx: ".($dx )."px; $posy: ".($dy-1)."px; color: black;\">$text</div>
1335 <div style=\"position: absolute; $posx: ".($dx )."px; $posy: ".($dy+
1)."px; color: black;\">$text</div>
1336 <div style=\"position: absolute; $posx: ".($dx-1)."px; $posy: ".($dy )."px; color: black;\">$text</div>
1337 <div style=\"position: absolute; $posx: ".($dx+
1)."px; $posy: ".($dy )."px; color: black;\">$text</div>
1338 <div style=\"position: absolute; $posx: ".($dx )."px; $posy: ".($dy )."px; color: white;\">$text</div>";
1340 function show_item_by_data($item_data, $style='item', $posx=0, $posy=0)
1342 $guid = $item_data[ITEM_FIELD_GUID
];
1344 if (@$item_data[ITEM_FIELD_TYPE
] == TYPE_ITEM
)
1345 $count = $item_data[ITEM_FIELD_STACK_COUNT
];
1346 else if (@$item_data[ITEM_FIELD_TYPE
] == TYPE_CONTAINER
)
1347 $count = $item_data[CONTAINER_FIELD_NUM_SLOTS
];
1352 $position.= 'style="position: absolute; left: '.$posx.'px; top: '.$posy.'px; border: 0px;"';
1353 $icon = getItemIconFromItemData($item_data);
1356 echo '<a style="float: left;" href="?item=g'.$guid.'">';
1357 echo "<img class=$style src='$icon' $position></a>";
1361 if (empty($position))
1362 $position = "style=\"position: relative; left: 0px;top: 0px; border: 0px;float: left;\"";
1363 echo "\n<div class=$style $position>";
1364 echo '<a href="?item=g'.$guid.'"><img class="'.$style.'" src="'.$icon.'"></a>';
1365 echo getborderText($count, 'right', 3, 'bottom', 1);
1370 function show_item_by_guid($guid, $style='item', $posx=0, $posy=0)
1374 if ($item_data = getItemData($guid))
1375 show_item_by_data($item_data, $style, $posx, $posy);
1378 function show_item_from_char($id, $guid, $style='item', $posx=0, $posy=0)
1383 $item_data = $cDB->selectCell("SELECT `guid` FROM `item_instance` WHERE `owner_guid`=?d AND (SUBSTRING_INDEX( SUBSTRING_INDEX(`data` , ' ' , 9) , ' ' , -1 )+0)=?d AND (SUBSTRING_INDEX( SUBSTRING_INDEX(`data` , ' ' , 4) , ' ' , -1 )+0)=$id", $guid, $guid, $id);
1384 if ($item_data = getItemData($item_data))
1385 show_item_by_data($item_data, $style, $posx, $posy);
1388 function getConditionItem($condition_id)
1391 return $dDB->select("-- CACHE: 1h
1392 SELECT * FROM `conditions` WHERE `condition_entry` = ?d", $condition_id);
1395 //********************************************************************************
1396 function getGuild($id)
1399 return $cDB->selectRow('-- CACHE: 1h
1400 SELECT * FROM `guild` WHERE `guildid` = ?d', $id);
1403 function getGuildName($id)
1406 $name = $cDB->selectCell('-- CACHE: 1h
1407 SELECT `name` FROM `guild` WHERE `guildid` = ?d', $id);
1408 return $name ?
$name : 'Unknown';
1411 function getGuildRankList($id)
1414 $rows = $cDB->select('-- CACHE: 1h
1415 SELECT * FROM `guild_rank` WHERE `guildid` = ?d ORDER BY `rid`', $id);
1418 foreach ($rows as $rank)
1419 $rankList[$rank['rid']] = $rank;
1422 //********************************************************************************
1423 function getCharacter($character_id, $fields = "*")
1426 return $cDB->selectRow("-- CACHE: 1h
1427 SELECT $fields FROM `characters` WHERE `guid` = ?d", $character_id);
1430 function getCharacterStats($character_id, $fields = "*")
1433 return $cDB->selectRow("-- CACHE: 1h
1434 SELECT $fields FROM `character_stats` WHERE `guid` = ?d", $character_id);
1437 function getCharacterName($character_id)
1440 $c = getCharacter($character_id, $fields = '`name`');
1441 return $c ?
$c['name'] : 'Unknown';
1444 function getGender($gender)
1446 global $gGenderType;
1447 return $gGenderType[$gender];
1450 function getClassNames()
1453 return $wDB->selectCol('-- CACHE: 1h
1454 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_chr_classes`');
1457 function getClass($class)
1459 $l = getClassNames();
1460 return isset($l[$class]) ?
$l[$class] : 'class_'.$class;
1463 function getAllowableClass($mask)
1466 // Return zero if for all class (or for none
1467 if ($mask == 0x5FF OR $mask == 0)
1469 return getListFromArray_1(getClassNames(), $mask);
1472 function getQAllowableClass($mask)
1475 // Return zero if for all class (or for none
1476 if ($mask == 0x5FF OR $mask == 0)
1478 return getListFromArray_1(getClassNames(), $mask, "?s=q&RedClass=%d");
1482 function getRaceNames()
1485 return $wDB->selectCol('-- CACHE: 1h
1486 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_chr_races`');
1489 function getRace($race)
1491 $l = getRaceNames();
1492 return isset($l[$race]) ?
$l[$race] : 'race_'.$race;
1495 function getAllowableRace($mask)
1498 // Return zero if for all class (or for none
1499 if ($mask == 0x7FF OR $mask == 0)
1501 return getListFromArray_1(getRaceNames(), $mask);
1504 function getRating($level)
1507 return $wDB->selectRow('-- CACHE: 1h
1508 SELECT * FROM `wowd_rating` WHERE `level` = ?d', $level);
1511 //********************************************************************************
1512 function getPlayerFaction($race)
1515 $l = $wDB->selectCol('-- CACHE: 1h
1516 SELECT `id` AS ARRAY_KEY, `team` FROM `wowd_chr_races`');
1517 return isset($l[$race]) ?
$l[$race] : 2;
1519 function getFactionImage($race)
1521 $faction = getPlayerFaction($race);
1523 return "images/player_info/factions_img/alliance.gif";
1525 return "images/player_info/factions_img/horde.gif";
1529 function getRaceImage($race, $genderid)
1531 return "images/player_info/race_img/".$race."_".$genderid.".gif";
1534 function getClassImage($class)
1536 return "images/player_info/class_img/".$class.".gif";
1539 function getFamilyImage($family)
1542 $l = $wDB->selectCol('-- CACHE: 1h
1543 SELECT `id` AS ARRAY_KEY, `icon` FROM `wowd_creature_family`');
1544 if (isset($l[$family]))
1545 return "images/icons/".strtolower($l[$family]).".jpg";
1546 return "images/icons/wowunknownitem01.jpg";
1548 function getStatTypeName($i)
1551 return isset($gStatType[$i]) ?
$gStatType[$i] : "Stat ($i)";
1554 function getResistance($i)
1556 global $gResistance;
1557 return isset($gResistance[$i]) ?
$gResistance[$i] : "Resistance ($i)";
1560 function getResistanceText($i, $amount)
1562 global $gResistanceType;
1563 $text = @$gResistanceType[$i];
1564 if ($text == "") $text = "Err resist $i - %d";
1565 if ($i >=0 && $i < 7 && $amount > 0)
1566 return sprintf("+".$text, $amount);
1567 return sprintf($text, $amount);
1570 function getSkillRank($i)
1573 return @$gSkillRank[$i];
1575 function getTalentName($id)
1578 $l = $wDB->selectCol('-- CACHE: 1h
1579 SELECT `id` AS ARRAY_KEY, `name` FROM `wowd_talent_tab`');
1580 return isset($l[$id]) ?
$l[$id] : 'talent_'.$id;