Skip to content

A jQuery plugin that adds a "characters remaining" display to an input or textarea html element.

Notifications You must be signed in to change notification settings

k4gdw/RemainingCharacters

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

56 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#RemainingCharacters

This is a jQuery plugin that adds a Twitter (tm) style "characters remaining" display to an html text input element such as <input> or <textarea>.

This html snippet shows how to apply the plugin to a <textarea> element:

    <html>
        <head>
            <script src='jQuery-1.8.2.js' type='text/javascript'></script>
        <script src='remainingCharacters.js' type='text/javascript'></script>
    </head>
    <body>
        <textarea id="charsLeft"></textarea>
        <script type="text/javascript">
	        $().ready(function(){
		        $('#charsLeft').remainingCharacters({
			    targetStyle: 'whatever css you want',
			    maxChars: 140,
			    hideTarget: true,
			    fadeTarget: {
				    speed: 'slow' //defaults to 'fast'
			    }
		      });
	        });
        </script>
    </body>
</html>

It's been tested against jQuery 1.8.2 and IT WORKS ON MY MACHINE. If you find a bug, please submit an issue. If you know how to fix an issue feel free to fork it and submit a pull request. I'll gladly check it out and merge your code if it's appropriate.

##CHANGE HISTORY

TODO: Figure out how to generate the output as a floating <div> with an absolute position relative to the textbox so that it is outside the regular page flow, allowing so that the <input> or <textarea> it's applied to doesn't jump around when the output <div> visibility is toggled.

###v2.3.4 Did some renaming to get the solution to fit the jQuery plugin naming conventions. Then I did some rearranging to get the solution into my current structure convention that has evolved with time and experience and to allow GitHub to pick up this file for display on the project home page.

###v2.3.3 Fixed a typo that broke the fadeing.

###v2.3.2 Fixed an error in the version numbers.

###v2.3.1 Fixed some JSHint messages and updated the README.md file to reflect the fact it has now been tested against jQuery 1.8.2. Cleaned up the default styling for the inserted default <div>. Got rid of the fade: true portion of the fadeTarget configuration object. Now, if the fadeTarget is there, fade is assumed to be true. So now, if all you need is fadeTarget {} to have it fade fast. fadeTarget {speed: 'slow'} makes it fade slow. If you want the code to be more explicit, you can use fadeTarget {speed: 'fast'}.

###v2.3.0 Added a new configuration property targetStyle which allows the user to apply styling to the runtime generated <div>. This new property will allow quite a bit of flexibility.

It's now been tested with jQuery 1.8.2.

Changed the vsdoc file to an intellisense file and updated the nuget package.

###v2.2.2b Changed this file from a plain README file to README.md so it has decent formatting.

###v2.2.0 Made the target parameter optional. If it's not supplied, a <span> is created and inserted into the DOM and used as the target.

    <span id='rcOutput' style="float: right;"></span>

For this to work properly, the textbox the plugin is applied to needs to be inside some other container such as a <div> or <td>. Otherwise, when the <span> is inserted and floated, it'll not be in a useful location. Also, if the textbox is the only element inside that container when the <span> is hidden or revealed via the hideTarget/fadeTarget properties, it'll jump around. The same thing will happen if the container isn't wide enough for the <span> to fit without wrapping.

###v2.1.7 The vsdoc intellisense is improved. Not perfect, but much better.

###v2.1.6 Fixed bug that prevented user from tabbing off of a filled up textbox.

###v2.1.5 Missed moving some of the 2.1.4 changes into the vsdoc file.

###v2.1.4 Fixed the incorrect initialization issue, for real this time.

###v2.1.2 Rolling back the "fix" applied in v2.1.1. It broke something and I'm not sure what.

###v2.1.1 Fixed a bug that caused a textbox that was populated from a database to show an incorrect character count until the user actually starts typing.

###v2.1.0 Changed the NuGet package to install the latest jQuery instead of using the complicated dependency resolution system NuGet uses by default. Also added a minified version.

###v2.0.0 Added the ability to optionally hide the output and show it when the text box receives focus, the hide it again when the user leaves the textbox. This was a major version bump because I was starting to need more and more parameters so it became easier to just accept an "args" parameter which is a javascript literal object as described above. This will make it easier to add new parameters in future versions without breaking backward compatibility.

###v1.0.1 Fixing the issue where enter is disabled if the user hits the maximum number of characters.

###v1.0.0 The plugin now takes a reference to the target element to use for displaying the number of characters remaining and how many characters to allow. It also restricts the user from actually entering too many characters.

###v0.1.0 Project created. 3/15/2012 at half past six PM central time. -- Bryan Johns

About

A jQuery plugin that adds a "characters remaining" display to an input or textarea html element.

Resources

Stars

Watchers

Forks

Packages

No packages published