web/static/res/js/incresize.js
author Edwin Razafimahatratra <edwin@robotalismsoft.com>
Mon, 10 Dec 2012 20:55:18 +0100
changeset 38 cdbb56b876c9
parent 36 6cd5bc3dc7a2
child 42 01415303372e
permissions -rw-r--r--
mosaic effect loops
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
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    25
		this.footer =  $('#' + footerId);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    26
		this.minTopBottomHeight = minTopBottomHeight;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    27
		this.ratio = ratio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    28
		this.preMiddleSizeFunc = preMiddleSizeFunc;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    29
		this.postMiddleSizeFunc = postMiddleSizeFunc;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    30
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    31
		$(window).resize(this.resizeElements);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    32
		window.onorientationchange = function() {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    33
			incResize.resizeElements();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    34
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    35
	};
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    36
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    37
	this.resizeElements = function()
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    38
	{
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    39
		var self = incResize;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    40
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    41
		// Compute maximun middle element height
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    42
		var heightForTopMiddleBotom = $(self.content).height() - $(self.footer).height() - 70;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    43
		var maxMiddleHeight = heightForTopMiddleBotom - self.minTopBottomHeight * 2;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    44
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    45
		// Get the middle element parent width nad test if it is not to big (to let place for top and bottom without adding scroll bars)
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    46
		var middleRatio = 1 / self.ratio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    47
		var newMiddleWidth = $(self.middleContainer).width();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    48
		var newMiddleHeight = newMiddleWidth * middleRatio;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    49
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    50
		/*
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    51
		if (newMiddleHeight > maxMiddleHeight) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    52
			newMiddleHeight = maxMiddleHeight;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    53
			newMiddleWidth = newMiddleHeight * 1 / 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
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    57
		// Pre register the middle element size change
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    58
		if (self.preMiddleSizeFunc !== undefined && self.preMiddleSizeFunc !== null) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    59
			self.preMiddleSizeFunc(newMiddleWidth, newMiddleHeight);
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
		// Change middle element size and the height of its parent
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    63
		$(self.middle).attr('width', newMiddleWidth);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    64
		$(self.middle).attr('height', newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    65
		$(self.middleContainer).attr('width', newMiddleWidth);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    66
		$(self.middleContainer).attr('height', newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    67
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    68
		// Change children size of the middle element
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    69
		var children = $(self.middle).children();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    70
		if (children.length > 0) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    71
			children.attr('width', newMiddleWidth);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    72
			children.attr('height', newMiddleHeight);
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    73
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    74
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    75
		// Post register the middle element size change
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    76
		if (self.postMiddleSizeFunc !== undefined && self.postMiddleSizeFunc !== null) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    77
			self.postMiddleSizeFunc(newMiddleWidth, 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
		// Change top and bottom heights
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    81
		if (this.top != undefined && this.bottom != undefined) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    82
			// Get the full height and compute heigth for top and bottom
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    83
			var remainingHeight = $(self.content).height() - $(self.footer).height() - newMiddleHeight - 70;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    84
			var newOtherHeight = remainingHeight / 2.0;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    85
			if (newOtherHeight < self.minTopBottomHeight) {
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    86
				newOtherHeight = self.minTopBottomHeight;
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    87
			}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    88
			$(self.top).css({"height" : +newOtherHeight+'px', "lineHeight" : +newOtherHeight+'px'});
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    89
			$(self.bottom).css({"height" : +newOtherHeight+'px', "lineHeight" : +newOtherHeight+'px'});					
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    90
		}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    91
	}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    92
}
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    93
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    94
var incResize = new IncResize();
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    95
Edwin Razafimahatratra <edwin@robotalismsoft.com>
parents:
diff changeset
    96