Вход Регистрация
Файл: modules/video1/unitegallery/themes/tilesgrid/ug-theme-tilesgrid.js
Строк: 398
<?php
if(typeof g_ugFunctions != "undefined")
    
g_ugFunctions.registerTheme("tilesgrid");
else 
    
jQuery(document).ready(function(){g_ugFunctions.registerTheme("tilesgrid")});


/**
 * Fixed tiles theme
 */
function UGTheme_tilesgrid(){

    var 
this;
    var 
g_gallery = new UniteGalleryMain(), g_objGalleryg_objectsg_objWrapper
    var 
g_objThumbsGrid = new UGThumbsGrid(), g_lightbox = new UGLightbox();
    var 
g_functions = new UGFunctions(), g_objTileDesign = new UGTileDesign();
    var 
g_objBulletsg_objNavWrapperg_objButtonLeftg_objButtonRightg_objPreloader;
    

    var 
g_options = {
            
theme_gallery_padding0,                //padding from sides of the gallery
            
theme_grid_align"center",                //grid align
            
theme_navigation_type"bullets",        //bullets, arrows
            
theme_arrows_margin_top20,            //the space between arrows and grid
            
theme_space_between_arrows5,            //horizontal space between arrows
            
theme_bullets_margin_top40,            //the space 
            
theme_navigation_align"center",        //center, left, right - horizontal align of the navigation
            
theme_navigation_offset_hor0,            //horizontal offset of the navigation, according the align
            
theme_bullets_color"gray",            //gray, blue, brown, green, red - color of the bullets
            
theme_auto_open:null                    //auto open lightbox at start
    
};
    
    var 
g_defaults = {
            
gallery_width"100%",
            
            
tile_width180,
            
tile_height150,
            
            
grid_num_rows3,
            
grid_padding10,
            
            
tile_enable_bordertrue,
            
tile_enable_shadowtrue,
            
            
tile_border_radius2,
            
            
grid_space_between_cols20,
            
grid_space_between_rows20,
            
            
bullets_space_between12,
            
grid_vertical_scroll_ondragtrue
    
};
    
    
    
//temp variables
    
var g_temp = {
            
handlenull        //interval handle
    
};
    
    
    
/**
     * Init the theme
     */
    
function initTheme(gallerycustomOptions){
        
        
g_gallery gallery;
        
        
//set default options
        
g_options jQuery.extend(g_optionsg_defaults);
        
        
//set custom options
        
g_options jQuery.extend(g_optionscustomOptions);
        
        
modifyOptions();
        
        
//set gallery options
        
g_gallery.setOptions(g_options);
        
        
g_gallery.setFreestyleMode();
        
        
g_objects gallery.getObjects();
        
        
//get some objects for local use
        
g_objGallery jQuery(gallery);        
        
g_objWrapper g_objects.g_objWrapper;
        
        
//init objects
        
g_lightbox.init(galleryg_options);
        
        
g_objThumbsGrid.init(galleryg_optionstrue);

        
g_objTileDesign g_objThumbsGrid.getObjTileDesign();
    }
    
    
    
/**
     * modify options
     */
    
function modifyOptions(){
        
        if(!
g_options.grid_num_rows)
            
g_options.grid_num_rows 9999;
        
        
g_options.bullets_addclass "ug-bullets-"+g_options.theme_bullets_color;
        
    }
    
    
    
/**
     * get gallery width available for the grid
     */
    
function getGalleryWidth(){
        var 
galleryWidth g_gallery.getSize().width;
        
galleryWidth -= g_options.theme_gallery_padding 2;
        
        return(
galleryWidth);
    }
    
    
    
/**
     * set gallery html elements
     */
    
function setHtml(){
        
        
//init bullets (only after panes size estimation)                
        
if(g_options.theme_navigation_type == "bullets"){
            
            
g_objBullets = new UGBullets();
            
            var 
galleryWidth getGalleryWidth();
            
            var 
numPanes g_objThumbsGrid.getNumPanesEstimationByWidth(galleryWidth);
            
            var 
objOptions g_gallery.getOptions();
            
g_objBullets.init(g_galleryobjOptionsnumPanes);            
            
        }
        
        
//add html elements
        
g_objWrapper.addClass("ug-theme-tilesfixed");
        
        
g_objThumbsGrid.setHtml();
        
        if(
g_objBullets)
            
g_objBullets.appendHTML(g_objWrapper);
        
        if(
g_options.theme_navigation_type == "arrows"){
            var 
htmlAdd "<div class='ug-tile-navigation-wrapper' style='position:absolute'>";
            
htmlAdd += "<div class='ug-button-tile-navigation ug-button-tile-left'></div>";
            
htmlAdd += "<div class='ug-button-tile-navigation ug-button-tile-right'></div>";
            
htmlAdd += "</div>";
            
g_objWrapper.append(htmlAdd);
            
            
g_objNavWrapper g_objWrapper.children(".ug-tile-navigation-wrapper");
            
            
g_objButtonLeft g_objNavWrapper.children(".ug-button-tile-left");
            
g_objButtonRight g_objNavWrapper.children(".ug-button-tile-right");
            
            
g_objButtonLeft.css("margin-right",g_options.theme_space_between_arrows+"px");
        }
        
        
g_lightbox.putHtml();
        
        
//add preloader
        
g_objWrapper.append("<div class='ug-tiles-preloader ug-preloader-trans'></div>");
        
g_objPreloader g_objWrapper.children(".ug-tiles-preloader");
        
g_objPreloader.fadeTo(0,0);
        
    }
    
    
    
/**
     * get height estimation by width
     */
    
function getHeightEstimation(galleryWidth){
        
        
//put the placeholder before run. check the width
        
var gridHeight g_objThumbsGrid.getHeightEstimationByWidth(galleryWidth);
        var 
numPanes g_objThumbsGrid.getNumPanesEstimationByWidth(galleryWidth);
        
        
//add navigation height
        
if(numPanes 1){
            if(
g_options.theme_navigation_type == "arrows"){
                
gridHeight += g_options.theme_arrows_margin_top;
                
gridHeight += 30;    //arrows size
            
}
            else{
                
gridHeight += g_options.theme_bullets_margin_top;
                
gridHeight += 15;    //bullets size
            
}
                
        }
    
        return(
gridHeight);
    }
    
    
    
/**
     * actually run the theme
     */
    
function actualRun(){
        
        
//get gallery width, set estimation height and get width again.
        
var galleryWidth getGalleryWidth();
        var 
totalHeight getHeightEstimation(galleryWidth);
        
g_objWrapper.height(totalHeight);
        var 
galleryWidth getGalleryWidth();

        
initEvents();
        
        
//place preloader
        
g_functions.placeElement(g_objPreloaderg_options.theme_grid_align50);
        
        
g_objThumbsGrid.setWidth(galleryWidth);
        
        
g_objThumbsGrid.run();
                
        
g_lightbox.run();
        
        
updateBullets();
        
        
positionElements();
        
        
    }

    
    
/**
     * run the theme
     */
    
function runTheme(){
        
        
setHtml();
        
actualRun();
        
    }
    
    
    
/**
     * position elements
     */
    
function positionElements(){
        
        var 
objGallerySize g_gallery.getSize();
        var 
g_objGridSize g_objThumbsGrid.getSize();
        
        var 
gridElement g_objThumbsGrid.getElement();
        
g_functions.placeElement(gridElementg_options.theme_grid_align0);
        
        
g_objGridSize g_objThumbsGrid.getSize();
        
        var 
galleryHeight g_objGridSize.height;
        
        var 
numPanes g_objThumbsGrid.getNumPanes();

        if(
numPanes 1){
            
            
//position bullets
            
if(g_objBullets){
                
                
g_objBullets.getElement().show();
                
                var 
bulletsElement g_objBullets.getElement();
                var 
bulletsWidth g_objBullets.getBulletsWidth();
                
                
//get bullets offset x (relative to the grid)
                
var bulletsX g_objGridSize.left g_functions.getElementRelativePos(bulletsWidthg_options.theme_navigation_aligng_options.theme_navigation_offset_horgridElement);
                
                
g_functions.placeElement(bulletsElementbulletsXgalleryHeight g_options.theme_bullets_margin_top);
                
                var 
sizeBullets g_functions.getElementSize(bulletsElement);
                
galleryHeight sizeBullets.bottom;
                
            }
            
            
//position buttons
            
if(g_objNavWrapper){
                
                
g_objNavWrapper.show();
                
                var 
navX g_objGridSize.left g_functions.getElementRelativePos(g_objNavWrapperg_options.theme_navigation_aligng_options.theme_navigation_offset_horgridElement);
                                
                
g_functions.placeElement(g_objNavWrappernavXgalleryHeight g_options.theme_arrows_margin_top);
                
                var 
sizeNav g_functions.getElementSize(g_objNavWrapper);
                
                
galleryHeight sizeNav.bottom;
            }
            
        }else{    
//if only one pame, hide the navigation
            
            
if(g_objNavWrapper)
                
g_objNavWrapper.hide();
            
            if(
g_objBullets)
                
g_objBullets.getElement().hide();
        }
        
        
g_objWrapper.height(galleryHeight);
    }
        
    
    
/**
     * on tile click - open lightbox
     */
    
function onTileClick(dataobjTile){
        
        
objTile jQuery(objTile);        
        var 
index objTile.index();
        
        
g_lightbox.open(index);
    }

    
    
/**
     * update the bullets
     */
    
function updateBullets(){
        
        
//update bullets
        
if(!g_objBullets)
            return(
false);
        
        
numPanes g_objThumbsGrid.getNumPanes();
        
g_objBullets.updateNumBullets(numPanes);
        
g_objBullets.setActive(0);
    }
    
    
    
/**
     * on gallery size change - resize the theme.
     */
    
function onSizeChange(){
        
        var 
galleryWidth getGalleryWidth();
        
        
g_objThumbsGrid.setWidth(galleryWidth);
        
g_objThumbsGrid.run();
        
        
updateBullets();
        
        
setTimeout(positionElements500);
        
    }


    
/**
     * on tile click - open lightbox
     */
    
function onTileClick(dataobjTile){
        
        
objTile jQuery(objTile);        
        
        var 
objItem g_objTileDesign.getItemByTile(objTile);
        var 
index objItem.index;        
            
        
g_lightbox.open(index);
    }
    
    
/**
     * before items request: hide items, show preloader
     */
    
function onBeforeReqestItems(){
        
        if(
g_objNavWrapper)
            
g_objNavWrapper.hide();
    
        if(
g_objThumbsGrid)
            
g_objThumbsGrid.getElement().hide();
        
        
//show preloader:
        
g_objPreloader.fadeTo(0,1);
    }
    
    
    
/**
     * open lightbox at start if needed
     */
    
function onLightboxInit(){

        if(
g_options.theme_auto_open !== null){
            
g_lightbox.open(g_options.theme_auto_open);
            
g_options.theme_auto_open null;
        }
        
    }
    
    
    
/**
     * init buttons functionality and events
     */
    
function initEvents(){
        
        
g_objGallery.on(g_gallery.events.SIZE_CHANGEonSizeChange);
        
g_objGallery.on(g_gallery.events.GALLERY_BEFORE_REQUEST_ITEMSonBeforeReqestItems);
        
        if(
g_objBullets)
            
g_objThumbsGrid.attachBullets(g_objBullets);        
        
        if(
g_objNavWrapper){
            
g_objThumbsGrid.attachNextPaneButton(g_objButtonRight);
            
g_objThumbsGrid.attachPrevPaneButton(g_objButtonLeft);
        }
        
        
jQuery(g_objTileDesign).on(g_objTileDesign.events.TILE_CLICKonTileClick);
        
        
jQuery(g_lightbox).on(g_lightbox.events.LIGHTBOX_INITonLightboxInit);
    }
    
    
    
/**
     * destroy the theme
     */
    
this.destroy = function(){
                
        
g_objGallery.off(g_gallery.events.SIZE_CHANGE);
        
g_objGallery.off(g_gallery.events.GALLERY_BEFORE_REQUEST_ITEMS);

        
jQuery(g_objTileDesign).off(g_objTileDesign.events.TILE_CLICK);
        
        if(
g_objBullets)
            
jQuery(g_objBullets).off(g_objBullets.events.BULLET_CLICK);

        
jQuery(g_lightbox).off(g_lightbox.events.LIGHTBOX_INIT);
        
        
g_objThumbsGrid.destroy();
        
g_lightbox.destroy();
        
    }

    
    
/**
     * run the theme setting
     */
    
this.run = function(){
        
        
runTheme();
    }
    
    
    
/**
     * init 
     */
    
this.init = function(gallerycustomOptions){
                
        
initTheme(gallerycustomOptions);
        
    }
    
    
}
?>
Онлайн: 1
Реклама