Index: lams_central/web/images/gateClosed.png =================================================================== diff -u Binary files differ Index: lams_central/web/images/grouping.png =================================================================== diff -u -r7475d08afc280b5e2e5ddf04e8bf35e3166aaf80 -r40c0555670eae84b4e4f27c79fb96ba95e87edbe Binary files differ Index: lams_central/web/images/svg/branchingEnd.svg =================================================================== diff -u --- lams_central/web/images/svg/branchingEnd.svg (revision 0) +++ lams_central/web/images/svg/branchingEnd.svg (revision 40c0555670eae84b4e4f27c79fb96ba95e87edbe) @@ -0,0 +1,58 @@ + +image/svg+xml + + + + + + + + + + + Index: lams_central/web/images/svg/branchingStart.svg =================================================================== diff -u --- lams_central/web/images/svg/branchingStart.svg (revision 0) +++ lams_central/web/images/svg/branchingStart.svg (revision 40c0555670eae84b4e4f27c79fb96ba95e87edbe) @@ -0,0 +1,58 @@ + +image/svg+xml + + + + + + + + + + + Index: lams_central/web/images/svg/gateClosed.svg =================================================================== diff -u --- lams_central/web/images/svg/gateClosed.svg (revision 0) +++ lams_central/web/images/svg/gateClosed.svg (revision 40c0555670eae84b4e4f27c79fb96ba95e87edbe) @@ -0,0 +1,81 @@ + +image/svg+xml + + + + + + + + + + + + + + + + + Index: lams_central/web/images/svg/grouping.svg =================================================================== diff -u --- lams_central/web/images/svg/grouping.svg (revision 0) +++ lams_central/web/images/svg/grouping.svg (revision 40c0555670eae84b4e4f27c79fb96ba95e87edbe) @@ -0,0 +1,107 @@ + +image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + Index: lams_central/web/includes/javascript/authoring/authoringActivity.js =================================================================== diff -u -r59477db6d18e2d0fe4632bc4690f1bbd93fdca6a -r40c0555670eae84b4e4f27c79fb96ba95e87edbe --- lams_central/web/includes/javascript/authoring/authoringActivity.js (.../authoringActivity.js) (revision 59477db6d18e2d0fe4632bc4690f1bbd93fdca6a) +++ lams_central/web/includes/javascript/authoring/authoringActivity.js (.../authoringActivity.js) (revision 40c0555670eae84b4e4f27c79fb96ba95e87edbe) @@ -3,17 +3,6 @@ */ /** - * Stores different Activity types structures. - */ -var ActivityIcons = { - 'grouping' : '', - 'gateClosed' : '', - 'branchingStart' : '', - 'branchingEnd' : '', - 'bin' : '', -}, - -/** * For colouring. See LDEV-5058 * CATEGORY_SYSTEM = 1; CATEGORY_COLLABORATION = 2; @@ -360,8 +349,14 @@ // create activity SVG elements var shape = paper.circle(x, y, 20) .addClass('svg-branching svg-branching-' + (this.isStart ? 'start' : 'end')), - icon = paper.image(this.isStart ? ActivityIcons.branchingStart : ActivityIcons.branchingEnd, x - 15, y - 15, 30, 30); - + icon = ActivityLib.getActivityIcon(this.isStart ? 'branchingStart' : 'branchingEnd'); + icon.select('svg').attr({ + 'x' : x - 15, + 'y' : y - 15, + 'width' : '30px', + 'height': '30px' + }); + this.items = paper.g(shape, icon); if (this.readOnly && !isReadOnlyMode) { this.items.attr('filter', layout.conf.readOnlyFilter); @@ -444,7 +439,13 @@ y = GeneralLib.snapToGrid(y) - layout.snapToGrid.offset * 2; // create activity SVG elements - var shape = paper.image(ActivityIcons.gateClosed, x, y, 40, 40); + var shape = ActivityLib.getActivityIcon('gateClosed'); + shape.select('svg').attr({ + 'x' : x, + 'y' : y, + 'width' : '40px', + 'height': '40px' + }); this.items = paper.g(shape); if (this.readOnly && !isReadOnlyMode) { @@ -488,17 +489,22 @@ shapeBorder = paper.path(shapePath) .addClass('svg-tool-activity-border' + (this.requireGrouping ? '-require-grouping' : '')), // check for icon in the library - icon = paper.image(ActivityIcons.grouping, x + 20, y + 3, 30, 30), + icon = ActivityLib.getActivityIcon('grouping'), label = paper.text(x + 55, y + 25, ActivityLib.shortenActivityTitle(this.title)) .attr(layout.defaultTextAttributes) .attr({ 'id' : 'toolActivityTitle', 'fill' : layout.colors.activityText, 'text-anchor' : 'start' }); + icon.select('svg').attr({ + 'x' : x + 20, + 'y' : y + 3, + 'width' : '30px', + 'height': '30px' + }); this.items = paper.g(shape, shapeBorder, label, icon); - if (this.readOnly && !isReadOnlyMode) { this.items.attr('filter', layout.conf.readOnlyFilter); } @@ -654,46 +660,28 @@ .addClass('svg-tool-activity-background'), shapeBorder = paper.path(shapePath) .addClass('svg-tool-activity-border' + (this.requireGrouping ? '-require-grouping' : '')), - learningLibraryID = this.learningLibraryID, label = paper.text(x + 55, y + 23, ActivityLib.shortenActivityTitle(this.title)) .attr(layout.defaultTextAttributes) .attr({ 'id' : 'toolActivityTitle', 'fill' : layout.colors.activityText, 'text-anchor' : 'start' - }); + }), + icon = ActivityLib.getActivityIcon(this.learningLibraryID); bannerPath += ' h ' + bannerWidth + ' v ' + height + ' z'; var banner = paper.path(bannerPath) - .addClass('svg-tool-activity-category-' + layout.toolMetadata[learningLibraryID].activityCategoryID); + .addClass('svg-tool-activity-category-' + layout.toolMetadata[this.learningLibraryID].activityCategoryID); this.items = paper.g(shape, banner, shapeBorder, label); - // check for icon SVG cache in the library - var iconData = layout.toolMetadata[learningLibraryID].iconData; - if (!iconData) { - // if SVG is not cached, get it synchronously - $.ajax({ - url : LAMS_URL + layout.toolMetadata[learningLibraryID].iconPath, - async : false, - dataType : 'text', - success : function(response) { - iconData = response; - layout.toolMetadata[learningLibraryID].iconData = iconData; - } - }); - } - - if (iconData) { - // build a SVG fragment and position it - var fragment = Snap.parse(iconData), - icon = Snap(fragment.node); + if (icon) { icon.select('svg').attr({ 'x' : x + 20, 'y' : y + 3, 'width' : '30px', 'height': '30px' }); - this.items.add(icon); + this.items.add(icon); } if (this.readOnly && !isReadOnlyMode) { @@ -1237,7 +1225,13 @@ GeneralLib.setModified(true); return transition; }, - + + adjustTransitionPoint : function(bottomLimit, topLimit, target) { + // find a good point inside the grid, then make sure it is within bounds + return Math.max(bottomLimit + layout.transition.adjustStep, Math.min(topLimit - layout.transition.adjustStep, + Math.floor(target / layout.transition.adjustStep) * layout.transition.adjustStep + layout.snapToGrid.offset)); + }, + /** * It is run from authoringConfirm.jsp * It closes the dialog with activity authoring @@ -1361,13 +1355,6 @@ return nestedBranching; }, - adjustTransitionPoint : function(bottomLimit, topLimit, target) { - // find a good point inside the grid, then make sure it is within bounds - return Math.max(bottomLimit + layout.transition.adjustStep, Math.min(topLimit - layout.transition.adjustStep, - Math.floor(target / layout.transition.adjustStep) * layout.transition.adjustStep + layout.snapToGrid.offset)); - }, - - /** * Calculates start, middle and end points of a line between two activities. */ @@ -1439,7 +1426,33 @@ return points; }, + getActivityIcon(activityName) { + // check for icon SVG cache in the library + var iconData = layout.toolMetadata[activityName].iconData; + if (!iconData) { + if (!layout.toolMetadata[activityName].iconPath) { + return; + } + // if SVG is not cached, get it synchronously + $.ajax({ + url : LAMS_URL + layout.toolMetadata[activityName].iconPath, + async : false, + dataType : 'text', + success : function(response) { + iconData = response; + layout.toolMetadata[activityName].iconData = iconData; + } + }); + } + + if (iconData) { + // build a SVG fragment + var fragment = Snap.parse(iconData); + return Snap(fragment.node); + } + }, + /** * Finds activity/region this shape is bound with. */ Index: lams_central/web/includes/javascript/authoring/authoringGeneral.js =================================================================== diff -u -rb05b0b354e28315a7b8e49813399ec4fe4a3d93d -r40c0555670eae84b4e4f27c79fb96ba95e87edbe --- lams_central/web/includes/javascript/authoring/authoringGeneral.js (.../authoringGeneral.js) (revision b05b0b354e28315a7b8e49813399ec4fe4a3d93d) +++ lams_central/web/includes/javascript/authoring/authoringGeneral.js (.../authoringGeneral.js) (revision 40c0555670eae84b4e4f27c79fb96ba95e87edbe) @@ -34,6 +34,23 @@ 'dialogs' : [], // for storing icons and other activity metadata 'toolMetadata': { + 'grouping' : { + 'iconPath' : 'images/svg/grouping.svg', + 'cursorPath' : 'images/grouping.png' + }, + 'gateClosed' : { + 'iconPath' : 'images/svg/gateClosed.svg', + 'cursorPath' : 'images/gateClosed.png' + }, + 'branchingStart' : { + 'iconPath' : 'images/svg/branchingStart.svg' + }, + 'branchingEnd' : { + 'iconPath' : 'images/svg/branchingEnd.svg' + }, + 'bin' : { + 'iconData' : '', + }, }, // graphics constants @@ -193,10 +210,6 @@ }); } - // assign icons' data uris to their learning library IDs instead of labels - ActivityIcons[learningLibraryID] = ActivityIcons[learningLibraryTitle]; - delete ActivityIcons[learningLibraryTitle]; - // register tool properties so they are later easily accessible layout.toolMetadata[learningLibraryID] = { 'iconPath' : $(this).attr('iconPath'), @@ -2936,7 +2949,7 @@ } // draw rubbish bin on canvas - layout.bin = paper.image(ActivityIcons.bin, width - 55, height - 55, 48, 48); + layout.bin = paper.image(layout.toolMetadata.bin.iconData, width - 55, height - 55, 48, 48); // so it can be found when SVG code gets cloned $(layout.bin.node).attr('id', 'rubbishBin'); Index: lams_central/web/includes/javascript/authoring/authoringMenu.js =================================================================== diff -u -r0d7fac3715a6bdbcfbef426db338fd1cd68d3652 -r40c0555670eae84b4e4f27c79fb96ba95e87edbe --- lams_central/web/includes/javascript/authoring/authoringMenu.js (.../authoringMenu.js) (revision 0d7fac3715a6bdbcfbef426db338fd1cd68d3652) +++ lams_central/web/includes/javascript/authoring/authoringMenu.js (.../authoringMenu.js) (revision 40c0555670eae84b4e4f27c79fb96ba95e87edbe) @@ -123,7 +123,7 @@ addGate : function() { HandlerLib.resetCanvasMode(); - canvas.css('cursor', 'url("' + ActivityIcons.gateClosed + '"), move').click(function(event){ + canvas.css('cursor', 'url("' + LAMS_URL + layout.toolMetadata.gateClosed.cursorPath + '"), move').click(function(event){ // pageX and pageY tell event coordinates relative to the whole page // we need relative to canvas var translatedEvent = GeneralLib.translateEventOnCanvas(event), @@ -150,7 +150,7 @@ layout.isGroupingStarted = true; HandlerLib.resetCanvasMode(); - canvas.css('cursor', 'url("' + ActivityIcons.grouping + '"), move') + canvas.css('cursor', 'url("' + LAMS_URL + layout.toolMetadata.grouping.cursorPath + '"), move') .click(function(event){ layout.isGroupingStarted = false; // pageX and pageY tell event coordinates relative to the whole page