mirror of
https://github.com/inventree/InvenTree.git
synced 2025-04-29 20:16:44 +00:00
Merge pull request #2300 from matmair/theme-changes
Theme selector fixes
This commit is contained in:
commit
1ffea63173
@ -1269,9 +1269,6 @@ def get_price(instance, quantity, moq=True, multiples=True, currency=None, break
|
|||||||
|
|
||||||
class ColorTheme(models.Model):
|
class ColorTheme(models.Model):
|
||||||
""" Color Theme Setting """
|
""" Color Theme Setting """
|
||||||
|
|
||||||
default_color_theme = ('', _('Default'))
|
|
||||||
|
|
||||||
name = models.CharField(max_length=20,
|
name = models.CharField(max_length=20,
|
||||||
default='',
|
default='',
|
||||||
blank=True)
|
blank=True)
|
||||||
@ -1291,10 +1288,7 @@ class ColorTheme(models.Model):
|
|||||||
# Get color themes choices (CSS sheets)
|
# Get color themes choices (CSS sheets)
|
||||||
choices = [(file_name.lower(), _(file_name.replace('-', ' ').title()))
|
choices = [(file_name.lower(), _(file_name.replace('-', ' ').title()))
|
||||||
for file_name, file_ext in files_list
|
for file_name, file_ext in files_list
|
||||||
if file_ext == '.css' and file_name.lower() != 'default']
|
if file_ext == '.css']
|
||||||
|
|
||||||
# Add default option as empty option
|
|
||||||
choices.insert(0, cls.default_color_theme)
|
|
||||||
|
|
||||||
return choices
|
return choices
|
||||||
|
|
||||||
|
@ -292,6 +292,19 @@ def progress_bar(val, max, *args, **kwargs):
|
|||||||
|
|
||||||
@register.simple_tag()
|
@register.simple_tag()
|
||||||
def get_color_theme_css(username):
|
def get_color_theme_css(username):
|
||||||
|
user_theme_name = get_user_color_theme(username)
|
||||||
|
# Build path to CSS sheet
|
||||||
|
inventree_css_sheet = os.path.join('css', 'color-themes', user_theme_name + '.css')
|
||||||
|
|
||||||
|
# Build static URL
|
||||||
|
inventree_css_static_url = os.path.join(settings.STATIC_URL, inventree_css_sheet)
|
||||||
|
|
||||||
|
return inventree_css_static_url
|
||||||
|
|
||||||
|
|
||||||
|
@register.simple_tag()
|
||||||
|
def get_user_color_theme(username):
|
||||||
|
""" Get current user color theme """
|
||||||
try:
|
try:
|
||||||
user_theme = ColorTheme.objects.filter(user=username).get()
|
user_theme = ColorTheme.objects.filter(user=username).get()
|
||||||
user_theme_name = user_theme.name
|
user_theme_name = user_theme.name
|
||||||
@ -300,13 +313,7 @@ def get_color_theme_css(username):
|
|||||||
except ColorTheme.DoesNotExist:
|
except ColorTheme.DoesNotExist:
|
||||||
user_theme_name = 'default'
|
user_theme_name = 'default'
|
||||||
|
|
||||||
# Build path to CSS sheet
|
return user_theme_name
|
||||||
inventree_css_sheet = os.path.join('css', 'color-themes', user_theme_name + '.css')
|
|
||||||
|
|
||||||
# Build static URL
|
|
||||||
inventree_css_static_url = os.path.join(settings.STATIC_URL, inventree_css_sheet)
|
|
||||||
|
|
||||||
return inventree_css_static_url
|
|
||||||
|
|
||||||
|
|
||||||
@register.simple_tag()
|
@register.simple_tag()
|
||||||
|
@ -170,35 +170,6 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div class='panel-heading'>
|
|
||||||
<h4>{% trans "Theme Settings" %}</h4>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class='row'>
|
|
||||||
|
|
||||||
<div class='col-sm-6'>
|
|
||||||
<form action='{% url "settings-appearance" %}' method='post'>
|
|
||||||
{% csrf_token %}
|
|
||||||
<input name='next' type='hidden' value='{% url "settings" %}'>
|
|
||||||
<label for='theme' class=' requiredField'>
|
|
||||||
{% trans "Select theme" %}
|
|
||||||
</label>
|
|
||||||
<div class='form-group input-group mb-3'>
|
|
||||||
<select id='theme' name='theme' class='select form-control'>
|
|
||||||
{% get_available_themes as themes %}
|
|
||||||
{% for theme in themes %}
|
|
||||||
<option value='{{ theme.key }}'>{{ theme.name }}</option>
|
|
||||||
{% endfor %}
|
|
||||||
</select>
|
|
||||||
<div class='input-group-append'>
|
|
||||||
<input type="submit" value="{% trans 'Set Theme' %}" class="btn btn-primary">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class='panel-heading'>
|
<div class='panel-heading'>
|
||||||
<h4>{% trans "Language Settings" %}</h4>
|
<h4>{% trans "Language Settings" %}</h4>
|
||||||
</div>
|
</div>
|
||||||
|
@ -21,4 +21,33 @@
|
|||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class='panel-heading'>
|
||||||
|
<h4>{% trans "Theme Settings" %}</h4>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class='row'>
|
||||||
|
|
||||||
|
<div class='col-sm-6'>
|
||||||
|
<form action='{% url "settings-appearance" %}' method='post'>
|
||||||
|
{% csrf_token %}
|
||||||
|
<input name='next' type='hidden' value='{% url "settings" %}'>
|
||||||
|
<label for='theme' class=' requiredField'>
|
||||||
|
{% trans "Select theme" %}
|
||||||
|
</label>
|
||||||
|
<div class='form-group input-group mb-3'>
|
||||||
|
<select id='theme' name='theme' class='select form-control'>
|
||||||
|
{% get_available_themes as themes %}
|
||||||
|
{% get_user_color_theme request.user.username as user_theme %}
|
||||||
|
{% for theme in themes %}
|
||||||
|
<option value='{{ theme.key }}'{% if theme.key == user_theme %} selected{% endif%}>{{ theme.name }}</option>
|
||||||
|
{% endfor %}
|
||||||
|
</select>
|
||||||
|
<div class='input-group-append'>
|
||||||
|
<input type="submit" value="{% trans 'Set Theme' %}" class="btn btn-primary">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
Loading…
x
Reference in New Issue
Block a user