修复ui.create.menu的一些bug

This commit is contained in:
shijian 2023-08-26 03:10:03 +08:00
parent bb39b6363a
commit 9eebea05a9
1 changed files with 319 additions and 312 deletions

View File

@ -39213,11 +39213,12 @@
if(start.childNodes[i].mode!=lib.configOL.mode){ if(start.childNodes[i].mode!=lib.configOL.mode){
start.childNodes[i].classList.add('unselectable'); start.childNodes[i].classList.add('unselectable');
start.childNodes[i].classList.remove('active'); start.childNodes[i].classList.remove('active');
start.childNodes[i].link.remove(); if(start.childNodes[i].link) start.childNodes[i].link.remove();
} }
else{ else{
start.childNodes[i].classList.add('active'); start.childNodes[i].classList.add('active');
start.nextSibling.appendChild(start.childNodes[i].link); if(start.childNodes[i].link) start.nextSibling.appendChild(start.childNodes[i].link);
else console.log(start.nextSibling, start.childNodes[i]);
} }
} }
} }
@ -39356,9 +39357,24 @@
var info=lib.mode[mode]; var info=lib.mode[mode];
var page=ui.create.div(''); var page=ui.create.div('');
var node=ui.create.div('.menubutton.large',info.name,position,clickMode); var node=ui.create.div('.menubutton.large',info.name,position,clickMode);
node.mode=mode;
var connectDisplayMap={
connect_player_number: null,
connect_versus_mode: null,
}
var updateConnectDisplayMap=function(){
if(_status.waitingForPlayer){
if(connectDisplayMap.connect_player_number){
connectDisplayMap.connect_player_number.style.display='none';
}
if(connectDisplayMap.connect_versus_mode){
connectDisplayMap.connect_versus_mode.style.display='none';
}
}
};
if(connectMenu) menuUpdates.push(updateConnectDisplayMap);
node._initLink=function(){ node._initLink=function(){
node.link=page; node.link=page;
node.mode=mode;
if(connectMenu){ if(connectMenu){
if(mode==lib.config.connect_mode){ if(mode==lib.config.connect_mode){
node.classList.add('active'); node.classList.add('active');
@ -39539,16 +39555,9 @@
} }
} }
if(connectMenu){ if(connectMenu){
menuUpdates.push(function(){ connectDisplayMap.connect_player_number=map.connect_player_number;
if(_status.waitingForPlayer){ connectDisplayMap.connect_versus_mode=map.connect_versus_mode;
if(map.connect_player_number){ updateConnectDisplayMap();
map.connect_player_number.style.display='none';
}
if(map.connect_versus_mode){
map.connect_versus_mode.style.display='none';
}
}
})
} }
}; };
return node; return node;
@ -39689,9 +39698,9 @@
var info=lib.configMenu[mode]; var info=lib.configMenu[mode];
var page=ui.create.div(''); var page=ui.create.div('');
var node=ui.create.div('.menubutton.large',info.name,position,clickMode); var node=ui.create.div('.menubutton.large',info.name,position,clickMode);
node.mode=mode;
node._initLink=function(){ node._initLink=function(){
node.link=page; node.link=page;
node.mode=mode;
var map={}; var map={};
if(info.config){ if(info.config){
var hiddenNodes=[]; var hiddenNodes=[];
@ -40685,27 +40694,27 @@
var updateNodes=function(){ var updateNodes=function(){
for(var i=0;i<start.firstChild.childNodes.length;i++){ for(var i=0;i<start.firstChild.childNodes.length;i++){
var node=start.firstChild.childNodes[i]; var node=start.firstChild.childNodes[i];
if(node.link){ if(node.mode){
if(node.mode.indexOf('mode_')==0) continue; if(node.mode.indexOf('mode_')==0) continue;
if(node.mode=='custom') continue; if(node.mode=='custom') continue;
if(connectMenu){ if(connectMenu){
if(!lib.config.connect_characters.contains(node.mode)){ if(!lib.config.connect_characters.contains(node.mode)){
node.classList.remove('off'); node.classList.remove('off');
node.link.firstChild.classList.add('on'); if(node.link) node.link.firstChild.classList.add('on');
} }
else{ else{
node.classList.add('off'); node.classList.add('off');
node.link.firstChild.classList.remove('on'); if(node.link) node.link.firstChild.classList.remove('on');
} }
} }
else{ else{
if(lib.config.characters.contains(node.mode)){ if(lib.config.characters.contains(node.mode)){
node.classList.remove('off'); node.classList.remove('off');
node.link.firstChild.classList.add('on'); if(node.link) node.link.firstChild.classList.add('on');
} }
else{ else{
node.classList.add('off'); node.classList.add('off');
node.link.firstChild.classList.remove('on'); if(node.link) node.link.firstChild.classList.remove('on');
} }
} }
} }
@ -40735,6 +40744,7 @@
}; };
var createModeConfig=function(mode,position,position2){ var createModeConfig=function(mode,position,position2){
var _info=lib.characterPack[mode];
var page=ui.create.div(''); var page=ui.create.div('');
var node=ui.create.div('.menubutton.large',lib.translate[mode+'_character_config'],position,clickMode); var node=ui.create.div('.menubutton.large',lib.translate[mode+'_character_config'],position,clickMode);
if(node.innerHTML.length>=5){ if(node.innerHTML.length>=5){
@ -40743,29 +40753,28 @@
if(position2){ if(position2){
position.insertBefore(node,position2); position.insertBefore(node,position2);
} }
node._initLink=function(){
var info=lib.characterPack[mode];
node.link=page;
node.mode=mode; node.mode=mode;
node._initLink=function(){
node.link=page;
page.node=node; page.node=node;
var list=[]; var list=[];
var boolAI=true; var boolAI=true;
var alterableSkills=[]; var alterableSkills=[];
var alterableCharacters=[]; var alterableCharacters=[];
var charactersToAlter=[]; var charactersToAlter=[];
for(var i in info){ for(var i in _info){
if(info[i][4]&&info[i][4].contains('unseen')) continue; if(_info[i][4]&&_info[i][4].contains('unseen')) continue;
if(connectMenu&&lib.connectBanned.contains(i)) continue; if(connectMenu&&lib.connectBanned.contains(i)) continue;
list.push(i); list.push(i);
if(boolAI&&!lib.config.forbidai_user.contains(i)) boolAI=false; if(boolAI&&!lib.config.forbidai_user.contains(i)) boolAI=false;
for(var j=0;j<info[i][3].length;j++){ for(var j=0;j<_info[i][3].length;j++){
if(!lib.skill[info[i][3][j]]){ if(!lib.skill[_info[i][3][j]]){
continue; continue;
} }
if(lib.skill[info[i][3][j]].alter){ if(lib.skill[_info[i][3][j]].alter){
alterableSkills.add(info[i][3][j]); alterableSkills.add(_info[i][3][j]);
alterableCharacters.add(i); alterableCharacters.add(i);
if(lib.config.vintageSkills.contains(info[i][3][j])){ if(lib.config.vintageSkills.contains(_info[i][3][j])){
charactersToAlter.add(i); charactersToAlter.add(i);
} }
} }
@ -41164,28 +41173,28 @@
var updateNodes=function(){ var updateNodes=function(){
for(var i=0;i<start.firstChild.childNodes.length;i++){ for(var i=0;i<start.firstChild.childNodes.length;i++){
var node=start.firstChild.childNodes[i]; var node=start.firstChild.childNodes[i];
if(node.link){ if(node.mode){
if(node.mode.indexOf('mode_')==0) continue; if(node.mode.indexOf('mode_')==0) continue;
if(node.mode=='custom') continue; if(node.mode=='custom') continue;
if(node.mode=='cardpile') continue; if(node.mode=='cardpile') continue;
if(connectMenu){ if(connectMenu){
if(!lib.config.connect_cards.contains(node.mode)){ if(!lib.config.connect_cards.contains(node.mode)){
node.classList.remove('off'); node.classList.remove('off');
node.link.firstChild.classList.add('on'); if(node.link) node.link.firstChild.classList.add('on');
} }
else{ else{
node.classList.add('off'); node.classList.add('off');
node.link.firstChild.classList.remove('on'); if(node.link) node.link.firstChild.classList.remove('on');
} }
} }
else{ else{
if(lib.config.cards.contains(node.mode)){ if(lib.config.cards.contains(node.mode)){
node.classList.remove('off'); node.classList.remove('off');
node.link.firstChild.classList.add('on'); if(node.link) node.link.firstChild.classList.add('on');
} }
else{ else{
node.classList.add('off'); node.classList.add('off');
node.link.firstChild.classList.remove('on'); if(node.link) node.link.firstChild.classList.remove('on');
} }
} }
} }
@ -41235,9 +41244,9 @@
if(node.innerHTML.length>=5){ if(node.innerHTML.length>=5){
node.classList.add('smallfont'); node.classList.add('smallfont');
} }
node.mode=mode;
node._initLink=function(){ node._initLink=function(){
node.link=page; node.link=page;
node.mode=mode;
var list=[]; var list=[];
for(var i=0;i<info.length;i++){ for(var i=0;i<info.length;i++){
if(!lib.card[info[i]]||(lib.card[info[i]].derivation&&mode!='mode_derivation')) continue; if(!lib.card[info[i]]||(lib.card[info[i]].derivation&&mode!='mode_derivation')) continue;
@ -41710,6 +41719,7 @@
this._initLink(); this._initLink();
rightPane.appendChild(this.link); rightPane.appendChild(this.link);
} }
updateNodes();
}; };
ui.click.extensionTab=function(name){ ui.click.extensionTab=function(name){
ui.click.menuTab('扩展'); ui.click.menuTab('扩展');
@ -41723,28 +41733,26 @@
var updateNodes=function(){ var updateNodes=function(){
for(var i=0;i<start.firstChild.childNodes.length;i++){ for(var i=0;i<start.firstChild.childNodes.length;i++){
var node=start.firstChild.childNodes[i]; var node=start.firstChild.childNodes[i];
if(node.link){
if(node.mode=='get') continue; if(node.mode=='get') continue;
if(node.mode=='create') continue; if(node.mode=='create') continue;
if(node.mode.indexOf('extension_')==0){ if(node.mode&&node.mode.indexOf('extension_')==0){
if(lib.config[node.mode+'_enable']){ if(lib.config[node.mode+'_enable']){
node.classList.remove('off'); node.classList.remove('off');
node.link.firstChild.classList.add('on'); if(node.link) node.link.firstChild.classList.add('on');
} }
else{ else{
node.classList.add('off'); node.classList.add('off');
node.link.firstChild.classList.remove('on'); if(node.link) node.link.firstChild.classList.remove('on');
} }
} }
else{ else{
if(lib.config.plays.contains(node.mode)){ if(lib.config.plays.contains(node.mode)){
node.classList.remove('off'); node.classList.remove('off');
node.link.firstChild.classList.add('on'); if(node.link) node.link.firstChild.classList.add('on');
} }
else{ else{
node.classList.add('off'); node.classList.add('off');
node.link.firstChild.classList.remove('on'); if(node.link) node.link.firstChild.classList.remove('on');
}
} }
} }
} }
@ -41788,9 +41796,9 @@
if(node.innerHTML.length>=5){ if(node.innerHTML.length>=5){
node.classList.add('smallfont'); node.classList.add('smallfont');
} }
node.mode=mode;
node._initLink=function(){ node._initLink=function(){
node.link=page; node.link=page;
node.mode=mode;
for(var i in lib.extensionMenu[mode]){ for(var i in lib.extensionMenu[mode]){
if(i=='game') continue; if(i=='game') continue;
var cfg=copyObj(lib.extensionMenu[mode][i]); var cfg=copyObj(lib.extensionMenu[mode][i]);
@ -41837,9 +41845,9 @@
if(lib.config.show_extensionmaker==false) return; if(lib.config.show_extensionmaker==false) return;
var page=ui.create.div('#create-extension'); var page=ui.create.div('#create-extension');
var node=ui.create.div('.menubutton.large','制作扩展',start.firstChild,clickMode); var node=ui.create.div('.menubutton.large','制作扩展',start.firstChild,clickMode);
node.mode='create';
node._initLink=function(){ node._initLink=function(){
node.link=page; node.link=page;
node.mode='create';
var pageboard=ui.create.div(page); var pageboard=ui.create.div(page);
var inputExtLine=ui.create.div(pageboard); var inputExtLine=ui.create.div(pageboard);
inputExtLine.style.transition='all 0s'; inputExtLine.style.transition='all 0s';
@ -43955,9 +43963,9 @@
(function(){ (function(){
var page=ui.create.div(''); var page=ui.create.div('');
var node=ui.create.div('.menubutton.large','获取扩展',start.firstChild,clickMode); var node=ui.create.div('.menubutton.large','获取扩展',start.firstChild,clickMode);
node.mode='get';
node._initLink=function(){ node._initLink=function(){
node.link=page; node.link=page;
node.mode='get';
page.listen(function(){ page.listen(function(){
if(!page.currenttimeout){ if(!page.currenttimeout){
var active=page.querySelector('.videonode.current'); var active=page.querySelector('.videonode.current');
@ -45034,9 +45042,6 @@
} }
}()); }());
(function(){ (function(){
var page=ui.create.div('');
var node=ui.create.div('.menubutton.large','控制',start.firstChild,clickMode);
node._initLink=function(){
var norow2=function(){ var norow2=function(){
var node=currentrow1; var node=currentrow1;
if(!node) return false; if(!node) return false;
@ -45144,6 +45149,9 @@
clickContainer.call(menuContainer); clickContainer.call(menuContainer);
} }
}); });
var page=ui.create.div('');
var node=ui.create.div('.menubutton.large','控制',start.firstChild,clickMode);
node.link=page; node.link=page;
node.type='cheat'; node.type='cheat';
page.classList.add('menu-sym'); page.classList.add('menu-sym');
@ -45287,28 +45295,27 @@
} }
checkCheat(); checkCheat();
}); });
};
}()); }());
(function(){ (function(){
var page=ui.create.div(''); var page=ui.create.div('');
var node=ui.create.div('.menubutton.large','命令',start.firstChild,clickMode); var node=ui.create.div('.menubutton.large','命令',start.firstChild,clickMode);
ui.commandnode=node; ui.commandnode=node;
node.type='cmd'; node.type='cmd';
node._initLink=function(){
node.link=page;
page.classList.add('menu-sym');
menuUpdates.push(function(){ menuUpdates.push(function(){
if(_status.connectMode){ if(_status.connectMode){
node.classList.add('off'); node.classList.add('off');
if(node.classList.contains('active')){ if(node.classList.contains('active')){
node.classList.remove('active'); node.classList.remove('active');
node.link.remove(); if(node.link) node.link.remove();
active=start.firstChild.firstChild; active=start.firstChild.firstChild;
active.classList.add('active'); active.classList.add('active');
rightPane.appendChild(active.link); rightPane.appendChild(active.link);
} }
} }
}); });
node._initLink=function(){
node.link=page;
page.classList.add('menu-sym');
var text=document.createElement('div'); var text=document.createElement('div');
text.style.width='194px'; text.style.width='194px';
text.style.height='124px'; text.style.height='124px';