v1.18.x
barisusakli 11 years ago
parent 57f9f8bc57
commit 73c89010cb

@ -1,15 +1,20 @@
define(['forum/admin/settings'], function(Settings) { define(['forum/admin/settings'], function(Settings) {
var Themes = {}; var Themes = {};
function highlightSelectedTheme(themeId) {
$('#themes li[data-theme]').removeClass('btn-warning');
$('#themes li[data-theme="' + themeId + '"]').addClass('btn-warning');
}
Themes.init = function() { Themes.init = function() {
var scriptEl = $('<script />'); var scriptEl = $('<script />');
scriptEl.attr('src', 'http://api.bootswatch.com/3/?callback=bootswatchListener'); scriptEl.attr('src', 'http://api.bootswatch.com/3/?callback=bootswatchListener');
$('body').append(scriptEl); $('body').append(scriptEl);
var bootstrapThemeContainer = $('#bootstrap_themes'), var bootstrapThemeContainer = $('#bootstrap_themes'),
installedThemeContainer = $('#installed_themes'), installedThemeContainer = $('#installed_themes');
themeEvent = function(e) { function themeEvent(e) {
var target = $(e.target), var target = $(e.target),
action = target.attr('data-action'); action = target.attr('data-action');
@ -26,6 +31,11 @@ define(['forum/admin/settings'], function(Settings) {
id: themeId, id: themeId,
src: cssSrc src: cssSrc
}, function(err) { }, function(err) {
if (err) {
return app.alertError(err.message);
}
highlightSelectedTheme(themeId);
app.alert({ app.alert({
alert_id: 'admin:theme', alert_id: 'admin:theme',
type: 'success', type: 'success',
@ -37,7 +47,7 @@ define(['forum/admin/settings'], function(Settings) {
break; break;
} }
} }
}; }
bootstrapThemeContainer.on('click', themeEvent); bootstrapThemeContainer.on('click', themeEvent);
installedThemeContainer.on('click', themeEvent); installedThemeContainer.on('click', themeEvent);
@ -49,6 +59,10 @@ define(['forum/admin/settings'], function(Settings) {
type: 'local', type: 'local',
id: 'nodebb-theme-cerulean' id: 'nodebb-theme-cerulean'
}, function(err) { }, function(err) {
if (err) {
return app.alertError(err.message);
}
highlightSelectedTheme('nodebb-theme-cerulean');
app.alert({ app.alert({
alert_id: 'admin:theme', alert_id: 'admin:theme',
type: 'success', type: 'success',
@ -59,7 +73,7 @@ define(['forum/admin/settings'], function(Settings) {
}); });
} }
}); });
}, false); });
// Installed Themes // Installed Themes
socket.emit('admin.themes.getInstalled', function(err, themes) { socket.emit('admin.themes.getInstalled', function(err, themes) {
@ -69,7 +83,11 @@ define(['forum/admin/settings'], function(Settings) {
var instListEl = $('#installed_themes').empty(), liEl; var instListEl = $('#installed_themes').empty(), liEl;
if (themes.length > 0) { if (!themes.length) {
instListEl.append($('<li/ >').addClass('no-themes').html('No installed themes found'));
return;
}
for (var x = 0, numThemes = themes.length; x < numThemes; x++) { for (var x = 0, numThemes = themes.length; x < numThemes; x++) {
liEl = $('<li/ >').attr({ liEl = $('<li/ >').attr({
'data-type': 'local', 'data-type': 'local',
@ -89,10 +107,8 @@ define(['forum/admin/settings'], function(Settings) {
instListEl.append(liEl); instListEl.append(liEl);
} }
} else {
// No themes found highlightSelectedTheme(config['theme:id']);
instListEl.append($('<li/ >').addClass('no-themes').html('No installed themes found'));
}
}); });
// Proper tabbing for "Custom CSS" field // Proper tabbing for "Custom CSS" field

@ -10,6 +10,11 @@
<div class="tab-content"> <div class="tab-content">
<div class="tab-pane active" id="themes"> <div class="tab-pane active" id="themes">
<h3>Revert to Default</h3>
<p class="alert">
<button class="btn btn-warning" id="revert_theme">Revert</button> This will remove any custom theme applied to your NodeBB, and restore the base theme.
</p>
<h3>Installed Themes</h3> <h3>Installed Themes</h3>
<p> <p>
The following themes are currently installed in this NodeBB instance. The following themes are currently installed in this NodeBB instance.
@ -27,10 +32,6 @@
<li><i class="fa fa-refresh fa-spin"></i> Loading Themes</li> <li><i class="fa fa-refresh fa-spin"></i> Loading Themes</li>
</ul> </ul>
<h3>Revert to Default</h3>
<p class="alert">
<button class="btn btn-warning" id="revert_theme">Revert</button> This will remove any custom theme applied to your NodeBB, and restore the base theme.
</p>
</div> </div>
<div class="tab-pane" id="customise"> <div class="tab-pane" id="customise">
<h3>Custom CSS</h3> <h3>Custom CSS</h3>

@ -152,9 +152,7 @@ var fs = require('fs'),
db.setObject('config', themeData, next); db.setObject('config', themeData, next);
} }
], function(err) { ], callback);
callback(err);
});
break; break;
case 'bootswatch': case 'bootswatch':

@ -66,6 +66,7 @@ var path = require('path'),
config.topicsPerPage = meta.config.topicsPerPage || 20; config.topicsPerPage = meta.config.topicsPerPage || 20;
config.postsPerPage = meta.config.postsPerPage || 20; config.postsPerPage = meta.config.postsPerPage || 20;
config.maximumFileSize = meta.config.maximumFileSize; config.maximumFileSize = meta.config.maximumFileSize;
config['theme:id'] = meta.config['theme:id'];
config.defaultLang = meta.config.defaultLang || 'en_GB'; config.defaultLang = meta.config.defaultLang || 'en_GB';
config.environment = process.env.NODE_ENV; config.environment = process.env.NODE_ENV;

Loading…
Cancel
Save