1 //wrap everything in a self-executing anonymous function to avoid conflicts
4 // smart(x) from Paul Irish
5 // http://paulirish.com/2009/throttled-smartresize-jquery-event-handler/
9 // debouncing function from John Hann
10 // http://unscriptable.com/index.php/2009/03/20/debouncing-javascript-methods/
11 var debounce = function (func, threshold, execAsap) {
14 return function debounced () {
15 var obj = this, args = arguments;
18 func.apply(obj, args);
23 clearTimeout(timeout);
25 func.apply(obj, args);
27 timeout = setTimeout(delayed, threshold || 100);
30 jQuery.fn[sr] = function(fn){ return fn ? this.bind('keypress', debounce(fn, 1000)) : this.trigger(sr); };
32 })(jQuery,'smartkeypress');
34 $(document).ready(function(){
35 $noticeDataText = $('#'+SN.C.S.NoticeDataText);
36 $noticeDataText.smartkeypress(function(e){
37 if(e.charCode == '32') {
41 $noticeDataText.bind('paste', shorten);
46 $noticeDataText = $('#'+SN.C.S.NoticeDataText);
47 var original = $noticeDataText.val();
49 url: $('address .url')[0].href+'/plugins/ClientSideShorten/shorten',
50 data: { text: $noticeDataText.val() },
52 success: function(data) {
53 if(original == $noticeDataText.val()) {
54 $noticeDataText.val(data).keyup();