0byt3m1n1
Path:
/
data
/
applications
/
aps.bak
/
phprojekt
/
6.0.6-0
/
standard
/
htdocs
/
htdocs
/
dojo
/
dijit
/
_editor
/
[
Home
]
File: _Plugin.js
/* Copyright (c) 2004-2010, The Dojo Foundation All Rights Reserved. Available via Academic Free License >= 2.1 OR the modified BSD license. see: http://dojotoolkit.org/license for details */ if(!dojo._hasResource["dijit._editor._Plugin"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code. dojo._hasResource["dijit._editor._Plugin"] = true; dojo.provide("dijit._editor._Plugin"); dojo.require("dijit._Widget"); dojo.require("dijit.form.Button"); dojo.declare("dijit._editor._Plugin", null, { // summary // Base class for a "plugin" to the editor, which is usually // a single button on the Toolbar and some associated code constructor: function(/*Object?*/args, /*DomNode?*/node){ this.params = args || {}; dojo.mixin(this, this.params); this._connects=[]; }, // editor: [const] dijit.Editor // Points to the parent editor editor: null, // iconClassPrefix: [const] String // The CSS class name for the button node is formed from `iconClassPrefix` and `command` iconClassPrefix: "dijitEditorIcon", // button: dijit._Widget? // Pointer to `dijit.form.Button` or other widget (ex: `dijit.form.FilteringSelect`) // that is added to the toolbar to control this plugin. // If not specified, will be created on initialization according to `buttonClass` button: null, // command: String // String like "insertUnorderedList", "outdent", "justifyCenter", etc. that represents an editor command. // Passed to editor.execCommand() if `useDefaultCommand` is true. command: "", // useDefaultCommand: Boolean // If true, this plugin executes by calling Editor.execCommand() with the argument specified in `command`. useDefaultCommand: true, // buttonClass: Widget Class // Class of widget (ex: dijit.form.Button or dijit.form.FilteringSelect) // that is added to the toolbar to control this plugin. // This is used to instantiate the button, unless `button` itself is specified directly. buttonClass: dijit.form.Button, getLabel: function(/*String*/key){ // summary: // Returns the label to use for the button // tags: // private return this.editor.commands[key]; // String }, _initButton: function(){ // summary: // Initialize the button or other widget that will control this plugin. // This code only works for plugins controlling built-in commands in the editor. // tags: // protected extension if(this.command.length){ var label = this.getLabel(this.command), editor = this.editor, className = this.iconClassPrefix+" "+this.iconClassPrefix + this.command.charAt(0).toUpperCase() + this.command.substr(1); if(!this.button){ var props = dojo.mixin({ label: label, dir: editor.dir, lang: editor.lang, showLabel: false, iconClass: className, dropDown: this.dropDown, tabIndex: "-1" }, this.params || {}); this.button = new this.buttonClass(props); } } }, destroy: function(){ // summary: // Destroy this plugin dojo.forEach(this._connects, dojo.disconnect); if(this.dropDown){ this.dropDown.destroyRecursive(); } }, connect: function(o, f, tf){ // summary: // Make a dojo.connect() that is automatically disconnected when this plugin is destroyed. // Similar to `dijit._Widget.connect`. // tags: // protected this._connects.push(dojo.connect(o, f, this, tf)); }, updateState: function(){ // summary: // Change state of the plugin to respond to events in the editor. // description: // This is called on meaningful events in the editor, such as change of selection // or caret position (but not simple typing of alphanumeric keys). It gives the // plugin a chance to update the CSS of its button. // // For example, the "bold" plugin will highlight/unhighlight the bold button depending on whether the // characters next to the caret are bold or not. // // Only makes sense when `useDefaultCommand` is true, as it calls Editor.queryCommandEnabled(`command`). var e = this.editor, c = this.command, checked, enabled; if(!e || !e.isLoaded || !c.length){ return; } if(this.button){ try{ enabled = e.queryCommandEnabled(c); if(this.enabled !== enabled){ this.enabled = enabled; this.button.set('disabled', !enabled); } if(typeof this.button.checked == 'boolean'){ checked = e.queryCommandState(c); if(this.checked !== checked){ this.checked = checked; this.button.set('checked', e.queryCommandState(c)); } } }catch(e){ console.log(e); // FIXME: we shouldn't have debug statements in our code. Log as an error? } } }, setEditor: function(/*dijit.Editor*/ editor){ // summary: // Tell the plugin which Editor it is associated with. // TODO: refactor code to just pass editor to constructor. // FIXME: detach from previous editor!! this.editor = editor; // FIXME: prevent creating this if we don't need to (i.e., editor can't handle our command) this._initButton(); // Processing for buttons that execute by calling editor.execCommand() if(this.button && this.useDefaultCommand){ if(this.editor.queryCommandAvailable(this.command)){ this.connect(this.button, "onClick", dojo.hitch(this.editor, "execCommand", this.command, this.commandArg) ); }else{ // hide button because editor doesn't support command (due to browser limitations) this.button.domNode.style.display = "none"; } } this.connect(this.editor, "onNormalizedDisplayChanged", "updateState"); }, setToolbar: function(/*dijit.Toolbar*/ toolbar){ // summary: // Tell the plugin to add it's controller widget (often a button) // to the toolbar. Does nothing if there is no controller widget. // TODO: refactor code to just pass toolbar to constructor. if(this.button){ toolbar.addChild(this.button); } // console.debug("adding", this.button, "to:", toolbar); } }); }