當前位置: 首頁>>代碼示例>>Python>>正文


Python hooks.wrap方法代碼示例

本文整理匯總了Python中anki.hooks.wrap方法的典型用法代碼示例。如果您正苦於以下問題:Python hooks.wrap方法的具體用法?Python hooks.wrap怎麽用?Python hooks.wrap使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在anki.hooks的用法示例。


在下文中一共展示了hooks.wrap方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: initializeLinks

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def initializeLinks():
    Overview._linkHandler = wrap(Overview._linkHandler, heatmapLinkHandler, "around")
    DeckBrowser._linkHandler = wrap(
        DeckBrowser._linkHandler, heatmapLinkHandler, "around"
    )
    DeckStats._linkHandler = heatmapLinkHandler

    try:
        from aqt.gui_hooks import browser_will_search

        browser_will_search.append(on_browser_will_search)
    except (ImportError, ModuleNotFoundError):
        from anki.find import Finder

        Finder.findRevlogEntries = findRevlogEntries
        Finder.__init__ = wrap(Finder.__init__, addFinders, "after") 
開發者ID:glutanimate,項目名稱:review-heatmap,代碼行數:18,代碼來源:links.py

示例2: _setupAddonMenus20

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def _setupAddonMenus20(self):
        from anki.hooks import wrap
        from aqt.addons import AddonManager
        from ..gui.dialog_configeditor import ConfigEditor
        
        from ..consts import ADDON
        from ..platform import PATH_ADDONS
        
        def onEdit(mgr, file_path, _old):
            entry_point = os.path.join(
                PATH_ADDONS, ADDON.NAME + ".py")
            if not file_path == entry_point:
                return _old(mgr, file_path)
            if self.conf_action:
                self.conf_action()
            elif "local" in self._config:
                ConfigEditor(self, self.mw)
            else:
                return _old(mgr, file_path)
        
        AddonManager.onEdit = wrap(AddonManager.onEdit, onEdit, "around")

    # Local storage
    ###################################################################### 
開發者ID:glutanimate,項目名稱:review-heatmap,代碼行數:26,代碼來源:configmanager.py

示例3: _ensureSaveBeforeConfigGUILoaded

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def _ensureSaveBeforeConfigGUILoaded(self) -> None:
        """ugly workaround, drop as soon as possible"""

        if checkVersion(ANKI.VERSION, "2.1.17"):
            self._mw.addonManager.setConfigAction(
                self._namespace, self._saveBeforeConfigLoaded
            )
            return

        from anki.hooks import wrap
        from aqt.addons import AddonsDialog

        def wrappedOnConfig(addonsDialog: AddonsDialog, *args, **kwargs):
            """Save before config editor is invoked"""
            addon = addonsDialog.onlyOneSelected()
            if not addon or addon != self._namespace:
                return
            self.save()

        AddonsDialog.onConfig = wrap(AddonsDialog.onConfig, wrappedOnConfig, "before") 
開發者ID:glutanimate,項目名稱:review-heatmap,代碼行數:22,代碼來源:local.py

示例4: _setupAddonMenus20

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def _setupAddonMenus20(self):
        from anki.hooks import wrap
        from aqt.addons import AddonManager
        from ..gui.dialog_configeditor import ConfigEditor
        
        from ..consts import ADDON
        from ..platform import DIRECTORY_ADDONS
        
        def onEdit(mgr, file_path, _old):
            entry_point = os.path.join(
                DIRECTORY_ADDONS, ADDON.NAME + ".py")
            if not file_path == entry_point:
                return _old(mgr, file_path)
            if self.conf_action:
                self.conf_action()
            elif "local" in self._config:
                ConfigEditor(self, self.mw)
            else:
                return _old(mgr, file_path)
        
        AddonManager.onEdit = wrap(AddonManager.onEdit, onEdit, "around")

    # Local storage
    ###################################################################### 
開發者ID:glutanimate,項目名稱:cloze-overlapper,代碼行數:26,代碼來源:configmanager.py

示例5: onInsertCloze

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def onInsertCloze(self, _old):
    """Handles cloze-wraps when the add-on model is active"""
    if not checkModel(self.note.model(), fields=False, notify=False):
        return _old(self)
    # find the highest existing cloze
    highest = 0
    for name, val in self.note.items():
        m = re.findall("\[\[oc(\d+)::", val)
        if m:
            highest = max(highest, sorted([int(x) for x in m])[-1])
    # reuse last?
    if not self.mw.app.keyboardModifiers() & Qt.AltModifier:
        highest += 1
    # must start at 1
    highest = max(1, highest)
    self.web.eval("wrap('[[oc%d::', ']]');" % highest) 
開發者ID:glutanimate,項目名稱:cloze-overlapper,代碼行數:18,代碼來源:editor.py

示例6: initializeEditor

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def initializeEditor():
    # Editor widget
    Editor.onCloze = wrap(Editor.onCloze, onInsertCloze, "around")
    Editor.onOlClozeButton = onOlClozeButton
    Editor.onOlOptionsButton = onOlOptionsButton
    Editor.onInsertMultipleClozes = onInsertMultipleClozes
    Editor.onRemoveClozes = onRemoveClozes
    if ANKI20:
        addHook("setupEditorButtons", onSetupEditorButtons20)
    else:
        addHook("setupEditorButtons", onSetupEditorButtons21)

    # AddCard / EditCurrent windows
    AddCards.addNote = wrap(AddCards.addNote, onAddNote, "around")
    if ANKI20:
        AddCards.addCards = wrap(AddCards.addCards, onAddCards, "around")
        EditCurrent.onSave = wrap(EditCurrent.onSave, onEditCurrent, "around")
    else:
        # always use the methods that are fired on editor save:
        AddCards._addCards = wrap(AddCards._addCards, onAddCards, "around")
        EditCurrent._saveAndClose = wrap(EditCurrent._saveAndClose,
                                         onEditCurrent, "around") 
開發者ID:glutanimate,項目名稱:cloze-overlapper,代碼行數:24,代碼來源:editor.py

示例7: load

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def load():
    ruby.install()
    chinese.install()
    addHook('profileLoaded', load_menu)
    addHook('profileLoaded', add_models)
    addHook('loadNote', append_tone_styling)
    addHook('unloadProfile', config.save)
    addHook('unloadProfile', dictionary.conn.close)
    addHook('unloadProfile', unload_menu)
    CollectionStats.todayStats = wrap(
        CollectionStats.todayStats, todayStats, 'around'
    )
    EditManager() 
開發者ID:luoliyan,項目名稱:chinese-support-redux,代碼行數:15,代碼來源:main.py

示例8: patch_config

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def patch_config():
    from aqt.clayout import CardLayout

    from .config import add_maobi_button

    CardLayout.setupButtons = wrap(CardLayout.setupButtons, add_maobi_button) 
開發者ID:jcklie,項目名稱:anki-maobi,代碼行數:8,代碼來源:__init__.py

示例9: initializeViews

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def initializeViews():
    try:
        from aqt.gui_hooks import (
            deck_browser_will_render_content,
            overview_will_render_content,
        )

        deck_browser_will_render_content.append(on_deckbrowser_will_render_content)
        overview_will_render_content.append(on_overview_will_render_content)
    except (ImportError, ModuleNotFoundError):
        Overview._body = ov_body
        Overview._renderPage = overviewRenderPage
        DeckBrowser._renderStats = wrap(
            DeckBrowser._renderStats, deckbrowserRenderStats, "around"
        )

    # TODO: Submit Anki PR to add hook to CollectionStats.report
    CollectionStats.dueGraph = wrap(
        CollectionStats.dueGraph, collectionStatsDueGraph, "around"
    )
    DeckStats.__init__ = wrap(DeckStats.__init__, deckStatsInit21, "after")
    DeckStats.reject = wrap(DeckStats.reject, deckStatsReject)

    # Initially set up hotkey:
    # TODO: Migrate to config.json storage, so that profile hook is not required
    try:
        from aqt.gui_hooks import profile_did_open

        profile_did_open.append(initializeHotkey)
    except (ImportError, ModuleNotFoundError):
        addHook("profileLoaded", initializeHotkey)

    # Update hotkey on config save:
    addHook("config_saved_heatmap", initializeHotkey) 
開發者ID:glutanimate,項目名稱:review-heatmap,代碼行數:36,代碼來源:views.py

示例10: customize_addcards

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def customize_addcards():
    AddCards.setupButtons = wrap(
        AddCards.setupButtons, add_query_button, "before") 
開發者ID:finalion,項目名稱:WordQuery,代碼行數:5,代碼來源:prepare.py

示例11: profileLoaded

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def profileLoaded():
    """Support for Advanced Previewer"""
    try:
        from advanced_previewer.previewer import Previewer
    except ImportError:
        return
    Previewer.linkHandler = wrap(
        Previewer.linkHandler, linkHandler, "around")
    addHook("previewerMungeQA", linkInserter) 
開發者ID:glutanimate,項目名稱:anki-addons-misc,代碼行數:11,代碼來源:reviewer_file_hyperlinks.py

示例12: onProfileLoaded

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def onProfileLoaded():
    """
    Apply modifications to Browser and Previewer
    Needs to be run after all other add-ons have been loaded
    """
    Browser.onTagMove = onTagMove
    Browser.switchToSidebarItem = switchToSidebarItem
    Browser.setFilter = wrap(Browser.setFilter, onSetFilter, "around")
    Previewer.setupHotkeys = wrap(Previewer.setupHotkeys, onSetupHotkeys, "after") 
開發者ID:glutanimate,項目名稱:anki-addons-misc,代碼行數:11,代碼來源:previewer_tag_browser.py

示例13: profileLoaded

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def profileLoaded():
    # add menu entry
    mw.addonManager.rebuildAddonsMenu = wrap(mw.addonManager.rebuildAddonsMenu,
                                             siblingMenu)
    mw.addonManager.rebuildAddonsMenu()

    # add scheduler
    anki.sched.Scheduler._adjRevIvl = wrap(anki.sched.Scheduler._adjRevIvl,
                                           siblingIvl, "around")

# --- Hooks: --- 
開發者ID:glutanimate,項目名稱:anki-addons-misc,代碼行數:13,代碼來源:sched_sibling_spacing_whitelist.py

示例14: pasteWithoutLinebreaks

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def pasteWithoutLinebreaks(self):
    """Remove linebreaks from clipboard and paste"""
    mime = self.web.mungeClip(mode=QClipboard.Clipboard)
    html = mime.html()
    text = mime.text()

    if not(text or html):
        return
    
    if html:
        content = re.sub(re_lb_open, " ", html)
        content = re.sub(re_lb_close, "", content)
    else:
        if PRESERVE_PARAGRAPHS:
            # remove EOL hyphens:
            content = re.sub(r"-\n(?!\n)", "", text) 
            # skip ends of sentences:
            content = re.sub(r"(?<!\.|\!|\:)\n(?!\n)", " ", content)
            # strip extraneous linebreaks while rejoining with <br> tags
            content = "<br />".join(i.strip() for i in content.split("\n"))
        else:
            content = content.replace("\n", " ")

    self.web.eval("""
        var pasteHTML = function(html) {
            setFormat("inserthtml", html);
        };
        var filterHTML = function(html) {
            // wrap it in <top> as we aren't allowed to change top level elements
            var top = $.parseHTML("<ankitop>" + html + "</ankitop>")[0];
            filterNode(top);
            var outHtml = top.innerHTML;
            // get rid of nbsp
            outHtml = outHtml.replace(/&nbsp;/ig, " ");
            return outHtml;
        };
        pasteHTML(%s);
        """ % json.dumps(content))

    if TOOLTIP:
        tooltip("Pasting without linebreaks", period=500) 
開發者ID:glutanimate,項目名稱:anki-addons-misc,代碼行數:43,代碼來源:editor_replace_linebreaks.py

示例15: initializeReviewer

# 需要導入模塊: from anki import hooks [as 別名]
# 或者: from anki.hooks import wrap [as 別名]
def initializeReviewer():
    if ANKI20:
        Reviewer._keyHandler = wrap(
            Reviewer._keyHandler, newKeyHandler20, "before")
    else:
        Reviewer._shortcutKeys = wrap(Reviewer._shortcutKeys, onShortcutKeys21,
                                      "around") 
開發者ID:glutanimate,項目名稱:cloze-overlapper,代碼行數:9,代碼來源:reviewer.py


注:本文中的anki.hooks.wrap方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。