* Some code cleanup

* Lots of notes/thoughts
This commit is contained in:
Bryan Ashby 2015-04-30 22:29:24 -06:00
parent e8346779da
commit 3f92a7949d
6 changed files with 157 additions and 41 deletions

View File

@ -452,8 +452,18 @@ function display(options, cb) {
parser.on('mci', function mciEncountered(mciInfo) { parser.on('mci', function mciEncountered(mciInfo) {
/*
if('PA' === mciInfo.mci) {
// :TODO: can't do this until this thing is pausable anyway...
options.client.waitForKeyPress(function kp(k) {
console.log('got a key: ' + k);
});
return;
}
*/
// :TODO: ensure generatedId's do not conflict with any |id| // :TODO: ensure generatedId's do not conflict with any |id|
var id = _.isUndefined(mciInfo.id) ? generatedId++ : mciInfo.id; var id = !_.isNumber(mciInfo.id) ? generatedId++ : mciInfo.id;
var mapKey = mciInfo.mci + id; var mapKey = mciInfo.mci + id;
var mapEntry = mciMap[mapKey]; var mapEntry = mciMap[mapKey];
if(mapEntry) { if(mapEntry) {

View File

@ -50,6 +50,13 @@ function MenuModule(options) {
// :TODO: fetch and render via method/generator // :TODO: fetch and render via method/generator
break; break;
case 'inline' :
if(_.isString(assetSpec.asset)) {
// :TODO: think about this more in relation to themes, etc. How can this come
// from a theme (with override from menu.json) ???
}
break;
default : default :
cb(new Error('Unsupported art asset type')); cb(new Error('Unsupported art asset type'));
break; break;

View File

@ -56,13 +56,20 @@ function View(options) {
} }
// :TODO: Don't allow width/height > client.term // :TODO: Don't allow width/height > client.term
if(options.dimens && options.dimens.height) { if(_.isObject(options.dimens)) {
this.dimens.height = options.dimens.height; if(_.isNumber(options.dimens.height)) {
this.dimens.height = options.dimens.height;
}
if(_.isNumber(options.dimens.width)) {
this.dimens.width = options.dimens.width;
}
} else {
options.dimens = { width : 1, height : 1 };
} }
if(options.dimens && options.dimens.width) { options.dimens.width = options.dimens.width || 1;
this.dimens.width = options.dimens.width; options.dimens.height = options.dimens.height || 1;
}
this.ansiSGR = options.ansiSGR || ansi.getSGRFromGraphicRendition( { fg : 39, bg : 49 }, true); this.ansiSGR = options.ansiSGR || ansi.getSGRFromGraphicRendition( { fg : 39, bg : 49 }, true);
this.ansiFocusSGR = options.ansiFocusSGR || this.ansiSGR; this.ansiFocusSGR = options.ansiFocusSGR || this.ansiSGR;

View File

@ -184,24 +184,16 @@ function ViewController(options) {
setViewProp('maxLength'); setViewProp('maxLength');
setViewProp('width', function(v) { view.dimens.width = parseInt(v, 10); }); setViewProp('width', function(v) { view.dimens.width = parseInt(v, 10); });
setViewProp('styleSGR1', function(v) { ['styleSGR1', 'styleSGR2'].forEach(function styleSgr(style) {
if(_.isObject(v)) { setViewProp(style, function(v) {
view.styleSGR1 = ansi.getSGRFromGraphicRendition(v, true); if(_.isObject(v)) {
console.log(view.styleSGR1.substr(1)) view.styleSGR1 = ansi.getSGRFromGraphicRendition(v, true);
} else if(_.isString(v)) { } else if(_.isString(v)) {
view.styleSGR1 = v; view.styleSGR1 = v;
} }
});
}); });
setViewProp('styleSGR2', function(v) {
if(_.isObject(v)) {
view.styleSGR2 = ansi.getSGRFromGraphicRendition(v, true);
} else if(_.isString(v)) {
view.styleSGR2 = v;
}
});
setViewProp('fillChar', function(v) { setViewProp('fillChar', function(v) {
if(_.isNumber(v)) { if(_.isNumber(v)) {
view.fillChar = String.fromCharCode(v); view.fillChar = String.fromCharCode(v);
@ -397,10 +389,14 @@ ViewController.prototype.loadFromPromptConfig = function(options, cb) {
}); });
}, },
function applyViewConfiguration(callback) { function applyViewConfiguration(callback) {
self.applyViewConfig(promptConfig, function configApplied(err, info) { if(_.isObject(promptConfig.mci)) {
initialFocusId = info.initialFocusId; self.applyViewConfig(promptConfig, function configApplied(err, info) {
callback(err); initialFocusId = info.initialFocusId;
}); callback(err);
});
} else {
callback(null);
}
}, },
function prepareFormSubmission(callback) { function prepareFormSubmission(callback) {

View File

@ -19,6 +19,22 @@
NOte that @draw & @art should check theme first. NOte that @draw & @art should check theme first.
@draw:myMethod -> theme/draw.js::myMethod(opts) @draw:myMethod -> theme/draw.js::myMethod(opts)
priority:
@draw:location.js/myMethod -> outside of theme
@draw:myMethod -> checks theme -> local first
-OR- just inside themes for customization...
e.g;
{
"myTheme" {
"views" : {
"VerticalMenuView" : {
"draw" : "@method:location.js/myMethod"
}
}
}
}
} }
} }
*/ */
@ -99,40 +115,64 @@
"form" : { "form" : {
"0" : { "0" : {
"BT12BT13ET1ET10ET2ET3ET4ET5ET6ET7ET8ET9TL11" : { "BT12BT13ET1ET10ET2ET3ET4ET5ET6ET7ET8ET9TL11" : {
//
// :TODO: defaults { width : XX, ... } kinda thing would be nice
// //
// "beforeViewsDraw" : "@method:location.js/myBeforeViewsDraw" -> myBeforeViewsDraw(views) // "beforeViewsDraw" : "@method:location.js/myBeforeViewsDraw" -> myBeforeViewsDraw(views)
"mci" : { "mci" : {
"ET1" : { "ET1" : {
"focus" : true, "focus" : true,
"argName" : "username" "argName" : "username",
"width" : 15,
"maxLength" : "@config:users.usernameMax"
}, },
"ET2" : { "ET2" : {
"argName" : "realName", "width" : 15,
"maxLength" : "@config:users.usernameMax" "argName" : "realName",
"width" : 15,
"maxLength" : 32
},
"ET3" : {
"argName" : "age",
"width" : 3,
"maxLength" : 3
},
"ET4" : {
"argName" : "sex",
"width" : 1,
"maxLength" : 1
},
"ET5" : {
"argName" : "location",
"width" : 15,
"maxLength" : 32
}, },
"ET3" : { "argName" : "age" },
"ET4" : { "argName" : "sex" },
"ET5" : { "argName" : "location" },
"ET6" : { "ET6" : {
"argName" : "affils", "argName" : "affils",
"maxLength" : 30 "width" : 15,
"maxLength" : 32
}, },
"ET7" : { "ET7" : {
"argName" : "email", "argName" : "email",
"width" : 15,
"maxLength" : 255 "maxLength" : 255
}, },
"ET8" : { "ET8" : {
"argName" : "web", "argName" : "web",
"width" : 15,
"maxLength" : 255 "maxLength" : 255
}, },
"ET9" : { "ET9" : {
"argName" : "password", "argName" : "password",
"password" : true "password" : true,
"width" : 15,
"maxLength" : "@config:users.passwordMax"
}, },
"ET10" : { "ET10" : {
"argName" : "passwordConfirm", "argName" : "passwordConfirm",
"password" : true, "password" : true,
"maxLength" : "@config:users.passwordMax" "width" : 15,
"maxLength" : "@config:users.passwordMax"
}, },
"BT12" : { "BT12" : {
"submit" : true, "submit" : true,
@ -170,6 +210,7 @@
}, },
"newUserActive" : { "newUserActive" : {
"art" : "STATS", "art" : "STATS",
"prompt" : "pause",
"options" : { "options" : {
// :TODO: implement MCI codes for this // :TODO: implement MCI codes for this
"cls" : true "cls" : true
@ -266,8 +307,9 @@
"items" : [ "Razor 1911", "DrinkOrDie", "TRSI" ] "items" : [ "Razor 1911", "DrinkOrDie", "TRSI" ]
}, },
"TM3" : { "TM3" : {
"items" : [ "Yarly", "Nowaii" ], "items" : [ "Yarly", "Nowaii" ],
"styleSGR1" : { "fg" : 30, "intensity" : 1 } "styleSGR1" : { "fg" : 30, "intensity" : 1 },
"hotkeys" : { "Y" : 0, "N" : 1 }
}, },
"BT8" : { "BT8" : {
"text" : "< Back", "text" : "< Back",

View File

@ -11,5 +11,59 @@
"password" : true "password" : true
} }
} }
},
"pause" : {
"art" : "pause"
/*
"mci" : {
// :TODO: Need special pause for a key MCI
// e.g. %PA -> themed prompt
}
...or maybe pause should just be special:
{
...
"pause" true
// uses theme pause which can be art/inline/etc.
}
... better, a special prompt
GetKeyView
* showKey : false
*/
},
"standard" : {
"pause" : {
"art" : "pause"
}
},
"custom" : {
} }
/*
see notes in menu_module.js also
...how to allow for this to come from the theme first???
same as custom vc drawing/etc.? ...
{
"theme" : {
"inlineArt" : {
"something" : "%MC and |01Pipe codes here"
}
}
}
"pause" : {
"art" : "@inline:simplePrompt",
// support pipe codes & MCI
"simplePrompt" : "--------/ Pause /----------------",
"mci" : {
}
}
*/
} }