chessground-haichess
Version:
lichess.org Chess UI
99 lines • 14.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.start = void 0;
const board = require("./board");
const fen_1 = require("./fen");
const config_1 = require("./config");
const anim_1 = require("./anim");
const drag_1 = require("./drag");
const explosion_1 = require("./explosion");
function start(state, redrawAll) {
function toggleOrientation() {
board.toggleOrientation(state);
redrawAll();
}
return {
set(config) {
if (config.orientation && config.orientation !== state.orientation)
toggleOrientation();
(config.fen ? anim_1.anim : anim_1.render)(state => config_1.configure(state, config), state);
},
state,
getFen: () => fen_1.write(state.pieces),
toggleOrientation,
setPieces(pieces) {
anim_1.anim(state => board.setPieces(state, pieces), state);
},
selectSquare(key, force) {
if (key)
anim_1.anim(state => board.selectSquare(state, key, force), state);
else if (state.selected) {
board.unselect(state);
state.dom.redraw();
}
},
move(orig, dest) {
anim_1.anim(state => board.baseMove(state, orig, dest), state);
},
newPiece(piece, key) {
anim_1.anim(state => board.baseNewPiece(state, piece, key), state);
},
playPremove() {
if (state.premovable.current) {
if (anim_1.anim(board.playPremove, state))
return true;
state.dom.redraw();
}
return false;
},
playPredrop(validate) {
if (state.predroppable.current) {
const result = board.playPredrop(state, validate);
state.dom.redraw();
return result;
}
return false;
},
cancelPremove() {
anim_1.render(board.unsetPremove, state);
},
cancelPredrop() {
anim_1.render(board.unsetPredrop, state);
},
cancelMove() {
anim_1.render(state => {
board.cancelMove(state);
drag_1.cancel(state);
}, state);
},
stop() {
anim_1.render(state => {
board.stop(state);
drag_1.cancel(state);
}, state);
},
explode(keys) {
explosion_1.explosion(state, keys);
},
setAutoShapes(shapes) {
anim_1.render(state => (state.drawable.autoShapes = shapes), state);
},
setShapes(shapes) {
anim_1.render(state => (state.drawable.shapes = shapes), state);
},
getKeyAtDomPos(pos) {
return board.getKeyAtDomPos(pos, board.whitePov(state), state.dom.bounds());
},
redrawAll,
dragNewPiece(piece, event, force) {
drag_1.dragNewPiece(state, piece, event, force);
},
destroy() {
board.stop(state);
state.dom.unbind && state.dom.unbind();
state.dom.destroyed = true;
},
};
}
exports.start = start;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["src/api.ts"],"names":[],"mappings":"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","sourcesContent":["import { State } from './state';\nimport * as board from './board';\nimport { write as fenWrite } from './fen';\nimport { Config, configure } from './config';\nimport { anim, render } from './anim';\nimport { cancel as dragCancel, dragNewPiece } from './drag';\nimport { DrawShape } from './draw';\nimport { explosion } from './explosion';\nimport * as cg from './types';\n\nexport interface Api {\n  // reconfigure the instance. Accepts all config options, except for viewOnly & drawable.visible.\n  // board will be animated accordingly, if animations are enabled.\n  set(config: Config): void;\n\n  // read chessground state; write at your own risks.\n  state: State;\n\n  // get the position as a FEN string (only contains pieces, no flags)\n  // e.g. rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR\n  getFen(): cg.FEN;\n\n  // change the view angle\n  toggleOrientation(): void;\n\n  // perform a move programmatically\n  move(orig: cg.Key, dest: cg.Key): void;\n\n  // add and/or remove arbitrary pieces on the board\n  setPieces(pieces: cg.PiecesDiff): void;\n\n  // click a square programmatically\n  selectSquare(key: cg.Key | null, force?: boolean): void;\n\n  // put a new piece on the board\n  newPiece(piece: cg.Piece, key: cg.Key): void;\n\n  // play the current premove, if any; returns true if premove was played\n  playPremove(): boolean;\n\n  // cancel the current premove, if any\n  cancelPremove(): void;\n\n  // play the current predrop, if any; returns true if premove was played\n  playPredrop(validate: (drop: cg.Drop) => boolean): boolean;\n\n  // cancel the current predrop, if any\n  cancelPredrop(): void;\n\n  // cancel the current move being made\n  cancelMove(): void;\n\n  // cancel current move and prevent further ones\n  stop(): void;\n\n  // make squares explode (atomic chess)\n  explode(keys: cg.Key[]): void;\n\n  // programmatically draw user shapes\n  setShapes(shapes: DrawShape[]): void;\n\n  // programmatically draw auto shapes\n  setAutoShapes(shapes: DrawShape[]): void;\n\n  // square name at this DOM position (like \"e4\")\n  getKeyAtDomPos(pos: cg.NumberPair): cg.Key | undefined;\n\n  // only useful when CSS changes the board width/height ratio (for 3D)\n  redrawAll: cg.Redraw;\n\n  // for crazyhouse and board editors\n  dragNewPiece(piece: cg.Piece, event: cg.MouchEvent, force?: boolean): void;\n\n  // unbinds all events\n  // (important for document-wide events like scroll and mousemove)\n  destroy: cg.Unbind;\n}\n\n// see API types and documentations in dts/api.d.ts\nexport function start(state: State, redrawAll: cg.Redraw): Api {\n  function toggleOrientation(): void {\n    board.toggleOrientation(state);\n    redrawAll();\n  }\n\n  return {\n    set(config): void {\n      if (config.orientation && config.orientation !== state.orientation) toggleOrientation();\n      (config.fen ? anim : render)(state => configure(state, config), state);\n    },\n\n    state,\n\n    getFen: () => fenWrite(state.pieces),\n\n    toggleOrientation,\n\n    setPieces(pieces): void {\n      anim(state => board.setPieces(state, pieces), state);\n    },\n\n    selectSquare(key, force): void {\n      if (key) anim(state => board.selectSquare(state, key, force), state);\n      else if (state.selected) {\n        board.unselect(state);\n        state.dom.redraw();\n      }\n    },\n\n    move(orig, dest): void {\n      anim(state => board.baseMove(state, orig, dest), state);\n    },\n\n    newPiece(piece, key): void {\n      anim(state => board.baseNewPiece(state, piece, key), state);\n    },\n\n    playPremove(): boolean {\n      if (state.premovable.current) {\n        if (anim(board.playPremove, state)) return true;\n        // if the premove couldn't be played, redraw to clear it up\n        state.dom.redraw();\n      }\n      return false;\n    },\n\n    playPredrop(validate): boolean {\n      if (state.predroppable.current) {\n        const result = board.playPredrop(state, validate);\n        state.dom.redraw();\n        return result;\n      }\n      return false;\n    },\n\n    cancelPremove(): void {\n      render(board.unsetPremove, state);\n    },\n\n    cancelPredrop(): void {\n      render(board.unsetPredrop, state);\n    },\n\n    cancelMove(): void {\n      render(state => {\n        board.cancelMove(state);\n        dragCancel(state);\n      }, state);\n    },\n\n    stop(): void {\n      render(state => {\n        board.stop(state);\n        dragCancel(state);\n      }, state);\n    },\n\n    explode(keys: cg.Key[]): void {\n      explosion(state, keys);\n    },\n\n    setAutoShapes(shapes: DrawShape[]): void {\n      render(state => (state.drawable.autoShapes = shapes), state);\n    },\n\n    setShapes(shapes: DrawShape[]): void {\n      render(state => (state.drawable.shapes = shapes), state);\n    },\n\n    getKeyAtDomPos(pos): cg.Key | undefined {\n      return board.getKeyAtDomPos(pos, board.whitePov(state), state.dom.bounds());\n    },\n\n    redrawAll,\n\n    dragNewPiece(piece, event, force): void {\n      dragNewPiece(state, piece, event, force);\n    },\n\n    destroy(): void {\n      board.stop(state);\n      state.dom.unbind && state.dom.unbind();\n      state.dom.destroyed = true;\n    },\n  };\n}\n"]}