mirror of
https://github.com/ankitects/anki.git
synced 2025-09-18 22:12:21 -04:00
Merge pull request #1273 from hgiesel/macshortcuts
Execute Ctrl+C/V/X/A via execCommand in editor
This commit is contained in:
commit
581c3e2486
2 changed files with 10 additions and 17 deletions
|
@ -210,7 +210,9 @@ class WebContent:
|
||||||
|
|
||||||
class AnkiWebView(QWebEngineView):
|
class AnkiWebView(QWebEngineView):
|
||||||
def __init__(
|
def __init__(
|
||||||
self, parent: Optional[QWidget] = None, title: str = "default"
|
self,
|
||||||
|
parent: Optional[QWidget] = None,
|
||||||
|
title: str = "default",
|
||||||
) -> None:
|
) -> None:
|
||||||
QWebEngineView.__init__(self, parent=parent)
|
QWebEngineView.__init__(self, parent=parent)
|
||||||
self.set_title(title)
|
self.set_title(title)
|
||||||
|
@ -238,22 +240,6 @@ class AnkiWebView(QWebEngineView):
|
||||||
context=Qt.WidgetWithChildrenShortcut,
|
context=Qt.WidgetWithChildrenShortcut,
|
||||||
activated=self.onEsc,
|
activated=self.onEsc,
|
||||||
)
|
)
|
||||||
if isMac:
|
|
||||||
for key, fn in [
|
|
||||||
(QKeySequence.Copy, self.onCopy),
|
|
||||||
(QKeySequence.Paste, self.onPaste),
|
|
||||||
(QKeySequence.Cut, self.onCut),
|
|
||||||
(QKeySequence.SelectAll, self.onSelectAll),
|
|
||||||
]:
|
|
||||||
QShortcut( # type: ignore
|
|
||||||
key, self, context=Qt.WidgetWithChildrenShortcut, activated=fn
|
|
||||||
)
|
|
||||||
QShortcut( # type: ignore
|
|
||||||
QKeySequence("ctrl+shift+v"),
|
|
||||||
self,
|
|
||||||
context=Qt.WidgetWithChildrenShortcut,
|
|
||||||
activated=self.onPaste,
|
|
||||||
)
|
|
||||||
|
|
||||||
def set_title(self, title: str) -> None:
|
def set_title(self, title: str) -> None:
|
||||||
self.title = title # type: ignore[assignment]
|
self.title = title # type: ignore[assignment]
|
||||||
|
|
|
@ -8,6 +8,8 @@
|
||||||
import { filterHTML } from "html-filter";
|
import { filterHTML } from "html-filter";
|
||||||
import { updateActiveButtons, disableButtons } from "./toolbar";
|
import { updateActiveButtons, disableButtons } from "./toolbar";
|
||||||
import { setupI18n, ModuleName } from "lib/i18n";
|
import { setupI18n, ModuleName } from "lib/i18n";
|
||||||
|
import { registerShortcut } from "lib/shortcuts";
|
||||||
|
import { bridgeCommand } from "./lib";
|
||||||
|
|
||||||
import "./fields.css";
|
import "./fields.css";
|
||||||
|
|
||||||
|
@ -40,6 +42,11 @@ customElements.define("anki-editing-area", EditingArea, { extends: "div" });
|
||||||
customElements.define("anki-label-container", LabelContainer, { extends: "div" });
|
customElements.define("anki-label-container", LabelContainer, { extends: "div" });
|
||||||
customElements.define("anki-editor-field", EditorField, { extends: "div" });
|
customElements.define("anki-editor-field", EditorField, { extends: "div" });
|
||||||
|
|
||||||
|
registerShortcut(() => document.execCommand("copy"), "Control+C");
|
||||||
|
registerShortcut(() => document.execCommand("cut"), "Control+X");
|
||||||
|
registerShortcut(() => document.execCommand("selectAll"), "Control+A");
|
||||||
|
registerShortcut(() => bridgeCommand("paste"), "Control+Shift+V");
|
||||||
|
|
||||||
export function getCurrentField(): EditingArea | null {
|
export function getCurrentField(): EditingArea | null {
|
||||||
return document.activeElement instanceof EditingArea
|
return document.activeElement instanceof EditingArea
|
||||||
? document.activeElement
|
? document.activeElement
|
||||||
|
|
Loading…
Reference in a new issue