diff --git a/ChangeLog b/ChangeLog
index deebc026a70..15c66406cde 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -4,6 +4,7 @@ English Dolibarr ChangeLog
***** ChangeLog for 2.8 compared to 2.7 *****
For users:
+- New: task #9935: Can edit accountancy code.
- New: Add a default errors-to email for emailing module.
- New: Can filter on user on stock movement list.
- New: When creating a third party from a member, it is set as a new
diff --git a/htdocs/comm/fiche.php b/htdocs/comm/fiche.php
index 8cae18e30a9..5558e83b136 100644
--- a/htdocs/comm/fiche.php
+++ b/htdocs/comm/fiche.php
@@ -173,7 +173,7 @@ if ($socid > 0)
print '
| ';
print $langs->trans('CustomerCode').' | ';
print $objsoc->code_client;
- if ($objsoc->check_codeclient() <> 0) print ' ('.$langs->trans("WrongCustomerCode").')';
+ if ($objsoc->check_codeclient() <> 0) print ' ('.$langs->trans("WrongCustomerCode").')';
print ' |
';
}
diff --git a/htdocs/compta/fiche.php b/htdocs/compta/fiche.php
index 71d38c504ad..c90cd045a72 100644
--- a/htdocs/compta/fiche.php
+++ b/htdocs/compta/fiche.php
@@ -68,6 +68,35 @@ if ($mode == 'search')
}
+if ($_POST['action'] == 'setcustomeraccountancycode')
+{
+ $societe = new Societe($db);
+ $result=$societe->fetch($_POST['socid']);
+ $societe->code_compta=$_POST["customeraccountancycode"];
+ $result=$societe->update($societe->id,$user,1,1,0);
+ if ($result < 0)
+ {
+ $mesg=join(',',$societe->errors);
+ }
+ $POST["action"]="";
+ $socid=$_POST["socid"];
+}
+
+if ($_POST['action'] == 'setsupplieraccountancycode')
+{
+ $societe = new Societe($db);
+ $result=$societe->fetch($_POST['socid']);
+ $societe->code_compta_fournisseur=$_POST["supplieraccountancycode"];
+ $result=$societe->update($societe->id,$user,1,0,1);
+ if ($result < 0)
+ {
+ $mesg=join(',',$societe->errors);
+ }
+ $POST["action"]="";
+ $socid=$_POST["socid"];
+}
+
+
/*
@@ -94,8 +123,9 @@ if ($socid > 0)
*/
$head = societe_prepare_head($societe);
- dol_fiche_head($head, 'compta', $langs->trans("ThirdParty"),0,'company');
+ dol_fiche_head($head, 'compta', $langs->trans("ThirdParty"),0,'company'); // Add a div
+ if ($mesg) print $mesg;
print '';
print '| ';
@@ -107,25 +137,78 @@ if ($socid > 0)
// Prefix
print ' |
| '.$langs->trans("Prefix").' | ';
print ($societe->prefix_comm?$societe->prefix_comm:' ');
- print ' | ';
+ print '
';
if ($societe->client)
{
print '';
- print '| '.$langs->trans("CustomerCode"). ' | '. $societe->code_client . ' | ';
+ print ''.$langs->trans("CustomerCode").' | ';
+ print $societe->code_client;
+ if ($societe->check_codeclient() <> 0) print ' ('.$langs->trans("WrongCustomerCode").')';
+ print ' | ';
print '
';
+
print '';
- print '| '.$langs->trans("CustomerAccountancyCode").' | '.$societe->code_compta.' | ';
+ // TODO Use a html->editfield function
+ print '| ';
+ print $langs->trans("CustomerAccountancyCode");
+ print ' | ';
+ if ($_GET['action'] != 'editcustomeraccountancycode' && $user->rights->societe->creer) print 'id.'">'.img_edit($langs->trans('Edit'),1).' | ';
+ print ' ';
+ print ' | ';
+ if ($_GET['action'] == 'editcustomeraccountancycode')
+ {
+ print "\n".''."\n";
+ }
+ else print $societe->code_compta;
+ print ' | ';
+ // End editfield
print '
';
+
}
if ($societe->fournisseur)
{
print '';
- print '| '.$langs->trans("SupplierCode"). ' | '. $societe->code_fournisseur . ' | ';
+ print ''.$langs->trans("SupplierCode"). ' | ';
+ print $societe->code_fournisseur;
+ if ($societe->check_codefournisseur() <> 0) print ' ('.$langs->trans("WrongSupplierCode").')';
+ print ' | ';
print '
';
+
print '';
- print '| '.$langs->trans("SupplierAccountancyCode").' | '.$societe->code_compta_fournisseur.' | ';
+ // TODO Use a html->editfield function
+ print '| ';
+ print $langs->trans("SupplierAccountancyCode");
+ print ' | ';
+ if ($_GET['action'] != 'editsupplieraccountancycode' && $user->rights->societe->creer) print 'id.'">'.img_edit($langs->trans('Edit'),1).' | ';
+ print ' ';
+ print ' | ';
+ if ($_GET['action'] == 'editsupplieraccountancycode')
+ {
+ print "\n".''."\n";
+ }
+ else print $societe->code_compta_fournisseur;
+ print ' | ';
+ // End editfield
print '
';
}
@@ -147,7 +230,7 @@ if ($socid > 0)
print ''.$langs->trans("Fax").' | '.dol_print_phone($societe->fax,$societe->pays_code,0,$societe->id,'AC_FAX').' | ';
// EMail
- print ''.$langs->trans('EMail').' | '.dol_print_email($societe->email,0,$societe->id,'AC_EMAIL').' | ';
+ print '| '.$langs->trans('EMail').' | '.dol_print_email($societe->email,0,$societe->id,'AC_EMAIL').' |
';
// Web
print '| '.$langs->trans("Web").' | '.dol_print_url($societe->url,'_blank').' |
';
@@ -331,7 +414,9 @@ if ($socid > 0)
}
print "";
- print "
\n";
+ print "";
+
+ print "\n\n";
/*
diff --git a/htdocs/fourn/fiche.php b/htdocs/fourn/fiche.php
index 5a8943e0201..446151b1529 100644
--- a/htdocs/fourn/fiche.php
+++ b/htdocs/fourn/fiche.php
@@ -77,7 +77,7 @@ if ( $societe->fetch($socid) )
print '| ';
print $langs->trans('SupplierCode').' | ';
print $societe->code_fournisseur;
- if ($societe->check_codefournisseur() <> 0) print ' '.$langs->trans("WrongSupplierCode");
+ if ($societe->check_codefournisseur() <> 0) print ' ('.$langs->trans("WrongSupplierCode").')';
print ' |
';
}
diff --git a/htdocs/lib/company.lib.php b/htdocs/lib/company.lib.php
index 135297643b1..8b6fbafd89c 100644
--- a/htdocs/lib/company.lib.php
+++ b/htdocs/lib/company.lib.php
@@ -304,8 +304,9 @@ function show_contacts($conf,$langs,$db,$objsoc)
$user->fetch_clicktodial(); // lecture des infos de clicktodial
}
+ print "\n";
print_titre($langs->trans("ContactsForCompany"));
- print '';
+ print "\n".''."\n";
print '| '.$langs->trans("Name").' | ';
print ''.$langs->trans("Poste").' | '.$langs->trans("Tel").' | ';
@@ -378,7 +379,7 @@ function show_contacts($conf,$langs,$db,$objsoc)
//print ''.$langs->trans("NoContactsYetDefined").' | ';
//print "
\n";
}
- print "
\n";
+ print "\n
\n";
print "
\n";
}
@@ -403,6 +404,7 @@ function show_actions_todo($conf,$langs,$db,$objsoc,$objcon='')
$userstatic=new User($db);
$contactstatic = new Contact($db);
+ print "\n";
if (is_object($objcon) && $objcon->id) print_titre($langs->trans("TasksHistoryForThisContact"));
else print_titre($langs->trans("ActionsOnCompany"));
@@ -627,6 +629,7 @@ function show_actions_done($conf,$langs,$db,$objsoc,$objcon='')
$orderstatic=new Commande($db);
$facturestatic=new Facture($db);
+ print "\n";
print '\n";
+ print "
\n";
$db->free($result);
}
- print "\n";
- print "
\n";
}
?>
diff --git a/htdocs/lib/functions.lib.php b/htdocs/lib/functions.lib.php
index a1f62ec2c4d..56798912a36 100644
--- a/htdocs/lib/functions.lib.php
+++ b/htdocs/lib/functions.lib.php
@@ -373,7 +373,7 @@ function dol_fiche_head($links, $active='0', $title='', $notab=0, $picto='')
print "\n";
- if (! $notab) print ''."\n\n";
+ if (! $notab) print "\n".'
'."\n";
}
diff --git a/htdocs/soc.php b/htdocs/soc.php
index 19912748860..cbc52efff9e 100644
--- a/htdocs/soc.php
+++ b/htdocs/soc.php
@@ -71,6 +71,12 @@ if ((! $_POST["getcustomercode"] && ! $_POST["getsuppliercode"])
require_once(DOL_DOCUMENT_ROOT."/lib/functions2.lib.php");
$error=0;
+ if ($_POST["action"] == 'update')
+ {
+ // Load properties of company
+ $soc->fetch($socid);
+ }
+
if ($_REQUEST["private"] == 1)
{
$soc->particulier = $_REQUEST["private"];
@@ -227,6 +233,7 @@ if ((! $_POST["getcustomercode"] && ! $_POST["getsuppliercode"])
// To not set code if third party is not concerned. But if it had values, we keep them.
if (empty($soc->client) && empty($oldsoc->code_client)) $soc->code_client='';
if (empty($soc->fournisseur)&& empty($oldsoc->code_fournisseur)) $soc->code_fournisseur='';
+ //var_dump($soc);exit;
$result = $soc->update($socid,$user,1,$oldsoc->codeclient_modifiable(),$oldsoc->codefournisseur_modifiable());
if ($result >= 0)
@@ -343,7 +350,7 @@ $_GET["action"] == 'create' || $_POST["action"] == 'create')
$soc->tva_assuj = $_POST["assujtva_value"];
$soc->tva_intra=$_POST["tva_intra"];
-
+
$soc->commercial_id=$_POST["commercial_id"];
// On positionne pays_id, pays_code et libelle du pays choisi
@@ -695,7 +702,7 @@ elseif ($_GET["action"] == 'edit' || $_POST["action"] == 'edit')
$soc->tva_assuj = $_POST["assujtva_value"];
$soc->tva_intra=$_POST["tva_intra"];
-
+
// On positionne pays_id, pays_code et libelle du pays choisi
if ($soc->pays_id)
{
diff --git a/htdocs/societe.class.php b/htdocs/societe.class.php
index 8dcfe2b7da0..99d25294374 100644
--- a/htdocs/societe.class.php
+++ b/htdocs/societe.class.php
@@ -313,8 +313,8 @@ class Societe extends CommonObject
* \param id id societe
* \param user Utilisateur qui demande la mise a jour
* \param call_trigger 0=non, 1=oui
- * \param allowmodcodeclient Autorise modif code client
- * \param allowmodcodefournisseur Autorise modif code fournisseur
+ * \param allowmodcodeclient Inclut modif code client et code compta
+ * \param allowmodcodefournisseur Inclut modif code fournisseur et code compta fournisseur
* \return int <0 si ko, >=0 si ok
*/
function update($id, $user='', $call_trigger=1, $allowmodcodeclient=0, $allowmodcodefournisseur=0)
@@ -323,7 +323,7 @@ class Societe extends CommonObject
global $langs,$conf;
- dol_syslog("Societe::Update id=".$id." call_trigger=".$call_triger." allowmodcodeclient=".$allowmodcodeclient." allowmodcodefournisseur=".$allowmodcodefournisseur);
+ dol_syslog("Societe::Update id=".$id." call_trigger=".$call_trigger." allowmodcodeclient=".$allowmodcodeclient." allowmodcodefournisseur=".$allowmodcodefournisseur);
// Clean parameters
$this->id=$id;
@@ -361,10 +361,13 @@ class Societe extends CommonObject
//Gencod
$this->gencod=trim($this->gencod);
- // For automatic creation (not used by Dolibarr)
+ // For automatic creation
if ($this->code_client == -1) $this->get_codeclient($this->prefix_comm,0);
if ($this->code_fournisseur == -1) $this->get_codefournisseur($this->prefix_comm,1);
+ $this->code_compta=trim($this->code_compta);
+ $this->code_compta_fournisseur=trim($this->code_compta_fournisseur);
+
// Check name is required and codes are ok or unique.
// If error, this->errors[] is filled
$result = $this->verify();
@@ -419,7 +422,7 @@ class Societe extends CommonObject
$sql .= ", code_client = ".($this->code_client?"'".addslashes($this->code_client)."'":"null");
// Attention get_codecompta peut modifier le code suivant le module utilise
- $this->get_codecompta('customer');
+ if (empty($this->code_compta)) $this->get_codecompta('customer');
$sql .= ", code_compta = ".($this->code_compta?"'".addslashes($this->code_compta)."'":"null");
}
@@ -431,7 +434,7 @@ class Societe extends CommonObject
$sql .= ", code_fournisseur = ".($this->code_fournisseur?"'".addslashes($this->code_fournisseur)."'":"null");
// Attention get_codecompta peut modifier le code suivant le module utilise
- $this->get_codecompta('supplier');
+ if (empty($this->code_compta_fournisseur)) $this->get_codecompta('supplier');
$sql .= ", code_compta_fournisseur = ".($this->code_compta_fournisseur?"'".addslashes($this->code_compta_fournisseur)."'":"null");
}