-
-
Notifications
You must be signed in to change notification settings - Fork 2.3k
Lichess UI Development
First, install the tools described on the main onboarding page.
There are three main types of code that UI contributors need to be aware of:
- scala - see https://internet for help with this
-
javascript - mostly built from typescript sources with the
.ts
extension -
css - compiled from SASS sources with the
.scss
extension
This guide will focus on javascript and css built from source in the top level ui
directory in lila in lila. This code is commonly referred to as the client.
The main build script is ui/build
. You run it, unsurprisingly, by typing ui/build
from the lila root directory.
The truly observant among us may notice that this script takes ages to run. This wiki outlines the build process and the main tools involved but is mainly focused on ways to speed things up.
ui/bleep
is a different way to build the client. It does everything that ui/build
does but keeps running - incrementally compiling and bundling any edits you make to the client source. When you save your changes to the code, you can just switch to your browser and press <shift> F5
(hard reload) a few seconds later to see them in action.
<path-to-lila>/ui/bleep --help
Go ahead and monkey with the UI code while remaining completely ignorant of all dependencies without waiting for ui/build
. It is recommended by 9 out of 10 gastroenterologists.
Next is a brief outline of the tools involved for those who want complete control over what builds, when it builds, and some understanding of why it must be built.
You should learn about yarn.
Meta™ forked yarn
from npm back when they were still Facebook™, probably due to deep philosophical differences about usage of the word add versus install. Or maybe they were not satisfied with the volume of cached files that npm
maintains and sought to increase it somehow. For most purposes their capabilities are the same, but they do not like each other and get in unruly brawls about package lock files so you should stick to yarn
for lila unless you know what you're doing.
Lichess uses tsc
to compile typescript code to javascript, gulp
to manage the compilation of *.scss
SASS files into CSS, and rollup
to compile the rest of the typescript (via typescript plugin) and bundle the result with its dependencies into a single javascript module suitable for linkage in an HTML <script>
tag.
First get as much done as possible in your browser inspector. Tinker with css, inspect your js objects, click your buttons, click them all twice. When you're ready to apply changes to code:
-
css - From the
ui
directory, typeyarn gulp css
. You can also background that. Any changes you make to scss files will be incrementally compiled and the changes will be visible after a hard reload of your browser. You're done. Read aboutgulp
here. If you just want to build the current scss without entering watch mode,yarn gulp css-dev
will do that. -
javascript - In many
ui
module subdirectories, you can simply typeyarn run dev
and see the changes immediately after a hard reload. Sometimes you need to runyarn run plugin-dev <plugin>
(oryarn run all-dev
where available). Inspect the"scripts"
inpackage.json
and if there are plugin targets, look inrollupconfig.mjs
to discover their names. Currentlyanalyse
,site
,round
,chart
, andmod
are split into plugins. The rest you can bundle withyarn run dev
.
For example, changes applied by the following commands will be usable after a hard browser reload or server restart:
-
cd <lila>/ui; yarn gulp css
- watches all scss files in ui/* and rebuilds as needed -
cd <lila>/ui/lobby; yarn run dev
- builds the lobby module -
cd <lila>/ui/site; yarn run all-dev
- builds the site module (including all plugins) -
cd <lila>/ui/chart; yarn run plugin-dev game
- builds thegame
plugin inchart
.yarn run dev
won't cut it here.
At this point you might wonder, why do I have to run these yarn
commands every time I change something? Why can't I have incremental compilation just like yarn gulp css
does for css, but without using bleep
? You can. Add --watch
to the end of your yarn
command and it will keep running and trigger a fast recompile every time you change a source in that module. So the above examples become:
-
yarn run dev --watch
(in lobby) -
yarn run all-dev --watch
(in site) -
yarn run plugin-dev game --watch
(in chart)
And so on. If you don't want to open multiple terminals, you can safely background one or more of those processes. Keep in mind that yarn ... --watch
may not be available in dependency modules such as common
, ceval
, or chess
. You must look at the package.json
files in the root of each module directory to discover how they all work together. Pay attention to "dependencies"
and build commands in "scripts"
and all shall be revealed.
How about when you need to make changes to a module from the npm
registry such as chessground
? For that, you can use yarn link
.
In a nutshell, clone the repo you want to modify to <local-package-version>
. Make your changes and recite whatever bizarre incantations are required to build it. If chickens must be sacrificed, please ensure they are no-antibiotic free range chickens to comply with GPL3's guidelines on ritual sacrifice in a derived work. Then do the following:
cd <local-package-version>
yarn link
-
cd <lila>
- the main lila project directory (notui
) yarn link <name-of-the-package-in-package-json>
This creates a symlink to <local-package-version>
in the secret ~/.config/yarn/link
directory and creates a symlink in /node_modules/<name-of-package>
that points to other symlink. You will also need to build whatever ui
module(s) or plugin(s) that references the package. Note that bleep
or yarn run ... --watch
should pick up changes in the linked package and build dependencies so if you have things set up right, you might not need to do anything but hard reload to see new changes in your linked package.
-
Symbols you can use on lichess webpages (defined in
public/font/lichess.sfd
) - come on guys help me out. add some links