Element Desktop =============== Element Desktop is a Matrix client for desktop platforms with Element Web at its core. Fetching Element ================ Since this package is just the Electron wrapper for Element Web, it doesn't contain any of the Element Web code, so the first step is to get a working copy of Element Web. There are a few ways of doing this: ``` # Fetch the prebuilt release Element package from the riot.im GitHub releases page. The version # fetched will be the same as the local element-desktop package. # We're explicitly asking for no config, so the packaged Element will have no config.json. yarn run fetch --noverify --cfgdir '' ``` ...or if you'd like to use GPG to verify the downloaded package: ``` # Fetch the Element public key from the riot.im web server over a secure connection and import # it into your local GPG keychain (you'll need GPG installed). You only need to to do this # once. yarn run fetch --importkey # Fetch the package and verify the signature yarn run fetch --cfgdir '' ``` ...or either of the above, but fetching a specific version of Element: ``` # Fetch the prebuilt release Element package from the riot.im GitHub releases page. The version # fetched will be the same as the local element-desktop package. yarn run fetch --noverify --cfgdir '' v1.5.6 ``` If you only want to run the app locally and don't need to build packages, you can provide the `webapp` directory directly: ``` # Assuming you've checked out and built a copy of riot-web in ../riot-web ln -s ../riot-web/webapp ./ ``` [TODO: add support for fetching develop builds, arbitrary URLs and arbitrary paths] Building ======== Now you have a copy of Element, you're ready to build packages. If you'd just like to run Element locally, skip to the next section. ``` yarn run build ``` This will do a couple of things: * Run the `setversion` script to set the local package version to match whatever version of Element you installed above. * Run electron-builder to build a package. The package built will match the operating system you're running the build process on. If you're on Windows, you can choose to build specifically for 32 or 64 bit: ``` yarn run build32 ``` or ``` yarn run build64 ``` This build step will not build any native modules. If you'd like to build the native modules (for searching in encrypted rooms): This will take 10 minutes or so, and will require a number of native tools to be installed, depending on your OS (eg. rust, tcl, make/nmake). ``` yarn run build:native ``` On Windows, this will automatically determine the architecture to build for based on the environment (ie. set up by vcvarsall.bat). You can also build using docker, which will always produce the linux package: ``` # Run this once to make the docker image yarn run docker:setup yarn run docker:install # if you want to build the native modules (this will take a while) yarn run docker:buildnative yarn run docker:build ``` After running, the packages should be in `dist/`. Starting ======== If you'd just like to run the electron app locally for development: ``` # Install electron - we don't normally need electron itself as it's provided # by electron-builder when building packages yarn add electron yarn start ``` Config ====== If you'd like the packaged Element to have a configuration file, you can create a config directory and place `config.json` in there, then specify this directory with the `--cfgdir` option to `yarn run fetch`, eg: ``` mkdir myconfig cp /path/to/my/config.json myconfig/ yarn run fetch --cfgdir myconfig ``` The config dir for the official Element.im app is in `riot.im`. If you use this, your app will auto-update itself using builds from element.io. Profiles ======== To run multiple instances of the desktop app for different accounts, you can launch the executable with the `--profile` argument followed by a unique identifier, e.g `element-desktop --profile Work` for it to run a separate profile and not interfere with the default one. Alternatively, a custom location for the profile data can be specified using the `--profile-dir` flag followed by the desired path. User-specified config.json ========================== + `%APPDATA%\$NAME\config.json` on Windows + `$XDG_CONFIG_HOME\$NAME\config.json` or `~/.config/$NAME/config.json` on Linux + `~/Library/Application Support/$NAME/config.json` on macOS In the paths above, `$NAME` is typically `Element`, unless you use `--profile $PROFILE` in which case it becomes `Element-$PROFILE`, or it is using one of the above created by a pre-1.7 install, in which case it will be `Riot` or `Riot-$PROFILE`.