X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-core.js;h=9cb794fdea7fb056b4c5393c5397f9c71e7ef1e6;hb=24209a0a9c198492db94011f1cf7862ff80937f2;hp=eb498c3c7a34de6af3ec7def42b51e06e46eff0c;hpb=a22e1f2b5b099b8f121e5e64a0070eb4cc7b2a1e;p=mkws-moved-to-github.git diff --git a/src/mkws-core.js b/src/mkws-core.js index eb498c3..9cb794f 100644 --- a/src/mkws-core.js +++ b/src/mkws-core.js @@ -14,6 +14,8 @@ var mkws = { log_level: 1, // Will be overridden from mkws_config, but // initial value allows jQuery popup to use logging. teams: {}, + widgetType2function: {}, + locale_lang: { "de": { "Authors": "Autoren", @@ -82,9 +84,7 @@ if (mkws_config == null || typeof mkws_config != 'object') { } -// wrapper to call team() after page load -(function (j) { - function log(string) { + mkws.log = function(string) { if (!mkws.log_level) return; @@ -99,8 +99,22 @@ if (mkws_config == null || typeof mkws_config != 'object') { console.log(">>> called from function " + arguments.callee.caller.name + ' <<<'); } console.log(string); + }; + + + +// wrapper to call team() after page load +(function(j) { + var log = mkws.log; + + mkws.registerWidgetType = function(name, fn) { + mkws.widgetType2function[name] = fn; + log("registered widget-type '" + name + "'"); + } + + mkws.promotionFunction = function(name) { + return mkws.widgetType2function[name]; } - mkws.log = log; function handleNodeWithTeam(node, callback) { @@ -162,41 +176,42 @@ if (mkws_config == null || typeof mkws_config != 'object') { // The following functions are dispatchers for team methods that - // are called from the UI using a te3am-name rather than implicit - // context. + // are called from the UI using a team-name rather than implicit + // context. Apart from mkws.log, they are the ONLY public UI to + // this module. mkws.switchView = function(tname, view) { mkws.teams[tname].switchView(view); } - mkws.showDetails = function (tname, prefixRecId) { + mkws.showDetails = function(tname, prefixRecId) { mkws.teams[tname].showDetails(prefixRecId); } - mkws.limitTarget = function (tname, id, name) { + mkws.limitTarget = function(tname, id, name) { mkws.teams[tname].limitTarget(id, name); } - mkws.limitQuery = function (tname, field, value) { + mkws.limitQuery = function(tname, field, value) { mkws.teams[tname].limitQuery(field, value); } - mkws.delimitTarget = function (tname, id) { + mkws.delimitTarget = function(tname, id) { mkws.teams[tname].delimitTarget(id); } - mkws.delimitQuery = function (tname, field, value) { + mkws.delimitQuery = function(tname, field, value) { mkws.teams[tname].delimitQuery(field, value); } - mkws.showPage = function (tname, pageNum) { + mkws.showPage = function(tname, pageNum) { mkws.teams[tname].showPage(pageNum); } - mkws.pagerPrev = function (tname) { + mkws.pagerPrev = function(tname) { mkws.teams[tname].pagerPrev(); } - mkws.pagerNext = function (tname) { + mkws.pagerNext = function(tname) { mkws.teams[tname].pagerNext(); } @@ -281,6 +296,11 @@ if (mkws_config == null || typeof mkws_config != 'object') { log("Service proxy auth successfully done"); mkws.authenticated = true; + var authName = $(data).find("displayName").text(); + for (var teamName in mkws.teams) { + mkws.teams[teamName].queue("authenticated").publish(authName); + } + runAutoSearches(); }); } @@ -344,7 +364,7 @@ if (mkws_config == null || typeof mkws_config != 'object') { // For all MKWS-classed nodes that don't have a team // specified, set the team to AUTO. - $('[class^="mkws"],[class*=" mkws"]').each(function () { + $('[class^="mkws"],[class*=" mkws"]').each(function() { if (!this.className.match(/mkwsTeam_/)) { log("adding AUTO team to node with class '" + this.className + "'"); $(this).addClass('mkwsTeam_AUTO'); @@ -354,7 +374,7 @@ if (mkws_config == null || typeof mkws_config != 'object') { // Find all nodes with an MKWS class, and determine their team from // the mkwsTeam_* class. Make all team objects. var then = $.now(); - $('[class^="mkws"],[class*=" mkws"]').each(function () { + $('[class^="mkws"],[class*=" mkws"]').each(function() { handleNodeWithTeam(this, function(tname, type) { if (!mkws.teams[tname]) { mkws.teams[tname] = team(j, tname); @@ -366,7 +386,7 @@ if (mkws_config == null || typeof mkws_config != 'object') { // to be done separately, and after the team-creation, since // that sometimes makes new widget nodes (e.g. creating // mkwsTermlists inside mkwsResults. - $('[class^="mkws"],[class*=" mkws"]').each(function () { + $('[class^="mkws"],[class*=" mkws"]').each(function() { handleNodeWithTeam(this, function(tname, type) { var myTeam = mkws.teams[tname]; var myWidget = widget(j, myTeam, type, this);