123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
-
- // ******* Internet Explorer MANAGER ******** //
- //this is to handle all the stupid IE Stuff
- $axure.internal(function($ax) {
- if(!$.browser.msie) return;
- var _ieColorManager = {};
- if(Number($.browser.version) < 9) $ax.ieColorManager = _ieColorManager;
- var _applyIEFixedPosition = function() {
- if(Number($.browser.version) >= 7) return;
- $axure(function(diagramObject) { return diagramObject.fixedVertical; }).$()
- .appendTo($('body'))
- .css('position', 'absolute').css('margin-left', 0 + 'px').css('margin-top', 0 + 'px');
- var handleScroll = function() {
- $axure(function(diagramObject) { return diagramObject.fixedVertical; })
- .each(function(diagramObject, elementId) {
- var win = $(window);
- var windowWidth = win.width();
- var windowHeight = win.height();
- var windowScrollLeft = win.scrollLeft();
- var windowScrollTop = win.scrollTop();
- var newLeft = 0;
- var newTop = 0;
- var elementQuery = $('#' + elementId);
- var width = elementQuery.width();
- var height = elementQuery.height();
- var horz = diagramObject.fixedHorizontal;
- if(horz == 'left') {
- newLeft = windowScrollLeft + diagramObject.fixedMarginHorizontal;
- } else if(horz == 'center') {
- newLeft = windowScrollLeft + ((windowWidth - width) / 2) + diagramObject.fixedMarginHorizontal;
- } else if(horz == 'right') {
- newLeft = windowScrollLeft + windowWidth - width - diagramObject.fixedMarginHorizontal;
- }
- var vert = diagramObject.fixedVertical;
- if(vert == 'top') {
- newTop = windowScrollTop + diagramObject.fixedMarginVertical;
- } else if(vert == 'middle') {
- newTop = windowScrollTop + ((windowHeight - height) / 2) + diagramObject.fixedMarginVertical;
- } else if(vert == 'bottom') {
- newTop = windowScrollTop + windowHeight - height - diagramObject.fixedMarginVertical;
- }
- elementQuery.css('top', newTop + 'px').css('left', newLeft + 'px');
- });
- };
- $(window).scroll(handleScroll);
- $axure.resize(handleScroll);
- handleScroll();
- };
- var _applyBackground = function() {
- if(Number($.browser.version) >= 9) return;
- var styleChain = $ax.adaptive.getAdaptiveIdChain($ax.adaptive.currentViewId);
- var argb = _getArgb($ax.pageData.page, styleChain);
- var hexColor = _getHexColor(argb, false);
- if(hexColor) $('body').css('background-color', hexColor);
- _applyBackgroundToQuery($ax('*'));
- };
- var _applyBackgroundToQuery = function(query) {
- if(Number($.browser.version) >= 9) return;
- var styleChain = $ax.adaptive.getAdaptiveIdChain($ax.adaptive.currentViewId);
- query.each(function(obj, elementId) {
- if(obj.type == 'dynamicPanel') {
- var stateCount = obj.diagrams.length;
- for(var j = 0; j < stateCount; j++) {
- var stateId = $ax.repeater.applySuffixToElementId(elementId, '_state' + j);
- var argb = _getArgb(obj.diagrams[j], styleChain);
- var hexColor = _getHexColor(argb, true);
- if(hexColor) $jobj(stateId).css('background-color', hexColor);
- }
- } else if(obj.type == 'repeater') {
- }
- });
- };
- _ieColorManager.applyBackground = _applyBackgroundToQuery;
- var _getArgb = function(diagram, styleChain) {
- var argb = undefined;
- for(var i = 0; i < styleChain.length && !argb; i++) {
- var style = diagram.adaptiveStyles[styleChain[i]];
- argb = style.fill && style.fill.color;
- }
- if(!argb) argb = diagram.style.fill.color;
- return argb;
- };
- var gMult = 256;
- var rMult = gMult * 256;
- var aMult = rMult * 256;
- var _getHexColor = function(argb, allowWhite) {
- var a = Math.floor(argb / aMult);
- argb -= a * aMult;
- var r = Math.floor(argb / rMult);
- argb -= r * rMult;
- var g = Math.floor(argb / gMult);
- var b = argb - g * gMult;
- return _getColorFromArgb(a, r, g, b, allowWhite);
- };
- var _getColorFromArgb = function(a, r, g, b, allowWhite) {
- if(Number($.browser.version) >= 9) return undefined;
- //convert the color with alpha to a color with no alpha (assuming white background)
- r = Math.min((r * a) / 255 + 255 - a, 255);
- g = Math.min((g * a) / 255 + 255 - a, 255);
- b = Math.min((b * a) / 255 + 255 - a, 255);
- if(a == 0) return undefined;
- if(!allowWhite && (r == 255 && g == 255 && b == 255)) return undefined;
- var color = '#';
- color += Math.floor(r / 16).toString(16);
- color += Math.floor(r % 16).toString(16);
- color += Math.floor(g / 16).toString(16);
- color += Math.floor(g % 16).toString(16);
- color += Math.floor(b / 16).toString(16);
- color += Math.floor(b % 16).toString(16);
- return color;
- };
- _ieColorManager.getColorFromArgb = _getColorFromArgb;
- var getIEOffset = function(transform, rect) {
- var translatedVertexes = [
- $axure.utils.Vector2D(0, 0), //we dont translate, so the orgin is fixed
- transform.mul($axure.utils.Vector2D(0, rect.height)),
- transform.mul($axure.utils.Vector2D(rect.width, 0)),
- transform.mul($axure.utils.Vector2D(rect.width, rect.height))];
- var minX = 0, minY = 0, maxX = 0, maxY = 0;
- $.each(translatedVertexes, function(index, p) {
- minX = Math.min(minX, p.x);
- minY = Math.min(minY, p.y);
- maxX = Math.max(maxX, p.x);
- maxY = Math.max(maxY, p.y);
- });
- return $axure.utils.Vector2D(
- (maxX - minX - rect.width) / 2,
- (maxY - minY - rect.height) / 2);
- };
- var _filterFromTransform = function(transform) {
- return "progid:DXImageTransform.Microsoft.Matrix(M11=" + transform.m11 +
- ", M12=" + transform.m12 + ", M21=" + transform.m21 +
- ", M22=" + transform.m22 + ", SizingMethod='auto expand')";
- };
- var _applyIERotation = function() {
- if(Number($.browser.version) >= 9) return;
- $axure(function(diagramObject) {
- return ((diagramObject.style.rotation && Math.abs(diagramObject.style.rotation) > 0.1)
- || (diagramObject.style.textRotation && Math.abs(diagramObject.style.textRotation) > 0.1))
- && !diagramObject.isContained;
- }).each(function(diagramObject, elementId) {
- var rotation = diagramObject.style.rotation || 0;
- var $element = $('#' + elementId);
- var width = $element.width();
- var height = $element.height();
- var originX = width / 2;
- var originY = height / 2;
- var shapeIeOffset;
- $element.children().each(function() {
- var $child = $(this);
- var childWidth = $child.width();
- var childHeight = $child.height() + $child.position().top;
- var centerX = $child.position().left + (childWidth / 2);
- var centerY = $child.position().top + (childHeight / 2);
- var deltaX = centerX - originX;
- var deltaY = centerY - originY;
- var effectiveRotation = rotation;
- var textObject = $ax.getObjectFromElementId($child.attr('id'));
- if(textObject) {
- if(textObject.style.textRotation) effectiveRotation = textObject.style.textRotation;
- else return;
- }
- var transform = $ax.utils.Matrix2D.identity().rotate(effectiveRotation);
- var filter = _filterFromTransform(transform);
- $child.css('filter', filter)
- .width(childWidth + 1)
- .height(childHeight + 1);
- var p = transform.mul($ax.utils.Vector2D(deltaX, deltaY));
- var ieOffset = getIEOffset(transform, { width: childWidth, height: childHeight });
- if(!textObject) {
- shapeIeOffset = ieOffset;
- } else {
- // This is a close approximation, but not exact
- if(diagramObject.style.verticalAlignment != 'top') ieOffset.y -= shapeIeOffset.y + Math.abs(shapeIeOffset.x);
- }
- $child.css("margin-left", -ieOffset.x - deltaX + p.x).css("margin-top", -ieOffset.y - deltaY + p.y);
- });
- });
- };
- var _fixIEStretchBackground = function() {
- if(Number($.browser.version) >= 9) return;
- var pageStyle = $ax.adaptive.getPageStyle();
- if(!pageStyle.imageRepeat || pageStyle.imageRepeat == 'auto') return;
- $('body').css('background-image', 'none');
- var viewId = $ax.adaptive.currentViewId;
- var imageInfo = viewId ? $ax.pageData.viewIdToBackgroundImageInfo && $ax.pageData.viewIdToBackgroundImageInfo[viewId] : $ax.pageData.defaultBackgroundImageInfo;
- if(imageInfo && imageInfo.path) {
- if($('#bg_img').length == 0) $('body').append('<img id="bg_img"/>');
- $('#bg_img').attr('src', imageInfo.path).css('position', 'fixed').css('z-index', '-10000');
- _resizeIEBackground();
- } else $('#bg_img').remove();
- };
- var _resizeIEBackground = function() {
- if(Number($.browser.version) >= 9) return;
- //var page = $ax.pageData.page;
- var viewId = $ax.adaptive.currentViewId;
- var pageStyle = $ax.adaptive.getPageStyle();
- if(!$ax.pageData.defaultBackgroundImageInfo && !$ax.pageData.viewIdToBackgroundImageInfo) return;
- var imageInfo = viewId ? $ax.pageData.viewIdToBackgroundImageInfo[viewId] : $ax.pageData.defaultBackgroundImageInfo;
- if(!imageInfo) return;
- var imageWidth = imageInfo.width;
- var imageHeight = imageInfo.height;
- var windowWidth = $(window).width();
- var windowHeight = $(window).height();
- var isCover = pageStyle.imageRepeat == 'cover';
- var wRatio = windowWidth / imageWidth;
- var hRatio = windowHeight / imageHeight;
- var ratio = wRatio;
- if(isCover) {
- if(hRatio > wRatio) ratio = hRatio;
- } else {
- if(hRatio < wRatio) ratio = hRatio;
- }
- var width = imageWidth * ratio;
- var height = imageHeight * ratio;
- var left = '0px';
- if((isCover && width > windowWidth) || (!isCover && width < windowWidth)) {
- if(pageStyle.imageHorizontalAlignment == 'center') {
- left = ((windowWidth - width) / 2) + 'px';
- } else if(pageStyle.imageHorizontalAlignment == 'far') {
- left = (windowWidth - width) + 'px';
- }
- }
- var top = '0px';
- if((isCover && height > windowHeight) || (!isCover && height < windowHeight)) {
- if(pageStyle.imageVerticalAlignment == 'center') {
- top = ((windowHeight - height) / 2) + 'px';
- } else if(pageStyle.imageVerticalAlignment == 'far') {
- top = (windowHeight - height) + 'px';
- }
- }
- $('#bg_img').css('top', top).css('left', left).css('width', width).css('height', height);
- };
- var _fixAllPngs = function() {
- if(!(/MSIE ((5\.5)|6)/.test(window.navigator.userAgent) && window.navigator.platform == "Win32")) return;
- $('img[src$=".png"]').each(function() {
- if(!this.complete) {
- this.onload = function() { $axure.utils.fixPng(this); };
- } else {
- $axure.utils.fixPng(this);
- }
- });
- };
- var _fixInputSize = function() {
- if(Number($.browser.version) >= 8) return;
- var inputs = $('input').not(':input[type=button], :input[type=submit], :input[type=radio], :input[type=checkbox]');
- inputs.each(function() {
- var $input = $(this);
- $input.css('height', ($input.height() - 4 + 'px')).css('width', ($input.width() - 2 + 'px'));
- });
- var textAreas = $('textarea');
- textAreas.each(function() {
- var $textArea = $(this);
- $textArea.css('height', ($textArea.height() - 6 + 'px')).css('width', ($textArea.width() - 6 + 'px'));
- });
- };
- $(document).ready(function() {
- _fixIEStretchBackground();
- _applyIEFixedPosition();
- $axure.resize(function() {
- _resizeIEBackground();
- });
- $ax.adaptive.bind('viewChanged', function() {
- _fixIEStretchBackground();
- _applyBackground();
- });
- _fixAllPngs();
- _applyIERotation();
- _applyBackground();
- _fixInputSize();
- });
- });
|