* Copyright (C) 2017 Laurent Destailleur * Copyright (C) 2019 Frédéric France * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ require '../main.inc.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/product.lib.php'; require_once DOL_DOCUMENT_ROOT.'/product/class/product.class.php'; require_once DOL_DOCUMENT_ROOT.'/variants/class/ProductAttribute.class.php'; require_once DOL_DOCUMENT_ROOT.'/variants/class/ProductAttributeValue.class.php'; require_once DOL_DOCUMENT_ROOT.'/variants/class/ProductCombination.class.php'; require_once DOL_DOCUMENT_ROOT.'/variants/class/ProductCombination2ValuePair.class.php'; $langs->load("products"); $langs->load("other"); $var = false; $id = GETPOST('id', 'int'); $valueid = GETPOST('valueid', 'int'); $ref = GETPOST('ref', 'alpha'); $weight_impact = GETPOST('weight_impact', 'alpha'); $price_impact = GETPOST('price_impact', 'alpha'); $price_impact_percent = (bool) GETPOST('price_impact_percent'); $form = new Form($db); $action=GETPOST('action','alpha'); $massaction=GETPOST('massaction','alpha'); $show_files=GETPOST('show_files','int'); $confirm=GETPOST('confirm','alpha'); $toselect = GETPOST('toselect', 'array'); $cancel = GETPOST('cancel','alpha'); // Security check $fieldvalue = (! empty($id) ? $id : $ref); $fieldtype = (! empty($ref) ? 'ref' : 'rowid'); $result=restrictedArea($user,'produit|service',$fieldvalue,'product&product','','',$fieldtype); $prodstatic = new Product($db); $prodattr = new ProductAttribute($db); $prodattr_val = new ProductAttributeValue($db); $object = new Product($db); if ($id > 0 || $ref) { $object->fetch($id, $ref); } $selectedvariant = $_SESSION['addvariant_'.$object->id]; /* * Actions */ if ($cancel) { $action=''; $massactions=''; unset($_SESSION['addvariant_'.$object->id]); } if (! $object->isProduct() && ! $object->isService()) { header('Location: '.dol_buildpath('/product/card.php?id='.$object->id, 2)); exit(); } if ($action == 'add') { unset($selectedvariant); unset($_SESSION['addvariant_'.$object->id]); } if ($action == 'create' && GETPOST('selectvariant','alpha')) // We click on select combination { $action = 'add'; if (GETPOST('attribute') != '-1' && GETPOST('value') != '-1') { $selectedvariant[GETPOST('attribute').':'.GETPOST('value')]=GETPOST('attribute').':'.GETPOST('value'); $_SESSION['addvariant_'.$object->id]=$selectedvariant; } } $prodcomb = new ProductCombination($db); $prodcomb2val = new ProductCombination2ValuePair($db); $productCombination2ValuePairs1 = array(); if ($_POST) { if (($action == 'add' || $action == 'create') && empty($massaction) && ! GETPOST('selectvariant', 'alpha')) // We click on Create all defined combinations { //$features = GETPOST('features', 'array'); $features = $_SESSION['addvariant_'.$object->id]; if (!$features) { setEventMessage($langs->trans('ErrorFieldsRequired'), 'errors'); } else { $weight_impact = price2num($weight_impact); $price_impact = price2num($price_impact); $sanit_features = array(); //First, sanitize foreach ($features as $feature) { $explode = explode(':', $feature); if ($prodattr->fetch($explode[0]) < 0) { continue; } if ($prodattr_val->fetch($explode[1]) < 0) { continue; } // Valuepair $sanit_features[$explode[0]] = $explode[1]; $tmp = new ProductCombination2ValuePair($db); $tmp->fk_prod_attr = $explode[0]; $tmp->fk_prod_attr_val = $explode[1]; $productCombination2ValuePairs1[] = $tmp; } $db->begin(); // sanit_feature is an array with 1 (and only 1) value per attribute. // For example: Color->blue, Size->Small, Option->2 //var_dump($sanit_features); //var_dump($productCombination2ValuePairs1); exit; if (! $prodcomb->fetchByProductCombination2ValuePairs($id, $sanit_features)) { $result = $prodcomb->createProductCombination($object, $sanit_features, array(), $price_impact_percent, $price_impact, $weight_impact); if ($result > 0) { setEventMessage($langs->trans('RecordSaved')); unset($_SESSION['addvariant_'.$object->id]); $db->commit(); header('Location: '.dol_buildpath('/variants/combinations.php?id='.$id, 2)); exit(); } else { $langs->load("errors"); setEventMessages('', $prodcomb->errors, 'errors'); } } else { setEventMessages($langs->trans('ErrorRecordAlreadyExists'), null, 'errors'); } $db->rollback(); } } elseif (! empty($massaction)) { $bulkaction = $massaction; $error = 0; $prodstatic = new Product($db); $db->begin(); foreach ($toselect as $prodid) { if ($prodstatic->fetch($prodid) < 0) { continue; } if ($bulkaction == 'on_sell') { $prodstatic->status = 1; $res = $prodstatic->update($prodstatic->id, $user); } elseif ($bulkaction == 'on_buy') { $prodstatic->status_buy = 1; $res = $prodstatic->update($prodstatic->id, $user); } elseif ($bulkaction == 'not_sell') { $prodstatic->status = 0; $res = $prodstatic->update($prodstatic->id, $user); } elseif ($bulkaction == 'not_buy') { $prodstatic->status_buy = 0; $res = $prodstatic->update($prodstatic->id, $user); } elseif ($bulkaction == 'delete') { $res = $prodstatic->delete($user, $prodstatic->id); } else { break; } if ($res <= 0) { $error++; break; } } if ($error) { $db->rollback(); if ($prodstatic->error) { setEventMessages($prodstatic->error, $prodstatic->errors, 'errors'); } else { setEventMessages($langs->trans('CoreErrorMessage'), null, 'errors'); } } else { $db->commit(); setEventMessage($langs->trans('RecordSaved')); } } elseif ($valueid > 0) { if ($prodcomb->fetch($valueid) < 0) { dol_print_error($db, $langs->trans('ErrorRecordNotFound')); exit(); } $prodcomb->variation_price_percentage = $price_impact_percent; $prodcomb->variation_price = $price_impact; $prodcomb->variation_weight = $weight_impact; if ($prodcomb->update($user) > 0) { setEventMessage($langs->trans('RecordSaved')); header('Location: '.dol_buildpath('/variants/combinations.php?id='.$id, 2)); exit(); } else { setEventMessages($prodcomb->error, $prodcomb->errors, 'errors'); } } } // Reload variants $productCombinations = $prodcomb->fetchAllByFkProductParent($object->id); if ($action === 'confirm_deletecombination') { if ($prodcomb->fetch($valueid) > 0) { $db->begin(); if ($prodcomb->delete($user) > 0 && $prodstatic->fetch($prodcomb->fk_product_child) > 0 && $prodstatic->delete($user) > 0) { $db->commit(); setEventMessage($langs->trans('RecordSaved')); header('Location: '.dol_buildpath('/variants/combinations.php?id='.$object->id, 2)); exit(); } $db->rollback(); setEventMessage($langs->trans('ProductCombinationAlreadyUsed'), 'errors'); $action = ''; } } elseif ($action === 'edit') { if ($prodcomb->fetch($valueid) < 0) { dol_print_error($db, $langs->trans('ErrorRecordNotFound')); exit(); } $weight_impact = $prodcomb->variation_weight; $price_impact = $prodcomb->variation_price; $price_impact_percent = $prodcomb->variation_price_percentage; $productCombination2ValuePairs1 = $prodcomb2val->fetchByFkCombination($valueid); } elseif ($action === 'confirm_copycombination') { //Check destination product $dest_product = GETPOST('dest_product'); if ($prodstatic->fetch('', $dest_product) > 0) { //To prevent from copying to the same product if ($prodstatic->ref != $object->ref) { if ($prodcomb->copyAll($object->id, $prodstatic) > 0) { header('Location: '.dol_buildpath('/variants/combinations.php?id='.$prodstatic->id, 2)); exit(); } else { setEventMessage($langs->trans('ErrorCopyProductCombinations'), 'errors'); } } } else { setEventMessage($langs->trans('ErrorDestinationProductNotFound'), 'errors'); } } /* * View */ $form = new Form($db); if (! empty($id) || ! empty($ref)) { llxHeader("", "", $langs->trans("CardProduct".$object->type)); $showbarcode=empty($conf->barcode->enabled)?0:1; if (! empty($conf->global->MAIN_USE_ADVANCED_PERMS) && empty($user->rights->barcode->lire_advance)) $showbarcode=0; $head=product_prepare_head($object); $titre=$langs->trans("CardProduct".$object->type); $picto=($object->type== Product::TYPE_SERVICE?'service':'product'); dol_fiche_head($head, 'combinations', $titre, 0, $picto); $linkback = ''.$langs->trans("BackToList").''; $object->next_prev_filter=" fk_product_type = ".$object->type; dol_banner_tab($object, 'ref', $linkback, ($user->societe_id?0:1), 'ref', '', '', '', 0, '', '', 1); dol_fiche_end(); // Create or edit a varian if ($action == 'add' || ($action == 'edit')) { if ($action == 'add') { $title = $langs->trans('NewProductCombination'); print dol_fiche_head(); $features = $_SESSION['addvariant_'.$object->id]; //First, sanitize print '
'; if (! empty($features)) { foreach ($features as $feature) { $explode = explode(':', $feature); if ($prodattr->fetch($explode[0]) < 0) { continue; } if ($prodattr_val->fetch($explode[1]) < 0) { continue; } print '' . $prodattr->label . ':'. $prodattr_val->value . ' '; } } print '
'; print dol_fiche_end(); } else { $title = $langs->trans('EditProductCombination'); } print_fiche_titre($title); if ($action == 'add') { $prodattr_all = $prodattr->fetchAll(); if (!$selected) { $selected = $prodattr_all[key($prodattr_all)]->id; } $prodattr_alljson = array(); foreach ($prodattr_all as $each) { $prodattr_alljson[$each->id] = $each; } ?> '."\n"; print ''; print ''."\n"; print ''."\n"; if($valueid > 0) { print ''."\n"; } print dol_fiche_head(); ?>
'; print ''; foreach ($prodattr_all as $attr) { print ''; } print ''; } $htmltext=$langs->trans("GoOnMenuToCreateVairants", $langs->transnoentities("Product"), $langs->transnoentities("VariantAttributes")); print $form->textwithpicto('', $htmltext); /*print '     id).'">'; print $langs->trans("Create"); print '';*/ ?>
trans("GoOnMenuToCreateVairants", $langs->transnoentities("Product"), $langs->transnoentities("VariantAttributes")); print $form->textwithpicto('', $htmltext); /* print '     id).'">'; print $langs->trans("Create"); print ''; */ ?>
">

isProduct()) { print ''; print ''; print ''; print ''; } print '
$val) { $result1 = $prodattr->fetch($val->fk_prod_attr); $result2 = $prodattr_val->fetch($val->fk_prod_attr_val); if ($result1 > 0 && $result2 > 0) { print $prodattr->label . ' - '.$prodattr_val->value.'
'; // TODO Add delete link } } } ?>
>
'; } print dol_fiche_end(); ?>
value="trans('Create') : $langs->trans('Save') ?>" class="button">  
'; } else { if ($action === 'delete') { if ($prodcomb->fetch($valueid) > 0) { $prodstatic->fetch($prodcomb->fk_product_child); print $form->formconfirm( "combinations.php?id=".$id."&valueid=".$valueid, $langs->trans('Delete'), $langs->trans('ProductCombinationDeleteDialog', $prodstatic->ref), "confirm_deletecombination", '', 0, 1 ); } } elseif ($action === 'copy') { print $form->formconfirm( 'combinations.php?id='.$id, $langs->trans('CloneCombinationsProduct'), $langs->trans('ConfirmCloneProductCombinations'), 'confirm_copycombination', array( array( 'type' => 'text', 'label' => $langs->trans('CloneDestinationReference'), 'name' => 'dest_product' ) ), 0, 1 ); } $comb2val = new ProductCombination2ValuePair($db); if ($productCombinations) { ?> '; print '
'; if ($productCombinations) { print ''.$langs->trans('PropagateVariant').''; } print ''.$langs->trans('NewProductCombination').''; // NewVariant // Too much bugged page. /* print ''.$langs->trans('ProductCombinationGenerator').''; */ print '
'; print ''; $arrayofselected=is_array($toselect)?$toselect:array(); // List of variants print '
'; print ''; print ''; print ''; print ''; // List of mass actions available /* $arrayofmassactions = array( 'presend'=>$langs->trans("SendByMail"), 'builddoc'=>$langs->trans("PDFMerge"), ); if ($user->rights->product->supprimer) $arrayofmassactions['predelete']=$langs->trans("Delete"); if (in_array($massaction, array('presend','predelete'))) $arrayofmassactions=array(); $massactionbutton=$form->selectMassAction('', $arrayofmassactions); */ $aaa=''; if (count($productCombinations)) { $aaa = ''; $aaa .= ''; $aaa .= ''; } $massactionbutton = $aaa; $title = $langs->trans("ProductCombinations"); print_barre_liste($title, 0, $_SERVER["PHP_SELF"], '', $sortfield, $sortorder, $aaa, 0); print '
'; ?> isProduct()) print''; ?> '; $searchpicto=$form->showCheckAddButtons('checkforselect', 1); print $searchpicto; print ''; ?> fetch($currcomb->fk_product_child); ?> isProduct()) print ''; ?> '; if ($productCombinations || $massactionbutton || $massaction) // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined { $selected=0; if (in_array($prodstatic->id, $arrayofselected)) $selected=1; print ''; } print ''; ?> '; } ?>
trans('Product') ?> trans('Combination') ?> trans('PriceImpact') ?> '.$langs->trans('WeightImpact').'trans('OnSell') ?> trans('OnBuy') ?>
getNomUrl(1) ?> fetchByFkCombination($currcomb->id); $iMax = count($productCombination2ValuePairs); for ($i = 0; $i < $iMax; $i++) { echo dol_htmlentities($productCombination2ValuePairs[$i]); if ($i !== ($iMax - 1)) { echo ', '; } } ?> variation_price >= 0 ? '+' : '').price($currcomb->variation_price).($currcomb->variation_price_percentage ? ' %' : '') ?> '.($currcomb->variation_weight >= 0 ? '+' : '').price($currcomb->variation_weight).' '.measuring_units_string($prodstatic->weight_units, 'weight').'getLibStatut(2, 0) ?> getLibStatut(2, 1) ?>
'.$langs->trans("None").'
'; print ''; } } else { llxHeader(); // not found } llxFooter(); $db->close();