projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Experimental multi-tabs support (TODO: prevent multi-connect)
[vchess.git]
/
client
/
src
/
utils
/
gameStorage.js
diff --git
a/client/src/utils/gameStorage.js
b/client/src/utils/gameStorage.js
index
0284763
..
f995828
100644
(file)
--- a/
client/src/utils/gameStorage.js
+++ b/
client/src/utils/gameStorage.js
@@
-1,10
+1,10
@@
// Game object: {
// // Static informations:
// Game object: {
// // Static informations:
-//
gameI
d: string
+//
i
d: string
// vname: string,
// fenStart: string,
// players: array of sid+id+name,
// vname: string,
// fenStart: string,
// players: array of sid+id+name,
-//
timeControl
: string,
+//
cadence
: string,
// increment: integer (seconds),
// mode: string ("live" or "corr")
// imported: boolean (optional, default false)
// increment: integer (seconds),
// mode: string ("live" or "corr")
// imported: boolean (optional, default false)
@@
-17,6
+17,7
@@
// }
import { ajax } from "@/utils/ajax";
// }
import { ajax } from "@/utils/ajax";
+import { store } from "@/store";
function dbOperation(callback)
{
function dbOperation(callback)
{
@@
-24,7
+25,7
@@
function dbOperation(callback)
let DBOpenRequest = window.indexedDB.open("vchess", 4);
DBOpenRequest.onerror = function(event) {
let DBOpenRequest = window.indexedDB.open("vchess", 4);
DBOpenRequest.onerror = function(event) {
- alert(
"Database error:
" + event.target.errorCode);
+ alert(
store.state.tr["Database error:"] + "
" + event.target.errorCode);
};
DBOpenRequest.onsuccess = function(event) {
};
DBOpenRequest.onsuccess = function(event) {
@@
-36,10
+37,10
@@
function dbOperation(callback)
DBOpenRequest.onupgradeneeded = function(event) {
let db = event.target.result;
db.onerror = function(event) {
DBOpenRequest.onupgradeneeded = function(event) {
let db = event.target.result;
db.onerror = function(event) {
- alert(
"Error while loading database:
" + event.target.errorCode);
+ alert(
store.state.tr["Error while loading database:"] + "
" + event.target.errorCode);
};
// Create objectStore for vchess->games
};
// Create objectStore for vchess->games
- let objectStore = db.createObjectStore("games", { keyPath: "
gameI
d" });
+ let objectStore = db.createObjectStore("games", { keyPath: "
i
d" });
objectStore.createIndex("score", "score"); //to search by game result
}
}
objectStore.createIndex("score", "score"); //to search by game result
}
}
@@
-47,7
+48,6
@@
function dbOperation(callback)
export const GameStorage =
{
// Optional callback to get error status
export const GameStorage =
{
// Optional callback to get error status
- // TODO: this func called from Hall seems to not work now...
add: function(game, callback)
{
dbOperation((db) => {
add: function(game, callback)
{
dbOperation((db) => {
@@
-58,7
+58,7
@@
export const GameStorage =
callback({}); //everything's fine
}
transaction.onerror = function() {
callback({}); //everything's fine
}
transaction.onerror = function() {
- callback({errmsg:
"addGame failed:
" + transaction.error});
+ callback({errmsg:
store.state.tr["Game retrieval failed:"] + "
" + transaction.error});
};
}
let objectStore = transaction.objectStore("games");
};
}
let objectStore = transaction.objectStore("games");
@@
-67,7
+67,8
@@
export const GameStorage =
},
// TODO: also option to takeback a move ?
},
// TODO: also option to takeback a move ?
- update: function(gameId, obj) //move, fen, clocks, score, initime, ...
+ // obj: chat, move, fen, clocks, score[Msg], initime, ...
+ update: function(gameId, obj)
{
if (Number.isInteger(gameId) || !isNaN(parseInt(gameId)))
{
{
if (Number.isInteger(gameId) || !isNaN(parseInt(gameId)))
{
@@
-79,10
+80,13
@@
export const GameStorage =
gid: gameId,
newObj:
{
gid: gameId,
newObj:
{
- // TODO: I think stringify isn't requuired here (see ajax() )
- move: JSON.stringify(obj.move), //may be undefined...
+ // Some fields may be undefined:
+ chat: obj.chat,
+ move: obj.move,
fen: obj.fen,
score: obj.score,
fen: obj.fen,
score: obj.score,
+ scoreMsg: obj.scoreMsg,
+ drawOffer: obj.drawOffer,
}
}
);
}
}
);
@@
-134,7
+138,11
@@
export const GameStorage =
if (Number.isInteger(gameId) || !isNaN(parseInt(gameId)))
{
ajax("/games", "GET", {gid:gameId}, res => {
if (Number.isInteger(gameId) || !isNaN(parseInt(gameId)))
{
ajax("/games", "GET", {gid:gameId}, res => {
- callback(res.game);
+ let game = res.game;
+ game.moves.forEach(m => {
+ m.squares = JSON.parse(m.squares);
+ });
+ callback(game);
});
}
else //local game
});
}
else //local game
@@
-169,7
+177,7
@@
export const GameStorage =
callback({}); //everything's fine
}
transaction.onerror = function() {
callback({}); //everything's fine
}
transaction.onerror = function() {
- callback({errmsg:
"removeGame failed:
" + transaction.error});
+ callback({errmsg:
store.state.tr["Game removal failed:"] + "
" + transaction.error});
};
}
transaction.objectStore("games").delete(gameId);
};
}
transaction.objectStore("games").delete(gameId);