2015-08-07 16:10:01 +00:00
|
|
|
/* global htmlSettingsTaxLocalizeScript */
|
2015-08-07 15:04:55 +00:00
|
|
|
/**
|
|
|
|
* Used by woocommerce/includes/admin/settings/views/html-settings-tax.php
|
|
|
|
*/
|
|
|
|
|
|
|
|
(function($, data, wp){
|
|
|
|
$(function() {
|
2015-08-07 19:36:12 +00:00
|
|
|
|
|
|
|
var rowTemplate = wp.template( 'wc-tax-table-row' ),
|
2015-08-07 20:36:50 +00:00
|
|
|
paginationTemplate = wp.template( 'wc-tax-table-pagination' ),
|
2015-08-07 19:36:12 +00:00
|
|
|
$tbody = $('#rates');
|
|
|
|
|
2015-08-07 19:44:10 +00:00
|
|
|
/**
|
|
|
|
* Build the table contents.
|
|
|
|
* @param rates
|
|
|
|
*/
|
|
|
|
function renderTableContents( rates ) {
|
|
|
|
// Blank out the contents.
|
|
|
|
$tbody.empty();
|
|
|
|
|
|
|
|
// Populate $tbody with the current page of results.
|
|
|
|
$.each( rates, function ( id, rowData ) {
|
|
|
|
$tbody.append( rowTemplate( rowData ) );
|
|
|
|
} );
|
|
|
|
|
|
|
|
// Initialize autocomplete for countries.
|
|
|
|
$tbody.find( 'td.country input' ).autocomplete({
|
|
|
|
source: data.countries,
|
|
|
|
minLength: 3
|
|
|
|
});
|
|
|
|
|
|
|
|
// Initialize autocomplete for states.
|
|
|
|
$tbody.find( 'td.state input' ).autocomplete({
|
|
|
|
source: data.states,
|
|
|
|
minLength: 3
|
|
|
|
});
|
2015-08-07 19:47:26 +00:00
|
|
|
|
|
|
|
// Postcode and city don't have `name` values by default. They're only created if the contents changes, to save on database queries (I think)
|
|
|
|
$tbody.find( 'td.postcode input, td.city input').change(function() {
|
|
|
|
$(this).attr( 'name', $(this).data( 'name' ) );
|
|
|
|
});
|
2015-08-07 19:44:10 +00:00
|
|
|
}
|
|
|
|
|
2015-08-07 20:02:45 +00:00
|
|
|
/**
|
|
|
|
* Handle the initial display.
|
|
|
|
*/
|
|
|
|
if ( data.rates.length <= data.limit ) {
|
|
|
|
renderTableContents( data.rates );
|
|
|
|
} else {
|
|
|
|
var first_index = data.limit * ( data.page - 1),
|
|
|
|
last_index = data.limit * data.page;
|
2015-08-07 19:44:10 +00:00
|
|
|
|
2015-08-07 20:02:45 +00:00
|
|
|
renderTableContents( data.rates.slice( first_index, last_index ) );
|
|
|
|
|
|
|
|
// We've now displayed our initial page, time to render the pagination box.
|
2015-08-07 20:36:50 +00:00
|
|
|
$('#rates-pagination' ).html( paginationTemplate( {
|
|
|
|
qty_rates : data.rates.length,
|
|
|
|
current_page : data.page,
|
|
|
|
qty_pages : Math.ceil( data.rates.length / data.limit )
|
|
|
|
} ) );
|
2015-08-07 20:02:45 +00:00
|
|
|
}
|
2015-08-07 15:42:49 +00:00
|
|
|
|
2015-08-07 19:36:12 +00:00
|
|
|
$('.wc_tax_rates .remove_tax_rates').click(function() {
|
|
|
|
if ( $tbody.find('tr.current').length > 0 ) {
|
|
|
|
var $current = $tbody.find('tr.current');
|
|
|
|
$current.find('input').val('');
|
|
|
|
$current.find('input.remove_tax_rate').val('1');
|
2015-08-07 15:42:49 +00:00
|
|
|
|
2015-08-07 19:36:12 +00:00
|
|
|
$current.each(function(){
|
|
|
|
if ( $(this).is('.new') ) {
|
|
|
|
$( this ).remove();
|
2015-08-07 15:42:49 +00:00
|
|
|
} else {
|
2015-08-07 19:36:12 +00:00
|
|
|
$( this ).hide();
|
2015-08-07 15:42:49 +00:00
|
|
|
}
|
2015-08-07 19:36:12 +00:00
|
|
|
});
|
|
|
|
} else {
|
|
|
|
window.alert( data.strings.no_rows_selected );
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle the exporting of tax rates.
|
|
|
|
*
|
|
|
|
* As an aside: Why is this being handled in Javascript instead of being built by php? -George
|
|
|
|
*/
|
|
|
|
$('.wc_tax_rates .export').click(function() {
|
|
|
|
var csv_data = 'data:application/csv;charset=utf-8,' + data.strings.csv_data_cols.join(',') + '\n';
|
|
|
|
|
|
|
|
$('#rates tr:visible').each(function() {
|
|
|
|
var row = '';
|
|
|
|
$(this).find('td:not(.sort) input').each(function() {
|
|
|
|
var val = '';
|
|
|
|
|
|
|
|
if ( $(this).is('.checkbox') ) {
|
|
|
|
if ( $(this).is(':checked') ) {
|
|
|
|
val = 1;
|
|
|
|
} else {
|
|
|
|
val = 0;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
val = $(this).val();
|
|
|
|
if ( ! val ) {
|
|
|
|
val = $( this ).attr( 'placeholder' );
|
|
|
|
}
|
2015-08-07 16:10:01 +00:00
|
|
|
}
|
2015-08-07 19:36:12 +00:00
|
|
|
row = row + val + ',';
|
|
|
|
});
|
|
|
|
row = row + data.current_class;
|
|
|
|
//row.substring( 0, row.length - 1 );
|
|
|
|
csv_data = csv_data + row + '\n';
|
2015-08-07 15:42:49 +00:00
|
|
|
});
|
|
|
|
|
2015-08-07 19:36:12 +00:00
|
|
|
$(this).attr( 'href', encodeURI( csv_data ) );
|
2015-08-07 15:42:49 +00:00
|
|
|
|
2015-08-07 19:36:12 +00:00
|
|
|
return true;
|
|
|
|
});
|
2015-08-07 15:42:49 +00:00
|
|
|
|
2015-08-07 19:36:12 +00:00
|
|
|
/**
|
|
|
|
* Add a new blank row to the table for the user to fill out and save.
|
|
|
|
*/
|
|
|
|
$('.wc_tax_rates .insert').click(function() {
|
|
|
|
var size = $tbody.find('tr').length;
|
|
|
|
var code = wp.template( 'wc-tax-table-row' )( {
|
|
|
|
tax_rate_id : 'new-' + size,
|
|
|
|
tax_rate_priority : 1,
|
|
|
|
tax_rate_shipping : 1,
|
|
|
|
newRow : true
|
|
|
|
} );
|
|
|
|
|
|
|
|
if ( $tbody.find('tr.current').length > 0 ) {
|
|
|
|
$tbody.find('tr.current').after( code );
|
|
|
|
} else {
|
|
|
|
$tbody.append( code );
|
|
|
|
}
|
|
|
|
|
|
|
|
$( 'td.country input' ).autocomplete({
|
|
|
|
source: data.countries,
|
|
|
|
minLength: 3
|
|
|
|
});
|
2015-08-07 15:42:49 +00:00
|
|
|
|
2015-08-07 19:36:12 +00:00
|
|
|
$( 'td.state input' ).autocomplete({
|
|
|
|
source: data.states,
|
|
|
|
minLength: 3
|
|
|
|
});
|
2015-08-07 15:42:49 +00:00
|
|
|
|
2015-08-07 19:36:12 +00:00
|
|
|
return false;
|
2015-08-07 15:42:49 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
});
|
2015-08-07 15:04:55 +00:00
|
|
|
})(jQuery, htmlSettingsTaxLocalizeScript, wp);
|