64 lines
1.9 KiB
JavaScript
64 lines
1.9 KiB
JavaScript
|
/*
|
||
|
* Character Count Plugin - jQuery plugin
|
||
|
* Dynamic character count for text areas and input fields
|
||
|
* written by Alen Grakalic
|
||
|
* http://cssglobe.com/post/7161/jquery-plugin-simplest-twitterlike-dynamic-character-count-for-textareas
|
||
|
*
|
||
|
* Copyright (c) 2009 Alen Grakalic (http://cssglobe.com)
|
||
|
* Dual licensed under the MIT (MIT-LICENSE.txt)
|
||
|
* and GPL (GPL-LICENSE.txt) licenses.
|
||
|
*
|
||
|
* Built for jQuery library
|
||
|
* http://jquery.com
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
(function($) {
|
||
|
|
||
|
$.fn.charCount = function(options){
|
||
|
|
||
|
// default configuration properties
|
||
|
var defaults = {
|
||
|
allowed: 140,
|
||
|
warning: 25,
|
||
|
css: 'counter',
|
||
|
counterElement: 'span',
|
||
|
counterContainerID:'',
|
||
|
cssWarning: 'warning',
|
||
|
cssExceeded: 'exceeded',
|
||
|
firstCounterText: '',
|
||
|
endCounterText: '',
|
||
|
errorCounterText: '',
|
||
|
errortype: 'positive' // positive or negative
|
||
|
};
|
||
|
var options = $.extend(defaults, options);
|
||
|
|
||
|
function calculate(obj){
|
||
|
var count = $(obj).val().length;
|
||
|
var counterText = options.firstCounterText;
|
||
|
var _css = '';
|
||
|
containerObj = $("#"+options.counterContainerID);
|
||
|
var available = options.allowed - count;
|
||
|
if(available <= options.warning && available >= 0){
|
||
|
_css = options.cssWarning;
|
||
|
}
|
||
|
if(available < 0){
|
||
|
if (options.errortype == 'positive')available = -available;
|
||
|
counterText = options.errorCounterText;
|
||
|
_css = options.cssExceeded;
|
||
|
} else {
|
||
|
counterText = options.firstCounterText;
|
||
|
}
|
||
|
$(containerObj).children().html(counterText +'<em class="'+ _css +'">'+ available +'</em>'+ options.endCounterText);
|
||
|
};
|
||
|
this.each(function() {
|
||
|
$("#"+options.counterContainerID).append('<'+ options.counterElement +' class="' + options.css + '"></'+ options.counterElement +'>');
|
||
|
calculate(this);
|
||
|
$(this).keyup(function(){calculate(this)});
|
||
|
$(this).change(function(){calculate(this)});
|
||
|
$(this).focus(function(){calculate(this)});
|
||
|
});
|
||
|
};
|
||
|
|
||
|
})(jQuery);
|