 /*
 * Copyright (c) 2008-2009 John McMullen (http://www.smple.com)
 * This is licensed under GPL (http://www.opensource.org/licenses/gpl-license.php) licenses.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 *
*/ 
 
 (function($){
    $.fn.pagePeel = function(options){
    
        var defaults = {
            
            // SET WIDTH / HEIGHT OF CORNER AD WHEN SMALL
            smallWidth: 120,
            smallHeight: 120,
            smallBG: 'pp-src/smallBG.png',
            
            // SET WIDTH / HEIGHT OF CORNER AD INTRO
            introWidth: 300,
            introHeight:300,
            
            // SET WIDTH / HEIGHT OF BIG AD (SAME AS .SWF)
            bigWidth: 500,
            bigHeight: 500,
            bigBG: 'pp-src/bigBG.png',
            bigAd: 'pp-src/bigAd.jpg',
            bigSWF: 'pp-src/page-peel-big.swf',
            
            // POSITION WILL REMAIN THE SAME FOR BOTH
            hPosition: 'right', // can use 'left' or 'right'
            vPosition: 'top', // can use 'top' or 'bottom'
            
            // CHOOSE WHETHER TO USE FLASH OR NOT
            flash: true,
            
            // WHETHER TO USE INTRO ANIMATION AND WHAT FILE TO USE
            introAnim: false,
            bigSWFIntro: 'pp-src/page-peel-big-intro.swf',
            
            // ADD LINK IF LEFT 'BLANK', NO ADD LINK WILL BE APPLIED
            adLink: 'blank',
            adLinkTarget: '_blank'
        };
        
        var options = $.extend(defaults, options);
        
        var element = this;
        
    return this.each(function(){
        
        if (options.flash === true){
            if (options.introAnim === true){
                $(element).after("<div class='page-peel-adjuster' style='overflow:hidden; width:" + options.introWidth + "px; height: " + options.introHeight + "px; display:none; position:absolute; " + options.vPosition + ":0px; " + options.hPosition + ":0px;'><div class='page-peel-holder' style='width:" + options.bigWidth + "px; height: " + options.bigHeight + "px; display:block; position:absolute; " + options.vPosition + ":0px; " + options.hPosition + ":0px; z-index:9999;'><embed style='display: block;' src='" + options.bigSWFIntro + "' flashvars='linkURL=" + options.adLink + "&linkURLTarget=" + options.adLinkTarget + "&bigURL=" + options.bigAd + "' type='application/x-shockwave-flash' pluginspage='http://www.adobe.com/go/getflashplayer' wmode='transparent' autoplay='false' width='" + options.bigWidth + "' height='" + options.bigHeight + "'></div></div>");
            }
            if (options.introAnim === false){
                $(element).after("<div class='page-peel-adjuster' style='overflow:hidden; width:" + options.smallWidth + "px; height: " + options.smallHeight + "px; display:none; position:absolute; " + options.vPosition + ":0px; " + options.hPosition + ":0px;'><div class='page-peel-holder' style='width:" + options.bigWidth + "px; height: " + options.bigHeight + "px; display:block; position:absolute; " + options.vPosition + ":0px; " + options.hPosition + ":0px; z-index:9999;'><embed style='display: block;' src='" + options.bigSWF + " 'flashvars='linkURL=" + options.adLink + "&linkURLTarget=" + options.adLinkTarget + "&bigURL=" + options.bigAd + "' type='application/x-shockwave-flash' pluginspage='http://www.adobe.com/go/getflashplayer' wmode='transparent' autoplay='false' width='" + options.bigWidth + "' height='" + options.bigHeight + "'></div></div>");
            }
        
            $('.page-peel-adjuster').hover(
                function(){
                    var w = $(this).width();
                    if (w === 300){
                        $(this).stop().css({
                            width: options.smallWidth,
                            height: options.smallHeight
                        });
                    } else {
                        $(this).css('z-index','9999');
                        $(this).stop().css({
                            width: options.bigWidth,
                            height: options.bigHeight
                        });
                    }
                },
                function(){
                    $(this).animate({width:options.smallWidth, height:options.smallHeight},1000)
                    $(this).css('z-index','1000');
                }
            );
            
            $('.page-peel-adjuster').css('display','block');
        }
        
        if (options.flash !== true){
            $(element).after("<div class='page-peel-adjuster' style='width:" + options.smallWidth + "px; height: " + options.smallHeight + "px; display:block; position:absolute; " + options.vPosition + ":0px; " + options.hPosition + ":0px; background:url(" + options.smallBG + ") " + options.vPosition + " " + options.hPosition + " no-repeat;'");
            
            $('.page-peel-adjuster').hover(
                function(){
                    $(this).css('z-index','9999');
                    $(this).css({
                        width: options.bigWidth,
                        height: options.bigHeight,
                        background: 'url(' + options.bigBG + ') top right no-repeat'
                    });
                },
                function(){
                    $(this).css({
                        width: options.smallWidth,
                        height: options.smallHeight,
                        background: 'url(' + options.smallBG + ') top right no-repeat'
                    });
                    $(this).css('z-index','1000');
                }
            );
        }
    });
        
    };
})(jQuery);
