Add simple version of Chooser buttons

This commit is contained in:
Henrik Giesel 2021-04-23 21:25:44 +02:00
parent 48b7cb49f9
commit 8ecd4f8c95
2 changed files with 38 additions and 5 deletions

View File

@ -13,6 +13,7 @@ from anki.notes import DuplicateOrEmptyResult, Note, NoteId
from anki.utils import htmlToTextLine, isMac from anki.utils import htmlToTextLine, isMac
from aqt import AnkiQt, gui_hooks from aqt import AnkiQt, gui_hooks
from aqt.deckchooser import DeckChooser from aqt.deckchooser import DeckChooser
from aqt.editor import Editor
from aqt.notetypechooser import NotetypeChooser from aqt.notetypechooser import NotetypeChooser
from aqt.operations.note import add_note from aqt.operations.note import add_note
from aqt.qt import * from aqt.qt import *
@ -57,7 +58,39 @@ class AddCards(QDialog):
self.show() self.show()
def setupEditor(self) -> None: def setupEditor(self) -> None:
def add_choosers(editor: Editor) -> None:
editor._links[
"choosenotetype"
] = lambda _editor: self.show_notetype_selector()
editor._links[
"choosedeck"
] = lambda _editor: self.deck_chooser.choose_deck()
editor.web.eval(
f"""
const notetypeChooser = editorToolbar.labelButton({{
label: `Choose note type`,
onClick: () => bridgeCommand("choosenotetype"),
disables: false,
}});
const deckChooser = editorToolbar.labelButton({{
label: `Choose deck`,
onClick: () => bridgeCommand("choosedeck"),
disables: false,
}});
$editorToolbar.insertButton(editorToolbar.buttonGroup({{
id: "choosers",
fullWidth: true,
items: [notetypeChooser, deckChooser],
}}), 0);
"""
)
gui_hooks.editor_did_init.append(add_choosers)
self.editor = aqt.editor.Editor(self.mw, self.form.fieldsArea, self, True) self.editor = aqt.editor.Editor(self.mw, self.form.fieldsArea, self, True)
gui_hooks.editor_did_init.remove(add_choosers)
def setup_choosers(self) -> None: def setup_choosers(self) -> None:
defaults = self.col.defaults_for_adding( defaults = self.col.defaults_for_adding(

View File

@ -28,14 +28,14 @@ License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
padding-inline-start: 0; padding-inline-start: 0;
margin: 0 0 calc(var(--toolbar-size) / 10); margin: 0 0 calc(var(--toolbar-size) / 10);
}
.border-overlap-group { &.border-overlap-group {
:global(button), :global(button),
:global(select) { :global(select) {
margin-left: -1px; margin-left: -1px;
} }
} }
}
li { li {
display: inline-block; display: inline-block;