function fixedEncodeURIComponent (str) {
return encodeURIComponent(str).replace(/[!'()]/g, escape).replace(/\*/g, "%2A");
}
(function($) {
$(function() {
var lexer_source = [];
for (var key in window.lexers) {
lexer_source.push({ label: window.lexers[key], value: key });
}
$('[id^=language-]').autocomplete({
source: lexer_source,
select: function(event, ui) {
event.preventDefault();
window.location = $(event.target).data("base-url") + '/' + fixedEncodeURIComponent(ui.item.value);
}
});
$('a.tabwidth-toggle').on('click', function (event) {
setTimeout(function () {
$(event.target).siblings('.dropdown-menu').find('input').trigger('focus');
}, 0);
});
var setTabwidth = function (value) {
value = value || 8;
$('span.tabwidth-value').html(value);
$('.tabwidth-form input').val(value);
$('.highlight pre').css('tab-size', value);
localStorage.setItem('tabwidth', value);
};
$(document).ready(function () {
setTabwidth(localStorage.getItem('tabwidth'));
});
$('form.tabwidth-form').on('submit', function (event) {
var value = $(event.target).find('input').val();
setTabwidth(value);
$(event.target).parents('.open').removeClass('open');
event.preventDefault();
});
$('form.tabwidth-form input').on('change', function (event) {
var value = $(event.target).val();
setTabwidth(value);
event.preventDefault();
});
$('form.tabwidth-form input').on('click', function (event) {
event.stopImmediatePropagation();
});
$(document).on("keyup", "[id^=language-]", function(event) {
if (event.keyCode == 13) {
event.preventDefault();
window.location = $(event.target).data("base-url") + '/' + fixedEncodeURIComponent($(this).val());
}
});
$('[id^=language-toggle-]').click(function(event) {
setTimeout(function() {
$(event.target).parent().find('[id^=language-]').focus();
}, 0);
});
$('[rel="tooltip"]').tooltip({
placement: 'bottom',
container: 'body',
});
$('#history-all').bind('change', function() {
$('.delete-history').prop('checked', $(this).is(':checked'));
});
window.lines_wrapped = true;
$('[id^=linewrap-]').click(function() {
if (window.lines_wrapped == true) {
$(".highlight > pre").css("white-space", "pre");
} else {
$(".highlight > pre").css("white-space", "pre-wrap");
}
window.lines_wrapped = !window.lines_wrapped;
});
$('.upload_thumbnails a').popover({
trigger: "hover",
placement: "bottom",
html: true,
});
$('#toggle_delete_mode').on("click", function() {
switch (window.page_mode) {
case "delete":
window.page_mode = "normal";
$('#delete_button').hide();
$("#delete_form input[id^='delete_']").remove();
$(".upload_thumbnails .marked").removeClass("marked");
if (typeof $.colorbox !== 'undefined') {
setup_colorbox();
}
break;
default:
window.page_mode = "delete";
$('#delete_button').show();
if (typeof $.colorbox !== 'undefined') {
$.colorbox.remove();
}
break;
}
});
$('.upload_thumbnails a').on("click", function(event) {
if (window.page_mode == "delete") {
event.preventDefault();
var data_id = $(event.target).parent().attr("data-id");
if ($('#delete_'+data_id).length == 0) {
$('').attr({
type: "hidden",
name: "ids["+data_id+"]",
value: data_id,
id: "delete_"+data_id,
}).appendTo('#delete_form');
$(event.target).parent().addClass("marked");
} else {
$('#delete_'+data_id).remove();
$(event.target).parent().removeClass("marked");
}
}
});
function handle_resize() {
$('.upload_thumbnails').each(function() {
var div = $(this);
need_multiple_lines = div.parent().width() < (div.find('a').outerWidth(true) * div.find('a').size());
div.css('margin-left', need_multiple_lines ? "auto" : "0");
div.width(div.parent().width() - (div.parent().width() % div.find('a').outerWidth(true)));
});
}
$(window).resize(function() {
handle_resize();
});
handle_resize();
// check file size before uploading if browser support html5
if (window.File && window.FileList) {
function checkFileUpload(evt) {
var sum = 0;
var filenum = 0;
var files = [];
$('.file-upload').each(function() {
for (var i = 0; i < this.files.length; i++) {
var file = this.files[i];
files.push(file);
}
});
for (var i = 0; i < files.length; i++) {
var f = files[i];
sum += f.size;
filenum++;
}
if (filenum > max_files_per_upload) {
document.getElementById('upload_button').innerHTML = "Too many files";
document.getElementById('upload_button').disabled = true;
} else if (sum > max_upload_size) {
document.getElementById('upload_button').innerHTML = "File(s) too big";
document.getElementById('upload_button').disabled = true;
} else {
document.getElementById('upload_button').innerHTML = "Upload/Paste it!";
document.getElementById('upload_button').disabled = false;
}
}
$(document).on('change', '.file-upload', checkFileUpload);
}
$(document).on("change", '.file-upload', function() {
var need_new = true;
$('.file-upload').each(function() {
if ($(this).prop("files").length == 0) {
need_new = false;
return;
}
});
if (need_new) {
$(this).parent().append('
');
}
});
$(document).on("input propertychange", '.text-upload', function() {
var need_new = true;
$('.text-upload').each(function() {
if (!$(this).val()) {
need_new = false;
return;
}
});
if (need_new) {
var i = $('#textboxes .tab-content .tab-pane').length + 1;
var new_tab = $('#text-upload-tab-1')
.clone()
.attr("id", "text-upload-tab-"+i)
.toggleClass("active", false)
.appendTo('#textboxes .tab-content');
new_tab.find("[name^=filename]").attr("name", "filename["+i+"]").val("");
new_tab.find("[name^=content]").attr("name", "content["+i+"]").val("");
$('#textboxes ul.nav')
.append('