Index: lams_monitoring/src/java/org/lamsfoundation/lams/monitoring/web/MonitoringController.java =================================================================== diff -u -r0b789ab29e5a14f005e0978cdcad6add8606c83f -r918a4d770ceef452f8dd7f2b91f3061ed83b5d7b --- lams_monitoring/src/java/org/lamsfoundation/lams/monitoring/web/MonitoringController.java (.../MonitoringController.java) (revision 0b789ab29e5a14f005e0978cdcad6add8606c83f) +++ lams_monitoring/src/java/org/lamsfoundation/lams/monitoring/web/MonitoringController.java (.../MonitoringController.java) (revision 918a4d770ceef452f8dd7f2b91f3061ed83b5d7b) @@ -57,6 +57,7 @@ import org.lamsfoundation.lams.learningdesign.ChosenBranchingActivity; import org.lamsfoundation.lams.learningdesign.ComplexActivity; import org.lamsfoundation.lams.learningdesign.ContributionTypes; +import org.lamsfoundation.lams.learningdesign.GateActivity; import org.lamsfoundation.lams.learningdesign.Group; import org.lamsfoundation.lams.learningdesign.GroupingActivity; import org.lamsfoundation.lams.learningdesign.LearningDesign; @@ -1249,6 +1250,10 @@ activityJSON.put("title", activity.getTitle()); activityJSON.put("type", activity.getActivityTypeId()); + if (activity.isGateActivity()) { + activityJSON.put("gateOpen", ((GateActivity) activity).getGateOpen()); + } + Activity parentActivity = activity.getParentActivity(); if (activity.isBranchingActivity()) { BranchingActivity ba = (BranchingActivity) monitoringService.getActivityById(activity.getActivityId()); Index: lams_monitoring/web/css/_monitorLesson_base.scss =================================================================== diff -u -r722ac3dc265cfd2c6b7eb9944083c6e87d09b21e -r918a4d770ceef452f8dd7f2b91f3061ed83b5d7b --- lams_monitoring/web/css/_monitorLesson_base.scss (.../_monitorLesson_base.scss) (revision 722ac3dc265cfd2c6b7eb9944083c6e87d09b21e) +++ lams_monitoring/web/css/_monitorLesson_base.scss (.../_monitorLesson_base.scss) (revision 918a4d770ceef452f8dd7f2b91f3061ed83b5d7b) @@ -316,6 +316,10 @@ overflow: hidden; } +div#sequenceCanvas svg g.gate image { + display: none; +} + img#sequenceCanvasLoading { padding: 5px 0 0 100px; display: none; Index: lams_monitoring/web/includes/javascript/monitorLesson.js =================================================================== diff -u -r63001d8cc2a26f21ee3312bf4c1fb2d2f0e6d623 -r918a4d770ceef452f8dd7f2b91f3061ed83b5d7b --- lams_monitoring/web/includes/javascript/monitorLesson.js (.../monitorLesson.js) (revision 63001d8cc2a26f21ee3312bf4c1fb2d2f0e6d623) +++ lams_monitoring/web/includes/javascript/monitorLesson.js (.../monitorLesson.js) (revision 918a4d770ceef452f8dd7f2b91f3061ed83b5d7b) @@ -33,7 +33,10 @@ lastTapTarget = null, // popup window size popupWidth = 1280, - popupHeight = 720; + popupHeight = 720, + + gateClosedIcon = '', + gateOpenIcon = ''; @@ -1196,11 +1199,11 @@ isOptional = activity.type == 7, isFloating = activity.type == 15; if (isGate) { - activityGroup.attr('class', 'gate'); + activityGroup.addClass('gate'); } else if (isOptional) { - activityGroup.attr('class', 'optional'); + activityGroup.addClass('optional'); } else if (isFloating) { - activityGroup.attr('class', 'floating'); + activityGroup.addClass('floating'); } }); @@ -1213,6 +1216,16 @@ var learnerCount = 0, reloadSVG = false; $.each(response.activities, function(index, activity){ + var activityGroup = $('g[id="' + activity.id + '"]', sequenceCanvas), + isGate = [3,4,5,14].indexOf(activity.type) > -1; + if (isGate) { + if (activity.gateOpen) { + activityGroup.find('image').attr('xlink:href', gateOpenIcon).show() + } else { + activityGroup.find('image').attr('xlink:href', gateClosedIcon).show(); + } + } + // are there any learners in this or any activity? learnerCount += activity.learnerCount; if (response.contributeActivities) {