Find tax when update

This commit is contained in:
Michael RICOIS 2018-03-09 12:41:14 +01:00
parent c86f90f0eb
commit 2985b1ed4f
2 changed files with 63 additions and 43 deletions

View File

@ -281,26 +281,26 @@ class TaxCore extends ObjectModel
*/ */
public static function getProductTaxRate($id_product, $id_address = NULL) public static function getProductTaxRate($id_product, $id_address = NULL)
{ {
$id_country = (int)Country::getDefaultCountryId(); $id_country = (int)Country::getDefaultCountryId();
$id_state = 0; $id_state = 0;
$id_county = 0; $id_county = 0;
$rate = 0; $rate = 0;
if (!empty($id_address)) if (!empty($id_address)) {
{ $address_infos = Address::getCountryAndState($id_address);
$address_infos = Address::getCountryAndState($id_address); if ($address_infos['id_country']) {
if ($address_infos['id_country']) $id_country = (int)($address_infos['id_country']);
{ $id_state = (int)$address_infos['id_state'];
$id_country = (int)($address_infos['id_country']); $id_county = (int)County::getIdCountyByZipCode($address_infos['id_state'], $address_infos['postcode']);
$id_state = (int)$address_infos['id_state'];
$id_county = (int)County::getIdCountyByZipCode($address_infos['id_state'], $address_infos['postcode']);
} }
if (!empty($address_infos['vat_number']) AND $address_infos['id_country'] != Configuration::get('VATNUMBER_COUNTRY') AND Configuration::get('VATNUMBER_MANAGEMENT')) if (!empty($address_infos['vat_number']) AND $address_infos['id_country'] != Configuration::get('VATNUMBER_COUNTRY') AND Configuration::get('VATNUMBER_MANAGEMENT')) {
return 0; return 0;
}
} }
if ($rate = Tax::getProductTaxRateViaRules((int)$id_product, (int)$id_country, (int)$id_state, (int)$id_county)) if ($rate = Tax::getProductTaxRateViaRules((int)$id_product, (int)$id_country, (int)$id_state, (int)$id_county)) {
return $rate; return $rate;
}
return $rate; return $rate;
} }

View File

@ -548,31 +548,35 @@ class AdminBulkUpdate extends AdminTab {
$prices = array(); $prices = array();
if (Tools::getValue('price_process') == 2) { if (Tools::getValue('price_process') == 2) {
while($line = fgetcsv($f, 0, ';')) { while ($line = fgetcsv($f, 0, ';')) {
if(empty($line[0])) { if (empty($line[0])) {
continue; continue;
} }
$products[] = (int) $line[0]; $products[] = (int) $line[0];
} }
} elseif(Tools::getValue('price_process') == 3 || Tools::getValue('price_process') == 4) { }
while($line = fgetcsv($f, 0, ';')) { // Prix d'achat HT || Prix public TTC
if(empty($line[0])) { elseif (Tools::getValue('price_process') == 3 || Tools::getValue('price_process') == 4) {
while ($line = fgetcsv($f, 0, ';')) {
if (empty($line[0])) {
continue; continue;
} }
$prices[] = array( $prices[] = array(
(int) $line[0], (int) $line[0],
$line[1] $line[1]
); );
} }
} else { }
while($line = fgetcsv($f, 0, ';')) { // Reduction
if(empty($line[0])) { else {
while ($line = fgetcsv($f, 0, ';')) {
if (empty($line[0])) {
continue; continue;
} }
if(!isset($line[1])) { if (!isset($line[1])) {
continue; continue;
} }
@ -587,6 +591,7 @@ class AdminBulkUpdate extends AdminTab {
fclose($f); fclose($f);
// Reduction || ...
if (Tools::getValue('price_process') == 1 || Tools::getValue('price_process') == 2) { if (Tools::getValue('price_process') == 1 || Tools::getValue('price_process') == 2) {
Db::getInstance()->ExecuteS(' Db::getInstance()->ExecuteS('
DELETE FROM `'._DB_PREFIX_.'specific_price` DELETE FROM `'._DB_PREFIX_.'specific_price`
@ -594,9 +599,10 @@ class AdminBulkUpdate extends AdminTab {
'); ');
} }
// Reduction
if (Tools::getValue('price_process') == 1) { if (Tools::getValue('price_process') == 1) {
foreach($prices as $price) { foreach ($prices as $price) {
if((int) $price[0] != 0) { if ((int) $price[0] != 0) {
Db::getInstance()->ExecuteS(' Db::getInstance()->ExecuteS('
INSERT INTO `'._DB_PREFIX_.'specific_price` VALUES ( INSERT INTO `'._DB_PREFIX_.'specific_price` VALUES (
DEFAULT, DEFAULT,
@ -618,51 +624,64 @@ class AdminBulkUpdate extends AdminTab {
} }
} }
} }
// Prix d'achat HT
if (Tools::getValue('price_process') == 3) { if (Tools::getValue('price_process') == 3) {
foreach($prices as $price) { foreach ($prices as $price) {
if((int) $price[0] != 0){ if ((int) $price[0] != 0){
$price[1] = str_replace(',', '.', $price[1]); $price[1] = str_replace(',', '.', $price[1]);
$price_ht = floatval($price[1]); $price_ht = floatval($price[1]);
Db::getInstance()->ExecuteS(' Db::getInstance()->ExecuteS('
UPDATE `'._DB_PREFIX_.'product` UPDATE `'._DB_PREFIX_.'product`
SET wholesale_price = '. (float)$price_ht .' SET wholesale_price = '. (float)$price_ht .'
WHERE id_product ='. (int)$price[0]); WHERE id_product ='. (int)$price[0]);
}else{ } else {
$output .= '<p class="error">ID produit à 0, ligne non traitée : '.serialize($price).'</p>'; $output .= '<p class="error">ID produit à 0, ligne non traitée : '.serialize($price).'</p>';
} }
} }
} }
// Prix public TTC
if (Tools::getValue('price_process') == 4) { if (Tools::getValue('price_process') == 4) {
foreach($prices as $price) { foreach ($prices as $price) {
if((int) $price[0] != 0){ if ((int) $price[0] != 0){
$price[1] = str_replace(',', '.', $price[1]); $price[1] = str_replace(',', '.', $price[1]);
$price_ht = floatval($price[1] / 1.20); // Find Tax for this id product
// product.id_tax_rules_group => tax_rules_group => tax_rule => tax.rate
$tax = new Tax();
$taxValue = $tax->getProductTaxRate((int)$price[0]);
if ($taxValue == 0) {
$taxValue = 20;
}
$price_ht = floatval($price[1] / (1 + $taxValue / 100) );
Db::getInstance()->ExecuteS(' Db::getInstance()->ExecuteS('
UPDATE `'._DB_PREFIX_.'product` UPDATE `'._DB_PREFIX_.'product`
SET price = '. (float)$price_ht .' SET price = '. (float)$price_ht .'
WHERE id_product ='. (int)$price[0]); WHERE id_product ='. (int)$price[0]);
}else{ } else {
$output .= '<p class="error">ID produit à 0, ligne non traitée : '.serialize($price).'</p>'; $output .= '<p class="error">ID produit à 0, ligne non traitée : '.serialize($price).'</p>';
} }
} }
} }
$output .= '<p class="conf">'.$this->l('Products updated').'</p>'; $output .= '<p class="conf">'.$this->l('Products updated').'</p>';
} elseif (Tools::isSubmit('submitUploadProductDescriptions')) { }
elseif (Tools::isSubmit('submitUploadProductDescriptions')) {
$id_lang = Tools::getValue('description_process'); $id_lang = Tools::getValue('description_process');
$f = fopen($_FILES['csvfile']['tmp_name'], 'r'); $f = fopen($_FILES['csvfile']['tmp_name'], 'r');
fgetcsv($f, 0, ';'); fgetcsv($f, 0, ';');
$products = array(); $products = array();
while($line = fgetcsv($f, 0, ';')) { while ($line = fgetcsv($f, 0, ';')) {
if($line[0] == '' || $line[1] == '') { if ($line[0] == '' || $line[1] == '') {
continue; continue;
} }
$products[] = $line; $products[] = $line;
} }
foreach($products as $line) { foreach ($products as $line) {
$result = Db::getInstance()->ExecuteS(' $result = Db::getInstance()->ExecuteS('
UPDATE `'._DB_PREFIX_.'product_lang` UPDATE `'._DB_PREFIX_.'product_lang`
SET `description` = "'. pSQL($line[1],true) .'" SET `description` = "'. pSQL($line[1],true) .'"
@ -676,14 +695,15 @@ class AdminBulkUpdate extends AdminTab {
fclose($f); fclose($f);
$output .= '<p class="conf">'.$this->l('Products updated').'</p>'; $output .= '<p class="conf">'.$this->l('Products updated').'</p>';
} elseif (Tools::isSubmit('submitUploadCombinations')) { }
elseif (Tools::isSubmit('submitUploadCombinations')) {
$f = fopen($_FILES['csvfile']['tmp_name'], 'r'); $f = fopen($_FILES['csvfile']['tmp_name'], 'r');
fgetcsv($f, 0, ';'); fgetcsv($f, 0, ';');
$products = array(); $products = array();
while($line = fgetcsv($f, 0, ';')) { while ($line = fgetcsv($f, 0, ';')) {
if(empty($line[0])) { if (empty($line[0])) {
continue; continue;
} }