mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-09 11:12:06 +00:00
[WebUI] Refactor changing theme
Simplify searching for themes and ensure theme is ordered last. Ideally themes would be set client-side but seems to be quite tricky to accomplish with ExtJS.
This commit is contained in:
parent
ee97864086
commit
5dd7aa5321
@ -1019,4 +1019,4 @@ class WebUtils(JSONComponent):
|
|||||||
Returns:
|
Returns:
|
||||||
list: of themes ``[theme1, theme2, ...]``
|
list: of themes ``[theme1, theme2, ...]``
|
||||||
"""
|
"""
|
||||||
return component.get('DelugeWeb').get_themes_list()
|
return component.get('DelugeWeb').get_themes()
|
||||||
|
@ -12,6 +12,7 @@ import logging
|
|||||||
import mimetypes
|
import mimetypes
|
||||||
import os
|
import os
|
||||||
import tempfile
|
import tempfile
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
from twisted.application import internet, service
|
from twisted.application import internet, service
|
||||||
from twisted.internet import defer, reactor
|
from twisted.internet import defer, reactor
|
||||||
@ -539,19 +540,27 @@ class TopLevel(resource.Resource):
|
|||||||
self.putChild(b'themes', Themes(rpath('themes')))
|
self.putChild(b'themes', Themes(rpath('themes')))
|
||||||
self.putChild(b'tracker', Tracker())
|
self.putChild(b'tracker', Tracker())
|
||||||
|
|
||||||
theme = component.get('DelugeWeb').config['theme']
|
|
||||||
if not os.path.isfile(rpath('themes', 'css', f'xtheme-{theme}.css')):
|
|
||||||
theme = CONFIG_DEFAULTS.get('theme')
|
|
||||||
self.__stylesheets.insert(1, f'themes/css/xtheme-{theme}.css')
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def stylesheets(self):
|
def stylesheets(self):
|
||||||
return self.__stylesheets
|
return self.__stylesheets
|
||||||
|
|
||||||
def change_theme(self, theme: str):
|
def get_themes(self):
|
||||||
|
themes_dir = Path(rpath('themes', 'css'))
|
||||||
|
themes = [
|
||||||
|
theme.stem.split('xtheme-')[1] for theme in themes_dir.glob('xtheme-*.css')
|
||||||
|
]
|
||||||
|
themes = [(theme, _(theme.capitalize())) for theme in themes]
|
||||||
|
return themes
|
||||||
|
|
||||||
|
def set_theme(self, theme: str):
|
||||||
if not os.path.isfile(rpath('themes', 'css', f'xtheme-{theme}.css')):
|
if not os.path.isfile(rpath('themes', 'css', f'xtheme-{theme}.css')):
|
||||||
theme = CONFIG_DEFAULTS.get('theme')
|
theme = CONFIG_DEFAULTS.get('theme')
|
||||||
self.__stylesheets[1] = f'themes/css/xtheme-{theme}.css'
|
self.__theme = f'themes/css/xtheme-{theme}.css'
|
||||||
|
|
||||||
|
# Only one xtheme CSS, ordered last to override other styles.
|
||||||
|
if 'xtheme-' in self.stylesheets[-1]:
|
||||||
|
self.__stylesheets.pop()
|
||||||
|
self.__stylesheets.append(self.__theme)
|
||||||
|
|
||||||
def add_script(self, script):
|
def add_script(self, script):
|
||||||
"""
|
"""
|
||||||
@ -688,6 +697,8 @@ class DelugeWeb(component.Component):
|
|||||||
elif options.no_ssl:
|
elif options.no_ssl:
|
||||||
self.https = False
|
self.https = False
|
||||||
|
|
||||||
|
self.top_level.set_theme(self.config['theme'])
|
||||||
|
|
||||||
setup_translation()
|
setup_translation()
|
||||||
|
|
||||||
# Remove twisted version number from 'server' http-header for security reasons
|
# Remove twisted version number from 'server' http-header for security reasons
|
||||||
@ -794,14 +805,11 @@ class DelugeWeb(component.Component):
|
|||||||
config['language'] = CONFIG_DEFAULTS['language']
|
config['language'] = CONFIG_DEFAULTS['language']
|
||||||
return config
|
return config
|
||||||
|
|
||||||
def get_themes_list(self):
|
def get_themes(self):
|
||||||
return [
|
return self.top_level.get_themes()
|
||||||
(file[7:-4], _(file[7:-4].capitalize()))
|
|
||||||
for file in os.listdir(rpath('themes', 'css'))
|
|
||||||
]
|
|
||||||
|
|
||||||
def set_theme(self, theme: str):
|
def set_theme(self, theme: str):
|
||||||
self.top_level.change_theme(theme)
|
self.top_level.set_theme(theme)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__builtin__':
|
if __name__ == '__builtin__':
|
||||||
|
Loading…
x
Reference in New Issue
Block a user