//>>built define("dojox/editor/plugins/Save", [ "dojo", "dijit", "dojox", "dijit/form/Button", "dijit/_editor/_Plugin", "dojo/_base/connect", "dojo/_base/declare", "dojo/i18n", "dojo/i18n!dojox/editor/plugins/nls/Save" ], function(dojo, dijit, dojox) { dojo.declare("dojox.editor.plugins.Save",dijit._editor._Plugin,{ // summary: // This plugin provides Save cabability to the editor. When // clicked, the document in the editor frame will be osted to the URL // provided, or none, if none provided. Users who desire a different save // function can extend this plugin (via dojo.extend) and over-ride the // save method while save is in process, the save button is disabled. // iconClassPrefix: [const] String // The CSS class name for the button node is formed from `iconClassPrefix` // and `command` iconClassPrefix: "dijitAdditionalEditorIcon", // url [public] String // The URL to POST the content back to. Used by the save function. url: "", // logErrors [public] boolean // Boolean flag to indicate that the default action for save and // error handlers is to just log to console. Default is true. logResults: true, _initButton: function(){ // summary: // Over-ride for creation of the save button. var strings = dojo.i18n.getLocalization("dojox.editor.plugins", "Save"); this.button = new dijit.form.Button({ label: strings["save"], showLabel: false, iconClass: this.iconClassPrefix + " " + this.iconClassPrefix + "Save", tabIndex: "-1", onClick: dojo.hitch(this, "_save") }); }, updateState: function(){ // summary: // Over-ride for button state control for disabled to work. this.button.set("disabled", this.get("disabled")); }, setEditor: function(editor){ // summary: // Over-ride for the setting of the editor. // editor: Object // The editor to configure for this plugin to use. this.editor = editor; this._initButton(); }, _save: function(){ // summary: // Function to trigger saving of the editor document // tags: // private var content = this.editor.get("value"); this.save(content); }, save: function(content){ // summary: // User over-ridable save function for the editor content. // Please note that the service URL provided should do content // filtering of the posted content to avoid XSS injection via // the data from the editor. // tags: // public // Set the default header to post as a body of text/html. var headers = { "Content-Type": "text/html" }; if(this.url){ var postArgs = { url: this.url, postData: content, headers: headers, handleAs: "text" }; this.button.set("disabled", true); var deferred = dojo.xhrPost(postArgs); deferred.addCallback(dojo.hitch(this, this.onSuccess)); deferred.addErrback(dojo.hitch(this, this.onError)); }else{ console.log("No URL provided, no post-back of content: " + content); } }, onSuccess: function(resp, ioargs){ // summary: // User over-ridable save success function for editor content. // Be sure to call this.inherited(arguments) if over-riding this method. // resp: // The response from the server, if any, in text format. // tags: // public this.button.set("disabled", false); if(this.logResults){ console.log(resp); } }, onError: function(error, ioargs){ // summary: // User over-ridable save success function for editor content. // Be sure to call this.inherited(arguments) if over-riding this method. // resp: // The response from the server, if any, in text format. // tags: // public this.button.set("disabled", false); if(this.logResults){ console.log(error); } } }); // Register this plugin. dojo.subscribe(dijit._scopeName + ".Editor.getPlugin",null,function(o){ if(o.plugin){ return; } var name = o.args.name.toLowerCase(); if(name === "save"){ o.plugin = new dojox.editor.plugins.Save({ url: ("url" in o.args)?o.args.url:"", logResults: ("logResults" in o.args)?o.args.logResults:true }); } }); return dojox.editor.plugins.Save; });