Editable numbered lists in HTML
One of the requirements of the submission application is to accept a list of steps that the user must do to either compile or run the tool or sample. Now, the old website supported this by presenting a series of single-line text boxes, with a button to add additional textboxes; this prevented the users from entering the data in a freeform fashion, and would allow future programmatic manipulation (autogenerated readme files).. My manager and I thought we might be able to improve on the UI...
The first thing that came to mind is all of the rich text editors that I've used (and indeed, am using now to compose this post). They always have a button for inserting a numbered list, and I thought I could leverage that functionality.
A quick search turned up this public domain tool: https://www.kevinroth.com/rte/demo.htm; On that website he mentions that this feature requires "designMode()." Moving on to the link he provides on MSDN, I found everything I needed to design an editable numbered list control. I also found the How to Create an HTML Editor Application article very helpful.
So, I first used the execCommand to execute an InsertOrderedList command, so that I could see what HTML was generated within my Div. I then pre-populated the Div with the standard <OL><LI> tags that were generated.
Finally, I had to prevent the users from exiting the numbered list. Towards that end, I added scripting that prevents the user from copy/pasting, drag/dropping, hitting enter on a blank line, or hitting backspace at the beginning of the line. This last requirement resulted in the fun atBeginning function, which retrieves the current caret's position, moves back a character, and determines if the caret is in a new element.
So, here you go! An editable control that forces the user to edit within numbered lists:
<
html>
<head>
<title>Numbered List Editor</title>
<script language="javascript" type="text/javascript">
function atBeginning()
{
//Get the current caret's position.
theCaret = document.selection.createRange().duplicate();
//Get the element that the caret is in.
var currentLI = theCaret.parentElement().uniqueID;
//Go back one character.
theCaret.move("character",-1);
//Return true if we are now in a new element (and hence _were_ at the beginning).
return (theCaret.parentElement().uniqueID != currentLI);
}
</script>
</head>
<body>
<!--
Div is editable.
On KeyDown we check for backspace, and only allow a deletion
if we are not at the very beginning of an element.
This prevents deletion of the row, and exiting the numbered list.
On KeyPress we prevent hitting Enter on a blank line (or if there are any blank lines)
This prevents the user from exiting the numbered list.
And we simply prevent people from pasting or drag/dropping.
-->
<div
id="EditRegion"
CONTENTEDITABLE
style="background-color:white; border-color:#779DB4; width:357px; border:solid 1px;height:100px;overflow:scroll;"
onkeydown="if (window.event.keyCode==8 && atBeginning()) return false;"
onkeypress="return !(window.event.keyCode==13 && EditRegion.innerHTML.toUpperCase().indexOf('<LI></LI>')>-1);"
ondrop="return false;"
onpaste="return false;"
> <OL><LI></LI></OL>
</div>
</body>
</html>
Comments
Anonymous
May 20, 2006
Good design!
[url=http://mxluomng.com/azwk/jglv.html]My homepage[/url] | [url=http://soagsesl.com/ofbd/zzba.html]Cool site[/url]Anonymous
May 20, 2006
Good design!
[url=http://mxluomng.com/azwk/jglv.html]My homepage[/url] | [url=http://soagsesl.com/ofbd/zzba.html]Cool site[/url]Anonymous
July 08, 2006
hello!! im just looking for same good site view and find you page. good luck.Anonymous
July 09, 2006
i want to tell about web securit<a href="http://blogs.ya.com/onwagering/">y</a>. it must be more harder.Anonymous
July 15, 2006
The comment has been removedAnonymous
July 17, 2006
The comment has been removedAnonymous
July 19, 2006
Great work!
[url=http://allpills.de.kakiko.com/order-hydrocodone.html]order hydrocodone[/url] | [url=http://allpills.de.kakiko.com/cheap-propecia.html]cheap propecia[/url] | [url=http://allpills.de.kakiko.com/hydrocodone-online.html]hydrocodone online[/url] | [url=http://allpills.de.kakiko.com/buy-vicodin-online.html]buy vicodin online[/url] | [url=http://allpills.de.kakiko.com/order-valium.html]order valium[/url]Anonymous
July 23, 2006
Nice site!
[url=http://wiki.pheno.wisc.edu/pub/Main/BuyPills/purchase-xanax.html]purchase xanax[/url] | [url=http://wiki.pheno.wisc.edu/pub/Main/BuyPills/buy-vicodin.html]buy vicodin[/url] | [url=http://wiki.pheno.wisc.edu/pub/Main/PillS/online-vicodin.html]online vicodin[/url] | [url=http://wiki.pheno.wisc.edu/pub/Main/BuyPills/hydrocodone-without-prescription.html]hydrocodone without prescription[/url] | [url=http://wiki.pheno.wisc.edu/pub/Main/BuyPills/buy-propecia-online.html]buy propecia online[/url]Anonymous
July 23, 2006
funny ringtonesAnonymous
July 28, 2006
patek philippe - is a real thing, I am sure !Anonymous
July 29, 2006
Work at home jobsAnonymous
August 06, 2006
It is interesting see it! I can recommendAnonymous
August 10, 2006
yo! http://buyclonazepam.pun.pl <a href="http://buyclonazepam.pun.pl">buy clonazepam</a> http://buylortab.pun.pl <a href="http://buylortab.pun.pl">buy lortab</a> http://buyhydrocodone.pun.plAnonymous
August 10, 2006
yo! http://buyclonazepam.pun.pl <a href="http://buyclonazepam.pun.pl">buy clonazepam</a> http://buylortab.pun.pl <a href="http://buylortab.pun.pl">buy lortab</a> http://buyhydrocodone.pun.plAnonymous
August 10, 2006
yo! http://buyclonazepam.pun.pl <a href="http://buyclonazepam.pun.pl">buy clonazepam</a> http://buylortab.pun.pl <a href="http://buylortab.pun.pl">buy lortab</a> http://buyhydrocodone.pun.plAnonymous
August 14, 2006
Huh!! Phentermine is up there globally, but .... sAnonymous
August 15, 2006
afx http://www.zope.org/Members/sosite/php/buy-tramadol.html <a href="http://www.zope.org/Members/sosite/php/buy-tramadol.html">buy tramadol</a> http://all-about-massage.rtart.infoAnonymous
August 15, 2006
afx http://www.zope.org/Members/sosite/php/buy-tramadol.html <a href="http://www.zope.org/Members/sosite/php/buy-tramadol.html">buy tramadol</a> http://all-about-massage.rtart.infoAnonymous
August 22, 2006
Thank you!
[url=http://ebzqbzbs.com/pfzs/spfp.html]My homepage[/url] | [url=http://vdkgvayb.com/svxe/pcnf.html]Cool site[/url]Anonymous
August 25, 2006
Well done!
[url=http://odwsfjrq.com/eaeq/vjib.html]My homepage[/url] | [url=http://ubiquudk.com/grzb/wnuq.html]Cool site[/url]Anonymous
August 26, 2006
The comment has been removedAnonymous
May 29, 2009
PingBack from http://paidsurveyshub.info/story.php?title=life-as-a-developer-editable-numbered-lists-in-htmlAnonymous
June 09, 2009
PingBack from http://insomniacuresite.info/story.php?id=8443