You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

script.js 22 kB

7 years ago
7 years ago
7 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665
  1. var ms = null;
  2. var language = null;
  3. var memberTeamObj = function(){
  4. return {id:0,level:0,awoken:0,plus:[0,0,0],latent:[]};
  5. }
  6. var memberAssistObj = function(){
  7. return {id:0,level:0,awoken:0,plus:[0,0,0]};
  8. }
  9. var teamObj = function(){
  10. return [
  11. [
  12. {id:0},
  13. {id:0},
  14. {id:0},
  15. {id:0},
  16. {id:0},
  17. ],
  18. [
  19. {id:0},
  20. {id:0},
  21. {id:0},
  22. {id:0},
  23. {id:0},
  24. ],
  25. ];
  26. }
  27. var formation = {
  28. title:"",
  29. detail:"",
  30. team:[
  31. new teamObj(),//队伍A
  32. new teamObj(),//队伍B
  33. ]
  34. };
  35. window.onload = function()
  36. {
  37. //添加语言列表
  38. var controlBox = document.body.querySelector(".control-box");
  39. var langList = controlBox.querySelector(".languages");
  40. languageList.forEach(function(l){
  41. var langOpt = new Option(l.name,l.i18n);
  42. langList.options.add(langOpt);
  43. })
  44. var language_i18n = getQueryString("lang"); //获取参数指定的语言
  45. var browser_i18n = (navigator.language||navigator.userLanguage); //获取浏览器语言
  46. var hasLanguage = languageList.filter(function(l){
  47. if (language_i18n) //如果已指定就用指定的语言
  48. return language_i18n.indexOf(l.i18n)>=0;
  49. else
  50. return browser_i18n.indexOf(l.i18n)>=0;
  51. });
  52. language = hasLanguage.length?hasLanguage[hasLanguage.length-1]:languageList[0];
  53. document.head.querySelector("#language-css").href = "languages/"+language.i18n+".css";
  54. Array.prototype.slice.call(langList.options).some(function(lOpt){
  55. if (lOpt.value == language.i18n)
  56. {
  57. lOpt.selected = true;
  58. return true;
  59. }
  60. });
  61. GM_xmlhttpRequest({
  62. method: "GET",
  63. url:"monsters-info/mon.json",
  64. onload: function(response) {
  65. ms = JSON.parse(response.response);
  66. initialize();//初始化
  67. try
  68. {
  69. var idataQer = getQueryString("data");
  70. if (idataQer)
  71. {
  72. var idata = JSON.parse(idataQer);
  73. formation = idata;
  74. refreshAll(formation);
  75. }
  76. }catch(e)
  77. {
  78. console.log("初始数据解码出错",e);
  79. }
  80. },
  81. onerror: function(response) {
  82. console.error("怪物数据获取错误",response);
  83. try
  84. {
  85. ms = JSON.parse(response.response);
  86. initialize();//初始化
  87. var idataQer = getQueryString("data");
  88. if (idataQer)
  89. {
  90. var idata = JSON.parse(idataQer);
  91. formation = idata;
  92. refreshAll(formation);
  93. }
  94. }catch(e)
  95. {
  96. console.log("尝试解码Chrome错误返回失败。或初始数据解码出错。",e);
  97. }
  98. }
  99. });
  100. }
  101. window.onpopstate = function()
  102. { //前进后退时修改页面
  103. try
  104. {
  105. var idataQer = getQueryString("data");
  106. if (idataQer)
  107. {
  108. var idata = JSON.parse(idataQer);
  109. formation = idata;
  110. refreshAll(formation);
  111. }
  112. }catch(e)
  113. {
  114. console.log("初始数据解码出错",e);
  115. }
  116. }
  117. //创建新的分享地址
  118. function creatNewUrl(lang){
  119. if (!!(window.history && history.pushState)) {
  120. // 支持History API
  121. var language_i18n = lang || getQueryString("lang"); //获取参数指定的语言
  122. history.pushState(null, null, '?' + (language_i18n?'lang=' + language_i18n + '&':'') + 'data=' + encodeURIComponent(JSON.stringify(formation)));
  123. }
  124. }
  125. //初始化
  126. function initialize()
  127. {
  128. var monstersList = document.querySelector("#monsters-list");
  129. ms.forEach(function(m){
  130. var opt = monstersList.appendChild(document.createElement("option"));
  131. opt.value = m.id;
  132. opt.label = m.id + " - " + language.searchlist.map(function(lc){ //取出每种语言
  133. return m.name[lc];
  134. }).filter(function(ln){ //去掉空值
  135. return ln.length>0;
  136. }).join(" | ");
  137. });
  138. //标题和介绍文本框
  139. var txtTitle = document.querySelector(".title-box .title");
  140. var txtDetail = document.querySelector(".detail-box .detail");
  141. txtTitle.onchange = function(){
  142. formation.title = this.value;
  143. creatNewUrl();
  144. }
  145. txtDetail.onchange = function(){
  146. formation.detail = this.value;
  147. creatNewUrl();
  148. }
  149. txtDetail.onblur = function(){
  150. this.style.height=this.scrollHeight+"px";
  151. }
  152. //队伍框
  153. var formationBox = document.querySelector(".formation-box");
  154. formationBox.formationBox = formation;
  155. //编辑框
  156. var editBox = document.querySelector(".edit-box");
  157. editBox.latent = []; //储存潜在觉醒
  158. editBox.assist = false; //储存是否为辅助宠物
  159. editBox.monsterBox = null;
  160. editBox.latentBox = null;
  161. editBox.memberIdx = []; //储存队伍数组下标
  162. editBox.show = function(){
  163. editBox.classList.remove("display-none");
  164. formationBox.classList.add("blur-bg");
  165. }
  166. editBox.hide = function(){
  167. editBox.classList.add("display-none");
  168. formationBox.classList.remove("blur-bg");
  169. }
  170. var settingBox = editBox.querySelector(".setting-box")
  171. //id搜索
  172. var monstersSearch = editBox.querySelector(".edit-box .m-id");
  173. monstersSearch.onchange = function(){
  174. if (/^\d+$/.test(this.value))
  175. {
  176. editBoxChangeMonId(parseInt(this.value));
  177. }
  178. }
  179. monstersSearch.oninput = monstersSearch.onchange;
  180. //觉醒
  181. var monEditAwokens = Array.prototype.slice.call(settingBox.querySelectorAll(".m-awoken-ul>.awoken-icon"));
  182. monEditAwokens.forEach(function(akDom,idx,domArr){
  183. akDom.onclick = function(){
  184. if (idx>0 && idx>=domArr.filter(function(d){return !d.classList.contains("display-none")}).length-1)
  185. domArr[0].innerHTML = "★";
  186. else
  187. domArr[0].innerHTML = idx;
  188. for(var ai=1;ai<domArr.length;ai++)
  189. {
  190. if(ai<=idx)
  191. {
  192. if(domArr[ai].classList.contains("unselected-awoken"))
  193. domArr[ai].classList.remove("unselected-awoken");
  194. }
  195. else
  196. {
  197. if(!domArr[ai].classList.contains("unselected-awoken"))
  198. domArr[ai].classList.add("unselected-awoken");
  199. }
  200. }
  201. }
  202. })
  203. //等级
  204. var monEditLv = settingBox.querySelector(".m-level");
  205. var monEditLvMax = settingBox.querySelector(".m-level-btn-max");
  206. monEditLvMax.onclick = function(){
  207. monEditLv.value = this.value;
  208. }
  209. //加蛋
  210. var monEditAddHp = settingBox.querySelector(".m-plus-hp");
  211. var monEditAddAtk = settingBox.querySelector(".m-plus-atk");
  212. var monEditAddRcv = settingBox.querySelector(".m-plus-rcv");
  213. var monEditAddHp99 = settingBox.querySelector(".m-plus-hp-btn-99");
  214. monEditAddHp99.onclick = function(){monEditAddHp.value = this.value}
  215. var monEditAddAtk99 = settingBox.querySelector(".m-plus-atk-btn-99");
  216. monEditAddAtk99.onclick = function(){monEditAddAtk.value = this.value}
  217. var monEditAddRcv99 = settingBox.querySelector(".m-plus-rcv-btn-99");
  218. monEditAddRcv99.onclick = function(){monEditAddRcv.value = this.value}
  219. var monEditAdd297 = settingBox.querySelector(".m-plus-btn-297");
  220. monEditAdd297.onclick = function(){monEditAddHp.value = monEditAddAtk.value = monEditAddRcv.value = 99}
  221. //潜觉
  222. var monEditLatentUl = settingBox.querySelector(".m-latent-ul");
  223. var monEditLatents = Array.prototype.slice.call(monEditLatentUl.querySelectorAll("li"));
  224. var monEditLatentAllowableUl = settingBox.querySelector(".m-latent-allowable-ul");
  225. var monEditLatentsAllowable = Array.prototype.slice.call(monEditLatentAllowableUl.querySelectorAll("li"));
  226. function refreshLatent(latent) //刷新潜觉
  227. {
  228. if (this.value<0) return;
  229. var usedHoleN = usedHole(latent);
  230. for (var ai=0;ai<6;ai++)
  231. {
  232. if (latent[ai])
  233. {
  234. monEditLatents[ai].className = "latent-icon latent-icon-" + latent[ai];
  235. monEditLatents[ai].value = ai;
  236. }
  237. else if(ai<(6-usedHoleN+latent.length))
  238. {
  239. monEditLatents[ai].className = "latent-icon";
  240. monEditLatents[ai].value = -1;
  241. }
  242. else
  243. {
  244. monEditLatents[ai].className = "display-none";
  245. monEditLatents[ai].value = -1;
  246. }
  247. }
  248. }
  249. editBox.refreshLatent = refreshLatent;
  250. //已有觉醒的去除
  251. monEditLatents.forEach(function(l){
  252. l.onclick = function(){
  253. var aIdx = parseInt(this.value);
  254. editBox.latent.splice(aIdx,1);
  255. refreshLatent(editBox.latent);
  256. }
  257. })
  258. //可选觉醒的添加
  259. monEditLatentsAllowable.forEach(function(la){
  260. la.onclick = function(){
  261. if (this.classList.contains("unselected-latent")) return;
  262. var lIdx = parseInt(this.value);
  263. var usedHoleN = usedHole(editBox.latent);
  264. if (lIdx >= 12 && usedHoleN<=4)
  265. editBox.latent.push(lIdx);
  266. else if (lIdx < 12 && usedHoleN<=5)
  267. editBox.latent.push(lIdx);
  268. refreshLatent(editBox.latent);
  269. }
  270. })
  271. var btnCancel = editBox.querySelector(".button-cancel");
  272. var btnDone = editBox.querySelector(".button-done");
  273. var btnNull = editBox.querySelector(".button-null");
  274. var btnDelay = editBox.querySelector(".button-delay");
  275. btnCancel.onclick = function(){
  276. btnDone.classList.remove("cant-assist");
  277. btnDone.disabled = false;
  278. editBox.memberIdx = [];
  279. editBox.hide();
  280. }
  281. btnDone.onclick = function(){
  282. if (parseInt(monEditLv.value) == 0)
  283. {
  284. btnNull.onclick();
  285. return;
  286. }
  287. var mD = formation.team[editBox.memberIdx[0]][editBox.memberIdx[1]][editBox.memberIdx[2]] = editBox.assist?new memberAssistObj():new memberTeamObj();
  288. mD.id = parseInt(monstersSearch.value);
  289. mD.level = parseInt(monEditLv.value);
  290. mD.awoken = monEditAwokens.filter(function(akDom){
  291. return !akDom.classList.contains("unselected-awoken") && !akDom.classList.contains("display-none")
  292. }).length - 1;
  293. if (ms[mD.id].type.some(function(t){return t == 0 || t == 12 || t == 14 || t == 15;}) && [303,305,307,600,602].indexOf(mD.id)<0)
  294. { //当4种特殊type的时候是无法297和打觉醒的,但是5种小企鹅可以
  295. mD.plus = [0,0,0];
  296. }else
  297. {
  298. mD.plus[0] = parseInt(monEditAddHp.value) || 0;
  299. mD.plus[1] = parseInt(monEditAddAtk.value) || 0;
  300. mD.plus[2] = parseInt(monEditAddRcv.value) || 0;
  301. if (!editBox.assist)
  302. { //如果不是辅助,则可以设定潜觉
  303. mD.latent = editBox.latent.concat();
  304. }
  305. }
  306. changeid(mD,editBox.monsterBox,editBox.latentBox);
  307. creatNewUrl();
  308. editBox.hide();
  309. }
  310. btnNull.onclick = function(){
  311. var mD = formation.team[editBox.memberIdx[0]][editBox.memberIdx[1]][editBox.memberIdx[2]] = {id:0};
  312. changeid(mD,editBox.monsterBox,editBox.latentBox);
  313. creatNewUrl();
  314. editBox.hide();
  315. }
  316. btnDelay.onclick = function(){ //应对威吓
  317. var mD = formation.team[editBox.memberIdx[0]][editBox.memberIdx[1]][editBox.memberIdx[2]] = {id:-1};
  318. changeid(mD,editBox.monsterBox,editBox.latentBox);
  319. creatNewUrl();
  320. editBox.hide();
  321. }
  322. var controlBox = document.body.querySelector(".control-box");
  323. var langList = controlBox.querySelector(".languages");
  324. langList.onchange = function(){
  325. creatNewUrl(this.value);
  326. history.go();
  327. }
  328. /*添对应语言执行的JS*/
  329. var languageJS = document.head.appendChild(document.createElement("script"));
  330. languageJS.id = "language-js";
  331. languageJS.type = "text/javascript";
  332. languageJS.src = "languages/"+language.i18n+".js";
  333. }
  334. //计算用了多少潜觉格子
  335. function usedHole(latent)
  336. {
  337. return latent.reduce(function(previous,current){
  338. return previous + (current>= 12?2:1);
  339. },0);
  340. }
  341. //改变一个怪物头像
  342. function changeid(mon,monDom,latentDom)
  343. {
  344. var md = ms[mon.id]; //怪物固定数据
  345. if (mon.id<0) //如果是延迟
  346. {
  347. monDom.parentNode.classList.add("delay");
  348. monDom.parentNode.classList.remove("null");
  349. return;
  350. }else if (mon.id==0) //如果是空
  351. {
  352. monDom.parentNode.classList.add("null");
  353. monDom.parentNode.classList.remove("delay");
  354. return;
  355. }else (mon.id>-1) //如果提供了id
  356. {
  357. monDom.parentNode.classList.remove("null");
  358. monDom.parentNode.classList.remove("delay");
  359. monDom.className = "monster";
  360. monDom.classList.add("pet-cards-" + Math.ceil(mon.id/100)); //添加图片编号
  361. var idxInPage = (mon.id-1) % 100; //获取当前页面的总序号
  362. monDom.classList.add("pet-cards-index-x-" + idxInPage % 10); //添加X方向序号
  363. monDom.classList.add("pet-cards-index-y-" + parseInt(idxInPage / 10)); //添加Y方向序号
  364. monDom.querySelector(".property").className = "property property-" + md.ppt[0]; //主属性
  365. monDom.querySelector(".subproperty").className = "subproperty subproperty-" + md.ppt[1]; //副属性
  366. monDom.title = "No." + mon.id + " " + md.name[language.searchlist[0]] || md.name["ja"];
  367. monDom.href = mon.id.toString().replace(/^(\d+)$/ig,language.guideURL);
  368. }
  369. if (mon.level>0) //如果提供了等级
  370. {
  371. var levelDom = monDom.querySelector(".level");
  372. levelDom.innerHTML = mon.level;
  373. if (mon.level == 99 || (mon.level >= md.maxLevel && md.maxLevel <=99))
  374. {
  375. levelDom.classList.add("max");
  376. }else
  377. {
  378. levelDom.classList.remove("max");
  379. }
  380. if (md.maxLevel>99 && mon.level>=99)
  381. levelDom.classList.add("_110");
  382. else
  383. levelDom.classList.remove("_110");
  384. }
  385. if (mon.awoken>-1) //如果提供了觉醒
  386. {
  387. var awokenIcon = monDom.querySelector(".awoken-count");
  388. if (mon.awoken == 0 || md.awoken.length < 1) //没觉醒
  389. {
  390. awokenIcon.classList.add("display-none");
  391. awokenIcon.innerHTML = "";
  392. }else
  393. {
  394. awokenIcon.classList.remove("display-none");
  395. if (mon.awoken < md.awoken.length) //觉醒没满直接写数字
  396. {
  397. awokenIcon.innerHTML = mon.awoken;
  398. awokenIcon.classList.remove("allowable-assist");
  399. }else //满觉醒打星星
  400. {
  401. awokenIcon.innerHTML = "★";
  402. if (md.assist)
  403. awokenIcon.classList.add("allowable-assist");
  404. else
  405. awokenIcon.classList.remove("allowable-assist");
  406. }
  407. }
  408. refreshAwokenCount(formation.team);
  409. }
  410. if (mon.plus) //如果提供了加值
  411. {
  412. monDom.querySelector(".plus .hp").innerHTML = mon.plus[0];
  413. monDom.querySelector(".plus .atk").innerHTML = mon.plus[1];
  414. monDom.querySelector(".plus .rcv").innerHTML = mon.plus[2];
  415. if (mon.plus[0]+mon.plus[1]+mon.plus[2] >= 297)
  416. {
  417. monDom.querySelector(".plus").classList.add("has297");
  418. monDom.querySelector(".plus").classList.remove("zero");
  419. }else if (mon.plus[0]+mon.plus[1]+mon.plus[2] <= 0)
  420. {
  421. monDom.querySelector(".plus").classList.add("zero");
  422. monDom.querySelector(".plus").classList.remove("has297");
  423. }else
  424. {
  425. monDom.querySelector(".plus").classList.remove("zero");
  426. monDom.querySelector(".plus").classList.remove("has297");
  427. }
  428. }
  429. if (latentDom && mon.latent) //如果提供了潜觉
  430. {
  431. var latent = mon.latent.sort(function(a,b){return b-a;});
  432. if (latent.length < 1)
  433. latentDom.classList.add("display-none");
  434. else
  435. latentDom.classList.remove("display-none");
  436. var latentDoms = Array.prototype.slice.call(latentDom.querySelectorAll("li"));
  437. var usedHoleN = usedHole(latent);
  438. for (var ai=0;ai<6;ai++)
  439. {
  440. if (latent[ai])
  441. {
  442. latentDoms[ai].className = "latent-icon latent-icon-" + latent[ai];
  443. }
  444. else if(ai<(6-usedHoleN+latent.length))
  445. {
  446. latentDoms[ai].className = "latent-icon";
  447. }
  448. else
  449. {
  450. latentDoms[ai].className = "display-none";
  451. }
  452. }
  453. }
  454. }
  455. //点击怪物头像,出现编辑框
  456. function editMon(AorB,isAssist,tempIdx)
  457. {
  458. //数据
  459. var mD = formation.team[AorB][isAssist][tempIdx];
  460. //对应的Dom
  461. var formationBox = AorB?document.querySelector(".formation-box .formation-B-box"):document.querySelector(".formation-box .formation-A-box");
  462. var teamBox = isAssist?formationBox.querySelector(".formation-assist"):formationBox.querySelector(".formation-team");
  463. var memberBox = teamBox.querySelector(".member-" + (tempIdx+1));
  464. var editBox = document.querySelector(".edit-box");
  465. var monsterBox = memberBox.querySelector(".monster");
  466. editBox.show();
  467. editBox.assist = isAssist;
  468. editBox.monsterBox = monsterBox;
  469. editBox.memberIdx = [AorB,isAssist,tempIdx]; //储存队伍数组下标
  470. editBox.assist = isAssist;
  471. if (!isAssist)
  472. {
  473. var latentBox = formationBox.querySelector(".formation-latents .latents-"+(tempIdx+1)+" .latent-ul");
  474. editBox.latentBox = latentBox;
  475. }
  476. var monstersSearch = editBox.querySelector(".search-box .m-id");
  477. monstersSearch.value = mD.id>0?mD.id:0;
  478. monstersSearch.onchange();
  479. var settingBox = editBox.querySelector(".setting-box");
  480. var monEditAwokens = settingBox.querySelectorAll(".m-awoken-ul .awoken-icon");
  481. if (mD.awoken>0) monEditAwokens[mD.awoken].onclick();
  482. var monEditLv = settingBox.querySelector(".m-level");
  483. monEditLv.value = mD.level || 1;
  484. var monEditAddHp = settingBox.querySelector(".m-plus-hp");
  485. var monEditAddAtk = settingBox.querySelector(".m-plus-atk");
  486. var monEditAddRcv = settingBox.querySelector(".m-plus-rcv");
  487. if (mD.plus)
  488. {
  489. monEditAddHp.value = mD.plus[0];
  490. monEditAddAtk.value = mD.plus[1];
  491. monEditAddRcv.value = mD.plus[2];
  492. }
  493. var btnDelay = editBox.querySelector(".button-delay");
  494. if (!isAssist)
  495. {
  496. editBox.latent = mD.latent || [];
  497. editBox.refreshLatent(editBox.latent);
  498. btnDelay.classList.add("display-none");
  499. settingBox.querySelector(".row-mon-latent").classList.remove("display-none");
  500. editBox.querySelector(".edit-box-title").classList.remove("edit-box-title-assist");
  501. }else
  502. {
  503. btnDelay.classList.remove("display-none");
  504. settingBox.querySelector(".row-mon-latent").classList.add("display-none");
  505. editBox.querySelector(".edit-box-title").classList.add("edit-box-title-assist");
  506. }
  507. }
  508. function editBoxChangeMonId(id)
  509. {
  510. var md = ms[id]; //怪物固定数据
  511. if (!md){
  512. id = 0;
  513. md = ms[0]
  514. }
  515. var editBox = document.querySelector(".edit-box");
  516. var monInfoBox = editBox.querySelector(".monsterinfo-box");
  517. var me = monInfoBox.querySelector(".monster");
  518. changeid({id:id,},me); //改变图像
  519. var mId = monInfoBox.querySelector(".monster-id");
  520. mId.innerHTML = id;
  521. var mRare = monInfoBox.querySelector(".monster-rare");
  522. mRare.className = "monster-rare rare-" + md.rare;
  523. var mName = monInfoBox.querySelector(".monster-name");
  524. mName.innerHTML = md.name[language.searchlist[0]] || md.name["ja"];
  525. var mType = monInfoBox.querySelectorAll(".monster-type li");
  526. for (var ti=0;ti<mType.length;ti++)
  527. {
  528. if (md.type[ti]>=0)
  529. {
  530. mType[ti].className = "type-name type-name-" + md.type[ti];
  531. mType[ti].firstChild.className = "type-icon type-icon-" + md.type[ti];
  532. }else
  533. {
  534. mType[ti].className = "display-none";
  535. }
  536. }
  537. var settingBox = editBox.querySelector(".setting-box");
  538. var mAwoken = settingBox.querySelectorAll(".m-awoken-ul li");
  539. mAwoken[0].innerHTML = md.awoken.length?"★":"0";
  540. for (var ai=1;ai<mAwoken.length;ai++)
  541. {
  542. if (md.awoken[ai-1])
  543. {
  544. mAwoken[ai].className = "awoken-icon awoken-" + md.awoken[ai-1];
  545. }else
  546. {
  547. mAwoken[ai].className = "display-none";
  548. }
  549. }
  550. var monEditLvMax = settingBox.querySelector(".m-level-btn-max");
  551. monEditLvMax.innerHTML = monEditLvMax.value = md.maxLevel;
  552. var monEditLv = settingBox.querySelector(".m-level");
  553. monEditLv.value = md.maxLevel>99?99:md.maxLevel;
  554. var rowPlus = settingBox.querySelector(".row-mon-plus");
  555. var rowLatent = settingBox.querySelector(".row-mon-latent");
  556. if (ms[id].type.some(function(t){return t == 0 || t == 12 || t == 14 || t == 15;}) && [303,305,307,600,602].indexOf(id)<0)
  557. { //当4种特殊type的时候是无法297和打觉醒的,但是5种小企鹅可以
  558. rowPlus.classList.add("disabled");
  559. rowLatent.classList.add("disabled");
  560. }else
  561. {
  562. rowPlus.classList.remove("disabled");
  563. rowLatent.classList.remove("disabled");
  564. }
  565. var monLatentAllowUl = rowLatent.querySelector(".m-latent-allowable-ul");
  566. //该宠Type允许的杀
  567. var allowLatent = uniq(md.type.reduce(function (previous, t, index, array) {
  568. return previous.concat(type_allowable_latent[t]);
  569. },[]));
  570. for(var li=17;li<=24;li++)
  571. {
  572. var latentDom = monLatentAllowUl.querySelector(".latent-icon-" + li);
  573. if (allowLatent.indexOf(li)>=0)
  574. {
  575. if(latentDom.classList.contains("unselected-latent"))
  576. latentDom.classList.remove("unselected-latent");
  577. }else
  578. {
  579. if(!latentDom.classList.contains("unselected-latent"))
  580. latentDom.classList.add("unselected-latent");
  581. }
  582. }
  583. if (editBox.assist)
  584. {
  585. var btnDone = editBox.querySelector(".button-done");
  586. if (!md.assist)
  587. {
  588. btnDone.classList.add("cant-assist");
  589. btnDone.disabled = true;
  590. }else
  591. {
  592. btnDone.classList.remove("cant-assist");
  593. btnDone.disabled = false;
  594. }
  595. }
  596. editBox.latent.length = 0;
  597. editBox.refreshLatent(editBox.latent);
  598. }
  599. //刷新整个队伍
  600. function refreshAll(fmt){
  601. var txtTitle = document.querySelector(".title-box .title");
  602. var txtDetail = document.querySelector(".detail-box .detail");
  603. txtTitle.value = fmt.title || "";
  604. txtDetail.value = fmt.detail || "";
  605. txtDetail.onblur();
  606. var formationA = document.querySelector(".formation-box .formation-A-box");
  607. var formationB = document.querySelector(".formation-box .formation-B-box");
  608. var fATeam = formationA.querySelectorAll(".formation-team .monster");
  609. var fALatents = formationA.querySelectorAll(".formation-latents .latent-ul");
  610. var fAAssist = formationA.querySelectorAll(".formation-assist .monster");
  611. var fBTeam = formationB.querySelectorAll(".formation-team .monster");
  612. var fBLatents = formationB.querySelectorAll(".formation-latents .latent-ul");
  613. var fBAssist = formationB.querySelectorAll(".formation-assist .monster");
  614. for (var ti=0;ti<5;ti++)
  615. {
  616. changeid(fmt.team[0][0][ti],fATeam[ti],fALatents[ti]);
  617. changeid(fmt.team[0][1][ti],fAAssist[ti]);
  618. changeid(fmt.team[1][0][ti],fBTeam[ti],fBLatents[ti]);
  619. changeid(fmt.team[1][1][ti],fBAssist[ti]);
  620. }
  621. refreshAwokenCount(fmt.team);
  622. }
  623. //刷新觉醒总计
  624. function refreshAwokenCount(team){
  625. var awokenUL = document.querySelector(".awoken-total-box .m-awoken-ul");
  626. function setCount(idx,number){
  627. var ali = awokenUL.querySelector(".a-c-" + idx);
  628. ali.querySelector(".count").innerHTML = number;
  629. if (number)
  630. ali.classList.remove("display-none");
  631. else
  632. ali.classList.add("display-none");
  633. }
  634. setCount(21,awokenCountInTeam(team,21)+awokenCountInTeam(team,56)*2); //SB+大SB
  635. setCount(28,awokenCountInTeam(team,28)); //SX
  636. setCount(11,awokenCountInTeam(team,11)); //防暗
  637. setCount(12,awokenCountInTeam(team,12)); //防废
  638. setCount(13,awokenCountInTeam(team,13)); //防毒
  639. setCount(54,awokenCountInTeam(team,54)); //防云
  640. setCount(55,awokenCountInTeam(team,55)); //防封条
  641. }

智龙迷城队伍图制作工具

Contributors (1)