JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
vanilla ckeditor-3.0
[ckeditor.git] / _source / plugins / forms / dialogs / checkbox.js
1 /*\r
2 Copyright (c) 2003-2009, CKSource - Frederico Knabben. All rights reserved.\r
3 For licensing, see LICENSE.html or http://ckeditor.com/license\r
4 */\r
5 CKEDITOR.dialog.add( 'checkbox', function( editor )\r
6 {\r
7         return {\r
8                 title : editor.lang.checkboxAndRadio.checkboxTitle,\r
9                 minWidth : 350,\r
10                 minHeight : 140,\r
11                 onShow : function()\r
12                 {\r
13                         delete this.checkbox;\r
14 \r
15                         var element = this.getParentEditor().getSelection().getSelectedElement();\r
16 \r
17                         if ( element && element.getAttribute( 'type' ) == "checkbox" )\r
18                         {\r
19                                 this.checkbox = element;\r
20                                 this.setupContent( element );\r
21                         }\r
22                 },\r
23                 onOk : function()\r
24                 {\r
25                         var editor,\r
26                                 element = this.checkbox,\r
27                                 isInsertMode = !element;\r
28 \r
29                         if ( isInsertMode )\r
30                         {\r
31                                 editor = this.getParentEditor();\r
32                                 element = editor.document.createElement( 'input' );\r
33                                 element.setAttribute( 'type', 'checkbox' );\r
34                         }\r
35 \r
36                         if ( isInsertMode )\r
37                                 editor.insertElement( element );\r
38                         this.commitContent( { element : element } );\r
39                 },\r
40                 contents : [\r
41                         {\r
42                                 id : 'info',\r
43                                 label : editor.lang.checkboxAndRadio.checkboxTitle,\r
44                                 title : editor.lang.checkboxAndRadio.checkboxTitle,\r
45                                 startupFocus : 'txtName',\r
46                                 elements : [\r
47                                         {\r
48                                                 id : 'txtName',\r
49                                                 type : 'text',\r
50                                                 label : editor.lang.common.name,\r
51                                                 'default' : '',\r
52                                                 accessKey : 'N',\r
53                                                 setup : function( element )\r
54                                                 {\r
55                                                         this.setValue(\r
56                                                                         element.getAttribute( '_cke_saved_name' ) ||\r
57                                                                         element.getAttribute( 'name' ) ||\r
58                                                                         '' );\r
59                                                 },\r
60                                                 commit : function( data )\r
61                                                 {\r
62                                                         var element = data.element;\r
63 \r
64                                                         // IE failed to update 'name' property on input elements, protect it now.\r
65                                                         if ( this.getValue() )\r
66                                                                 element.setAttribute( '_cke_saved_name', this.getValue() );\r
67                                                         else\r
68                                                         {\r
69                                                                 element.removeAttribute( '_cke_saved_name' );\r
70                                                                 element.removeAttribute( 'name' );\r
71                                                         }\r
72                                                 }\r
73                                         },\r
74                                         {\r
75                                                 id : 'txtValue',\r
76                                                 type : 'text',\r
77                                                 label : editor.lang.checkboxAndRadio.value,\r
78                                                 'default' : '',\r
79                                                 accessKey : 'V',\r
80                                                 setup : function( element )\r
81                                                 {\r
82                                                         this.setValue( element.getAttribute( 'value' ) || '' );\r
83                                                 },\r
84                                                 commit : function( data )\r
85                                                 {\r
86                                                         var element = data.element;\r
87 \r
88                                                         if ( this.getValue() )\r
89                                                                 element.setAttribute( 'value', this.getValue() );\r
90                                                         else\r
91                                                                 element.removeAttribute( 'value' );\r
92                                                 }\r
93                                         },\r
94                                         {\r
95                                                 id : 'cmbSelected',\r
96                                                 type : 'checkbox',\r
97                                                 label : editor.lang.checkboxAndRadio.selected,\r
98                                                 'default' : '',\r
99                                                 accessKey : 'S',\r
100                                                 value : "checked",\r
101                                                 setup : function( element )\r
102                                                 {\r
103                                                         this.setValue( element.getAttribute( 'checked' ) );\r
104                                                 },\r
105                                                 commit : function( data )\r
106                                                 {\r
107                                                         var element = data.element;\r
108 \r
109                                                         if ( CKEDITOR.env.ie )\r
110                                                         {\r
111                                                                 var isElementChecked = !!element.getAttribute( 'checked' );\r
112                                                                 var isChecked = !!this.getValue();\r
113 \r
114                                                                 if ( isElementChecked != isChecked )\r
115                                                                 {\r
116                                                                         var replace = CKEDITOR.dom.element.createFromHtml( '<input type="checkbox"'\r
117                                                                                    + ( isChecked ? ' checked="checked"' : '' )\r
118                                                                                    + '></input>', editor.document );\r
119                                                                         element.copyAttributes( replace, { type : 1, checked : 1 } );\r
120                                                                         replace.replace( element );\r
121                                                                         editor.getSelection().selectElement( replace );\r
122                                                                         data.element = replace;\r
123                                                                 }\r
124                                                         }\r
125                                                         else\r
126                                                         {\r
127                                                                 if ( this.getValue() )\r
128                                                                         element.setAttribute( 'checked', this.getValue() );\r
129                                                                 else\r
130                                                                         element.removeAttribute( 'checked' );\r
131                                                         }\r
132                                                 }\r
133                                         }\r
134                                 ]\r
135                         }\r
136                 ]\r
137         };\r
138 });\r