parent
481ab9d8fa
commit
3810b7e329
|
@ -10,10 +10,6 @@
|
||||||
"Download Completed": "Download Completed",
|
"Download Completed": "Download Completed",
|
||||||
"Open": "Open",
|
"Open": "Open",
|
||||||
"Dismiss": "Dismiss",
|
"Dismiss": "Dismiss",
|
||||||
"Switch to space by number": "Switch to space by number",
|
|
||||||
"Open user settings": "Open user settings",
|
|
||||||
"Previous recently visited room or community": "Previous recently visited room or community",
|
|
||||||
"Next recently visited room or community": "Next recently visited room or community",
|
|
||||||
"%(brand)s Desktop (%(platformName)s)": "%(brand)s Desktop (%(platformName)s)",
|
"%(brand)s Desktop (%(platformName)s)": "%(brand)s Desktop (%(platformName)s)",
|
||||||
"Go to your browser to complete Sign In": "Go to your browser to complete Sign In",
|
"Go to your browser to complete Sign In": "Go to your browser to complete Sign In",
|
||||||
"Unknown device": "Unknown device",
|
"Unknown device": "Unknown device",
|
||||||
|
|
|
@ -26,7 +26,7 @@ import BaseEventIndexManager, {
|
||||||
ISearchArgs,
|
ISearchArgs,
|
||||||
} from 'matrix-react-sdk/src/indexing/BaseEventIndexManager';
|
} from 'matrix-react-sdk/src/indexing/BaseEventIndexManager';
|
||||||
import dis from 'matrix-react-sdk/src/dispatcher/dispatcher';
|
import dis from 'matrix-react-sdk/src/dispatcher/dispatcher';
|
||||||
import { _t, _td } from 'matrix-react-sdk/src/languageHandler';
|
import { _t } from 'matrix-react-sdk/src/languageHandler';
|
||||||
import SdkConfig from 'matrix-react-sdk/src/SdkConfig';
|
import SdkConfig from 'matrix-react-sdk/src/SdkConfig';
|
||||||
import * as rageshake from 'matrix-react-sdk/src/rageshake/rageshake';
|
import * as rageshake from 'matrix-react-sdk/src/rageshake/rageshake';
|
||||||
import { MatrixClient } from "matrix-js-sdk/src/client";
|
import { MatrixClient } from "matrix-js-sdk/src/client";
|
||||||
|
@ -34,22 +34,14 @@ import { Room } from "matrix-js-sdk/src/models/room";
|
||||||
import Modal from "matrix-react-sdk/src/Modal";
|
import Modal from "matrix-react-sdk/src/Modal";
|
||||||
import InfoDialog from "matrix-react-sdk/src/components/views/dialogs/InfoDialog";
|
import InfoDialog from "matrix-react-sdk/src/components/views/dialogs/InfoDialog";
|
||||||
import Spinner from "matrix-react-sdk/src/components/views/elements/Spinner";
|
import Spinner from "matrix-react-sdk/src/components/views/elements/Spinner";
|
||||||
import {
|
|
||||||
CategoryName,
|
|
||||||
DIGITS,
|
|
||||||
registerShortcut,
|
|
||||||
} from "matrix-react-sdk/src/accessibility/KeyboardShortcuts";
|
|
||||||
import { isOnlyCtrlOrCmdKeyEvent, Key } from "matrix-react-sdk/src/Keyboard";
|
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { randomString } from "matrix-js-sdk/src/randomstring";
|
import { randomString } from "matrix-js-sdk/src/randomstring";
|
||||||
import { Action } from "matrix-react-sdk/src/dispatcher/actions";
|
import { Action } from "matrix-react-sdk/src/dispatcher/actions";
|
||||||
import { ActionPayload } from "matrix-react-sdk/src/dispatcher/payloads";
|
import { ActionPayload } from "matrix-react-sdk/src/dispatcher/payloads";
|
||||||
import { SwitchSpacePayload } from "matrix-react-sdk/src/dispatcher/payloads/SwitchSpacePayload";
|
|
||||||
import { showToast as showUpdateToast } from "matrix-react-sdk/src/toasts/UpdateToast";
|
import { showToast as showUpdateToast } from "matrix-react-sdk/src/toasts/UpdateToast";
|
||||||
import { CheckUpdatesPayload } from "matrix-react-sdk/src/dispatcher/payloads/CheckUpdatesPayload";
|
import { CheckUpdatesPayload } from "matrix-react-sdk/src/dispatcher/payloads/CheckUpdatesPayload";
|
||||||
import ToastStore from "matrix-react-sdk/src/stores/ToastStore";
|
import ToastStore from "matrix-react-sdk/src/stores/ToastStore";
|
||||||
import GenericExpiringToast from "matrix-react-sdk/src/components/views/toasts/GenericExpiringToast";
|
import GenericExpiringToast from "matrix-react-sdk/src/components/views/toasts/GenericExpiringToast";
|
||||||
import SettingsStore from 'matrix-react-sdk/src/settings/SettingsStore';
|
|
||||||
import { IMatrixProfile, IEventWithRoomId as IMatrixEvent, IResultRoomEvents } from "matrix-js-sdk/src/@types/search";
|
import { IMatrixProfile, IEventWithRoomId as IMatrixEvent, IResultRoomEvents } from "matrix-js-sdk/src/@types/search";
|
||||||
import { logger } from "matrix-js-sdk/src/logger";
|
import { logger } from "matrix-js-sdk/src/logger";
|
||||||
import { MatrixEvent } from "matrix-js-sdk/src/models/event";
|
import { MatrixEvent } from "matrix-js-sdk/src/models/event";
|
||||||
|
@ -285,54 +277,6 @@ export default class ElectronPlatform extends VectorBasePlatform {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// register OS-specific shortcuts
|
|
||||||
registerShortcut("KeyBinding.switchToSpaceByNumber", CategoryName.NAVIGATION, {
|
|
||||||
default: {
|
|
||||||
ctrlOrCmdKey: true,
|
|
||||||
key: DIGITS,
|
|
||||||
},
|
|
||||||
displayName: _td("Switch to space by number"),
|
|
||||||
});
|
|
||||||
|
|
||||||
if (isMac) {
|
|
||||||
registerShortcut("KeyBinding.openUserSettings", CategoryName.NAVIGATION, {
|
|
||||||
default: {
|
|
||||||
metaKey: true,
|
|
||||||
key: Key.COMMA,
|
|
||||||
},
|
|
||||||
displayName: _td("Open user settings"),
|
|
||||||
});
|
|
||||||
registerShortcut("KeyBinding.previousVisitedRoomOrCommunity", CategoryName.NAVIGATION, {
|
|
||||||
default: {
|
|
||||||
metaKey: true,
|
|
||||||
key: Key.SQUARE_BRACKET_LEFT,
|
|
||||||
},
|
|
||||||
displayName: _td("Previous recently visited room or community"),
|
|
||||||
});
|
|
||||||
registerShortcut("KeyBinding.nextVisitedRoomOrCommunity", CategoryName.NAVIGATION, {
|
|
||||||
default: {
|
|
||||||
metaKey: true,
|
|
||||||
key: Key.SQUARE_BRACKET_RIGHT,
|
|
||||||
},
|
|
||||||
displayName: _td("Next recently visited room or community"),
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
registerShortcut("KeyBinding.previousVisitedRoomOrCommunity", CategoryName.NAVIGATION, {
|
|
||||||
default: {
|
|
||||||
altKey: true,
|
|
||||||
key: Key.ARROW_LEFT,
|
|
||||||
},
|
|
||||||
displayName: _td("Previous recently visited room or community"),
|
|
||||||
});
|
|
||||||
registerShortcut("KeyBinding.nextVisitedRoomOrCommunity", CategoryName.NAVIGATION, {
|
|
||||||
default: {
|
|
||||||
altKey: true,
|
|
||||||
key: Key.ARROW_RIGHT,
|
|
||||||
},
|
|
||||||
displayName: _td("Next recently visited room or community"),
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
this.ipcCall("startSSOFlow", this.ssoID);
|
this.ipcCall("startSSOFlow", this.ssoID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -578,52 +522,12 @@ export default class ElectronPlatform extends VectorBasePlatform {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private navigateForwardBack(back: boolean) {
|
public navigateForwardBack(back: boolean): void {
|
||||||
this.ipcCall(back ? "navigateBack" : "navigateForward");
|
this.ipcCall(back ? "navigateBack" : "navigateForward");
|
||||||
}
|
}
|
||||||
|
|
||||||
private navigateToSpace(num: number) {
|
public overrideBrowserShortcuts(): boolean {
|
||||||
dis.dispatch<SwitchSpacePayload>({
|
return true;
|
||||||
action: Action.SwitchSpace,
|
|
||||||
num,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
onKeyDown(ev: KeyboardEvent): boolean {
|
|
||||||
let handled = false;
|
|
||||||
|
|
||||||
switch (ev.key) {
|
|
||||||
case Key.SQUARE_BRACKET_LEFT:
|
|
||||||
case Key.SQUARE_BRACKET_RIGHT:
|
|
||||||
if (isMac && ev.metaKey && !ev.altKey && !ev.ctrlKey && !ev.shiftKey) {
|
|
||||||
this.navigateForwardBack(ev.key === Key.SQUARE_BRACKET_LEFT);
|
|
||||||
handled = true;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Key.ARROW_LEFT:
|
|
||||||
case Key.ARROW_RIGHT:
|
|
||||||
if (!isMac && ev.altKey && !ev.metaKey && !ev.ctrlKey && !ev.shiftKey) {
|
|
||||||
this.navigateForwardBack(ev.key === Key.ARROW_LEFT);
|
|
||||||
handled = true;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!handled &&
|
|
||||||
// ideally we would use SpaceStore.spacesEnabled here but importing SpaceStore in this platform
|
|
||||||
// breaks skinning as the platform is instantiated prior to the skin being loaded
|
|
||||||
!SettingsStore.getValue("showCommunitiesInsteadOfSpaces") &&
|
|
||||||
ev.code.startsWith("Digit") &&
|
|
||||||
ev.code !== "Digit0" && // this is the shortcut for reset zoom, don't override it
|
|
||||||
isOnlyCtrlOrCmdKeyEvent(ev)
|
|
||||||
) {
|
|
||||||
const spaceNumber = ev.code.slice(5); // Cut off the first 5 characters - "Digit"
|
|
||||||
this.navigateToSpace(parseInt(spaceNumber, 10));
|
|
||||||
handled = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return handled;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async getPickleKey(userId: string, deviceId: string): Promise<string | null> {
|
async getPickleKey(userId: string, deviceId: string): Promise<string | null> {
|
||||||
|
|
Loading…
Reference in New Issue