123 lines
3.1 KiB
JavaScript
123 lines
3.1 KiB
JavaScript
/* jslint node: true */
|
|
'use strict';
|
|
|
|
var MenuModule = require('../core/menu_module.js').MenuModule;
|
|
var ViewController = require('../core/view_controller.js').ViewController;
|
|
|
|
var async = require('async');
|
|
var assert = require('assert');
|
|
var _ = require('lodash');
|
|
|
|
exports.getModule = FullScreenEditorModule;
|
|
|
|
exports.moduleInfo = {
|
|
name : 'Full Screen Editor (FSE)',
|
|
desc : 'A full screen editor/viewer',
|
|
author : 'NuSkooler',
|
|
};
|
|
|
|
function FullScreenEditorModule(options) {
|
|
MenuModule.call(this, options);
|
|
|
|
var self = this;
|
|
this.menuConfig = options.menuConfig;
|
|
this.editorType = this.menuConfig.config.editorType;
|
|
|
|
this.initSequence = function() {
|
|
var mciData = { };
|
|
|
|
async.waterfall(
|
|
[
|
|
function beforeDisplayArt(callback) {
|
|
self.beforeArt();
|
|
callback(null);
|
|
},
|
|
function displayMainArt(callback) {
|
|
if(_.isString(self.menuConfig.art)) {
|
|
self.displayArtAsset(self.menuConfig.art, function frameDisplayed(err, artData) {
|
|
mciData.main = artData;
|
|
callback(err);
|
|
});
|
|
} else {
|
|
callback(null); // :TODO: should probably throw error... can't do much without this
|
|
}
|
|
},
|
|
function afterArtDisplayed(callback) {
|
|
self.mciReady(mciData);
|
|
callback(null);
|
|
}
|
|
],
|
|
function complete(err) {
|
|
|
|
}
|
|
);
|
|
};
|
|
|
|
this.mciReadyHandlerNetMail = function(mciData) {
|
|
var vc = self.addViewController('main', new ViewController( { client : self.client } ));
|
|
|
|
// :TODO: This can probably come from the normal mci configuration...
|
|
// additional mci stuff could be in config{} block. This should all be easily user-defined
|
|
var mciConfig = {
|
|
ET1 : {
|
|
width : 20,
|
|
text : 'Hello, World'
|
|
},
|
|
ET2 : {
|
|
width : 10,
|
|
text : 'This is a longer string',
|
|
},
|
|
MT3 : {
|
|
width : 79,
|
|
height : 17,
|
|
focus : true,
|
|
text : 'Ermergerd!\nHuzzah!'
|
|
}
|
|
|
|
};
|
|
|
|
var initialFocusedId = 3; // editor
|
|
|
|
async.waterfall(
|
|
[
|
|
function createViews(callback) {
|
|
vc.createViewsFromMCI(mciData.main.mciMap, function viewsCreated(err) {
|
|
callback(err);
|
|
});
|
|
},
|
|
function applyThemeCustomization(callback) {
|
|
console.log('applyThemeCustomization...')
|
|
// :TODO: menuUtil.applyThemeCustomization() ...
|
|
// this should update local hard coded mci stuff for example to change colors, widths, blah blah
|
|
callback(null);
|
|
},
|
|
function applyViewConfiguration(callback) {
|
|
console.log('applyViewConfiguration...')
|
|
|
|
vc.applyViewConfig( { mci : mciConfig }, function configApplied(err, info) {
|
|
callback(err);
|
|
});
|
|
},
|
|
function drawAllViews(callback) {
|
|
vc.redrawAll(initialFocusedId);
|
|
callback(null);
|
|
},
|
|
function setInitialFocus(callback) {
|
|
vc.switchFocus(initialFocusedId); // editor
|
|
}
|
|
]
|
|
);
|
|
};
|
|
}
|
|
|
|
require('util').inherits(FullScreenEditorModule, MenuModule);
|
|
|
|
FullScreenEditorModule.prototype.enter = function(client) {
|
|
FullScreenEditorModule.super_.prototype.enter.call(this, client);
|
|
};
|
|
|
|
FullScreenEditorModule.prototype.mciReady = function(mciData) {
|
|
this['mciReadyHandler' + _.capitalize(this.editorType)](mciData);
|
|
};
|
|
|