2006-10-20 03:18:06 +00:00
|
|
|
/**
|
|
|
|
* Contains Main class and supporting functions for ajax course layout
|
2006-09-23 14:03:48 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//hide content body until done loading (manipulation looks ugly elsewise)
|
2006-10-24 08:11:38 +00:00
|
|
|
//document.getElementById('content').style.display = 'none';
|
2006-10-20 03:18:06 +00:00
|
|
|
|
2009-10-03 01:53:17 +00:00
|
|
|
// If firebug console is undefined, define a fake one here
|
|
|
|
if (window.console) {
|
|
|
|
console.vardump = function(data) {
|
|
|
|
retval = '';
|
|
|
|
for (key in data) {
|
|
|
|
retval += key+' = '+data[key] + "\n";
|
|
|
|
}
|
|
|
|
console.log(retval);
|
|
|
|
};
|
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2006-10-24 08:11:38 +00:00
|
|
|
//onload object for handling scripts on page load, this insures they run in my order
|
2006-09-23 14:03:48 +00:00
|
|
|
function onload_class() {
|
|
|
|
this.scripts = new Array();
|
2006-10-24 08:11:38 +00:00
|
|
|
this.debug = true;
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
|
2006-09-23 14:03:48 +00:00
|
|
|
onload_class.prototype.add = function(script) {
|
2006-10-24 08:11:38 +00:00
|
|
|
if (this.debug) {
|
2007-05-09 01:11:45 +00:00
|
|
|
YAHOO.log("onloadobj.add - adding "+script, "junk");
|
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
this.scripts[this.scripts.length] = script;
|
|
|
|
}
|
|
|
|
|
2006-10-24 08:11:38 +00:00
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
onload_class.prototype.load = function() {
|
2006-09-23 14:03:48 +00:00
|
|
|
var scriptcount = this.scripts.length;
|
2007-05-09 01:11:45 +00:00
|
|
|
if (this.debug) {
|
|
|
|
YAHOO.log("onloadobj.load - loading "+scriptcount+" scripts", "info");
|
|
|
|
}
|
2006-10-24 08:11:38 +00:00
|
|
|
for (i=0; i<scriptcount; i++) {
|
|
|
|
eval(this.scripts[i]);
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
|
2006-10-24 08:11:38 +00:00
|
|
|
var onloadobj = new onload_class();
|
2006-09-23 14:03:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
//main page object
|
2006-10-20 03:18:06 +00:00
|
|
|
function main_class() {
|
2007-05-09 01:11:45 +00:00
|
|
|
this.debug = true;
|
2006-09-23 14:03:48 +00:00
|
|
|
this.portal = new php_portal_class();
|
|
|
|
|
|
|
|
this.blocks = new Array();
|
|
|
|
this.sections = new Array();
|
2009-10-03 01:53:17 +00:00
|
|
|
this.sectiondates = {};
|
2006-09-23 14:03:48 +00:00
|
|
|
this.leftcolumn = null;
|
2006-10-24 08:11:38 +00:00
|
|
|
this.rightcolumn = null;
|
|
|
|
this.adminBlock = null;
|
2009-10-21 06:25:21 +00:00
|
|
|
this.tempBlock = null;
|
2006-09-23 14:03:48 +00:00
|
|
|
this.icons = [];
|
2009-10-21 06:25:21 +00:00
|
|
|
this.courseformat = null;
|
2006-09-23 14:03:48 +00:00
|
|
|
this.marker = null;
|
2009-10-30 08:02:16 +00:00
|
|
|
this.numsections = null;
|
2006-09-23 14:03:48 +00:00
|
|
|
|
|
|
|
//things to process onload
|
2006-10-24 08:11:38 +00:00
|
|
|
onloadobj.add('main.process_document();');
|
|
|
|
onloadobj.add("document.getElementById('content').style.display='block';");
|
2006-09-23 14:03:48 +00:00
|
|
|
|
|
|
|
//connection queue allows xhttp requests to be sent in order
|
|
|
|
this.connectQueue = [];
|
|
|
|
this.connectQueueHead = 0;
|
|
|
|
this.connectQueueConnection = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
main_class.prototype.process_blocks = function() {
|
2006-10-24 08:11:38 +00:00
|
|
|
//remove unneeded icons (old school position icons and delete/hide
|
2007-05-09 01:11:45 +00:00
|
|
|
//although they will be read)
|
2006-10-20 03:18:06 +00:00
|
|
|
var rmIconClasses = ['icon up', 'icon down', 'icon right', 'icon left', 'icon delete', 'icon hide'];
|
|
|
|
for (var c=0; c<rmIconClasses.length; c++) {
|
2006-09-23 14:03:48 +00:00
|
|
|
els = YAHOO.util.Dom.getElementsByClassName(rmIconClasses[c]);
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
for (var x=0; x<els.length; x++) {
|
2006-09-23 14:03:48 +00:00
|
|
|
els[x].parentNode.removeChild(els[x]);
|
|
|
|
}
|
2008-10-08 12:22:04 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
//process the block ids passed from php
|
|
|
|
var blockcount = this.portal.blocks.length;
|
2006-10-20 03:18:06 +00:00
|
|
|
YAHOO.log("main.processBlocks - processing "+blockcount+" blocks", "info");
|
|
|
|
|
2006-10-24 08:11:38 +00:00
|
|
|
for (i=0; i<blockcount; i++) {
|
2006-10-20 03:18:06 +00:00
|
|
|
this.blocks[i] = new block_class(this.portal.blocks[i][1], "blocks");
|
2006-09-23 14:03:48 +00:00
|
|
|
|
|
|
|
//put in correct side array also
|
|
|
|
if (this.portal.blocks[i][0] == 'l') {
|
|
|
|
main.leftcolumn.add_block(this.blocks[i]);
|
|
|
|
} else if (this.portal.blocks[i][0] == 'r') {
|
2008-10-08 12:22:04 +00:00
|
|
|
main.rightcolumn.add_block(this.blocks[i]);
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//hide if called for
|
|
|
|
if (this.portal.blocks[i][2] == 1) {
|
2006-10-20 03:18:06 +00:00
|
|
|
this.blocks[i].toggle_hide(null, null, true);
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
2008-10-08 12:22:04 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
main_class.prototype.process_document = function() {
|
2006-10-24 08:11:38 +00:00
|
|
|
//process the document to get important containers
|
2006-10-20 03:18:06 +00:00
|
|
|
YAHOO.log("Processing Document", "info");
|
|
|
|
|
2006-09-23 14:03:48 +00:00
|
|
|
//process columns for blocks
|
2006-10-20 03:18:06 +00:00
|
|
|
this.leftcolumn = new column_class('left-column', "blocks", null, 'l');
|
|
|
|
this.rightcolumn = new column_class('right-column', "blocks", null, 'r');
|
2006-09-23 14:03:48 +00:00
|
|
|
|
|
|
|
//process sections
|
2009-10-30 08:02:16 +00:00
|
|
|
//var ct = 0;
|
|
|
|
//while (document.getElementById('section-'+ct) != null) {
|
|
|
|
var maxct = this.portal.numsections;
|
|
|
|
this.courseformat = this.portal.courseformat;
|
|
|
|
for(var ct=0; ct <= maxct; ct++){
|
|
|
|
if(document.getElementById('section-'+ct) != null) {
|
|
|
|
this.sections[ct] = new section_class('section-'+ct, "sections", null, ct!=0?true:false);
|
|
|
|
this.sections[ct].addToGroup('resources');
|
|
|
|
if (ct > 0) {
|
|
|
|
var sectiontitle = YAHOO.util.Selector.query('#section-'+ct+' h3.weekdates')[0];
|
|
|
|
if (undefined !== sectiontitle) { // Only save date for weekly format
|
|
|
|
this.sectiondates[ct] = sectiontitle.innerHTML;
|
|
|
|
}
|
2009-10-03 01:53:17 +00:00
|
|
|
}
|
|
|
|
}
|
2009-10-30 08:02:16 +00:00
|
|
|
//ct++;
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
2006-10-24 08:11:38 +00:00
|
|
|
if (this.debug) {
|
2007-05-09 01:11:45 +00:00
|
|
|
YAHOO.log("Processed "+ct+" sections");
|
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2008-10-08 12:22:04 +00:00
|
|
|
this.adminBlock = YAHOO.util.Dom.getElementsByClassName('block_adminblock')[0];
|
2009-10-21 06:25:21 +00:00
|
|
|
this.tempBlock = YAHOO.util.Dom.getElementsByClassName('tempblockhandler')[0];
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
|
|
|
|
main_class.prototype.mk_safe_for_transport = function(input) {
|
|
|
|
return input.replace(/&/i, '_.amp._');
|
2008-10-08 12:22:04 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
|
|
|
|
//return block by id
|
|
|
|
main_class.prototype.get_block_index = function(el) {
|
2006-09-23 14:03:48 +00:00
|
|
|
var blockcount = this.blocks.length;
|
2006-10-20 03:18:06 +00:00
|
|
|
for (i=0; i<blockcount; i++) {
|
2006-09-23 14:03:48 +00:00
|
|
|
if (this.blocks[i] == el) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
|
|
|
|
main_class.prototype.get_section_index = function(el) {
|
2006-09-23 14:03:48 +00:00
|
|
|
var sectioncount = this.sections.length;
|
2006-10-20 03:18:06 +00:00
|
|
|
for (i=0; i<sectioncount; i++) {
|
2006-09-23 14:03:48 +00:00
|
|
|
if (this.sections[i] == el) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
2006-10-20 03:18:06 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2007-11-19 17:22:04 +00:00
|
|
|
main_class.prototype.mk_button = function(tag, imgSrc, text, attributes, imgAttributes) {
|
|
|
|
//Create button and return object.
|
|
|
|
//Set the text: the container TITLE or image ALT attributes can be overridden, eg.
|
2009-07-03 06:19:25 +00:00
|
|
|
// main.mk_button('a', main.portal.icons['move_2d'], strmove, [['title', strmoveshort]]);
|
2006-09-23 14:03:48 +00:00
|
|
|
var container = document.createElement(tag);
|
2007-11-19 17:22:04 +00:00
|
|
|
container.style.cursor = 'pointer';
|
|
|
|
container.setAttribute('title', text);
|
2006-09-23 14:03:48 +00:00
|
|
|
var image = document.createElement('img');
|
2006-11-14 03:07:18 +00:00
|
|
|
|
2009-07-03 06:19:25 +00:00
|
|
|
image.setAttribute('src', imgSrc);
|
2007-11-19 17:22:04 +00:00
|
|
|
image.setAttribute('alt', text);
|
|
|
|
//image.setAttribute('title', '');
|
2006-09-23 14:03:48 +00:00
|
|
|
container.appendChild(image);
|
|
|
|
|
|
|
|
if (attributes != null) {
|
2006-10-20 03:18:06 +00:00
|
|
|
for (var c=0; c<attributes.length; c++) {
|
2007-11-20 14:37:58 +00:00
|
|
|
if (attributes[c][0] == 'title' && this.is_ie()) {
|
|
|
|
image.setAttribute(attributes[c][0], attributes[c][1]); //IE hack: transfer 'title'.
|
|
|
|
} else {
|
|
|
|
container.setAttribute(attributes[c][0], attributes[c][1]);
|
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (imgAttributes != null) {
|
2007-11-19 15:25:16 +00:00
|
|
|
for (var c=0; c<imgAttributes.length; c++) {
|
2007-11-19 17:22:04 +00:00
|
|
|
image.setAttribute(imgAttributes[c][0], imgAttributes[c][1]);
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
|
|
|
}
|
2007-05-09 01:11:45 +00:00
|
|
|
image.setAttribute('hspace', '3');
|
2006-09-23 14:03:48 +00:00
|
|
|
return container;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
main_class.prototype.connect = function(method, urlStub, callback, body) {
|
2006-10-24 08:11:38 +00:00
|
|
|
if (this.debug) {
|
2007-05-09 01:11:45 +00:00
|
|
|
YAHOO.log("Making "+method+" connection to /course/rest.php?courseId="+main.portal.id+"&"+urlStub);
|
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
if (callback == null) {
|
2008-10-08 12:22:04 +00:00
|
|
|
if (this.debug) {
|
|
|
|
callback = {
|
|
|
|
success: function(response) {
|
|
|
|
YAHOO.log("Response from the Request: " + response.statusText + ": " + response.responseText, 'info');
|
|
|
|
},
|
|
|
|
failure: function() {
|
|
|
|
YAHOO.log("Response from the Request: " + response.statusText + ": " + response.responseText, 'error');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
callback = {};
|
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
2009-11-21 16:29:33 +00:00
|
|
|
return YAHOO.util.Connect.asyncRequest(method, this.portal.strings['wwwroot']+"/course/rest.php?courseId="+main.portal.id+"&sesskey="+this.portal.strings['sesskey']+"&"+urlStub, callback, body);
|
2006-10-20 03:18:06 +00:00
|
|
|
}
|
|
|
|
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
main_class.prototype.connectQueue_add = function(method, urlStub, callback, body) {
|
2006-09-23 14:03:48 +00:00
|
|
|
var Qlength = main.connectQueue.length;
|
|
|
|
main.connectQueue[Qlength] = [];
|
|
|
|
main.connectQueue[Qlength]['method'] = method;
|
|
|
|
main.connectQueue[Qlength]['urlStub'] = urlStub;
|
|
|
|
main.connectQueue[Qlength]['body'] = body;
|
|
|
|
|
|
|
|
if (main.connectQueueConnection == null || !YAHOO.util.Connect.isCallInProgress(main.connectQueueConnection)) {
|
|
|
|
main.connectQueue_fireNext();
|
|
|
|
}
|
2006-10-20 03:18:06 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
|
|
|
|
main_class.prototype.connectQueue_fireNext = function() {
|
2006-09-23 14:03:48 +00:00
|
|
|
var head = main.connectQueueHead;
|
|
|
|
if (head >= main.connectQueue.length) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
var callback = {
|
2007-05-09 01:11:45 +00:00
|
|
|
success: function(){
|
|
|
|
main.connectQueue_fireNext();
|
2006-10-20 03:18:06 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|
2006-10-20 03:18:06 +00:00
|
|
|
main.connectQueueConnection = main.connect(main.connectQueue[head]['method'],
|
2007-05-09 01:11:45 +00:00
|
|
|
main.connectQueue[head]['urlStub'],
|
|
|
|
callback,
|
|
|
|
main.connectQueue[head]['body']);
|
2006-09-23 14:03:48 +00:00
|
|
|
main.connectQueueHead++;
|
2006-10-20 03:18:06 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
|
|
|
|
main_class.prototype.update_marker = function(newMarker) {
|
2006-09-23 14:03:48 +00:00
|
|
|
if (this.marker != null) {
|
|
|
|
this.marker.toggle_highlight();
|
|
|
|
}
|
2008-10-08 12:22:04 +00:00
|
|
|
this.marker = newMarker;
|
2006-09-23 14:03:48 +00:00
|
|
|
this.marker.toggle_highlight();
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
this.connect('post', 'class=course&field=marker', null, 'value='+this.marker.sectionId);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-11-19 17:22:04 +00:00
|
|
|
main_class.prototype.getString = function(identifier, variable) {
|
|
|
|
if (this.portal.strings[identifier]) {
|
|
|
|
return this.portal.strings[identifier].replace(/_var_/, variable);
|
2007-05-09 01:11:45 +00:00
|
|
|
}
|
2006-10-20 03:18:06 +00:00
|
|
|
}
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2007-11-20 14:37:58 +00:00
|
|
|
main_class.prototype.is_ie = function() {
|
|
|
|
var agent = navigator.userAgent.toLowerCase();
|
|
|
|
if ((agent.indexOf('msie') != -1)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2006-10-08 21:24:38 +00:00
|
|
|
|
2006-09-23 14:03:48 +00:00
|
|
|
var main = new main_class();
|
|
|
|
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
function php_portal_class() {
|
|
|
|
//portal to php data
|
2006-09-23 14:03:48 +00:00
|
|
|
this.id = null;
|
2007-05-09 01:11:45 +00:00
|
|
|
this.debug = null;
|
2006-09-23 14:03:48 +00:00
|
|
|
|
2008-10-08 12:22:04 +00:00
|
|
|
//array of id's of blocks set at end of page load by php
|
2006-09-23 14:03:48 +00:00
|
|
|
this.blocks = new Array();
|
|
|
|
this.imagePath = null;
|
|
|
|
|
|
|
|
//flag for week fomat
|
|
|
|
this.isWeek = false;
|
|
|
|
|
2008-10-08 12:22:04 +00:00
|
|
|
//strings
|
2006-09-23 14:03:48 +00:00
|
|
|
this.strings = [];
|
|
|
|
|
2009-10-21 06:25:21 +00:00
|
|
|
//icons
|
|
|
|
this.icons = [];
|
|
|
|
|
2006-10-20 03:18:06 +00:00
|
|
|
YAHOO.log("Instantiated php_portal_class", "info");
|
2006-09-23 14:03:48 +00:00
|
|
|
}
|