{
elementArray.push(
h('div',
- { },
+ { attrs: { id: "pgn-div" } },
[
+ h('a',
+ {
+ attrs: {
+ id: "download",
+ href: "#",
+ }
+ }
+ ),
h('p',
{
+ attrs: { id: "pgn-game" },
+ on: { click: this.download },
domProps: {
innerHTML: this.vr.getPGN(this.mycolor, this.score, this.fenStart, this.mode)
}
this.conn.onclose = socketCloseListener;
},
methods: {
+ download: function() {
+ let content = document.getElementById("pgn-game").innerHTML;
+ content = content.replace(/<br>/g, "\n");
+ // Prepare and trigger download link
+ let downloadAnchor = document.getElementById("download");
+ downloadAnchor.setAttribute("download", "game.pgn");
+ downloadAnchor.href = "data:text/plain;charset=utf-8," + encodeURIComponent(content);
+ downloadAnchor.click();
+ },
endGame: function(score) {
this.score = score;
let modalBox = document.getElementById("modal-eog");
this.selectedPiece.style.display = "inline-block";
this.selectedPiece.style.zIndex = 3000;
let startSquare = this.getSquareFromId(e.target.parentNode.id);
- this.possibleMoves = this.vr.canIplay(this.mycolor,startSquare)
+ this.possibleMoves = this.mode!="idle" && this.vr.canIplay(this.mycolor,startSquare)
? this.vr.getPossibleMovesFrom(startSquare)
: [];
e.target.parentNode.appendChild(this.selectedPiece);