Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
53 changes: 49 additions & 4 deletions docs/ssvc-calc/ssvc.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
*/

/* SSVC code for graph building */
const _version = "5.1.7"
const _version = "5.1.8"
const _tool = "Dryad SSVC Calculator "+_version
var showFullTree = false
var diagonal,tree,svg,duration,root
Expand Down Expand Up @@ -667,6 +667,47 @@ function create_short_keys(x,uniq_keys) {
x["key"] = ssvc_short_keys[x.label];
}
}
function schemaTransform(dtnew) {
const dtobj = JSON.parse(JSON.stringify(dtnew));
const dtold = {};
let finalkey;
if('outcome' in dtobj)
finalkey = dtobj.outcome;
if('decision_points' in dtobj) {
dtold['decision_points'] = [];
Object.entries(dtobj['decision_points']).forEach(function([k,dp]) {
dp.decision_type = "simple";
if(k == finalkey)
dp.decision_type = "final";
dp.values.forEach(function(dv) {
dv.label = dv.name;
delete dv.name;
});
dp.options = dp.values;
delete dp.values;
dp.label = dp.name;
delete dp.name;
dtold.decision_points.push(dp);
});
}
if('mapping' in dtobj) {
dtold['decisions_table'] = [];
dtobj.mapping.forEach(function(dvpair) {
const dt = {}
Object.entries(dvpair).forEach(function([k,v]) {
const dp = dtnew.decision_points[k];
const name = dp.name;
for(let i=0; i< dp.values.length; i++) {
if('key' in dp.values[i] && dp.values[i].key == v)
dt[name] = dp.values[i].name;
}
});
dtold['decisions_table'].push(dt);
});
}
return dtold;

}
function parse_json(xraw,paused) {
$('.bcomplex').remove();
$('.graphy').not('#zoomcontrol').show();
Expand All @@ -678,6 +719,9 @@ function parse_json(xraw,paused) {
tm = JSON.parse(xraw)
else
tm = xraw
if(('schemaVersion' in tm) && (tm.schemaVersion == "2.0.0")) {
tm = schemaTransform(tm);
}
if('decision_tree' in tm) {
/* This has a decision_tree and a score - a computed and provision
schemas together*/
Expand Down Expand Up @@ -785,7 +829,6 @@ function parse_json(xraw,paused) {
var duniq_keys = {};
/* unique keys for choices under decision points*/
var ouniq_keys = {};
acolors = [];
lcolors = {};
tm.decision_points.map(x => {
create_short_keys(x,duniq_keys);
Expand Down Expand Up @@ -853,8 +896,10 @@ function parse_json(xraw,paused) {
classes.push(srlabel);
if(("color" in r) && (r.color)) {
lcolors[r.label] = r.color;
} else if(acolors[i]) {
r.color = acolors[i];
} else if(acolors[ir]) {
r.color = acolors[ir];
} else {
r.color = "#fefefe";
}
return h + $("<div>").append($("<strong/>").addClass("decisiontab").
css({color:r.color}).html(r.label))
Expand Down