X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=_source%2Fplugins%2Fforms%2Fplugin.js;h=8c247c426c433c20b3edae20be3e2af068f08d25;hb=2f22c0c38f17e75be5541089076885442aaa2377;hp=daf36c62c9b5434b70e5c14faa308eafe5b5e52d;hpb=055b6b0792ce7dc53d47af606b367c04b927c2ab;p=ckeditor.git diff --git a/_source/plugins/forms/plugin.js b/_source/plugins/forms/plugin.js index daf36c6..8c247c4 100644 --- a/_source/plugins/forms/plugin.js +++ b/_source/plugins/forms/plugin.js @@ -1,5 +1,5 @@ /* -Copyright (c) 2003-2010, CKSource - Frederico Knabben. All rights reserved. +Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. For licensing, see LICENSE.html or http://ckeditor.com/license */ @@ -131,13 +131,13 @@ CKEDITOR.plugins.add( 'forms', { editor.contextMenu.addListener( function( element ) { - if ( element && element.hasAscendant( 'form', true ) ) + if ( element && element.hasAscendant( 'form', true ) && !element.isReadOnly() ) return { form : CKEDITOR.TRISTATE_OFF }; }); editor.contextMenu.addListener( function( element ) { - if ( element ) + if ( element && !element.isReadOnly() ) { var name = element.getName(); @@ -149,25 +149,28 @@ CKEDITOR.plugins.add( 'forms', if ( name == 'input' ) { - var type = element.getAttribute( 'type' ); + switch( element.getAttribute( 'type' ) ) + { + case 'button' : + case 'submit' : + case 'reset' : + return { button : CKEDITOR.TRISTATE_OFF }; - if ( type == 'text' || type == 'password' ) - return { textfield : CKEDITOR.TRISTATE_OFF }; + case 'checkbox' : + return { checkbox : CKEDITOR.TRISTATE_OFF }; - if ( type == 'button' || type == 'submit' || type == 'reset' ) - return { button : CKEDITOR.TRISTATE_OFF }; + case 'radio' : + return { radio : CKEDITOR.TRISTATE_OFF }; - if ( type == 'checkbox' ) - return { checkbox : CKEDITOR.TRISTATE_OFF }; + case 'image' : + return { imagebutton : CKEDITOR.TRISTATE_OFF }; - if ( type == 'radio' ) - return { radio : CKEDITOR.TRISTATE_OFF }; - - if ( type == 'image' ) - return { imagebutton : CKEDITOR.TRISTATE_OFF }; + default : + return { textfield : CKEDITOR.TRISTATE_OFF }; + } } - if ( name == 'img' && element.getAttribute( '_cke_real_element_type' ) == 'hiddenfield' ) + if ( name == 'img' && element.data( 'cke-real-element-type' ) == 'hiddenfield' ) return { hiddenfield : CKEDITOR.TRISTATE_OFF }; } }); @@ -183,18 +186,15 @@ CKEDITOR.plugins.add( 'forms', evt.data.dialog = 'select'; else if ( element.is( 'textarea' ) ) evt.data.dialog = 'textarea'; - else if ( element.is( 'img' ) && element.getAttribute( '_cke_real_element_type' ) == 'hiddenfield' ) + else if ( element.is( 'img' ) && element.data( 'cke-real-element-type' ) == 'hiddenfield' ) evt.data.dialog = 'hiddenfield'; else if ( element.is( 'input' ) ) { - var type = element.getAttribute( 'type' ); - - switch ( type ) + switch ( element.getAttribute( 'type' ) ) { - case 'text' : case 'password': - evt.data.dialog = 'textfield'; - break; - case 'button' : case 'submit' : case 'reset' : + case 'button' : + case 'submit' : + case 'reset' : evt.data.dialog = 'button'; break; case 'checkbox' : @@ -206,6 +206,9 @@ CKEDITOR.plugins.add( 'forms', case 'image' : evt.data.dialog = 'imagebutton'; break; + default : + evt.data.dialog = 'textfield'; + break; } } }); @@ -228,6 +231,9 @@ CKEDITOR.plugins.add( 'forms', { var attrs = input.attributes, type = attrs.type; + // Old IEs don't provide type for Text inputs #5522 + if ( !type ) + attrs.type = 'text'; if ( type == 'checkbox' || type == 'radio' ) attrs.value == 'on' && delete attrs.value; } @@ -255,27 +261,28 @@ CKEDITOR.plugins.add( 'forms', if ( CKEDITOR.env.ie ) { - CKEDITOR.dom.element.prototype.hasAttribute = function( name ) - { - var $attr = this.$.attributes.getNamedItem( name ); - - if ( this.getName() == 'input' ) + CKEDITOR.dom.element.prototype.hasAttribute = CKEDITOR.tools.override( CKEDITOR.dom.element.prototype.hasAttribute, + function( original ) { - switch ( name ) - { - case 'class' : - return this.$.className.length > 0; - case 'checked' : - return !!this.$.checked; - case 'value' : - var type = this.getAttribute( 'type' ); - if ( type == 'checkbox' || type == 'radio' ) - return this.$.value != 'on'; - break; - default: - } - } + return function( name ) + { + var $attr = this.$.attributes.getNamedItem( name ); + + if ( this.getName() == 'input' ) + { + switch ( name ) + { + case 'class' : + return this.$.className.length > 0; + case 'checked' : + return !!this.$.checked; + case 'value' : + var type = this.getAttribute( 'type' ); + return type == 'checkbox' || type == 'radio' ? this.$.value != 'on' : this.$.value; + } + } - return !!( $attr && $attr.specified ); - }; + return original.apply( this, arguments ); + }; + }); }