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.
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.
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
andedit
. 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 ismerida
), -
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 onlygoto="first"
andgoto="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. Modedefaults
records the value for all given attributes, except attributemode
and attributeclass
. 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 attributeclass
in modedefaults
, 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 currentpgn
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.
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.
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.