Added actions button on all chat conversations
This commit is contained in:
parent
2e508a53a0
commit
684a6006f5
@ -11,6 +11,7 @@ import widgetUtils
|
|||||||
import output
|
import output
|
||||||
from pubsub import pub
|
from pubsub import pub
|
||||||
from vk_api.exceptions import VkApiError
|
from vk_api.exceptions import VkApiError
|
||||||
|
from extra import translator, SpellChecker
|
||||||
from wxUI.tabs import chat
|
from wxUI.tabs import chat
|
||||||
from mysc.thread_utils import call_threaded
|
from mysc.thread_utils import call_threaded
|
||||||
from wxUI import commonMessages, menus
|
from wxUI import commonMessages, menus
|
||||||
@ -87,6 +88,7 @@ class chatBuffer(homeBuffer):
|
|||||||
widgetUtils.connect_event(self.tab.send, widgetUtils.BUTTON_PRESSED, self.send_chat_to_user)
|
widgetUtils.connect_event(self.tab.send, widgetUtils.BUTTON_PRESSED, self.send_chat_to_user)
|
||||||
widgetUtils.connect_event(self.tab.attachment, widgetUtils.BUTTON_PRESSED, self.add_attachment)
|
widgetUtils.connect_event(self.tab.attachment, widgetUtils.BUTTON_PRESSED, self.add_attachment)
|
||||||
widgetUtils.connect_event(self.tab.text, widgetUtils.KEYPRESS, self.catch_enter)
|
widgetUtils.connect_event(self.tab.text, widgetUtils.KEYPRESS, self.catch_enter)
|
||||||
|
widgetUtils.connect_event(self.tab.actions, widgetUtils.BUTTON_PRESSED, self.actions)
|
||||||
self.tab.set_focus_function(self.onFocus)
|
self.tab.set_focus_function(self.onFocus)
|
||||||
|
|
||||||
def catch_enter(self, event, *args, **kwargs):
|
def catch_enter(self, event, *args, **kwargs):
|
||||||
@ -117,7 +119,6 @@ class chatBuffer(homeBuffer):
|
|||||||
self.create_tab(self.parent)
|
self.create_tab(self.parent)
|
||||||
# Add name to the new control so we could look for it when needed.
|
# Add name to the new control so we could look for it when needed.
|
||||||
self.tab.name = self.name
|
self.tab.name = self.name
|
||||||
|
|
||||||
if show_nextpage == False:
|
if show_nextpage == False:
|
||||||
if self.tab.history.GetValue() != "" and num > 0:
|
if self.tab.history.GetValue() != "" and num > 0:
|
||||||
v = [i for i in self.session.db[self.name]["items"][:num]]
|
v = [i for i in self.session.db[self.name]["items"][:num]]
|
||||||
@ -258,3 +259,49 @@ class chatBuffer(homeBuffer):
|
|||||||
peer_id = self.kwargs["peer_id"]
|
peer_id = self.kwargs["peer_id"]
|
||||||
url = "https://vk.com/im?sel={peer_id}".format(peer_id=peer_id)
|
url = "https://vk.com/im?sel={peer_id}".format(peer_id=peer_id)
|
||||||
webbrowser.open_new_tab(url)
|
webbrowser.open_new_tab(url)
|
||||||
|
|
||||||
|
def actions(self, *args, **kwargs):
|
||||||
|
menu = menus.toolsMenu()
|
||||||
|
widgetUtils.connect_event(menu, widgetUtils.MENU, self.translate_action, menuitem=menu.translate)
|
||||||
|
widgetUtils.connect_event(menu, widgetUtils.MENU, self.spellcheck_action, menuitem=menu.spellcheck)
|
||||||
|
self.tab.PopupMenu(menu, self.tab.actions.GetPosition())
|
||||||
|
|
||||||
|
def translate(self, text):
|
||||||
|
dlg = translator.gui.translateDialog()
|
||||||
|
if dlg.get_response() == widgetUtils.OK:
|
||||||
|
language_dict = translator.translator.available_languages()
|
||||||
|
for k in language_dict:
|
||||||
|
if language_dict[k] == dlg.dest_lang.GetStringSelection():
|
||||||
|
dst = k
|
||||||
|
msg = translator.translator.translate(text, dst)
|
||||||
|
dlg.Destroy()
|
||||||
|
return msg
|
||||||
|
|
||||||
|
def spellcheck(self, text):
|
||||||
|
checker = SpellChecker.spellchecker.spellChecker(text)
|
||||||
|
if hasattr(checker, "fixed_text"):
|
||||||
|
final_text = checker.fixed_text
|
||||||
|
return final_text
|
||||||
|
|
||||||
|
def translate_action(self, *args, **kwargs):
|
||||||
|
text = self.tab.text.GetValue()
|
||||||
|
if text == "":
|
||||||
|
wx.Bell()
|
||||||
|
return
|
||||||
|
translated = self.translate(text)
|
||||||
|
if translated != None:
|
||||||
|
self.tab.text.ChangeValue(translated)
|
||||||
|
self.tab.text.SetFocus()
|
||||||
|
|
||||||
|
def spellcheck_action(self, *args, **kwargs):
|
||||||
|
text = self.tab.text.GetValue()
|
||||||
|
fixed = self.spellcheck(text)
|
||||||
|
if fixed != None:
|
||||||
|
self.tab.text.ChangeValue(fixed)
|
||||||
|
self.tab.text.SetFocus()
|
||||||
|
|
||||||
|
def translate_message(self, *args, **kwargs):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def spellcheck_message(self, *args, **kwargs):
|
||||||
|
pass
|
Loading…
Reference in New Issue
Block a user