From cc26ae1dd412ffa7db114f4635477b1988df8013 Mon Sep 17 00:00:00 2001 From: Ingo Schommer Date: Sat, 15 Sep 2007 01:14:16 +0000 Subject: [PATCH] elofgren: Use Effect.ReSize? to add smooth resizing to left sidebar sections in 'Site Content' section. (merged from branches/gsoc) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/trunk@41884 467b73ca-7a2a-4603-9d3b-597d59a354a9 --- javascript/SideTabs.js | 81 +++++++++++++++++++++++++++++++++++++----- 1 file changed, 72 insertions(+), 9 deletions(-) diff --git a/javascript/SideTabs.js b/javascript/SideTabs.js index abc87a61..c7fdb3e6 100755 --- a/javascript/SideTabs.js +++ b/javascript/SideTabs.js @@ -1,3 +1,57 @@ +// script.aculo.us EffectResize.js +// Copyright(c) 2007 - Frost Innovation AS, http://ajaxwidgets.com +// +// EffectResize.js is freely distributable under the terms of an MIT-style license. +// For details, see the script.aculo.us web site: http://script.aculo.us/ +// +// From: http://wiki.script.aculo.us/scriptaculous/show/Effect+Resize+Extension +// Modified to work with Prototype 1.4.0_rc3 + +/* Helper Effect for resizing elements... + */ +Effect.ReSize = Class.create(); +Object.extend(Object.extend(Effect.ReSize.prototype, Effect.Base.prototype), { + initialize: function(element) { + this.element = element; + if(!this.element) throw(Effect._elementDoesNotExistError); + var options = Object.extend({ amount: 100, direction: 'vert', toSize:null }, arguments[1] || {}); + if( options.direction == 'vert' ) + this.originalSize = options.originalSize || parseInt(this.element.style.height); + else + this.originalSize = options.originalSize || parseInt(this.element.style.width); + + if( options.toSize != null ) { + options.amount = options.toSize - this.originalSize; + } + + this.start(options); + }, + + setup: function() { + // Prevent executing on elements not in the layout flow + if(this.element.style.display == 'none') { this.cancel(); return; } + }, + + update: function(position) { + if( this.options.direction == 'vert' ) { + this.element.style.height = this.originalSize+(this.options.amount*position)+'px'; + } else { + this.element.style.width = this.originalSize+(this.options.amount*position)+'px'; + } + }, + + finish: function() { + if( this.options.direction == 'vert' ) { + this.element.style.height = this.originalSize+this.options.amount+'px'; + // Modification to make 'Page Version History' resize correctly: + if(this.element.onresize) this.element.onresize(); + } else { + this.element.style.width = this.originalSize+this.options.amount+'px'; + } + } +}); +// End: script.aculo.us EffectResize.js + SideTabs = Class.create(); SideTabs.prototype = { /** @@ -15,30 +69,38 @@ SideTabs.prototype = { }, /** - * Fix all the panes' sizes in reponse to one being opened or closed + * Fix all the panes' sizes in response to one being opened or closed + * + * @param useEffect boolean Use smooth resizing effect */ - resize: function() { + resize: function(useEffect) { var i,numOpenPanes=0,otherPanes = []; for(i=0;i 0) { - $('left').show(); + // We no longer hide the left frame + // $('left').show(); var totalHeight = getFittingHeight(this.tabs[0].linkedPane, 0, otherPanes); var eachHeight = totalHeight / numOpenPanes; for(i=0;i