From d78dd289071e8464fac57f6b13d711fa99cf9e87 Mon Sep 17 00:00:00 2001 From: Daniel Bucci Date: Tue, 10 Feb 2015 18:15:53 -0500 Subject: [PATCH 01/15] Set up breadcrumbs array --- app/assets/stylesheets/style.css.scss | 6 ++-- app/controllers/application_controller.rb | 12 ++++++++ app/controllers/assessments_controller.rb | 1 + app/views/layouts/_navbar.html.erb | 36 +++++------------------ 4 files changed, 25 insertions(+), 30 deletions(-) diff --git a/app/assets/stylesheets/style.css.scss b/app/assets/stylesheets/style.css.scss index 7e5890d0e..b3563a568 100755 --- a/app/assets/stylesheets/style.css.scss +++ b/app/assets/stylesheets/style.css.scss @@ -208,9 +208,11 @@ div.main-header img { color: rgb(103, 100, 100); } -.sub-navigation .arrow { +.sub-navigation .item + .item:before, /* IE8 *sigh* */ +.sub-navigation .item + .item::before { + color: #999696; + content: "»"; font-size: 24px; - color: rgb(153, 150, 150); } @media (max-width: 768px) { diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb index 0d1d7252b..eeb0162ab 100755 --- a/app/controllers/application_controller.rb +++ b/app/controllers/application_controller.rb @@ -12,6 +12,7 @@ class ApplicationController < ActionController::Base before_action :authorize_user_for_course, except: [:action_no_auth ] before_action :authenticate_for_action before_action :update_persistent_announcements + before_action :set_breadcrumbs # this is where Error Handling is configured. this routes exceptions to # the error handler in the HomeController, unless we're in development mode @@ -237,6 +238,17 @@ def run_scheduler def update_persistent_announcements @persistent_announcements = Announcement.where("persistent and (course_id=? or system)", @course.id) end + + def set_breadcrumbs + @breadcrumbs = [] + if @course then + if @course.disabled? then + @breadcrumbs << (view_context.link_to "#{@course.display_name} (Course Disabled)", [@course], id: "courseTitle") + else + @breadcrumbs << (view_context.link_to @course.display_name, [@course], id: "courseTitle") + end + end + end def pluralize(count, singular, plural = nil) "#{count || 0} " + ((count == 1 || count =~ /^1(\.0+)?$/) ? singular : (plural || singular.pluralize)) diff --git a/app/controllers/assessments_controller.rb b/app/controllers/assessments_controller.rb index a1a79c15d..c6047b246 100755 --- a/app/controllers/assessments_controller.rb +++ b/app/controllers/assessments_controller.rb @@ -1982,6 +1982,7 @@ def get_props def get_assessment @assessment = Assessment.find params[:assessment_id] || params[:id] @course = @assessment.course + @breadcrumbs << (view_context.current_assessment_link) if ((!@cud.user.administrator?) && (@cud.course_id != @assessment.course_id)) then flash[:error] = "You do not have permission to access this submission" diff --git a/app/views/layouts/_navbar.html.erb b/app/views/layouts/_navbar.html.erb index ce123b36f..00da9db36 100644 --- a/app/views/layouts/_navbar.html.erb +++ b/app/views/layouts/_navbar.html.erb @@ -80,33 +80,13 @@ -<% if @course %> - +<% unless @breadcrumbs.blank? then %> + <% end %> From ffad43df8663e008268f0c6b3d11bcb42c1452e7 Mon Sep 17 00:00:00 2001 From: Ilter Canberk Date: Sun, 1 Mar 2015 20:06:20 -0500 Subject: [PATCH 02/15] Improvements to gradesheet --- app/assets/javascripts/KeyTable.js | 1138 ----------------- app/assets/javascripts/gradesheet.js | 696 ---------- .../{gradesheet1.js.erb => gradesheet.js.erb} | 56 +- app/assets/stylesheets/gradesheet1.css.scss | 47 +- app/views/assessments/_gradesheet.html.erb | 23 +- 5 files changed, 41 insertions(+), 1919 deletions(-) delete mode 100755 app/assets/javascripts/KeyTable.js delete mode 100755 app/assets/javascripts/gradesheet.js rename app/assets/javascripts/{gradesheet1.js.erb => gradesheet.js.erb} (91%) diff --git a/app/assets/javascripts/KeyTable.js b/app/assets/javascripts/KeyTable.js deleted file mode 100755 index 1d0903f22..000000000 --- a/app/assets/javascripts/KeyTable.js +++ /dev/null @@ -1,1138 +0,0 @@ -/* - * File: KeyTable.js - * Version: 1.1.7 - * CVS: $Idj$ - * Description: Keyboard navigation for HTML tables - * Author: Allan Jardine (www.sprymedia.co.uk) - * Created: Fri Mar 13 21:24:02 GMT 2009 - * Modified: $Date$ by $Author$ - * Language: Javascript - * License: GPL v2 or BSD 3 point style - * Project: Just a little bit of fun :-) - * Contact: www.sprymedia.co.uk/contact - * - * Copyright 2009-2011 Allan Jardine, all rights reserved. - * - * This source file is free software, under either the GPL v2 license or a - * BSD style license, available at: - * http://datatables.net/license_gpl2 - * http://datatables.net/license_bsd - */ - - -function KeyTable ( oInit ) -{ - /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * API parameters - * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ - - /* - * Variable: block - * Purpose: Flag whether or not KeyTable events should be processed - * Scope: KeyTable - public - */ - this.block = false; - - /* - * Variable: event - * Purpose: Container for all event application methods - * Scope: KeyTable - public - * Notes: This object contains all the public methods for adding and removing events - these - * are dynamically added later on - */ - this.event = { - "remove": {} - }; - - /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * API methods - * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ - - /* - * Function: fnGetCurrentPosition - * Purpose: Get the currently focused cell's position - * Returns: array int: [ x, y ] - * Inputs: void - */ - this.fnGetCurrentPosition = function () - { - return [ _iOldX, _iOldY ]; - }; - - - /* - * Function: fnGetCurrentData - * Purpose: Get the currently focused cell's data (innerHTML) - * Returns: string: - data requested - * Inputs: void - */ - this.fnGetCurrentData = function () - { - return _nOldFocus.innerHTML; - }; - - - /* - * Function: fnGetCurrentTD - * Purpose: Get the currently focused cell - * Returns: node: - focused element - * Inputs: void - */ - this.fnGetCurrentTD = function () - { - return _nOldFocus; - }; - - - /* - * Function: fnSetPosition - * Purpose: Set the position of the focused cell - * Returns: - - * Inputs: int:x - x coordinate - * int:y - y coordinate - * Notes: Thanks to Rohan Daxini for the basis of this function - */ - this.fnSetPosition = function( x, y ) - { - if ( typeof x == 'object' && x.nodeName ) - { - _fnSetFocus( x ); - } - else - { - _fnSetFocus( _fnCellFromCoords(x, y) ); - } - }; - - - /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * Private parameters - * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ - - /* - * Variable: _nBody - * Purpose: Body node of the table - cached for renference - * Scope: KeyTable - private - */ - var _nBody = null; - - /* - * Variable: - * Purpose: - * Scope: KeyTable - private - */ - var _nOldFocus = null; - - /* - * Variable: _iOldX and _iOldY - * Purpose: X and Y coords of the old elemet that was focused on - * Scope: KeyTable - private - */ - var _iOldX = null; - var _iOldY = null; - - /* - * Variable: _that - * Purpose: Scope saving for 'this' after a jQuery event - * Scope: KeyTable - private - */ - var _that = null; - - /* - * Variable: sFocusClass - * Purpose: Class that should be used for focusing on a cell - * Scope: KeyTable - private - */ - var _sFocusClass = "focus"; - - /* - * Variable: _bKeyCapture - * Purpose: Flag for should KeyTable capture key events or not - * Scope: KeyTable - private - */ - var _bKeyCapture = false; - - /* - * Variable: _oaoEvents - * Purpose: Event cache object, one array for each supported event for speed of searching - * Scope: KeyTable - private - */ - var _oaoEvents = { - "action": [], - "esc": [], - "focus": [], - "blur": [] - }; - - /* - * Variable: _oDatatable - * Purpose: DataTables object for if we are actually using a DataTables table - * Scope: KeyTable - private - */ - var _oDatatable = null; - - var _bForm; - var _nInput; - var _bInputFocused = false; - - - /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * Private methods - * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ - - /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * Key table events - */ - - /* - * Function: _fnEventAddTemplate - * Purpose: Create a function (with closure for sKey) event addition API - * Returns: function: - template function - * Inputs: string:sKey - type of event to detect - */ - function _fnEventAddTemplate( sKey ) - { - /* - * Function: - - * Purpose: API function for adding event to cache - * Returns: - - * Inputs: 1. node:x - target node to add event for - * 2. function:y - callback function to apply - * or - * 1. int:x - x coord. of target cell (can be null for live events) - * 2. int:y - y coord. of target cell (can be null for live events) - * 3. function:z - callback function to apply - * Notes: This function is (interally) overloaded (in as much as javascript allows for - * that) - the target cell can be given by either node or coords. - */ - return function ( x, y, z ) { - if ( (x===null || typeof x == "number") && - (y===null || typeof y == "number") && - typeof z == "function" ) - { - _fnEventAdd( sKey, x, y, z ); - } - else if ( typeof x == "object" && typeof y == "function" ) - { - var aCoords = _fnCoordsFromCell( x ); - _fnEventAdd( sKey, aCoords[0], aCoords[1], y ); - } - else - { - alert( "Unhandable event type was added: x" +x+ " y:" +y+ " z:" +z ); - } - }; - } - - - /* - * Function: _fnEventRemoveTemplate - * Purpose: Create a function (with closure for sKey) event removal API - * Returns: function: - template function - * Inputs: string:sKey - type of event to detect - */ - function _fnEventRemoveTemplate( sKey ) - { - /* - * Function: - - * Purpose: API function for removing event from cache - * Returns: int: - number of events removed - * Inputs: 1. node:x - target node to remove event from - * 2. function:y - callback function to apply - * or - * 1. int:x - x coord. of target cell (can be null for live events) - * 2. int:y - y coord. of target cell (can be null for live events) - * 3. function:z - callback function to remove - optional - * Notes: This function is (interally) overloaded (in as much as javascript allows for - * that) - the target cell can be given by either node or coords and the function - * to remove is optional - */ - return function ( x, y, z ) { - if ( (x===null || typeof arguments[0] == "number") && - (y===null || typeof arguments[1] == "number" ) ) - { - if ( typeof arguments[2] == "function" ) - { - _fnEventRemove( sKey, x, y, z ); - } - else - { - _fnEventRemove( sKey, x, y ); - } - } - else if ( typeof arguments[0] == "object" ) - { - var aCoords = _fnCoordsFromCell( x ); - if ( typeof arguments[1] == "function" ) - { - _fnEventRemove( sKey, aCoords[0], aCoords[1], y ); - } - else - { - _fnEventRemove( sKey, aCoords[0], aCoords[1] ); - } - } - else - { - alert( "Unhandable event type was removed: x" +x+ " y:" +y+ " z:" +z ); - } - }; - } - - /* Use the template functions to add the event API functions */ - for ( var sKey in _oaoEvents ) - { - if ( sKey ) - { - this.event[sKey] = _fnEventAddTemplate( sKey ); - this.event.remove[sKey] = _fnEventRemoveTemplate( sKey ); - } - } - - - /* - * Function: _fnEventAdd - * Purpose: Add an event to the internal cache - * Returns: - - * Inputs: string:sType - type of event to add, given by the available elements in _oaoEvents - * int:x - x-coords to add event to - can be null for "blanket" event - * int:y - y-coords to add event to - can be null for "blanket" event - * function:fn - callback function for when triggered - */ - function _fnEventAdd( sType, x, y, fn ) - { - _oaoEvents[sType].push( { - "x": x, - "y": y, - "fn": fn - } ); - } - - - /* - * Function: _fnEventRemove - * Purpose: Remove an event from the event cache - * Returns: int: - number of matching events removed - * Inputs: string:sType - type of event to look for - * node:nTarget - target table cell - * function:fn - optional - remove this function. If not given all handlers of this - * type will be removed - */ - function _fnEventRemove( sType, x, y, fn ) - { - var iCorrector = 0; - - for ( var i=0, iLen=_oaoEvents[sType].length ; i= oSettings.fnDisplayEnd() ) - { - if ( oSettings._iDisplayLength >= 0 ) - { - /* Make sure we are not over running the display array */ - if ( oSettings._iDisplayStart + oSettings._iDisplayLength < oSettings.fnRecordsDisplay() ) - { - oSettings._iDisplayStart += oSettings._iDisplayLength; - } - } - else - { - oSettings._iDisplayStart = 0; - } - _oDatatable.oApi._fnCalculateEnd( oSettings ); - } - - /* Page backwards */ - while ( iRow < oSettings._iDisplayStart ) - { - oSettings._iDisplayStart = oSettings._iDisplayLength>=0 ? - oSettings._iDisplayStart - oSettings._iDisplayLength : - 0; - - if ( oSettings._iDisplayStart < 0 ) - { - oSettings._iDisplayStart = 0; - } - _oDatatable.oApi._fnCalculateEnd( oSettings ); - } - - /* Re-draw the table */ - // AUTOLAB - // since we don't use paging - //_oDatatable.oApi._fnDraw( oSettings ); - - /* Restore the key capture */ - _bKeyCapture = bKeyCaptureCache; - } - - /* Cache the information that we are interested in */ - var aNewPos = _fnCoordsFromCell( nTarget ); - _nOldFocus = nTarget; - _iOldX = aNewPos[0]; - _iOldY = aNewPos[1]; - - var iViewportHeight, iViewportWidth, iScrollTop, iScrollLeft, iHeight, iWidth, aiPos; - if ( bAutoScroll ) - { - /* Scroll the viewport such that the new cell is fully visible in the rendered window */ - iViewportHeight = document.documentElement.clientHeight; - iViewportWidth = document.documentElement.clientWidth; - iScrollTop = document.body.scrollTop || document.documentElement.scrollTop; - iScrollLeft = document.body.scrollLeft || document.documentElement.scrollLeft; - iHeight = nTarget.offsetHeight; - iWidth = nTarget.offsetWidth; - aiPos = _fnGetPos( nTarget ); - - /* Take account of scrolling in DataTables 1.7 - remove scrolling since that would add to - * the positioning calculation - */ - if ( _oDatatable && typeof oSettings.oScroll != 'undefined' && - (oSettings.oScroll.sX !== "" || oSettings.oScroll.sY !== "") ) - { - aiPos[1] -= jQuery(oSettings.nTable.parentNode).scrollTop(); - aiPos[0] -= jQuery(oSettings.nTable.parentNode).scrollLeft(); - } - - /* Correct viewport positioning for vertical scrolling */ - if ( aiPos[1]+iHeight > iScrollTop+iViewportHeight ) - { - /* Displayed element if off the bottom of the viewport */ - _fnSetScrollTop( aiPos[1]+iHeight - iViewportHeight ); - } - else if ( aiPos[1] < iScrollTop ) - { - /* Displayed element if off the top of the viewport */ - _fnSetScrollTop( aiPos[1] ); - } - - /* Correct viewport positioning for horizontal scrolling */ - if ( aiPos[0]+iWidth > iScrollLeft+iViewportWidth ) - { - /* Displayed element is off the bottom of the viewport */ - _fnSetScrollLeft( aiPos[0]+iWidth - iViewportWidth ); - } - else if ( aiPos[0] < iScrollLeft ) - { - /* Displayed element if off the Left of the viewport */ - _fnSetScrollLeft( aiPos[0] ); - } - } - - /* Take account of scrolling in DataTables 1.7 */ - if ( _oDatatable && typeof oSettings.oScroll != 'undefined' && - (oSettings.oScroll.sX !== "" || oSettings.oScroll.sY !== "") ) - { - var dtScrollBody = oSettings.nTable.parentNode; - iViewportHeight = dtScrollBody.clientHeight; - iViewportWidth = dtScrollBody.clientWidth; - iScrollTop = dtScrollBody.scrollTop; - iScrollLeft = dtScrollBody.scrollLeft; - iHeight = nTarget.offsetHeight; - iWidth = nTarget.offsetWidth; - - /* Correct for vertical scrolling */ - if ( nTarget.offsetTop + iHeight > iViewportHeight+iScrollTop ) - { - dtScrollBody.scrollTop = (nTarget.offsetTop + iHeight) - iViewportHeight; - } - else if ( nTarget.offsetTop < iScrollTop ) - { - dtScrollBody.scrollTop = nTarget.offsetTop; - } - - /* Correct for horizontal scrolling */ - if ( nTarget.offsetLeft + iWidth > iViewportWidth+iScrollLeft ) - { - dtScrollBody.scrollLeft = (nTarget.offsetLeft + iWidth) - iViewportWidth; - } - else if ( nTarget.offsetLeft < iScrollLeft ) - { - dtScrollBody.scrollLeft = nTarget.offsetLeft; - } - } - - /* Focused - so we want to capture the keys */ - _fnCaptureKeys(); - - /* Fire of the focus event if there is one */ - _fnEventFire( "focus", _iOldX, _iOldY ); - } - - - /* - * Function: _fnBlur - * Purpose: Blur focus from the whole table - * Returns: - - * Inputs: - - */ - function _fnBlur() - { - _fnRemoveFocus( _nOldFocus ); - _iOldX = null; - _iOldY = null; - _nOldFocus = null; - _fnReleaseKeys(); - } - - // AUTOLAB - this.fnBlur = _fnBlur - - - /* - * Function: _fnRemoveFocus - * Purpose: Remove focus from a cell and fire any blur events which are attached - * Returns: - - * Inputs: node:nTarget - cell of interest - */ - function _fnRemoveFocus( nTarget ) - { - jQuery(nTarget).removeClass( _sFocusClass ); - jQuery(nTarget).parent().removeClass( _sFocusClass ); - _fnEventFire( "blur", _iOldX, _iOldY ); - } - - - /* - * Function: _fnClick - * Purpose: Focus on the element that has been clicked on by the user - * Returns: - - * Inputs: event:e - click event - */ - function _fnClick ( e ) - { - var nTarget = this; - while ( nTarget.nodeName != "TD" ) - { - nTarget = nTarget.parentNode; - } - - _fnSetFocus( nTarget ); - _fnCaptureKeys(); - } - - - - /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * Key events - */ - - /* - * Function: _fnKey - * Purpose: Deal with a key events, be it moving the focus or return etc. - * Returns: bool: - allow browser default action - * Inputs: event:e - key event - */ - function _fnKey ( e ) - { - /* If user or system has blocked KeyTable from doing anything, just ignore this event */ - if ( _that.block || !_bKeyCapture ) - { - return true; - } - - /* If a modifier key is pressed (exapct shift), ignore the event */ - if ( e.metaKey || e.altKey || e.ctrlKey ) - { - return true; - } - var - x, y, - iTableWidth = _nBody.getElementsByTagName('tr')[0].getElementsByTagName('td').length, - iTableHeight; - - if ( oInit.num < 0) { - oInit.num = iTableWidth - oInit.start - } - - /* Get table height and width - done here so as to be dynamic (if table is updated) */ - if ( _oDatatable ) - { - /* - * Locate the current node in the DataTable overriding the old positions - the reason for - * is is that there might have been some DataTables interaction between the last focus and - * now - */ - var oSettings = _oDatatable.fnSettings(); - iTableHeight = oSettings.aiDisplay.length; - - var aDtPos = _fnFindDtCell( _nOldFocus ); - if ( aDtPos === null ) - { - /* If the table has been updated such that the focused cell can't be seen - do nothing */ - return; - } - _iOldX = aDtPos[ 0 ]; - _iOldY = aDtPos[ 1 ]; - } - else - { - iTableHeight = _nBody.getElementsByTagName('tr').length; - } - - /* Capture shift+tab to match the left arrow key */ - var iKey = (e.keyCode == 9 && e.shiftKey) ? -1 : e.keyCode; - - switch( iKey ) - { - case 13: /* return */ - e.preventDefault(); - e.stopPropagation(); - _fnEventFire( "action", _iOldX, _iOldY ); - return true; - - case 27: /* esc */ - if ( !_fnEventFire( "esc", _iOldX, _iOldY ) ) - { - /* Only lose focus if there isn't an escape handler on the cell */ - _fnBlur(); - return; - } - x = _iOldX; - y = _iOldY; - break; - - case -1: - case 37: /* left arrow */ - // AUTOLAB - if ( _iOldX > oInit.start) { - x = _iOldX - 1; - y = _iOldY; - } else if ( _iOldY > 0 ) { - //x = iTableWidth-1; - x = oInit.start + oInit.num - 1 - y = _iOldY - 1; - } else { - /* at start of table */ - if ( iKey == -1 && _bForm ) - { - /* If we are in a form, return focus to the 'input' element such that tabbing will - * follow correctly in the browser - */ - _bInputFocused = true; - _nInput.focus(); - - /* This timeout is a little nasty - but IE appears to have some asyhnc behaviour for - * focus - */ - setTimeout( function(){ _bInputFocused = false; }, 0 ); - _bKeyCapture = false; - _fnBlur(); - return true; - } - else - { - return false; - } - } - break; - - case 38: /* up arrow */ - if ( _iOldY > 0 ) { - x = _iOldX; - y = _iOldY - 1; - } else { - return false; - } - break; - - case 9: /* tab */ - case 39: /* right arrow */ - // AUTOLAB - if ( _iOldX < oInit.start + oInit.num - 1) { - //if ( _iOldX < iTableWidth-1 ) { - x = _iOldX + 1; - y = _iOldY; - } else if ( _iOldY < iTableHeight-1 ) { - // AUTOLAB - x = oInit.start; - y = _iOldY + 1; - } else { - /* at end of table */ - if ( iKey == 9 && _bForm ) - { - /* If we are in a form, return focus to the 'input' element such that tabbing will - * follow correctly in the browser - */ - _bInputFocused = true; - _nInput.focus(); - - /* This timeout is a little nasty - but IE appears to have some asyhnc behaviour for - * focus - */ - setTimeout( function(){ _bInputFocused = false; }, 0 ); - _bKeyCapture = false; - _fnBlur(); - return true; - } - else - { - return false; - } - } - break; - - case 40: /* down arrow */ - if ( _iOldY < iTableHeight-1 ) { - x = _iOldX; - y = _iOldY + 1; - } else { - return false; - } - break; - - default: /* Nothing we are interested in */ - return true; - } - - _fnSetFocus( _fnCellFromCoords(x, y) ); - return false; - } - - - /* - * Function: _fnCaptureKeys - * Purpose: Start capturing key events for this table - * Returns: - - * Inputs: - - */ - function _fnCaptureKeys( ) - { - if ( !_bKeyCapture ) - { - _bKeyCapture = true; - } - } - - - /* - * Function: _fnReleaseKeys - * Purpose: Stop capturing key events for this table - * Returns: - - * Inputs: - - */ - function _fnReleaseKeys( ) - { - _bKeyCapture = false; - } - - - - /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * Support functions - */ - - /* - * Function: _fnCellFromCoords - * Purpose: Calulate the target TD cell from x and y coordinates - * Returns: node: - TD target - * Inputs: int:x - x coordinate - * int:y - y coordinate - */ - function _fnCellFromCoords( x, y ) - { - if ( _oDatatable ) - { - var oSettings = _oDatatable.fnSettings(); - if ( typeof oSettings.aoData[ oSettings.aiDisplay[ y ] ] != 'undefined' ) - { - // AUTOLAB - return jQuery(oSettings.aoData[ oSettings.aiDisplay[ y ] ].nTr).children('td')[x]; - //return oSettings.aoData[ oSettings.aiDisplay[ y ] ].nTr.getElementsByTagName('td')[x]; - } - else - { - return null; - } - } - else - { - return jQuery('tr:eq('+y+')>td:eq('+x+')', _nBody )[0]; - } - } - - - /* - * Function: _fnCoordsFromCell - * Purpose: Calculate the x and y position in a table from a TD cell - * Returns: array[2] int: [x, y] - * Inputs: node:n - TD cell of interest - * Notes: Not actually interested in this for DataTables since it might go out of date - */ - function _fnCoordsFromCell( n ) - { - if ( _oDatatable ) - { - var oSettings = _oDatatable.fnSettings(); - return [ - jQuery('td', n.parentNode).index(n), - jQuery('tr', n.parentNode.parentNode).index(n.parentNode) + oSettings._iDisplayStart - ]; - } - else - { - return [ - jQuery('td', n.parentNode).index(n), - jQuery('tr', n.parentNode.parentNode).index(n.parentNode) - ]; - } - } - - - /* - * Function: _fnSetScrollTop - * Purpose: Set the vertical scrolling position - * Returns: - - * Inputs: int:iPos - scrolltop - * Notes: This is so nasty, but without browser detection you can't tell which you should set - * So on browsers that support both, the scroll top will be set twice. I can live with - * that :-) - */ - function _fnSetScrollTop( iPos ) - { - document.documentElement.scrollTop = iPos; - document.body.scrollTop = iPos; - } - - - /* - * Function: _fnSetScrollLeft - * Purpose: Set the horizontal scrolling position - * Returns: - - * Inputs: int:iPos - scrollleft - */ - function _fnSetScrollLeft( iPos ) - { - document.documentElement.scrollLeft = iPos; - document.body.scrollLeft = iPos; - } - - - /* - * Function: _fnGetPos - * Purpose: Get the position of an object on the rendered page - * Returns: array[2] int: [left, right] - * Inputs: node:obj - element of interest - */ - function _fnGetPos ( obj ) - { - var iLeft = 0; - var iTop = 0; - - if (obj.offsetParent) - { - iLeft = obj.offsetLeft; - iTop = obj.offsetTop; - obj = obj.offsetParent; - while (obj) - { - iLeft += obj.offsetLeft; - iTop += obj.offsetTop; - obj = obj.offsetParent; - } - } - return [iLeft,iTop]; - } - - - /* - * Function: _fnFindDtCell - * Purpose: Get the coords. of a cell from the DataTables internal information - * Returns: array[2] int: [x, y] coords. or null if not found - * Inputs: node:nTarget - the node of interest - */ - function _fnFindDtCell( nTarget ) - { - var oSettings = _oDatatable.fnSettings(); - for ( var i=0, iLen=oSettings.aiDisplay.length ; i