X-Git-Url: http://git.cielonegro.org/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=js%2FsystemConfig.js;h=e9254e3837d867236cc4645eb0a28ca28917af54;hb=619d36dbcf0bc8846da44fcaa5fafc0004adb567;hp=9dd7f9c280507c1da619c1693d4de43b66905f88;hpb=fb86cb6941e466fd43ce45338024c79d0fdb33a2;p=Rakka.git diff --git a/js/systemConfig.js b/js/systemConfig.js index 9dd7f9c..e9254e3 100644 --- a/js/systemConfig.js +++ b/js/systemConfig.js @@ -1,45 +1,72 @@ (function () { - var identityDecoder = function (src) { - return src; - }; + var identityDecoder = function (src) { + return src; + }; - var mapDecoder = function (src) { - var map = {}; - var lines = src.split(/\n/); - - $.each(lines, function () { - var m = this.match(/^(\S+)\s+(\S+)$/); + var identityEncoder = function (src) { + return src; + }; - map[ m[1] ] = m[2]; - }); + var mapDecoder = function (src) { + var map = {}; + var lines = src.split(/\n/); - return map; - }; + $.each(lines, function () { + var m = this.match(/^(\S+)\s+(\S+)$/); - var boolDecoder = function (src) { - return src == "*"; - }; + map[ m[1] ] = m[2]; + }); - var decoder_of = { - siteName : identityDecoder, - baseURI : identityDecoder, - defaultPage: identityDecoder, - styleSheet : identityDecoder, - languages : mapDecoder, - globalLock : boolDecoder - }; + return map; + }; - var cachedConf = null; + var mapEncoder = function (map) { + var lines = []; + + $.each(map, function (key) { + lines.push(key + " " + this); + }); + + return lines.join("\n"); + }; + + var boolDecoder = function (src) { + return src == "*"; + }; + + var boolEncoder = function (bool) { + return bool ? "*" : ""; + }; + + var decoder_of = { + siteName : identityDecoder, + baseURI : identityDecoder, + defaultPage: identityDecoder, + styleSheet : identityDecoder, + languages : mapDecoder, + globalLock : boolDecoder + }; + + var encoder_of = { + siteName : identityEncoder, + baseURI : identityEncoder, + defaultPage: identityEncoder, + styleSheet : identityEncoder, + languages : mapEncoder, + globalLock : boolEncoder + }; + + var cachedConf = null; Rakka.getSystemConfig = function () { if (cachedConf != null) { return cachedConf; } - + var conf = {}; cachedConf = conf; - + $.ajax({ type : "GET", url : Rakka.baseURI + "systemConfig", @@ -65,4 +92,81 @@ return conf; }; + Rakka.showConfigPanel = function () { + var conf = Rakka.getSystemConfig(); + var $area = Rakka.switchScreen(); + + $area.append($.H1({}, "Configuration")); + + var fldSiteName + = $.INPUT({type: "text", value: conf.siteName}); + + var fldBaseURI + = $.INPUT({type: "text", value: conf.baseURI}); + + var fldDefaultPage + = $.INPUT({type: "text", value: conf.defaultPage}); + + var fldStyleSheet + = $.INPUT({type: "text", value: conf.styleSheet}); + + var fldLanguages + = $.TEXTAREA({value: encoder_of.languages(conf.languages)}); + + var chkGlobalLock + = $.INPUT({type: "checkbox", checked: conf.globalLock}); + + var btnSave + = $.INPUT({type: "button", value: "Save"}); + + var btnCancel + = $.INPUT({type: "button", value: "Cancel"}); + + var configPanel + = $.TABLE({className: "pageEditor"}, + $.TBODY({}, + $.TR({}, + $.TH({}, "Site name"), + $.TD({}, fldSiteName) + ), + $.TR({}, + $.TH({}, "Base URI"), + $.TD({}, fldBaseURI) + ), + $.TR({}, + $.TH({}, "Default page"), + $.TD({}, fldDefaultPage) + ), + $.TR({}, + $.TH({}, "Style sheet"), + $.TD({}, fldStyleSheet) + ), + $.TR({}, + $.TH({}, "Languages"), + $.TD({}, fldLanguages) + ), + $.TR({}, + $.TH({}, "Global lock"), + $.TD({}, + $.LABEL({}, + chkGlobalLock, + "Disallow guest users to edit pages.")) + ), + $.TR({}, + $.TH({}), + $.TD({}, btnSave, btnCancel) + ) + ) + ); + + $area.append(configPanel); + }; + + $(document).ready(function () { + $("input.configButton") + .click(function () { + Rakka.showConfigPanel(); + }); + }); + })(); \ No newline at end of file