moment/README.md

157 lines
5.7 KiB
Markdown
Raw Normal View History

# Mirage
[![Latest release](https://img.shields.io/github/v/release/mirukana/mirage)](https://github.com/mirukana/mirage/releases)
[![#mirage-client:matrix.org](https://img.shields.io/matrix/mirage-client:matrix.org)](https://matrix.to/#/#mirage-client:matrix.org)
2020-03-19 19:13:08 -04:00
[Features](#currently-implemented-features) ⬥
[Installation](INSTALL.md) ⬥
2020-03-19 19:42:49 -04:00
[Configuration & Theming](#configuration--theming) ⬥
[Screenshots](#more-screenshots)
2019-09-12 18:10:21 -04:00
2020-03-21 14:24:43 -04:00
A fancy, customizable, keyboard-operable [Matrix](https://matrix.org/) chat
client for encrypted and decentralized communication.
2020-03-21 15:42:32 -04:00
Written in Qt/QML + Python with [nio](https://github.com/poljar/matrix-nio),
**currently in alpha**.
2020-03-19 19:13:08 -04:00
![Chat screenshot](extra/general/screenshots/01-chat.png?raw=true)
2020-03-19 19:42:49 -04:00
## Currently Implemented Features
2019-07-18 08:10:36 -04:00
2020-06-26 08:33:22 -04:00
### Interface
2019-07-25 19:19:39 -04:00
2020-03-19 19:13:08 -04:00
- **Fluid interface** that adapts to any window size
2020-03-23 18:15:51 -04:00
- Toggleable **compact mode**
2020-03-19 19:13:08 -04:00
- Customizable **keyboard shortcuts** for (almost) everything, including
2020-03-21 17:42:45 -04:00
filtering/switching rooms, scrolling, sending files...
- Versatile **theming system**, properties can refer to each other and have
any valid ECMAScript 7 expression as values
2020-03-21 14:24:43 -04:00
- Comes by default with **dark** and **transparent themes**
2019-08-30 00:07:05 -04:00
2020-06-26 08:33:22 -04:00
### Accounts
2019-08-30 00:07:05 -04:00
2020-06-26 08:33:22 -04:00
- **Multiple accounts** in one client
2020-03-19 19:13:08 -04:00
- Set your display name and profile picture
- Import/export **E2E** key files
2020-06-26 08:33:22 -04:00
- Inspect, rename and manually verify your sessions
2019-07-18 08:10:36 -04:00
2020-03-19 19:13:08 -04:00
### Rooms
2020-03-19 19:13:08 -04:00
- Create, join, leave and forget rooms
- Send, accept and refuse invites
- Edit the room's name, topic, invite requirement, guest access and enable E2E
2020-05-14 23:25:36 -04:00
- Kick and ban users
2020-06-01 10:03:38 -04:00
- Unread message and highlight counters
- Sending **read receipts** to mark rooms as read
2020-03-19 19:13:08 -04:00
### Messages
2019-07-18 08:10:36 -04:00
2020-03-19 19:13:08 -04:00
- Send and receive **E2E encrypted messages**
- Send and receive emote messages (e.g. `/me reads attentively`)
- Receive notice (bot) messages
- Send **markdown** formatted messages
2020-03-21 17:42:45 -04:00
- Additional syntax for **coloring text**, e.g. `<red>(Some text...)` -
2020-03-19 19:13:08 -04:00
[SVG/CSS color names](https://www.december.com/html/spec/colorsvg.html),
and `#hex` codes can be used
- Send and receive normal or **E2E encrypted files**
- Client-side Matrix & HTTP URL **image previews**, including animated GIF
- User ID, display names, room ID and room aliases **mentions**
2020-04-03 08:50:10 -04:00
- Individual and mass **message removal**
2020-05-22 09:16:47 -04:00
- Sending **rich replies**
2019-07-18 08:10:36 -04:00
2020-03-19 19:13:08 -04:00
### Presence
2019-08-30 20:24:13 -04:00
2020-03-19 19:13:08 -04:00
- Typing notifications
2019-08-30 20:24:13 -04:00
2020-03-19 19:13:08 -04:00
## Installation
2019-07-18 08:10:36 -04:00
See [INSTALL.md](INSTALL.md)
2019-07-18 08:10:36 -04:00
2020-03-19 19:42:49 -04:00
## Configuration & Theming
2019-07-18 08:10:36 -04:00
2020-03-19 19:13:08 -04:00
The config file can be found at *$XDG_CONFIG_HOME/mirage/settings.json*,
or *~/.config/mirage/settings.json*.
2019-07-18 08:10:36 -04:00
For Flatpak users, this will be
*~/.var/app/io.github.mirukana.mirage/config/mirage* instead.
2020-06-11 21:50:26 -04:00
The config folder where *accounts.json* and *settings.json* is located can be
overriden by setting the `MIRAGE_CONFIG_DIR` environment variable.
The user data folder where *themes*, encryption data and interface states
are saved can be overriden with `MIRAGE_DATA_DIR`.
2020-06-11 21:50:26 -04:00
The cache folder where downloaded files and thumbnails are saved can be
overriden with `MIRAGE_CACHE_DIR`.
2020-03-19 19:13:08 -04:00
The `theme` setting can be:
2019-08-30 17:05:22 -04:00
- The filename of a built-in theme (`Midnight.qpl` or `Glass.qpl`)
- The filename of a custom theme at
*$XDG_DATA_HOME/mirage/themes*, *~/.local/share/mirage/themes*,
or *~/.var/app/io.github.mirukana.mirage/data/mirage/themes* (Flatpak)
2020-03-19 19:13:08 -04:00
A default theme from this repository can be copied to use as a base and edit,
for example:
```sh
cp mirage/src/themes/Midnight.qpl \
"${XDG_DATA_HOME:-$HOME/.local/share}/mirage/themes/MyTheme.qpl"
```
Or for Flatpak users:
```sh
cp mirage/src/themes/Midnight.qpl \
~/.var/app/io.github.mirukana.mirage/data/mirage/themes/MyTheme.qpl
```
The config setting `theme` would need to be set to `MyTheme.qpl` in this case.
2020-03-19 19:13:08 -04:00
Theme files are nested-by-indentations sections of properties and values.
Properties are declared as `<type> <name>: <value>`.
Values can be any JavaScript (ECMAScript 7) expressions.
Most of the properties are of type `color`.
Their values, if not just refering to another property,
can be expressed with a:
- [SVG/CSS color name](https://www.december.com/html/spec/colorsvg.html)
string, e.g. `"blue"`
2020-03-19 20:06:25 -04:00
- Hexadecimal code string, e.g. `"#fff"` or `"#cc0000"`
2020-03-19 19:13:08 -04:00
- RGBA value, using the `Qt.rgba(0-1, 0-1, 0-1, 0-1)` function
- HSLA value, using the `Qt.hsla(0-1, 0-1, 0-1, 0-1)` function
- HSVA value, using the `Qt.hsva(0-1, 0-1, 0-1, 0-1)` function
- [HSLUV](https://www.hsluv.org/) value, using the
`hsluv(0-360, 0-100, 0-100, 0-1)` function. This is the prefered method
used throughout the default theme files
(why? see [this](https://www.hsluv.org/comparison/#rainbow-hsluv) and
[that](https://www.boronine.com/2012/03/26/Color-Spaces-for-Human-Beings/#hsl-is-a-lemon))
If you just want to change the background picture,
or use a gradient/simple color instead, search for the `ui:` section in your
text editor.
With `Alt+Shift+R` by default, the config and theme can be reloaded without
restarting the app.
**Warnings**:
- API currently unstable: theme properties are often renamed, added or deleted.
- The file format for both config and themes will soon change
- The current file format forces all theme to have all properties
2020-03-19 19:13:08 -04:00
defined, instead of being able to only specify the ones to override from the
default theme.
GUI settings will also be implemented in the future.
2020-03-19 19:42:49 -04:00
## Screenshots
2020-03-19 19:13:08 -04:00
![Sign-in](extra/general/screenshots/02-sign-in.png)
![Account settings](extra/general/screenshots/03-account-settings.png)
![Room creation](extra/general/screenshots/04-create-room.png)
2020-03-19 19:42:49 -04:00
![Chat](extra/general/screenshots/01-chat.png?raw=true)
2020-03-19 19:13:08 -04:00
![Main pane in small window](extra/general/screenshots/05-main-pane-small.png)
![Chat in small window](extra/general/screenshots/06-chat-small.png)
![Room pane in small window](extra/general/screenshots/07-room-pane-small.png)
2019-08-30 17:05:22 -04:00