Merge pull request #1311 from hikaru-y/flag-mark-icons-in-previewer

Show flag and mark icons in previewer
This commit is contained in:
Damien Elmes 2021-08-02 18:33:36 +10:00 committed by GitHub
commit f0b8b10314
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 15 additions and 2 deletions

View File

@ -151,12 +151,14 @@ class Browser(QMainWindow):
return
self.editor.set_note(note)
self._renderPreview()
if changes.browser_table and changes.card:
self.card = self.table.get_current_card()
self._update_context_actions()
# changes.card is required for updating flag icon
if changes.note_text or changes.card:
self._renderPreview()
def on_focus_change(self, new: Optional[QWidget], old: Optional[QWidget]) -> None:
if current_window() == self:
self.setUpdatesEnabled(True)

View File

@ -11,6 +11,7 @@ from typing import Any, Callable, Optional, Tuple, Union
import aqt.browser
from anki.cards import Card
from anki.collection import Config
from anki.tags import MARKED_TAG
from aqt import AnkiQt, gui_hooks
from aqt.qt import (
QCheckBox,
@ -140,6 +141,15 @@ class Previewer(QDialog):
if cmd.startswith("play:"):
play_clicked_audio(cmd, self.card())
def _update_flag_and_mark_icons(self, card: Optional[Card]) -> None:
if card:
flag = card.user_flag()
marked = card.note(reload=True).has_tag(MARKED_TAG)
else:
flag = 0
marked = False
self._web.eval(f"_drawFlag({flag}); _drawMark({json.dumps(marked)});")
def render_card(self) -> None:
self.cancel_timer()
# Keep track of whether render() has ever been called
@ -167,6 +177,7 @@ class Previewer(QDialog):
if not self._open:
return
c = self.card()
self._update_flag_and_mark_icons(c)
func = "_showQuestion"
ans_txt = ""
if not c: