fcktextcolorcommand.js
资源名称:Myblog.rar [点击查看]
上传用户:wlfwy2004
上传日期:2016-12-12
资源大小:33978k
文件大小:5k
源码类别:
Jsp/Servlet
开发平台:
Java
- /*
- * FCKeditor - The text editor for internet
- * Copyright (C) 2003-2005 Frederico Caldeira Knabben
- *
- * Licensed under the terms of the GNU Lesser General Public License:
- * http://www.opensource.org/licenses/lgpl-license.php
- *
- * For further information visit:
- * http://www.fckeditor.net/
- *
- * File Name: fcktextcolorcommand.js
- * FCKTextColorCommand Class: represents the text color comand. It shows the
- * color selection panel.
- *
- * File Authors:
- * Frederico Caldeira Knabben (fredck@fckeditor.net)
- */
- // FCKTextColorCommand Contructor
- // type: can be 'ForeColor' or 'BackColor'.
- var FCKTextColorCommand = function( type )
- {
- this.Name = type == 'ForeColor' ? 'TextColor' : 'BGColor' ;
- this.Type = type ;
- /* BEGIN ###
- The panel should be created in the "Execute" method for best
- memory use, but it not works in Gecko in that way.
- */
- this._Panel = new FCKPanel() ;
- this._Panel.StyleSheet = FCKConfig.SkinPath + 'fck_contextmenu.css' ;
- this._Panel.Create() ;
- this._CreatePanelBody( this._Panel.Document, this._Panel.PanelDiv ) ;
- // END ###
- }
- FCKTextColorCommand.prototype.Execute = function( panelX, panelY, relElement )
- {
- /*
- BEGIN ###
- This is the right code to create the panel, but it is not
- working well with Gecko, so it has been moved to the
- class contructor.
- // Create the Color Panel if needed.
- if ( ! this._Panel )
- {
- this._Panel = new FCKPanel() ;
- this._Panel.StyleSheet = FCKConfig.SkinPath + 'fck_contextmenu.css' ;
- this._Panel.Create() ;
- this._CreatePanelBody( this._Panel.Document, this._Panel.PanelDiv ) ;
- }
- END ###
- */
- // We must "cache" the actual panel type to be used in the SetColor method.
- FCK._ActiveColorPanelType = this.Type ;
- // Show the Color Panel at the desired position.
- this._Panel.Show( panelX, panelY, relElement ) ;
- }
- FCKTextColorCommand.prototype.SetColor = function( color )
- {
- if ( FCK._ActiveColorPanelType == 'ForeColor' )
- FCK.ExecuteNamedCommand( 'ForeColor', color ) ;
- else if ( FCKBrowserInfo.IsGecko )
- FCK.ExecuteNamedCommand( 'hilitecolor', color ) ;
- else
- FCK.ExecuteNamedCommand( 'BackColor', color ) ;
- // Delete the "cached" active panel type.
- delete FCK._ActiveColorPanelType ;
- }
- FCKTextColorCommand.prototype.GetState = function()
- {
- return FCK_TRISTATE_OFF ;
- }
- function FCKTextColorCommand_OnMouseOver() { this.className='ColorSelected' ; }
- function FCKTextColorCommand_OnMouseOut() { this.className='ColorDeselected' ; }
- function FCKTextColorCommand_OnClick()
- {
- this.className = 'ColorDeselected' ;
- this.Command.SetColor( '#' + this.Color ) ;
- this.Command._Panel.Hide() ;
- }
- function FCKTextColorCommand_AutoOnClick()
- {
- this.className = 'ColorDeselected' ;
- this.Command.SetColor( '' ) ;
- this.Command._Panel.Hide() ;
- }
- function FCKTextColorCommand_MoreOnClick()
- {
- this.className = 'ColorDeselected' ;
- this.Command._Panel.Hide() ;
- FCKDialog.OpenDialog( 'FCKDialog_Color', FCKLang.DlgColorTitle, 'dialog/fck_colorselector.html', 400, 330, this.Command.SetColor ) ;
- }
- FCKTextColorCommand.prototype._CreatePanelBody = function( targetDocument, targetDiv )
- {
- function CreateSelectionDiv()
- {
- var oDiv = targetDocument.createElement( "DIV" ) ;
- oDiv.className = 'ColorDeselected' ;
- oDiv.onmouseover = FCKTextColorCommand_OnMouseOver ;
- oDiv.onmouseout = FCKTextColorCommand_OnMouseOut ;
- return oDiv ;
- }
- // Create the Table that will hold all colors.
- var oTable = targetDiv.appendChild( targetDocument.createElement( "TABLE" ) ) ;
- oTable.style.tableLayout = 'fixed' ;
- oTable.cellPadding = 0 ;
- oTable.cellSpacing = 0 ;
- oTable.border = 0 ;
- oTable.width = 150 ;
- var oCell = oTable.insertRow(-1).insertCell(-1) ;
- oCell.colSpan = 8 ;
- // Create the Button for the "Automatic" color selection.
- var oDiv = oCell.appendChild( CreateSelectionDiv() ) ;
- oDiv.innerHTML =
- '<table cellspacing="0" cellpadding="0" width="100%" border="0">
- <tr>
- <td><div class="ColorBoxBorder"><div class="ColorBox" style="background-color: #000000"></div></div></td>
- <td nowrap width="100%" align="center" unselectable="on">' + FCKLang.ColorAutomatic + '</td>
- </tr>
- </table>' ;
- oDiv.Command = this ;
- oDiv.onclick = FCKTextColorCommand_AutoOnClick ;
- // Create an array of colors based on the configuration file.
- var aColors = FCKConfig.FontColors.toString().split(',') ;
- // Create the colors table based on the array.
- var iCounter = 0 ;
- while ( iCounter < aColors.length )
- {
- var oRow = oTable.insertRow(-1) ;
- for ( var i = 0 ; i < 8 && iCounter < aColors.length ; i++, iCounter++ )
- {
- var oDiv = oRow.insertCell(-1).appendChild( CreateSelectionDiv() ) ;
- oDiv.Color = aColors[iCounter] ;
- oDiv.innerHTML = '<div class="ColorBoxBorder"><div class="ColorBox" style="background-color: #' + aColors[iCounter] + '"></div></div>' ;
- oDiv.Command = this ;
- oDiv.onclick = FCKTextColorCommand_OnClick ;
- }
- }
- // Create the Row and the Cell for the "More Colors..." button.
- var oCell = oTable.insertRow(-1).insertCell(-1) ;
- oCell.colSpan = 8 ;
- var oDiv = oCell.appendChild( CreateSelectionDiv() ) ;
- oDiv.innerHTML = '<table width="100%" cellpadding="0" cellspacing="0" border="0"><tr><td nowrap align="center">' + FCKLang.ColorMoreColors + '</td></tr></table>' ;
- oDiv.Command = this ;
- oDiv.onclick = FCKTextColorCommand_MoreOnClick ;
- }