208 lines
6.1 KiB
JavaScript
208 lines
6.1 KiB
JavaScript
/* global fusionAppConfig */
|
|
var FusionPageBuilder = FusionPageBuilder || {};
|
|
|
|
( function() {
|
|
|
|
FusionPageBuilder.Website = FusionPageBuilder.Studio.extend( {
|
|
|
|
/**
|
|
* Init.
|
|
*
|
|
* @since 2.0.0
|
|
* @return {void}
|
|
*/
|
|
initialize: function() {
|
|
this.websiteData = false;
|
|
this.websiteRequest = false;
|
|
this.state = {
|
|
current: '',
|
|
title: '',
|
|
nextCat: ''
|
|
};
|
|
},
|
|
|
|
/**
|
|
* Gets the webfonts via AJAX.
|
|
*
|
|
* @since 2.0.0
|
|
* @return {void}
|
|
*/
|
|
getWebsiteData: function() {
|
|
var self = this;
|
|
|
|
if ( self.websiteData && self.websiteData ) {
|
|
return;
|
|
}
|
|
|
|
if ( false !== self.websiteRequest ) {
|
|
return self.websiteRequest;
|
|
}
|
|
return jQuery.post( fusionAppConfig.ajaxurl, { action: 'awb_load_websites', load_website_data: true, fusion_load_nonce: fusionAppConfig.fusion_load_nonce }, function( data ) {
|
|
if ( ! _.isNull( data ) ) {
|
|
self.websiteData = data;
|
|
}
|
|
}, 'json' );
|
|
},
|
|
|
|
/**
|
|
* Init filter sidebar.
|
|
*
|
|
* @since 3.5
|
|
* @param {Object} sidebar - The sidebar elements.
|
|
* @return {void}
|
|
*/
|
|
initFilter: function( $sidebar ) {
|
|
var timeouts = [],
|
|
self = this,
|
|
$container = jQuery( '#fusion-builder-layouts-demos' );
|
|
|
|
$sidebar.find( 'li' ).off();
|
|
|
|
$sidebar.find( 'li' ).on( 'click', function() {
|
|
var $studioImports = jQuery( this ).closest( '.studio-wrapper' ).find( '.studio-imports' ),
|
|
$templates = $studioImports.find( 'li' ),
|
|
slug = jQuery( this ).attr( 'data-slug' ),
|
|
counter = 1,
|
|
order = [],
|
|
$showTemplates = [],
|
|
i;
|
|
|
|
// Don't do filtering for active filter.
|
|
if ( jQuery( this ).hasClass( 'current' ) ) {
|
|
return false;
|
|
}
|
|
|
|
// Clear all timeouts to prevent animations still running.
|
|
jQuery.each( timeouts, function( index, value ) {
|
|
clearTimeout( value );
|
|
} );
|
|
|
|
// Hide detail demo.
|
|
if ( ! $studioImports.next().hasClass( 'hidden' ) ) {
|
|
$studioImports.removeClass( 'hidden' ).next().addClass( 'hidden' ).find( '.demo-' + self.state.current ).addClass( 'hidden' );
|
|
}
|
|
|
|
// Remove current from active.
|
|
$sidebar.find( 'li.current' ).removeClass( 'current' );
|
|
|
|
// Hide all templates.
|
|
$templates.css( { display: 'none' } ).addClass( 'hidden' );
|
|
|
|
// Fade correct templates in.
|
|
$templates.each( function() {
|
|
var $template = jQuery( this );
|
|
if ( 'undefined' === typeof $template.data( 'slug' ) ) {
|
|
return true;
|
|
}
|
|
|
|
if ( 'all' === slug || -1 !== $template.data( 'slug' ).indexOf( slug ) ) {
|
|
$template.css( { display: 'inline-block' } );
|
|
$showTemplates.push( $template );
|
|
}
|
|
} );
|
|
|
|
setTimeout( function() {
|
|
jQuery.each( $showTemplates, function() {
|
|
var $template = jQuery( this ),
|
|
position = $template.position();
|
|
|
|
// Loop afer all have been added to get position.
|
|
position.$el = $template;
|
|
order.push( position );
|
|
} );
|
|
|
|
// Sort top to bottom.
|
|
order.sort( self.SortByTop );
|
|
|
|
// Reveal top to bottom.
|
|
for ( i = 0; i < order.length; i++ ) {
|
|
timeouts.push(
|
|
self.doSetTimeout( i, order, counter )
|
|
);
|
|
counter++;
|
|
}
|
|
}, 50 );
|
|
|
|
// Add current to show it is active.
|
|
jQuery( this ).addClass( 'current' );
|
|
} );
|
|
|
|
$container.find( '#awb_sites_search_demos' ).on( 'change paste keyup', _.debounce( function( ) {
|
|
var demoPageLink = jQuery( this ).val(),
|
|
demoPage,
|
|
parentDemo;
|
|
|
|
demoPageLink = demoPageLink.replace( 'https://', '' ).replace( 'http://', '' );
|
|
if ( '/' !== demoPageLink[ demoPageLink.length - 1 ] && ! _.isEmpty( demoPageLink ) ) {
|
|
demoPageLink += '/';
|
|
}
|
|
|
|
demoPage = $container.find( 'li[data-page-link="' + demoPageLink + '"]' );
|
|
parentDemo = demoPage.closest( '.awb-page-item' );
|
|
|
|
if ( demoPage.length ) {
|
|
if ( $container.find( '.site-details' ).hasClass( 'hidden' ) ) {
|
|
$container.find( '.site-details' ).removeClass( 'hidden' ).prev().addClass( 'hidden' );
|
|
}
|
|
demoPage.removeClass( 'hidden' ).siblings().addClass( 'hidden' );
|
|
|
|
self.state.current = parentDemo.data( 'website_id' );
|
|
self.state.title = parentDemo.data( 'website_title' );
|
|
parentDemo.removeClass( 'hidden' ).siblings().addClass( 'hidden' );
|
|
self.updateDetailHeader( $container );
|
|
}
|
|
|
|
}, 100 ) );
|
|
},
|
|
|
|
/**
|
|
* Init Import Demo.
|
|
*
|
|
* @since 3.5
|
|
* @param {Object} sidebar - The sidebar elements.
|
|
* @return {void}
|
|
*/
|
|
initImport: function( $container ) {
|
|
var self = this;
|
|
|
|
// Demo on Click.
|
|
$container.find( '.studio-imports > li.awb-demo-pages-layout' ).on( 'click', function( event ) {
|
|
event.preventDefault();
|
|
self.state.current = jQuery( this ).data( 'website_id' );
|
|
self.state.title = jQuery( this ).data( 'website_title' );
|
|
jQuery( this ).closest( '.studio-imports' ).addClass( 'hidden' )
|
|
.next().removeClass( 'hidden' ).find( '.demo-' + self.state.current ).removeClass( 'hidden' )
|
|
.find( 'li.hidden' ).removeClass( 'hidden' );
|
|
|
|
self.updateDetailHeader( $container );
|
|
} ).end().find( '.awb-sites-back-js' ).on( 'click', function( event ) {
|
|
event.preventDefault();
|
|
jQuery( this ).closest( '.site-details' ).find( '.demo-' + self.state.current ).addClass( 'hidden' )
|
|
.end().closest( '.site-details' ).addClass( 'hidden' ).prev().removeClass( 'hidden' );
|
|
} ).end().find( '.awb-sites-next-js' ).on( 'click', function( event ) {
|
|
event.preventDefault();
|
|
$container.find( 'aside li[data-slug="' + self.state.nextCat + '"]' ).trigger( 'click' );
|
|
} );
|
|
|
|
},
|
|
|
|
/**
|
|
* Update Detail Header.
|
|
*
|
|
* @since 3.5
|
|
* @param {Object} container - The container elements.
|
|
* @return {void}
|
|
*/
|
|
updateDetailHeader: function( $container ) {
|
|
this.state.nextCat = $container.find( 'aside ul > li.current' ).next().data( 'slug' );
|
|
$container.find( '.awb-sites-title' ).html( this.state.title );
|
|
if ( this.state.nextCat && this.websiteData.tags[ this.state.nextCat ] ) {
|
|
$container.find( '.awb-sites-next-js' ).removeClass( 'vs-hidden' ).html( this.websiteData.tags[ this.state.nextCat ].name );
|
|
} else {
|
|
$container.find( '.awb-sites-next-js' ).addClass( 'vs-hidden' );
|
|
}
|
|
}
|
|
} );
|
|
|
|
}( jQuery ) );
|