관리-도구
편집 파일: price-slider.js
/* global kkart_price_slider_params, accounting */ jQuery( function( $ ) { // kkart_price_slider_params is required to continue, ensure the object exists if ( typeof kkart_price_slider_params === 'undefined' ) { return false; } $( document.body ).bind( 'price_slider_create price_slider_slide', function( event, min, max ) { $( '.price_slider_amount span.from' ).html( accounting.formatMoney( min, { symbol: kkart_price_slider_params.currency_format_symbol, decimal: kkart_price_slider_params.currency_format_decimal_sep, thousand: kkart_price_slider_params.currency_format_thousand_sep, precision: kkart_price_slider_params.currency_format_num_decimals, format: kkart_price_slider_params.currency_format } ) ); $( '.price_slider_amount span.to' ).html( accounting.formatMoney( max, { symbol: kkart_price_slider_params.currency_format_symbol, decimal: kkart_price_slider_params.currency_format_decimal_sep, thousand: kkart_price_slider_params.currency_format_thousand_sep, precision: kkart_price_slider_params.currency_format_num_decimals, format: kkart_price_slider_params.currency_format } ) ); $( document.body ).trigger( 'price_slider_updated', [ min, max ] ); }); function init_price_filter() { $( 'input#min_price, input#max_price' ).hide(); $( '.price_slider, .price_label' ).show(); var min_price = $( '.price_slider_amount #min_price' ).data( 'min' ), max_price = $( '.price_slider_amount #max_price' ).data( 'max' ), step = $( '.price_slider_amount' ).data( 'step' ) || 1, current_min_price = $( '.price_slider_amount #min_price' ).val(), current_max_price = $( '.price_slider_amount #max_price' ).val(); $( '.price_slider:not(.ui-slider)' ).slider({ range: true, animate: true, min: min_price, max: max_price, step: step, values: [ current_min_price, current_max_price ], create: function() { $( '.price_slider_amount #min_price' ).val( current_min_price ); $( '.price_slider_amount #max_price' ).val( current_max_price ); $( document.body ).trigger( 'price_slider_create', [ current_min_price, current_max_price ] ); }, slide: function( event, ui ) { $( 'input#min_price' ).val( ui.values[0] ); $( 'input#max_price' ).val( ui.values[1] ); $( document.body ).trigger( 'price_slider_slide', [ ui.values[0], ui.values[1] ] ); }, change: function( event, ui ) { $( document.body ).trigger( 'price_slider_change', [ ui.values[0], ui.values[1] ] ); } }); } init_price_filter(); var hasSelectiveRefresh = ( 'undefined' !== typeof wp && wp.customize && wp.customize.selectiveRefresh && wp.customize.widgetsPreview && wp.customize.widgetsPreview.WidgetPartial ); if ( hasSelectiveRefresh ) { wp.customize.selectiveRefresh.bind( 'partial-content-rendered', function() { init_price_filter(); } ); } });