src/cm/media/js/client/c_toc.js
author gibus
Mon, 14 May 2012 10:15:01 +0200
changeset 425 d70552fc1a66
parent 424 2f9108930e47
child 440 0d2d10bc47bd
permissions -rw-r--r--
Fix some javascript error with IE8 (getElementsByClassName() is unknown).
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     1
gToc = null ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     2
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     3
instanciateToc = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     4
  gToc = {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     5
      'tocId':CY.guid(),
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     6
      'tocTitleId':CY.guid(),
422
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
     7
      'closeBtnId':CY.guid(),
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
     8
      'empty': false
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     9
  } ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    10
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    11
  var overlayHtml = {};
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    12
  overlayHtml['headerContent'] = '<div id="' + gToc['tocId'] + '"><h3 id="' + gToc['tocTitleId'] + '"></h3>';
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    13
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    14
  var toBeTOCced = getElementsByTagNames('h2,h3,h4,h5,h6', document.getElementById('maincontainer'));
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    15
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    16
  var content = document.createElement('div');
422
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    17
  if (toBeTOCced.length >= 2) {
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    18
    for (var i=0;i<toBeTOCced.length;i++) {
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    19
	  	var tmp = document.createElement('a');
424
2f9108930e47 Removes <a> tags inside toc + adjusts height of toc.
gibus
parents: 423
diff changeset
    20
		  tmp.innerHTML = toBeTOCced[i].innerHTML.replace(/<\/?a[^>]*>/g,'');
422
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    21
  		tmp.className = 'page indent' + toBeTOCced[i].nodeName;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    22
	  	content.appendChild(tmp);
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    23
		  var headerId = toBeTOCced[i].id || 'link' + i;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    24
  		tmp.href = '#' + headerId;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    25
	  	toBeTOCced[i].id = headerId;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    26
    }
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    27
  }
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    28
  else {
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    29
    content.innerHTML = '';
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    30
    gToc['empty'] = true;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    31
  }
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    32
  overlayHtml['bodyContent'] = content.innerHTML;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    33
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    34
  var width = gLayout.getTopICommentsWidth() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    35
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    36
  var overlay = new CY.Overlay( {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    37
    zIndex :3,
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    38
    shim :false, // until we really need it, no shim 
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    39
    visible :false,
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    40
    headerContent :overlayHtml['headerContent'],
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    41
    bodyContent :overlayHtml['bodyContent'],
423
db95e6b3fc6e Better positionning of table of contents.
gibus
parents: 422
diff changeset
    42
    xy :[3,30],
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    43
    width : width
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    44
  });
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    45
  overlay.get('contentBox').addClass("c-toc") ;
424
2f9108930e47 Removes <a> tags inside toc + adjusts height of toc.
gibus
parents: 423
diff changeset
    46
  overlay.get('contentBox').set("id", "the-toc") ;
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    47
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    48
  // attach to DOM
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    49
  overlay.render('#leftcolumn');
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    50
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    51
  CY.get("#"+gToc['tocTitleId']).set('innerHTML', gettext('Table of contents')) ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    52
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    53
  gToc['overlay'] = overlay ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    54
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    55
  var animationHide = null ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    56
  animationHide = new CY.Anim({
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    57
        node: overlay.get('boundingBox'),
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    58
        duration: .3, //gPrefs['general']['animduration'],
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    59
        easing: CY.Easing.easeOut
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    60
    });   
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    61
  gToc['animationHide'] = animationHide ; 
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    62
  animationHide.set('to', { opacity: 0});// height : 0 doesn't work
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    63
  gToc['animationHide-handle'] = animationHide.on('end', onTocHideAnimEnd, gToc);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    64
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    65
  var animationShow = null ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    66
  animationShow = new CY.Anim({
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    67
        node: overlay.get('boundingBox'),
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    68
        duration: .3, //gPrefs['general']['animduration'],
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    69
        easing: CY.Easing.easeOut
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    70
    });   
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    71
  gToc['animationShow'] = animationShow ; 
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    72
  animationShow.set('to', { opacity: 1});
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    73
  gToc['animationShow-handle'] = animationShow.on('end', onTocShowAnimEnd, gToc);
425
d70552fc1a66 Fix some javascript error with IE8 (getElementsByClassName() is unknown).
gibus
parents: 424
diff changeset
    74
  if (typeof document.getElementsByClassName!='function') {
d70552fc1a66 Fix some javascript error with IE8 (getElementsByClassName() is unknown).
gibus
parents: 424
diff changeset
    75
    document.querySelectorAll('.c-toc')[0].style.width = width + 'px';
d70552fc1a66 Fix some javascript error with IE8 (getElementsByClassName() is unknown).
gibus
parents: 424
diff changeset
    76
  }
d70552fc1a66 Fix some javascript error with IE8 (getElementsByClassName() is unknown).
gibus
parents: 424
diff changeset
    77
  else {
d70552fc1a66 Fix some javascript error with IE8 (getElementsByClassName() is unknown).
gibus
parents: 424
diff changeset
    78
    document.getElementsByClassName('c-toc')[0].style.width = width + 'px';
d70552fc1a66 Fix some javascript error with IE8 (getElementsByClassName() is unknown).
gibus
parents: 424
diff changeset
    79
  }
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    80
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    81
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    82
toggleTocFn = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    83
  if (isTocVisible())
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    84
    hideToc();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    85
  else
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    86
    showToc();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    87
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    88
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    89
hideToc = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    90
  gToc['overlay'].hide();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    91
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    92
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    93
onTocHideAnimEnd = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    94
//  iComment['overlay'].blur() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    95
  this.overlay.hide() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    96
  gSync.resume() ;    
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    97
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    98
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    99
onTocShowAnimEnd = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   100
  gSync.resume() ;    
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   101
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   102
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   103
showToc= function () {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   104
  removeFormErrMsg(gToc['tocId']) ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   105
  gIComments.hide() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   106
  gToc['overlay'].show();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   107
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   108
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   109
isTocVisible = function () {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   110
  if (gToc != null)
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   111
    return gToc['overlay'].get('visible') ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   112
  return false ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   113
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   114
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   115
function getElementsByTagNames(list,obj) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   116
	if (!obj) var obj = document;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   117
	var tagNames = list.split(',');
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   118
	var resultArray = new Array();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   119
	for (var i=0;i<tagNames.length;i++) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   120
		var tags = obj.getElementsByTagName(tagNames[i]);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   121
		for (var j=0;j<tags.length;j++) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   122
			resultArray.push(tags[j]);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   123
		}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   124
	}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   125
	var testNode = resultArray[0];
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   126
	if (!testNode) return [];
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   127
	if (testNode.sourceIndex) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   128
		resultArray.sort(function (a,b) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   129
				return a.sourceIndex - b.sourceIndex;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   130
		});
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   131
	}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   132
	else if (testNode.compareDocumentPosition) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   133
		resultArray.sort(function (a,b) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   134
				return 3 - (a.compareDocumentPosition(b) & 6);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   135
		});
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   136
	}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   137
	return resultArray;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   138
}