2014-11-12 20:41:29 -06:00
|
|
|
# -*- coding: utf-8 -*-
|
2016-01-09 00:45:52 -06:00
|
|
|
import re
|
2015-04-03 16:57:08 -06:00
|
|
|
import platform
|
2018-09-30 14:39:59 -05:00
|
|
|
import arrow
|
|
|
|
import languageHandler
|
2015-04-03 16:57:08 -06:00
|
|
|
system = platform.system()
|
2014-11-12 20:41:29 -06:00
|
|
|
import widgetUtils
|
2014-11-12 22:37:52 -06:00
|
|
|
import output
|
2014-11-15 19:40:19 -06:00
|
|
|
import url_shortener
|
|
|
|
import sound
|
2018-02-06 17:37:49 -06:00
|
|
|
import config
|
2014-12-29 20:58:30 -06:00
|
|
|
from pubsub import pub
|
2021-01-21 17:12:18 -06:00
|
|
|
from twitter_text import parse_tweet
|
2015-04-03 16:57:08 -06:00
|
|
|
if system == "Windows":
|
2021-06-16 16:18:41 -05:00
|
|
|
from wxUI.dialogs import message, urlList
|
|
|
|
from wxUI import commonMessageDialogs
|
|
|
|
from extra import translator, SpellChecker, autocompletionUsers
|
|
|
|
from extra.AudioUploader import audioUploader
|
2015-04-03 16:57:08 -06:00
|
|
|
elif system == "Linux":
|
2021-06-16 16:18:41 -05:00
|
|
|
from gtkUI.dialogs import message
|
2018-08-16 17:26:19 -05:00
|
|
|
from sessions.twitter import utils
|
2021-01-21 17:12:18 -06:00
|
|
|
from . import attach
|
2014-11-12 20:41:29 -06:00
|
|
|
|
2014-12-31 00:07:27 -06:00
|
|
|
class basicTweet(object):
|
2021-06-16 16:18:41 -05:00
|
|
|
""" This class handles the tweet main features. Other classes should derive from this class."""
|
|
|
|
def __init__(self, session, title, caption, text, messageType="tweet", max=280, *args, **kwargs):
|
|
|
|
super(basicTweet, self).__init__()
|
|
|
|
self.max = max
|
|
|
|
self.title = title
|
|
|
|
self.session = session
|
|
|
|
self.message = getattr(message, messageType)(title, caption, text, *args, **kwargs)
|
|
|
|
widgetUtils.connect_event(self.message.spellcheck, widgetUtils.BUTTON_PRESSED, self.spellcheck)
|
|
|
|
widgetUtils.connect_event(self.message.attach, widgetUtils.BUTTON_PRESSED, self.attach)
|
|
|
|
widgetUtils.connect_event(self.message.text, widgetUtils.ENTERED_TEXT, self.text_processor)
|
|
|
|
widgetUtils.connect_event(self.message.shortenButton, widgetUtils.BUTTON_PRESSED, self.shorten)
|
|
|
|
widgetUtils.connect_event(self.message.unshortenButton, widgetUtils.BUTTON_PRESSED, self.unshorten)
|
|
|
|
widgetUtils.connect_event(self.message.translateButton, widgetUtils.BUTTON_PRESSED, self.translate)
|
|
|
|
if hasattr(self.message, "long_tweet"):
|
|
|
|
widgetUtils.connect_event(self.message.long_tweet, widgetUtils.CHECKBOX, self.text_processor)
|
|
|
|
if config.app["app-settings"]["remember_mention_and_longtweet"]:
|
|
|
|
self.message.long_tweet.SetValue(config.app["app-settings"]["longtweet"])
|
|
|
|
self.attachments = []
|
2014-11-12 22:37:52 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def translate(self, event=None):
|
|
|
|
dlg = translator.gui.translateDialog()
|
|
|
|
if dlg.get_response() == widgetUtils.OK:
|
|
|
|
text_to_translate = self.message.get_text()
|
|
|
|
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=text_to_translate, target=dst)
|
|
|
|
self.message.set_text(msg)
|
|
|
|
self.text_processor()
|
|
|
|
self.message.text_focus()
|
|
|
|
output.speak(_(u"Translated"))
|
|
|
|
else:
|
|
|
|
return
|
2014-11-15 19:40:19 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def shorten(self, event=None):
|
|
|
|
urls = utils.find_urls_in_text(self.message.get_text())
|
|
|
|
if len(urls) == 0:
|
|
|
|
output.speak(_(u"There's no URL to be shortened"))
|
|
|
|
self.message.text_focus()
|
|
|
|
elif len(urls) == 1:
|
|
|
|
self.message.set_text(self.message.get_text().replace(urls[0], url_shortener.shorten(urls[0])))
|
|
|
|
output.speak(_(u"URL shortened"))
|
|
|
|
self.text_processor()
|
|
|
|
self.message.text_focus()
|
|
|
|
elif len(urls) > 1:
|
|
|
|
list_urls = urlList.urlList()
|
|
|
|
list_urls.populate_list(urls)
|
|
|
|
if list_urls.get_response() == widgetUtils.OK:
|
|
|
|
self.message.set_text(self.message.get_text().replace(urls[list_urls.get_item()], url_shortener.shorten(list_urls.get_string())))
|
|
|
|
output.speak(_(u"URL shortened"))
|
|
|
|
self.text_processor()
|
|
|
|
self.message.text_focus()
|
2014-11-15 19:40:19 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def unshorten(self, event=None):
|
|
|
|
urls = utils.find_urls_in_text(self.message.get_text())
|
|
|
|
if len(urls) == 0:
|
|
|
|
output.speak(_(u"There's no URL to be expanded"))
|
|
|
|
self.message.text_focus()
|
|
|
|
elif len(urls) == 1:
|
|
|
|
self.message.set_text(self.message.get_text().replace(urls[0], url_shortener.unshorten(urls[0])))
|
|
|
|
output.speak(_(u"URL expanded"))
|
|
|
|
self.text_processor()
|
|
|
|
self.message.text_focus()
|
|
|
|
elif len(urls) > 1:
|
|
|
|
list_urls = urlList.urlList()
|
|
|
|
list_urls.populate_list(urls)
|
|
|
|
if list_urls.get_response() == widgetUtils.OK:
|
|
|
|
self.message.set_text(self.message.get_text().replace(urls[list_urls.get_item()], url_shortener.unshorten(list_urls.get_string())))
|
|
|
|
output.speak(_(u"URL expanded"))
|
|
|
|
self.text_processor()
|
|
|
|
self.message.text_focus()
|
2014-11-15 19:40:19 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def text_processor(self, *args, **kwargs):
|
|
|
|
if len(self.message.get_text()) > 1:
|
|
|
|
self.message.enable_button("shortenButton")
|
|
|
|
self.message.enable_button("unshortenButton")
|
|
|
|
else:
|
|
|
|
self.message.disable_button("shortenButton")
|
|
|
|
self.message.disable_button("unshortenButton")
|
2021-08-26 09:16:02 -05:00
|
|
|
if self.message.get("long_tweet") == False and hasattr(self, "max"):
|
2021-06-16 16:18:41 -05:00
|
|
|
text = self.message.get_text()
|
|
|
|
results = parse_tweet(text)
|
|
|
|
self.message.set_title(_(u"%s - %s of %d characters") % (self.title, results.weightedLength, self.max))
|
|
|
|
if results.weightedLength > self.max:
|
|
|
|
self.session.sound.play("max_length.ogg")
|
|
|
|
else:
|
|
|
|
self.message.set_title(_(u"%s - %s characters") % (self.title, len(self.message.get_text())))
|
2014-11-16 22:30:58 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def spellcheck(self, event=None):
|
|
|
|
text = self.message.get_text()
|
|
|
|
checker = SpellChecker.spellchecker.spellChecker(text, "")
|
|
|
|
if hasattr(checker, "fixed_text"):
|
|
|
|
self.message.set_text(checker.fixed_text)
|
|
|
|
self.text_processor()
|
|
|
|
self.message.text_focus()
|
2014-12-29 20:58:30 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def attach(self, *args, **kwargs):
|
|
|
|
def completed_callback(dlg):
|
|
|
|
url = dlg.uploaderFunction.get_url()
|
|
|
|
pub.unsubscribe(dlg.uploaderDialog.update, "uploading")
|
|
|
|
dlg.uploaderDialog.destroy()
|
|
|
|
if "sndup.net/" in url:
|
|
|
|
self.message.set_text(self.message.get_text()+url+" #audio")
|
|
|
|
self.text_processor()
|
|
|
|
else:
|
|
|
|
commonMessageDialogs.common_error(url)
|
2018-01-31 17:12:43 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
dlg.cleanup()
|
|
|
|
dlg = audioUploader.audioUploader(self.session.settings, completed_callback)
|
|
|
|
self.message.text_focus()
|
2014-12-31 00:07:27 -06:00
|
|
|
|
|
|
|
class tweet(basicTweet):
|
2021-06-16 16:18:41 -05:00
|
|
|
def __init__(self, session, title, caption, text, max=280, messageType="tweet", *args, **kwargs):
|
|
|
|
super(tweet, self).__init__(session, title, caption, text, messageType, max, *args, **kwargs)
|
|
|
|
self.image = None
|
|
|
|
widgetUtils.connect_event(self.message.upload_image, widgetUtils.BUTTON_PRESSED, self.upload_image)
|
|
|
|
widgetUtils.connect_event(self.message.autocompletionButton, widgetUtils.BUTTON_PRESSED, self.autocomplete_users)
|
|
|
|
self.text_processor()
|
2014-12-31 00:07:27 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def upload_image(self, *args, **kwargs):
|
|
|
|
a = attach.attach()
|
|
|
|
if len(a.attachments) != 0:
|
|
|
|
self.attachments = a.attachments
|
2015-01-02 09:38:44 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def autocomplete_users(self, *args, **kwargs):
|
|
|
|
c = autocompletionUsers.completion.autocompletionUsers(self.message, self.session.session_id)
|
|
|
|
c.show_menu()
|
2015-01-27 17:09:28 -06:00
|
|
|
|
2015-01-02 09:38:44 -06:00
|
|
|
class reply(tweet):
|
2021-06-16 16:18:41 -05:00
|
|
|
def __init__(self, session, title, caption, text, users=[], ids=[]):
|
|
|
|
super(reply, self).__init__(session, title, caption, text, messageType="reply", users=users)
|
|
|
|
self.ids = ids
|
|
|
|
self.users = users
|
|
|
|
if len(users) > 0:
|
|
|
|
widgetUtils.connect_event(self.message.mentionAll, widgetUtils.CHECKBOX, self.mention_all)
|
|
|
|
self.message.enable_button("mentionAll")
|
|
|
|
if config.app["app-settings"]["remember_mention_and_longtweet"]:
|
|
|
|
self.message.mentionAll.SetValue(config.app["app-settings"]["mention_all"])
|
|
|
|
self.mention_all()
|
|
|
|
self.message.set_cursor_at_end()
|
|
|
|
self.text_processor()
|
2015-01-02 09:38:44 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def mention_all(self, *args, **kwargs):
|
|
|
|
if self.message.mentionAll.GetValue() == True:
|
|
|
|
for i in self.message.checkboxes:
|
|
|
|
i.SetValue(True)
|
|
|
|
i.Hide()
|
|
|
|
else:
|
|
|
|
for i in self.message.checkboxes:
|
|
|
|
i.SetValue(False)
|
|
|
|
i.Show()
|
2016-12-09 10:15:39 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def get_ids(self):
|
|
|
|
excluded_ids = ""
|
|
|
|
for i in range(0, len(self.message.checkboxes)):
|
|
|
|
if self.message.checkboxes[i].GetValue() == False:
|
|
|
|
excluded_ids = excluded_ids + "{0},".format(self.ids[i],)
|
|
|
|
return excluded_ids
|
2015-01-02 09:38:44 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def get_people(self):
|
|
|
|
people = ""
|
|
|
|
for i in range(0, len(self.message.checkboxes)):
|
|
|
|
if self.message.checkboxes[i].GetValue() == True:
|
|
|
|
people = people + "{0} ".format(self.message.checkboxes[i].GetLabel(),)
|
|
|
|
return people
|
2016-12-19 11:43:32 -06:00
|
|
|
|
2015-01-02 09:38:44 -06:00
|
|
|
class dm(basicTweet):
|
2021-06-16 16:18:41 -05:00
|
|
|
def __init__(self, session, title, caption, text):
|
|
|
|
super(dm, self).__init__(session, title, caption, text, messageType="dm", max=10000)
|
|
|
|
widgetUtils.connect_event(self.message.autocompletionButton, widgetUtils.BUTTON_PRESSED, self.autocomplete_users)
|
|
|
|
self.text_processor()
|
|
|
|
widgetUtils.connect_event(self.message.cb, widgetUtils.ENTERED_TEXT, self.user_changed)
|
2020-06-03 11:19:23 -05:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def user_changed(self, *args, **kwargs):
|
|
|
|
self.title = _("Direct message to %s") % (self.message.get_user())
|
|
|
|
self.text_processor()
|
2015-03-12 12:24:34 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def autocomplete_users(self, *args, **kwargs):
|
|
|
|
c = autocompletionUsers.completion.autocompletionUsers(self.message, self.session.session_id)
|
|
|
|
c.show_menu("dm")
|
2015-01-05 05:33:09 -06:00
|
|
|
|
|
|
|
class viewTweet(basicTweet):
|
2021-08-25 16:30:37 -05:00
|
|
|
def __init__(self, tweet, tweetList, is_tweet=True, utc_offset=0, date="", item_url=""):
|
2021-06-16 16:18:41 -05:00
|
|
|
""" This represents a tweet displayer. However it could be used for showing something wich is not a tweet, like a direct message or an event.
|
|
|
|
param tweet: A dictionary that represents a full tweet or a string for non-tweets.
|
|
|
|
param tweetList: If is_tweet is set to True, this could be a list of quoted tweets.
|
|
|
|
param is_tweet: True or false, depending wether the passed object is a tweet or not."""
|
|
|
|
if is_tweet == True:
|
|
|
|
self.title = _(u"Tweet")
|
|
|
|
image_description = []
|
|
|
|
text = ""
|
|
|
|
for i in range(0, len(tweetList)):
|
|
|
|
# tweets with message keys are longer tweets, the message value is the full messaje taken from twishort.
|
|
|
|
if hasattr(tweetList[i], "message") and tweetList[i].is_quote_status == False:
|
|
|
|
value = "message"
|
|
|
|
else:
|
|
|
|
value = "full_text"
|
|
|
|
if hasattr(tweetList[i], "retweeted_status") and tweetList[i].is_quote_status == False:
|
|
|
|
if not hasattr(tweetList[i], "message"):
|
|
|
|
text = text + "rt @%s: %s\n" % (tweetList[i].retweeted_status.user.screen_name, tweetList[i].retweeted_status.full_text)
|
|
|
|
else:
|
|
|
|
text = text + "rt @%s: %s\n" % (tweetList[i].retweeted_status.user.screen_name, getattr(tweetList[i], value))
|
|
|
|
else:
|
|
|
|
text = text + " @%s: %s\n" % (tweetList[i].user.screen_name, getattr(tweetList[i], value))
|
|
|
|
# tweets with extended_entities could include image descriptions.
|
|
|
|
if hasattr(tweetList[i], "extended_entities") and "media" in tweetList[i].extended_entities:
|
|
|
|
for z in tweetList[i].extended_entities["media"]:
|
|
|
|
if "ext_alt_text" in z and z["ext_alt_text"] != None:
|
|
|
|
image_description.append(z["ext_alt_text"])
|
|
|
|
if hasattr(tweetList[i], "retweeted_status") and hasattr(tweetList[i].retweeted_status, "extended_entities") and "media" in tweetList[i].retweeted_status["extended_entities"]:
|
|
|
|
for z in tweetList[i].retweeted_status.extended_entities["media"]:
|
|
|
|
if "ext_alt_text" in z and z["ext_alt_text"] != None:
|
|
|
|
image_description.append(z["ext_alt_text"])
|
|
|
|
# set rt and likes counters.
|
|
|
|
rt_count = str(tweet.retweet_count)
|
|
|
|
favs_count = str(tweet.favorite_count)
|
|
|
|
# Gets the client from where this tweet was made.
|
|
|
|
source = tweet.source
|
|
|
|
original_date = arrow.get(tweet.created_at, locale="en")
|
|
|
|
date = original_date.shift(seconds=utc_offset).format(_(u"MMM D, YYYY. H:m"), locale=languageHandler.getLanguage())
|
|
|
|
if text == "":
|
|
|
|
if hasattr(tweet, "message"):
|
|
|
|
value = "message"
|
|
|
|
else:
|
|
|
|
value = "full_text"
|
|
|
|
if hasattr(tweet, "retweeted_status"):
|
|
|
|
if not hasattr(tweet, "message"):
|
|
|
|
text = "rt @%s: %s" % (tweet.retweeted_status.user.screen_name, tweet.retweeted_status.full_text)
|
|
|
|
else:
|
|
|
|
text = "rt @%s: %s" % (tweet.retweeted_status.user.screen_name, getattr(tweet, value))
|
|
|
|
else:
|
|
|
|
text = getattr(tweet, value)
|
|
|
|
text = self.clear_text(text)
|
|
|
|
if hasattr(tweet, "extended_entities") and "media" in tweet.extended_entities:
|
|
|
|
for z in tweet.extended_entities["media"]:
|
|
|
|
if "ext_alt_text" in z and z["ext_alt_text"] != None:
|
|
|
|
image_description.append(z["ext_alt_text"])
|
|
|
|
if hasattr(tweet, "retweeted_status") and hasattr(tweet.retweeted_status, "extended_entities") and "media" in tweet.retweeted_status.extended_entities:
|
|
|
|
for z in tweet.retweeted_status.extended_entities["media"]:
|
|
|
|
if "ext_alt_text" in z and z["ext_alt_text"] != None:
|
|
|
|
image_description.append(z["ext_alt_text"])
|
|
|
|
self.message = message.viewTweet(text, rt_count, favs_count, source, date)
|
|
|
|
results = parse_tweet(text)
|
|
|
|
self.message.set_title(results.weightedLength)
|
|
|
|
[self.message.set_image_description(i) for i in image_description]
|
|
|
|
else:
|
|
|
|
self.title = _(u"View item")
|
|
|
|
text = tweet
|
|
|
|
self.message = message.viewNonTweet(text, date)
|
|
|
|
widgetUtils.connect_event(self.message.spellcheck, widgetUtils.BUTTON_PRESSED, self.spellcheck)
|
2021-08-25 16:30:37 -05:00
|
|
|
if item_url != "":
|
|
|
|
self.message.enable_button("share")
|
|
|
|
widgetUtils.connect_event(self.message.share, widgetUtils.BUTTON_PRESSED, self.share)
|
|
|
|
self.item_url = item_url
|
2021-06-16 16:18:41 -05:00
|
|
|
widgetUtils.connect_event(self.message.translateButton, widgetUtils.BUTTON_PRESSED, self.translate)
|
|
|
|
if self.contain_urls() == True:
|
|
|
|
self.message.enable_button("unshortenButton")
|
|
|
|
widgetUtils.connect_event(self.message.unshortenButton, widgetUtils.BUTTON_PRESSED, self.unshorten)
|
|
|
|
self.message.get_response()
|
2015-01-05 05:33:09 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def contain_urls(self):
|
|
|
|
if len(utils.find_urls_in_text(self.message.get_text())) > 0:
|
|
|
|
return True
|
|
|
|
return False
|
2015-11-03 10:07:06 -06:00
|
|
|
|
2021-06-16 16:18:41 -05:00
|
|
|
def clear_text(self, text):
|
|
|
|
urls = utils.find_urls_in_text(text)
|
|
|
|
for i in urls:
|
|
|
|
if "https://twitter.com/" in i:
|
|
|
|
text = text.replace(i, "\n")
|
|
|
|
return text
|
2021-08-25 16:30:37 -05:00
|
|
|
|
|
|
|
def share(self, *args, **kwargs):
|
|
|
|
if hasattr(self, "item_url"):
|
|
|
|
output.copy(self.item_url)
|
|
|
|
output.speak(_("Link copied to clipboard."))
|