diff --git a/lib/admin.js b/lib/admin.js new file mode 100644 index 0000000..53fd658 --- /dev/null +++ b/lib/admin.js @@ -0,0 +1,24 @@ +'use strict'; +/* globals $, app */ + +define('admin/plugins/persona', ['settings'], function(Settings) { + + var ACP = {}; + + ACP.init = function() { + Settings.load('persona', $('.persona-settings')); + + $('#save').on('click', function() { + Settings.save('persona', $('.persona-settings'), function() { + app.alert({ + type: 'success', + alert_id: 'persona-saved', + title: 'Settings Saved', + message: 'Persona settings saved' + }); + }); + }); + }; + + return ACP; +}); \ No newline at end of file diff --git a/library.js b/library.js index ccc03a9..2d6bd19 100644 --- a/library.js +++ b/library.js @@ -1,9 +1,30 @@ 'use strict'; var S = require.main.require('string'); +var meta = module.parent.require('./meta'); var library = {}; +library.init = function(params, callback) { + var app = params.router; + var middleware = params.middleware; + + app.get('/admin/plugins/persona', middleware.admin.buildHeader, renderAdmin); + app.get('/api/admin/plugins/persona', renderAdmin); + + callback(); +}; + +library.addAdminNavigation = function(header, callback) { + header.plugins.push({ + route: '/plugins/persona', + icon: 'fa-paint-brush', + name: 'Persona Theme' + }); + + callback(null, header); +}; + library.getTeasers = function(data, callback) { data.teasers.forEach(function(teaser) { if (teaser && teaser.content) { @@ -65,4 +86,17 @@ library.defineWidgetAreas = function(areas, callback) { callback(null, areas); }; -module.exports = library; +library.getThemeConfig = function(config, callback) { + + meta.settings.get('persona', function(err, settings) { + config.hideSubCategories = settings.hideSubCategories === 'on'; + }); + + callback(false, config); +}; + +function renderAdmin(req, res, next) { + res.render('admin/plugins/persona', {}); +} + +module.exports = library; \ No newline at end of file diff --git a/plugin.json b/plugin.json index 4fa47f9..d26f5cc 100644 --- a/plugin.json +++ b/plugin.json @@ -3,7 +3,10 @@ "library": "library.js", "hooks": [ { "hook": "filter:teasers.get", "method": "getTeasers" }, - { "hook": "filter:widgets.getAreas", "method": "defineWidgetAreas" } + { "hook": "filter:widgets.getAreas", "method": "defineWidgetAreas" }, + { "hook": "filter:config.get", "method": "getThemeConfig" }, + { "hook": "static:app.load", "method": "init" }, + { "hook": "filter:admin.header.build", "method": "addAdminNavigation" } ], "scripts": [ "lib/persona.js", @@ -11,5 +14,8 @@ "lib/modules/autohidingnavbar.min.js", "lib/modules/slideout.min.js", "lib/client/chats.js" + ], + "acpScripts": [ + "lib/admin.js" ] } \ No newline at end of file diff --git a/templates/admin/plugins/persona.tpl b/templates/admin/plugins/persona.tpl new file mode 100644 index 0000000..d39dd72 --- /dev/null +++ b/templates/admin/plugins/persona.tpl @@ -0,0 +1,17 @@ +