web/static/res/js/incresize.js
author Edwin Razafimahatratra <edwin@robotalismsoft.com>
Wed, 12 Dec 2012 15:54:57 +0100
changeset 48 d92196482ad9
parent 42 01415303372e
child 78 8c3f0b94d056
permissions -rw-r--r--
tweaks
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
36
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     1
function IncResize()
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     2
{
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     3
	this.content;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     4
	this.top;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     5
	this.middle;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     6
	this.middleContainer;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     7
	this.bottom;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     8
	this.footer;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
     9
	this.minTopBottomHeight;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    10
	this.ratio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    11
	this.preMiddleSizeFunc;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    12
	this.postMiddleSizeFunc;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    13
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    14
	this.init = function(contantId, topId, middleId, bottomId, footerId, minTopBottomHeight, ratio, preMiddleSizeFunc, postMiddleSizeFunc)
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    15
	{
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    16
		this.content = $('#' + contantId);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    17
		if (topId != null) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    18
			this.top = $('#' + topId); 			
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    19
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    20
		this.middle = $('#' + middleId); 
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    21
		this.middleContainer = $(this.middle).parent();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    22
		if (bottomId != null) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    23
			this.bottom = $('#' + bottomId);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    24
		}
42
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    25
		if (footerId != null) {
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    26
			this.footer =  $('#' + footerId);
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    27
		}
36
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    28
		this.minTopBottomHeight = minTopBottomHeight;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    29
		this.ratio = ratio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    30
		this.preMiddleSizeFunc = preMiddleSizeFunc;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    31
		this.postMiddleSizeFunc = postMiddleSizeFunc;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    32
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    33
		$(window).resize(this.resizeElements);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    34
		window.onorientationchange = function() {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    35
			incResize.resizeElements();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    36
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    37
	};
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    38
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    39
	this.resizeElements = function()
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    40
	{
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    41
		var self = incResize;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    42
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    43
		// Compute maximun middle element height
42
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    44
		var heightForTopMiddleBotom = $(self.content).height() - 70;
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    45
		if (self.footer !== undefined) {
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    46
			heightForTopMiddleBotom -= $(self.footer).height()			
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    47
		}
36
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    48
		var maxMiddleHeight = heightForTopMiddleBotom - self.minTopBottomHeight * 2;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    49
42
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    50
		// Get the middle element parent width and test if it is not to big (to let place for top and bottom without adding scroll bars)
36
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    51
		var middleRatio = 1 / self.ratio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    52
		var newMiddleWidth = $(self.middleContainer).width();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    53
		var newMiddleHeight = newMiddleWidth * middleRatio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    54
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    55
		/*
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    56
		if (newMiddleHeight > maxMiddleHeight) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    57
			newMiddleHeight = maxMiddleHeight;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    58
			newMiddleWidth = newMiddleHeight * 1 / middleRatio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    59
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    60
		*/
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    61
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    62
		// Pre register the middle element size change
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    63
		if (self.preMiddleSizeFunc !== undefined && self.preMiddleSizeFunc !== null) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    64
			self.preMiddleSizeFunc(newMiddleWidth, newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    65
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    66
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    67
		// Change middle element size and the height of its parent
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    68
		$(self.middle).attr('width', newMiddleWidth);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    69
		$(self.middle).attr('height', newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    70
		$(self.middleContainer).attr('width', newMiddleWidth);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    71
		$(self.middleContainer).attr('height', newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    72
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    73
		// Change children size of the middle element
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    74
		var children = $(self.middle).children();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    75
		if (children.length > 0) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    76
			children.attr('width', newMiddleWidth);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    77
			children.attr('height', newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    78
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    79
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    80
		// Post register the middle element size change
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    81
		if (self.postMiddleSizeFunc !== undefined && self.postMiddleSizeFunc !== null) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    82
			self.postMiddleSizeFunc(newMiddleWidth, newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    83
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    84
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    85
		// Change top and bottom heights
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    86
		if (this.top != undefined && this.bottom != undefined) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    87
			// Get the full height and compute heigth for top and bottom
42
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    88
			var remainingHeight = heightForTopMiddleBotom - newMiddleHeight;
36
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    89
			var newOtherHeight = remainingHeight / 2.0;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    90
			if (newOtherHeight < self.minTopBottomHeight) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    91
				newOtherHeight = self.minTopBottomHeight;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    92
			}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    93
			$(self.top).css({"height" : +newOtherHeight+'px', "lineHeight" : +newOtherHeight+'px'});
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    94
			$(self.bottom).css({"height" : +newOtherHeight+'px', "lineHeight" : +newOtherHeight+'px'});					
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    95
		}
42
01415303372e écran choix
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents: 36
diff changeset
    96
	};
36
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    97
}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    98
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    99
var incResize = new IncResize();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
   100
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
   101