368 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			368 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
// identica badge -- updated to work with the native API, 12-4-2008
 | 
						|
// Modified to point to Identi.ca, 2-20-2009 by Zach
 | 
						|
// Modified for XHTML, 27-9-2009 by Will Daniels
 | 
						|
// (see http://willdaniels.co.uk/blog/tech-stuff/26-identica-badge-xhtml)
 | 
						|
// copyright Kent Brewster 2008
 | 
						|
// see http://kentbrewster.com/identica-badge for info
 | 
						|
 | 
						|
function createHTMLElement(tagName) {
 | 
						|
   if(document.createElementNS)
 | 
						|
      var elem = document.createElementNS("http://www.w3.org/1999/xhtml", tagName);
 | 
						|
   else
 | 
						|
      var elem = document.createElement(tagName);
 | 
						|
 | 
						|
   return elem;
 | 
						|
}
 | 
						|
 | 
						|
function isNumeric(value) {
 | 
						|
  if (value == null || !value.toString().match(/^[-]?\d*\.?\d*$/)) return false;
 | 
						|
  return true;
 | 
						|
}
 | 
						|
 | 
						|
function markupPost(raw, server) {
 | 
						|
  var start = 0; var p = createHTMLElement('p');
 | 
						|
 | 
						|
  raw.replace(/((http|https):\/\/|\!|@|#)(([\w_]+)?[^\s]*)/g,
 | 
						|
    function(sub, type, scheme, url, word, offset, full)
 | 
						|
    {
 | 
						|
      if(!scheme && !word) return; // just punctuation
 | 
						|
      var label = ''; var href = '';
 | 
						|
      var pretext = full.substr(start, offset - start);
 | 
						|
 | 
						|
      moniker = word.split('_'); // behaviour with underscores differs
 | 
						|
      if(type == '#') moniker = moniker.join('');
 | 
						|
      else word = moniker = moniker[0].toLowerCase();
 | 
						|
 | 
						|
      switch(type) {
 | 
						|
        case 'http://': case 'https://': // html links
 | 
						|
          href = scheme + '://' + url; break;
 | 
						|
        case '@': // link users
 | 
						|
          href = 'http://' + server + '/' + moniker; break;
 | 
						|
        case '!': // link groups
 | 
						|
          href = 'http://' + server + '/group/' + moniker; break;
 | 
						|
        case '#': // link tags
 | 
						|
          href = 'http://' + server + '/tag/' + moniker; break;
 | 
						|
        default: // bad call (just reset position for text)
 | 
						|
          start = offset;
 | 
						|
      }
 | 
						|
      if(scheme) { // only urls will have scheme
 | 
						|
        label = sub; start = offset + sub.length;
 | 
						|
      } else {
 | 
						|
        label = word; pretext += type;
 | 
						|
        start = offset + word.length + type.length;
 | 
						|
      }
 | 
						|
      p.appendChild(document.createTextNode(pretext));
 | 
						|
 | 
						|
      var link = createHTMLElement('a');
 | 
						|
      link.appendChild(document.createTextNode(label));
 | 
						|
      link.href = href; link.target = '_statusnet';
 | 
						|
      p.appendChild(link);
 | 
						|
    });
 | 
						|
 | 
						|
  if(start != raw.length) {
 | 
						|
    endtext = raw.substr(start);
 | 
						|
    p.appendChild(document.createTextNode(endtext));
 | 
						|
  }
 | 
						|
  return p;
 | 
						|
}
 | 
						|
(function() {
 | 
						|
   var trueName = '';
 | 
						|
   for (var i = 0; i < 16; i++) { 
 | 
						|
      trueName += String.fromCharCode(Math.floor(Math.random() * 26) + 97); 
 | 
						|
   }
 | 
						|
   window[trueName] = {};
 | 
						|
   var $ = window[trueName];
 | 
						|
   $.f = function() {
 | 
						|
      return { 
 | 
						|
         runFunction : [],
 | 
						|
         init : function(target) {
 | 
						|
            var theScripts = document.getElementsByTagName('script');
 | 
						|
            for (var i = 0; i < theScripts.length; i++) {
 | 
						|
               if (theScripts[i].src.match(target)) {
 | 
						|
                  $.a = {};
 | 
						|
                  if (theScripts[i].innerHTML) {
 | 
						|
                     $.a = $.f.parseJson(theScripts[i].innerHTML);
 | 
						|
                  }
 | 
						|
                  if ($.a.err) {
 | 
						|
                     alert('bad json!');
 | 
						|
                  }
 | 
						|
                  $.f.loadDefaults();
 | 
						|
                  $.f.buildStructure();
 | 
						|
                  $.f.buildPresentation();
 | 
						|
                  theScripts[i].parentNode.insertBefore($.s, theScripts[i]);
 | 
						|
                  theScripts[i].parentNode.removeChild(theScripts[i]);
 | 
						|
                  break;
 | 
						|
               }
 | 
						|
            }         
 | 
						|
         },
 | 
						|
         parseJson : function(json) {
 | 
						|
            this.parseJson.data = json;
 | 
						|
            if ( typeof json !== 'string') {
 | 
						|
               return {"err":"trying to parse a non-string JSON object"};
 | 
						|
            }
 | 
						|
            try {
 | 
						|
               var f = Function(['var document,top,self,window,parent,Number,Date,Object,Function,',
 | 
						|
                  'Array,String,Math,RegExp,Image,ActiveXObject;',
 | 
						|
                  'return (' , json.replace(/<\!--.+-->/gim,'').replace(/\bfunction\b/g,'function­') , ');'].join(''));
 | 
						|
               return f();
 | 
						|
            } catch (e) {
 | 
						|
               return {"err":"trouble parsing JSON object"};
 | 
						|
            }
 | 
						|
         },
 | 
						|
         loadDefaults : function() {
 | 
						|
            $.d = { 
 | 
						|
               "user":"7000",
 | 
						|
               "headerText" : "",
 | 
						|
               "height" : 350,
 | 
						|
               "width" : 300,
 | 
						|
               "background" : "#193441",
 | 
						|
               "border" : "1px solid black",
 | 
						|
               "userFontSize" : "inherit",
 | 
						|
               "userColor" : "inherit",
 | 
						|
               "headerBackground" : "transparent", 
 | 
						|
               "headerColor" : "white",
 | 
						|
               "evenBackground" : "#fff",
 | 
						|
               "oddBackground" : "#eee",
 | 
						|
               "thumbnailBorder" : "1px solid black",
 | 
						|
               "thumbnailSize" : 24,
 | 
						|
               "padding" : 3,
 | 
						|
               "server" : "identi.ca"
 | 
						|
            };
 | 
						|
            for (var k in $.d) { if ($.a[k] === undefined) { $.a[k] = $.d[k]; } }
 | 
						|
            // fix inout units
 | 
						|
            if(isNumeric($.a.width)) {
 | 
						|
               $.a.innerWidth = ($.a.width - 22) + 'px'; $.a.width += 'px';
 | 
						|
            } else {
 | 
						|
               $.a.innerWidth = 'auto';
 | 
						|
            }
 | 
						|
            if(isNumeric($.a.height)) $.a.height += 'px';
 | 
						|
         },
 | 
						|
         buildPresentation : function () {
 | 
						|
            var setZoom = ''; if(navigator.appName == 'Microsoft Internet Explorer') setZoom = 'zoom:1;';
 | 
						|
            var ns = createHTMLElement('style');
 | 
						|
            document.getElementsByTagName('head')[0].appendChild(ns);
 | 
						|
            if (!window.createPopup) {
 | 
						|
               ns.appendChild(document.createTextNode(''));
 | 
						|
               ns.setAttribute("type", "text/css");
 | 
						|
            }
 | 
						|
            var s = document.styleSheets[document.styleSheets.length - 1];
 | 
						|
            var rules = {
 | 
						|
               "" : "{margin:0px;padding:0px;width:" + $.a.width + ";background:" + $.a.background + ";border:" + $.a.border + ";font:87%/1.2em tahoma, veranda, arial, helvetica, clean, sans-serif;}",
 | 
						|
               "a" : "{cursor:pointer;text-decoration:none;}",
 | 
						|
               "a:hover" : "{text-decoration:underline;}",
 | 
						|
               ".cite" : "{" + setZoom + "font-weight:bold;margin:0px 0px 0px 4px;padding:0px;display:block;font-style:normal;line-height:" + ($.a.thumbnailSize/2) + "px;vertical-align:middle;}",
 | 
						|
               ".cite a" : "{color:#C15D42;}",
 | 
						|
               ".date":"{margin:0px 0px 0px 4px;padding:0px;display:block;font-style:normal;line-height:" + ($.a.thumbnailSize/2) + "px;vertical-align:middle;}",
 | 
						|
               ".date:after" : "{clear:both;content:\".\"; display:block;height:0px;visibility:hidden;}",
 | 
						|
               ".date a" : "{color:#676;}",
 | 
						|
               "h3" : "{margin:0px;padding:" + $.a.padding + "px;font-weight:bold;background:" + $.a.headerBackground + " url('http://" + $.a.server + "/favicon.ico') " + $.a.padding + "px 50% no-repeat;padding-left:" + ($.a.padding + 20) + "px;}",
 | 
						|
               "h3.loading" : "{background-image:url('http://l.yimg.com/us.yimg.com/i/us/my/mw/anim_loading_sm.gif');}",
 | 
						|
               "h3 a" : "{font-size:92%; color:" + $.a.headerColor + ";}",
 | 
						|
               "h4" : "{font-weight:normal;background:" + $.a.headerBackground + ";text-align:right;margin:0px;padding:" + $.a.padding + "px;}",
 | 
						|
               "h4 a" : "{font-size:92%; color:" + $.a.headerColor + ";}",
 | 
						|
               "img":"{float:left;height:" + $.a.thumbnailSize + "px;width:" + $.a.thumbnailSize + "px;border:" + $.a.thumbnailBorder + ";margin-right:" + $.a.padding + "px;}",
 | 
						|
               "p" : "{margin:2px 0px 0px 0px;padding:0px;width:" + $.a.innerWidth + ";overflow:hidden;line-height:normal;}",
 | 
						|
               "p a" : "{color:#C15D42;}",
 | 
						|
               "ul":"{margin:0px; padding:0px; height:" + $.a.height + ";width:" + $.a.innerWidth + ";overflow:auto;}",
 | 
						|
               "ul li":"{background:" + $.a.evenBackground + ";margin:0px;padding:" + $.a.padding + "px;list-style:none;width:auto;overflow:hidden;border-bottom:1px solid #D8E2D7;}",
 | 
						|
               "ul li:hover":"{background:#f3f8ea;}"
 | 
						|
            };
 | 
						|
            var ieRules = "";
 | 
						|
            // brute-force each and every style rule here to !important
 | 
						|
            // sometimes you have to take off and nuke the site from orbit; it's the only way to be sure
 | 
						|
            for (var z in rules) {
 | 
						|
               if(z.charAt(0)=='.') var selector = '.' + trueName + '-' + z.substring(1);
 | 
						|
               else var selector = '.' + trueName + ' ' + z;
 | 
						|
               var rule = rules[z];
 | 
						|
               if (typeof rule === 'string') {
 | 
						|
                  var important = rule.replace(/;/gi, '!important;');
 | 
						|
                  if (!window.createPopup) {
 | 
						|
                     var theRule = document.createTextNode(selector + important + '\n');
 | 
						|
                     ns.appendChild(theRule);
 | 
						|
                  } else {
 | 
						|
                     ieRules += selector + important;
 | 
						|
                  }
 | 
						|
               }
 | 
						|
            }
 | 
						|
            if (window.createPopup) { s.cssText = ieRules; }
 | 
						|
         },
 | 
						|
         buildStructure : function() {
 | 
						|
            $.s = createHTMLElement('div');
 | 
						|
            $.s.className = trueName;         
 | 
						|
            $.s.h = createHTMLElement('h3');
 | 
						|
            $.s.h.a = createHTMLElement('a');
 | 
						|
            $.s.h.a.target = '_statusnet';
 | 
						|
            $.s.h.appendChild($.s.h.a);
 | 
						|
            $.s.appendChild($.s.h);
 | 
						|
            $.s.r = createHTMLElement('ul');
 | 
						|
            $.s.appendChild($.s.r);
 | 
						|
            $.s.f = createHTMLElement('h4');
 | 
						|
            var a = createHTMLElement('a');
 | 
						|
            a.innerHTML = 'get this';
 | 
						|
            a.target = '_blank';
 | 
						|
            a.href = 'http://identi.ca/doc/badge';
 | 
						|
            $.s.f.appendChild(a);
 | 
						|
            $.s.appendChild($.s.f);
 | 
						|
            $.f.getUser();
 | 
						|
         },
 | 
						|
         getUser : function() {
 | 
						|
            if (!$.f.runFunction) { $.f.runFunction = []; }
 | 
						|
            var n = $.f.runFunction.length;
 | 
						|
            var id = trueName + '.f.runFunction[' + n + ']';
 | 
						|
            $.f.runFunction[n] = function(r) {
 | 
						|
               delete($.f.runFunction[n]);
 | 
						|
               var a = createHTMLElement('a');
 | 
						|
               a.rel = $.a.user;
 | 
						|
               a.rev = r.name; 
 | 
						|
               a.id = r.screen_name;
 | 
						|
               $.f.removeScript(id);
 | 
						|
               $.f.changeUserTo(a);
 | 
						|
            };
 | 
						|
            var url = 'http://' + $.a.server + '/api/users/show/' + $.a.user + '.json?callback=' + id;
 | 
						|
            $.f.runScript(url, id);
 | 
						|
         },
 | 
						|
         changeUserTo : function(el) {
 | 
						|
            $.a.user = el.rel;
 | 
						|
            $.s.h.a.appendChild(document.createTextNode(el.rev + $.a.headerText));
 | 
						|
            $.s.h.a.href = 'http://' + $.a.server + '/' + el.id;
 | 
						|
            $.f.runSearch(); 
 | 
						|
         },
 | 
						|
         runSearch : function() {
 | 
						|
            $.s.h.className = 'loading';
 | 
						|
            $.s.r.innerHTML = '';
 | 
						|
            if (!$.f.runFunction) { $.f.runFunction = []; }
 | 
						|
            var n = $.f.runFunction.length;
 | 
						|
            var id = trueName + '.f.runFunction[' + n + ']';
 | 
						|
            $.f.runFunction[n] = function(r) {
 | 
						|
               delete($.f.runFunction[n]);
 | 
						|
               $.f.removeScript(id);
 | 
						|
               $.f.renderResult(r); 
 | 
						|
            };
 | 
						|
            var url = 'http://' + $.a.server + '/api/statuses/friends/' + $.a.user + '.json?callback=' + id;
 | 
						|
            $.f.runScript(url, id);
 | 
						|
         },
 | 
						|
         renderResult: function(r) { 
 | 
						|
            for (var i = 0; i < r.length; i++) {
 | 
						|
               if (!r[i].status) {
 | 
						|
                  r.splice(i, 1);
 | 
						|
               } else {
 | 
						|
                  r[i].status_id = parseInt(r[i].status.id);
 | 
						|
               }
 | 
						|
            }
 | 
						|
            r = $.f.sortArray(r, "status_id", true);
 | 
						|
            $.s.h.className = ''; // for IE6
 | 
						|
            $.s.h.removeAttribute('class');
 | 
						|
            for (var i = 0; i < r.length; i++) {
 | 
						|
               var li = createHTMLElement('li');
 | 
						|
               var icon = createHTMLElement('a');
 | 
						|
               if (r[i] && r[i].url) {
 | 
						|
                  icon.href = r[i].url;
 | 
						|
                  icon.target = '_statusnet'; 
 | 
						|
                  icon.title = 'Visit ' + r[i].screen_name + ' at ' + r[i].url;
 | 
						|
               } else {
 | 
						|
                  icon.href = 'http://' + $.a.server + '/' + r[i].screen_name;
 | 
						|
                  icon.target = '_statusnet'; 
 | 
						|
                  icon.title = 'Visit ' + r[i].screen_name + ' at http://' + $.a.server + '/' + r[i].screen_name;
 | 
						|
               }
 | 
						|
 | 
						|
               var img = createHTMLElement('img');
 | 
						|
               img.alt = 'profile image for ' + r[i].screen_name;
 | 
						|
               img.src = r[i].profile_image_url;
 | 
						|
               icon.appendChild(img);
 | 
						|
               li.appendChild(icon);
 | 
						|
               
 | 
						|
               var user = createHTMLElement('span');
 | 
						|
               user.className = trueName + '-cite';
 | 
						|
               var a = createHTMLElement('a');
 | 
						|
               a.rel = r[i].id;
 | 
						|
               a.rev = r[i].name;
 | 
						|
               a.id = r[i].screen_name;
 | 
						|
               a.innerHTML = r[i].name;
 | 
						|
               a.href = 'http://' + $.a.server + '/' + r[i].screen_name;
 | 
						|
               a.onclick = function() {
 | 
						|
                  $.f.changeUserTo(this);
 | 
						|
                  return false;
 | 
						|
               };
 | 
						|
               user.appendChild(a);
 | 
						|
               li.appendChild(user);
 | 
						|
               var updated = createHTMLElement('span');
 | 
						|
               updated.className = trueName + '-date';
 | 
						|
               if (r[i].status && r[i].status.created_at) {
 | 
						|
                  var date_link = createHTMLElement('a');
 | 
						|
                  date_link.innerHTML = r[i].status.created_at.split(/\+/)[0];
 | 
						|
                  date_link.href = 'http://' + $.a.server + '/notice/' + r[i].status.id;
 | 
						|
                  date_link.target = '_statusnet';
 | 
						|
                  updated.appendChild(date_link);
 | 
						|
                  if (r[i].status.in_reply_to_status_id) {
 | 
						|
                     updated.appendChild(document.createTextNode(' in reply to '));
 | 
						|
                     var in_reply_to = createHTMLElement('a');
 | 
						|
                     in_reply_to.innerHTML = r[i].status.in_reply_to_status_id;
 | 
						|
                     in_reply_to.href = 'http://' + $.a.server + '/notice/' + r[i].status.in_reply_to_status_id;
 | 
						|
                     in_reply_to.target = '_statusnet';
 | 
						|
                     updated.appendChild(in_reply_to);
 | 
						|
                  }
 | 
						|
               } else {
 | 
						|
                  updated.innerHTML = 'has not updated yet';
 | 
						|
               }
 | 
						|
               li.appendChild(updated);
 | 
						|
               var p = createHTMLElement('p');
 | 
						|
               if (r[i].status && r[i].status.text) {
 | 
						|
                  var raw = r[i].status.text;
 | 
						|
                  p = markupPost(raw, $.a.server);
 | 
						|
               }
 | 
						|
               li.appendChild(p);
 | 
						|
               var a = p.getElementsByTagName('a');
 | 
						|
               for (var j = 0; j < a.length; j++) {
 | 
						|
                  if (a[j].className == 'changeUserTo') {
 | 
						|
                     a[j].removeAttribute('class');
 | 
						|
                     a[j].href = 'http://' + $.a.server + '/' + a[j].innerHTML;
 | 
						|
                     a[j].rel = a[j].innerHTML;
 | 
						|
                     a[j].onclick = function() { 
 | 
						|
                        $.f.changeUserTo(this); 
 | 
						|
                        return false;
 | 
						|
                     } 
 | 
						|
                  }
 | 
						|
               }
 | 
						|
               $.s.r.appendChild(li);
 | 
						|
            }         
 | 
						|
         },
 | 
						|
         sortArray : function(r, k, x) {
 | 
						|
            if (window.createPopup) { 
 | 
						|
               return r; 
 | 
						|
            }
 | 
						|
            function s(a, b) {
 | 
						|
               if (x === true) {
 | 
						|
                   return b[k] - a[k];
 | 
						|
               } else {
 | 
						|
                   return a[k] - b[k];
 | 
						|
               }
 | 
						|
            }
 | 
						|
            r = r.sort(s);
 | 
						|
            return r;
 | 
						|
         },         
 | 
						|
         runScript : function(url, id) {
 | 
						|
            var s = createHTMLElement('script');
 | 
						|
            s.id = id;
 | 
						|
            s.type ='text/javascript';
 | 
						|
            s.src = url;
 | 
						|
            document.getElementsByTagName('body')[0].appendChild(s);
 | 
						|
         },
 | 
						|
         removeScript : function(id) {
 | 
						|
            if (document.getElementById(id)) {
 | 
						|
               var s = document.getElementById(id);
 | 
						|
               s.parentNode.removeChild(s);
 | 
						|
            }
 | 
						|
         }         
 | 
						|
      };
 | 
						|
   }();
 | 
						|
//   var thisScript = /^https?:\/\/[^\/]*r8ar.com\/identica-badge.js$/;
 | 
						|
   var thisScript = /identica-badge.js$/;
 | 
						|
   if(typeof window.addEventListener !== 'undefined') {
 | 
						|
      window.addEventListener('load', function() { $.f.init(thisScript); }, false);
 | 
						|
   } else if(typeof window.attachEvent !== 'undefined') {
 | 
						|
      window.attachEvent('onload', function() { $.f.init(thisScript); });
 | 
						|
   }
 | 
						|
} )();
 | 
						|
 | 
						|
 |