Parse and use dependent groups
- Parse #if, #ifdef, etc. for rules to enable fields
This commit is contained in:
parent
838a22de64
commit
f994729999
3 changed files with 214 additions and 68 deletions
|
@ -91,6 +91,8 @@ label {
|
||||||
margin-right: -450px;
|
margin-right: -450px;
|
||||||
text-align: right;
|
text-align: right;
|
||||||
}
|
}
|
||||||
|
label.blocked { color: #AAA; }
|
||||||
|
|
||||||
input[type="text"], select { margin: 0.75em 0 0; }
|
input[type="text"], select { margin: 0.75em 0 0; }
|
||||||
input[type="checkbox"], input[type="radio"], input[type="file"] { margin: 1em 0 0; }
|
input[type="checkbox"], input[type="radio"], input[type="file"] { margin: 1em 0 0; }
|
||||||
input[type="checkbox"].enabler, input[type="radio"].enabler { margin-left: 1em; }
|
input[type="checkbox"].enabler, input[type="radio"].enabler { margin-left: 1em; }
|
||||||
|
@ -308,3 +310,5 @@ a.download-all { margin: 9px 2em 0; color: #449; border-color: #449; }
|
||||||
.disclose { display: none; }
|
.disclose { display: none; }
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*.blocked { display: none; }*/
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
|
|
||||||
<div id="tooltip"></div>
|
<div id="tooltip"></div>
|
||||||
|
|
||||||
<label>Drop Files Here:</label><input type="file" id="file-upload" />
|
<label>Drop Files:</label><input type="file" id="file-upload" />
|
||||||
<label id="tipson"><input type="checkbox" checked /> ?</label>
|
<label id="tipson"><input type="checkbox" checked /> ?</label>
|
||||||
<a href="" class="download-all">Download Zip</a>
|
<a href="" class="download-all">Download Zip</a>
|
||||||
|
|
||||||
|
|
|
@ -142,8 +142,10 @@ window.configuratorApp = (function(){
|
||||||
$tooltip = $('#tooltip'),
|
$tooltip = $('#tooltip'),
|
||||||
$cfg = $('#config_text'), $adv = $('#config_adv_text'),
|
$cfg = $('#config_text'), $adv = $('#config_adv_text'),
|
||||||
$config = $cfg.find('pre'), $config_adv = $adv.find('pre'),
|
$config = $cfg.find('pre'), $config_adv = $adv.find('pre'),
|
||||||
|
define_info = {},
|
||||||
define_list = [[],[]],
|
define_list = [[],[]],
|
||||||
define_section = {},
|
define_section = {},
|
||||||
|
dependentGroups = {},
|
||||||
boards_list = {},
|
boards_list = {},
|
||||||
therms_list = {},
|
therms_list = {},
|
||||||
total_config_lines,
|
total_config_lines,
|
||||||
|
@ -321,7 +323,7 @@ window.configuratorApp = (function(){
|
||||||
/**
|
/**
|
||||||
* Init the thermistors array from the Configuration.h file
|
* Init the thermistors array from the Configuration.h file
|
||||||
*/
|
*/
|
||||||
initThermistorsFromText: function(txt) {
|
initThermistorList: function(txt) {
|
||||||
// Get all the thermistors and save them into an object
|
// Get all the thermistors and save them into an object
|
||||||
var r, s, findDef = new RegExp('(//.*\n)+\\s+(#define[ \\t]+TEMP_SENSOR_0)', 'g');
|
var r, s, findDef = new RegExp('(//.*\n)+\\s+(#define[ \\t]+TEMP_SENSOR_0)', 'g');
|
||||||
r = findDef.exec(txt);
|
r = findDef.exec(txt);
|
||||||
|
@ -334,7 +336,7 @@ window.configuratorApp = (function(){
|
||||||
/**
|
/**
|
||||||
* Get all the unique define names
|
* Get all the unique define names
|
||||||
*/
|
*/
|
||||||
updateDefinesFromText: function(index, txt) {
|
initDefineList: function(index, txt) {
|
||||||
var section = 'hidden',
|
var section = 'hidden',
|
||||||
leave_out_defines = ['CONFIGURATION_H', 'CONFIGURATION_ADV_H'],
|
leave_out_defines = ['CONFIGURATION_H', 'CONFIGURATION_ADV_H'],
|
||||||
define_sect = {},
|
define_sect = {},
|
||||||
|
@ -343,7 +345,7 @@ window.configuratorApp = (function(){
|
||||||
var name = r[2];
|
var name = r[2];
|
||||||
if (r[1] == '@section')
|
if (r[1] == '@section')
|
||||||
section = name;
|
section = name;
|
||||||
else if ($.inArray(name, leave_out_defines) < 0 && !(name in define_sect))
|
else if ($.inArray(name, leave_out_defines) < 0 && !(name in define_section) && !(name in define_sect))
|
||||||
define_sect[name] = section;
|
define_sect[name] = section;
|
||||||
}
|
}
|
||||||
define_list[index] = Object.keys(define_sect);
|
define_list[index] = Object.keys(define_sect);
|
||||||
|
@ -351,22 +353,101 @@ window.configuratorApp = (function(){
|
||||||
this.log(define_list[index], 2);
|
this.log(define_list[index], 2);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get all condition blocks and their line ranges.
|
||||||
|
* Conditions may control multiple line-ranges
|
||||||
|
* across both config files.
|
||||||
|
*/
|
||||||
|
initDependentGroups: function() {
|
||||||
|
var findDef = /^[ \t]*#(ifn?def|if|else|endif)[ \t]*(.*)([ \t]*\/\/[^\n]+)?$/gm,
|
||||||
|
leave_out_defines = ['CONFIGURATION_H', 'CONFIGURATION_ADV_H'];
|
||||||
|
$.each([$config, $config_adv], function(i, $v) {
|
||||||
|
var ifStack = [];
|
||||||
|
var r, txt = $v.text();
|
||||||
|
while((r = findDef.exec(txt)) !== null) {
|
||||||
|
var lineNum = txt.substr(0, r.index).lineCount();
|
||||||
|
var code = r[2].replace(/[ \t]*\/\/.*$/, '');
|
||||||
|
switch(r[1]) {
|
||||||
|
case 'if':
|
||||||
|
var code = code
|
||||||
|
.replace(/([A-Z][A-Z0-9_]+)/g, 'self.defineValue("$1")')
|
||||||
|
.replace(/defined[ \t]*\(?[ \t]*self.defineValue\(("[A-Z][A-Z0-9_]+")\)[ \t]*\)?/g, 'self.defineIsEnabled($1)');
|
||||||
|
ifStack.push(['('+code+')', lineNum]); // #if starts on next line
|
||||||
|
self.log("push if " + code, 4);
|
||||||
|
break;
|
||||||
|
case 'ifdef':
|
||||||
|
if ($.inArray(code, leave_out_defines) < 0) {
|
||||||
|
ifStack.push(['self.defineIsEnabled("' + code + '")', lineNum]);
|
||||||
|
self.log("push ifdef " + code, 4);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ifStack.push(0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'ifndef':
|
||||||
|
if ($.inArray(code, leave_out_defines) < 0) {
|
||||||
|
ifStack.push(['!self.defineIsEnabled("' + code + '")', lineNum]);
|
||||||
|
self.log("push ifndef " + code, 4);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ifStack.push(0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'else':
|
||||||
|
case 'endif':
|
||||||
|
var c = ifStack.pop();
|
||||||
|
if (c) {
|
||||||
|
var cond = c[0], line = c[1];
|
||||||
|
self.log("pop " + c[0], 4);
|
||||||
|
if (dependentGroups[cond] === undefined) dependentGroups[cond] = [];
|
||||||
|
dependentGroups[cond].push({adv:i,start:line,end:lineNum});
|
||||||
|
if (r[1] == 'else') {
|
||||||
|
// Reverse the condition
|
||||||
|
cond = (cond.indexOf('!') === 0) ? cond.substr(1) : ('!'+cond);
|
||||||
|
ifStack.push([cond, lineNum]);
|
||||||
|
self.log("push " + cond, 4);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (r[1] == 'else') ifStack.push(0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}); // text blobs loop
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Init all the defineInfo structures after reload
|
||||||
|
* The "enabled" field may need an update for newly-loaded dependencies
|
||||||
|
*/
|
||||||
|
initDefineInfo: function() {
|
||||||
|
$.each(define_list, function(e,def_list){
|
||||||
|
var adv = e == 1;
|
||||||
|
$.each(def_list, function(i,name) {
|
||||||
|
define_info[name] = self.getDefineInfo(name, adv);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create fields for any defines that have none
|
* Create fields for any defines that have none
|
||||||
*/
|
*/
|
||||||
createFieldsForDefines: function(adv) {
|
createFieldsForDefines: function(e) {
|
||||||
var e = adv ? 1 : 0, n = 0;
|
var n = 0, fail_list = [];
|
||||||
var fail_list = [];
|
|
||||||
$.each(define_list[e], function(i,name) {
|
$.each(define_list[e], function(i,name) {
|
||||||
var section = define_section[name];
|
var section = define_section[name];
|
||||||
if (section != 'hidden' && !$('#'+name).length) {
|
if (section != 'hidden' && !$('#'+name).length) {
|
||||||
var inf = self.getDefineInfo(name, adv);
|
var inf = define_info[name];
|
||||||
|
|
||||||
if (inf) {
|
if (inf) {
|
||||||
|
|
||||||
var $ff = $('#'+section), $newfield,
|
var $ff = $('#'+section), $newfield,
|
||||||
|
avail = eval(inf.enabled),
|
||||||
$newlabel = $('<label>',{for:name,class:'added'}).text(name.toLabel());
|
$newlabel = $('<label>',{for:name,class:'added'}).text(name.toLabel());
|
||||||
|
|
||||||
|
if (!avail) $newlabel.addClass('blocked');
|
||||||
|
|
||||||
// if (!(++n % 3))
|
// if (!(++n % 3))
|
||||||
$newlabel.addClass('newline');
|
$newlabel.addClass('newline');
|
||||||
|
|
||||||
|
@ -376,7 +457,8 @@ window.configuratorApp = (function(){
|
||||||
if (inf.type == 'list') {
|
if (inf.type == 'list') {
|
||||||
for (var i=0; i<inf.size; i++) {
|
for (var i=0; i<inf.size; i++) {
|
||||||
var fieldname = i > 0 ? name+'-'+i : name;
|
var fieldname = i > 0 ? name+'-'+i : name;
|
||||||
$newfield = $('<input>',{type:'text',size:6,maxlength:10,id:fieldname,name:fieldname,class:'subitem added'}).prop({defineInfo:inf});
|
$newfield = $('<input>',{type:'text',size:6,maxlength:10,id:fieldname,name:fieldname,class:'subitem added',disabled:!avail});
|
||||||
|
if (!avail) $newfield.addClass('blocked');
|
||||||
$ff.append($newfield);
|
$ff.append($newfield);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -396,7 +478,8 @@ window.configuratorApp = (function(){
|
||||||
else {
|
else {
|
||||||
$newfield = inf.type == 'switch' ? $('<input>',{type:'checkbox'}) : $('<input>',{type:'text',size:10,maxlength:40});
|
$newfield = inf.type == 'switch' ? $('<input>',{type:'checkbox'}) : $('<input>',{type:'text',size:10,maxlength:40});
|
||||||
}
|
}
|
||||||
$newfield.attr({id:name,name:name,class:'added'}).prop({defineInfo:inf});
|
$newfield.attr({id:name,name:name,class:'added',disabled:!avail});
|
||||||
|
if (!avail) $newfield.addClass('blocked');
|
||||||
// Add the new field to the form
|
// Add the new field to the form
|
||||||
$ff.append($newfield);
|
$ff.append($newfield);
|
||||||
}
|
}
|
||||||
|
@ -442,7 +525,7 @@ window.configuratorApp = (function(){
|
||||||
if (has_boards) {
|
if (has_boards) {
|
||||||
$config.text(txt);
|
$config.text(txt);
|
||||||
total_config_lines = txt.lineCount();
|
total_config_lines = txt.lineCount();
|
||||||
// this.initThermistorsFromText(txt);
|
// this.initThermistorList(txt);
|
||||||
init_index = 0;
|
init_index = 0;
|
||||||
has_config = true;
|
has_config = true;
|
||||||
if (has_config_adv)
|
if (has_config_adv)
|
||||||
|
@ -466,19 +549,24 @@ window.configuratorApp = (function(){
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// When a config file loads defines might change
|
// When a config file loads defines need update
|
||||||
if (init_index != null) {
|
if (init_index != null) {
|
||||||
var adv = init_index == 1;
|
var adv = init_index == 1;
|
||||||
|
// Purge old fields from the form, clear the define list
|
||||||
this.purgeAddedFields(init_index);
|
this.purgeAddedFields(init_index);
|
||||||
this.updateDefinesFromText(init_index, txt);
|
// Build the define_list
|
||||||
|
this.initDefineList(init_index, txt);
|
||||||
// TODO: Find sequential names and group them
|
// TODO: Find sequential names and group them
|
||||||
// Allows related settings to occupy one line in the form
|
// Allows related settings to occupy one line in the form
|
||||||
// this.refreshSequentialDefines();
|
// this.refreshSequentialDefines();
|
||||||
// TODO: Get dependent groups (#ifdef's) from text
|
// Build the dependent defines list
|
||||||
// Allows parent to hide/show or disable/enable dependent fields!
|
this.initDependentGroups(); // all config text
|
||||||
// this.refreshDependentGroups(); // (from all config text)
|
// Get define_info for all known defines
|
||||||
this.createFieldsForDefines(adv);
|
this.initDefineInfo(); // all config text
|
||||||
this.refreshConfigForm(init_index); // TODO: <-- hide dependent fields
|
// Create new fields
|
||||||
|
this.createFieldsForDefines(init_index); // create new fields
|
||||||
|
// Init the fields, set values, etc
|
||||||
|
this.refreshConfigForm(init_index);
|
||||||
this.activateDownloadLink(adv);
|
this.activateDownloadLink(adv);
|
||||||
}
|
}
|
||||||
this.setMessage(err
|
this.setMessage(err
|
||||||
|
@ -595,25 +683,65 @@ window.configuratorApp = (function(){
|
||||||
// Refresh the motherboard menu with new options
|
// Refresh the motherboard menu with new options
|
||||||
$('#MOTHERBOARD').html('').addOptions(boards_list);
|
$('#MOTHERBOARD').html('').addOptions(boards_list);
|
||||||
|
|
||||||
// Init all existing fields, getting define info for any that need it
|
// Init all existing fields, getting define info for those that need it
|
||||||
// refreshing the options and updating their current values
|
// refreshing the options and updating their current values
|
||||||
$.each(define_list[init_index], function() {
|
$.each(define_list[init_index], function() {
|
||||||
if ($('#'+this).length)
|
if ($('#'+this).length) {
|
||||||
self.initField(this,init_index==1);
|
self.initField(this);
|
||||||
|
self.initFieldValue(this);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
self.log(this + " is not on the page yet.", 2);
|
self.log(this + " is not on the page yet.", 2);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Set enabled state based on dependencies
|
||||||
|
// this.enableForDependentConditions();
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enable / disable fields based on condition tests
|
||||||
|
*/
|
||||||
|
refreshDependentFields: function() {
|
||||||
|
// Simplest way is to go through all define_info
|
||||||
|
// and run a test on all fields that have one.
|
||||||
|
//
|
||||||
|
// Each define_info caches its enable test as code.
|
||||||
|
//
|
||||||
|
// The fields that act as switches for these dependencies
|
||||||
|
// are not currently modified, but they will soon be.
|
||||||
|
//
|
||||||
|
// Once all conditions have been gathered into define_info
|
||||||
|
// the conditions can be scraped for define names.
|
||||||
|
//
|
||||||
|
// Those named fields will be given a .change action to
|
||||||
|
// check and update enabled state for the field.
|
||||||
|
//
|
||||||
|
$.each(define_list, function(e,def_list){
|
||||||
|
$.each(def_list, function() {
|
||||||
|
var inf = define_info[this];
|
||||||
|
if (inf && inf.enabled != 'true') {
|
||||||
|
var $elm = $('#'+this), ena = eval(inf.enabled);
|
||||||
|
// Make any switch toggle also
|
||||||
|
$('#'+this+'-switch').attr('disabled', !ena);
|
||||||
|
var alreadyEnabled = inf.type == 'switch' || self.defineIsEnabled(this);
|
||||||
|
$elm.attr('disabled', !(ena && alreadyEnabled));
|
||||||
|
ena ? $elm.removeClass('blocked') : $elm.addClass('blocked');
|
||||||
|
// Dim label for unavailable element
|
||||||
|
var $lbl = $elm.prev('label');
|
||||||
|
if ($lbl.length)
|
||||||
|
ena ? $lbl.removeClass('blocked') : $lbl.addClass('blocked');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the defineInfo for a field on the form
|
* Make the field responsive, add optional tooltip, enabler box
|
||||||
* Make it responsive, add a tooltip
|
|
||||||
*/
|
*/
|
||||||
initField: function(name, adv) {
|
initField: function(name) {
|
||||||
this.log("initField:"+name,4);
|
this.log("initField:"+name,4);
|
||||||
var $elm = $('#'+name), elm = $elm[0], inf = elm.defineInfo;
|
var $elm = $('#'+name), inf = define_info[name];
|
||||||
if (inf == null)
|
$elm[0].defineInfo = inf;
|
||||||
inf = elm.defineInfo = this.getDefineInfo(name, adv);
|
|
||||||
|
|
||||||
// Create a tooltip on the label if there is one
|
// Create a tooltip on the label if there is one
|
||||||
if (inf.tooltip) {
|
if (inf.tooltip) {
|
||||||
|
@ -672,16 +800,16 @@ window.configuratorApp = (function(){
|
||||||
.change(self.handleSwitch)
|
.change(self.handleSwitch)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set the field's initial value from the define
|
|
||||||
this.setFieldFromDefine(name);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle any value field being changed
|
* Handle any value field being changed
|
||||||
* this = the field
|
* this = the field
|
||||||
*/
|
*/
|
||||||
handleChange: function() { self.updateDefineFromField(this.id); },
|
handleChange: function() {
|
||||||
|
self.updateDefineFromField(this.id);
|
||||||
|
self.refreshDependentFields();
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle a switch checkbox being changed
|
* Handle a switch checkbox being changed
|
||||||
|
@ -690,7 +818,7 @@ window.configuratorApp = (function(){
|
||||||
handleSwitch: function() {
|
handleSwitch: function() {
|
||||||
var $elm = $(this),
|
var $elm = $(this),
|
||||||
name = $elm[0].id.replace(/-.+/,''),
|
name = $elm[0].id.replace(/-.+/,''),
|
||||||
inf = $('#'+name)[0].defineInfo,
|
inf = define_info[name],
|
||||||
on = $elm.prop('checked') || false;
|
on = $elm.prop('checked') || false;
|
||||||
|
|
||||||
self.setDefineEnabled(name, on);
|
self.setDefineEnabled(name, on);
|
||||||
|
@ -711,9 +839,10 @@ window.configuratorApp = (function(){
|
||||||
*/
|
*/
|
||||||
defineValue: function(name) {
|
defineValue: function(name) {
|
||||||
this.log('defineValue:'+name,4);
|
this.log('defineValue:'+name,4);
|
||||||
var inf = $('#'+name)[0].defineInfo;
|
var inf = define_info[name];
|
||||||
if (inf == null) return 'n/a';
|
if (inf == null) return 'n/a';
|
||||||
var result = inf.regex.exec($(inf.field).text());
|
// var result = inf.regex.exec($(inf.field).text());
|
||||||
|
var result = inf.regex.exec(inf.line);
|
||||||
|
|
||||||
this.log(result,2);
|
this.log(result,2);
|
||||||
|
|
||||||
|
@ -725,13 +854,14 @@ window.configuratorApp = (function(){
|
||||||
*/
|
*/
|
||||||
defineIsEnabled: function(name) {
|
defineIsEnabled: function(name) {
|
||||||
this.log('defineIsEnabled:'+name,4);
|
this.log('defineIsEnabled:'+name,4);
|
||||||
var inf = $('#'+name)[0].defineInfo;
|
var inf = define_info[name];
|
||||||
if (inf == null) return false;
|
if (inf == null) return false;
|
||||||
var result = inf.regex.exec($(inf.field).text());
|
// var result = inf.regex.exec($(inf.field).text());
|
||||||
|
var result = inf.regex.exec(inf.line);
|
||||||
|
|
||||||
this.log(result,2);
|
this.log(result,2);
|
||||||
|
|
||||||
var on = result !== null ? result[1].trim() != '//' : true;
|
var on = result[1] != null ? result[1].trim() != '//' : true;
|
||||||
this.log(name + ' = ' + on, 2);
|
this.log(name + ' = ' + on, 2);
|
||||||
|
|
||||||
return on;
|
return on;
|
||||||
|
@ -742,7 +872,7 @@ window.configuratorApp = (function(){
|
||||||
*/
|
*/
|
||||||
setDefineEnabled: function(name, val) {
|
setDefineEnabled: function(name, val) {
|
||||||
this.log('setDefineEnabled:'+name,4);
|
this.log('setDefineEnabled:'+name,4);
|
||||||
var inf = $('#'+name)[0].defineInfo;
|
var inf = define_info[name];
|
||||||
if (inf) {
|
if (inf) {
|
||||||
var slash = val ? '' : '//';
|
var slash = val ? '' : '//';
|
||||||
var newline = inf.line
|
var newline = inf.line
|
||||||
|
@ -761,7 +891,7 @@ window.configuratorApp = (function(){
|
||||||
// Drop the suffix on sub-fields
|
// Drop the suffix on sub-fields
|
||||||
name = name.replace(/-\d+$/, '');
|
name = name.replace(/-\d+$/, '');
|
||||||
|
|
||||||
var $elm = $('#'+name), inf = $elm[0].defineInfo;
|
var $elm = $('#'+name), inf = define_info[name];
|
||||||
if (inf == null) return;
|
if (inf == null) return;
|
||||||
|
|
||||||
var isCheck = $elm.attr('type') == 'checkbox',
|
var isCheck = $elm.attr('type') == 'checkbox',
|
||||||
|
@ -797,7 +927,7 @@ window.configuratorApp = (function(){
|
||||||
*/
|
*/
|
||||||
setDefineLine: function(name, newline) {
|
setDefineLine: function(name, newline) {
|
||||||
this.log('setDefineLine:'+name+'\n'+newline,4);
|
this.log('setDefineLine:'+name+'\n'+newline,4);
|
||||||
var inf = $('#'+name)[0].defineInfo;
|
var inf = define_info[name];
|
||||||
var $c = $(inf.field), txt = $c.text();
|
var $c = $(inf.field), txt = $c.text();
|
||||||
|
|
||||||
var hilite_token = '[HIGHLIGHTER-TOKEN]';
|
var hilite_token = '[HIGHLIGHTER-TOKEN]';
|
||||||
|
@ -820,7 +950,7 @@ window.configuratorApp = (function(){
|
||||||
*/
|
*/
|
||||||
scrollToDefine: function(name, always) {
|
scrollToDefine: function(name, always) {
|
||||||
this.log('scrollToDefine:'+name,4);
|
this.log('scrollToDefine:'+name,4);
|
||||||
var inf = $('#'+name)[0].defineInfo, $c = $(inf.field);
|
var inf = define_info[name], $c = $(inf.field);
|
||||||
|
|
||||||
// Scroll to the altered text if it isn't visible
|
// Scroll to the altered text if it isn't visible
|
||||||
var halfHeight = $c.height()/2, scrollHeight = $c.prop('scrollHeight'),
|
var halfHeight = $c.height()/2, scrollHeight = $c.prop('scrollHeight'),
|
||||||
|
@ -836,14 +966,14 @@ window.configuratorApp = (function(){
|
||||||
/**
|
/**
|
||||||
* Set a form field to the current #define value in the config text
|
* Set a form field to the current #define value in the config text
|
||||||
*/
|
*/
|
||||||
setFieldFromDefine: function(name) {
|
initFieldValue: function(name) {
|
||||||
var $elm = $('#'+name), inf = $elm[0].defineInfo,
|
var $elm = $('#'+name), inf = define_info[name],
|
||||||
val = this.defineValue(name);
|
val = this.defineValue(name);
|
||||||
|
|
||||||
this.log('setFieldFromDefine:' + name + ' to ' + val, 2);
|
this.log('initFieldValue:' + name + ' to ' + val, 2);
|
||||||
|
|
||||||
// If the item has a checkbox then set enabled state too
|
// If the item has a checkbox then set enabled state too
|
||||||
var $cb = $('#'+name+'-switch'), on = true;
|
var $cb = $('#'+name+'-switch'), avail = eval(inf.enabled), on = true;
|
||||||
if ($cb.length) {
|
if ($cb.length) {
|
||||||
on = self.defineIsEnabled(name);
|
on = self.defineIsEnabled(name);
|
||||||
$cb.prop('checked', on);
|
$cb.prop('checked', on);
|
||||||
|
@ -854,13 +984,19 @@ window.configuratorApp = (function(){
|
||||||
var $e = i > 0 ? $('#'+name+'-'+i) : $elm;
|
var $e = i > 0 ? $('#'+name+'-'+i) : $elm;
|
||||||
$e.val(v.trim());
|
$e.val(v.trim());
|
||||||
$e.attr('disabled', !on);
|
$e.attr('disabled', !on);
|
||||||
|
avail ? $e.removeClass('blocked') : $e.addClass('blocked');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (inf.type == 'toggle') val = val == inf.options[1];
|
if (inf.type == 'toggle') val = val == inf.options[1];
|
||||||
$elm.attr('type') == 'checkbox' ? $elm.prop('checked', val) : $elm.val(''+val);
|
$elm.attr('type') == 'checkbox' ? $elm.prop('checked', val) : $elm.val(''+val);
|
||||||
$elm.attr('disabled', !on); // enable/disable the form field (could also dim it)
|
$elm.attr('disabled', !on); // enable/disable the form field (could also dim it)
|
||||||
|
avail ? $elm.removeClass('blocked') : $elm.addClass('blocked');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set label color
|
||||||
|
var $lbl = $elm.prev('label');
|
||||||
|
avail ? $lbl.removeClass('blocked') : $lbl.addClass('blocked');
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -873,17 +1009,6 @@ window.configuratorApp = (function(){
|
||||||
define_list[index] = [];
|
define_list[index] = [];
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
|
||||||
* Update #define information for one of the config files
|
|
||||||
*/
|
|
||||||
refreshDefineInfo: function(adv) {
|
|
||||||
if (adv === undefined) adv = false;
|
|
||||||
$('[name]').each(function() {
|
|
||||||
var inf = this.defineInfo;
|
|
||||||
if (inf && adv == inf.adv) this.defineInfo = self.getDefineInfo(this.id, adv);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get information about a #define from configuration file text:
|
* Get information about a #define from configuration file text:
|
||||||
*
|
*
|
||||||
|
@ -909,9 +1034,9 @@ window.configuratorApp = (function(){
|
||||||
val_i: 1,
|
val_i: 1,
|
||||||
type: 'switch',
|
type: 'switch',
|
||||||
line: result[0], // whole line
|
line: result[0], // whole line
|
||||||
pre: result[1] === undefined ? '' : result[1].replace('//',''),
|
pre: result[1] == null ? '' : result[1].replace('//',''),
|
||||||
define: result[2],
|
define: result[2],
|
||||||
post: result[3] === undefined ? '' : result[3]
|
post: result[3] == null ? '' : result[3]
|
||||||
});
|
});
|
||||||
info.regex = new RegExp('([ \\t]*//)?([ \\t]*' + info.define.regEsc() + info.post.regEsc() + ')', 'm');
|
info.regex = new RegExp('([ \\t]*//)?([ \\t]*' + info.define.regEsc() + info.post.regEsc() + ')', 'm');
|
||||||
info.repl = new RegExp('([ \\t]*)(\/\/)?([ \\t]*' + info.define.regEsc() + info.post.regEsc() + ')', 'm');
|
info.repl = new RegExp('([ \\t]*)(\/\/)?([ \\t]*' + info.define.regEsc() + info.post.regEsc() + ')', 'm');
|
||||||
|
@ -924,10 +1049,10 @@ window.configuratorApp = (function(){
|
||||||
$.extend(info, {
|
$.extend(info, {
|
||||||
type: 'list',
|
type: 'list',
|
||||||
line: result[0],
|
line: result[0],
|
||||||
pre: result[1] === undefined ? '' : result[1].replace('//',''),
|
pre: result[1] == null ? '' : result[1].replace('//',''),
|
||||||
define: result[2],
|
define: result[2],
|
||||||
size: result[3].split(',').length,
|
size: result[3].split(',').length,
|
||||||
post: result[4] === undefined ? '' : result[4]
|
post: result[4] == null ? '' : result[4]
|
||||||
});
|
});
|
||||||
info.regex = new RegExp('([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '\{([^\}]*)\}' + info.post.regEsc(), 'm');
|
info.regex = new RegExp('([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '\{([^\}]*)\}' + info.post.regEsc(), 'm');
|
||||||
info.repl = new RegExp('(([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '\{)[^\}]*(\}' + info.post.regEsc() + ')', 'm');
|
info.repl = new RegExp('(([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '\{)[^\}]*(\}' + info.post.regEsc() + ')', 'm');
|
||||||
|
@ -940,9 +1065,9 @@ window.configuratorApp = (function(){
|
||||||
$.extend(info, {
|
$.extend(info, {
|
||||||
type: 'quoted',
|
type: 'quoted',
|
||||||
line: result[0],
|
line: result[0],
|
||||||
pre: result[1] === undefined ? '' : result[1].replace('//',''),
|
pre: result[1] == null ? '' : result[1].replace('//',''),
|
||||||
define: result[2],
|
define: result[2],
|
||||||
post: result[4] === undefined ? '' : result[4]
|
post: result[4] == null ? '' : result[4]
|
||||||
});
|
});
|
||||||
info.regex = new RegExp('([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '"([^"]*)"' + info.post.regEsc(), 'm');
|
info.regex = new RegExp('([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '"([^"]*)"' + info.post.regEsc(), 'm');
|
||||||
info.repl = new RegExp('(([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '")[^"]*("' + info.post.regEsc() + ')', 'm');
|
info.repl = new RegExp('(([ \\t]*//)?[ \\t]*' + info.define.regEsc() + '")[^"]*("' + info.post.regEsc() + ')', 'm');
|
||||||
|
@ -955,9 +1080,9 @@ window.configuratorApp = (function(){
|
||||||
$.extend(info, {
|
$.extend(info, {
|
||||||
type: 'plain',
|
type: 'plain',
|
||||||
line: result[0],
|
line: result[0],
|
||||||
pre: result[1] === undefined ? '' : result[1].replace('//',''),
|
pre: result[1] == null ? '' : result[1].replace('//',''),
|
||||||
define: result[2],
|
define: result[2],
|
||||||
post: result[4] === undefined ? '' : result[4]
|
post: result[4] == null ? '' : result[4]
|
||||||
});
|
});
|
||||||
if (result[3].match(/false|true/)) {
|
if (result[3].match(/false|true/)) {
|
||||||
info.type = 'toggle';
|
info.type = 'toggle';
|
||||||
|
@ -1005,14 +1130,31 @@ window.configuratorApp = (function(){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Add .tooltip and .lineNum properties to the info
|
// Add .tooltip and .lineNum properties to the info
|
||||||
findDef = new RegExp('^'+name); // Strip the name from the tooltip
|
findDef = new RegExp('^'+name); // Strip the name from the tooltip
|
||||||
|
var lineNum = this.getLineNumberOfText(info.line, txt);
|
||||||
|
|
||||||
|
// See if this define is enabled conditionally
|
||||||
|
var enable_cond = '';
|
||||||
|
var adv_index = adv ? 1 : 0;
|
||||||
|
$.each(dependentGroups, function(cond,dat){
|
||||||
|
$.each(dat, function(i,o){
|
||||||
|
if (o.adv == adv_index && lineNum > o.start && lineNum < o.end) {
|
||||||
|
// self.log(name + " is in range " + o.start + "-" + o.end, 2);
|
||||||
|
// if this setting is in a range, conditions are added
|
||||||
|
if (enable_cond != '') enable_cond += ' && ';
|
||||||
|
enable_cond += '(' + cond + ')';
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
$.extend(info, {
|
$.extend(info, {
|
||||||
tooltip: '<strong>'+name+'</strong> '+tooltip.trim().replace(findDef,'').toHTML(),
|
tooltip: '<strong>'+name+'</strong> '+tooltip.trim().replace(findDef,'').toHTML(),
|
||||||
lineNum: this.getLineNumberOfText(info.line, txt),
|
lineNum: lineNum,
|
||||||
switchable: (info.type != 'switch' && info.line.match(/^[ \t]*\/\//)) || false // Disabled? Mark as "switchable"
|
switchable: (info.type != 'switch' && info.line.match(/^[ \t]*\/\//)) || false, // Disabled? Mark as "switchable"
|
||||||
|
enabled: enable_cond ? enable_cond : 'true'
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
info = null;
|
info = null;
|
||||||
|
|
Reference in a new issue