function tagObject() {
 this.id = 0;
 this.Name = '';
 this.Count = 0;
 this.Url = 'http;//url';
 this.OnClick = '';
}

jQuery.fn.tagCloud = function(cl, givenOptions) { //return this.each( function() { //like a real jQuery plugin: run on on each element
   if (!cl || !cl.length)
      return this;

   // Default settings:
   var defaults = {
      sort: function (a, b) {return a.Name < b.Name ? -1 : (a.Name == b.Name ? 0 : 1)},//default sorting: abc
      click: function(tag) {},
      maxFontSizeEm: 3
   }

   var options = {};
   jQuery.extend(options, defaults, givenOptions);

   // calculating the max and min count values
   var max = -1;
   var min = cl[0].Count;
   jQuery.each(cl, function(i, n) {
      max = Math.max(n.Count, max);
      min = Math.min(n.Count, min);
   });

   if (options.sort) {
      cl.sort(options.sort);
   }

   //Normalization helper
   var diff = ( max == min ? 1    // if all values are equal, do not divide by zero
                           : (max - min) / (options.maxFontSizeEm - 1) ); //optimization: Originally we want to divide by diff
                           // and multiple by maxFontSizeEm - 1 in getNormalizedSize.
   function getNormalizedSize(count) {
      return 1 + (count - min) / diff;
   }

   // Generating the output
   this.empty();
   for (var i = 0; i < cl.length; ++i) {
      var tag = cl[i].Name;
      var tagEl = jQuery('<a href="' + cl[i].Url + '" class="tagcloudlink" onclick="' +  cl[i].OnClick + '" style="font-size: '
                           + getNormalizedSize(cl[i].Count)
                           + 'em">' + tag + '<\/a>')
                  .data('tag', tag);

      if (options.click) {
         tagEl.click(function(event) {
            event.preventDefault();
            options.click(jQuery(event.target).data('tag'), event);
         });
      }
      this.append(tagEl).append(" ");
   }
   return this;
//})
}
