UNPKG

lichess-pgn-viewer

Version:

PGN viewer widget, designed to be embedded in content pages.

47 lines (42 loc) 2.13 kB
import { Opts } from './interfaces'; const defaults: Opts = { pgn: '*', // the PGN to render fen: undefined, // initial FEN, will append [FEN "initial FEN"] to the PGN showPlayers: 'auto', // show the players above and under the board showClocks: true, // show the clocks alongside the players showMoves: 'auto', // false | "right" | "bottom" | auto. "auto" uses media queries showControls: true, // show the [prev, menu, next] buttons scrollToMove: true, // enable scrolling through moves with a mouse wheel orientation: undefined, // orientation of the board. Undefined to use the Orientation PGN tag. initialPly: 0, // current position to display. Can be a number, or "last" chessground: {}, // chessground configuration https://github.com/lichess-org/chessground/blob/master/src/config.ts#L7 drawArrows: true, // allow mouse users to draw volatile arrows on the board. Disable for little perf boost menu: { getPgn: { enabled: true, // enable the "Get PGN" menu entry fileName: undefined, // name of the file when user clicks "Download PGN". Leave empty for automatic name. }, }, lichess: 'https://lichess.org', // support for Lichess games, with links to the game and players. Set to false to disable. classes: undefined, // CSS classes to set on the root element. Defaults to the element classes before being replaced by LPV. }; export default function (element: HTMLElement, cfg: Partial<Opts>) { const opts = { ...defaults }; deepMerge(opts, cfg); if (opts.fen) opts.pgn = `[FEN "${opts.fen}"]\n${opts.pgn}`; if (!opts.classes) opts.classes = element.className; return opts; } function deepMerge(base: any, extend: any): void { for (const key in extend) { if (typeof extend[key] !== 'undefined') { if (isPlainObject(base[key]) && isPlainObject(extend[key])) deepMerge(base[key], extend[key]); else base[key] = extend[key]; } } } function isPlainObject(o: unknown): boolean { if (typeof o !== 'object' || o === null) return false; const proto = Object.getPrototypeOf(o); return proto === Object.prototype || proto === null; }