Files
ultimatemember/assets/js/um-members.js
T
nikitasinelnikov a7f046fe6f - member directory;
2019-09-02 16:35:10 +03:00

1214 lines
34 KiB
JavaScript

var um_members_directory_busy = [];
var um_member_directories = [];
var um_member_directory_last_data = [];
function um_parse_current_url() {
var data = {};
var query = window.location.search.substring(1);
var attrs = query.split( '&' );
jQuery.each( attrs, function( i ) {
var attr = attrs[ i ].split( '=' );
data[ attr[0] ] = attr[1];
});
return data;
}
function um_get_data_for_directory( directory, search_key ) {
var hash = um_members_get_hash( directory );
var data = {};
var url_data = um_parse_current_url();
jQuery.each( url_data, function( key ) {
if ( key.indexOf( '_' + hash ) !== -1 && url_data[ key ] !== '' ) {
data[ key.replace( '_' + hash, '' ) ] = url_data[ key ];
}
});
if ( ! search_key ) {
return data;
} else {
if ( typeof data[ search_key ] !== 'undefined' ) {
try {
data[ search_key ] = decodeURI( data[ search_key ] );
} catch(e) { // catches a malformed URI
console.error(e);
}
}
return data[ search_key ];
}
}
function um_set_url_from_data( directory, key, value ) {
var hash = um_members_get_hash( directory );
var data = um_get_data_for_directory( directory );
var new_data = {};
if ( value !== '' ) {
new_data[ key + '_' + hash ] = value;
}
jQuery.each( data, function( data_key ) {
if ( key === data_key ) {
if ( value !== '' ) {
new_data[ data_key + '_' + hash ] = value;
}
} else {
new_data[ data_key + '_' + hash ] = data[ data_key ];
}
});
var query_strings = [];
jQuery.each( new_data, function( data_key ) {
query_strings.push( data_key + '=' + new_data[ data_key ] );
});
var query_string = '?' + query_strings.join( '&' );
window.history.pushState("string", "UM Member Directory", window.location.origin + window.location.pathname + query_string );
}
function um_members_get_hash( directory ) {
return directory.data( 'hash' );
}
function um_is_directory_busy( directory ) {
var hash = um_members_get_hash( directory );
return typeof um_members_directory_busy[ hash ] != 'undefined' && um_members_directory_busy[ hash ];
}
function um_members_show_preloader( directory ) {
um_members_directory_busy[ um_members_get_hash( directory ) ] = true;
directory.find('.um-members-overlay').show();
}
function um_members_hide_preloader( directory ) {
um_members_directory_busy[ um_members_get_hash( directory ) ] = false;
directory.find('.um-members-overlay').hide();
}
function um_set_range_label( slider, ui ) {
var placeholder = slider.siblings( '.um-slider-range' ).data( 'placeholder' );
if( ui ) {
placeholder = placeholder.replace( '\{min_range\}', ui.values[ 0 ] )
.replace( '\{max_range\}', ui.values[ 1 ] )
.replace( '\{field_label\}', slider.siblings( '.um-slider-range' )
.data('label') );
} else {
placeholder = placeholder.replace( '\{min_range\}', slider.slider( "values", 0 ) )
.replace( '\{max_range\}', slider.slider( "values", 1 ) )
.replace( '\{field_label\}', slider.siblings( '.um-slider-range' )
.data('label') );
}
slider.siblings( '.um-slider-range' ).html( placeholder );
slider.siblings( ".um_range_min" ).val( slider.slider( "values", 0 ) );
slider.siblings( ".um_range_max" ).val( slider.slider( "values", 1 ) );
}
function um_get_search( directory ) {
if ( directory.find('.um-search-line').length ) {
return directory.find( '.um-search-line' ).val();
} else {
return '';
}
}
function um_get_sort( directory ) {
if ( directory.find('.um-member-directory-sorting-options').length ) {
return directory.find( '.um-member-directory-sorting-options' ).val();
} else {
return '';
}
}
function um_get_current_page( directory ) {
var page = directory.data( 'page' );
if ( ! page || typeof page == 'undefined' ) {
page = 1;
}
return page;
}
function um_ajax_get_members( directory, args ) {
/**
* Operates with the next data:
*
* 1) Page - getting from directory data 'page'
* 2) Sort - getting from 'um-member-directory-sorting-options' field value
* 3) Search - getting from 'um-search-line' field value
* 4) Filters - getting from URL data by 'um_get_data_for_directory' function
*
*/
var hash = um_members_get_hash( directory );
var page = um_get_current_page( directory );
var search = um_get_search( directory );
var sorting = um_get_sort( directory );
var local_date = new Date();
var gmt_hours = -local_date.getTimezoneOffset() / 60;
var request = {
directory_id: hash,
page: page,
search: search,
sorting: sorting,
gmt_offset: gmt_hours,
nonce: um_scripts.nonce
};
if ( directory.find('.um-search-filter').length ) {
directory.find('.um-search-filter').each( function() {
var filter = jQuery(this);
if ( filter.find( '.um-slider' ).length ) {
var filter_name = filter.find( '.um-slider' ).data('field_name');
var value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof value_from != 'undefined' || typeof value_to != 'undefined' ) {
request[ filter_name ] = [ value_from, value_to ];
}
} else if ( filter.find( '.um-datepicker-filter' ).length ) {
var filter_name = filter.find( '.um-datepicker-filter' ).data('filter_name');
var value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof value_from != 'undefined' || typeof value_to != 'undefined') {
request[ filter_name ] = [ value_from, value_to ];
}
} else if ( filter.find( '.um-timepicker-filter' ).length ) {
var filter_name = filter.find( '.um-timepicker-filter' ).data('filter_name');
var value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof value_from != 'undefined' || typeof value_to != 'undefined' ) {
request[ filter_name ] = [ value_from, value_to ];
}
} else {
var filter_name = filter.find('select').attr('name');
var value = um_get_data_for_directory( directory, 'filter_' + filter_name );
if ( typeof value != 'undefined' ) {
request[ filter_name ] = value.split( '||' );
}
}
});
}
wp.ajax.send( 'um_get_members', {
data: request,
success: function( answer ) {
//set last data hard for using on layouts reloading
um_member_directory_last_data[ hash ] = answer;
um_build_template( directory, answer.users );
um_members_hide_preloader( directory );
var pagination_template = wp.template( 'um-members-pagination' );
directory.find('.um-members-pagination-box').html( pagination_template( answer ) );
directory.data( 'total_pages', answer.pagination.total_pages );
jQuery( document ).trigger('um_members_rendered');
},
error: function( data ) {
console.log( data );
um_members_hide_preloader( directory );
}
});
}
function um_build_template( directory, data ) {
var layout = directory.data('view_type');
var template = wp.template( 'um-member-' + layout );
directory.find('.um-members-grid, .um-members-list').remove();
directory.find('.um-members-wrapper').prepend( template( data ) );
directory.addClass('um-loaded');
if ( directory.find('.um-members').length ) {
UM_Member_Grid( directory.find('.um-members') );
jQuery( window ).trigger( 'resize' );
}
jQuery( document ).trigger( "um_build_template", [ directory, data ] );
jQuery( window ).trigger( "resize" );
}
function UM_Member_Grid( container ) {
if ( container.find( '.um-member' ).length ) {
container.imagesLoaded( function() {
var $grid = container.masonry({
itemSelector: '.um-member',
columnWidth: '.um-member',
gutter: '.um-gutter-sizer'
});
$grid.on( 'layoutComplete', function( event, laidOutItems ) {
jQuery( document ).trigger( "um_grid_initialized", [ event, laidOutItems ] );
});
});
}
}
function um_change_tag( directory ) {
var filters_data = [];
var filter_array = [];
directory.find('.um-search-filter').each( function() {
var filter = jQuery(this);
var hoper,
filter_name,
query_value,
filter_title,
filter_range,
filter_value_title;
var filter_type;
if ( filter.find('input.um-datepicker-filter').length ) {
filter_type = 'datepicker';
filter.find('input.um-datepicker-filter').each( function() {
var range = jQuery(this).data('range');
if ( range === 'to' ) {
return;
}
var filter_name = jQuery(this).data('filter_name');
var filter_value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var filter_value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof filter_value_from === 'undefined' && typeof filter_value_to === 'undefined' ) {
return;
}
var from_val = jQuery(this).val();
var to_val = directory.find('input.um-datepicker-filter[data-range="to"][data-filter_name="' + filter_name + '"]').val();
var value;
if ( from_val !== '' && to_val !== '' ) {
value = from_val + ' - ' + to_val;
} else if ( from_val === '' ) {
value = 'before ' + to_val;
} else if ( to_val === '' ) {
value = 'since ' + from_val;
}
filters_data.push( {'name':filter_name, 'label':jQuery(this).data('filter-label'), 'value_label': value, 'value':[filter_value_from, filter_value_to], 'type':filter_type} );
});
} else if( filter.find('input.um-timepicker-filter').length ) {
filter_type = 'timepicker';
filter.find('input.um-timepicker-filter').each( function() {
var range = jQuery(this).data('range');
if ( range === 'to' ) {
return;
}
var filter_name = jQuery(this).data('filter_name');
var filter_value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var filter_value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof filter_value_from === 'undefined' && typeof filter_value_to === 'undefined' ) {
return;
}
var from_val = jQuery(this).val();
var to_val = directory.find('input.um-timepicker-filter[data-range="to"][data-filter_name="' + filter_name + '"]').val();
var value;
if ( from_val !== '' && to_val !== '' ) {
value = from_val + ' - ' + to_val;
} else if ( from_val === '' ) {
value = 'before ' + to_val;
} else if ( to_val === '' ) {
value = 'since ' + from_val;
}
filters_data.push( {'name':filter_name, 'label':jQuery(this).data('filter-label'), 'value_label': value, 'value':[filter_value_from, filter_value_to], 'type':filter_type} );
});
} else if( filter.find('select').length ) {
filter_type = 'select';
filter_name = filter.find('select').attr('name');
filter_title = filter.find('select').data('placeholder');
var filter_value = um_get_data_for_directory( directory, 'filter_' + filter_name );
if ( typeof filter_value == 'undefined' ) {
filter_value = [];
} else {
filter_value = filter_value.split( '||' );
}
jQuery.each( filter_value, function(i) {
var filter_value_title = filter.find('select option[value="' + filter_value[ i ] + '"]').data('value_label');
filters_data.push( {'name':filter_name, 'label':filter_title, 'value_label':filter_value_title, 'value':filter_value[ i ], 'type':filter_type} );
});
} else if( filter.find('div.ui-slider').length ) {
filter_type = 'slider';
filter_name = filter.find('div.ui-slider').data( 'field_name' );
var filter_value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var filter_value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof filter_value_from === 'undefined' && typeof filter_value_to === 'undefined' ) {
return;
}
filter_title = filter.find('div.um-slider-range').data('label');
var filter_value_title = filter.find('div.um-slider-range').data( 'placeholder' ).replace( '\{min_range\}', filter_value_from )
.replace( '\{max_range\}', filter_value_to )
.replace( '\{field_label\}', filter.find('div.um-slider-range').data('label') );
filters_data.push( {'name':filter_name, 'label':filter_title, 'value_label':filter_value_title, 'value':[filter_value_from, filter_value_to], 'type':filter_type} );
}
// if ( filter.find('input.um-datepicker-filter').length ) {
// hoper = 'datepicker';
//
// filter.find('input.um-datepicker-filter').each(function() {
// var _this = jQuery(this);
// var obj = {};
//
// if( _this.length ) {
// query_value = um_get_directory_storage( directory, 'filter_' + _this.data('filter_name') );
// filter_name = _this.data('filter_name');
// filter_range = _this.data('range');
//
// if ( query_value !== null ) {
// if( query_value[filter_range] ) {
// obj.name = filter_name;
// obj.label = _this.attr('placeholder');
// obj.range = filter_range;
// obj.value_title = _this.val();
// filter_array.push(obj);
// }
// }
// }
// });
//
// }
//
// if ( typeof( query_value ) != 'undefined' && query_value != null) {
// if( hoper == 'datepicker' ) {
// jQuery.each( filter_array, function(e) {
// var find = filters_data.find(function (item) {
// return item.name == filter_array[e].name && item.range == filter_array[e].range;
// });
// if( typeof( find ) == 'undefined' ) {
// filters_data.push(
// {
// 'name':filter_array[e].name,
// 'range':filter_array[e].range,
// 'label':filter_array[e].label,
// 'value_label':filter_array[e].value_title,
// 'value':query_value[filter_array[e].range],
// 'unique_id':unique_id
// }
// );
// }
// })
//
// }
// }
});
directory.find('.um-members-filter-tag').remove();
var filters_template = wp.template( 'um-members-filtered-line' );
directory.find('.um-filtered-line').prepend( filters_template( {'filters': filters_data} ) );
if ( filters_data.length > 0 ) {
directory.find('.um-filtered-line').show();
show_after_search = false;
} else {
directory.find('.um-filtered-line').hide();
show_after_search = true;
}
if ( directory.find( '.um-members-filter-remove' ).length === 0 ) {
directory.find('.um-clear-filters-a').hide();
} else {
directory.find('.um-clear-filters-a').show();
}
}
jQuery(document).ready( function() {
/**
* Change View Type Handlers
*/
//UI for change view type button
jQuery( document.body ).on( 'mouseover', '.um-member-directory-view-type', function() {
var $obj = jQuery(this).find('.um-member-directory-view-type-a:visible');
$obj.hide();
if ( $obj.next().length ) {
$obj.next().show().tipsy('show');
} else {
jQuery(this).find( '.um-member-directory-view-type-a:first' ).show().tipsy('show');
}
}).on( 'mouseout', '.um-member-directory-view-type', function() {
jQuery(this).find('.um-member-directory-view-type-a').hide().tipsy('hide');
jQuery(this).find('.um-member-directory-view-type-a[data-type="' + jQuery(this).parents( '.um-directory' ).data('view_type') + '"]').show();
});
//change layout handler
jQuery( document.body ).on( 'click', '.um-member-directory-view-type-a', function() {
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return false;
}
var $this = jQuery(this);
var views = $this.parents('.um-member-directory-view-type');
var $obj = views.find('.um-member-directory-view-type-a:visible');
$obj.hide();
if ( $obj.next().length ) {
$obj.next().show().tipsy('show');
} else {
views.find( '.um-member-directory-view-type-a:first' ).show().tipsy('show');
}
var data = um_member_directory_last_data[ um_members_get_hash( directory ) ];
if ( data !== null ) {
var layout = $this.data('type');
um_set_url_from_data( directory, 'view_type', layout );
directory.data( 'view_type', layout );
um_build_template( directory, data.users );
}
});
/**
* END: Change View Type Handlers
*/
/**
* General Search
*/
//searching
jQuery( document.body ).on( 'click', '.um-do-search', function() {
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
var pre_search = um_get_data_for_directory( directory, 'search' );
var search = directory.find('.um-search-line').val();
if ( search === pre_search || ( search === '' && typeof pre_search == 'undefined' ) ) {
return;
}
directory.data( 'general_search', search );
um_set_url_from_data( directory, 'search', search );
//set 1st page after search
directory.data( 'page', 1 );
um_set_url_from_data( directory, 'page', 1 );
um_ajax_get_members( directory );
});
//make search on Enter click
jQuery( document.body ).on( 'keypress', '.um-search-line', function(e) {
if ( e.which === 13 ) {
var directory = jQuery(this).parents('.um-directory');
directory.find('.um-do-search').trigger('click');
}
});
/**
* END: General Search
*/
/**
* Sorting
*/
jQuery( document.body ).on( 'change', '.um-member-directory-sorting-options', function() {
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
var sort = jQuery(this).val();
//
// var show_after_search = false;
// //set search line from session storage
// if ( directory.find('.um-search-line').length ) {
// var general_search = um_get_directory_storage( directory, 'general_search' );
// if ( general_search === null ) {
// //show results after search
// show_after_search = true;
// }
// }
//
// if ( jQuery('#tmpl-um-members-filtered-line').length ) {
// var filters_data = [];
// directory.find('.um-search-filter').each( function() {
// var filter = jQuery(this);
// var filter_name = filter.find('select').attr('name');
// var query_value = um_get_directory_storage( directory, 'filter_' + filter_name );
//
// if ( typeof( query_value ) != 'undefined' ) {
// if ( typeof( query_value ) == 'string' ) {
// filters_data.push( {'name':filter_name} );
// } else {
// jQuery.each( query_value, function() {
// filters_data.push( {'name': filter_name} );
// });
// }
// }
// });
//
// show_after_search = ( filters_data.length <= 0 );
// }
//
// if ( parseInt( directory.data( 'only_search' ) ) === 1 && show_after_search ) {
// return;
// }
directory.data( 'sorting', jQuery(this).val() );
um_set_url_from_data( directory, 'sort', sort );
um_ajax_get_members( directory );
});
/**
* END: Sorting
*/
/**
* Pagination
*/
jQuery( document.body ).on( 'click', '.um-directory .pagi:not(.current)', function() {
if ( jQuery(this).hasClass('disabled') ) {
return;
}
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
um_members_show_preloader( directory );
var page;
if ( 'first' === jQuery(this).data('page') ) {
page = 1;
} else if ( 'prev' === jQuery(this).data('page') ) {
page = directory.data( 'page' )*1 - 1;
} else if ( 'next' === jQuery(this).data('page') ) {
page = directory.data( 'page' )*1 + 1;
} else if ( 'last' === jQuery(this).data('page') ) {
page = parseInt( directory.data( 'total_pages' ) );
} else {
page = parseInt( jQuery(this).data('page') );
}
if ( page === 1 ) {
directory.find('.pagi[data-page="first"], .pagi[data-page="prev"]').addClass('disabled');
directory.find('.pagi[data-page="prev"], .pagi[data-page="last"]').removeClass('disabled');
} else if ( page === parseInt( directory.data( 'total_pages' ) ) ) {
directory.find('.pagi[data-page="prev"], .pagi[data-page="last"]').addClass('disabled');
directory.find('.pagi[data-page="first"], .pagi[data-page="prev"]').removeClass('disabled');
} else {
directory.find('.pagi[data-page="prev"], .pagi[data-page="last"]').removeClass('disabled');
directory.find('.pagi[data-page="first"], .pagi[data-page="prev"]').removeClass('disabled');
}
directory.find('.pagi').removeClass('current');
directory.find('.pagi[data-page="' + page + '"]').addClass('current');
directory.data( 'page', page );
um_set_url_from_data( directory, 'page', page );
um_ajax_get_members( directory );
});
//mobile pagination
jQuery( document.body ).on( 'change', '.um-directory .um-members-pagi-dropdown', function() {
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
var page = jQuery(this).val();
directory.find('.pagi').removeClass('current');
directory.find('.pagi[data-page="' + page + '"]').addClass('current');
directory.data( 'page', page );
um_set_url_from_data( directory, 'page', page );
um_ajax_get_members( directory );
});
/**
* END: Pagination
*/
/**
* Profile Cards actions
*/
jQuery( document.body ).on('click', '.um-member-more a', function(e){
e.preventDefault();
var block = jQuery(this).parents('.um-member');
var container = jQuery(this).parents('.um-members');
block.find('.um-member-more').hide();
block.find('.um-member-meta').slideDown( function(){ UM_Member_Grid( container ) } );
block.find('.um-member-less').fadeIn( );
setTimeout(function(){ UM_Member_Grid( container ) }, 100);
return false;
});
jQuery( document.body ).on('click', '.um-member-less a', function(e){
e.preventDefault();
var block = jQuery(this).parents('.um-member');
var container = jQuery(this).parents('.um-members');
block.find('.um-member-less').hide();
block.find('.um-member-meta').slideUp( function() {
block.find('.um-member-more').fadeIn();
UM_Member_Grid( container );
});
return false;
});
/**
* END: Profile Cards actions
*/
//filters controls
jQuery('.um-member-directory-filters a').click( function() {
var search_bar = jQuery(this).parents('.um-directory').find('.um-search');
if ( search_bar.is( ':visible' ) ) {
search_bar.slideUp(650);
} else {
search_bar.slideDown(650);
}
});
//filtration process
jQuery( document.body ).on( 'change', '.um-search-filter select', function() {
if ( jQuery(this).val() === '' ) {
return;
}
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
var filter_name = jQuery(this).prop('name');
var current_value = um_get_data_for_directory( directory, 'filter_' + filter_name );
if ( typeof current_value == 'undefined' ) {
current_value = [];
} else {
current_value = current_value.split( '||' );
}
if ( -1 === jQuery.inArray( jQuery(this).val(), current_value ) ) {
current_value.push( jQuery(this).val() );
current_value = current_value.join( '||' );
um_set_url_from_data( directory, 'filter_' + filter_name, current_value );
//set 1st page after filtration
directory.data( 'page', 1 );
um_set_url_from_data( directory, 'page', 1 );
}
jQuery(this).val('').trigger( 'change' );
um_ajax_get_members( directory );
um_change_tag( directory );
});
//slider filter
jQuery( '.um-slider' ).each( function() {
var slider = jQuery( this );
var directory = slider.parents('.um-directory');
var filter_name = slider.data('field_name');
var min_default_value = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var max_default_value = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof min_default_value == 'undefined' ) {
min_default_value = parseInt( slider.data('min') );
}
if ( typeof max_default_value == 'undefined' ) {
max_default_value = parseInt( slider.data('max') );
}
var default_value = [ min_default_value, max_default_value ];
slider.slider({
range: true,
min: parseInt( slider.data('min') ),
max: parseInt( slider.data('max') ),
values: default_value,
create: function( event, ui ) {
//console.log( ui );
},
step: 1,
slide: function( event, ui ) {
um_set_range_label( jQuery( this ), ui );
},
stop: function( event, ui ) {
if ( ! um_is_directory_busy( directory ) ) {
um_set_url_from_data( directory, 'filter_' + filter_name + '_from', ui.values[0] );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', ui.values[1] );
//set 1st page after filtration
directory.data( 'page', 1 );
um_set_url_from_data( directory, 'page', 1 );
um_ajax_get_members( directory );
um_change_tag( directory );
}
}
});
um_set_range_label( slider );
});
//datepicker filter
jQuery('.um-datepicker-filter').each( function() {
var elem = jQuery(this);
var min = new Date( elem.data('date_min')*1000 );
var max = new Date( elem.data('date_max')*1000 );
var $input = elem.pickadate({
selectYears: true,
min: min,
max: max,
formatSubmit: 'yyyy/mm/dd',
hiddenName: true,
onOpen: function() {
elem.blur();
},
onClose: function() {
elem.blur();
},
onSet: function( context ) {
var directory = elem.parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
var filter_name = elem.data( 'filter_name' );
var range = elem.data( 'range' );
var current_value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var current_value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof current_value_from === "undefined" ) {
current_value_from = min / 1000;
}
if ( typeof current_value_to === "undefined" ) {
current_value_to = max / 1000;
}
var select_val = context.select / 1000;
var change_val = elem.val();
if ( range === 'from' ) {
current_value_from = select_val;
} else if ( range === 'to' ) {
current_value_to = select_val;
}
um_set_url_from_data( directory, 'filter_' + filter_name + '_from', current_value_from );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', current_value_to );
//set 1st page after filtration
directory.data( 'page', 1 );
um_set_url_from_data( directory, 'page', 1 );
um_ajax_get_members( directory );
um_change_tag( directory );
//elem.val('');
//elem.data('value','');
}
});
var $picker = $input.pickadate('picker');
var $fname = elem.data('filter_name');
var $frange = elem.data('range');
var $directory = elem.parents('.um-directory');
var query_value = um_get_data_for_directory( $directory, 'filter_' + $fname + '_' + $frange );
if ( typeof query_value !== 'undefined' ) {
$picker.set( 'select', query_value*1000 );
//elem.attr('data-value',elem.val());
//elem.val(elem.val());
//elem.val('data-value', query_value*100);
}
});
//timepicker filter
jQuery('.um-timepicker-filter').each( function() {
var elem = jQuery(this);
//using arrays formatted as [HOUR,MINUTE]
var min = elem.data('min');
var max = elem.data('max');
var $input = elem.pickatime({
format: elem.data('format'),
interval: parseInt( elem.data('intervals') ),
min: elem.data('min'),
max: elem.data('max'),
formatSubmit: 'HH:i',
hiddenName: true,
onOpen: function() { elem.blur(); },
onClose: function() { elem.blur(); },
onSet: function( context ) {
var directory = elem.parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
var filter_name = elem.data( 'filter_name' );
var range = elem.data( 'range' );
var current_value_from = um_get_data_for_directory( directory, 'filter_' + filter_name + '_from' );
var current_value_to = um_get_data_for_directory( directory, 'filter_' + filter_name + '_to' );
if ( typeof current_value_from === "undefined" ) {
current_value_from = min;
}
if ( typeof current_value_to === "undefined" ) {
current_value_to = max;
}
if ( typeof context.select !== 'undefined' ) {
var select_val = context.select / 60;
var change_val = elem.val();
if ( range === 'from' ) {
current_value_from = select_val + ':00';
} else if ( range === 'to' ) {
current_value_to = select_val + ':00';
}
} else {
if ( range === 'from' ) {
current_value_from = min;
} else if ( range === 'to' ) {
current_value_to = max;
}
}
um_set_url_from_data( directory, 'filter_' + filter_name + '_from', current_value_from );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', current_value_to );
//set 1st page after filtration
directory.data( 'page', 1 );
um_set_url_from_data( directory, 'page', 1 );
um_ajax_get_members( directory );
um_change_tag( directory );
}
});
var $picker = $input.pickatime('picker');
var $fname = elem.data('filter_name');
var $frange = elem.data('range');
var $directory = elem.parents('.um-directory');
var query_value = um_get_data_for_directory( $directory, 'filter_' + $fname + '_' + $frange );
if ( typeof query_value !== 'undefined' ) {
$picker.set( 'select', query_value );
}
});
jQuery( document.body ).on( 'click', '.um-members-filter-remove', function() {
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
var removeItem = jQuery(this).data('value');
var filter_name = jQuery(this).data('name');
var type = jQuery(this).data('type');
if ( type === 'select' ) {
var current_value = um_get_data_for_directory( directory, 'filter_' + filter_name );
if ( typeof current_value == 'undefined' ) {
current_value = [];
} else {
current_value = current_value.split( '||' );
}
if ( -1 !== jQuery.inArray( removeItem.toString(), current_value ) ) {
current_value = jQuery.grep( current_value, function( value ) {
return value !== removeItem.toString();
});
}
if ( ! current_value.length ) {
current_value = '';
}
um_set_url_from_data( directory, 'filter_' + filter_name, current_value );
} else if ( type === 'slider' ) {
um_set_url_from_data( directory, 'filter_' + filter_name + '_from','' );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', '' );
} else if ( type === 'datepicker' ) {
um_set_url_from_data( directory, 'filter_' + filter_name + '_from','' );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', '' );
} else if ( type === 'timepicker' ) {
um_set_url_from_data( directory, 'filter_' + filter_name + '_from','' );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', '' );
}
//set 1st page after filtration
directory.data( 'page', 1 );
um_set_url_from_data( directory, 'page', 1 );
jQuery(this).parents('.um-members-filter-tag').remove();
um_ajax_get_members( directory );
if ( directory.find( '.um-members-filter-remove' ).length === 0 ) {
directory.find('.um-clear-filters-a').hide();
} else {
directory.find('.um-clear-filters-a').show();
}
});
jQuery( document.body ).on( 'click', '.um-clear-filters-a', function() {
var directory = jQuery(this).parents('.um-directory');
if ( um_is_directory_busy( directory ) ) {
return;
}
directory.find( '.um-members-filter-remove' ).each( function() {
var removeItem = jQuery(this).data('value');
var filter_name = jQuery(this).data('name');
var type = jQuery(this).data('type');
if ( type === 'select' ) {
var current_value = um_get_data_for_directory( directory, 'filter_' + filter_name );
if ( typeof current_value == 'undefined' ) {
current_value = [];
} else {
current_value = current_value.split( '||' );
}
if ( -1 !== jQuery.inArray( removeItem.toString(), current_value ) ) {
current_value = jQuery.grep( current_value, function( value ) {
return value !== removeItem.toString();
});
}
if ( ! current_value.length ) {
current_value = '';
}
um_set_url_from_data( directory, 'filter_' + filter_name, current_value );
} else if ( type === 'slider' ) {
um_set_url_from_data( directory, 'filter_' + filter_name + '_from','' );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', '' );
} else if ( type === 'datepicker' ) {
um_set_url_from_data( directory, 'filter_' + filter_name + '_from','' );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', '' );
} else if ( type === 'timepicker' ) {
um_set_url_from_data( directory, 'filter_' + filter_name + '_from','' );
um_set_url_from_data( directory, 'filter_' + filter_name + '_to', '' );
}
});
//set 1st page after filtration
directory.data( 'page', 1 );
um_set_url_from_data( directory, 'page', 1 );
directory.find('.um-members-filter-tag').remove();
um_ajax_get_members( directory );
jQuery(this).hide();
});
// jQuery('.um-directory .um-member-connect').each(function(){
// if ( jQuery(this).find('a').length == 0 ) {
// jQuery(this).remove();
// }
// });
//
// jQuery('.um-member-meta-main').each(function(){
// if ( jQuery(this).find('.um-member-metaline').length == 0 && jQuery(this).find('.um-member-connect').find('a').length == 0 ) {
// jQuery(this).remove();
// }
// });
// jQuery(document.body).on('click', '.um-do-search', function(e){
// e.preventDefault();
//
// jQuery(this).parents('form').find('input').filter(function(e){
// if ( this.value.length ===0 ) {
// return true;
// }
// }).prop('disabled', true);
//
//
// jQuery(this).parents('form').find('select').filter(function(e){
// if ( this.value.length ===0 ) {
// return true;
// }
// }).prop('disabled', true);
// jQuery(this).parents('form').submit();
// return false;
// });
// jQuery('.um-close-filter').click( function() {
// var search_bar = jQuery(this).parents('.um-directory').find('.um-search');
// search_bar.slideUp(650);
// });
/**
* First Page Loading
*/
//Init Directories
jQuery( '.um-directory' ).each( function() {
var directory = jQuery(this);
var hash = um_members_get_hash( directory );
um_member_directories.push( hash );
var show_after_search = false;
var search = um_get_search( directory );
if ( search && typeof search !== 'undefined' ) {
show_after_search = true;
}
if ( ! ( directory.data( 'only_search' ) > 0 && show_after_search ) ) {
//show preloader at first
um_members_show_preloader( directory );
} else {
return;
}
um_ajax_get_members( directory );
um_change_tag( directory );
// if ( jQuery('#tmpl-um-members-filtered-line').length ) {
// um_change_tag( directory );
// }
// if ( directory.data( 'only_search' ) > 0 && show_after_search ) {
// um_members_hide_preloader( directory );
// return;
// }
//um_ajax_get_members( directory, {page: page, sorting: sort} );
});
});