Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
 
 
 

335 строки
7.9 KiB

  1. define([
  2. 'js/system/events',
  3. 'js/system/client',
  4. 'html!ui/templates/equipment/template',
  5. 'css!ui/templates/equipment/styles'
  6. ], function(
  7. events,
  8. client,
  9. template,
  10. styles
  11. ) {
  12. return {
  13. tpl: template,
  14. centered: true,
  15. modal: true,
  16. stats: null,
  17. equipment: null,
  18. hoverItem: null,
  19. hoverEl: null,
  20. hoverCompare: null,
  21. shiftDown: false,
  22. postRender: function() {
  23. this.onEvent('onGetStats', this.onGetStats.bind(this));
  24. this.onEvent('onGetItems', this.onGetItems.bind(this));
  25. this.onEvent('onShowEquipment', this.toggle.bind(this));
  26. this.find('.tab').on('click', this.onTabClick.bind(this));
  27. this.onEvent('onKeyDown', this.onKeyDown.bind(this));
  28. this.onEvent('onKeyUp', this.onKeyUp.bind(this));
  29. },
  30. toggle: function(show) {
  31. this.shown = !this.el.is(':visible');
  32. if (this.shown) {
  33. this.find('.itemList').hide();
  34. this.show();
  35. this.onGetStats();
  36. this.onGetItems();
  37. } else {
  38. this.find('.itemList').hide();
  39. this.hide();
  40. }
  41. this.onHoverItem(null, null, null);
  42. },
  43. onKeyDown: function(key) {
  44. if (key == 'j')
  45. this.toggle();
  46. else if (key == 'shift') {
  47. this.shiftDown = true;
  48. if (this.hoverItem)
  49. this.onHoverItem(this.hoverEl, this.hoverItem, this.hoverCompare);
  50. }
  51. },
  52. onKeyUp: function(key) {
  53. if (key == 'shift') {
  54. this.shiftDown = false;
  55. if (this.hoverItem)
  56. this.onHoverItem(this.hoverEl, this.hoverItem, null);
  57. }
  58. },
  59. onTabClick: function(e) {
  60. this.find('.tab.selected').removeClass('selected');
  61. $(e.currentTarget).addClass('selected');
  62. this.onGetStats(this.stats);
  63. },
  64. onGetItems: function(items) {
  65. items = items || this.items;
  66. this.items = items;
  67. this.find('.slot').addClass('empty');
  68. var skipSpellId = 0;
  69. this.find('[slot]')
  70. .removeData('item')
  71. .addClass('empty')
  72. .find('.icon')
  73. .off()
  74. .css('background', '')
  75. .on('click', this.buildSlot.bind(this));
  76. items
  77. .filter(function(item) {
  78. var spellId = item.spellId;
  79. if ((spellId != null) && (item.slot))
  80. skipSpellId = spellId;
  81. return ((item.eq) && ((item.slot) || (item.spellId != null)));
  82. }, this)
  83. .forEach(function(item) {
  84. var imgX = -item.sprite[0] * 64;
  85. var imgY = -item.sprite[1] * 64;
  86. var slot = item.slot;
  87. if (!slot) {
  88. var spellId = item.spellId;
  89. if (spellId > skipSpellId)
  90. spellId--;
  91. slot = 'rune-' + spellId;
  92. }
  93. var spritesheet = item.spritesheet || '../../../images/items.png';
  94. var elSlot = this.find('[slot="' + slot + '"]');
  95. elSlot
  96. .data('item', item)
  97. .removeClass('empty')
  98. .find('.icon')
  99. .css('background', 'url("' + spritesheet + '") ' + imgX + 'px ' + imgY + 'px')
  100. .off()
  101. .on('mousemove', this.onHoverItem.bind(this, elSlot, item, null))
  102. .on('mouseleave', this.onHoverItem.bind(this, null, null))
  103. .on('click', this.buildSlot.bind(this, elSlot));
  104. }, this);
  105. },
  106. buildSlot: function(el) {
  107. if (el.currentTarget)
  108. el = $(el.currentTarget).parent();
  109. var slot = el.attr('slot');
  110. var isRune = (slot.indexOf('rune') == 0);
  111. var container = this.find('.itemList')
  112. .empty()
  113. .show();
  114. this.hoverCompare = el.data('item');
  115. var items = this.items
  116. .filter(function(item) {
  117. if (isRune)
  118. return ((!item.slot) && (item.spell) && (!item.eq));
  119. else
  120. return ((item.slot == slot) && (!item.eq));
  121. }, this);
  122. items.splice(0, 0, {
  123. name: 'None',
  124. slot: this.hoverCompare ? this.hoverCompare.slot : null,
  125. id: this.hoverCompare ? this.hoverCompare.id : null,
  126. empty: true
  127. });
  128. if (this.hoverCompare)
  129. items.splice(1, 0, this.hoverCompare);
  130. items
  131. .forEach(function(item) {
  132. var sprite = item.sprite || [7, 0];
  133. var spriteSheet = item.empty ? '../../../images/uiIcons.png' : item.spritesheet || '../../../images/items.png';
  134. var imgX = -sprite[0] * 64;
  135. var imgY = -sprite[1] * 64;
  136. var el = $('<div class="slot"><div class="icon"></div></div>')
  137. .appendTo(container);
  138. el
  139. .find('.icon')
  140. .css('background', 'url("' + spriteSheet + '") ' + imgX + 'px ' + imgY + 'px')
  141. .on('mousemove', this.onHoverItem.bind(this, el, item, null))
  142. .on('mouseleave', this.onHoverItem.bind(this, null, null))
  143. .on('click', this.equipItem.bind(this, item));
  144. if (item == this.hoverCompare)
  145. el.find('.icon').addClass('eq');
  146. }, this);
  147. if (items.length == 0)
  148. container.hide();
  149. },
  150. equipItem: function(item) {
  151. if (item == this.hoverCompare) {
  152. this.find('.itemList').hide();
  153. return;
  154. }
  155. var cpn = 'equipment';
  156. var method = 'equip';
  157. var data = item.id;
  158. if (item.empty)
  159. method = 'unequip';
  160. if (!item.slot) {
  161. cpn = 'inventory';
  162. method = 'learnAbility';
  163. data = {
  164. id: item.id,
  165. replaceId: this.hoverCompare ? this.hoverCompare.id : null
  166. };
  167. if (item.empty) {
  168. if (!this.hoverCompare) {
  169. this.find('.itemList').hide();
  170. return;
  171. }
  172. else
  173. data = this.hoverCompare.id;
  174. }
  175. }
  176. client.request({
  177. cpn: 'player',
  178. method: 'performAction',
  179. data: {
  180. cpn: cpn,
  181. method: method,
  182. data: data
  183. }
  184. });
  185. this.find('.itemList').hide();
  186. },
  187. onHoverItem: function(el, item, compare, e) {
  188. if (el) {
  189. this.hoverItem = item;
  190. this.hoverEl = el;
  191. var ttPos = null;
  192. if (e) {
  193. ttPos = {
  194. x: ~~(e.clientX + 32),
  195. y: ~~(e.clientY)
  196. };
  197. }
  198. events.emit('onShowItemTooltip', item, ttPos, this.hoverCompare, false, this.shiftDown);
  199. } else {
  200. events.emit('onHideItemTooltip', this.hoverItem);
  201. this.hoverItem = null;
  202. }
  203. },
  204. onGetStats: function(stats) {
  205. stats = stats || this.stats;
  206. this.stats = stats;
  207. var container = this.el.find('.stats');
  208. container
  209. .children('*:not(.tabs)')
  210. .remove();
  211. var xpRemaining = (stats.xpMax - stats.xp).toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',');
  212. var newStats = {
  213. basic: {
  214. level: stats.level,
  215. 'next level': xpRemaining + 'xp',
  216. gap1: '',
  217. gold: 0, //window.player.trade.gold,
  218. gap2: '',
  219. hp: ~~stats.hp + '/' + stats.hpMax,
  220. mana: ~~stats.mana + '/' + stats.manaMax,
  221. 'hp regen': stats.regenHp,
  222. 'mana regen': stats.regenMana + '%',
  223. gap3: '',
  224. str: stats.str,
  225. int: stats.int,
  226. dex: stats.dex
  227. },
  228. offense: {
  229. 'crit chance': (~~(stats.critChance * 10) / 10) + '%',
  230. gap1: '',
  231. 'arcane increase': stats.elementArcanePercent + '%',
  232. 'fire increase': stats.elementFirePercent + '%',
  233. 'frost increase': stats.elementFrostPercent + '%',
  234. 'holy increase': stats.elementHolyPercent + '%',
  235. 'physical increase': stats.elementPhysicalPercent + '%',
  236. 'poison increase': stats.elementPoisonPercent + '%',
  237. gap2: '',
  238. 'damage increase': stats.dmgPercent + '%'
  239. },
  240. defense: {
  241. armor: stats.armor,
  242. gap1: '',
  243. 'arcane resist': stats.elementArcaneResist,
  244. 'fire resist': stats.elementFireResist,
  245. 'frost resist': stats.elementFrostResist,
  246. 'holy resist': stats.elementHolyResist,
  247. 'physical resist': stats.elementPhysicalResist,
  248. 'poison resist': stats.elementPoisonResist,
  249. gap2: '',
  250. 'all resist': stats.elementAllResist
  251. },
  252. misc: {
  253. 'magic find': stats.magicFind,
  254. gap1: '',
  255. 'sprint chance': (stats.sprintChance || 0) + '%',
  256. gap2: '',
  257. 'xp increase': stats.xpIncrease + '%',
  258. }
  259. }[this.find('.tab.selected').html()];
  260. for (var s in newStats) {
  261. var label = s + ': ';
  262. var value = newStats[s];
  263. var isGap = false;
  264. if (label.indexOf('gap') == 0) {
  265. isGap = true;
  266. label = '';
  267. value = '';
  268. }
  269. var row = $('<div class="stat"><font class="q0">' + label + '</font><font color="#999">' + value + '</font></div>')
  270. .appendTo(container);
  271. if (s == 'gold')
  272. row.addClass('gold');
  273. else if ((s == 'level') || (s == 'next level'))
  274. row.addClass('blueText');
  275. if (isGap)
  276. row.addClass('empty');
  277. }
  278. }
  279. };
  280. });