[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
Zen Cart 源代码 reference.html

Zen Cart 源代码 reference.html




下载文件

文件名: reference.html
文件类型: HTML文件
文件大小: 26.26 KiB
MD5: e61cdc21a2167baa4d1494712de42b35

reference.html - 关闭高亮
  1. <!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 3.2//EN">
  2. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  3. <title>HTMLArea-3.0 Reference</title>
  4.  
  5. <style type="text/css">
  6.   @import url(htmlarea.css);
  7.   body { font: 14px verdana,sans-serif; background: #fff; color: #000; }
  8.   h1, h2 { font-family:tahoma,sans-serif; }
  9.   h1 { border-bottom: 2px solid #000; }
  10.   h2 { border-bottom: 1px solid #aaa; }
  11.   h3, h4 { margin-bottom: 0px; font-family: Georgia,serif; font-style: italic; }
  12.   h4 { font-size: 90%; margin-left: 1em; }
  13.   acronym { border-bottom: 1px dotted #063; color: #063; }
  14.   p { margin-left: 2em; margin-top: 0.3em; }
  15.   li p { margin-left: 0px; }
  16.   .abstract { padding: 5px; margin: 0px 10em; font-size: 90%; border: 1px dashed #aaa; background: #eee;}
  17.   li { margin-left: 2em; }
  18.   em { color: #042; }
  19.   a { color: #00f; }
  20.   a:hover { color: #f00; }
  21.   a:active { color: #f80; }
  22.   span.browser { font-weight: bold; color: #864; }
  23.   .fixme { font-size: 20px; font-weight: bold; color: red; background: #fab;
  24. padding: 5px; text-align: center; }
  25.   .code {
  26.    background: #e4efff; padding: 5px; border: 1px dashed #abc; margin-left: 2em; margin-right: 2em;
  27.    font-family: fixed,"lucidux mono","andale mono","courier new",monospace;
  28.   }
  29.   .note, .warning { font-weight: bold; color: #0a0; font-variant: small-caps; }
  30.   .warning { color: #a00; }
  31.  
  32. .string {
  33.   color: #06c;
  34. } /* font-lock-string-face */
  35. .comment {
  36.   color: #840;
  37. } /* font-lock-comment-face */
  38. .variable-name {
  39.   color: #000;
  40. } /* font-lock-variable-name-face */
  41. .type {
  42.   color: #008;
  43.   font-weight: bold;
  44. } /* font-lock-type-face */
  45. .reference {
  46.   color: #048;
  47. } /* font-lock-reference-face */
  48. .preprocessor {
  49.   color: #808;
  50. } /* font-lock-preprocessor-face */
  51. .keyword {
  52.   color: #00f;
  53.   font-weight: bold;
  54. } /* font-lock-keyword-face */
  55. .function-name {
  56.   color: #044;
  57. } /* font-lock-function-name-face */
  58. .html-tag {
  59.   font-weight: bold;
  60. } /* html-tag-face */
  61. .html-helper-italic {
  62.   font-style: italic;
  63. } /* html-helper-italic-face */
  64. .html-helper-bold {
  65.   font-weight: bold;
  66. } /* html-helper-bold-face */
  67.  
  68.  
  69. <script type="text/javascript">
  70.   _editor_url = './';
  71.   _editor_lang = 'en';
  72. <script type="text/javascript" src="htmlarea.js"></script>
  73. <script type="text/javascript" src="dialog.js"></script>
  74. <script tyle="text/javascript" src="lang/en.js"></script>
  75.  
  76. </head>
  77.  
  78. <body onload="HTMLArea.replace('TA')">
  79.  
  80.  
  81. <h1>HTMLArea-3.0 Documentation</h1>
  82.  
  83. <div class="abstract" style="color: red; font-weight: bold">
  84.  
  85.       This documentation contains valid information, but is outdated in the
  86.       terms that it does not covers all the features of HTMLArea.  A new
  87.       documentation project will be started, based on LaTeX.
  88.  
  89. </div>
  90.  
  91.  
  92. <h2>Introduction</h2>
  93.  
  94. <h3>What is HTMLArea?</h3>
  95.  
  96. <p>HTMLArea is a free <acronym title="What You See Is What You Get"
  97. >WYSIWYG</acronym> editor replacement for <code>&lt;textarea&gt;</code>
  98. fields.  By adding a few simple lines of JavaScript code to your web page
  99. you can replace a regular textarea with a rich text editor that lets your
  100. users do the following:</p>
  101.  
  102. <ul>
  103.   <li>Format text to be bold, italicized, or underlined.</li>
  104.   <li>Change the face, size, style and color.</li>
  105.   <li>Left, center, or right-justify paragraphs.</li>
  106.   <li>Make bulleted or numbered lists.</li>
  107.   <li>Indent or un-indent paragraphs.</li>
  108.   <li>Insert a horizontal line.</li>
  109.   <li>Insert hyperlinks and images.</li>
  110.   <li>View the raw HTML source of what they're editing.</li>
  111.   <li>and much more...</li>
  112. </ul>
  113.  
  114. <p>Some of the interesting features of HTMLArea that set's it apart from
  115. other web based WYSIWYG editors are as follows:</p>
  116.  
  117. <ul>
  118.   <li>It's lightweight, fast loading and can transform a regular textarea
  119.   into a rich-text editor with a single line of JavaScript.</li>
  120.   <li>Generates clean, valid HTML.</li>
  121.   <li>It degrades gracefully to older or non-supported browsers
  122.   (they get the original textarea field).</li>
  123.   <li>It's free and can be incorporated into any free or commercial
  124.   program.</li>
  125.   <li>It works with any server-side languages (ASP, PHP, Perl, Java,
  126.   etc).</li>
  127.   <li>It's written in JavaScript and can be easily viewed, modified or
  128.   extended.</li>
  129.   <li>It remembers entered content when a user navigates away and then hits
  130.   "back" in their browser.</li>
  131.   <li>Since it replaces existing textareas it doesn't require a lot of code
  132.   to add it to your pages (just one line).</li>
  133.   <li>Did we mention it was free? ;-)</li>
  134. </ul>
  135.  
  136. <h3>Is it really free?  What's the catch?</h3>
  137.  
  138. <p>Yes! It's really free. You can use it, modify it, distribute it with your
  139. software, or do just about anything you like with it.</p>
  140.  
  141. <h3>What are the browser requirements?</h3>
  142.  
  143. <p>HTMLArea requires <span class="browser"><a
  144. href="http://www.microsoft.com/ie">Internet Explorer</a> &gt;= 5.5</span>
  145. (Windows only), or <span class="browser"><a
  146. href="http://mozilla.org">Mozilla</a> &gt;= 1.3-Beta</span> on any platform.
  147. Any browser based on <a href="http://mozilla.org/newlayout">Gecko</a> will
  148. also work, provided that Gecko version is at least the one included in
  149. Mozilla-1.3-Beta (for example, <a
  150. href="http://galeon.sf.net">Galeon-1.2.8</a>).  However, it degrades
  151. gracefully to other browsers. They will get a regular textarea field
  152. instead of a WYSIWYG editor.</p>
  153.  
  154. <h3>Can I see an example of what it looks like?</h3>
  155.  
  156. <p>Just make sure you're using one of the browsers mentioned above and see
  157. below.</p>
  158.  
  159. <form onsubmit="return false;">
  160. <textarea id="TA" style="width: 100%; height: 15em;">
  161. <p>Here is some sample text in textarea that's been transformed with <font
  162. color="#0000CC"><b>HTMLArea</b></font>.<br />
  163. You can make things <b>bold</b>, <i>italic</i>, <u>underline</u>.  You can change the
  164. <font size="3">size</font> and <b><font color="#0000CC">c</font><font color="#00CC00">o</font><font color="#00CCCC">l</font><font color="#CC0000">o</font><font color="#CC00CC">r</font><font color="#CCCC00">s</font><font color="#CCCCCC">!</font></b>
  165. And lots more...</p>
  166.  
  167. <p align="center"><font size="4" color="#ff0000"><b><u>Try HTMLArea
  168. today!</u></b></font><br /></p>
  169. </form>
  170.  
  171. <h3>Where can I find out more info, download the latest version and talk to
  172. other HTMLArea users?</h3>
  173.  
  174. <p>You can find out more about HTMLArea and download the latest version on
  175. the <a href="http://dynarch.com/htmlarea/">HTMLArea
  176. homepage</a> and you can talk to other HTMLArea users and post any comments
  177. or suggestions you have in the <a
  178. href="http://www.interactivetools.com/iforum/Open_Source_C3/htmlArea_v3.0_-_Alpha_Release_F14/"
  179. >HTMLArea forum</a>.</p>
  180.  
  181. <h2>Keyboard shortcuts</h2>
  182.  
  183. <p>The editor provides the following key combinations:</p>
  184.  
  185. <ul>
  186.   <li>CTRL-A -- select all</li>
  187.   <li>CTRL-B -- bold</li>
  188.   <li>CTRL-I -- italic</li>
  189.   <li>CTRL-U -- underline</li>
  190.   <li>CTRL-S -- strikethrough</li>
  191.   <li>CTRL-L -- justify left</li>
  192.   <li>CTRL-E -- justify center</li>
  193.   <li>CTRL-R -- justify right</li>
  194.   <li>CTRL-J -- justify full</li>
  195.   <li>CTRL-1 .. CTRL-6 -- headings (&lt;h1&gt; .. &lt;h6&gt;)</li>
  196.   <li>CTRL-0 (zero) -- clean content pasted from Word</li>
  197. </ul>
  198.  
  199. <h2>Installation</h2>
  200.  
  201. <h3>How do I add HTMLArea to my web page?</h3>
  202.  
  203. <p>It's easy.  First you need to upload HTMLArea files to your website.
  204. Just follow these steps.</p>
  205.  
  206. <ol>
  207.   <li>Download the latest version from the <a
  208.  href="http://www.interactivetools.com/products/htmlarea/">htmlArea
  209.   homepage</a>.</li>
  210.   <li>Unzip the files onto your local computer (making sure to maintain the
  211.   directory structure contained in the zip).</li>
  212.   <li>Create a new folder on your website called /htmlarea/ (make sure it's
  213.   NOT inside the cgi-bin).</li>
  214.   <li>Transfer all the HTMLArea files from your local computer into the
  215.   /htmlarea/ folder on your website.</li>
  216.   <li>Open the example page /htmlarea/examples/core.html with your browser to make
  217.   sure everything works.</li>
  218. </ol>
  219.  
  220. <p>Once htmlArea is on your website all you need to do is add some
  221. JavaScript to any pages that you want to add WYSIWYG editors to.  Here's how
  222. to do that.</p>
  223.  
  224. <ol>
  225.  
  226.   <li>Define some global variables.  "_editor_url" has to be the absolute
  227.   URL where HTMLArea resides within your
  228.   website; as we discussed, this would be “/htmlarea/”.  "_editor_lang" must
  229.   be the language code in which you want HTMLArea to appear.  This defaults
  230.   to "en" (English); for a list of supported languages, please look into
  231.   the "lang" subdirectory in the distribution.
  232.   <pre class="code"
  233.  ><span class="function-name">&lt;</span><span class="html-tag">script</span> <span class="variable-name">type=</span><span class="string">&quot;text/javascript&quot;</span><span class="function-name">&gt;</span>
  234.    _editor_url = <span class="string">&quot;/htmlarea/&quot;</span>;
  235.    _editor_lang = <span class="string">&quot;en&quot;</span>;
  236. <span class="function-name">&lt;</span><span class="html-tag">/script</span><span class="function-name">&gt;</span></pre>
  237.  
  238.   <li>Include the "htmlarea.js" script:
  239.   <pre class="code"
  240.  ><span class="function-name">&lt;</span><span class="html-tag">script</span> <span class="variable-name">type=</span><span class="string">&quot;text/javascript&quot;</span> <span class="variable-name">src=</span><span class="string">&quot;/htmlarea/htmlarea.js&quot;</span><span class="function-name">&gt;</span><span class="paren-face-match">&lt;</span><span class="html-tag">/script</span><span class="paren-face-match">&gt;</span></pre>
  241.   </li>
  242.  
  243.   <li><p>If you want to change all your &lt;textarea&gt;-s into
  244.   HTMLArea-s then you can use the simplest way to create HTMLArea:</p>
  245.   <pre class="code"
  246.  ><span class="function-name">&lt;</span><span class="html-tag">script</span> <span class="variable-name">type=</span><span class="string">&quot;text/javascript&quot;</span> <span class="variable-name">defer=</span><span class="string">&quot;1&quot;</span><span class="function-name">&gt;</span>
  247.     HTMLArea.replaceAll<span class="function-name">()</span>;
  248. <span class="paren-face-match">&lt;</span><span class="html-tag">/script</span><span class="paren-face-match">&gt;</span></pre>
  249.   <p><span class="note">Note:</span> you can also add the
  250.   <code>HTMLArea.replaceAll()</code> code to the <code>onload</code>
  251.   event handler for the <code>body</code> element, if you find it more appropriate.</p>
  252.  
  253.   <p>A different approach, if you have more than one textarea and only want
  254.   to change one of them, is to use <code>HTMLArea.replace("id")</code> --
  255.   pass the <code>id</code> of your textarea.  Do not use the
  256.   <code>name</code> attribute anymore, it's not a standard solution!</p>
  257.  
  258. </ol>
  259.  
  260. <p>This section applies to HTMLArea-3.0 release candidate 1 or later; prior
  261. to this version, one needed to include more files; however, now HTMLArea is
  262. able to include other files too (such as stylesheet, language definition
  263. file, etc.) so you only need to define the editor path and load
  264. "htmlarea.js".  Nice, eh? ;-)</p>
  265.  
  266. <h3>I want to change the editor settings, how do I do that?</h3>
  267.  
  268. <p>While it's true that all you need is one line of JavaScript to create an
  269. htmlArea WYSIWYG editor, you can also specify more config settings in the
  270. code to control how the editor works and looks.  Here's an example of some of
  271. the available settings:</p>
  272.  
  273. <pre class="code"
  274. ><span class="keyword">var</span> <span class="variable-name">config</span> = <span class="keyword">new</span> HTMLArea.Config(); <span class="comment">// create a new configuration object
  275. </span>                                    <span class="comment">// having all the default values
  276. </span>config.width = '<span class="string">90%</span>';
  277. config.height = '<span class="string">200px</span>';
  278.  
  279. <span class="comment">// the following sets a style for the page body (black text on yellow page)
  280. // and makes all paragraphs be bold by default
  281. </span>config.pageStyle =
  282.   '<span class="string">body { background-color: yellow; color: black; font-family: verdana,sans-serif } </span>' +
  283.   '<span class="string">p { font-width: bold; } </span>';
  284.  
  285. <span class="comment">// the following replaces the textarea with the given id with a new
  286. // HTMLArea object having the specified configuration
  287. </span>HTMLArea.replace('<span class="string">id</span>', config);</pre>
  288.  
  289. <p><span class="warning">Important:</span> It's recommended that you add
  290. custom features and configuration to a separate file.  This will ensure you
  291. that when we release a new official version of HTMLArea you'll have less
  292. trouble upgrading it.</p>
  293.  
  294. <h3>How do I customize the toolbar?</h3>
  295.  
  296. <p>Using the configuration object introduced above allows you to completely
  297. control what the toolbar contains.  Following is an example of a one-line,
  298. customized toolbar, much simpler than the default one:</p>
  299.  
  300. <pre class="code"
  301. ><span class="keyword">var</span> <span class="variable-name">config</span> = <span class="keyword">new</span> HTMLArea.Config();
  302. config.toolbar = [
  303.   ['<span class="string">fontname</span>', '<span class="string">space</span>',
  304.    '<span class="string">fontsize</span>', '<span class="string">space</span>',
  305.    '<span class="string">formatblock</span>', '<span class="string">space</span>',
  306.    '<span class="string">bold</span>', '<span class="string">italic</span>', '<span class="string">underline</span>']
  307. ];
  308. HTMLArea.replace('<span class="string">id</span>', config);</pre>
  309.  
  310. <p>The toolbar is an Array of Array objects.  Each array in the toolbar
  311. defines a new line.  The default toolbar looks like this:</p>
  312.  
  313. <pre class="code"
  314. >config.toolbar = [
  315. [ &quot;<span class="string">fontname</span>&quot;, &quot;<span class="string">space</span>&quot;,
  316.   &quot;<span class="string">fontsize</span>&quot;, &quot;<span class="string">space</span>&quot;,
  317.   &quot;<span class="string">formatblock</span>&quot;, &quot;<span class="string">space</span>&quot;,
  318.   &quot;<span class="string">bold</span>&quot;, &quot;<span class="string">italic</span>&quot;, &quot;<span class="string">underline</span>&quot;, &quot;<span class="string">separator</span>&quot;,
  319.   &quot;<span class="string">strikethrough</span>&quot;, &quot;<span class="string">subscript</span>&quot;, &quot;<span class="string">superscript</span>&quot;, &quot;<span class="string">separator</span>&quot;,
  320.   &quot;<span class="string">copy</span>&quot;, &quot;<span class="string">cut</span>&quot;, &quot;<span class="string">paste</span>&quot;, &quot;<span class="string">space</span>&quot;, &quot;<span class="string">undo</span>&quot;, &quot;<span class="string">redo</span>&quot; ],
  321.        
  322. [ &quot;<span class="string">justifyleft</span>&quot;, &quot;<span class="string">justifycenter</span>&quot;, &quot;<span class="string">justifyright</span>&quot;, &quot;<span class="string">justifyfull</span>&quot;, &quot;<span class="string">separator</span>&quot;,
  323.   &quot;<span class="string">insertorderedlist</span>&quot;, &quot;<span class="string">insertunorderedlist</span>&quot;, &quot;<span class="string">outdent</span>&quot;, &quot;<span class="string">indent</span>&quot;, &quot;<span class="string">separator</span>&quot;,
  324.   &quot;<span class="string">forecolor</span>&quot;, &quot;<span class="string">hilitecolor</span>&quot;, &quot;<span class="string">textindicator</span>&quot;, &quot;<span class="string">separator</span>&quot;,
  325.   &quot;<span class="string">inserthorizontalrule</span>&quot;, &quot;<span class="string">createlink</span>&quot;, &quot;<span class="string">insertimage</span>&quot;, &quot;<span class="string">inserttable</span>&quot;, &quot;<span class="string">htmlmode</span>&quot;, &quot;<span class="string">separator</span>&quot;,
  326.   &quot;<span class="string">popupeditor</span>&quot;, &quot;<span class="string">separator</span>&quot;, &quot;<span class="string">showhelp</span>&quot;, &quot;<span class="string">about</span>&quot; ]
  327. ];</pre>
  328.  
  329. <p>Except three strings, all others in the examples above need to be defined
  330. in the <code>config.btnList</code> object (detailed a bit later in this
  331. document).  The three exceptions are: 'space', 'separator' and 'linebreak'.
  332. These three have the following meaning, and need not be present in
  333. <code>btnList</code>:</p>
  334.  
  335. <ul>
  336.   <li>'space' -- Inserts a space of 5 pixels (the width is configurable by external
  337.   <acronym title="Cascading Style Sheets">CSS</acronym>) at the current
  338.   position in the toolbar.</li>
  339.   <li>'separator' -- Inserts a small vertical separator, for visually grouping related
  340.   buttons.</li>
  341.   <li>'linebreak' -- Starts a new line in the toolbar.  Subsequent controls will be
  342.   inserted on the new line.</li>
  343. </ul>
  344.  
  345. <p><span class="warning">Important:</span> It's recommended that you add
  346. custom features and configuration to a separate file.  This will ensure you
  347. that when we release a new official version of HTMLArea you'll have less
  348. trouble upgrading it.</p>
  349.  
  350. <h3>How do I create custom buttons?</h3>
  351.  
  352. <p>By design, the toolbar is easily extensible.  For adding a custom button
  353. one needs to follow two steps.</p>
  354.  
  355. <h4 id="regbtn">1. Register the button in <code>config.btnList</code>.</h4>
  356.  
  357. <p>For each button in the toolbar, HTMLArea needs to know the following
  358. information:</p>
  359. <ul>
  360.   <li>a name for it (we call it the ID of the button);</li>
  361.   <li>the path to an image to be displayed in the toolbar;</li>
  362.   <li>a tooltip for it;</li>
  363.   <li>whether the button is enabled or not in text mode;</li>
  364.   <li>what to do when the button is clicked;</li>
  365. </ul>
  366. <p>You need to provide all this information for registering a new button
  367. too.  The button ID can be any string identifier and it's used when
  368. defining the toolbar, as you saw above.  We recommend starting
  369. it with "my-" so that it won't clash with the standard ID-s (those from
  370. the default toolbar).</p>
  371.  
  372. <p class="note">Register button example #1</p>
  373.  
  374. <pre class="code"
  375. ><span class="comment">// get a default configuration
  376. </span><span class="keyword">var</span> <span class="variable-name">config</span> = <span class="keyword">new</span> HTMLArea.Config();
  377. <span class="comment">// register the new button using Config.registerButton.
  378. // parameters:        button ID,   tooltip,          image,           textMode,
  379. </span>config.registerButton(&quot;<span class="string">my-hilite</span>&quot;, &quot;<span class="string">Highlight text</span>&quot;, &quot;<span class="string">my-hilite.gif</span>&quot;, <span class="keyword">false</span>,
  380. <span class="comment">// function that gets called when the button is clicked
  381. </span>  <span class="keyword">function</span>(editor, id) {
  382.     editor.surroundHTML('<span class="string">&lt;span class=&quot;hilite&quot;&gt;</span>', '<span class="string">&lt;/span&gt;</span>');
  383.   }
  384. );</pre>
  385.  
  386. <p>An alternate way of calling registerButton is exemplified above.  Though
  387. the code might be a little bit larger, using this form makes your code more
  388. maintainable.  It doesn't even needs comments as it's pretty clear.</p>
  389.  
  390. <p class="note">Register button example #2</p>
  391.  
  392. <pre class="code"
  393. ><span class="keyword">var</span> <span class="variable-name">config</span> = <span class="keyword">new</span> HTMLArea.Config();
  394. config.registerButton({
  395.   id        : &quot;<span class="string">my-hilite</span>&quot;,
  396.   tooltip   : &quot;<span class="string">Highlight text</span>&quot;,
  397.   image     : &quot;<span class="string">my-hilite.gif</span>&quot;,
  398.   textMode  : <span class="keyword">false</span>,
  399.   action    : <span class="keyword">function</span>(editor, id) {
  400.                 editor.surroundHTML('<span class="string">&lt;span class=&quot;hilite&quot;&gt;</span>', '<span class="string">&lt;/span&gt;</span>');
  401.               }
  402. });</pre>
  403.  
  404. <p>You might notice that the "action" function receives two parameters:
  405. <b>editor</b> and <b>id</b>.  In the examples above we only used the
  406. <b>editor</b> parameter.  But it could be helpful for you to understand
  407. both:</p>
  408.  
  409. <ul>
  410.   <li><b>editor</b> is a reference to the HTMLArea object.  Since our entire
  411.   code now has an <acronym title="Object Oriented Programming">OOP</acronym>-like
  412.   design, you need to have a reference to
  413.   the editor object in order to do things with it.  In previous versions of
  414.   HTMLArea, in order to identify the object an ID was used -- the ID of the
  415.   HTML element.  In this version ID-s are no longer necessary.</li>
  416.  
  417.   <li><b>id</b> is the button ID.  Wondering why is this useful?  Well, you
  418.   could use the same handler function (presuming that it's not an anonymous
  419.   function like in the examples above) for more buttons.  You can <a
  420.  href="#btnex">see an example</a> a bit later in this document.</li>
  421. </ul>
  422.  
  423. <h4>2. Inserting it into the toolbar</h4>
  424.  
  425. <p>At this step you need to specify where in the toolbar to insert the
  426. button, or just create the whole toolbar again as you saw in the previous
  427. section.  You use the button ID, as shown in the examples of customizing the
  428. toolbar in the previous section.</p>
  429.  
  430. <p>For the sake of completion, following there are another examples.</p>
  431.  
  432. <p class="note">Append your button to the default toolbar</p>
  433.  
  434. <pre class="code"
  435. >config.toolbar.push([ &quot;<span class="string">my-hilite</span>&quot; ]);</pre>
  436.  
  437. <p class="note">Customized toolbar</p>
  438.  
  439. <pre class="code"
  440. >config.toolbar = [
  441.   ['<span class="string">fontname</span>', '<span class="string">space</span>',
  442.    '<span class="string">fontsize</span>', '<span class="string">space</span>',
  443.    '<span class="string">formatblock</span>', '<span class="string">space</span>',
  444.    '<span class="string">separator</span>', '<span class="string">my-hilite</span>', '<span class="string">separator</span>', '<span class="string">space</span>', <span class="comment">// here's your button
  445. </span>   '<span class="string">bold</span>', '<span class="string">italic</span>', '<span class="string">underline</span>', '<span class="string">space</span>']
  446. ];</pre>
  447.  
  448. <p><span class="note">Note:</span> in the example above our new button is
  449. between two vertical separators.  But this is by no means required.  You can
  450. put it wherever you like.  Once registered in the btnList (<a
  451. href="#regbtn">step 1</a>) your custom button behaves just like a default
  452. button.</p>
  453.  
  454. <p><span class="warning">Important:</span> It's recommended that you add
  455. custom features and configuration to a separate file.  This will ensure you
  456. that when we release a new official version of HTMLArea you'll have less
  457. trouble upgrading it.</p>
  458.  
  459. <h4 id="btnex">A complete example</h4>
  460.  
  461. <p>Please note that it is by no means necessary to include the following
  462. code into the htmlarea.js file.  On the contrary, it might not work there.
  463. The configuration system is designed such that you can always customize the
  464. editor <em>from outside files</em>, thus keeping the htmlarea.js file
  465. intact.  This will make it easy for you to upgrade your HTMLArea when we
  466. release a new official version.  OK, I promise it's the last time I said
  467. this. ;)</p>
  468.  
  469. <pre class="code"
  470. ><span class="comment">// All our custom buttons will call this function when clicked.
  471. // We use the <b>buttonId</b> parameter to determine what button
  472. // triggered the call.
  473. </span><span class="keyword">function</span> <span class="function-name">clickHandler</span>(editor, buttonId) {
  474.   <span class="keyword">switch</span> (buttonId) {
  475.     <span class="keyword">case</span> &quot;<span class="string">my-toc</span>&quot;:
  476.       editor.insertHTML(&quot;<span class="string">&lt;h1&gt;Table Of Contents&lt;/h1&gt;</span>&quot;);
  477.       <span class="keyword">break</span>;
  478.     <span class="keyword">case</span> &quot;<span class="string">my-date</span>&quot;:
  479.       editor.insertHTML((<span class="keyword">new</span> Date()).toString());
  480.       <span class="keyword">break</span>;
  481.     <span class="keyword">case</span> &quot;<span class="string">my-bold</span>&quot;:
  482.       editor.execCommand(&quot;<span class="string">bold</span>&quot;);
  483.       editor.execCommand(&quot;<span class="string">italic</span>&quot;);
  484.       <span class="keyword">break</span>;
  485.     <span class="keyword">case</span> &quot;<span class="string">my-hilite</span>&quot;:
  486.       editor.surroundHTML(&quot;<span class="string">&lt;span class=\&quot;hilite\&quot;&gt;</span>&quot;, &quot;<span class="string">&lt;/span&gt;</span>&quot;);
  487.       <span class="keyword">break</span>;
  488.   }
  489. };
  490.  
  491. <span class="comment">// Create a new configuration object
  492. </span><span class="keyword">var</span> <span class="variable-name">config</span> = <span class="keyword">new</span> HTMLArea.Config();
  493.  
  494. <span class="comment">// Register our custom buttons
  495. </span>config.registerButton(&quot;<span class="string">my-toc</span>&quot;,  &quot;<span class="string">Insert TOC</span>&quot;, &quot;<span class="string">my-toc.gif</span>&quot;, <span class="keyword">false</span>, clickHandler);
  496. config.registerButton(&quot;<span class="string">my-date</span>&quot;, &quot;<span class="string">Insert date/time</span>&quot;, &quot;<span class="string">my-date.gif</span>&quot;, <span class="keyword">false</span>, clickHandler);
  497. config.registerButton(&quot;<span class="string">my-bold</span>&quot;, &quot;<span class="string">Toggle bold/italic</span>&quot;, &quot;<span class="string">my-bold.gif</span>&quot;, <span class="keyword">false</span>, clickHandler);
  498. config.registerButton(&quot;<span class="string">my-hilite</span>&quot;, &quot;<span class="string">Hilite selection</span>&quot;, &quot;<span class="string">my-hilite.gif</span>&quot;, <span class="keyword">false</span>, clickHandler);
  499.  
  500. <span class="comment">// Append the buttons to the default toolbar
  501. </span>config.toolbar.push([&quot;<span class="string">linebreak</span>&quot;, &quot;<span class="string">my-toc</span>&quot;, &quot;<span class="string">my-date</span>&quot;, &quot;<span class="string">my-bold</span>&quot;, &quot;<span class="string">my-hilite</span>&quot;]);
  502.  
  503. <span class="comment">// Replace an existing textarea with an HTMLArea object having the above config.
  504. </span>HTMLArea.replace(&quot;<span class="string">textAreaID</span>&quot;, config);</pre>
  505.  
  506.  
  507. <hr />
  508. <address>&copy; <a href="http://interactivetools.com" title="Visit our website"
  509. >InteractiveTools.com</a> 2002-2004.
  510. <br />
  511. © <a href="http://dynarch.com">dynarch.com</a> 2003-2004<br />
  512. HTMLArea v3.0 developed by <a
  513. href="http://dynarch.com/mishoo/">Mihai Bazon</a>.
  514. <br />
  515. Documentation written by Mihai Bazon.
  516. <!-- hhmts start --> Last modified: Wed Jan 28 12:18:23 EET 2004 <!-- hhmts end -->
  517. <!-- doc-lang: English -->
  518. </body> </html>
  519.  


cron