Separate module for text mode browser functions

main
Bob Mottram 2025-05-27 11:35:56 +01:00
parent 4e6bd76ccf
commit e1b3b7a1a0
13 changed files with 113 additions and 100 deletions

View File

@ -71,8 +71,8 @@ from content import load_auto_cw_cache
from content import load_dogwhistles
from theme import scan_themes_for_scripts
from theme import is_news_theme_name
from theme import get_text_mode_banner
from theme import set_news_avatar
from textmode import get_text_mode_banner
from schedule import run_post_schedule
from schedule import run_post_schedule_watchdog
from happening import dav_propfind_response

View File

@ -51,12 +51,12 @@ from content import add_html_tags
from content import extract_text_fields_in_post
from content import extract_media_in_form_post
from content import save_media_in_form_post
from textmode import get_text_mode_banner
from theme import enable_grayscale
from theme import disable_grayscale
from theme import get_theme
from theme import is_news_theme_name
from theme import set_news_avatar
from theme import get_text_mode_banner
from theme import set_theme
from theme import export_theme
from theme import import_theme

View File

@ -7,7 +7,7 @@ __email__ = "bob@libreserver.org"
__status__ = "Production"
__module_group__ = "Core"
from webapp_utils import text_mode_browser
from textmode import text_mode_browser
def request_csv(headers: {}) -> bool:

97
textmode.py 100644
View File

@ -0,0 +1,97 @@
__filename__ = "textmode.py"
__author__ = "Bob Mottram"
__license__ = "AGPL3+"
__version__ = "1.6.0"
__maintainer__ = "Bob Mottram"
__email__ = "bob@libreserver.org"
__status__ = "Production"
__module_group__ = "Web Interface"
import os
from shutil import copyfile
from utils import data_dir
def text_mode_browser(ua_str: str) -> bool:
"""Does the user agent indicate a text mode browser?
"""
if ua_str:
text_mode_agents = ('Lynx/', 'w3m/', 'Links (', 'Emacs/', 'ELinks')
for agent in text_mode_agents:
if agent in ua_str:
return True
return False
def text_mode_removals(text: str, translate: {}) -> str:
"""Removes some elements of a post when displaying in a text mode browser
"""
text = text.replace(translate['SHOW MORE'], '')
text = text.replace(translate['mitm'], '👁 ')
return text
def get_text_mode_banner(base_dir: str) -> str:
"""Returns the banner used for shell browsers, like Lynx
"""
text_mode_banner_filename = data_dir(base_dir) + '/banner.txt'
if os.path.isfile(text_mode_banner_filename):
with open(text_mode_banner_filename, 'r',
encoding='utf-8') as fp_text:
banner_str = fp_text.read()
if banner_str:
return banner_str.replace('\n', '<br>')
return None
def get_text_mode_logo(base_dir: str) -> str:
"""Returns the login screen logo used for shell browsers, like Lynx
"""
text_mode_logo_filename = data_dir(base_dir) + '/logo.txt'
if not os.path.isfile(text_mode_logo_filename):
text_mode_logo_filename = base_dir + '/img/logo.txt'
with open(text_mode_logo_filename, 'r', encoding='utf-8') as fp_text:
logo_str = fp_text.read()
if logo_str:
return logo_str.replace('\n', '<br>')
return None
def set_text_mode_theme(base_dir: str, name: str) -> None:
# set the text mode logo which appears on the login screen
# in browsers such as Lynx
text_mode_logo_filename = \
base_dir + '/theme/' + name + '/logo.txt'
dir_str = data_dir(base_dir)
if os.path.isfile(text_mode_logo_filename):
try:
copyfile(text_mode_logo_filename, dir_str + '/logo.txt')
except OSError:
print('EX: set_text_mode_theme unable to copy ' +
text_mode_logo_filename + ' ' +
dir_str + '/logo.txt')
else:
dir_str = data_dir(base_dir)
try:
copyfile(base_dir + '/img/logo.txt', dir_str + '/logo.txt')
except OSError:
print('EX: set_text_mode_theme unable to copy ' +
base_dir + '/img/logo.txt ' + dir_str + '/logo.txt')
# set the text mode banner which appears in browsers such as Lynx
text_mode_banner_filename = \
base_dir + '/theme/' + name + '/banner.txt'
if os.path.isfile(dir_str + '/banner.txt'):
try:
os.remove(dir_str + '/banner.txt')
except OSError:
print('EX: set_text_mode_theme unable to delete ' +
dir_str + '/banner.txt')
if os.path.isfile(text_mode_banner_filename):
try:
copyfile(text_mode_banner_filename, dir_str + '/banner.txt')
except OSError:
print('EX: set_text_mode_theme unable to copy ' +
text_mode_banner_filename + ' ' +
dir_str + '/banner.txt')

View File

@ -27,6 +27,7 @@ from utils import text_in_file
from utils import remove_eol
from utils import language_right_to_left
from content import dangerous_css
from textmode import set_text_mode_theme
def import_theme(base_dir: str, filename: str) -> bool:
@ -695,72 +696,6 @@ def _set_theme_fonts(base_dir: str, theme_name: str) -> None:
break
def get_text_mode_banner(base_dir: str) -> str:
"""Returns the banner used for shell browsers, like Lynx
"""
text_mode_banner_filename = data_dir(base_dir) + '/banner.txt'
if os.path.isfile(text_mode_banner_filename):
with open(text_mode_banner_filename, 'r',
encoding='utf-8') as fp_text:
banner_str = fp_text.read()
if banner_str:
return banner_str.replace('\n', '<br>')
return None
def get_text_mode_logo(base_dir: str) -> str:
"""Returns the login screen logo used for shell browsers, like Lynx
"""
text_mode_logo_filename = data_dir(base_dir) + '/logo.txt'
if not os.path.isfile(text_mode_logo_filename):
text_mode_logo_filename = base_dir + '/img/logo.txt'
with open(text_mode_logo_filename, 'r', encoding='utf-8') as fp_text:
logo_str = fp_text.read()
if logo_str:
return logo_str.replace('\n', '<br>')
return None
def _set_text_mode_theme(base_dir: str, name: str) -> None:
# set the text mode logo which appears on the login screen
# in browsers such as Lynx
text_mode_logo_filename = \
base_dir + '/theme/' + name + '/logo.txt'
dir_str = data_dir(base_dir)
if os.path.isfile(text_mode_logo_filename):
try:
copyfile(text_mode_logo_filename, dir_str + '/logo.txt')
except OSError:
print('EX: _set_text_mode_theme unable to copy ' +
text_mode_logo_filename + ' ' +
dir_str + '/logo.txt')
else:
dir_str = data_dir(base_dir)
try:
copyfile(base_dir + '/img/logo.txt', dir_str + '/logo.txt')
except OSError:
print('EX: _set_text_mode_theme unable to copy ' +
base_dir + '/img/logo.txt ' + dir_str + '/logo.txt')
# set the text mode banner which appears in browsers such as Lynx
text_mode_banner_filename = \
base_dir + '/theme/' + name + '/banner.txt'
if os.path.isfile(dir_str + '/banner.txt'):
try:
os.remove(dir_str + '/banner.txt')
except OSError:
print('EX: _set_text_mode_theme unable to delete ' +
dir_str + '/banner.txt')
if os.path.isfile(text_mode_banner_filename):
try:
copyfile(text_mode_banner_filename, dir_str + '/banner.txt')
except OSError:
print('EX: _set_text_mode_theme unable to copy ' +
text_mode_banner_filename + ' ' +
dir_str + '/banner.txt')
def _set_theme_images(base_dir: str, name: str) -> None:
"""Changes the profile background image
and banner to the defaults
@ -778,7 +713,7 @@ def _set_theme_images(base_dir: str, name: str) -> None:
right_col_image_filename = \
base_dir + '/theme/' + theme_name_lower + '/right_col_image.png'
_set_text_mode_theme(base_dir, theme_name_lower)
set_text_mode_theme(base_dir, theme_name_lower)
background_names = ('login', 'shares', 'delete', 'follow',
'options', 'block', 'search', 'calendar',

View File

@ -5493,14 +5493,6 @@ def save_mitm_servers(base_dir: str, mitm_servers: []) -> None:
print('EX: error while saving mitm_servers.txt')
def text_mode_removals(text: str, translate: {}) -> str:
"""Removes some elements of a post when displaying in a text mode browser
"""
text = text.replace(translate['SHOW MORE'], '')
text = text.replace(translate['mitm'], '👁 ')
return text
def get_event_categories() -> []:
"""Returns event categories
https://codeberg.org/fediverse/fep/src/branch/main/fep/8a8e/fep-8a8e.md

View File

@ -34,7 +34,7 @@ from webapp_utils import get_banner_file
from webapp_utils import html_post_separator
from webapp_utils import header_buttons_front_screen
from webapp_utils import edit_text_field
from webapp_utils import text_mode_browser
from textmode import text_mode_browser
def _votes_indicator(total_votes: int, positive_voting: bool) -> str:

View File

@ -16,9 +16,9 @@ from utils import get_config_param
from utils import get_nickname_from_actor
from utils import get_domain_from_actor
from utils import get_attributed_to
from utils import text_mode_removals
from textmode import text_mode_removals
from blocking import is_blocked
from webapp_utils import text_mode_browser
from textmode import text_mode_browser
from webapp_utils import html_header_with_external_style
from webapp_utils import html_post_separator
from webapp_utils import html_footer

View File

@ -20,8 +20,8 @@ from webapp_utils import set_custom_background
from webapp_utils import html_header_with_website_markup
from webapp_utils import html_footer
from webapp_utils import html_keyboard_navigation
from webapp_utils import text_mode_browser
from theme import get_text_mode_logo
from textmode import text_mode_browser
from textmode import get_text_mode_logo
def html_get_login_credentials(login_params: str,

View File

@ -35,8 +35,8 @@ from flags import is_news_post
from flags import is_recent_post
from flags import is_chat_message
from flags import is_pgp_encrypted
from textmode import text_mode_removals
from utils import save_json
from utils import text_mode_removals
from utils import remove_header_tags
from utils import get_actor_from_post_id
from utils import contains_statuses
@ -102,8 +102,8 @@ from content import switch_words
from content import add_auto_cw
from person import is_person_snoozed
from person import get_person_avatar_url
from textmode import text_mode_browser
from webapp_utils import mitm_warning_html
from webapp_utils import text_mode_browser
from webapp_utils import get_buy_links
from webapp_utils import get_banner_file
from webapp_utils import get_avatar_image_url

View File

@ -18,8 +18,8 @@ from flags import is_valid_date
from flags import is_premium_account
from status import actor_status_expired
from status import get_actor_status
from textmode import text_mode_removals
from utils import get_person_icon
from utils import text_mode_removals
from utils import replace_strings
from utils import data_dir
from utils import time_days_ago
@ -93,7 +93,7 @@ from follow import is_follower_of_person
from follow import get_follower_domains
from follow import is_following_actor
from webapp_frontscreen import html_front_screen
from webapp_utils import text_mode_browser
from textmode import text_mode_browser
from webapp_utils import html_following_dropdown
from webapp_utils import edit_number_field
from webapp_utils import html_keyboard_navigation

View File

@ -22,11 +22,11 @@ from utils import acct_dir
from utils import local_actor_url
from utils import remove_eol
from utils import get_actor_from_post
from utils import text_mode_removals
from textmode import text_mode_removals
from follow import follower_approval_active
from person import is_person_snoozed
from markdown import markdown_to_html
from webapp_utils import text_mode_browser
from textmode import text_mode_browser
from webapp_utils import html_keyboard_navigation
from webapp_utils import html_hide_from_screen_reader
from webapp_utils import html_post_separator

View File

@ -2256,17 +2256,6 @@ def html_common_emoji(base_dir: str, no_of_emoji: int) -> str:
return html_str
def text_mode_browser(ua_str: str) -> bool:
"""Does the user agent indicate a text mode browser?
"""
if ua_str:
text_mode_agents = ('Lynx/', 'w3m/', 'Links (', 'Emacs/', 'ELinks')
for agent in text_mode_agents:
if agent in ua_str:
return True
return False
def get_default_path(media_instance: bool, blogs_instance: bool,
nickname: str) -> str:
"""Returns the default timeline