src/cm/media/js/client/c_toc.js
author gibus
Fri, 11 May 2012 13:10:19 +0200
changeset 422 37cd1c72115d
parent 421 3ddbfa64f596
child 423 db95e6b3fc6e
permissions -rw-r--r--
Hides button if table of contents is empty.
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
      'position':[CY.WidgetPositionExt.TL, CY.WidgetPositionExt.TL],
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     6
      'tocId':CY.guid(),
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
     7
      'tocTitleId':CY.guid(),
422
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
     8
      'closeBtnId':CY.guid(),
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
     9
      'empty': false
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    10
  } ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    11
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    12
  var overlayHtml = {};
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    13
  overlayHtml['headerContent'] = '<div id="' + gToc['tocId'] + '"><h3 id="' + gToc['tocTitleId'] + '"></h3>';
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    14
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    15
  var toBeTOCced = getElementsByTagNames('h2,h3,h4,h5,h6', document.getElementById('maincontainer'));
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    16
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    17
  var content = document.createElement('div');
422
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    18
  if (toBeTOCced.length >= 2) {
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    19
    for (var i=0;i<toBeTOCced.length;i++) {
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    20
	  	var tmp = document.createElement('a');
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    21
		  tmp.innerHTML = toBeTOCced[i].innerHTML;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    22
  		tmp.className = 'page indent' + toBeTOCced[i].nodeName;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    23
	  	content.appendChild(tmp);
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    24
		  var headerId = toBeTOCced[i].id || 'link' + i;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    25
  		tmp.href = '#' + headerId;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    26
	  	toBeTOCced[i].id = headerId;
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
  }
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    29
  else {
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    30
    content.innerHTML = '';
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    31
    gToc['empty'] = true;
37cd1c72115d Hides button if table of contents is empty.
gibus
parents: 421
diff changeset
    32
  }
421
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    33
  overlayHtml['bodyContent'] = content.innerHTML;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    34
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    35
  var width = gLayout.getTopICommentsWidth() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    36
  
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    37
  var overlay = new CY.Overlay( {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    38
    zIndex :3,
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    39
    shim :false, // until we really need it, no shim 
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    40
    visible :false,
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    41
    headerContent :overlayHtml['headerContent'],
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    42
    bodyContent :overlayHtml['bodyContent'],
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    43
    xy :[10,10],
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    44
    width : width
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    45
  });
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    46
  overlay.get('contentBox').addClass("c-toc") ;
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);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    74
  document.getElementsByClassName('c-toc')[0].style.width = width + 'px';
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    75
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    76
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    77
toggleTocFn = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    78
  if (isTocVisible())
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    79
    hideToc();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    80
  else
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    81
    showToc();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    82
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    83
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    84
hideToc = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    85
  gToc['overlay'].hide();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    86
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    87
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    88
onTocHideAnimEnd = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    89
//  iComment['overlay'].blur() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    90
  this.overlay.hide() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    91
  gSync.resume() ;    
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    92
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    93
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    94
onTocShowAnimEnd = function() {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    95
  gSync.resume() ;    
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    96
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    97
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    98
showToc= function () {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
    99
  removeFormErrMsg(gToc['tocId']) ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   100
  gIComments.hide() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   101
  positionToc() ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   102
  gToc['overlay'].show();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   103
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   104
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   105
isTocVisible = function () {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   106
  if (gToc != null)
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   107
    return gToc['overlay'].get('visible') ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   108
  return false ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   109
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   110
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   111
positionToc = function () {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   112
  if (gToc != null) { 
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   113
    var overlay = gToc['overlay'] ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   114
    var boundingBox = overlay.get('boundingBox') ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   115
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   116
    var commentFormHeight = boundingBox.get('offsetHeight') ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   117
    var windowHeight = boundingBox.get('winHeight') ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   118
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   119
    var pos = gToc['position'] ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   120
    if (commentFormHeight > windowHeight) // trying to have save comment visible ... :
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   121
      pos = [CY.WidgetPositionExt.BL, CY.WidgetPositionExt.BL] ;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   122
    
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   123
    overlay.set("align", {points:pos});
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   124
    if (commentFormHeight <= windowHeight)
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   125
      overlay.set("y", overlay.get("y") + 30);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   126
    boundingBox.setX(boundingBox.getX() + gConf['iCommentLeftPadding']);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   127
  }
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   128
}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   129
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   130
function getElementsByTagNames(list,obj) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   131
	if (!obj) var obj = document;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   132
	var tagNames = list.split(',');
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   133
	var resultArray = new Array();
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   134
	for (var i=0;i<tagNames.length;i++) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   135
		var tags = obj.getElementsByTagName(tagNames[i]);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   136
		for (var j=0;j<tags.length;j++) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   137
			resultArray.push(tags[j]);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   138
		}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   139
	}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   140
	var testNode = resultArray[0];
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   141
	if (!testNode) return [];
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   142
	if (testNode.sourceIndex) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   143
		resultArray.sort(function (a,b) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   144
				return a.sourceIndex - b.sourceIndex;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   145
		});
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   146
	}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   147
	else if (testNode.compareDocumentPosition) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   148
		resultArray.sort(function (a,b) {
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   149
				return 3 - (a.compareDocumentPosition(b) & 6);
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   150
		});
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   151
	}
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   152
	return resultArray;
3ddbfa64f596 Adds a table of content.
gibus
parents:
diff changeset
   153
}