Merge pull request #333 from zecakeh/fractal-matrix-uri
Add support for deeplink for Fractal
This commit is contained in:
commit
cba383bc32
1 changed files with 30 additions and 2 deletions
|
@ -24,11 +24,39 @@ export class Fractal {
|
|||
get name() { return "Fractal"; }
|
||||
get icon() { return "images/client-icons/fractal.svg"; }
|
||||
get author() { return "Daniel Garcia Moreno"; }
|
||||
get homepage() { return "https://gitlab.gnome.org/GNOME/fractal"; }
|
||||
get homepage() { return "https://gitlab.gnome.org/World/fractal"; }
|
||||
get platforms() { return [Platform.Linux]; }
|
||||
get description() { return 'GNOME client, suitable for desktop and mobile. Written in Rust.'; }
|
||||
getMaturity(platform) { return Maturity.Beta; }
|
||||
getDeepLink(platform, link) {}
|
||||
|
||||
getDeepLink(platform, link) {
|
||||
if (platform === Platform.Linux) {
|
||||
let identifier = encodeURIComponent(link.identifier.substring(1));
|
||||
let isRoomid = link.identifier.substring(0, 1) === '!';
|
||||
let fragmentPath;
|
||||
switch (link.kind) {
|
||||
case LinkKind.User:
|
||||
fragmentPath = `u/${identifier}?action=chat`;
|
||||
break;
|
||||
case LinkKind.Room:
|
||||
case LinkKind.Event:
|
||||
if (isRoomid)
|
||||
fragmentPath = `roomid/${identifier}`;
|
||||
else
|
||||
fragmentPath = `r/${identifier}`;
|
||||
|
||||
if (link.kind === LinkKind.Event)
|
||||
fragmentPath += `/e/${encodeURIComponent(link.eventId.substring(1))}`;
|
||||
fragmentPath += '?action=join';
|
||||
fragmentPath += link.servers.map(server => `&via=${encodeURIComponent(server)}`).join('');
|
||||
break;
|
||||
case LinkKind.Group:
|
||||
return;
|
||||
}
|
||||
return `matrix:${fragmentPath}`;
|
||||
}
|
||||
}
|
||||
|
||||
canInterceptMatrixToLinks(platform) { return false; }
|
||||
|
||||
getLinkInstructions(platform, link) {
|
||||
|
|
Loading…
Reference in a new issue