if (active_page == 'thread' || active_page == 'index') {
	$(document).ready(function(){
		if (window.Options && Options.get_tab('general')) {
			selector = '#color-ids>input';
			event = 'change';
			Options.extend_tab("general", "<label id='color-ids'><input type='checkbox' /> "+_('Color IDs')+"</label>");
		}

		else {
			selector = '#color-ids';
			event = 'click';
			$('hr:first').before('<div id="color-ids" style="text-align:right"><a class="unimportant" href="javascript:void(0)">'+_('Color IDs')+'</a></div>')
		}

		$(selector).on(event, function() {
			if (localStorage.color_ids === 'true') {
				localStorage.color_ids = 'false';
			} else {
				localStorage.color_ids = 'true';
			}
		});

		if (!localStorage.color_ids || localStorage.color_ids === 'false') {
			return;
		} else {
			$('#color-ids>input').attr('checked','checked');
		}

		function IDToRGB(id_str){
			var id = id_str.match(/.{1,2}/g);
			var rgb = new Array();

			for (i = 0; i < id.length; i++) {
				rgb[i] = parseInt(id[i], 16);
			}

			return rgb;
		}

		function colorPostId(el) {
			var rgb = IDToRGB($(el).text());
			var ft = "#fff";

			if ((rgb[0]*0.299 + rgb[1]*0.587 + rgb[2]*0.114) > 125)
				ft = "#000";

			$(el).css({
				"background-color": "rgb("+rgb[0]+", "+rgb[1]+", "+rgb[2]+")",
				"padding": "0px 5px",
				"border-radius": "8px",
				"color": ft
			});

			$(el).mouseover(function() {
				$(this).css('color', '#800000'); // how about a CSS :hover rule instead?
			}).mouseout(function() {
				$(this).css('color', ft);
			});
		}

		$(".poster_id").each(function(k, v){
			colorPostId(v);
		});

		$(document).on('new_post', function(e, post) {
			$(post).find('.poster_id').each(function(k, v) {
				colorPostId(v);
			});
		});
	});
}