intial layin of lesson menu
This commit is contained in:
		| @ -2,10 +2,10 @@ define(['jquery', | |||||||
| 	'underscore', | 	'underscore', | ||||||
| 	'backbone', | 	'backbone', | ||||||
| 	'goatApp/model/MenuItemModel'],  | 	'goatApp/model/MenuItemModel'],  | ||||||
| 	function($,_,Backbone,MenuItemModel) { | 	function($,_,Backbone,MenuModel) { | ||||||
| 
 | 
 | ||||||
| 	return Backbone.Collection.extend({ | 	return Backbone.Collection.extend({ | ||||||
| 		model: MenuItemModel, | 		model: MenuModel, | ||||||
| 		url:'service/lessonmenu.mvc', | 		url:'service/lessonmenu.mvc', | ||||||
| 		initialize: function () { | 		initialize: function () { | ||||||
| 			var self = this; | 			var self = this; | ||||||
							
								
								
									
										175
									
								
								src/main/webapp/js/goatApp/support/GoatUtils.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								src/main/webapp/js/goatApp/support/GoatUtils.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,175 @@ | |||||||
|  | define(['jquery', | ||||||
|  |     'underscore', | ||||||
|  |     'backbone'],  | ||||||
|  |     function($, | ||||||
|  |         _, | ||||||
|  |         Backbone) { | ||||||
|  |             var goatUtils = { | ||||||
|  |                 makeId: function(lessonName) { | ||||||
|  |                     //var id = | ||||||
|  |                     return  lessonName.replace(/\s|\(|\)|\!|\:|\;|\@|\#|\$|\%|\^|\&|\*/g, ''); | ||||||
|  |                 }, | ||||||
|  |                 addMenuClasses: function(arr) { | ||||||
|  |                     for (var i = 0; i < arr.length; i++) { | ||||||
|  |                         var menuItem = arr[i]; | ||||||
|  |                         //console.log(menuItem); | ||||||
|  |                         if (menuItem.type && menuItem.type === 'CATEGORY') { | ||||||
|  |                             menuItem.class = 'fa-angle-right pull-right'; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     return arr; | ||||||
|  |                 }, | ||||||
|  | //                debugFormSubmission: false, | ||||||
|  |                 // pre-submit callback  | ||||||
|  |                 showRequest: function(formData, jqForm, options) { | ||||||
|  |                     if (goat.utils.debugFormSubmission) { | ||||||
|  |                         // formData is an array; here we use $.param to convert it to a string to display it  | ||||||
|  |                         // but the form plugin does this for you automatically when it submits the data  | ||||||
|  |                         var queryString = $.param(formData); | ||||||
|  |  | ||||||
|  |                         // jqForm is a jQuery object encapsulating the form element.  To access the  | ||||||
|  |                         // DOM element for the form do this:  | ||||||
|  |                         // var formElement = jqForm[0];  | ||||||
|  |  | ||||||
|  |                         alert('About to submit: \n\n' + queryString); | ||||||
|  |                     } | ||||||
|  |                     // here we could return false to prevent the form from being submitted;  | ||||||
|  |                     // returning anything other than false will allow the form submit to continue  | ||||||
|  |                     return true; | ||||||
|  |                 }, | ||||||
|  |                 // post-submit callback  | ||||||
|  |                 showResponse: function(responseText, statusText, xhr, $form) { | ||||||
|  |                     // for normal html responses, the first argument to the success callback  | ||||||
|  |                     // is the XMLHttpRequest object's responseText property  | ||||||
|  |  | ||||||
|  |                     // if the ajaxForm method was passed an Options Object with the dataType  | ||||||
|  |                     // property set to 'xml' then the first argument to the success callback  | ||||||
|  |                     // is the XMLHttpRequest object's responseXML property  | ||||||
|  |  | ||||||
|  |                     // if the ajaxForm method was passed an Options Object with the dataType  | ||||||
|  |                     // property set to 'json' then the first argument to the success callback  | ||||||
|  |                     // is the json data object returned by the server  | ||||||
|  |                     if (goat.utils.debugFormSubmission) { | ||||||
|  |                         alert('status: ' + statusText + '\n\nresponseText: \n' + responseText + | ||||||
|  |                                 '\n\nThe output div should have already been updated with the responseText.'); | ||||||
|  |                     } | ||||||
|  |                     // update lesson cookies and params | ||||||
|  |                     // make any embedded forms ajaxy | ||||||
|  |                     goat.utils.showLessonCookiesAndParams(); | ||||||
|  |                     // forms and links are now hooked with each standard lesson render (see Java class Screen.getContent()) | ||||||
|  |                     // but these are safe to call twice | ||||||
|  |                     goat.utils.makeFormsAjax(); | ||||||
|  |                     goat.utils.ajaxifyAttackHref(); //TODO find some way to hook scope for current menu. Likely needs larger refactor which is already started/stashed | ||||||
|  |                     //refresh menu | ||||||
|  |                     angular.element($('#leftside-navigation')).scope().renderMenu(); | ||||||
|  |                 }, | ||||||
|  |                 makeFormsAjax: function() { | ||||||
|  |                     // make all forms ajax forms | ||||||
|  |                     var options = { | ||||||
|  |                         target: '#lesson_content', // target element(s) to be updated with server response                      | ||||||
|  |                         beforeSubmit: goat.utils.showRequest, // pre-submit callback, comment out after debugging  | ||||||
|  |                         success: goat.utils.showResponse  // post-submit callback, comment out after debugging  | ||||||
|  |  | ||||||
|  |                                 // other available options:  | ||||||
|  |                                 //url:       url         // override for form's 'action' attribute  | ||||||
|  |                                 //type:      type        // 'get' or 'post', override for form's 'method' attribute  | ||||||
|  |                                 //dataType:  null        // 'xml', 'script', or 'json' (expected server response type)  | ||||||
|  |                                 //clearForm: true        // clear all form fields after successful submit  | ||||||
|  |                                 //resetForm: true        // reset the form after successful submit  | ||||||
|  |  | ||||||
|  |                                 // $.ajax options can be used here too, for example:  | ||||||
|  |                                 //timeout:   3000  | ||||||
|  |                     }; | ||||||
|  |                     //console.log("Hooking any lesson forms to make them ajax"); | ||||||
|  |                     $("form").ajaxForm(options); | ||||||
|  |                 }, | ||||||
|  |                 displayButton: function(id, show) { | ||||||
|  |                     if ($('#' + id)) { | ||||||
|  |                         if (show) { | ||||||
|  |                             $('#' + id).show(); | ||||||
|  |                         } else { | ||||||
|  |                             $('#' + id).hide(); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 }, | ||||||
|  |                 showLessonCookiesAndParams: function() { | ||||||
|  |                     $.get(goatConstants.cookieService, {}, function(reply) { | ||||||
|  |                         $("#lesson_cookies").html(reply); | ||||||
|  |                     }, "html"); | ||||||
|  |                 }, | ||||||
|  |                 showLessonHints: function() { | ||||||
|  |                     $('.lessonHelp').hide(); | ||||||
|  |                     $('#lesson_hint').html(); | ||||||
|  |                     $('#lesson_hint_row').show(); | ||||||
|  |                 }, | ||||||
|  |                 showLessonSource: function(source) { | ||||||
|  |                     $('.lessonHelp').hide(); | ||||||
|  |                     //$('#lesson_source').html("<pre>"+goat.lesson.lessonInfo.source+"</pre>"); | ||||||
|  |                     $('#lesson_source_row').show(); | ||||||
|  |                     goat.utils.scrollToHelp(); | ||||||
|  |                 }, | ||||||
|  |                 showLessonSolution: function() { | ||||||
|  |                     $('.lessonHelp').hide(); | ||||||
|  |                     $('#lesson_solution').html(goat.lesson.lessonInfo.solution); | ||||||
|  |                     $('#lesson_solution_row').show(); | ||||||
|  |                     goat.utils.scrollToHelp(); | ||||||
|  |                 }, | ||||||
|  |                 showLessonPlan: function(plan) { | ||||||
|  |                     $('.lessonHelp').hide(); | ||||||
|  |                     $("#lesson_plan").html(goat.lesson.lessonInfo.plan); | ||||||
|  |                     $('#lesson_plan_row').show(); | ||||||
|  |                     goat.utils.scrollToHelp(); | ||||||
|  |                 }, | ||||||
|  |                 scrollToHelp: function() { | ||||||
|  |                     $('#leftside-navigation').height($('#main-content').height() + 15) | ||||||
|  |                     var target = $('#lessonHelpsWrapper'); | ||||||
|  |                     goat.utils.scrollEasy(target); | ||||||
|  |                 }, | ||||||
|  |                 scrollToTop: function() { | ||||||
|  |                     $('.lessonHelp').hide(); | ||||||
|  |                     var target = $('#container'); | ||||||
|  |                     goat.utils.scrollEasy(target); | ||||||
|  |                 }, | ||||||
|  |                 scrollEasy: function(target) { | ||||||
|  |                     $('html,body').animate({ | ||||||
|  |                         scrollTop: target.offset().top | ||||||
|  |                     }, 1000); | ||||||
|  |                 }, | ||||||
|  |                 scrapeParams: function(url) { | ||||||
|  |                     if (!url) { | ||||||
|  |                         return; | ||||||
|  |                     } | ||||||
|  |                     var params = url.split('?')[1].split('&'); | ||||||
|  |                     var paramsArr = []; | ||||||
|  |                     for (var i = 0; i < params.length; i++) { | ||||||
|  |                         var paramObj = {}; | ||||||
|  |                         paramObj.name = params[i].split('=')[0]; | ||||||
|  |                         paramObj.value = params[i].split('=')[1]; | ||||||
|  |                         paramsArr.push(paramObj); | ||||||
|  |                     } | ||||||
|  |                     return paramsArr; | ||||||
|  |                 }, | ||||||
|  |                 highlightCurrentLessonMenu: function(id) { | ||||||
|  |                     //TODO: move selectors in first two lines into goatConstants | ||||||
|  |                     $('ul li.selected').removeClass(goatConstants.selectedMenuClass) | ||||||
|  |                     $('ul li.selected a.selected').removeClass(goatConstants.selectedMenuClass) | ||||||
|  |                     $('#' + id).addClass(goatConstants.selectedMenuClass); | ||||||
|  |                     $('#' + id).parent().addClass(goatConstants.selectedMenuClass); | ||||||
|  |                 }, | ||||||
|  |                 ajaxifyAttackHref: function() {  // rewrite any links with hrefs point to relative attack URLs              | ||||||
|  |                  $.each($('a[href^="attack?"]'), | ||||||
|  |         			function(i,el) { | ||||||
|  |         				var url = $(el).attr('href'); | ||||||
|  |         				$(el).unbind('click').attr('href','#').attr('link',url); | ||||||
|  |         				//TODO pull currentMenuId | ||||||
|  |         				$(el).click(function() { | ||||||
|  |         					event.preventDefault(); | ||||||
|  |         					var _url = $(el).attr('link'); | ||||||
|  |         					$.get(_url, {success:showResponse}); | ||||||
|  |         				}); | ||||||
|  |                     }); | ||||||
|  |         		} | ||||||
|  |         }; | ||||||
|  |      | ||||||
|  |         return goatUtils; | ||||||
|  | }); | ||||||
| @ -1,220 +0,0 @@ | |||||||
| goatUtils = { |  | ||||||
|     //TODO add recursion to handle arr[i].children objects |  | ||||||
|     // ... in case lower-level's need classes as well ... don't right now |  | ||||||
|     addMenuClasses: function(arr) { |  | ||||||
|         for (var i = 0; i < arr.length; i++) { |  | ||||||
|             var menuItem = arr[i]; |  | ||||||
|             //console.log(menuItem); |  | ||||||
|             if (menuItem.type && menuItem.type === 'CATEGORY') { |  | ||||||
|                 menuItem.class = 'fa-angle-right pull-right'; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return arr; |  | ||||||
|     }, |  | ||||||
|     debugFormSubmission: false, |  | ||||||
|     // pre-submit callback  |  | ||||||
|     showRequest: function(formData, jqForm, options) { |  | ||||||
|         if (goat.utils.debugFormSubmission) { |  | ||||||
|             // formData is an array; here we use $.param to convert it to a string to display it  |  | ||||||
|             // but the form plugin does this for you automatically when it submits the data  |  | ||||||
|             var queryString = $.param(formData); |  | ||||||
|  |  | ||||||
|             // jqForm is a jQuery object encapsulating the form element.  To access the  |  | ||||||
|             // DOM element for the form do this:  |  | ||||||
|             // var formElement = jqForm[0];  |  | ||||||
|  |  | ||||||
|             alert('About to submit: \n\n' + queryString); |  | ||||||
|         } |  | ||||||
|         // here we could return false to prevent the form from being submitted;  |  | ||||||
|         // returning anything other than false will allow the form submit to continue  |  | ||||||
|         return true; |  | ||||||
|     }, |  | ||||||
|     // post-submit callback  |  | ||||||
|     showResponse: function(responseText, statusText, xhr, $form) { |  | ||||||
|         // for normal html responses, the first argument to the success callback  |  | ||||||
|         // is the XMLHttpRequest object's responseText property  |  | ||||||
|  |  | ||||||
|         // if the ajaxForm method was passed an Options Object with the dataType  |  | ||||||
|         // property set to 'xml' then the first argument to the success callback  |  | ||||||
|         // is the XMLHttpRequest object's responseXML property  |  | ||||||
|  |  | ||||||
|         // if the ajaxForm method was passed an Options Object with the dataType  |  | ||||||
|         // property set to 'json' then the first argument to the success callback  |  | ||||||
|         // is the json data object returned by the server  |  | ||||||
|         if (goat.utils.debugFormSubmission) { |  | ||||||
|             alert('status: ' + statusText + '\n\nresponseText: \n' + responseText + |  | ||||||
|                     '\n\nThe output div should have already been updated with the responseText.'); |  | ||||||
|         } |  | ||||||
|         // update lesson cookies and params |  | ||||||
|         // make any embedded forms ajaxy |  | ||||||
|         goat.utils.showLessonCookiesAndParams(); |  | ||||||
|         // forms and links are now hooked with each standard lesson render (see Java class Screen.getContent()) |  | ||||||
|         // but these are safe to call twice |  | ||||||
|         goat.utils.makeFormsAjax(); |  | ||||||
|         goat.utils.ajaxifyAttackHref(); //TODO find some way to hook scope for current menu. Likely needs larger refactor which is already started/stashed |  | ||||||
|         //refresh menu |  | ||||||
|         angular.element($('#leftside-navigation')).scope().renderMenu(); |  | ||||||
|     }, |  | ||||||
|     makeFormsAjax: function() { |  | ||||||
|         // make all forms ajax forms |  | ||||||
|         var options = { |  | ||||||
|             target: '#lesson_content', // target element(s) to be updated with server response                      |  | ||||||
|             beforeSubmit: goat.utils.showRequest, // pre-submit callback, comment out after debugging  |  | ||||||
|             success: goat.utils.showResponse  // post-submit callback, comment out after debugging  |  | ||||||
|  |  | ||||||
|                     // other available options:  |  | ||||||
|                     //url:       url         // override for form's 'action' attribute  |  | ||||||
|                     //type:      type        // 'get' or 'post', override for form's 'method' attribute  |  | ||||||
|                     //dataType:  null        // 'xml', 'script', or 'json' (expected server response type)  |  | ||||||
|                     //clearForm: true        // clear all form fields after successful submit  |  | ||||||
|                     //resetForm: true        // reset the form after successful submit  |  | ||||||
|  |  | ||||||
|                     // $.ajax options can be used here too, for example:  |  | ||||||
|                     //timeout:   3000  |  | ||||||
|         }; |  | ||||||
|         //console.log("Hooking any lesson forms to make them ajax"); |  | ||||||
|         $("form").ajaxForm(options); |  | ||||||
|     }, |  | ||||||
|     enhanceMenuData: function (menuItems,selectedItem) { |  | ||||||
|         for (var i = 0; i < menuItems.length; i++) { |  | ||||||
|             menuItems[i].id = goatUtils.makeId(menuItems[i].name);//TODO move the replace routine into util function |  | ||||||
|             if (selectedItem) { |  | ||||||
|             } |  | ||||||
|             //TODO: maintain state marker on refresh |  | ||||||
|             //menuItems[i].displayClass = ($scope.openMenu === menuItems[i].id) ? goatConstants.getClasses().keepOpenClass : ''; |  | ||||||
|             //TODO: move to utility method |  | ||||||
|             if (menuItems[i].children) { |  | ||||||
|                 for (var j = 0; j < menuItems[i].children.length; j++) { |  | ||||||
|                     menuItems[i].children[j].id = goatUtils.makeId(menuItems[i].children[j].name); |  | ||||||
|                     //handle selected Menu state |  | ||||||
|                     if (menuItems[i].children[j].id ===  selectedItem) { |  | ||||||
|                         menuItems[i].children[j].selectedClass = goatConstants.getClasses().selectedMenuClass; |  | ||||||
|                         menuItems[i].selectedClass = goatConstants.getClasses().selectedMenuClass; |  | ||||||
|                     } |  | ||||||
|                     //handle complete state |  | ||||||
|                     if (menuItems[i].children[j].complete) { |  | ||||||
|                         menuItems[i].children[j].completeClass = goatConstants.getClasses().lessonCompleteClass; |  | ||||||
|                     } else { |  | ||||||
|                         menuItems[i].children[j].completeClass = ''; |  | ||||||
|                     } |  | ||||||
|                     if (menuItems[i].children[j].children) { |  | ||||||
|                         for (var k = 0; k < menuItems[i].children[j].children.length; k++) { |  | ||||||
|                             //TODO make utility function for name >> id |  | ||||||
|                             menuItems[i].children[j].children[k].id = goatUtils.makeId(menuItems[i].children[j].children[k].name); |  | ||||||
|                             //menuItems[i].children[j].children[k].id = menuItems[i].children[j].children[k].name.replace(/\s|\(|\)/g,''); |  | ||||||
|                             //handle selected Menu state |  | ||||||
|                             if (menuItems[i].children[j].children[k].id === selectedItem) { |  | ||||||
|                                 menuItems[i].children[j].children[k].selectedClass = goatConstants.getClasses().selectedMenuClass; |  | ||||||
|                                 menuItems[i].children[j].selectedClass = goatConstants.getClasses().selectedMenuClass; |  | ||||||
|                             } |  | ||||||
|                             //handle complete state |  | ||||||
|                             if (menuItems[i].children[j].children[k].complete) { |  | ||||||
|                                 menuItems[i].children[j].children[k].completeClass = goatConstants.lessonCompleteClass; |  | ||||||
|                             } else { |  | ||||||
|                                 menuItems[i].children[j].children[k].completeClass = '' |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } // done parsing menuItems |  | ||||||
|     }, |  | ||||||
|     // |  | ||||||
|     displayButton: function(id, show) { |  | ||||||
|         if ($('#' + id)) { |  | ||||||
|             if (show) { |  | ||||||
|                 $('#' + id).show(); |  | ||||||
|             } else { |  | ||||||
|                 $('#' + id).hide(); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
|     showLessonCookiesAndParams: function() { |  | ||||||
|         $.get(goatConstants.cookieService, {}, function(reply) { |  | ||||||
|             $("#lesson_cookies").html(reply); |  | ||||||
|         }, "html"); |  | ||||||
|     }, |  | ||||||
|     showLessonHints: function() { |  | ||||||
|         $('.lessonHelp').hide(); |  | ||||||
|         $('#lesson_hint').html(); |  | ||||||
|         $('#lesson_hint_row').show(); |  | ||||||
|     }, |  | ||||||
|     showLessonSource: function(source) { |  | ||||||
|         $('.lessonHelp').hide(); |  | ||||||
|         //$('#lesson_source').html("<pre>"+goat.lesson.lessonInfo.source+"</pre>"); |  | ||||||
|         $('#lesson_source_row').show(); |  | ||||||
|         goat.utils.scrollToHelp(); |  | ||||||
|     }, |  | ||||||
|     showLessonSolution: function() { |  | ||||||
|         $('.lessonHelp').hide(); |  | ||||||
|         $('#lesson_solution').html(goat.lesson.lessonInfo.solution); |  | ||||||
|         $('#lesson_solution_row').show(); |  | ||||||
|         goat.utils.scrollToHelp(); |  | ||||||
|     }, |  | ||||||
|     showLessonPlan: function(plan) { |  | ||||||
|         $('.lessonHelp').hide(); |  | ||||||
|         $("#lesson_plan").html(goat.lesson.lessonInfo.plan); |  | ||||||
|         $('#lesson_plan_row').show(); |  | ||||||
|         goat.utils.scrollToHelp(); |  | ||||||
|     }, |  | ||||||
|     scrollToHelp: function() { |  | ||||||
|         $('#leftside-navigation').height($('#main-content').height() + 15) |  | ||||||
|         var target = $('#lessonHelpsWrapper'); |  | ||||||
|         goat.utils.scrollEasy(target); |  | ||||||
|     }, |  | ||||||
|     scrollToTop: function() { |  | ||||||
|         $('.lessonHelp').hide(); |  | ||||||
|         var target = $('#container'); |  | ||||||
|         goat.utils.scrollEasy(target); |  | ||||||
|     }, |  | ||||||
|     scrollEasy: function(target) { |  | ||||||
|         $('html,body').animate({ |  | ||||||
|             scrollTop: target.offset().top |  | ||||||
|         }, 1000); |  | ||||||
|     }, |  | ||||||
|     scrapeParams: function(url) { |  | ||||||
|         if (!url) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         var params = url.split('?')[1].split('&'); |  | ||||||
|         var paramsArr = []; |  | ||||||
|         for (var i = 0; i < params.length; i++) { |  | ||||||
|             var paramObj = {}; |  | ||||||
|             paramObj.name = params[i].split('=')[0]; |  | ||||||
|             paramObj.value = params[i].split('=')[1]; |  | ||||||
|             paramsArr.push(paramObj); |  | ||||||
|         } |  | ||||||
|         return paramsArr; |  | ||||||
|     }, |  | ||||||
|     highlightCurrentLessonMenu: function(id) { |  | ||||||
|         //TODO: move selectors in first two lines into goatConstants |  | ||||||
|         $('ul li.selected').removeClass(goatConstants.selectedMenuClass) |  | ||||||
|         $('ul li.selected a.selected').removeClass(goatConstants.selectedMenuClass) |  | ||||||
|         $('#' + id).addClass(goatConstants.selectedMenuClass); |  | ||||||
|         $('#' + id).parent().addClass(goatConstants.selectedMenuClass); |  | ||||||
|     }, |  | ||||||
|     makeId: function(lessonName) { |  | ||||||
|         return lessonName.replace(/\s|\(|\)|\!|\:|\;|\@|\#|\$|\%|\^|\&|\*/g, '');//TODO move the replace routine into util function |  | ||||||
|     }, |  | ||||||
|     ajaxifyAttackHref: function() { |  | ||||||
|         // rewrite any links with hrefs point to relative attack URLs |  | ||||||
|          $.each($('a[href^="attack?"]'), |  | ||||||
| 			function(i,el) { |  | ||||||
| 				var url = $(el).attr('href'); |  | ||||||
| 				$(el).unbind('click').attr('href','#').attr('link',url); |  | ||||||
| 				//TODO pull currentMenuId |  | ||||||
| 				$(el).click(function() { |  | ||||||
| 					event.preventDefault(); |  | ||||||
| 					var _url = $(el).attr('link'); |  | ||||||
| 					$.get(_url, {success:showResponse}); |  | ||||||
| 				} |  | ||||||
| 			); |  | ||||||
|          }); |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| $(window).resize(function() { |  | ||||||
|     //$('#leftside-navigation').css('height',$('div.panel-body').height()); |  | ||||||
|     console.log($(window).height()); |  | ||||||
| }); |  | ||||||
| @ -1,13 +1,29 @@ | |||||||
| define(['jquery', | define(['jquery', | ||||||
| 	'underscore', | 	'underscore', | ||||||
| 	'backbone'], function($,_,Backbone) { | 	'backbone', | ||||||
|  | 	'goatApp/support/GoatUtils', | ||||||
|  | 	'goatApp/view/MenuItemView'], | ||||||
|  | 	function( | ||||||
|  | 		$, | ||||||
|  | 		_, | ||||||
|  | 		Backbone, | ||||||
|  | 		GoatUtils, | ||||||
|  | 		MenuItemView) { | ||||||
|  |  | ||||||
| 	return Backbone.View.extend({ | 	return Backbone.View.extend({ | ||||||
| 		initialize: function(options) { | 		initialize: function(options) { | ||||||
| 			options = options || {}; | 			options = options || {}; | ||||||
|  | 			this.items = options.items; | ||||||
|  | 		}, | ||||||
|  | 		render: function() { | ||||||
|  | 			var viewItems = []; | ||||||
|  | 			for (var i=0;i<this.items.length;i++) { | ||||||
|  | 				var listItem = $('<li>',{text:this.items[i].name}); | ||||||
|  | 				//viewItems | ||||||
|  | 				viewItems.push(listItem); | ||||||
|  | 			} | ||||||
|  | 			return viewItems; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  |  | ||||||
| 	}); | 	}); | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										37
									
								
								src/main/webapp/js/goatApp/view/MenuModel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								src/main/webapp/js/goatApp/view/MenuModel.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | |||||||
|  | // define(['jquery', | ||||||
|  | // 	'underscore', | ||||||
|  | // 	'backbone', | ||||||
|  | // 	'goatApp/model/MenuItemModel', | ||||||
|  | // 	'goatApp/model/MenuItemCollection'], | ||||||
|  | // 	function($,_,Backbone,MenuItemModel,MenuItemCollection) { | ||||||
|  |  | ||||||
|  | // 	return Backbone.View.extend({ | ||||||
|  | // 		initialize: function(options) { | ||||||
|  | // 			options = options || {}; | ||||||
|  | // 			//if children, generate Stage views | ||||||
|  | // 			this.collection = new MenuItemCollection(); | ||||||
|  | // 			this.collection.set(options.collection); | ||||||
|  | // 		}, | ||||||
|  | // 		render: function() { | ||||||
|  | // 			//example | ||||||
|  | // 			/* | ||||||
|  | // 			"name": "Using an Access Control Matrix", | ||||||
|  | // 			"type": "LESSON", | ||||||
|  | // 			"children": [ ], | ||||||
|  | // 			"complete": false, | ||||||
|  | // 			"link": "#attack/18/200", | ||||||
|  | // 			"showSource": true, | ||||||
|  | // 			"showHints": true | ||||||
|  | // 			*/ | ||||||
|  | // 			var link = $('<a>',{}); | ||||||
|  | // 			var listItem = $('<li>',{class:'sub-menu',text:this.model.get('name')}); | ||||||
|  |  | ||||||
|  | // 			listItem.append(link); | ||||||
|  | // 				//this.model.get('name') + this.model.get('children').length + '</li>'; | ||||||
|  | // 			return listItem; | ||||||
|  | // 		} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // 	}); | ||||||
|  |  | ||||||
|  | // }); | ||||||
							
								
								
									
										14
									
								
								src/main/webapp/js/goatApp/view/MenuStageView.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								src/main/webapp/js/goatApp/view/MenuStageView.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | |||||||
|  | define(['jquery', | ||||||
|  | 	'underscore', | ||||||
|  | 	'backbone'], function($,_,Backbone) { | ||||||
|  |  | ||||||
|  | 	return Backbone.View.extend({ | ||||||
|  | 		initialize: function(options) { | ||||||
|  | 			options = options || {}; | ||||||
|  |  | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	}); | ||||||
|  |  | ||||||
|  | }); | ||||||
| @ -1,57 +1,37 @@ | |||||||
| define(['jquery', | define(['jquery', | ||||||
| 	'underscore', | 	'underscore', | ||||||
| 	'backbone', | 	'backbone', | ||||||
| 	'goatApp/model/MenuItemCollection'],  | 	'goatApp/model/MenuCollection', | ||||||
| 	function($,_,Backbone,MenuItemCollection) { | 	'goatApp/view/MenuItemView'],  | ||||||
|  | 	function($,_,Backbone,MenuCollection,MenuItemView) { | ||||||
|  |  | ||||||
| 	return  Backbone.View.extend({ | 	return  Backbone.View.extend({ | ||||||
| 		el:'#menuContainer', | 		el:'#menuContainer', | ||||||
| 		//TODO: set template | 		//TODO: set template | ||||||
| 		initialize: function() { | 		initialize: function() { | ||||||
| 			this.collection = new MenuItemCollection(); | 			this.collection = new MenuCollection(); | ||||||
| 			this.listenTo(this.collection,'menuData:loaded',this.render); | 			this.listenTo(this.collection,'menuData:loaded',this.render); | ||||||
| 		}, | 		}, | ||||||
|  | 		// rendering top level menu | ||||||
| 		render: function (model){ | 		render: function (model){ | ||||||
| 			//TODO: implement own HTML Encoder | 			var items = this.collection.models; // top level items | ||||||
| 			this.$el.html('render ' + this.collection.length + ' items');//buildMenu(items) | 			var menuMarkup = ''; | ||||||
| 		}, | 			var menuUl = $('<ul>',{class:'nano-content'}); | ||||||
| 		buildMenu: function(items) { | 			for(var i=0;i<items.length;i++) { | ||||||
|  | 				var category = $('<li>',{class:'sub-menu'}); | ||||||
| 			var menuData = new MenuData(); | 				var catLink = $('<a>',{text:items[i].get('name')}); | ||||||
|  | 				category.append(catLink); | ||||||
| 			var i, j, k, $wholeMenu, $menuCat, itemClass, $lessonItem, lessons, stages, $stageItem; | 				// lesson level (first children level) | ||||||
| 			var _renderMenu = function (items) { | 				var categoryLessonList = $('<ul>',{class:'slideDown lessonsAndStages'}); | ||||||
| 				$wholeMenu = $('<ul>'); | 				var catItems = new MenuItemView({items:items[i].get('children')}).render(); | ||||||
| 				for (var i=0;i<items.length;i++){ | 				for (var j=0;j< catItems.length;j++) { | ||||||
| 					// should be at category level ... | 					categoryLessonList.append(catItems[j]); | ||||||
| 					itemClass = (items[i].class || ''); |  | ||||||
| 					if (items[i].type && items.type === 'CATEGORY') { |  | ||||||
| 						itemClass += 'fa-angle-right pull-right'; |  | ||||||
| 				} | 				} | ||||||
| 					var $menuCat = $('<li>',{text:items[i].name,class:itemClass}); | 				category.append(categoryLessonList); | ||||||
| 					$wholeMenu.append($menuCat); | 				menuUl.append(category); | ||||||
| 					var lessonList = $('<ul>',{class:'slideDown lessonsAndStages' + items[0].displayClass,id:items[0].id}) // |  | ||||||
| 					// first tier lessons |  | ||||||
| 					var lessons = items[i].children; |  | ||||||
| 					for (j=0;j<lessons.length;j++) { |  | ||||||
| 						itemClass = (lessons[j].class || ''); |  | ||||||
| 						$lessonItem = $('<li>',{text:lessons[j].name,id:lessons[j].id});//add click |  | ||||||
| 						lessonList.append($lessonItem); |  | ||||||
| 						//stages (children of lesson) |  | ||||||
| 						stages = lessons[j].children; |  | ||||||
| 						for (k=0;k<stages.length;k++) { |  | ||||||
| 							$stageItem = $('<li>',{text:stages[k].name,id:stages[k].id}); |  | ||||||
| 							lessonList.append($stageItem); |  | ||||||
| 			} | 			} | ||||||
| 					} | 			this.$el.append(menuUl); | ||||||
| 					$menuCat.append(lessonList); |  | ||||||
| 				} |  | ||||||
| 				return $wholeMenu; |  | ||||||
| 				//$wholeMenu.append($menuCat); |  | ||||||
| 				$(goatConstants.getDOMContainers().lessonMenu).html('').append($wholeMenu); |  | ||||||
| 			}; |  | ||||||
| 			 |  | ||||||
| 		}, |  | ||||||
|  |  | ||||||
|  | 		} | ||||||
| 	}); | 	}); | ||||||
| }); | }); | ||||||
		Reference in New Issue
	
	Block a user