PGN viewer widget, designed to be embedded in content pages.
This won't replace a fully featured analysis board.
Lichess PGN Viewer is distributed under the GPL-3.0 license (or any later version, at your option). When you use it for your website, your combined work may be distributed only under the GPL. You must release your source code to the users of your website.
Please read more about GPL for JavaScript on greendrake.info.
- load and render very fast
- browse through a game
- variation tree
- PGN comments
- players and clocks
- mobile support
- accessible to screen readers with ARIA support
- translatable and customisable
- client-side only
- easy to set up on any page
- custom user moves
- engine support
- opening explorer
For these features, use an analysis board or Lichess studies.
The viewer is fully accessible to screen reader users with:
- Complete board representation: Screen readers can navigate through all 64 squares with piece positions announced
- Live move announcements: Real-time narration of moves including number, color, notation, and annotations
- Keyboard navigation: All controls accessible via keyboard (arrow keys for moves, 'f' to flip board)
- ARIA labels and roles: Comprehensive semantic markup for assistive technologies
- Game context: Players, ratings, result, and timing information properly announced
pnpm install
pnpm run demo
Then open the demo page at http://localhost:8080
npm i @lichess-org/pgn-viewer
import LichessPgnViewer from '@lichess-org/pgn-viewer';
const lpv = LichessPgnViewer(domElement, {
  pgn: 'e4 c5 Nf3 d6 e5 Nc6 exd6 Qxd6 Nc3 Nf6',
});
// lpv is an instance of PgnViewer , providing some utilities such as:
lpv.goTo('first');
lpv.goTo('next');
lpv.flip();
console.log(lpv.game);
// see more in pgnViewer.tsconst lpv = LichessPgnViewer(domElement, {
  pgn: 'e4 c5 Nf3 d6 e5 Nc6 exd6 Qxd6 Nc3 Nf6',
  // ... more Config
});See all configuration options in the documented source code.
View more examples in demo/index.html
If you use SCSS, you can import the styles with:
@import '../../node_modules/@lichess-org/pgn-viewer/scss/lichess-pgn-viewer.lib';Customisable SCSS variables are available, see how lichess configures pgn-viewer with SCSS.
Alternatively you can build a CSS file with
npm run sass-prodThen copy the dist/lichess-pgn-viewer.css file into your project.
pnpm test
## or
pnpm test:watch- Vue.js: dragunovartem99/vue-pgn-viewer
More? Please make a pull request to include it here.
- https://github.com/lichess-org/pgn-viewer/actions/workflows/release.yaml
- [Run workflow]
- Branch: master
- Version tag: vX.Y.Z
The release workflow will increment the package.json version, create the tag, the github release, and publish to npm
