-define(function() {
+define(['libs/jquery', 'libs/ace/ace', 'libs/text!./template.html'], function($, ace, template) {
'use strict';
return function(sandbox) {
- var view = $(sandbox.getTemplate('main')());
-
+ var view = $(template),
+ documentIsDirty = true,
+ documentEditedHere = false,
+ wlxmlDocument;
+
+ view.onShow = function() {
+ if(documentIsDirty) {
+ editor.setValue(wlxmlDocument.toXML());
+ editor.gotoLine(0);
+ documentEditedHere = false;
+
+ documentIsDirty = false;
+ }
+ };
+
+ view.onHide = function() {
+ if(documentEditedHere) {
+ commitDocument();
+ }
+ };
+
+ var commitDocument = function() {
+ documentEditedHere = false;
+ wlxmlDocument.loadXML(editor.getValue());
+ };
+
var editor = ace.edit(view.find('#rng-sourceEditor-editor')[0]),
session = editor.getSession();
- editor.setTheme("ace/theme/chrome");
- session.setMode("ace/mode/xml")
+ session.setMode('ace/mode/xml');
session.setUseWrapMode(true);
- $('textarea', view).on('keyup', function() {
- sandbox.publish('xmlChanged');
- });
-
editor.getSession().on('change', function() {
- sandbox.publish('xmlChanged');
+ documentEditedHere = true;
});
return {
start: function() {
return view;
},
setDocument: function(document) {
- editor.setValue(document.toXML());
- editor.gotoLine(0);
- sandbox.publish('documentSet');
+ wlxmlDocument = document;
+ wlxmlDocument.on('change', function() {
+ documentIsDirty = true;
+ });
+ wlxmlDocument.on('contentSet', function() {
+ documentIsDirty = true;
+ });
+ },
+ changesCommited: function() {
+ return !documentEditedHere;
},
+ commitChanges: commitDocument,
getDocument: function() {
return editor.getValue();
}