2016-03-16 11:49:15 +01:00
|
|
|
<?php
|
|
|
|
if(!defined('_PS_VERSION_')) {
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
class AdminBraderie extends AdminTab
|
|
|
|
{
|
|
|
|
private $_html = '';
|
|
|
|
private $error = '';
|
|
|
|
|
|
|
|
public function display()
|
|
|
|
{
|
|
|
|
global $cookie;
|
|
|
|
|
|
|
|
$id_category = Tools::getValue('id_category', 1);
|
|
|
|
$id_product = Tools::getValue('id_product', false);
|
|
|
|
|
|
|
|
$db = Db::getInstance();
|
2016-03-31 11:51:37 +02:00
|
|
|
/*$sql_category = '
|
2016-03-16 11:49:15 +01:00
|
|
|
SELECT * FROM `'._DB_PREFIX_.'privatesale` ps
|
|
|
|
LEFT JOIN `'._DB_PREFIX_.'category_lang` cl ON ps.`id_category` = cl.`id_category`
|
|
|
|
WHERE ps.`braderie` = 1
|
2016-03-31 11:51:37 +02:00
|
|
|
AND cl.`id_lang` = '.(int) $cookie->id_lang;*/
|
|
|
|
$sql_category = '
|
|
|
|
SELECT c.`id_category`, cl.`name` FROM `'._DB_PREFIX_.'category` c
|
|
|
|
LEFT JOIN `'._DB_PREFIX_.'category_lang` cl ON c.`id_category` = cl.`id_category`
|
|
|
|
WHERE c.`id_parent` = 1
|
|
|
|
AND cl.`id_lang` = '.(int) $cookie->id_lang.'
|
|
|
|
ORDER BY c.`id_category` DESC';
|
2016-03-16 11:49:15 +01:00
|
|
|
$categories = $db->ExecuteS($sql_category);
|
|
|
|
|
2016-03-31 11:51:37 +02:00
|
|
|
$ids_categories = array();
|
|
|
|
foreach ($categories as $key => $category) {
|
|
|
|
$ids_categories[] = (int) $category["id_category"];
|
|
|
|
}
|
|
|
|
|
|
|
|
$small_titles = array();
|
|
|
|
foreach (Db::getInstance()->executeS('
|
|
|
|
SELECT ex.`value`, ps.`id_category`
|
|
|
|
FROM `'._DB_PREFIX_.'privatesale_extrafield_sale` ex
|
|
|
|
LEFT JOIN `'._DB_PREFIX_.'privatesale` ps on ex.`id_sale` = ps.`id_sale`
|
|
|
|
LEFT JOIN `'._DB_PREFIX_.'category` c on c.`id_category` = ps.`id_category`
|
|
|
|
WHERE ex.`id_field` = 1
|
|
|
|
AND ex.`id_lang` = '. (int) $cookie->id_lang.'
|
|
|
|
AND c.`id_category` IN ('.implode(',', $ids_categories).')
|
|
|
|
') as $key => $data) {
|
|
|
|
$small_titles[(int) $data['id_category']] = $data['value'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->_html .= $this->_buildHtmlCategoryBlock($categories, $small_titles);
|
2016-03-16 11:49:15 +01:00
|
|
|
|
|
|
|
$this->_html .= '<link type="text/css" rel="stylesheet" href="'._MODULE_DIR_.'bulkupdate/chosen.min.css" />';
|
|
|
|
$this->_html .= '<script type="text/javascript" src="'._MODULE_DIR_.'bulkupdate/chosen.jquery.min.js"></script>';
|
|
|
|
$this->_html .= '<script type="text/javascript">
|
|
|
|
$(function() {
|
|
|
|
|
|
|
|
$(".chosen-select").chosen(
|
|
|
|
{
|
|
|
|
allow_single_deselect:true,
|
|
|
|
placeholder_text_single : "Choisir une vente",
|
|
|
|
no_results_text : "Aucun résultat",
|
|
|
|
enable_split_word_search : true,
|
|
|
|
search_contains : true,
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
var $token = "'.Tools::getAdminToken('AdminCatalog'.(int)(Tab::getIdFromClassName('AdminCatalog')).(int)($cookie->id_employee)).'";
|
2016-03-21 10:07:35 +01:00
|
|
|
var $product_id = 0;
|
2016-03-16 11:49:15 +01:00
|
|
|
|
|
|
|
$(\'#sale\').change(function() {
|
|
|
|
$.ajax({
|
|
|
|
type: \'POST\',
|
|
|
|
url: \''._MODULE_DIR_.'braderie/ajax.php?action=getCategories'.'\',
|
|
|
|
dataType: \'json\',
|
|
|
|
data: { sale: $(this).val() },
|
|
|
|
success: function(response) {
|
|
|
|
$(\'#category\').empty();
|
|
|
|
for (var i in response) {
|
|
|
|
var html = \'<option value="\'+ response[i].id_category +\'">\'+ response[i].id_category +\' - \'+ response[i].name +\'</option>\';
|
|
|
|
$(\'#category\').append(html);
|
|
|
|
}
|
|
|
|
$(".chosen-select").trigger("chosen:updated");
|
2016-03-16 18:05:41 +01:00
|
|
|
$("#divider, #category_input_group, #ean_input_group, #storage_input_group, #button_input_group, #show_current_category_button, #quantity_input_group").show();
|
2016-03-16 11:49:15 +01:00
|
|
|
$("#error").empty();
|
|
|
|
},
|
|
|
|
error: function(xhr) {
|
|
|
|
$("#ean_from_product").empty();
|
|
|
|
$("#error").empty().append(JSON.parse(xhr.responseText));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2016-03-22 16:55:07 +01:00
|
|
|
$("#category").change(function(event) {
|
2016-03-16 11:49:15 +01:00
|
|
|
$("#show_current_category_button").show();
|
|
|
|
});
|
|
|
|
|
2016-03-22 16:55:07 +01:00
|
|
|
$("#input_ean").change(function(event) {
|
2016-03-16 11:49:15 +01:00
|
|
|
$.ajax({
|
|
|
|
type: \'POST\',
|
|
|
|
url: \''._MODULE_DIR_.'braderie/ajax.php?action=getProductId'.'\',
|
|
|
|
dataType: \'json\',
|
|
|
|
data: { ean: $(this).val() },
|
|
|
|
success: function(response) {
|
2016-03-22 16:32:33 +01:00
|
|
|
if (response.name == null) {
|
|
|
|
$("#error").empty().append("'.$this->l('Aucun produit n\'a été trouvé. Vérifier le code EAN').'");
|
|
|
|
$("#ean_from_product").empty();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-03-16 11:49:15 +01:00
|
|
|
$product_id = response.id_product;
|
2016-03-21 10:07:35 +01:00
|
|
|
$attibute_id = response.id_product_attribute;
|
2016-04-11 12:13:41 +02:00
|
|
|
if (response.attribute_name) {
|
|
|
|
$("#ean_from_product").empty().append(response.name+" - "+response.attribute_name);
|
|
|
|
} else {
|
|
|
|
$("#ean_from_product").empty().append(response.name);
|
|
|
|
}
|
2016-03-21 10:07:35 +01:00
|
|
|
if ($attibute_id) {
|
|
|
|
$("#hidden_attribute_id").val($attibute_id);
|
|
|
|
} else {
|
|
|
|
$("#hidden_attribute_id").val(0);
|
|
|
|
}
|
2016-03-23 11:49:34 +01:00
|
|
|
$("#hidden_product_id").val($product_id);
|
2016-04-12 16:11:08 +02:00
|
|
|
$("#error").empty();
|
|
|
|
$("#input_storage").focus();
|
2016-03-16 11:49:15 +01:00
|
|
|
},
|
|
|
|
error: function(xhr) {
|
|
|
|
$("#ean_from_product").empty();
|
|
|
|
$("#error").empty().append(JSON.parse(xhr.responseText));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2016-03-22 16:55:07 +01:00
|
|
|
$("#check_button").click(function(event) {
|
2016-03-23 11:49:34 +01:00
|
|
|
|
|
|
|
if ($product_id == undefined || $product_id == 0) {
|
2016-03-16 11:49:15 +01:00
|
|
|
$("#error").empty().append("'.$this->l('Aucun produit n\'a été trouvé. Vérifier le code EAN').'");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($token.length == 0) {
|
|
|
|
$("#error").empty().append("'.$this->l('Un problème de sécurité est survenu. Merci de réinitialisé la page').'");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-03-23 11:49:34 +01:00
|
|
|
window.open("?tab=AdminCatalog&updateproduct&id_product=" + $product_id + "&token=" + $token);
|
2016-03-16 11:49:15 +01:00
|
|
|
return false;
|
|
|
|
});
|
|
|
|
|
2016-04-12 16:11:08 +02:00
|
|
|
$("#input_storage").change(function(event) {
|
|
|
|
event.preventDefault();
|
|
|
|
if ($product_id == undefined || $product_id == 0) {
|
|
|
|
$("#error").empty().append("'.$this->l('Aucun produit n\'a été trouvé. Vérifier le code EAN').'");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
var emplacement = $("#input_storage").val();
|
|
|
|
|
|
|
|
if (emplacement.length == 0 || emplacement>205) {
|
|
|
|
$("#error").empty().append("'.$this->l('L\'emplacement n\'est pas renseigné ou est mal renseigné').'");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($("#input_quantity").val().length == 0) {
|
|
|
|
$("#error").empty().append("'.$this->l('La quantité n\'est pas renseignée').'");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$("#hidden_product_id").val($product_id);
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
type: \'POST\',
|
|
|
|
url: \''._MODULE_DIR_.'braderie/ajax.php?action=addToSellout'.'\',
|
|
|
|
dataType: \'json\',
|
|
|
|
data: {
|
|
|
|
parent_category: $("#sale").val(),
|
|
|
|
category: $("#category").val(),
|
|
|
|
storage: $("#input_storage").val(),
|
|
|
|
product: $("#hidden_product_id").val(),
|
|
|
|
quantity: $("#input_quantity").val(),
|
|
|
|
attribute: $("#hidden_attribute_id").val()
|
|
|
|
},
|
|
|
|
success: function(response) {
|
|
|
|
$("#error").empty().append(response);
|
|
|
|
$("#input_ean, #input_storage").val("");
|
|
|
|
$("#ean_from_product").empty();
|
|
|
|
$("#input_ean").focus();
|
|
|
|
},
|
|
|
|
error: function(xhr) {
|
|
|
|
$("#error").empty().append(JSON.parse(xhr.responseText));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
|
2016-03-22 16:55:07 +01:00
|
|
|
$("#add_button").click(function(event) {
|
2016-03-21 10:07:35 +01:00
|
|
|
event.preventDefault();
|
2016-04-25 10:43:24 +02:00
|
|
|
return false;
|
|
|
|
|
2016-03-22 16:32:33 +01:00
|
|
|
if ($product_id == undefined || $product_id == 0) {
|
2016-03-16 11:49:15 +01:00
|
|
|
$("#error").empty().append("'.$this->l('Aucun produit n\'a été trouvé. Vérifier le code EAN').'");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
var emplacement = $("#input_storage").val();
|
|
|
|
|
2016-04-05 14:20:50 +02:00
|
|
|
if (emplacement.length == 0 || emplacement>205) {
|
|
|
|
$("#error").empty().append("'.$this->l('L\'emplacement n\'est pas renseigné ou est mal renseigné').'");
|
2016-03-16 11:49:15 +01:00
|
|
|
return false;
|
|
|
|
}
|
2016-03-22 16:32:33 +01:00
|
|
|
|
|
|
|
if ($("#input_quantity").val().length == 0) {
|
|
|
|
$("#error").empty().append("'.$this->l('La quantité n\'est pas renseignée').'");
|
|
|
|
return false;
|
|
|
|
}
|
2016-03-16 11:49:15 +01:00
|
|
|
|
|
|
|
$("#hidden_product_id").val($product_id);
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
type: \'POST\',
|
|
|
|
url: \''._MODULE_DIR_.'braderie/ajax.php?action=addToSellout'.'\',
|
|
|
|
dataType: \'json\',
|
2016-04-01 11:51:58 +02:00
|
|
|
data: {
|
|
|
|
parent_category: $("#sale").val(),
|
2016-03-16 11:49:15 +01:00
|
|
|
category: $("#category").val(),
|
|
|
|
storage: $("#input_storage").val(),
|
2016-03-16 18:05:41 +01:00
|
|
|
product: $("#hidden_product_id").val(),
|
2016-03-21 10:07:35 +01:00
|
|
|
quantity: $("#input_quantity").val(),
|
|
|
|
attribute: $("#hidden_attribute_id").val()
|
2016-03-16 11:49:15 +01:00
|
|
|
},
|
|
|
|
success: function(response) {
|
|
|
|
$("#error").empty().append(response);
|
2016-03-31 11:51:37 +02:00
|
|
|
$("#input_ean, #input_storage").val("");
|
2016-03-31 12:47:51 +02:00
|
|
|
$("#ean_from_product").empty();
|
2016-03-16 11:49:15 +01:00
|
|
|
},
|
|
|
|
error: function(xhr) {
|
|
|
|
$("#error").empty().append(JSON.parse(xhr.responseText));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
|
|
|
|
$("#show_current_category_button").click(function() {
|
|
|
|
$category = $("#category").val();
|
|
|
|
if ($category.length == 0) {
|
|
|
|
$("#error").empty().append("'.$this->l('Catégorie invalide').'");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
window.open("?tab=AdminCatalog&viewcategory&id_category=" + $category + "&token=" + $token, "_blank");
|
|
|
|
return false;
|
|
|
|
});
|
2016-03-31 12:47:51 +02:00
|
|
|
|
2016-03-16 11:49:15 +01:00
|
|
|
});
|
|
|
|
</script>';
|
|
|
|
echo $this->_html;
|
|
|
|
}
|
|
|
|
|
2016-03-31 11:51:37 +02:00
|
|
|
private function _buildHtmlCategoryBlock($categories, $small_titles)
|
2016-03-16 11:49:15 +01:00
|
|
|
{
|
|
|
|
global $cookie;
|
|
|
|
|
|
|
|
$token = Tools::getAdminToken('AdminBraderie'.(int)(Tab::getIdFromClassName('AdminBraderie')).(int)($cookie->id_employee));
|
|
|
|
|
|
|
|
$html = '
|
|
|
|
<style>
|
|
|
|
.chosen-container { width: 315px !important; }
|
|
|
|
.button-container input { margin: 10px 25px; }
|
|
|
|
#error, #ean_from_product { margin-left: 210px; }
|
|
|
|
#error { font-weight: bold; margin-bottom: 20px; color: #CC0000; }
|
|
|
|
</style>
|
|
|
|
<fieldset>
|
|
|
|
<legend>'.$this->l('Braderie').'</legend>';
|
|
|
|
if ($this->error) {
|
|
|
|
$html .= '<p class="margin-form" id="error">'.$this->error.'</p>';
|
|
|
|
} else {
|
|
|
|
$html .= '<p class="margin-form" id="error">'.$this->error.'</p>';
|
|
|
|
}
|
2016-03-31 12:47:51 +02:00
|
|
|
$html .= '<div class="margin-form">
|
|
|
|
<label>'.$this->l('Ventes').' : </label>
|
|
|
|
<select class="chosen-select" id="sale" name="sale">
|
|
|
|
<option value=""></option>';
|
|
|
|
|
|
|
|
foreach ($categories as $key => $value) {
|
|
|
|
$html .= '<option value="'.$value['id_category'].'">'.$value['id_category'].' - '.$value['name'].(!empty($small_titles[(int)$value['id_category']])?' - '.$small_titles[(int)$value['id_category']]:'').'</option>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$html .= ' </select>
|
|
|
|
</div>
|
|
|
|
<hr id="divider" style="display: none;">
|
|
|
|
<div class="margin-form" id="category_input_group" style="display: none;">
|
|
|
|
<label>'.$this->l('Catégories').' : </label>
|
|
|
|
<select class="chosen-select" id="category" name="category">
|
|
|
|
<option value=""></option>
|
|
|
|
</select>
|
|
|
|
<input type="submit" class="button" id="show_current_category_button" value="'.$this->l('Voir cette catégorie').'" style="margin-left: 20px; display: none">
|
|
|
|
</div>
|
|
|
|
<form id="formBraderie" action="?tab=AdminBraderie&token='.$token.'" method="POST">
|
2016-03-16 11:49:15 +01:00
|
|
|
<div class="margin-form" id="ean_input_group" style="display: none;">
|
|
|
|
<label>'.$this->l('Code EAN').' : </label>
|
|
|
|
<input type="text" name="ean" id="input_ean">
|
|
|
|
<p id="ean_from_product"></p>
|
|
|
|
</div>
|
|
|
|
<div class="margin-form" id="storage_input_group" style="display: none;">
|
|
|
|
<label>'.$this->l('Emplacement').' : </label>
|
|
|
|
<input type="text" name="storage" id="input_storage">
|
|
|
|
</div>
|
2016-03-16 18:05:41 +01:00
|
|
|
<div class="margin-form" id="quantity_input_group" style="display: none;">
|
|
|
|
<label>'.$this->l('Quantité').' : </label>
|
2016-03-31 11:51:37 +02:00
|
|
|
<input type="number" name="quantity" id="input_quantity" value="1">
|
2016-03-16 18:05:41 +01:00
|
|
|
</div>
|
2016-03-16 11:49:15 +01:00
|
|
|
<div class="margin-form button-container" id="button_input_group" style="display: none;">
|
|
|
|
<input type="submit" class="button" name="adminbraderie" value="'.$this->l('Ajouter').'" style="margin-left: 200px;" id="add_button">
|
2016-03-23 11:49:34 +01:00
|
|
|
<input type="submit" class="button" id="check_button" value="'.$this->l('Vérifier').'">
|
2016-03-16 11:49:15 +01:00
|
|
|
</div>
|
|
|
|
<input type="hidden" name="product" id="hidden_product_id">
|
2016-03-21 10:07:35 +01:00
|
|
|
<input type="hidden" name="attribute" id="hidden_attribute_id">
|
2016-03-16 11:49:15 +01:00
|
|
|
</form>
|
|
|
|
</fieldset>';
|
|
|
|
return $html;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|