mirror of
https://github.com/webxoss/webxoss-core.git
synced 2025-02-13 16:13:26 +01:00
improve test helper
refactor test helper grow lrig to max level and put other lrig card to the bottom of lrig zone aviod use innerHTML
This commit is contained in:
parent
3b98b12593
commit
012308b4a4
1 changed files with 85 additions and 42 deletions
127
testHelper.js
127
testHelper.js
|
@ -4,12 +4,11 @@
|
|||
|
||||
var $ = document.getElementById.bind(document);
|
||||
|
||||
function TestHelper() {
|
||||
this.noBGM = true;
|
||||
}
|
||||
TestHelper.prototype.disableAudio = function(doc) {
|
||||
var noBGM = true;
|
||||
|
||||
function disableAudio(doc) {
|
||||
// disable BGM
|
||||
if (!this.noBGM) {
|
||||
if (!noBGM) {
|
||||
return;
|
||||
}
|
||||
var bgm = doc.getElementById('checkbox-bgm');
|
||||
|
@ -20,8 +19,8 @@ TestHelper.prototype.disableAudio = function(doc) {
|
|||
if (sound && sound.checked) {
|
||||
sound.click();
|
||||
}
|
||||
};
|
||||
TestHelper.prototype.initClient = function(win) {
|
||||
}
|
||||
function initClient(win) {
|
||||
var doc = win.document;
|
||||
var socket = new FakeSocket(win);
|
||||
win.addEventListener('unload', function() {
|
||||
|
@ -30,11 +29,9 @@ TestHelper.prototype.initClient = function(win) {
|
|||
win.document.title = 'Client' + socket.id;
|
||||
io._handler(socket);
|
||||
|
||||
this.disableAudio(doc);
|
||||
disableAudio(doc);
|
||||
log(win.document.title + ' added.');
|
||||
};
|
||||
|
||||
var helper = new TestHelper();
|
||||
}
|
||||
|
||||
// prepare and start game
|
||||
function startBattle() {
|
||||
|
@ -49,16 +46,16 @@ function startBattle() {
|
|||
win.addEventListener('load', function() {
|
||||
var win2 = window.open('../webxoss-client/?local=true');
|
||||
win2.addEventListener('load', function() {
|
||||
helper.initClient(win2);
|
||||
initClient(win2);
|
||||
oben();
|
||||
});
|
||||
helper.initClient(win);
|
||||
initClient(win);
|
||||
});
|
||||
}
|
||||
|
||||
function oben() {
|
||||
if (sockets.length !== 2) {
|
||||
log('two client needed');
|
||||
log('two client needed.');
|
||||
return;
|
||||
}
|
||||
var createRoomMsg = {
|
||||
|
@ -66,7 +63,7 @@ function oben() {
|
|||
'nickname': 'host',
|
||||
'password': '',
|
||||
'mayusRoom': true,
|
||||
}
|
||||
};
|
||||
sockets[0]._doEmit('createRoom', createRoomMsg);
|
||||
log('Client<1> create room.');
|
||||
|
||||
|
@ -74,7 +71,7 @@ function oben() {
|
|||
'roomName': 'test',
|
||||
'nickname': 'ghost',
|
||||
'password': '',
|
||||
}
|
||||
};
|
||||
sockets[1]._doEmit('joinRoom', joinRoomMsg);
|
||||
log('Client<2> join room.');
|
||||
|
||||
|
@ -83,16 +80,17 @@ function oben() {
|
|||
sockets[0]._doEmit('startGame', getDeckPids('ghost'));
|
||||
log('oben!');
|
||||
|
||||
updateBattle();
|
||||
handleBattle();
|
||||
}
|
||||
|
||||
var game; // in-play game
|
||||
function updateBattle() {
|
||||
function handleBattle() {
|
||||
if (roomManager.rooms.length === 0) {
|
||||
log('no in-play game found.');
|
||||
return;
|
||||
}
|
||||
game = roomManager.rooms[0].game;
|
||||
enableButtons();
|
||||
log('Handle game successfully.');
|
||||
log('Now you can use helper function.');
|
||||
}
|
||||
|
@ -102,13 +100,22 @@ function grow() {
|
|||
var p = game.turnPlayer;
|
||||
var cards = p.lrigDeck.cards.concat(p.lrigTrashZone.cards);
|
||||
var lrigCards = [];
|
||||
var maxLevel = 0;
|
||||
cards.forEach(function(card) {
|
||||
if (card.type === 'LRIG') {
|
||||
lrigCards.push(card);
|
||||
if (maxLevel < card.level) {
|
||||
lrigCards.push(card);
|
||||
maxLevel = card.level;
|
||||
} else {
|
||||
lrigCards.unshift(card);
|
||||
}
|
||||
}
|
||||
});
|
||||
game.moveCards(lrigCards, p.lrigZone);
|
||||
log('grow lrig to level max.');
|
||||
lrigCards.pop().moveTo(p.lrigZone);
|
||||
lrigCards.forEach(function(card) {
|
||||
card.moveTo(p.lrigZone, {bottom: true});
|
||||
});
|
||||
log('grow lrig to max level.');
|
||||
}
|
||||
function draw(num) {
|
||||
if (!num) {
|
||||
|
@ -134,28 +141,27 @@ function matchCard(arg) {
|
|||
return;
|
||||
}
|
||||
var cid = 0;
|
||||
game.cards.forEach(function(card) {
|
||||
for (var i = 0; i < game.cards.length; i++) {
|
||||
var card = game.cards[i];
|
||||
var info = CardInfo[card.cid];
|
||||
var matched = info.pid === arg ||
|
||||
info.cid === arg ||
|
||||
info.wxid === arg;
|
||||
var matched = info.name === arg ||
|
||||
info.name_zh_CN === arg ||
|
||||
info.cid === arg ||
|
||||
info.wxid === arg;
|
||||
if (matched) {
|
||||
cid = card.cid;
|
||||
return;
|
||||
break;
|
||||
}
|
||||
});
|
||||
}
|
||||
if (!cid) return null;
|
||||
var player = game.turnPlayer;
|
||||
var cards = concat(player.mainDeck.cards,
|
||||
player.trashZone.cards,
|
||||
player.enerZone.cards,
|
||||
player.lifeClothZone.cards);
|
||||
|
||||
cards.forEach(function(card) {
|
||||
var p = selectPlayer();
|
||||
var cards = concat(p.mainDeck.cards,p.trashZone.cards,p.enerZone.cards,p.lifeClothZone.cards);
|
||||
for (var j = 0; j < cards.length; j++) {
|
||||
var card = cards[j];
|
||||
if (card.cid === cid) {
|
||||
return card;
|
||||
}
|
||||
});
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
|
@ -171,28 +177,37 @@ function addTo(zone) {
|
|||
return;
|
||||
}
|
||||
var input = $('card-name').value;
|
||||
if (input && matchCard(input)) {
|
||||
if (input) {
|
||||
var matchedCard = matchCard(input);
|
||||
if (!matchedCard) {
|
||||
log('no matched card');
|
||||
return;
|
||||
}
|
||||
matchedCard.moveTo(game.turnPlayer[zone]);
|
||||
var p = selectPlayer();
|
||||
matchedCard.moveTo(p[zone]);
|
||||
log('add <' + matchedCard.name + '> to ' + zone + '.');
|
||||
} else {
|
||||
log('card\'s wxid / pid / cid needed.');
|
||||
}
|
||||
}
|
||||
|
||||
function resetLrigDeck() {
|
||||
game.moveCards(game.turnPlayer.lrigTrashZone.cards, game.turnPlayer.lrigDeck);
|
||||
var p = selectPlayer();
|
||||
game.moveCards(p.lrigTrashZone.cards, p.lrigDeck);
|
||||
log('reset lrig deck.');
|
||||
}
|
||||
// log
|
||||
function log(text) {
|
||||
var logger = $('log');
|
||||
logger.innerHTML += text;
|
||||
logger.innerHTML += '\n';
|
||||
logger.textContent += text;
|
||||
logger.textContent += '\n';
|
||||
}
|
||||
// dom
|
||||
function selectPlayer() {
|
||||
return $('target-player').value === 'opponent' ?
|
||||
game.turnPlayer.opponent :
|
||||
game.turnPlayer;
|
||||
}
|
||||
function getDeckPids(player) {
|
||||
var name = {
|
||||
'host': $('host-decks').value || '',
|
||||
|
@ -216,7 +231,7 @@ function initDeckSelect() {
|
|||
deckNames.forEach(function(name) {
|
||||
var deckName = document.createElement('option');
|
||||
deckName.setAttribute('value', name);
|
||||
deckName.innerHTML = name;
|
||||
deckName.textContent = name;
|
||||
hostDeckSelect.appendChild(deckName);
|
||||
ghostDeckSelect.appendChild(deckName.cloneNode(true));
|
||||
});
|
||||
|
@ -227,8 +242,36 @@ function changeLanguage() {
|
|||
log('set language to ' + lang + '.');
|
||||
location.reload();
|
||||
}
|
||||
|
||||
function resizeIFrameToFitContent() {
|
||||
var iFrame = $('deck-editor');
|
||||
iFrame.width = iFrame.contentWindow.document.body.scrollWidth;
|
||||
iFrame.height = iFrame.contentWindow.document.body.scrollHeight;
|
||||
}
|
||||
function enableButtons() {
|
||||
var buttons = document.getElementsByTagName('button');
|
||||
for (var i = 0; i < buttons.length; i++) {
|
||||
if (buttons[i].id !== 'oben') {
|
||||
buttons[i].disabled = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
function disableButtons() {
|
||||
var buttons = document.getElementsByTagName('button');
|
||||
for (var i = 0; i < buttons.length; i++) {
|
||||
if (buttons[i].id !== 'oben') {
|
||||
buttons[i].disabled = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
window.onload = function() {
|
||||
$('select-language').value = localStorage.getItem('language');
|
||||
initDeckSelect();
|
||||
resizeIFrameToFitContent();
|
||||
disableButtons();
|
||||
};
|
||||
|
||||
window.onunload = function() {
|
||||
sockets.forEach(function(socket) {
|
||||
socket._win.close();
|
||||
});
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue