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