| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 | 
							- <!doctype html>
 
- <html>
 
-   <head>
 
-     <meta charset="utf-8">
 
-     <title>CodeMirror: Full Screen Editing</title>
 
-     <link rel="stylesheet" href="../lib/codemirror.css">
 
-     <script src="../lib/codemirror.js"></script>
 
-     <link rel="stylesheet" href="../theme/night.css">
 
-     <script src="../mode/xml/xml.js"></script>
 
-     <link rel="stylesheet" href="../doc/docs.css">
 
-     <style type="text/css">
 
-       .CodeMirror-fullscreen {
 
-         display: block;
 
-         position: absolute;
 
-         top: 0; left: 0;
 
-         width: 100%;
 
-         z-index: 9999;
 
-       }
 
-     </style>
 
-   </head>
 
-   <body>
 
-     <h1>CodeMirror: Full Screen Editing</h1>
 
-     <form><textarea id="code" name="code" rows="5">
 
-   <dt id="option_indentWithTabs"><code>indentWithTabs (boolean)</code></dt>
 
-   <dd>Whether, when indenting, the first N*8 spaces should be
 
-   replaced by N tabs. Default is false.</dd>
 
-   <dt id="option_tabMode"><code>tabMode (string)</code></dt>
 
-   <dd>Determines what happens when the user presses the tab key.
 
-   Must be one of the following:
 
-     <dl>
 
-       <dt><code>"classic" (the default)</code></dt>
 
-       <dd>When nothing is selected, insert a tab. Otherwise,
 
-       behave like the <code>"shift"</code> mode. (When shift is
 
-       held, this behaves like the <code>"indent"</code> mode.)</dd>
 
-       <dt><code>"shift"</code></dt>
 
-       <dd>Indent all selected lines by
 
-       one <a href="#option_indentUnit"><code>indentUnit</code></a>.
 
-       If shift was held while pressing tab, un-indent all selected
 
-       lines one unit.</dd>
 
-       <dt><code>"indent"</code></dt>
 
-       <dd>Indent the line the 'correctly', based on its syntactic
 
-       context. Only works if the
 
-       mode <a href="#indent">supports</a> it.</dd>
 
-       <dt><code>"default"</code></dt>
 
-       <dd>Do not capture tab presses, let the browser apply its
 
-       default behaviour (which usually means it skips to the next
 
-       control).</dd>
 
-     </dl></dd>
 
-   <dt id="option_enterMode"><code>enterMode (string)</code></dt>
 
-   <dd>Determines whether and how new lines are indented when the
 
-   enter key is pressed. The following modes are supported:
 
-     <dl>
 
-       <dt><code>"indent" (the default)</code></dt>
 
-       <dd>Use the mode's indentation rules to give the new line
 
-       the correct indentation.</dd>
 
-       <dt><code>"keep"</code></dt>
 
-       <dd>Indent the line the same as the previous line.</dd>
 
-       <dt><code>"flat"</code></dt>
 
-       <dd>Do not indent the new line.</dd>
 
-     </dl></dd>
 
-   <dt id="option_enterMode"><code>enterMode (string)</code></dt>
 
-   <dd>Determines whether and how new lines are indented when the
 
-   enter key is pressed. The following modes are supported:
 
-     <dl>
 
-       <dt><code>"indent" (the default)</code></dt>
 
-       <dd>Use the mode's indentation rules to give the new line
 
-       the correct indentation.</dd>
 
-       <dt><code>"keep"</code></dt>
 
-       <dd>Indent the line the same as the previous line.</dd>
 
-       <dt><code>"flat"</code></dt>
 
-       <dd>Do not indent the new line.</dd>
 
-     </dl></dd>
 
-   <dt id="option_enterMode"><code>enterMode (string)</code></dt>
 
-   <dd>Determines whether and how new lines are indented when the
 
-   enter key is pressed. The following modes are supported:
 
-     <dl>
 
-       <dt><code>"indent" (the default)</code></dt>
 
-       <dd>Use the mode's indentation rules to give the new line
 
-       the correct indentation.</dd>
 
-       <dt><code>"keep"</code></dt>
 
-       <dd>Indent the line the same as the previous line.</dd>
 
-       <dt><code>"flat"</code></dt>
 
-       <dd>Do not indent the new line.</dd>
 
-     </dl></dd>
 
-   <dt id="option_enterMode"><code>enterMode (string)</code></dt>
 
-   <dd>Determines whether and how new lines are indented when the
 
-   enter key is pressed. The following modes are supported:
 
-     <dl>
 
-       <dt><code>"indent" (the default)</code></dt>
 
-       <dd>Use the mode's indentation rules to give the new line
 
-       the correct indentation.</dd>
 
-       <dt><code>"keep"</code></dt>
 
-       <dd>Indent the line the same as the previous line.</dd>
 
-       <dt><code>"flat"</code></dt>
 
-       <dd>Do not indent the new line.</dd>
 
-     </dl></dd>
 
- </textarea></form>
 
-   <script>
 
-     function isFullScreen(cm) {
 
-       return /\bCodeMirror-fullscreen\b/.test(cm.getWrapperElement().className);
 
-     }
 
-     function winHeight() {
 
-       return window.innerHeight || (document.documentElement || document.body).clientHeight;
 
-     }
 
-     function setFullScreen(cm, full) {
 
-       var wrap = cm.getWrapperElement();
 
-       if (full) {
 
-         wrap.className += " CodeMirror-fullscreen";
 
-         wrap.style.height = winHeight() + "px";
 
-         document.documentElement.style.overflow = "hidden";
 
-       } else {
 
-         wrap.className = wrap.className.replace(" CodeMirror-fullscreen", "");
 
-         wrap.style.height = "";
 
-         document.documentElement.style.overflow = "";
 
-       }
 
-       cm.refresh();
 
-     }
 
-     CodeMirror.on(window, "resize", function() {
 
-       var showing = document.body.getElementsByClassName("CodeMirror-fullscreen")[0];
 
-       if (!showing) return;
 
-       showing.CodeMirror.getWrapperElement().style.height = winHeight() + "px";
 
-     });
 
-     var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
 
-       lineNumbers: true,
 
-       theme: "night",
 
-       extraKeys: {
 
-         "F11": function(cm) {
 
-           setFullScreen(cm, !isFullScreen(cm));
 
-         },
 
-         "Esc": function(cm) {
 
-           if (isFullScreen(cm)) setFullScreen(cm, false);
 
-         }
 
-       }
 
-     });
 
-   </script>
 
-     <p>Press <strong>F11</strong> when cursor is in the editor to toggle full screen editing. <strong>Esc</strong> can also be used to <i>exit</i> full screen editing.</p>
 
-   </body>
 
- </html>
 
 
  |