diff --git a/htdocs/admin/dict.php b/htdocs/admin/dict.php
index abf62b51fa7..8b63c5842ba 100644
--- a/htdocs/admin/dict.php
+++ b/htdocs/admin/dict.php
@@ -2510,11 +2510,11 @@ function fieldList($fieldlist, $obj = '', $tabname = '', $context = '')
print '';
} elseif ($value == 'block_if_negative') {
print '
';
- print $form->selectyesno("block_if_negative", (!empty($obj->{$value}) ? $obj->{$value}:''), 1);
+ print $form->selectyesno("block_if_negative", (empty($obj->block_if_negative) ? '' : $obj->block_if_negative), 1);
print ' | ';
} elseif ($value == 'type_duration') {
print '';
- print $form->selectTypeDuration('', $obj->{$value}, array('i','h'));
+ print $form->selectTypeDuration('', (empty($obj->type_duration) ? '' : $obj->type_duration), array('i','h'));
print ' | ';
} else {
$fieldValue = isset($obj->{$value}) ? $obj->{$value}: '';
diff --git a/htdocs/societe/class/companybankaccount.class.php b/htdocs/societe/class/companybankaccount.class.php
index 26305bb0013..26a6169dbe6 100644
--- a/htdocs/societe/class/companybankaccount.class.php
+++ b/htdocs/societe/class/companybankaccount.class.php
@@ -35,6 +35,17 @@ class CompanyBankAccount extends Account
{
public $socid;
+ /**
+ * @var string ID to identify managed object
+ */
+ public $element = 'societe_rib';
+
+ /**
+ * @var string Name of table without prefix where object is stored
+ */
+ public $table_element = 'societe_rib';
+
+ /** @var bool $default_rib 1 = this object is the third party's default bank information */
public $default_rib;
/**
@@ -64,6 +75,13 @@ class CompanyBankAccount extends Account
*/
public $datem;
+ /**
+ * @var string TRIGGER_PREFIX Dolibarr 16.0 and above use the prefix to prevent the creation of inconsistently
+ * named triggers
+ * @see CommonObject::call_trigger()
+ */
+ const TRIGGER_PREFIX = 'COMPANY_RIB';
+
/**
* Constructor
@@ -86,7 +104,7 @@ class CompanyBankAccount extends Account
*
* @param User $user User
* @param int $notrigger 1=Disable triggers
- * @return int <0 if KO, >= 0 if OK
+ * @return int <0 if KO, > 0 if OK (ID of newly created company bank account information)
*/
public function create(User $user = null, $notrigger = 0)
{
@@ -97,6 +115,7 @@ class CompanyBankAccount extends Account
// Check paramaters
if (empty($this->socid)) {
$this->error = 'BadValueForParameter';
+ $this->errors[] = $this->error;
return -1;
}
@@ -114,6 +133,9 @@ class CompanyBankAccount extends Account
}
}
+
+ $this->db->begin();
+
$sql = "INSERT INTO ".MAIN_DB_PREFIX."societe_rib (fk_soc, type, datec)";
$sql .= " VALUES (".((int) $this->socid).", 'ban', '".$this->db->idate($now)."')";
$resql = $this->db->query($sql);
@@ -128,19 +150,20 @@ class CompanyBankAccount extends Account
$error++;
}
// End call triggers
-
- if (!$error) {
- return $this->id;
- } else {
- return 0;
- }
- } else {
- return 1;
}
}
} else {
+ $error++;
$this->error = $this->db->lasterror();
- return 0;
+ $this->errors[] = $this->error;
+ }
+
+ if (!$error) {
+ $this->db->commit();
+ return $this->id;
+ } else {
+ $this->db->rollback();
+ return -1;
}
}
@@ -168,6 +191,8 @@ class CompanyBankAccount extends Account
$this->owner_address = dol_trunc($this->owner_address, 254, 'right', 'UTF-8', 1);
}
+ $this->db->begin();
+
$sql = "UPDATE ".MAIN_DB_PREFIX."societe_rib SET";
$sql .= " bank = '".$this->db->escape($this->bank)."'";
$sql .= ",code_banque='".$this->db->escape($this->code_banque)."'";
@@ -203,20 +228,22 @@ class CompanyBankAccount extends Account
$error++;
}
// End call triggers
- if (!$error) {
- return 1;
- } else {
- return -1;
- }
- } else {
- return 1;
}
} else {
+ $error++;
if ($this->db->errno() == 'DB_ERROR_RECORD_ALREADY_EXISTS') {
$this->error = $langs->trans('ErrorDuplicateField');
} else {
$this->error = $this->db->lasterror();
}
+ $this->errors[] = $this->error;
+ }
+
+ if (!$error) {
+ $this->db->commit();
+ return 1;
+ } else {
+ $this->db->rollback();
return -1;
}
}
diff --git a/htdocs/societe/paymentmodes.php b/htdocs/societe/paymentmodes.php
index d1dafde4622..0166a3a5635 100644
--- a/htdocs/societe/paymentmodes.php
+++ b/htdocs/societe/paymentmodes.php
@@ -183,8 +183,10 @@ if (empty($reshook)) {
$companybankaccount->stripe_card_ref = GETPOST('stripe_card_ref', 'alpha');
$result = $companybankaccount->update($user);
- if (!$result) {
+ if ($result <= 0) {
+ // Display error message and get back to edit mode
setEventMessages($companybankaccount->error, $companybankaccount->errors, 'errors');
+ $action = 'edit';
} else {
// If this account is the default bank account, we disable others
if ($companybankaccount->default_rib) {