JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
vanilla ckeditor-3.4.2
[ckeditor.git] / _source / plugins / forms / dialogs / checkbox.js
index 021163b..b36526d 100644 (file)
@@ -1,5 +1,5 @@
 /*\r
-Copyright (c) 2003-2009, CKSource - Frederico Knabben. All rights reserved.\r
+Copyright (c) 2003-2010, CKSource - Frederico Knabben. All rights reserved.\r
 For licensing, see LICENSE.html or http://ckeditor.com/license\r
 */\r
 CKEDITOR.dialog.add( 'checkbox', function( editor )\r
@@ -14,7 +14,7 @@ CKEDITOR.dialog.add( 'checkbox', function( editor )
 \r
                        var element = this.getParentEditor().getSelection().getSelectedElement();\r
 \r
-                       if ( element && element.getAttribute( 'type' ) == "checkbox" )\r
+                       if ( element && element.getAttribute( 'type' ) == 'checkbox' )\r
                        {\r
                                this.checkbox = element;\r
                                this.setupContent( element );\r
@@ -31,10 +31,8 @@ CKEDITOR.dialog.add( 'checkbox', function( editor )
                                editor = this.getParentEditor();\r
                                element = editor.document.createElement( 'input' );\r
                                element.setAttribute( 'type', 'checkbox' );\r
-                       }\r
-\r
-                       if ( isInsertMode )\r
                                editor.insertElement( element );\r
+                       }\r
                        this.commitContent( { element : element } );\r
                },\r
                contents : [\r
@@ -91,7 +89,19 @@ CKEDITOR.dialog.add( 'checkbox', function( editor )
                                                        if ( value && !( CKEDITOR.env.ie && value == 'on' ) )\r
                                                                element.setAttribute( 'value', value );\r
                                                        else\r
-                                                               element.removeAttribute( 'value' );\r
+                                                       {\r
+                                                               if ( CKEDITOR.env.ie )\r
+                                                               {\r
+                                                                       // Remove attribute 'value' of checkbox (#4721).\r
+                                                                       var checkbox = new CKEDITOR.dom.element( 'input', element.getDocument() );\r
+                                                                       element.copyAttributes( checkbox, { value: 1 } );\r
+                                                                       checkbox.replace( element );\r
+                                                                       editor.getSelection().selectElement( checkbox );\r
+                                                                       data.element = checkbox;\r
+                                                               }\r
+                                                               else\r
+                                                                       element.removeAttribute( 'value' );\r
+                                                       }\r
                                                }\r
                                        },\r
                                        {\r
@@ -111,8 +121,8 @@ CKEDITOR.dialog.add( 'checkbox', function( editor )
 \r
                                                        if ( CKEDITOR.env.ie )\r
                                                        {\r
-                                                               var isElementChecked = !!element.getAttribute( 'checked' );\r
-                                                               var isChecked = !!this.getValue();\r
+                                                               var isElementChecked = !!element.getAttribute( 'checked' ),\r
+                                                                       isChecked = !!this.getValue();\r
 \r
                                                                if ( isElementChecked != isChecked )\r
                                                                {\r