mirror of
https://github.com/webxoss/webxoss-core.git
synced 2025-01-18 19:56:02 +01:00
339 lines
7.7 KiB
JavaScript
339 lines
7.7 KiB
JavaScript
'use strict';
|
|
|
|
// browser only
|
|
|
|
// server
|
|
var io = {
|
|
on: function (name,handler) {
|
|
io._handler = handler;
|
|
},
|
|
use: function () {}
|
|
};
|
|
var cfg = {
|
|
MAX_ROOMS: 100,
|
|
MAX_CLIENTS: 500,
|
|
MAX_ROOM_NAME_LENGTH: 15,
|
|
MAX_NICKNAME_LENGTH: 10,
|
|
MAX_PASSWORD_LENGTH: 15
|
|
};
|
|
var roomManager = new RoomManager(cfg);
|
|
var MAX_SOCKETS = 500;
|
|
function getSocketCount () {
|
|
if (!io.sockets) return 0;
|
|
return Object.keys(io.sockets.connected).length;
|
|
}
|
|
io.use(function (socket,next) {
|
|
if (getSocketCount() >= MAX_SOCKETS) {
|
|
next(new Error('MAX_SOCKETS'));
|
|
return;
|
|
}
|
|
next();
|
|
});
|
|
io.on('connect',function (socket) {
|
|
return roomManager.createClient(socket);
|
|
});
|
|
|
|
// client
|
|
var noBGM = true;
|
|
function disableAudio(doc) {
|
|
// disable BGM
|
|
if (!noBGM) {
|
|
return;
|
|
}
|
|
var bgm = doc.getElementById('checkbox-bgm');
|
|
var sound = doc.getElementById('checkbox-sound-effect');
|
|
if (bgm && bgm.checked) {
|
|
bgm.click();
|
|
}
|
|
if (sound && sound.checked) {
|
|
sound.click();
|
|
}
|
|
}
|
|
function initClient(win) {
|
|
var doc = win.document;
|
|
var socket = new FakeSocket(win);
|
|
win.addEventListener('unload', function() {
|
|
socket._doEmit('disconnect');
|
|
});
|
|
win.document.title = 'Client' + socket.id;
|
|
io._handler(socket);
|
|
|
|
disableAudio(doc);
|
|
log(win.document.title + ' added.');
|
|
}
|
|
|
|
// prepare and start game
|
|
function startBattle() {
|
|
if (sockets.length) {
|
|
sockets.forEach(function(target) {
|
|
target._win.close();
|
|
});
|
|
location.reload();
|
|
return;
|
|
}
|
|
var relativePath = './webxoss-client/?local=true';
|
|
var link = document.createElement('a');
|
|
link.href = relativePath;
|
|
var absolutePath = link.href;
|
|
var win = window.open(absolutePath);
|
|
win.addEventListener('load', function() {
|
|
var win2 = window.open(absolutePath);
|
|
win2.addEventListener('load', function() {
|
|
initClient(win2);
|
|
skipDiscards();
|
|
oben();
|
|
});
|
|
initClient(win);
|
|
});
|
|
}
|
|
function oben() {
|
|
if (sockets.length !== 2) {
|
|
log('two client needed.');
|
|
return;
|
|
}
|
|
var createRoomMsg = {
|
|
'roomName': 'test',
|
|
'nickname': 'host',
|
|
'password': '',
|
|
'mayusRoom': true,
|
|
};
|
|
sockets[0]._doEmit('createRoom', createRoomMsg);
|
|
log('Client<1> create room.');
|
|
|
|
var joinRoomMsg = {
|
|
'roomName': 'test',
|
|
'nickname': 'guest',
|
|
'password': '',
|
|
};
|
|
sockets[1]._doEmit('joinRoom', joinRoomMsg);
|
|
log('Client<2> join room.');
|
|
|
|
sockets[1]._doEmit('ready', getDeckPids('host'));
|
|
log('Client<2> is ready.');
|
|
sockets[0]._doEmit('startGame', getDeckPids('guest'));
|
|
log('oben!');
|
|
|
|
handleBattle();
|
|
}
|
|
|
|
var game; // in-play game
|
|
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.');
|
|
}
|
|
function skipDiscards() {
|
|
Player.prototype.redrawAsyn = function() {
|
|
return new Callback.immediately();
|
|
}
|
|
}
|
|
// helper function
|
|
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') {
|
|
if (maxLevel < card.level) {
|
|
lrigCards.push(card);
|
|
maxLevel = card.level;
|
|
} else {
|
|
lrigCards.unshift(card);
|
|
}
|
|
}
|
|
});
|
|
lrigCards.pop().moveTo(p.lrigZone);
|
|
game.moveCards(lrigCards, p.lrigZone, { bottom: true });
|
|
log('grow lrig to max level.');
|
|
}
|
|
|
|
function draw(num) {
|
|
if (!num) {
|
|
num = 5;
|
|
}
|
|
var p = game.turnPlayer;
|
|
p.draw(num);
|
|
log('draw ' + num + ' cards.');
|
|
}
|
|
|
|
function charge(num) {
|
|
if (!num) {
|
|
num = 5;
|
|
}
|
|
var p = game.turnPlayer;
|
|
p.enerCharge(num);
|
|
log('ener charge ' + num + '.');
|
|
}
|
|
|
|
function matchCard(arg) {
|
|
if (arg) {
|
|
arg = arg.toUpperCase();
|
|
} else {
|
|
return;
|
|
}
|
|
var cid = 0;
|
|
for (var i = 0; i < game.cards.length; i++) {
|
|
var card = game.cards[i];
|
|
var info = CardInfo[card.cid];
|
|
var matched = info.name === arg ||
|
|
info.name_zh_CN === arg ||
|
|
info.cid === arg ||
|
|
info.wxid === arg;
|
|
if (matched) {
|
|
cid = card.cid;
|
|
break;
|
|
}
|
|
}
|
|
if (!cid) return null;
|
|
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;
|
|
}
|
|
|
|
var $ = document.getElementById.bind(document);
|
|
|
|
var zones = [
|
|
'handZone',
|
|
'enerZone',
|
|
'trashZone',
|
|
'lifeClothZone',
|
|
];
|
|
function addTo(zone) {
|
|
if (zones.indexOf(zone) === -1) {
|
|
log('no such zone: ' + zone);
|
|
return;
|
|
}
|
|
var input = $('card-name').value;
|
|
if (input) {
|
|
var matchedCard = matchCard(input);
|
|
if (!matchedCard) {
|
|
log('no matched card');
|
|
return;
|
|
}
|
|
var p = selectPlayer();
|
|
matchedCard.moveTo(p[zone]);
|
|
log('add <' + matchedCard.name + '> to ' + zone + '.');
|
|
} else {
|
|
log('card\'s wxid / pid / cid needed.');
|
|
}
|
|
}
|
|
function resetArts() {
|
|
var p = selectPlayer();
|
|
game.moveCards(p.lrigTrashZone.cards, p.lrigDeck);
|
|
log('reset lrig deck.');
|
|
}
|
|
function ignoreLimiting() {
|
|
var p = selectPlayer();
|
|
// conflict with <虚无阎魔 乌莉丝>
|
|
p.ignoreLimitingOfArtsAndSpell = true;
|
|
log('ignore limiting of arts and spell');
|
|
}
|
|
// log
|
|
function log(text) {
|
|
var logger = $('log');
|
|
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 || '',
|
|
'guest': $('guest-decks').value || '',
|
|
}[player];
|
|
if (!name) {
|
|
log('error in deck select');
|
|
}
|
|
return JSON.parse(localStorage.getItem('deck_file_' + name));
|
|
}
|
|
var deckNames = [];
|
|
|
|
function readDeckNames() {
|
|
return JSON.parse(localStorage.getItem('deck_filenames')) || [];
|
|
}
|
|
|
|
function updateDeckSelect() {
|
|
deckNames = readDeckNames();
|
|
var hostDeckSelect = $('host-decks');
|
|
var guestDeckSelect = $('guest-decks');
|
|
hostDeckSelect.innerHTML = '';
|
|
guestDeckSelect.innerHTML = '';
|
|
deckNames.forEach(function(name) {
|
|
var deckName = document.createElement('option');
|
|
deckName.setAttribute('value', name);
|
|
deckName.textContent = name;
|
|
hostDeckSelect.appendChild(deckName);
|
|
guestDeckSelect.appendChild(deckName.cloneNode(true));
|
|
});
|
|
}
|
|
|
|
function changeLanguage() {
|
|
var lang = $('select-language').value;
|
|
localStorage.setItem('language', lang);
|
|
log('set language to ' + lang + '.');
|
|
location.reload();
|
|
}
|
|
function handleDeckEditor() {
|
|
var iFrame = $('deck-editor');
|
|
|
|
//resizeIFrameToFitContent
|
|
iFrame.width = iFrame.contentWindow.document.body.scrollWidth;
|
|
iFrame.height = iFrame.contentWindow.document.body.scrollHeight;
|
|
|
|
// disable deck-editor return
|
|
iFrame.contentDocument
|
|
.getElementById('link-back-to-webxoss').href = "#"
|
|
|
|
// auto update deck names when change in deckEditor
|
|
window.addEventListener('storage', function(e) {
|
|
if (e.key === 'deck_filenames') {
|
|
updateDeckSelect();
|
|
}
|
|
});
|
|
}
|
|
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');
|
|
updateDeckSelect();
|
|
handleDeckEditor();
|
|
disableButtons();
|
|
};
|
|
|
|
window.onunload = function() {
|
|
sockets.forEach(function(socket) {
|
|
socket._win.close();
|
|
});
|
|
};
|