--- /dev/null
+/*\r
+Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved.\r
+For licensing, see LICENSE.html or http://ckeditor.com/license\r
+*/\r
+CKEDITOR.dialog.add( 'radio', function( editor )\r
+{\r
+ return {\r
+ title : editor.lang.checkboxAndRadio.radioTitle,\r
+ minWidth : 350,\r
+ minHeight : 140,\r
+ onShow : function()\r
+ {\r
+ delete this.radioButton;\r
+\r
+ var element = this.getParentEditor().getSelection().getSelectedElement();\r
+ if ( element && element.getName() == 'input' && element.getAttribute( 'type' ) == 'radio' )\r
+ {\r
+ this.radioButton = element;\r
+ this.setupContent( element );\r
+ }\r
+ },\r
+ onOk : function()\r
+ {\r
+ var editor,\r
+ element = this.radioButton,\r
+ isInsertMode = !element;\r
+\r
+ if ( isInsertMode )\r
+ {\r
+ editor = this.getParentEditor();\r
+ element = editor.document.createElement( 'input' );\r
+ element.setAttribute( 'type', 'radio' );\r
+ }\r
+\r
+ if ( isInsertMode )\r
+ editor.insertElement( element );\r
+ this.commitContent( { element : element } );\r
+ },\r
+ contents : [\r
+ {\r
+ id : 'info',\r
+ label : editor.lang.checkboxAndRadio.radioTitle,\r
+ title : editor.lang.checkboxAndRadio.radioTitle,\r
+ elements : [\r
+ {\r
+ id : 'name',\r
+ type : 'text',\r
+ label : editor.lang.common.name,\r
+ 'default' : '',\r
+ accessKey : 'N',\r
+ setup : function( element )\r
+ {\r
+ this.setValue(\r
+ element.data( 'cke-saved-name' ) ||\r
+ element.getAttribute( 'name' ) ||\r
+ '' );\r
+ },\r
+ commit : function( data )\r
+ {\r
+ var element = data.element;\r
+\r
+ if ( this.getValue() )\r
+ element.data( 'cke-saved-name', this.getValue() );\r
+ else\r
+ {\r
+ element.data( 'cke-saved-name', false );\r
+ element.removeAttribute( 'name' );\r
+ }\r
+ }\r
+ },\r
+ {\r
+ id : 'value',\r
+ type : 'text',\r
+ label : editor.lang.checkboxAndRadio.value,\r
+ 'default' : '',\r
+ accessKey : 'V',\r
+ setup : function( element )\r
+ {\r
+ this.setValue( element.getAttribute( 'value' ) || '' );\r
+ },\r
+ commit : function( data )\r
+ {\r
+ var element = data.element;\r
+\r
+ if ( this.getValue() )\r
+ element.setAttribute( 'value', this.getValue() );\r
+ else\r
+ element.removeAttribute( 'value' );\r
+ }\r
+ },\r
+ {\r
+ id : 'checked',\r
+ type : 'checkbox',\r
+ label : editor.lang.checkboxAndRadio.selected,\r
+ 'default' : '',\r
+ accessKey : 'S',\r
+ value : "checked",\r
+ setup : function( element )\r
+ {\r
+ this.setValue( element.getAttribute( 'checked' ) );\r
+ },\r
+ commit : function( data )\r
+ {\r
+ var element = data.element;\r
+\r
+ if ( !( CKEDITOR.env.ie || CKEDITOR.env.opera ) )\r
+ {\r
+ if ( this.getValue() )\r
+ element.setAttribute( 'checked', 'checked' );\r
+ else\r
+ element.removeAttribute( 'checked' );\r
+ }\r
+ else\r
+ {\r
+ var isElementChecked = element.getAttribute( 'checked' );\r
+ var isChecked = !!this.getValue();\r
+\r
+ if ( isElementChecked != isChecked )\r
+ {\r
+ var replace = CKEDITOR.dom.element.createFromHtml( '<input type="radio"'\r
+ + ( isChecked ? ' checked="checked"' : '' )\r
+ + '></input>', editor.document );\r
+ element.copyAttributes( replace, { type : 1, checked : 1 } );\r
+ replace.replace( element );\r
+ editor.getSelection().selectElement( replace );\r
+ data.element = replace;\r
+ }\r
+ }\r
+ }\r
+ }\r
+ ]\r
+ }\r
+ ]\r
+ };\r
+});\r