JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
vanilla ckeditor-3.0
[ckeditor.git] / _source / plugins / forms / dialogs / checkbox.js
diff --git a/_source/plugins/forms/dialogs/checkbox.js b/_source/plugins/forms/dialogs/checkbox.js
new file mode 100644 (file)
index 0000000..96c356e
--- /dev/null
@@ -0,0 +1,138 @@
+/*\r
+Copyright (c) 2003-2009, 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
+{\r
+       return {\r
+               title : editor.lang.checkboxAndRadio.checkboxTitle,\r
+               minWidth : 350,\r
+               minHeight : 140,\r
+               onShow : function()\r
+               {\r
+                       delete this.checkbox;\r
+\r
+                       var element = this.getParentEditor().getSelection().getSelectedElement();\r
+\r
+                       if ( element && element.getAttribute( 'type' ) == "checkbox" )\r
+                       {\r
+                               this.checkbox = element;\r
+                               this.setupContent( element );\r
+                       }\r
+               },\r
+               onOk : function()\r
+               {\r
+                       var editor,\r
+                               element = this.checkbox,\r
+                               isInsertMode = !element;\r
+\r
+                       if ( isInsertMode )\r
+                       {\r
+                               editor = this.getParentEditor();\r
+                               element = editor.document.createElement( 'input' );\r
+                               element.setAttribute( 'type', 'checkbox' );\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.checkboxTitle,\r
+                               title : editor.lang.checkboxAndRadio.checkboxTitle,\r
+                               startupFocus : 'txtName',\r
+                               elements : [\r
+                                       {\r
+                                               id : 'txtName',\r
+                                               type : 'text',\r
+                                               label : editor.lang.common.name,\r
+                                               'default' : '',\r
+                                               accessKey : 'N',\r
+                                               setup : function( element )\r
+                                               {\r
+                                                       this.setValue(\r
+                                                                       element.getAttribute( '_cke_saved_name' ) ||\r
+                                                                       element.getAttribute( 'name' ) ||\r
+                                                                       '' );\r
+                                               },\r
+                                               commit : function( data )\r
+                                               {\r
+                                                       var element = data.element;\r
+\r
+                                                       // IE failed to update 'name' property on input elements, protect it now.\r
+                                                       if ( this.getValue() )\r
+                                                               element.setAttribute( '_cke_saved_name', this.getValue() );\r
+                                                       else\r
+                                                       {\r
+                                                               element.removeAttribute( '_cke_saved_name' );\r
+                                                               element.removeAttribute( 'name' );\r
+                                                       }\r
+                                               }\r
+                                       },\r
+                                       {\r
+                                               id : 'txtValue',\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 : 'cmbSelected',\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 )\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="checkbox"'\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
+                                                       else\r
+                                                       {\r
+                                                               if ( this.getValue() )\r
+                                                                       element.setAttribute( 'checked', this.getValue() );\r
+                                                               else\r
+                                                                       element.removeAttribute( 'checked' );\r
+                                                       }\r
+                                               }\r
+                                       }\r
+                               ]\r
+                       }\r
+               ]\r
+       };\r
+});\r