mirror of
https://github.com/MCV-Software/TWBlue.git
synced 2025-10-24 09:32:01 +00:00
Mastodon: Improved character count to match Mastodon's backend implementation. Remote users are counted only by username (domains are not taken into account), content warning text counts against character limit, and emoji&CJK characters are counted as 1
This commit is contained in:
@@ -7,6 +7,7 @@ This release focuses on fixing some important bugs that have been reported in th
|
|||||||
* Fixed the update system.
|
* Fixed the update system.
|
||||||
* Fixed a bug when attempting to switch between different accounts using the invisible interface, if the focused account is not an active session.
|
* Fixed a bug when attempting to switch between different accounts using the invisible interface, if the focused account is not an active session.
|
||||||
* Mastodon:
|
* Mastodon:
|
||||||
|
* Improved the way TWBlue counts characters in Mastodon. Now it counts only the username part in a remote user (@domain is not counted against character limit), adds content warning text to character count, also emojis and CJK characters are counted as 1 as opposed to 2. ([#511](https://github.com/MCV-Software/TWBlue/issues/511))
|
||||||
* Added notification when a user joins an instance. This notification is only available for administrators.
|
* Added notification when a user joins an instance. This notification is only available for administrators.
|
||||||
* Added option to disable Streaming in the account options. This can be useful if TWBlue, for some reason, repeatedly calls the instance API.
|
* Added option to disable Streaming in the account options. This can be useful if TWBlue, for some reason, repeatedly calls the instance API.
|
||||||
* Improved the code that works with the Streaming API to reduce the number of reconnection attempts TWBlue performs.
|
* Improved the code that works with the Streaming API to reduce the number of reconnection attempts TWBlue performs.
|
||||||
|
@@ -1,13 +1,28 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
import os
|
import os
|
||||||
|
import re
|
||||||
import wx
|
import wx
|
||||||
import widgetUtils
|
import widgetUtils
|
||||||
import config
|
import config
|
||||||
import output
|
import output
|
||||||
|
from twitter_text import parse_tweet, config
|
||||||
from controller.twitter import messages
|
from controller.twitter import messages
|
||||||
from sessions.mastodon import templates
|
from sessions.mastodon import templates
|
||||||
from wxUI.dialogs.mastodon import postDialogs
|
from wxUI.dialogs.mastodon import postDialogs
|
||||||
|
|
||||||
|
def character_count(post_text, post_cw, character_limit=500):
|
||||||
|
# We will use text for counting character limit only.
|
||||||
|
full_text = post_text+post_cw
|
||||||
|
# find remote users as Mastodon doesn't count the domain in char limit.
|
||||||
|
users = re.findall("@[\w\.-]+@[\w\.-]+", full_text)
|
||||||
|
for user in users:
|
||||||
|
domain = user.split("@")[-1]
|
||||||
|
full_text = full_text.replace("@"+domain, "")
|
||||||
|
options = config.config.get("defaults")
|
||||||
|
options.update(max_weighted_tweet_length=character_limit, default_weight=100)
|
||||||
|
parsed = parse_tweet(full_text, options=options)
|
||||||
|
return parsed.weightedLength
|
||||||
|
|
||||||
class post(messages.basicTweet):
|
class post(messages.basicTweet):
|
||||||
def __init__(self, session, title, caption, text="", *args, **kwargs):
|
def __init__(self, session, title, caption, text="", *args, **kwargs):
|
||||||
# take max character limit from session as this might be different for some instances.
|
# take max character limit from session as this might be different for some instances.
|
||||||
@@ -19,6 +34,7 @@ class post(messages.basicTweet):
|
|||||||
self.message.text.SetInsertionPoint(len(self.message.text.GetValue()))
|
self.message.text.SetInsertionPoint(len(self.message.text.GetValue()))
|
||||||
widgetUtils.connect_event(self.message.spellcheck, widgetUtils.BUTTON_PRESSED, self.spellcheck)
|
widgetUtils.connect_event(self.message.spellcheck, widgetUtils.BUTTON_PRESSED, self.spellcheck)
|
||||||
widgetUtils.connect_event(self.message.text, widgetUtils.ENTERED_TEXT, self.text_processor)
|
widgetUtils.connect_event(self.message.text, widgetUtils.ENTERED_TEXT, self.text_processor)
|
||||||
|
widgetUtils.connect_event(self.message.spoiler, widgetUtils.ENTERED_TEXT, self.text_processor)
|
||||||
widgetUtils.connect_event(self.message.translate, widgetUtils.BUTTON_PRESSED, self.translate)
|
widgetUtils.connect_event(self.message.translate, widgetUtils.BUTTON_PRESSED, self.translate)
|
||||||
widgetUtils.connect_event(self.message.add, widgetUtils.BUTTON_PRESSED, self.on_attach)
|
widgetUtils.connect_event(self.message.add, widgetUtils.BUTTON_PRESSED, self.on_attach)
|
||||||
widgetUtils.connect_event(self.message.remove_attachment, widgetUtils.BUTTON_PRESSED, self.remove_attachment)
|
widgetUtils.connect_event(self.message.remove_attachment, widgetUtils.BUTTON_PRESSED, self.remove_attachment)
|
||||||
@@ -49,7 +65,12 @@ class post(messages.basicTweet):
|
|||||||
return self.thread
|
return self.thread
|
||||||
|
|
||||||
def text_processor(self, *args, **kwargs):
|
def text_processor(self, *args, **kwargs):
|
||||||
super(post, self).text_processor(*args, **kwargs)
|
text = self.message.text.GetValue()
|
||||||
|
cw = self.message.spoiler.GetValue()
|
||||||
|
results = character_count(text, cw, character_limit=self.max)
|
||||||
|
self.message.SetTitle(_("%s - %s of %d characters") % (self.title, results, self.max))
|
||||||
|
if results > self.max:
|
||||||
|
self.session.sound.play("max_length.ogg")
|
||||||
if len(self.thread) > 0:
|
if len(self.thread) > 0:
|
||||||
if hasattr(self.message, "posts"):
|
if hasattr(self.message, "posts"):
|
||||||
self.message.posts.Enable(True)
|
self.message.posts.Enable(True)
|
||||||
|
Reference in New Issue
Block a user