JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
vanilla ckeditor-3.5.3
[ckeditor.git] / _samples / divreplace.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">\r
2 <!--\r
3 Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved.\r
4 For licensing, see LICENSE.html or http://ckeditor.com/license\r
5 -->\r
6 <html xmlns="http://www.w3.org/1999/xhtml">\r
7 <head>\r
8         <title>Replace DIV &mdash; CKEditor Sample</title>\r
9         <meta content="text/html; charset=utf-8" http-equiv="content-type" />\r
10         <script type="text/javascript" src="../ckeditor.js"></script>\r
11         <script src="sample.js" type="text/javascript"></script>\r
12         <link href="sample.css" rel="stylesheet" type="text/css" />\r
13         <style id="styles" type="text/css">\r
14 \r
15                 div.editable\r
16                 {\r
17                         border: solid 2px Transparent;\r
18                         padding-left: 15px;\r
19                         padding-right: 15px;\r
20                 }\r
21 \r
22                 div.editable:hover\r
23                 {\r
24                         border-color: black;\r
25                 }\r
26 \r
27         </style>\r
28         <script type="text/javascript">\r
29         //<![CDATA[\r
30 \r
31 // Uncomment the following code to test the "Timeout Loading Method".\r
32 // CKEDITOR.loadFullCoreTimeout = 5;\r
33 \r
34 window.onload = function()\r
35 {\r
36         // Listen to the double click event.\r
37         if ( window.addEventListener )\r
38                 document.body.addEventListener( 'dblclick', onDoubleClick, false );\r
39         else if ( window.attachEvent )\r
40                 document.body.attachEvent( 'ondblclick', onDoubleClick );\r
41 \r
42 };\r
43 \r
44 function onDoubleClick( ev )\r
45 {\r
46         // Get the element which fired the event. This is not necessarily the\r
47         // element to which the event has been attached.\r
48         var element = ev.target || ev.srcElement;\r
49 \r
50         // Find out the div that holds this element.\r
51         var name;\r
52         do\r
53         {\r
54                 element = element.parentNode;\r
55         }\r
56         while ( element && ( name = element.nodeName.toLowerCase() ) && ( name != 'div' || element.className.indexOf( 'editable' ) == -1 ) && name != 'body' )\r
57 \r
58 \r
59         if ( name == 'div' && element.className.indexOf( 'editable' ) != -1 )\r
60                 replaceDiv( element );\r
61 }\r
62 \r
63 var editor;\r
64 \r
65 function replaceDiv( div )\r
66 {\r
67         if ( editor )\r
68                 editor.destroy();\r
69 \r
70         editor = CKEDITOR.replace( div );\r
71 }\r
72 \r
73         //]]>\r
74         </script>\r
75 \r
76 </head>\r
77 <body>\r
78         <h1 class="samples">\r
79                 CKEditor Sample &mdash; Replace DIV with CKEditor on the Fly\r
80         </h1>\r
81         <div class="description">\r
82         <p>\r
83                 This sample shows how to automatically replace <code>&lt;div&gt;</code> elements\r
84                 with a CKEditor instance on the fly, following user's doubleclick. The content\r
85                 that was previously placed inside the <code>&lt;div&gt;</code> element will now\r
86                 be moved into CKEditor editing area.\r
87         </p>\r
88         <p>\r
89                 For details on how to create this setup check the source code of this sample page.\r
90         </p>\r
91         </div>\r
92         <!-- This <div> holds alert messages to be display in the sample page. -->\r
93         <div id="alerts">\r
94                 <noscript>\r
95                         <p>\r
96                                 <strong>CKEditor requires JavaScript to run</strong>. In a browser with no JavaScript\r
97                                 support, like yours, you should still see the contents (HTML data) and you should\r
98                                 be able to edit it normally, without a rich editor interface.\r
99                         </p>\r
100                 </noscript>\r
101         </div>\r
102         <p>\r
103                 Double-click any of the following <code>&lt;div&gt;</code> elements to transform them into\r
104                 editor instances.</p>\r
105         <div class="editable">\r
106                 <h3>\r
107                         Part 1</h3>\r
108                 <p>\r
109                         Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Cras et ipsum quis mi\r
110                         semper accumsan. Integer pretium dui id massa. Suspendisse in nisl sit amet urna\r
111                         rutrum imperdiet. Nulla eu tellus. Donec ante nisi, ullamcorper quis, fringilla\r
112                         nec, sagittis eleifend, pede. Nulla commodo interdum massa. Donec id metus. Fusce\r
113                         eu ipsum. Suspendisse auctor. Phasellus fermentum porttitor risus.\r
114                 </p>\r
115         </div>\r
116         <div class="editable">\r
117                 <h3>\r
118                         Part 2</h3>\r
119                 <p>\r
120                         Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Cras et ipsum quis mi\r
121                         semper accumsan. Integer pretium dui id massa. Suspendisse in nisl sit amet urna\r
122                         rutrum imperdiet. Nulla eu tellus. Donec ante nisi, ullamcorper quis, fringilla\r
123                         nec, sagittis eleifend, pede. Nulla commodo interdum massa. Donec id metus. Fusce\r
124                         eu ipsum. Suspendisse auctor. Phasellus fermentum porttitor risus.\r
125                 </p>\r
126                 <p>\r
127                         Donec velit. Mauris massa. Vestibulum non nulla. Nam suscipit arcu nec elit. Phasellus\r
128                         sollicitudin iaculis ante. Ut non mauris et sapien tincidunt adipiscing. Vestibulum\r
129                         vitae leo. Suspendisse nec mi tristique nulla laoreet vulputate.\r
130                 </p>\r
131         </div>\r
132         <div class="editable">\r
133                 <h3>\r
134                         Part 3</h3>\r
135                 <p>\r
136                         Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Cras et ipsum quis mi\r
137                         semper accumsan. Integer pretium dui id massa. Suspendisse in nisl sit amet urna\r
138                         rutrum imperdiet. Nulla eu tellus. Donec ante nisi, ullamcorper quis, fringilla\r
139                         nec, sagittis eleifend, pede. Nulla commodo interdum massa. Donec id metus. Fusce\r
140                         eu ipsum. Suspendisse auctor. Phasellus fermentum porttitor risus.\r
141                 </p>\r
142         </div>\r
143         <div id="footer">\r
144                 <hr />\r
145                 <p>\r
146                         CKEditor - The text editor for the Internet - <a class="samples" href="http://ckeditor.com/">http://ckeditor.com</a>\r
147                 </p>\r
148                 <p id="copy">\r
149                         Copyright &copy; 2003-2011, <a class="samples" href="http://cksource.com/">CKSource</a> - Frederico\r
150                         Knabben. All rights reserved.\r
151                 </p>\r
152         </div>\r
153 </body>\r
154 </html>\r