2015-06-25 04:45:21 +00:00
|
|
|
/* jslint node: true */
|
|
|
|
'use strict';
|
|
|
|
|
2015-07-11 22:39:42 +00:00
|
|
|
var MenuModule = require('../core/menu_module.js').MenuModule;
|
|
|
|
var ViewController = require('../core/view_controller.js').ViewController;
|
|
|
|
var ansi = require('../core/ansi_term.js');
|
|
|
|
var theme = require('../core/theme.js');
|
|
|
|
var MultiLineEditTextView = require('../core/multi_line_edit_text_view.js').MultiLineEditTextView;
|
2015-07-16 05:51:00 +00:00
|
|
|
var Message = require('../core/message.js');
|
2015-06-25 04:45:21 +00:00
|
|
|
|
2015-07-11 22:39:42 +00:00
|
|
|
var async = require('async');
|
|
|
|
var assert = require('assert');
|
|
|
|
var _ = require('lodash');
|
2015-06-25 05:09:26 +00:00
|
|
|
|
2015-08-14 20:49:06 +00:00
|
|
|
exports.FullScreenEditorModule = FullScreenEditorModule;
|
|
|
|
|
|
|
|
// :TODO: clean this up:
|
|
|
|
|
2015-06-25 22:33:17 +00:00
|
|
|
exports.getModule = FullScreenEditorModule;
|
2015-06-25 04:45:21 +00:00
|
|
|
|
|
|
|
exports.moduleInfo = {
|
2015-06-25 22:33:17 +00:00
|
|
|
name : 'Full Screen Editor (FSE)',
|
|
|
|
desc : 'A full screen editor/viewer',
|
2015-06-25 04:45:21 +00:00
|
|
|
author : 'NuSkooler',
|
|
|
|
};
|
|
|
|
|
2015-06-25 22:33:17 +00:00
|
|
|
function FullScreenEditorModule(options) {
|
2015-06-25 05:09:26 +00:00
|
|
|
MenuModule.call(this, options);
|
|
|
|
|
2015-06-26 04:34:33 +00:00
|
|
|
var self = this;
|
2015-08-14 20:49:06 +00:00
|
|
|
var config = this.menuConfig.config;
|
2015-07-13 20:58:45 +00:00
|
|
|
|
|
|
|
//
|
2015-08-10 01:32:38 +00:00
|
|
|
// menuConfig.config:
|
|
|
|
// editorType : email | area
|
2015-08-14 20:49:06 +00:00
|
|
|
// editorMode : view | edit | quote (private: editMenu | ... )
|
2015-08-10 01:32:38 +00:00
|
|
|
//
|
2015-08-14 20:49:06 +00:00
|
|
|
// extraArgs:
|
2015-08-20 23:05:02 +00:00
|
|
|
// messageAreaName
|
2015-08-14 20:49:06 +00:00
|
|
|
// messageNumber / messageTotal
|
2015-08-10 01:32:38 +00:00
|
|
|
//
|
2015-08-14 20:49:06 +00:00
|
|
|
//
|
|
|
|
this.editorType = config.editorType;
|
|
|
|
this.editorMode = config.editorMode;
|
2015-08-06 04:22:17 +00:00
|
|
|
|
2015-08-16 19:35:34 +00:00
|
|
|
if(_.isObject(options.extraArgs)) {
|
2015-09-01 05:18:46 +00:00
|
|
|
this.messageAreaName = options.extraArgs.messageAreaName || Message.WellKnownAreaNames.Private;
|
2015-08-16 19:35:34 +00:00
|
|
|
}
|
2015-07-16 05:51:00 +00:00
|
|
|
|
2015-08-20 04:10:18 +00:00
|
|
|
this.isLocalEmail = function() {
|
2015-09-01 05:18:46 +00:00
|
|
|
return 'email' === this.editorType && Message.WellKnownAreaNames.Private === this.messageAreaName;
|
2015-08-20 04:10:18 +00:00
|
|
|
};
|
2015-07-09 04:07:25 +00:00
|
|
|
|
|
|
|
this.getFooterName = function(editorMode) {
|
|
|
|
editorMode = editorMode || this.editorMode;
|
|
|
|
return 'footer' + _.capitalize(editorMode); // e.g.. 'footerEditMenu'
|
|
|
|
};
|
|
|
|
|
2015-07-10 05:23:37 +00:00
|
|
|
this.getFormId = function(name) {
|
2015-07-09 04:07:25 +00:00
|
|
|
return {
|
|
|
|
header : 0,
|
|
|
|
body : 1,
|
|
|
|
footerEdit : 2,
|
|
|
|
footerEditMenu : 3,
|
2015-07-11 22:39:42 +00:00
|
|
|
footerView : 4,
|
|
|
|
|
|
|
|
help : 50,
|
2015-07-10 05:23:37 +00:00
|
|
|
}[name];
|
2015-07-09 04:07:25 +00:00
|
|
|
};
|
|
|
|
|
2015-09-01 05:18:46 +00:00
|
|
|
this.buildMessage = function() {
|
2015-07-13 20:58:45 +00:00
|
|
|
var headerValues = self.viewControllers.header.getFormData().value;
|
2015-07-13 04:56:33 +00:00
|
|
|
|
2015-09-01 05:18:46 +00:00
|
|
|
var msgOpts = {
|
2015-08-20 23:05:02 +00:00
|
|
|
areaName : self.messageAreaName,
|
2015-07-13 20:58:45 +00:00
|
|
|
toUserName : headerValues.to,
|
|
|
|
fromUserName : headerValues.from,
|
|
|
|
subject : headerValues.subject,
|
|
|
|
message : self.viewControllers.body.getFormData().value.message,
|
2015-07-13 04:56:33 +00:00
|
|
|
};
|
|
|
|
|
2015-09-01 05:18:46 +00:00
|
|
|
self.message = new Message(msgOpts);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.setMessage = function(message) {
|
|
|
|
console.log('setting message....')
|
|
|
|
console.log(message)
|
|
|
|
self.message = message;
|
|
|
|
};
|
|
|
|
|
|
|
|
this.getMessage = function() {
|
|
|
|
if('edit' === this.editMode) {
|
|
|
|
self.buildMessage();
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.message;
|
2015-07-13 04:56:33 +00:00
|
|
|
};
|
|
|
|
|
2015-07-09 04:07:25 +00:00
|
|
|
this.redrawFooter = function(options, cb) {
|
|
|
|
async.waterfall(
|
|
|
|
[
|
|
|
|
function moveToFooterPosition(callback) {
|
|
|
|
//
|
|
|
|
// Calculate footer staring position
|
|
|
|
//
|
|
|
|
// row = (header height + body height)
|
|
|
|
//
|
|
|
|
// Header: mciData.body.height
|
|
|
|
// Body : We must find this in the config / theme
|
|
|
|
//
|
2015-07-10 21:24:30 +00:00
|
|
|
// :TODO: don't hard code this -- allow footer height to be part of theme/etc.
|
2015-07-09 04:07:25 +00:00
|
|
|
self.client.term.rawWrite(ansi.goto(23, 1));
|
|
|
|
callback(null);
|
|
|
|
},
|
|
|
|
function clearFooterArea(callback) {
|
|
|
|
if(options.clear) {
|
2015-07-10 21:24:30 +00:00
|
|
|
self.client.term.rawWrite(ansi.reset() + ansi.deleteLine(3));
|
2015-07-09 04:07:25 +00:00
|
|
|
}
|
|
|
|
callback(null);
|
|
|
|
},
|
|
|
|
function displayFooterArt(callback) {
|
|
|
|
var footerArt = self.menuConfig.config.art[options.footerName];
|
|
|
|
|
2015-07-25 22:10:12 +00:00
|
|
|
theme.displayThemedAsset(
|
2015-07-25 00:33:59 +00:00
|
|
|
footerArt,
|
|
|
|
self.client,
|
2015-07-25 22:10:12 +00:00
|
|
|
{ font : self.menuConfig.font },
|
|
|
|
function displayed(err, artData) {
|
2015-07-25 00:33:59 +00:00
|
|
|
callback(err, artData);
|
2015-07-25 22:10:12 +00:00
|
|
|
}
|
|
|
|
);
|
2015-07-09 04:07:25 +00:00
|
|
|
}
|
|
|
|
],
|
|
|
|
function complete(err, artData) {
|
|
|
|
cb(err, artData);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2015-07-11 22:39:42 +00:00
|
|
|
this.redrawScreen = function(options, cb) {
|
|
|
|
var comps = [ 'header', 'body' ];
|
|
|
|
var art = self.menuConfig.config.art;
|
|
|
|
|
|
|
|
self.client.term.rawWrite(ansi.resetScreen());
|
|
|
|
|
|
|
|
async.series(
|
|
|
|
[
|
|
|
|
function displayHeaderAndBody(callback) {
|
|
|
|
async.eachSeries( comps, function dispArt(n, next) {
|
2015-07-25 22:10:12 +00:00
|
|
|
theme.displayThemedAsset(
|
2015-07-25 00:33:59 +00:00
|
|
|
art[n],
|
|
|
|
self.client,
|
2015-07-25 22:10:12 +00:00
|
|
|
{ font : self.menuConfig.font },
|
2015-07-25 00:33:59 +00:00
|
|
|
function displayed(err, artData) {
|
|
|
|
next(err);
|
2015-07-25 22:10:12 +00:00
|
|
|
}
|
|
|
|
);
|
2015-07-11 22:39:42 +00:00
|
|
|
}, function complete(err) {
|
|
|
|
callback(err);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
function displayFooter(callback) {
|
|
|
|
// we have to treat the footer special
|
|
|
|
self.redrawFooter( { clear : false, footerName : self.getFooterName() }, function footerDisplayed(err) {
|
|
|
|
callback(err);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
function refreshViews(callback) {
|
|
|
|
comps.push(self.getFooterName());
|
|
|
|
|
|
|
|
comps.forEach(function artComp(n) {
|
|
|
|
self.viewControllers[n].redrawAll();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
],
|
|
|
|
function complete(err) {
|
|
|
|
cb(err);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2015-07-09 04:07:25 +00:00
|
|
|
this.switchFooter = function(cb) {
|
|
|
|
var footerName = self.getFooterName();
|
|
|
|
|
|
|
|
self.redrawFooter( { footerName : footerName, clear : true }, function artDisplayed(err, artData) {
|
|
|
|
if(err) {
|
|
|
|
cb(err);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var formId = self.getFormId(footerName);
|
|
|
|
|
|
|
|
if(_.isUndefined(self.viewControllers[footerName])) {
|
|
|
|
var menuLoadOpts = {
|
|
|
|
callingMenu : self,
|
|
|
|
formId : formId,
|
|
|
|
mciMap : artData.mciMap
|
|
|
|
};
|
|
|
|
|
|
|
|
self.addViewController(
|
|
|
|
footerName,
|
|
|
|
new ViewController( { client : self.client, formId : formId } )
|
|
|
|
).loadFromMenuConfig(menuLoadOpts, function footerReady(err) {
|
|
|
|
cb(err);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
self.viewControllers[footerName].redrawAll();
|
|
|
|
cb(null);
|
|
|
|
}
|
|
|
|
});
|
2015-07-06 01:05:55 +00:00
|
|
|
};
|
|
|
|
|
2015-06-25 05:09:26 +00:00
|
|
|
this.initSequence = function() {
|
2015-06-26 04:34:33 +00:00
|
|
|
var mciData = { };
|
2015-07-04 18:02:37 +00:00
|
|
|
var art = self.menuConfig.config.art;
|
|
|
|
assert(_.isObject(art));
|
2015-06-26 04:34:33 +00:00
|
|
|
|
2015-07-06 01:05:55 +00:00
|
|
|
async.series(
|
2015-06-25 05:09:26 +00:00
|
|
|
[
|
|
|
|
function beforeDisplayArt(callback) {
|
|
|
|
self.beforeArt();
|
|
|
|
callback(null);
|
|
|
|
},
|
2015-07-09 04:07:25 +00:00
|
|
|
function displayHeaderAndBodyArt(callback) {
|
2015-07-04 18:02:37 +00:00
|
|
|
assert(_.isString(art.header));
|
|
|
|
assert(_.isString(art.body));
|
|
|
|
|
|
|
|
async.eachSeries( [ 'header', 'body' ], function dispArt(n, next) {
|
2015-08-03 00:27:05 +00:00
|
|
|
theme.displayThemedAsset(
|
2015-07-25 00:33:59 +00:00
|
|
|
art[n],
|
|
|
|
self.client,
|
2015-07-25 22:10:12 +00:00
|
|
|
{ font : self.menuConfig.font },
|
2015-07-25 00:33:59 +00:00
|
|
|
function displayed(err, artData) {
|
|
|
|
mciData[n] = artData;
|
|
|
|
next(err);
|
2015-07-25 22:10:12 +00:00
|
|
|
}
|
|
|
|
);
|
2015-07-04 18:02:37 +00:00
|
|
|
}, function complete(err) {
|
|
|
|
callback(err);
|
|
|
|
});
|
|
|
|
},
|
2015-07-09 04:07:25 +00:00
|
|
|
function displayFooter(callback) {
|
|
|
|
var footerName = self.getFooterName();
|
|
|
|
self.redrawFooter( { footerName : footerName }, function artDisplayed(err, artData) {
|
2015-07-06 01:05:55 +00:00
|
|
|
mciData[footerName] = artData;
|
|
|
|
callback(err);
|
|
|
|
});
|
|
|
|
},
|
2015-06-26 04:34:33 +00:00
|
|
|
function afterArtDisplayed(callback) {
|
|
|
|
self.mciReady(mciData);
|
|
|
|
callback(null);
|
|
|
|
}
|
|
|
|
],
|
|
|
|
function complete(err) {
|
2015-09-01 05:18:46 +00:00
|
|
|
if(err) {
|
|
|
|
console.log(err)
|
|
|
|
}
|
2015-06-26 04:34:33 +00:00
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2015-08-16 19:35:34 +00:00
|
|
|
this.createInitialViews = function(mciData, cb) {
|
|
|
|
|
|
|
|
var menuLoadOpts = { callingMenu : self };
|
2015-08-14 20:49:06 +00:00
|
|
|
|
2015-07-04 18:02:37 +00:00
|
|
|
async.series(
|
|
|
|
[
|
|
|
|
function header(callback) {
|
2015-07-09 04:07:25 +00:00
|
|
|
menuLoadOpts.formId = self.getFormId('header');
|
2015-07-04 18:02:37 +00:00
|
|
|
menuLoadOpts.mciMap = mciData.header.mciMap;
|
|
|
|
|
|
|
|
self.addViewController(
|
|
|
|
'header',
|
2015-07-09 04:07:25 +00:00
|
|
|
new ViewController( { client : self.client, formId : menuLoadOpts.formId } )
|
2015-07-04 18:02:37 +00:00
|
|
|
).loadFromMenuConfig(menuLoadOpts, function headerReady(err) {
|
|
|
|
callback(err);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
function body(callback) {
|
2015-07-09 04:07:25 +00:00
|
|
|
menuLoadOpts.formId = self.getFormId('body');
|
2015-07-04 18:02:37 +00:00
|
|
|
menuLoadOpts.mciMap = mciData.body.mciMap;
|
|
|
|
|
|
|
|
self.addViewController(
|
|
|
|
'body',
|
2015-07-09 04:07:25 +00:00
|
|
|
new ViewController( { client : self.client, formId : menuLoadOpts.formId } )
|
2015-07-04 18:02:37 +00:00
|
|
|
).loadFromMenuConfig(menuLoadOpts, function bodyReady(err) {
|
|
|
|
callback(err);
|
|
|
|
});
|
2015-07-06 01:05:55 +00:00
|
|
|
},
|
|
|
|
function footer(callback) {
|
2015-07-09 04:07:25 +00:00
|
|
|
var footerName = self.getFooterName();
|
2015-07-06 01:05:55 +00:00
|
|
|
|
2015-07-09 04:07:25 +00:00
|
|
|
menuLoadOpts.formId = self.getFormId(footerName);
|
2015-07-06 01:05:55 +00:00
|
|
|
menuLoadOpts.mciMap = mciData[footerName].mciMap;
|
|
|
|
|
|
|
|
self.addViewController(
|
|
|
|
footerName,
|
2015-07-09 04:07:25 +00:00
|
|
|
new ViewController( { client : self.client, formId : menuLoadOpts.formId } )
|
2015-07-06 01:05:55 +00:00
|
|
|
).loadFromMenuConfig(menuLoadOpts, function footerReady(err) {
|
|
|
|
callback(err);
|
|
|
|
});
|
2015-08-16 19:35:34 +00:00
|
|
|
},
|
|
|
|
function prepareViewStates(callback) {
|
|
|
|
var header = self.viewControllers.header;
|
|
|
|
var from = header.getView(1);
|
|
|
|
from.acceptsFocus = false;
|
|
|
|
from.setText(self.client.user.username);
|
|
|
|
|
|
|
|
var body = self.viewControllers.body.getView(1);
|
|
|
|
self.updateTextEditMode(body.getTextEditMode());
|
|
|
|
self.updateEditModePosition(body.getEditPosition());
|
|
|
|
|
|
|
|
callback(null);
|
|
|
|
},
|
2015-09-01 05:18:46 +00:00
|
|
|
function loadSuppliedMessage(callback) {
|
|
|
|
if(self.message) {
|
|
|
|
self.initHeaderFromMessage();
|
|
|
|
}
|
|
|
|
callback(null);
|
|
|
|
},
|
2015-08-16 19:35:34 +00:00
|
|
|
function setInitialFocus(callback) {
|
2015-09-01 05:18:46 +00:00
|
|
|
switch(self.editorMode) {
|
|
|
|
case 'edit' :
|
|
|
|
self.switchToHeader();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'view' :
|
|
|
|
self.switchToBody();
|
|
|
|
break;
|
|
|
|
}
|
2015-08-16 19:35:34 +00:00
|
|
|
|
|
|
|
callback(null);
|
2015-07-04 18:02:37 +00:00
|
|
|
}
|
|
|
|
],
|
|
|
|
function complete(err) {
|
2015-08-16 19:35:34 +00:00
|
|
|
cb(err);
|
2015-07-04 18:02:37 +00:00
|
|
|
}
|
2015-08-16 19:35:34 +00:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.mciReadyHandler = function(mciData) {
|
|
|
|
|
|
|
|
self.createInitialViews(mciData, function viewsCreated(err) {
|
2015-08-20 04:10:18 +00:00
|
|
|
self.viewControllers.header.on('leave', function headerViewLeave(view) {
|
|
|
|
|
|
|
|
if(2 === view.id) { // "to" field
|
|
|
|
self.validateToUserName(view.getData(), function result(err) {
|
|
|
|
if(err) {
|
|
|
|
// :TODO: display a error in a %TL area or such
|
|
|
|
view.clearText();
|
|
|
|
self.viewControllers.headers.switchFocus(2);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2015-08-16 19:35:34 +00:00
|
|
|
});
|
2015-07-04 18:02:37 +00:00
|
|
|
};
|
|
|
|
|
2015-07-06 01:05:55 +00:00
|
|
|
this.updateEditModePosition = function(pos) {
|
|
|
|
if('edit' === this.editorMode) {
|
2015-07-09 04:07:25 +00:00
|
|
|
var posView = self.viewControllers.footerEdit.getView(1);
|
2015-07-06 01:05:55 +00:00
|
|
|
if(posView) {
|
2015-07-06 05:16:22 +00:00
|
|
|
self.client.term.rawWrite(ansi.savePos());
|
|
|
|
posView.setText(_.padLeft(String(pos.row + 1), 2, '0') + ',' + _.padLeft(String(pos.col + 1), 2, '0'));
|
|
|
|
self.client.term.rawWrite(ansi.restorePos());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
this.updateTextEditMode = function(mode) {
|
|
|
|
if('edit' === this.editorMode) {
|
2015-07-09 04:07:25 +00:00
|
|
|
var modeView = self.viewControllers.footerEdit.getView(2);
|
2015-07-06 05:16:22 +00:00
|
|
|
if(modeView) {
|
|
|
|
self.client.term.rawWrite(ansi.savePos());
|
|
|
|
modeView.setText('insert' === mode ? 'INS' : 'OVR');
|
|
|
|
self.client.term.rawWrite(ansi.restorePos());
|
2015-07-06 01:05:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-09-01 05:18:46 +00:00
|
|
|
this.initHeaderFromMessage = function() {
|
|
|
|
assert(_.isObject(this.message));
|
|
|
|
|
|
|
|
var fromView = this.viewControllers.header.getView(1); // TL
|
|
|
|
var toView = this.viewControllers.header.getView(2); // ET
|
|
|
|
var subjView = this.viewControllers.header.getView(3); // ET
|
2015-07-11 22:39:42 +00:00
|
|
|
|
2015-09-01 05:18:46 +00:00
|
|
|
fromView.setText(this.message.fromUserName);
|
|
|
|
toView.setText(this.message.toUserName);
|
|
|
|
subjView.setText(this.message.subject);
|
|
|
|
|
2015-07-11 22:39:42 +00:00
|
|
|
};
|
|
|
|
|
2015-07-12 02:12:07 +00:00
|
|
|
this.displayHelp = function() {
|
2015-07-11 22:39:42 +00:00
|
|
|
self.client.term.rawWrite(ansi.resetScreen());
|
|
|
|
|
|
|
|
theme.displayThemeArt( { name : self.menuConfig.config.art.help, client : self.client },
|
2015-07-12 02:12:07 +00:00
|
|
|
function helpDisplayed(err, artData) {
|
2015-07-11 22:39:42 +00:00
|
|
|
self.client.waitForKeyPress(function keyPress(ch, key) {
|
|
|
|
self.redrawScreen();
|
|
|
|
self.viewControllers.footerEditMenu.setFocus(true);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2015-09-01 05:18:46 +00:00
|
|
|
this.observeEditorEvents = function() {
|
2015-07-12 02:12:07 +00:00
|
|
|
var bodyView = self.viewControllers.body.getView(1);
|
2015-07-09 22:28:44 +00:00
|
|
|
|
|
|
|
bodyView.on('edit position', function cursorPosUpdate(pos) {
|
|
|
|
self.updateEditModePosition(pos);
|
|
|
|
});
|
|
|
|
|
|
|
|
bodyView.on('text edit mode', function textEditMode(mode) {
|
|
|
|
self.updateTextEditMode(mode);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2015-09-01 05:18:46 +00:00
|
|
|
this.switchToHeader = function() {
|
|
|
|
self.viewControllers.body.setFocus(false);
|
|
|
|
self.viewControllers.header.switchFocus(2); // to
|
|
|
|
};
|
|
|
|
|
|
|
|
this.switchToBody = function() {
|
|
|
|
self.viewControllers.header.setFocus(false);
|
|
|
|
self.viewControllers.body.switchFocus(1);
|
|
|
|
|
|
|
|
self.observeEditorEvents();
|
|
|
|
};
|
|
|
|
|
2015-06-25 05:12:03 +00:00
|
|
|
|
2015-06-27 21:32:29 +00:00
|
|
|
this.menuMethods = {
|
2015-07-04 18:02:37 +00:00
|
|
|
headerSubmit : function(formData, extraArgs) {
|
2015-09-01 05:18:46 +00:00
|
|
|
self.switchToBody();
|
2015-07-04 18:02:37 +00:00
|
|
|
},
|
2015-07-09 04:49:22 +00:00
|
|
|
editModeEscPressed : function(formData, extraArgs) {
|
|
|
|
self.editorMode = 'edit' === self.editorMode ? 'editMenu' : 'edit';
|
2015-07-10 05:23:37 +00:00
|
|
|
|
2015-07-09 04:07:25 +00:00
|
|
|
self.switchFooter(function next(err) {
|
|
|
|
if(err) {
|
|
|
|
// :TODO:... what now?
|
|
|
|
console.log(err)
|
|
|
|
} else {
|
2015-07-09 04:49:22 +00:00
|
|
|
switch(self.editorMode) {
|
|
|
|
case 'edit' :
|
|
|
|
if(!_.isUndefined(self.viewControllers.footerEditMenu)) {
|
|
|
|
self.viewControllers.footerEditMenu.setFocus(false);
|
|
|
|
}
|
|
|
|
self.viewControllers.body.switchFocus(1);
|
2015-09-01 05:18:46 +00:00
|
|
|
self.observeEditorEvents();
|
2015-07-09 04:49:22 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 'editMenu' :
|
|
|
|
self.viewControllers.body.setFocus(false);
|
|
|
|
self.viewControllers.footerEditMenu.switchFocus(1);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default : throw new Error('Unexpected mode');
|
|
|
|
}
|
|
|
|
|
2015-07-09 04:07:25 +00:00
|
|
|
}
|
|
|
|
});
|
2015-07-09 04:49:22 +00:00
|
|
|
},
|
2015-08-16 19:35:34 +00:00
|
|
|
/*
|
2015-07-12 02:12:07 +00:00
|
|
|
editModeMenuSave : function(formData, extraArgs) {
|
2015-08-10 01:32:38 +00:00
|
|
|
var msg = self.getMessage();
|
|
|
|
console.log(msg);
|
2015-08-16 19:35:34 +00:00
|
|
|
},*/
|
2015-07-12 06:32:31 +00:00
|
|
|
editModeMenuQuote : function(formData, extraArgs) {
|
|
|
|
|
2015-07-12 02:12:07 +00:00
|
|
|
},
|
|
|
|
editModeMenuHelp : function(formData, extraArgs) {
|
|
|
|
self.viewControllers.footerEditMenu.setFocus(false);
|
|
|
|
self.displayHelp();
|
2015-06-27 21:32:29 +00:00
|
|
|
}
|
2015-06-25 05:09:26 +00:00
|
|
|
};
|
2015-09-01 05:18:46 +00:00
|
|
|
|
|
|
|
if(_.isObject(options.extraArgs.message)) {
|
|
|
|
this.setMessage(options.extraArgs.message);
|
|
|
|
}
|
2015-06-25 04:45:21 +00:00
|
|
|
}
|
|
|
|
|
2015-06-25 22:33:17 +00:00
|
|
|
require('util').inherits(FullScreenEditorModule, MenuModule);
|
2015-06-25 05:09:26 +00:00
|
|
|
|
2015-06-25 22:33:17 +00:00
|
|
|
FullScreenEditorModule.prototype.enter = function(client) {
|
|
|
|
FullScreenEditorModule.super_.prototype.enter.call(this, client);
|
2015-06-25 05:09:26 +00:00
|
|
|
};
|
|
|
|
|
2015-06-26 04:34:33 +00:00
|
|
|
FullScreenEditorModule.prototype.mciReady = function(mciData) {
|
2015-08-14 20:49:06 +00:00
|
|
|
this.mciReadyHandler(mciData);
|
|
|
|
//this['mciReadyHandler' + _.capitalize(this.editorType)](mciData);
|
2015-06-26 04:34:33 +00:00
|
|
|
};
|
|
|
|
|
2015-08-20 04:10:18 +00:00
|
|
|
FullScreenEditorModule.prototype.validateToUserName = function(un, cb) {
|
|
|
|
cb(null); // note: to be implemented by sub classes
|
|
|
|
};
|
|
|
|
|