Skip to content

A MediaWiki extension to display and animate chess games (boards and moves) given in PGN format

License

Notifications You must be signed in to change notification settings

xeyownt/mwpgnjs

Repository files navigation

PgnJS

PgnJS is a MediaWiki extension that displays chess games (boards and moves) interactively. Chess games are simply given in PGN format in a <pgn> tag and displayed thanks to the powerful javascript engine PgnViewerJS. In fact most of the functionality is provided by PgnViewerJS. This extension only implements the parsing of the <pgn> tag.

Visit PgnJS test page on WikiTest for examples and trying the extension by yourself.

Status

Currently this extension is in beta status, ie. it is stable but not fully tested. The latest known compatible version of MediaWiki is 1.35.1.

The extension contains many features, and future releases will likely add more. Some features might change in the future. The stability of each feature is detailed in the next section.

Features

We classify the features in one of these three categories:

  • Stable features will not change in future releases of the extension.
  • Experimental features are subject to change in future releases.
  • Broken features are features that are... broken. They indicate work-in-progress and may either be fixed, disappear or remain broken in future releases.

The Stable features are:

  • The 4 PgnViewerJS modes: board, view (default), print and edit. In print mode, use $220 NAG to print the board (see example).
  • The following PgnViewerJS attributes:
    • position (also in combination with PGN moves),
    • showNotation,
    • orientation,
    • theme,
    • pieceStyle (note that default is merida),
    • timerTime,
    • locale,
    • boardSize,
    • showFen,
    • size,
    • layout,
    • movesWidth,
    • movesHeight,
    • scrollable, and
    • headers.
  • CSS styling via standard attribute style. This is handy for specifying the DIV width (e.g. style="width: 200px").
  • Use MediaWiki templates to store complete boards or simply PGN strings (e.g. for translation purpose).
  • Read configuration from user preferences (locale, theme, piece style and timer time).

The Experimental features are:

  • Attribute goto to specify which move to display when board is created. For now only goto="first" and goto="last" are supported. This feature will remain available, but the keyword might change and it will be possible to select any move in the given PGN (pending a PgnViewerJS feature request).
  • Mode defaults to specify default configuration for next boards. When using this mode, no board is displayed but the given configuration is recorded for reuse in next boards. Mode defaults records the value for all given attributes, except attribute mode and attribute class. Previously saved configuration are ignored when using this mode, so one can clear the defaults with an empty tag <pgn mode="defaults" />.
  • Attribute class to specify one or more classname. This can be used for CSS styling, but also to organize defaults in separate classes. When using attribute class in mode defaults, the defaults are assigned to the given classnames. When used in other modes, the defaults assigned to each given classnames (if any) are loaded to configure the current pgn element, in addition to the anonymous defaults (if any). In case of multiple defaults, the one of the first given classname takes precedence over the next classname, and over any anonymous defaults.

The Broken features are:

  • None known.

Installation

The simplest is to clone the git repository in folder extensions of your wiki and run the install target (for MW 1.25 or above) or install-1.24 (for MW 1.24 or older):

cd /path/to/your/wiki/extensions
git clone --recursive --depth 1 https://github.com/xeyownt/mwpgnjs PgnJS
cd PgnJS
make install             # For MW 1.25 or above
make install-1.24        # For MW 1.24 or older

Don't forget the --recursive option since the extension uses git submodules.

make install / make install-1.24 will delete all files that are not necessary for the extension to run, and add the following line at the end of LocalSettings.php:

// For MW 1.25 or above:
wfLoadExtension( 'PgnJS' );
// For MW 1.24 or older:
require_once "$IP/extensions/PgnJS/PgnJS.php";

Done! Navigate to Special:Version on your wiki to verify that the extension is successfully installed.

Usage

The extension provides a new tag <pgn>. To embed a new chess game on your page, simply enclose the PGN representation of that game in a <pgn> tag.

Some examples:

Code Result
<pgn/> An empty board
<pgn>1. f4 e6 2. g4 Qh4</pgn> A board with moves
<pgn>1. f4 e6 2. g4 Qh4 {Oups!}</pgn> PGN may include annotation (or variants)
<pgn style="width: 200px">1. f3 e6 2. g4 Qh4</pgn> Some styling
<pgn mode="print">1. f3 $220 e6 2. g4 Qh4 $220</pgn> A board in print mode

More examples on the PgnJS test page or in the tests folder.

Contribute

See DEV.md and TODO.md.

Links

About

A MediaWiki extension to display and animate chess games (boards and moves) given in PGN format

Resources

License

Stars

Watchers

Forks

Packages

No packages published